

Electronic Devices Division data catalog


R6500
MEMORY I/O COMBOS

AIM 65
MICROCOMPUTER

RM 65
BOARD PRODUCTS

# Electronic Devices Division Data Catalog 

SYSTEM 65 DEVELOPMENT SYSTEM

NMOS
MEMORY PRODUCTS

R68000
16-BIT $\mu$ P PRODUCTS

PPS-4/1 PMOS $\mu \mathrm{Cs}$

INTEGRAL MODEMS

TELECOM DEVICES

FILTER PRODUCTS

## TABLE OF CONTENTS

R6500 NMOS $\mu$ Ps \& $\mu$ Cs
R6500 Brochure
R6500 CPUs
R6500/1 One-Chip Microcomputer
R6500/1E Emulator Device
R6500/1EB Backpack Emulator
R6500/1-11 One-Chip Microcomputer
R6500/1-11Q One-Chip Microcomputer
R6500/2-11 Extended Microprocessor
R6500 I/O DEVICES
R6520 Peripheral Interface Adapter (PIA)
R6522 Versatile Interface Adapter (VIA)
R6545-1 CRT Controller (CRTC)
R6551 Asynchronous Communication Interface Adapter (ACIA)
R6592 Single-Chip Printer Controller
R6500 MEMORY-1/O COMBOS
R6530 ROM-RAM-I/O-Timer (RRIOT)
R6531 ROM-RAM-I/O-Counter (RRIOC)
R6532 RAM-I/O-Timer (RIOT)
AIM 65 MICROCOMPUTER
AIM 65 Brochure
AIM 65 Expansion Motherboard
AIM 65 PROM Programmer \& CO-ED
Forth Language for AIM 65
PL/65 Language for AIM 65
RM 65 BOARD PRODUCTS
RM 65 Brochure
Single Board Computer (SBC) Module
Floppy Disk Controller (FDC) Module
Asynchronous Communications Interface Adapter (ACIA) Module
General Purpose Input/Output (GPIO) \& Timer Module
IEEE-488 Bus Interface Module
8K Static RAM Module
32K Dynamic RAM Module
16K PROM/ROM Module
Single-Card Adapter
Adapter/Buffer
Cable Driver Adapter/Buffer
Design Prototyping Module
Extender Module
4-Slot Piggyback Module Stack (PMS)
8-Slot Card Cage
16-Slot Card Cage
SYSTEM 65 DEVELOPMENT SYSTEM
System 65 Brochure
USER 65 Option Module
R6500/1 Evaluation Module
16K Static RAM Module
PROM Programmer Module
16K PROM/ROM Module
Design Prototyping Module
Extender Module
R6500 Macro Assembler and Linking Loader
PL/65 Language for System 65

## NMOS MEMORY PRODUCTS

R2316 $2048 \times 8$ Static ROMs
R2332 $4096 \times 8$ Static ROMs
R2332-xL $4096 \times 8$ Low-Power Static ROMs
R2364A $8192 \times 8$ Static ROMs
R2364B $8192 \times 8$ Static ROMs
R8104/R8114 $1024 \times 8$ Static RAMs

## R68000 16-BIT $\mu$ P PRODUCTS

R68000 Microprocessing Unit
R68120 Intelligent Peripheral Controller (IPC)
R68451 Memory Management Unit (MMU)
R68450 DMA Controller (DMAC)
R68561 Multi-Protocol Communications Controller (MPCC)

## PPS-4/1 PMOS $\mu$ Cs

PPS-4/1 Brochure
MM75 Microcomputer
MM76EL Low-Power Microcomputer
MM78 Microcomputer
MM78L Low-Power Microcomputer
MM78LA Low-Power Microcomputer
Serial Communication Protocol for Multiple PPS-4/1 Systems
Using PPS-4/1 to Operate a Liquid Crystal Display

## INTEGRAL MODEMS

R24 2400 BPS Modular Modem
R24 DC 2400 BPS Direct Connect Modem V96P/1 Multi-Configuration 9600 BPS Modem

## TELECOM DEVICES

MOS/LSI Telecommunication Products Flyer CRC8000,8001 Binary to Dial Pulse Dialer CRC8030 Dual Tone Multi-Frequency Detector
R8040 T-1 Tri-Port Memory
R8050 T-1 Serial Transmitter
R8060 T-1 Serial Receiver

## FILTER PRODUCTS

Rockwell-Collins Disc Wire Mechanical Filters Collins Low Frequency Mechanical Filters
Collins USB-LSB-AM Mechanical Filters
F455FD Low-Cost Mechanical Filters
Disc Wire Mechanical Filters Standard Products
Low Frequency Narrowband Mechanical Filters Standard Products

R6500
NMOS $\mu$ Ps \& $\mu$ Cs


MICROCOMPUTERSYSTEM


## The R6500 Fomily

## R6500 Family

A family of 10 software-compatible CPUs and 11 I/O, ROM, RAM and one-chip memory-I/O-timer circuits operating at proven 1 MHz and 2 MHz speeds with a single 5 V power supply, provides you with economic system solutions for a broad range of applications.

The R6500/1 provides you with CPU, ROM, RAM, interrupts, counter and bi-directional data ports on a single chip. And it's totally software compatible with all other members of the R6500 family.

The R6500 promises you boosted performance and improved economics through its third generation architecture, which includes 13 powerful addressing modes, and its innovative circuit design and processing technology which reduce chip size and power consumption.


## Rockwell is solidly backing the R6500

Rockwell has dedicated facilities for the high volume manufacturing of R6500 circuits produced with its own depletion load, silicon-gate N -channel process

And Rockwell provides complete system development support: Rockwell's SYSTEM 65, a floppy-disk based, powerful yet low-cost complete development system. Plus AIM 65, TIM or timesharing program, complete documentation and extensive applications engineering support.

For the future, Rockwell is developing new R6500 devices that will enhance your own product development opportunities.

Rockwell's R650X CPU options offer a selection of features in 40 - and 28 -pin versions to meet your system needs (see table below). The R6502-R6507 Series has on-chip clock generation. The R6512-R6515 Series allows the user to generate and control the clock externally.

## R6500 CPU Options

## Why the R6500 is a cost performance winner

- Proven 1 MHz or 2 MHz performance
- Pipeline architecture for fast operation with fewer cycles
- Single 5 -volt power supply
- On-the-chip clock or an external clock
- 56 instructions
- 13 addressing modes and true indexing capability
- Decimal/binary arithmetic mode selection
- Bi-directional Data Bus (compatible with the MC 6800)
- Addressable memory range up to 65 K bytes
- Multi-level interrupts - maskable/non-maskable
- Use with any type or speed memory
- Programmable stack pointer and variable length stack
- 40- and 28-pin DIP package options

|  | 40-Pin DIP |  | 28-Pin DIP |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | R6502 | R6512 | $\begin{aligned} & \text { R6503 } \\ & \text { R6513 } \end{aligned}$ | $\begin{aligned} & \text { R6504 } \\ & \text { R6514 } \end{aligned}$ | $\begin{aligned} & \text { R6505 } \\ & \text { R6515 } \end{aligned}$ | R6506 | R6507 |
| Memory Address Space | 65 K | 65K | 4K | 8K | 4K | 4 K | 8K |
| Interrupts-Maskable <br> - Non-Maskable | $\begin{aligned} & \text { Yes } \\ & \text { Yes } \end{aligned}$ | $\begin{aligned} & \text { Yes } \\ & \text { Yes } \end{aligned}$ | Yes Yes | $\begin{aligned} & \text { Yes } \\ & \text { No } \end{aligned}$ | $\begin{aligned} & \text { Yes } \\ & \text { No } \end{aligned}$ | $\begin{aligned} & \text { Yes } \\ & \text { No } \end{aligned}$ | $\begin{aligned} & \text { No } \\ & \text { No } \end{aligned}$ |
| SYNC-Output indicates op code fetch cycle | Yes | Yes | No | No | No | No | No |
| RDY - Single step and slow memory synchronization | Yes | Yes | No | No | Yes | No | Yes |
| $\emptyset_{1}$ Clock Output | Yes | Yes | No | No | No | Yes | No |
| DBE-Extended Data Bus Hold Time | No | Yes | No | No | No | No | No |

The 40-pin versions provide full functional capability for memory intensive systems with extensive I/O requirements. The 28-pin versions offer flexibility in
selecting the lowest cost CPU best suited to your application. 28-pin packages also provide denser board layout.

## Thirteen addressing modes + true indexing $=$ R6500 software power

The R6500 features 13 addressing modes. The first byte of each instruction is the operation code specifying both the instruction and the addressing mode. The addressing modes are summarized below.

- ACCUMULATOR ADDRESSING - A one byte instruction, operating on the accumulator.
- IMMEDIATE ADDRESSING - The operand is in the second byte of the instruction.
- ABSOLUTE ADDRESSING - The second and third bytes of the instruction specify the effective address in 65 K bytes of addressable memory.
- ZERO PAGE ADDRESSING - Allows shorter code and execution times by assuming a zero page address.
- INDEXED ZERO PAGE ADDRESSING ( $X$ or $Y$, indexing.) - Zero page addressing used with an index register.
- INDEXED ABSOLUTE ADDRESSING ( $X$ or $Y$, in dexing) - Absolute addressing used with $X$ or $Y$ index registers.
- IMPLIED ADDRESSING - The register containing the operand is implicitly stated in the operation code.
- RELATIVE ADDRESSING - Used only with branch instructions. The second byte is an "Offset" added to the contents of the program counter.
- INDEXED INDIRECT ADDRESSING - Uses an indirect zero page address indexed by $X$ to fetch the effective address.
- INDIRECT INDEXED ADDRESSING - Uses a zero page address to fetch the effective base address to be indexed by $Y$.
- ABSOLUTE INDIRECT - Used only with JMP. the second and third bytes point to a two-byte effective address.


## R6500 Microprocessor Instiruction Set



## R6500/4 Onerehip Microcompueer

## The R6500/1

In the R6500/1, Rockwell has combined the highperformance R6502 CPU with such versatile features as 2048 bytes of ROM, 64 bytes of RAM, 32 bi-directional I/O lines, four interrupts and a 16-bit programmable counter (with four separate interval/event modes) - all in a single 40-pin package.

The R6500/1 also has on-the-chip 1 MHz or 2 MHz clock operation with external single clock, crystal or RC frequency input.

The R6500/1 includes a separate power pin that maintains RAM on $10 \%$ of the operating power. In the event power is lost, this standby power retains RAM data until execution is resumed.

Rockwell backs up the R6500/1 with solid system development support in two ways:

The R6500/1E, a 64-pin emulator device with 40 pins electrically identical to the R6500/1, may be used for program development and prototyping with external EPROM or RAM

A Personality option to SYSTEM 65 customizes Rockwell's popular microcomputer development system for complete R6500/1 software and hardware development.

## R6500/1 Features

- 2K-Byte Mask Programmable ROM
- 64-Byte Static RAM
- R6502 CPU
- Four 8-Bit Bidirectional I/O Ports
- 16-Bit Programmable Counter/Latch With Four Modes:
- Interval Timer
- Pulse Generator
- Event Counter
- Pulse Width Measurement
- Five Interrupts
- Fully Upward/Downward Compatible With 6500 Family
- 64-Pin PROM-compatible Emulator Device Available



## 

The R6500 system bus enables you to use low cost, widely available standard memory devices. For your convenience, Rockwell now offers the five memory devices. described below. All are completely TTL compatible, fully static - no clocks or refresh strobes required - and operate from a single +5 V power supply

- R21144K STATIC RAM
$1024 \times 4$ in high-density 18 -pin package with common data I/O: 450 ns access and cycle time; fully static - no clocks or strobes required; single +5 V power supply; total TTL compatibility. (Industry standard.)
- R2316B 16K STATIC ROM
$2048 \times 8$ in standard 24-pin package; pin-compatible with 2708 EPROM; 450 ns. max. cycle time; three chip selects. (Industry standard; replaces two 8K EPROMs.)
- R2332 32K STATIC ROM

The industry's first static $4096 \times 8 \mathrm{~N}$-channel ROM; standard 24-pin package; 450 ns . max. cycle time; two chip selects.

## - R2332-3 32K STATIC ROM

Same as R2332, but has 300 ns. max. cycle time.


## 【ロคu§|Output Devi̊ces

## General-Purpose I/O Devices

These versatile peripheral controllers allow effective trade-offs between software and hardware, enabling implementation of complex R6500 microcomputer systems at minimum overall cost. Both are available in 1 MHz and 2 MHz versions. All R6500 I/O devicesincluding the memory-I/O combos-have TTL and CMOS compatible peripheral lines with transistor drive capability and high-impedance, tri-state data outputs.

## - R6520 Peripheral Interface Adapter (PIA)

40-pin package, two 8-bit bi-directional I/O ports, four peripheral control/interrupt input lines. fully automatic data transfers between processor and peripheral devices.

The PIA provides individual I/O line control for keyboard strobes and returns, driving displays and discrete indicators as well as 8 -bit parallel communications in handshake or clocked control modes.

- R6522 Versatile Interface Adapter (VIA)

40-pin package, has R 6520 PIA features plus two 16-bit programmable interval timers/counters. data latching on I/O ports, 8 -bit buffered shift register for serial l/O interfacing.
The enhanced features of the VIA provide a serial interface for inter-system communications, ASCII serial data generation, pulse width modulation, and waveform synthesis. The two timers work in conjunction with the serial channel or may provide interval timing for real time applications.

## Memory.I/O-Timer Combination Devices

By combining an R650X Series CPU with one-chip memory, I/O and timer combination devices, the designer nets a powerful, cost-effective two chip microcomputer system which can also be the base configuration for modular. expandable applications.

- R6530 ROM-RAM-I/O-Timer (RRIOT) 40-pin package: 1 MHz operation; $1024 \times 8$ ROM; $64 \times$ 8 static RAM; two 8 -bit bi-directional data $1 / \mathrm{O}$ ports; two progammable data direction registers; programmable 8-bit interval timer with prescale and interrupt control.
- R6531 ROM-RAM-I/O-Counter (RRIOC) 40-pin package; 1 MHz or 2 MHz operation; $2048 \times 8$ ROM; $128 \times 8$ static RAM; 8 -bit serial data channel; two bi-directional I/O ports, with a total of 15 data lines, including four external interrupts and handshake control.

The RRIOC also provides a fully-buffered 16 -bit counter/timer with four program selectable modes interval timer, pulse generator, event counter and pulse width measurement.

A separate 52-pin version of RRIOC offers expanded I/O in additional 8 -bit output port and 4-bit input port.

- R6532 RAM-I/O-Timer (RIOT)

40-pin package; 1 MHz operation; $128 \times 8$ static RAM; two 8 -bit bi-directional data ports; two programmable data direction registers; programmable 8-bit interval timer with prescale and interrupt control; programmable edge detect interrupt, for fast service of critical events.

- R6534 ROM-I/O-Counter (RIOC)

40-pin package; 1 MHz operation; $4096 \times 8$ ROM; 8 -bit serial data channel; two bi-directional data l/O ports, with a total of 14 data lines, including four external interrupts and handshake control.

The RIOC also provides a programmable 16 -bit counter/latch with interval timer, pulse generator and event counter modes.
A separate 52-pin version of RIOC offers an additional 8 -bit output port, 3-bit input port and one additional I/O line.

## Intelligent Peripheral Controller Devices

The devices listed below get your interface design off to a solid start.

- R6541 Programmable Keyboard/Display Controller (PKDC)
40-pin package, 8-character FIFO/Sensor RAM for keyboard entries, two CPU-addressable 16-byte display RAMs.

The PKDC is a general-purpose keyboard and segmented display interface device. The keyboard portion can scan up to 128 matrix-type key switches, and can also interface with an array of 64 sensors or a strobed interface keyboard. The display portion provides a
buffered scanned display interface with LED, fluorescent, Borroughs SELF-SCAN ${ }^{\circledR}$, and other display technologies.

## - R6545 CRT Controller (CRTC)

40-pin package, refresh RAM, fully-programmable scanning and cursor, light pen register.
The CRTC is designed to interface an 8 -bit microprocessor to CRT raster scan video displays. It 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. Refresh memory may be addressed in either straight binary or by row/column.

## Communications Interface Device

## - R6551 Asynchronous Communication Interface Adapter (ACIA)

28-pin package provides the interface between R6500based systems and serial communication data sets and modems. With its on-chip baud rate generator, the

ACIA is capable of transmitting at 15 different programselectable rates between 50 baud and 19,200 baud, and receiving at either the transmit rate or at 16X an external clock rate.

The ACIA has programmable word lengths of $5,6,7$ or 8 bits; even, odd or no parity; 1, 1-1/2 or 2 stop bits.

$\%$

## Rockwell's SYSTEM 65

SYSTEM 65 is a new easy to use, powerful, complete development system for the R6500 family of microcomputers. The basic configuration includes two built-in, mini-floppy disk drives, 16 K bytes of user memory and 16 K bytes of resident operating system. .

Monitor commands are self-prompting whenever memory, peripheral, or disk file assignment is required. Text editor provides line, string, and character editing functions. A resident two-pass assembler and dynamic debug package complete the operating system. Both source and object code may be maintained in memory for fast editing, assembling, and checkout. Since the total monitor, editor, debug and assembler are resident in ROM, $100 \%$ of the disk storage and drive utilization is available to the user.

The mini-floppy diskettes may be used as storage for source and object code and documentation. Each diskette has the capacity for 78 K bytes of information in a maximum of 60 files.

SYSTEM 65 supports a vareity of terminals with serial data from 100 baud to 9600 baud. Connectors are provided for both RS-232 C and current loop interfacing. Reader ON/OFF signals and RTS/CTS control signals are standard. Included is a parallel port providing automatic control to high speed printers, such as Diablo, Centronics and Tally.

## And Rockwell offers these options to SYSTEM 65:

- PL/65 High-Level Language
- USER 65 in-circuit emulation option
- PROM Programmer Module, for programming a 2704/2708/2716/2758 PROM device from the front panel socket
- R6500/1 Personality option, for developing with the R6500/1 single-chip microcomputer
- $16 \mathrm{~K} \times 8$ Static RAM Modules
- PROM/ROM Module. accepts 2316/2332 ROM or 2708/2716/2758 PROM devices
- Wire-wrap Design Prototyping Module
- Extender Card for circuit probing


## PL/65 High-Level Language

A high-level language resembling PL/1 and ALGOL is now available to designers developing programs for the R6500 microprocessor family using the SYSTEM 65 development system.

Designated PL/65, the language is considerably easier to use than assembly language or object code, thus increasing programmer productivity while reducing software development time and costs. The PL/65 compiler outputs source code to the SYSTEM 65's resident assembler. This permits enhancing or debugging at the assembler level before object code is generated. In addition, PL/65 statements may be mixed with assembly language instructions for timing or code optimization.

The PL/65 compiler is available to SYSTEM 65 users as a preprogrammed mini-floppy diskette. No additional memory is required other than the standard 16 K bytes of RAM.

The PL/65 language supports modular program design. Its general control structures for conditional and iterative looping allow the language to be used effectively for structured programs. Other language features include: assignment, integer arithmetic, conditional execution, collective execution, linear array manipulation, data area declaration and array initialization. Block structures, subscripts and parenthetical expressions are also supported.

## For learning, designing, work or just plain fun. ...



Rockwell's R6500 Advanced Interactive Microcomputer (AIM 65) can get you into the exciting world of microcomputers a lot easier and at a lot lower cost than you may have thought possible.

As a learning aid, AIM 65 gives you an assembled, tested and warranted R6502-based microcomputer system with a full-sized keyboard, an alphanumeric 20character display and, uniquely, an alphanumeric 20column thermal printer.

An on-board Advanced Interactive Monitor program provides extensive control and program development
functions. You'll be writing your programs in assembly language - there's no need to memorize "opcodes". And for more specialized applications, we offer a twopass, symbolic assembler and a BASIC interpreter as plug-in ROM options.

You'll master fundamentals rapidly. Then you'll appreciate the fact that unlike the computer "toys' on the market, AIM 65 offers flexibility and expandability you would expect to find only in a sophisticated microcomputer development system.

How to make it all work for you
Rockwell has put together a complete set of documentation and reference manuals to help you implement the R6500 microprocessor family.

## - R6500 Hardware Manual

A detailed description of each chip in the family, how they interface, how the peripherals are controlled, as well as the design techniques facilitating system operation, testing and maintenance. Special emphasis is on 'bringing up' a system with testing techniques, scope synchronizing and general trouble-shooting procedures - \$5.

- R6500 Programming Manual

Defines the architecture of the R6500 Series, the function of each instruction and valuable programming information. Special emphasis is on the sophisticated addressing modes of the family - $\$ 5$.

- Cross-Assembler Manual

Cross-Assembler directives are described as used in time-share and batch operations, with special aids on understanding and resolving error messages - \$5.

- SYSTEM 65 User's Manual Instructs the user in operating the SYSTEM 65 Microcomputer Development System and its application in developing a working microprocessor system - $\$ 5$.
- PL/65 User's Manual

A complete guide to PL/65, the high-level language for the R6500 family - $\$ 10$.

- AIM 65 User's Guide

Full technical details tell you everything you need to operate the AIM 65 - $\$ 5$.

- AIM 65 BASIC Language Reference Manual A how-to guide for using AIM 65 with the BASIC language ROM option installed-\$5.
- TIM Manual

Defines how to apply the Teletype I/O Monitor - \$2.

- R6500 Data Sheets

Provides quick understanding of the capabilities and characteristics of each available R6500 device and support equipment. To order data sheets simply specify the part number or the name of the support equipment.

## Where to get more on the R6500

Rockwell's normal procedure is to provide you with free data sheets so that you can select the R6500 devices and support equipment of most interest to you. A nominal charge is made for reference manuals.

For data, devices or support equipment contact the nearest Rockwell office or distributor listed on the back page of this brochure. For in-depth assistance, obtain the name of your nearest Rockwell sales representative from any Rockwell office.

## R6500 MICROPROCESSORS (CPU's)

## SYSTEM ABSTRACT

The 8-bit R6500 mierocomputer system is produced with N Channel, Silicon Gate technology. Its performance speeds are enhanced by advanced system architecture. This innovative architecture results in smaller chips - the semiconductor threshold to 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 memory and microcomputer system . . . as well as low-cost design aids and documentation.

## R6500 MICROPROCESSOR (CPU) CONCEPT

Ten CPU devices are available. All are software-compatibie. 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 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 MHz and 2 MHz ) and temperature (commercial, industrial and military) versions.

MEMBERS OF THE R6500 MICROPROCESSOR (CPU) FAMILY

Microprocessors with On-Chip Clock Oscillator

| Model | Addressable Memory |
| :---: | :---: |
|  |  |
| R6502 | $65 K$ Bytes |
| R6503 | 4K Bytes |
| $R 6504$ | $8 K$ Bytes |
| $R 6505$ | $4 K$ Bytes |
| R6506 | $4 K$ Bytes |
| R6507 | $8 K$ Bytes |

Microprocessors with External Two Phase Clock Output

| Model | Addressable Memory |
| :---: | ---: |
| R6512 |  |
| R6513 | $65 K$ Bytes |
| R6514 | $4 K$ Bytes |
| R65:5 | 8K Bytes |
|  | $4 K$ Bytes |

## FEATURES

- Single +5 V supply
- $\mathbf{N}$ channel, silicon gate, depletion load technology
- Eight bit parallel processing
- 56 Instructions
- Decimal and binary arithmetic
- Thirteen addressing modes
- True indexing capability
- Programmable stack pointer
- Variable length stack
- Interrupt capability
- Non-maskable interrupt
- Use with any type of speed memory
- 8-bit Bidirectional Data Bus
- Addressable memory range of up to 65K bytes
- "Ready" input
- Direct Memory Access capability
- Bus compatible with M6800
- 1 MHz and 2 MHz operation
- Choice of external or on-chip clocks
- On-the-chip clock options
- External single clock input
- RC time base input
- Crystal time base input
- Commercial, industrial and military temperature versions
- Pipeline architecture

Ordering Information
Order Number:


No suffix $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ $E=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Industrial)
MT $=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$ (Military)
$M=$ MILSTD-883,
Class B
C $=$ Ceramic
P = Plastic
(Not Avaible for
M or MT suffix)
Frequency Range:
No suffix $=1 \mathrm{MHz}$
$A=2 \mathrm{MHz}$
Designator:
$X X=02,03,04, \ldots 15$
NOTE: Contact your local Rockwell Representative concerning availability.

## R6500 Signal Description

## Clocks ( $\phi_{1}, \phi_{2}$ )

The R651X requires a two phase non-overlapping clock that runs at the $V_{C C}$ voltage level.
The R650X clocks are supplied with an internal clock generator. The frequency of these clocks is externally controlled.

## Address Bus (A0.A15)

These outputs are TTL compatible, capable of driving one standard TTL load and 130 pF .

## Data Bus (D0-D7)

Eight pins are used for the data bus. This is a bidirectional bus, transferring data to and from the device and peripherals. The outputs are tri-state buffers capable of driving one standard TTL load and 130 pF .

## Data Bus Enable (DBE)

This TTL compatible input allows external control of the tri-state data output buffers and will enable the microprocessor bus driver when in the high state. In normal operation DBE would be driven by the phase two $\left(\phi_{2}\right)$ clock, thus allowing data output from microprocessor only during $\boldsymbol{\phi}_{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)

This input signal allows the user to hatt or single cycle the microprocessor on all cycles except write cycles. A negative transition to the low state during or coincident with phase one $\left(\phi_{1}\right)$ will halt the microprocessor with the output address lines reflecting the current address being fetched. If Ready is low during a write cycte, it is ignored until the following read operation. This condition will remain through a subsequent phase two $\left(\phi_{\mathbf{2}}\right)$ in which the Ready signal is low. This feature allows microprocessor interfacing with the low speed PROMs as well as fast (max. 2 cycle) Direct Memory Access (DMA).

## Interrupt Request ( $\overline{\mathbf{R O}}$ )

This TTL level 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 Status Code 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 storcd in the stack. The microprocessor will then set the interrupt mask flag high so that no further interrupts may 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 (NMI)

A negative going edge on this input requests that a non-maskable interrupt sequence be generated within the microprocessor.
$\overline{\text { NMI }}$ is an unconditional interrupt. Following completion of the current instruction, the sequence of operations defined for IRO 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{N M I}$ also requires an external $3 \mathrm{~K} \Omega$ register to $\mathrm{V}_{\mathbf{C C}}$ for proper wire-OR operations.
Inputs $\overline{\mathrm{RO}}$ and $\overline{\mathrm{NMI}}$ are hardware interrupts lines that are sampled during $\phi_{2}$ (phase 2) and will begin the appropriate interrupt routine on the $\phi_{1}$ (phase 1) following the completion of the current instruction.

## Set Overflow Flag (S.O.)

A negative going edge on this input sets the overflow bit in the Status Code Register. This signal is sampled on the trailing edge of $\phi 1$ and must be externally synchronized.

## SYNC

This output line is provided to identify those cycles in which the microprocessor is doing an OP CODE fetch. The SYNC line goes high during $\phi_{1}$ of an OP CODE fetch and stays high for the remainder of that cycle. If the RDY line is pulled low during the $\phi_{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

This input is used to reset or start the microprocessor from a power down 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 will be set and the microprocessor will load 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) signal will become valid.
When the reset signal goes high following these two clock cycles, the microprocessor will proceed with the normal reset procedure detailed above.

## ADDRESSING MODES

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

IMMEDIATE ADDRESSING - In immediate addressing, the operand is contained in the second byte of the instruction, with no further memory addressing required.

ABSOLUTE ADDRESSING - 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 65 K bytes of addressable memory.

ZERO PAGE ADDRESSING - The zero page instructions allow for shorter code and execution times by only fetching 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 - ( $\mathrm{X}, \mathrm{Y}$ indexing) - This form of addressing is used in conjunction 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 8 bits of memory and crossing of page boundaries does not occur.

INDEXED ABSOLUTE ADDRESSING - ( $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 multiple fields resulting in reduced coding and execution time.

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

RELATIVE ADDRESSING - 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.

INDEXED INDIRECT ADDRESSING - 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 is 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 - 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 is 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 resutt being the high order eight bits of the effective address.

ABSOLUTE INDIRECT - 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 is contained in the third byte of the instruction. The contents of the fully specified memory location is the low order byte of the affective 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.

INSTRUCTION SET - ALPHABETIC SEQUENCE

ADC Add Memory to Accumulator with Carry
AND "AND" Memory with Accumulator
ASL Shift left One Bit (Memory or Accumulator)
BCC Branch on Carry Clear
BCS Branch on Carry Set
BEQ Branch on Result Zero
BIT Test Bits in Memory with Accumulator
BMI Branch on Result Minus
BNE Branch on Result not Zero
BPL Branch on Result Plus
BRK Force Break
BVC Branch on Overflow Clear
BVS Branch on Overflow Set

CLC Clear Carry Flag
CLD Clear Decimal Mode
CLI Clear Interrupt Disable Bit
CLV Clear Overflow Flag
CMP Compare Memory and Accumulator
CPX Compare Memory and Index X
CPY Compare Memory and Index $Y$

DEC Decrement Memory by One
DEX Decrement Index X by One
DEY Decrement Index $Y$ by One
EOR "Exclusive-or" Memory with Accumulator
INC Increment Memory by One
INX Increment Index $X$ by One
INY Increment Index $Y$ by One

JMP Jump to New Location
JSR Jump to New Location Saving Return Address
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)
NOP No Operation
ORA "OR" Memory with Accumulator
PHA Push Accumulator on Stack
PHP Push Processor Status on Stack
PLA Pull Accumulator from Stack
PLP Pull Processor Status from Stack
ROL Rotate One Bit Left (Memory or Accumulator)
ROR Rotate One Bit Right (Memory or Accumulator)
RTI Return from Interrupt
RTS Return from Subroutine
SBC Subtract Memory from Accumulator with Borrow
SEC Set Carry Flag
SED Set Decimal Mode
SEI Set Interrupt Disable Status
STA Store Accumulator in Memory
STX Store Index X in Memory
STY Store Index $\mathbf{Y}$ in Memory
TAX Transfer Accumulator to Index $X$
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
TYA Transfer Index Y to Accumulator


R6503 - 28 Pin Package


## Features of R6503

- 4 K Addressable Bytes of Memory (AO-A11)
- On-the-chip Clock
- IRQ Interrupt
- $\overline{\text { NMII Interrupt }}$
- 8 Bit Bidirectional Data Bus

R6504-28 Pin Package
$\begin{array}{ll}\overline{R E S}-1 & 28 \\ \text { VSS } & 1\end{array}$


IRO 9
$\mathrm{VCc} \mathrm{B}_{4} \quad 25$ 20


- 8K Addressable Bytes of Memory (AO-A12)

23 D2

- On-the-chip Clock
- $\bar{R} \mathbf{R O}$ Interrupt
- 8 Bit Bidirectional Data Bus

R6505-28 Pin Package


| $\overline{\text { RES }}$ | 51 | 28 | $\phi_{2}$（OUT） |
| :---: | :---: | :---: | :---: |
| vss | ${ }^{2}$ | 27 | $\varphi_{0}$（IN） |
| $\phi_{1}$ lout | －3 | 26 | صR／w |
| $\overline{\text { ino }}$ | 5 | 25 | Do |
| vcc | 단 | 24 | D1 |
| AO | － | 23 | صD2 |
| A1 | －7 | 22 | ص๐3 |
| A2 | 日8 | 21 | ص04 |
| A3 | －9 | 20 | 曰o5 |
| A4 | －10 | 19 | D6 |
| A5 | －11 | 18 | 曰D7 |
| A6 | －12 | 17 | صA11 |
| A7 | ［ 13 | 16 | PA10 |
| A8 | －14 | 15 | صA9 |

## Features of R6506

－ 4 K Addressable Bytes of Memory（A0－A11）
－On－the－chip Clock
－$\overline{\mathrm{RO}}$ Interrupt
－Two phase output clock for timing of support chips
－ 8 Bit Bidirectional Data Bus

R6507－28 Pin Package

| RES－ 1 | 28 | $\square \phi_{2}(\mathrm{OUT})$ |  |
| :---: | :---: | :---: | :---: |
| vss $\square^{2}$ | 27 | $\square \phi_{0}($ IN $)$ |  |
| RDY 3 | 26 | $\mathrm{R} / \mathrm{W}$ | Features of R6507 |
| vac 4 | 25 | 已DO |  |
| AO 5 | 24 | 己D1 | －8K Addressable Bytes of Memory（A0－A12） |
| $A_{1}{ }^{-1}$ | 23 | D2 | －On－the－chip Clock |
| A2 $\mathrm{Cl}_{7}$ | 22 | コ03 | －RDY Signal |
| A3－ 8 | 21 | صロ4 | － 8 Bit Bidirectional Data Bus |
| A4 9 | 20 | $\square \mathrm{D} 5$ |  |
| A5 10 | 19 | $\square \mathrm{D} 6$ |  |
| A6 11 | 18 | D7 |  |
| A7 12 | 17 | ص A12 |  |
| A8 13 | 16 | A11 |  |
| A9 14 | 15 | － $\mathrm{Al}^{10}$ |  |

R6512－ 40 Pin Package

| vss $\quad$－ | 1 | 40 | $\overline{\text { RES }}$ |  |
| :---: | :---: | :---: | :---: | :---: |
| RDY | 2 | 39 | $\phi_{2}$（OUT） | Features of R6512 |
| $\Phi_{1}$－ | 3 | 38 | s．o． | Features of R6512 |
| $\overline{\text { IRO }}$ | 4 | 37 | ص $\phi_{2}$ | 65K Addressable Bytes of Memory（A0－A15） |
| VSS | 5 | 36 | D DBE | －IROInterrupt |
| NMI－ | 6 | 35 | N．C． | －NलMI Interrupt |
| SYNC | 7 | 34 | $\mathrm{R} / \overline{\mathrm{w}}$ | －RDV Signal |
| VCC | 8 | 33 | D0 | － 8 Bit Bidirectional Data Bus |
| AO | 9 | 32 | D1 | －SYNC Signal |
| A1 | 10 | 31 | D2 | －Two phase clock input |
| $A 2$ E | 11 | 30 | D3 | －Data Bus Enable |
| A3 | 12 | 29 | D4 | －Data Bus Enable |
| A4 | 13 | 28 | D5 |  |
| A5 5 | 14 | 27 | D6 |  |
| A6 | 15 | 26 | D D7 |  |
| A7 | 16 | 25 | ص 115 |  |
| A8 | 17 | 24 | A14 |  |
| A9 | 18 | 23 | ［ ${ }^{\text {A }} 13$ |  |
| A10 C | 19 | 22 | ［ A12 |  |
| A11 | 20 | 21 | $\square \mathrm{VSS}$ |  |



## Features of R6513

- 4K Addressable Bytes of Memory (A0-A11)
- Two phase clock input
- IRQ Interrupt
- NMI Interrupt
- 8 Bit Bidirectional Data Bus


## R6514-28 Pin Package



R6515-28 Pin Package

| VSS | 1 |  |  |
| :---: | :---: | :---: | :---: |
|  |  |  |  |
| RDY | 2 | 27 | $\varphi_{2}$ |
| $\phi_{1}$ | 3 | 26 | $R / \bar{W}$ |
| IRO | 4 | 25 | DO |
| VCC | 5 | 24 | D1 |
| AO | 6 | 23 | $\square \mathrm{D} 2$ |
| A1 | 7 | 22 | $\square \mathrm{D} 3$ |
| A2 | 8 | 21 | D4 |
| A3 | 9 | 20 | D5 |
| A4 | 10 | 19 | D6 |
| A5 | 11 | 18 | 07 |
| A6 | 12 | 17 | A11 |
| A7 | 13 | 16 | A10 |
| A8 | 14 | 15 | $\square \mathrm{A} 9$ |

## Features of R6514

- 8 K Addressable Bytes of Memory (AO-A12)
- Two phase clock input
- IRO Interrupt
- 8 Bit Bidirectional Data Bus

Features of R6515

- 4K Addressable Bytes of Memory (AO-A11)
- Two phase clock input
- IRQ Interrupt
- RDY Signal
- 8 Bit Bidirectional Data Bus

| instauctions |  | immediate |  |  | absolite |  |  | zeropage |  |  | actum |  | Imputo |  |  | (ind. $\mathrm{x}_{1}$ |  | IINOJ. Y |  |  | 2 Pace. x |  | ans. ${ }^{\text {a }}$ |  |  | ass. 1 |  | melative |  | mointct |  | 2 Pace. 7 |  | macess din 3 tatuscodes |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| mMemonic | OPERATIOM | OP $n$ |  | - | OP | $n$ | - | OP | n | ${ }^{*}$ | OP | * | OP | n | $\cdots$ | OP | n | OP | $n$ | $\cdots$ | OP | n ${ }^{\circ}$ | 1 OP | $n$ | 0 | OP $n$ | 10 | OP $n$ | - | OP | - | OP ${ }^{1}$ | n |  | mimonic |
|  | $\begin{array}{lr} \hline A+M+C-A & 141(1) \\ A A M \rightarrow A & \\ C-E \\ \text { BRANCHONC }=0 & \\ \text { BRANCHONC }=1 & 121 \\ \hline \end{array}$ | 69 |  |  | $\left\|\begin{array}{l} 60 \\ 20 \\ 08 \end{array}\right\|$ | 4 | 3 | $\begin{aligned} & 65 \\ & 25 \\ & 06 \end{aligned}$ | 3 3 3 | 2 2 2 |  | 21 |  |  |  |  |  | 2 71 <br> 2 31 | 5 | 2 | 75 | $\begin{array}{l\|l} \hline 4 & 2 \\ 4 & 2 \\ 6 & 2 \end{array}$ | $\begin{array}{l\|l} \mathbf{2} & 10 \\ \mathbf{2} & 30 \\ \mathbf{2} & 1 \varepsilon \end{array}$ | 4 | 79 | 79 39 | ${ }^{3}$ |   <br> 90  <br>  2 <br> 80 2 <br> 2  | 2 |  |  |  |  |  | ADC <br> $A N O$ <br> $A S L$ <br> $B C C$ <br> $B C S$ |
| $\begin{aligned} & \mathrm{BEO} \\ & \mathrm{BIT} \\ & \mathrm{BM} \\ & \mathrm{BNE} \\ & \mathrm{BAL} \end{aligned}$ | BRANCHONZ $=1$ (2) <br> AAM <br> GRANCHONN = 1 (2) <br> BRANCHONZ $=0$ (2) <br> BRANCHONN $=0$ (2) |  |  |  | 2 C | 4 | 3 | 24 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | F0 2 <br>  2 <br> 30 2 <br> 00 2 <br> 10 2 | 2 2 2 2 |  |  |  |  |  |  |
| $\begin{aligned} & \hline \text { BRK } \\ & \text { BVC } \\ & \text { BVS } \\ & \text { CLC } \\ & \text { CLO } \end{aligned}$ | break <br> BRANCHONV = 0 (2) <br> BAANCHONV = 1 (2) $\begin{aligned} & 0-c \\ & 0-0 \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{\|c\|} \hline \infty \\ \hline 18 \\ \hline 08 \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | 1 | , |  |  |  |  |  |  |  |  |  |  |  |  | 2 |  |  |  |  |  | B.AK <br> BVC <br> BVS <br> CLC <br> CLE |
| $\begin{aligned} & \hline \text { CLI } \\ & \text { CLY } \\ & \text { CMP } \\ & \text { CPX } \\ & \text { CPY } \end{aligned}$ | $\begin{aligned} & 0 \rightarrow 1 \\ & 0 \rightarrow V \\ & A-M \\ & X-M \\ & Y-M \end{aligned}$ | $C 9$ 2 <br> $E 0$ 2 <br> $c 0$ 2 | 2 |  |  | 4 |  | $\begin{aligned} & C_{5} \\ & E 4_{4} \\ & C_{4} \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \\ & \hline \end{aligned}$ | 2 2 2 |  |  | 58 88 | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | 1 | c) | 62 | 201 | 5 | 2 | 05 | 42 | 200 | 4 | 309 | D9 | 3 |  |  |  |  |  |  |  |  |
| DEC <br> DEX <br> OEY <br> EOR <br> INC | $\begin{aligned} & M-1-M \\ & X+1-X \\ & Y-1-Y \end{aligned}$ <br> $A \vee M-A$ <br> (1) $M+1-M$ | 49 | 2 | 2 | $\begin{gathered} \mathrm{CE} \\ \hline \\ \hline \mathrm{CE} \\ \hline \end{gathered}$ | 6 | $\begin{aligned} & 3 \\ & 3 \\ & \hline \end{aligned}$ | $\begin{gathered} c s \\ 45 \\ \hline \mathrm{Es} \\ \hline \end{gathered}$ | $5$ <br> 3 <br> 5 | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ |  |  | $\left\|\begin{array}{c} \mathrm{CA} \\ \mathrm{BB} \end{array}\right\|$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | 1 | 41 | 62 | 231 | 3 | 2 | D6 | 6 2 <br> 4 2 <br> 6 2 |  | 4 | 3  <br> 3  <br> 3  | 59 | 3 |  |  |  |  |  |  | $\left\lvert\, \begin{array}{cccccc}N & \cdots & . & \cdots & \cdots & Z\end{array}\right.$ | DEC <br> OEX <br> DEY <br> EOR <br> INC |
| $\begin{aligned} & \text { INX } \\ & \text { INY } \\ & \text { JMP } \\ & \text { JSR } \\ & \text { LDA } \end{aligned}$ | $\begin{aligned} & x+1-x \\ & y+1-y \end{aligned}$ <br> JUMP TONEW LOC <br> JUMP SUB $M \rightarrow A$ |  | 2 |  | $\left\|\begin{array}{l} 4 \mathrm{C} \\ 20 \\ \mathrm{AO} \end{array}\right\|$ | $\begin{aligned} & 3 \\ & 6 \\ & 4 \\ & \hline \end{aligned}$ | 3 3 3 |  |  | 2 |  |  | C8 | $\left\lvert\, \begin{aligned} & 2 \\ & 2 \end{aligned}\right.$ | 1 |  | 62 | 281 | 5 | 2 | B5 | 2 | 280 | 4 | 31 | 89 | 3 |  |  | 6 C | 3 |  |  |  | INX <br> INY <br> JMP <br> JSA <br> LOA <br> LOA |
| $\begin{aligned} & \text { LDX } \\ & \text { LDY } \\ & \text { LSA } \\ & \text { NOP } \\ & \text { ORA } \end{aligned}$ |  | $\left[\begin{array}{c} A 2 \\ A 0 \\ A 0 \\ 0 \\ 0 . \end{array}\right.$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & \hline \end{aligned}$ | 2 | $\begin{aligned} & A E \\ & A C \\ & \Delta E \\ & 00 \end{aligned}$ |  | $\begin{aligned} & 3 \\ & 3 \\ & 3 \\ & 3 \end{aligned}$ | $\left\lvert\, \begin{aligned} & A_{6} \\ & A^{4} \\ & 46 \\ & \\ & 08 \end{aligned}\right.$ | $\begin{array}{\|l\|} \hline \\ 3 \\ 5 \\ 3 \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & \hline \end{aligned}$ | 4 A | 21 | EA | 2 | 1 |  |  | 211 | 5 | 2 | [84 |  | $\begin{array}{l\|l} 2 & \mathrm{BC} \\ 2 & 5 \mathrm{E} \\ & \\ \hline \end{array}$ | 7 | ${ }_{3}^{3}{ }_{3}^{\mathrm{Br}}$ |  | 3 |  |  |  |  | B6 | 42 |  | $\begin{aligned} & \text { LDX } \\ & \text { LOK } \\ & \text { LSA } \\ & \text { NOP } \\ & \text { OAA } \end{aligned}$ |
| PHA <br> PHP <br> PLA <br> PLP <br> POL <br> POR |  |  |  |  | 2 E |  |  | 26 | 5 | 2 | 2A |  | $\left(\left.\begin{array}{l} 48 \\ 08 \\ 68 \\ 28 \end{array} \right\rvert\,\right.$ | $\begin{aligned} & 3 \\ & 3 \\ & 4 \\ & 4 \end{aligned}$ | 1 1 1 1 |  |  |  |  |  | 30 |  | 23 E | 7 | 3 |  |  |  |  |  |  |  |  | (RESTORED: <br> N•••• $\mathbf{Z}$ C | $\begin{aligned} & \text { PHA } \\ & \text { NHP } \\ & \text { PLA } \\ & \text { PLP } \\ & \text { ROL } \end{aligned}$ |
| $\begin{aligned} & \text { AOR } \\ & \text { ATT } \\ & \text { RTS } \\ & \text { SBC } \\ & \text { SEC } \\ & \text { SEC } \\ & \hline \end{aligned}$ | C다 <br> $\stackrel{\square}{4}$ $\square$ <br> atranint <br> RTRN Sub $\begin{aligned} & A-M-\bar{C}-A \\ & 1-C \\ & 1-D \end{aligned}$ | E9 | 2 | 2 | $\left.\right\|_{6 E} ^{6} \mid$ | 6 | ${ }^{3}$ | ${ }_{\text {ES }}^{65}$ | 3 | $\begin{gathered} 2 \\ 2 \\ 2 \end{gathered}$ | 6 a | 21 | 40 | $\begin{aligned} & 6 \\ & 6 \\ & 2 \\ & 2 \end{aligned}$ |  | E1 6 | 62 | 2 F | 5 | 2 | ${ }_{55}{ }^{75}$ |  | $2 \int_{\mathrm{FO}}^{2}$ | 4 | $3{ }^{3}$ | F9 4 | 3 |  |  |  |  |  |  | /AESTOAED, | AOR <br> ATI <br> RTS <br> SAC <br> SEC <br> SED <br> St |
| STEI STA STA STY TAX | $\begin{aligned} & B \rightarrow 1 \\ & A \rightarrow M \\ & X \rightarrow M \\ & Y \rightarrow M \\ & A \rightarrow X \end{aligned}$ |  |  |  | 80 8 | 4 | 3 3 3 | $\left\|\begin{array}{l} 85 \\ 86 \\ 84 \end{array}\right\|$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \end{aligned}$ | 2 2 2 |  |  | $78$ | ${ }_{2}^{2}$ | ${ }^{1}$ | 31 | 62 | 291 | 6 | 2 | 95 | $4{ }_{4}^{4} 2$ | $2$ | 5 | 39 | 99.5 | 3 |  |  |  |  | 96 | 4 |  |  |
|  | $\begin{aligned} & A \rightarrow r \\ & s \rightarrow x \\ & x \rightarrow A \\ & x \rightarrow s \\ & r \rightarrow A \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  | AB | 2 2 2 2 2 | 1 1 1 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | Ms |  |  |  |  | TACK | crive |  |  |  | $\hat{v}$ |  | trac O <br> cusiv |  | m. MEMOAY <br> M. MEmORY <br> $n$ No CrCl <br> - no. bytes | BIT 7 <br> Bit 6 ES S |

Clock Timing - R6502, 03, 04, 05, 06, 07


Clock Timing - R6512, 13, 14, 15


Note: "REF." means Reference Points on clocks.

PROGRAMMING MODEL


Clock Timing－R6502，03，04，05，06， 07

| Chersteriatic | Symbol | Min | Trp | max | Untu |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Crele Time | ${ }^{7} \mathrm{CrC}$ | 1.0 | － | 10.0 | U＊ |
| $\left.\Phi_{\text {ofin）}}{ }^{\text {Puise Width（messurad at }} \mathbf{1 . 5 V}\right)$ | PWH．${ }_{\text {O }}$ | 460 | － | 520 | n！ |
| $\Phi_{\text {ollin）}}{ }^{\text {Rise，Fall Time }}$ | TR $\varphi_{0}, T F \varphi_{0}$ | － | － | 10 | nt |
| Detay Time Between Clocks （mesured at 1.5 V ） |  | 5 | － | － | ${ }^{\text {n }}$ |
| $\Phi_{1 \text {（1outi）}}{ }^{\text {Puise Width（meenred at 1．5V）}}$ | PWH ${ }^{\text {¢ }}$ 1 | PWH ${ }_{\text {OL }}{ }^{20}$ | － | PWH ${ }_{\text {OL }}$ | n＊ |
|  | PWH ${ }_{\text {¢ }}^{2}$ | PWH $\Phi_{\text {OH }}{ }^{-40}$ | － | ${ }^{\text {PWH }}$ ¢ $_{\text {OH }}{ }^{-10}$ | n |
| $\Phi_{1 \text { OUT）}} \phi_{\text {2OUUT）}}{ }^{\text {Rise，Fall Time }}$ （mesurted en 0.8 E to 2.0 V ） （Low－ $130 \mathrm{pF}+1$ TTLI） | $\mathrm{T}_{\mathrm{R}} \cdot \mathrm{T}_{\mathrm{F}}$ | － | － | 25 | ns |

Clock Timing－R6502，03，04，05，06， 07

| Cherretarative | symbol | min | TYp | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Cycle Time | ${ }^{T} \mathrm{CrO}$ | 0.5 | － | 10.0 | W |
| $\varphi_{\text {o（IN）}}$ Pulse Width（memeured at 1.5 VV ） | ${ }^{\text {PWH }}{ }_{\text {¢ }}$ 。 | 240 | － | 260 | $n$ |
| $\phi_{\text {o（IN）}}$ Rise，Fall Time | TR ¢ $_{0}$ ，TF¢ ${ }_{0}$ | － | － | 10 | ns |
| Delay Time Between Clock： （messured at 1.5 V ） | ${ }^{T}$ | 5 | － | － | m |
| $\Phi_{1 \text {（IOUT）}}{ }^{\text {Pulse }}$ Width（mesured at 1.5 V ） | PWH $\Phi_{1}$ | PWH OL $^{-20}$ | － | －WH ${ }_{\text {OL }}$ | $n s$ |
| $\Phi_{210 \cup T)}$ Pulue Width（meenured at 1.5 V ） | PWH ¢ $_{2}$ | PWH $¢_{0 \mathrm{OH}^{-40}}$ | － | PWH ¢ $_{\text {OH }}{ }^{-10}$ | n |
| $\phi_{1 \text {（OUT）}}{ }^{\Phi_{\text {2IOUT }}}$ Rise．Fall Time （measurve at 0.8 V to 2.0 V ） thoad－ $130 \mathrm{pF}+1 \mathrm{TTH}$ | $\mathrm{t}_{\mathrm{F}} \cdot \mathrm{T}_{\mathbf{F}}$ |  | － | 25 | $n$ |

＊The lowest operating frequency for the commercial temperature range CPU＇s is 100 KHz ，which corresponds to a maximum cycle time （TCYC）of $10 \mu \mathrm{~s}$ ．The lowest operating frequency for the industrial and military temperature range CPU＇s is 250 KHz ，which corresponds to a maximum cycle time（ $T_{C Y C}$ ）of $4 \mu \mathrm{~s}$ ．

## Clock Timing－R6512，13，14， 15

| Charsoterintic | Symbel | Min | Tvo | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Cvele Time | ${ }^{\top} \mathrm{CrC}{ }^{*}$ | 1000 | － | － | ${ }^{m}$ |
| Clock Pulse Widen ${ }^{\text {a }}$ | PWH \＄1 | 430 | － | － | m |
| （Messured at Vec－0．2V） $\boldsymbol{\$ 2}$ | PWH ${ }^{\text {\％}} \mathbf{2}$ | 470 |  |  |  |
| Fall Time <br> （Memured from 0.2 V to $\mathrm{Vce} \cdot 0.2 \mathrm{~V}$ ） | $\mathrm{T}_{\mathrm{F}}$ | － | － | 25 | ns |
| Delay Time between Clocks （Measured at 0.2 V ） | ${ }^{T}$ | 0 | － | － | n |

Clock Timing－R6512，13，14， 15

| Cherseteristie | symbol | min | Trp | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Cycle Time | ${ }^{\text {T cre }}{ }^{\text {＊}}$ | 500 | － | － | m |
| Clock Pubse Width $\quad \$ 1$ | PWH \＄1 | 215 | － | － | ${ }^{4}$ |
| （Meseured at Vec－0．2V）\＄2 | PWH \＄ 2 | 235 |  |  |  |
| F all Time <br> （meseured from 0．2V to Vec－0．2V） | $\mathrm{T}_{\text {F }}$ | － | － | 12 | ns |
| Delay Time between Clocky （metured at 0.2 V ） | $T_{0}$ | 0 | － | － | m |

Read／Nrite Timing＊＊

| Chacrewistic | Srmbat | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Resd／Write Setup Time trom R6500A | ${ }^{\text {rews }}$ | － | 75 | 140 | \％ |
| Address Setup Time from R65004 | ${ }^{T}$ ADS | － | 75 | 140 | n |
| Memory Resd Access Time | ${ }^{\text {a }}$ ACC | － | － | 310 | ns |
| Dats Stability Time Period | ${ }^{\text {t }}$ DSU | 50 | － | － | $n 3$ |
| Data Hoid Time－Read | $T_{\text {HR }}$ | 10 | － | － | nt |
| Deta Hold Time－Write | $\mathrm{T}_{\text {Hw }}$ | 60 | 90 | － | ns |
| Date Setup Time from R6500a | ${ }^{\text {m M S }}$ | － | 75 | 100 | $n$ |
| RDY．S．O．Setup Time | $\mathrm{T}_{\text {ROY }}$ | 50 | － | － | ns |
| SYNC Setup Time from R6500A | ${ }^{\text {T Sync }}$ | － | － | 150 | $n$ |
| Address Hold Time | $\mathrm{T}_{\text {HA }}$ | 30 | 60 | － | ns |
| R $\overline{\mathbf{N}}$ Hold Time | $T_{\text {HRW }}$ | 30 | 60 | － | n4 |

Read／Write Timing＊＊

| Charseteristic | symbot | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read／Write Setup Time from R6500 | ${ }^{\text {r }}$ RWs | － | 100 | 225 | ns |
| Address Setue Time from R6500 | ${ }^{\text {T }}$ ADS | － | 100 | 225 | ns |
| Memory Resa Access Time | ${ }^{\text {t }}$ ACC | － | － | 650 | $n$ |
| Data Stabilitr Time Period | ${ }^{\text {Tosu }}$ | 100 | － | － | ns |
| Data Hold Time－Read | $\mathrm{T}_{\text {HR }}$ | 10 | － | － | $n$ |
| Data Hold Time－Write | $\mathrm{T}_{\text {Hw }}$ | 60 | 90 | － | ns |
| Data Setuo Time from R6500 | $\dagger_{\text {mos }}$ | － | 150 | 175 | n＊ |
| RDY，S．O．Setup Time | ${ }^{\text {r ROY }}$ | 100 | － | － | $n s$ |
| SYNC Setup Time from R6500 | $\mathrm{T}_{\text {Srnc }}$ | － | － | 225 | m |
| Address Hold Time | $\mathrm{T}_{\mathrm{HA}}$ | 30 | 60 | － | ns |
| R／W Hold Time | $T_{\text {HRW }}$ | 30 | 60 | － | ns |



## SPECIFICATIONS

Maximum Ratings

| Rating | Symbol | Value | Unit |
| :---: | :--- | :--- | :--- |
| Supply Voltage <br> Input Voltage <br> Operating Temperature <br> Commercial <br> Industrial <br> Military <br> Storage Temperature | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Vdc |  |  |  |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |

This device contains input protection against damage due to high static voltages or electric fields; however, precautions should be taken to avoid application of voltages higher than the maximum rating.

## Electrical Characteristics

$\left(V_{C C}=5.0 \pm 5 \%, V_{S S}=0\right)$
$\phi_{1}, \phi_{2}$ applies to R6512, 13, 14, 15, $\phi_{\text {olin })}$ applies to R6502, 03, 04, 05, 06 and 07.

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage $\begin{aligned} & \text { Logic, } \phi_{\text {o(in) }} \\ & \phi_{1}, \phi_{2} \end{aligned}$ | $V_{1 H}$ | $\begin{aligned} & v_{\mathrm{SS}^{+2.4}} \\ & \mathrm{v}_{\mathrm{cc}}-0.3 \end{aligned}$ |  | $\begin{gathered} v_{\mathrm{CC}} \\ v_{\mathrm{cc}}+0.25 \end{gathered}$ | Vdc |
| Input Low Voltage $\begin{aligned} & \text { Logic, } \phi_{\text {o(in) }} \\ & \phi_{1}, \phi_{2} \end{aligned}$ | $V_{\text {IL }}$ | $\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.4 \end{aligned}$ | Vdc |
| Input High Threshold Voltage RES, $\overline{\text { NMI, RDY, } \overline{R O}, ~ D a t a, ~ S . O . ~}$ | $V_{\text {IHT }}$ | $\mathrm{V}_{\mathrm{SS}}+2.0$ | - | - | Vdc |
| Input Low Threshold Voltage $\overline{\text { RES }}, \overline{\text { NMI }}$, RDY, $\overline{\mathrm{RQ}}$, Data, S.O. | $V_{\text {ILT }}$ | - | - | $\mathrm{V}_{\text {SS }}+0.8$ | Vdc |
| Input Leakage Current $\begin{aligned} &\left(\mathrm{V}_{\text {in }}=0 \text { to } 5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=0\right) \\ &\text { Logic (ExCI. RDY, S.O. }) \\ & \phi_{1}, \phi_{2} \\ & \phi_{\mathrm{o}(\mathrm{in})} \end{aligned}$ | $\mathrm{I}_{\text {in }}$ | - - - | $\begin{aligned} & - \\ & - \\ & - \end{aligned}$ | $\begin{aligned} & 2.5 \\ & 100 \\ & 10.0 \end{aligned}$ | $\mu \mathrm{A}$ |
| Three-State (Off State) Input Current $\left(V_{\text {in }}=0.4 \text { to } 2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{Cc}}=5.25 \mathrm{~V}\right)$ <br> Data Lines | ${ }^{\text {ITSI }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Output High Voltage $\begin{aligned} &\left(I_{\text {LOAD }}\right.\left.=-100 \mu A d c, V_{C C}=4.75 \mathrm{~V}\right) \\ & \text { SYNC, Data, AO-A15, R/W, } \phi_{1}, \phi_{2} \end{aligned}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\text {SS }}+2.4$ | - | - | Vdc |
| Output Low Voltage $\begin{aligned} &\left(I_{\text {LOAD }}\right.\left.=1.6 \text { mAdc, } V_{C C}=4.75 \mathrm{~V}\right) \\ & \text { SYNC, Data, AO.A15, R/W}, \phi_{1}, \phi_{2} \end{aligned}$ | ${ }^{\mathrm{OL}}$ | - | - | $\mathrm{V}_{\text {SS }}+0.4$ | Vdc |
| Power Dissipation Commercial temp. versions Industrial and military temp. versions | $P_{\text {D }}$ | - | $\begin{array}{r} 0.25 \\ 0.50 \\ \hline \end{array}$ | $\begin{aligned} & 0.575 \\ & 0.700 \end{aligned}$ | w |
|  | $\begin{aligned} & c \\ & c_{i n} \\ & c_{\text {out }} \\ & c_{\phi_{\text {olin }}} \\ & c_{\phi_{1}} \\ & c_{\phi_{2}} \\ & \hline \end{aligned}$ | - | $\begin{array}{r} - \\ - \\ 30 \\ 50 \end{array}$ | $\begin{aligned} & 10 \\ & 15 \\ & 12 \\ & 15 \\ & 50 \\ & 80 \end{aligned}$ | pF |

Note: $\overline{\mathrm{RQ}}$ and $\overline{\mathrm{NM}} \mathrm{I}$ require 3 K pull-up resistors.

## R6500 Microcomputer System DATA SHEET

## R6500/1 ONE-CHIP MICROCOMPUTER

## INTRODUCTION

The Rockwell R6500/1 is a complete, high-performance 8 -bit NMOS microcomputer on a single chip, and is totally upward/ downward software compatible with all members of the R6500 family.
The R6500/1 consists of an R6502 CPU, an internal clock oscillator, 2048 bytes of Read Only Memory (ROM), 64 bytes of Random Access Memory (RAM) and flexible interface circuitry. The interface circuitry includes a 16 -bit programmable counter/ latch with four operating modes, 32 bidirectional input/output lines (including two edge-sensitive lines), five interrupts and a counter I/O line.

## PRODUCT SUPPORT

To allow prototype circuit development. Rockwell offers a PROM compatible 64-pin Emulator device. This device provides all R6500/1 interface lines plus routing the address bus, data bus, and associated control lines off the chip to be connected to external memory.
To facilitate system and program development for the R6500/1. Rockwell offers extensive product support. The SYSTEM 65 Microcomputer Development System with the 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.

Regularly scheduled designer's courses are offered at regional centers.

The support products available are:

- SYSTEM 65 Microcomputer Develop-

P/N S65-101 ment System

- 1 MHz R6500/1 Personality Module
- 2 MHz R6500/1 Personality Module
- 1 MHz R6500/1 Emulator Device

P/N M65-081 P/N M65-082

- 2 MHz R6500/1 Emulator Device P/N R6500/1EC P/N R6500/1EAC
- R6500/1 Evaluation Module

ORDERING INFORMATION

| Order <br> Number | Package <br> Type | Frequency <br> Option | Temperature <br> Range |
| :--- | :--- | :--- | :--- |
| R6500/1P | Plastic | 1 MHz | $00^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| R6500/1C | Ceramic | 1 MHz | $0{ }^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| R6500/1AP | Plastic | 2 MHz | $00^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| R6500/1AC | Ceramic | 2 MHz | $00^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
|  |  |  |  |
| R6500/1PE | Plastic | 1 MHz | $-40{ }^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ |
| R6500/1CE | Ceramic | 1 MHz | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| R6500/1ACE | .Ceramic | 2 MHz | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

Note: The RC frequency option is available only in the 1 MHz R6500/1.

## FEATURES

- R6502 CPU
- Software upward/downward compatibility
- Decimal or binary arithmetic modes
- 13 addressing modes
- True direct and indirect indexing
- Memory addressable I/O
- $2048 \times 8$ mask programmable ROM
- $64 \times 8$ static RAM
- 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
- Five Interrupts
- Reset
- Non-maskable
- Two external edge sensitive
- Counter
- 1 of 3 frequency references
- Crystal
- Clock
- RC (resistor only)
- 4 MHz max crystal or clock external frequency
- 2 MHz or 1 MHz internal clock.
- $1 \mu \mathrm{~s}$ minimum instruction execution
- N-channel, silicon gate, depletion load technology
- Single +5 V power supply
- 500 mW operating power
- Separate power pin for RAM
- 40 pin DIP
- 64 pin PROM compatible Emulator device


Interface Diagram

## FUNCTIONAL DESCRIPTION

## CENTRAL PROCESSING UNIT (CPU)

## 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, clock or RC network input. The RC network mode is a mask option. The external frequency can vary from 200 kHz to 4 MHz . The internal Phase $2(02)$ frequency is one-half the external reference frequency. A 4.7 K ohm resistor will provide nominal 2 MHz oscillation and 1 MHz internal operation in the RC mask option ( $\pm 35 \%$ ).

## Timing Control

The Timing Control Logic keeps track of the specific instruction eycle being executed. Each data transfer which takes place between the registers is caused by decoding the contents of both the Instruction Register and Timing Controf Logic.

## Program Counter

The 16 -bit Program Counter provides the addresses which step the CPU through sequential instructions in a program. The Program Counter is incremented each time an instruction or data is fetched from 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).

## 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.

## Index Registers

There are two 8 -bit index registers, $X$ and $Y$. These registers can be used for general purpose storage, or as a displacement to modify the base address and thus obtain a new effective address. Pre- or postindexing of indirect addresses is possible.

## 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 under direction of either the program or interrupts NVI and 1RQ. The stack allows simple implementation of nested subroutines and multiple level interrupts.

## 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 R6500 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags.

## Interrupt Logic

Interrupt logic controls the sequencing of three interrupts; $\overline{\operatorname{RES}}, \overline{\mathrm{NMI}}$ and $\overline{\mathrm{TRO}} \overline{\mathrm{IRO}}$ is generated by any one of three conditions: Counter Overflow, PAO Positive Edge Detected, and PA1 Negative Edge Detected.


## Processor Status Register

## MEMORY

## $2048 \times 8$ ROM

The 2048 byte Read-Only Memory (ROM) contains the 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.

## $64 \times 8$ RAM

The 64 byte Random Access Memory (RAM) is used for read/write memory during system operation, and contains the stack. This RAM is completely static in operation and requires no clock or dynamic refresh. 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.
In order to take advantage of efficient zero page addressing capabilities, the RAM is assigned memory addresses 0 to 03F.

## INPUT/OUTPUT

## Bidirectional I/O Ports

The R6500/1 provides four 8-bit input/output ports (PA, PB, PC, and PD). Associated with the $1 / 0$ ports are four 8 bit registers located on page zero. See the system memory map for specific addresses. Each I/O line is individually selectable as an input or an output without line yrouping or port association restrictions.
An internal active transistor drives each $1 / O$ line to the low state. An internal passive resistance pulls the $1 / 0$ lines to the high state, eliminating the need for external pull-up resistors.
An option is available to delete the internal pull-up resistance on 8-bit port groups or on the CNTR line at mask time. This option is employed to permanently assign an 8 -bit port group to input functions, to interface with CMOS drivers, or to interface with external pull-up devices.

## Inputs

Inputs are enabled by setting the appropriate bit of the $1 / O$ port to the high state (Logic 1). A low input signal causes a logic 0 to be read. A high input signal causes a logic 1 to be read. $\overline{R E S}$ loads Logic 1 into the 1/O ports, thereby jnitializing all I/O lines as inputs.

## Outputs

Outputs are set by loading the desired bit pattern into the corresponding I/O ports. A Logic 1 selects a high output; a Logic 0 selects a low output.

## CONTROL REGISTER

The Control Register (CR) controls four Counter operating modes and three maskable interrupts. It also reports the status of three interrupt conditions. There are five control bits and three status bits. The control bits are set to Logic 1 or cleared to Logic 0 by writing the desired state into the respective bit positions. The Control Register is cleared to Logic $\mathbf{O}$ by the occurrence of RES.


Control Register

## EDG'E DETECT CAPABILITY

There is an asynchronous edge detect capability on two of the Port A I/O lines. This capability exists in addition to and independently from the normal Port A I/O functions. The maximum rate at which an edge can be detected is one-half the $\phi 2$ clock rate. The edge detect logic is continuously active. Each edge detect signal is associated with a mask able interrupt.

## PAO Positive Edge Detection

A positive (rising) edge is detectable on PAO. When this edge is detected the PAO Positive Edge Detected bit - Bit 6 in the Control Register is set to Logic 1. When both this bit and the PAO Interrupt Enable Bit - Bit 3 of the Control Register - are set to Logic 1, an IRQ interrupt request is generated. The PAO Positive Edge Detected bit is cleared by writing to address 089.

## PA1 Negative Edge Detection

A negative (falling) edge is detectable on PA1. When this edge is detected, the PA1 Negative Edge Detected bit - Bit 5 of the Contro Register - is set to Logic 1. When both this bit and the PAI Interrupt Enable bit - Bit 2 of the Control Register - are set to Logic 1, an TRQ interrupt request is generated. The PA1 Negative Edge Detected bit is cleared by writing to address 08A.

## COUNTER/LATCH

The Counter/Latch consists of a 16 bit decrementing Counter and a 16 -bit Latch. The Counter is comprised of two 8 -bit registers. Address 086 contains the Upper Count (UC) and address 087 contains the Lower Count (LC). The Counter counts either $\$ 2$ clock periods or occurrences of an external event, depending on the selected counter mode. The UC and LC can be read at any time without affecting counter operation.
The Latch contains the Counter preset value. The Latch consists of two 8 -bit registers. Address 084 contains the Upper Latch (UL) and address 085 contains the lower latch (LL). The 16 -bit Latch can hold a count from 0 to 65,535 . The Latch can be accessed as two write-only memory locations.
The Latch registers can be loaded at any time by storing into UL and LL. The UL can also be loaded by writing into address 088.

The Counter can be preset at any time by writing to address 088. Presetting the Counter in this manner causes the contents of the accumulator to be stored into the UL before the 16 -bit value in the Latch (UL and LL) is transferred in the Counter (UC and LC).
The Counter is preset to the Latch value when the Counter overflows. When the counter decrements from 0000. Counter overflow occurs causing the next counter value to be the Latch value, not FFFF.

When the Counter overflows, Counter Overflow bit - Bit 7 of the Control Register - is set to Logic 1. When both this bit and the Counter Interrupt Enable bit - Bit 4 of the Control Register - are set, an $\overline{\text { IRQ }}$ interrupt request is generated. The Counter Overflow bit in the Control Register can be examined in an TRQ interrupt service routine to determine that the $\overline{\mathrm{RQ}}$ was generated by Counter overflow.

The Counter Overflow bit is cleared when the LC is read or Counter preset is performed by writing into address 088.

## .COUNTER MODES

The Counter operates in any of four modes. These modes are selected by the Counter Mode Control bits in the Control Register.

| Mode | CMC 1 |  |
| :--- | :---: | :---: |
| CMC 0 |  |  |
| Interval Timer | 0 |  |
| Pulse Generator | 0 | 0 |
| Event Counter | 1 | 1 |
| Pulse Width Measurement | 1 | 0 |
|  |  |  |

The Interval Timer, Pulse Generator, and Pulse Width Measurement Modes are $\boldsymbol{\phi} 2$ clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line.

## Interval Timer (Mode 0)

In this mode the Counter is free running and decrements at the $\boldsymbol{\phi} 2$ clock rate. Counter overflow sets the Control Register status bit and causes the Counter to be preset to the Latch value.
The CNTR line is held in the high state.

## Pulse Generator (Mode 1)

In this mode the Counter is free running and decrements at the $\phi 2$ clock rate. Counter overflow sets the Control Register status bit and causes the Counter to be preset to the Latch value.
The CNTR line toggles from one state to the other when Counter overflow occurs. Writing to address 088 will also toggle the CNTR line.
A symmetric or asymmetric output waveform can be generated on the CNTR line in this mode. A one-shot waveform can easily be generated by changing from Mode 1 to Mode 0 after only one occurrence of the output toggle condition.

## Event Counter (Mode 2)

In this mode the CNTR line is used as an event input line. The Counter decrements each time a rising edge is detected on CNTR. The maximum rate at which this edge can be detected is one-half the $\phi 2$ clock rate. Counter overflow sets the Control Register status bit and causes the Counter to be preset to the Latch value.

## Pulse Width Measurement (Mode 3)

This mode allows the accurate measurement of the duration of a low state on the CNTR line. The Counter decrements at the $\phi 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 state.

## RESET CONSIDERATIONS

The occurrence of $\overline{\mathrm{RES}}$ going from low to high causes initialization of various conditions in the R6500/1. 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 reset to Logic 0, causing the Interval Timer Mode (Mode 0) to be selected and, all interrupt enabled bits to be cleared. Neither the Latch nor the Counter registers are initialized by RES. The Interrupt Disable bit in the CPU Processor Status Register is set and the program starts execution at the address contained in the Reset Vector location.

TEST LOGIC
Special test logic provides a method for thoroughly testing the R6500/1. Applying a +10 V signal to the RES line places the R6500/1 in the test mode. While in this mode, all memory fetches are made from Port PC. External test equipment can use this feature to test internal CPU logic and I/O. A program can be loaded into RAM allowing the contents of the instruction ROM to be dumped to any port for external verification. All R6500/1 microcomputers are tested by Rockwell using this feature.

## MEMORY ADDRESSABLE I/O

The I/O ports, registers, and commands are treated as memory and are assigned specific addresses. See the system memory map for the addresses. This I/O technique allows the full set of CPU instructions to be used in the generation and sampling of $1 / O$ commands and data. When an instruction is executed with an 1/O address and appropriate $R / \bar{W}$ state, the corresponding I/O function is performed.


Noten:
(1) l/O commend only; i.e., no stored data.
(2) Clears Counter Overflow - Bit 7 in Control Register.

SIGNAL DESCRIPTIONS

SIGNAL NAME PINNO
VCC

|  |  |
| :--- | :---: |
| PAO-PA7 | $38-31$ |
| PBO-PB7 | $29-22$ |
| PCO-PC7 | $20-13$ |
| PD0-PD7 | $9-2$ |

CNTR

## description

Main power supply +5 V
Separate power pin for RAM. In the event that VCC power is lost. this power retains RAM data.

Signal ground
Crystal, clock or RC network input for internal clock oscillator.

Crystal or RC network output from internal clock oscillator.

The Reset input is used to initialize the R6500/1. This signal must not transition from low to high for at least eight cycles after VCC reaches operating range and the internal oscillator has stabilized.
+10 V input enables the test mode.
A negative going edge on the NonMaskable Interrupt signal requests that a non-maskable interrupt be generated within the CPU.

Four 8 bit ports used for either input/output. Each line consists of an active transistor to VSS and a passive pull-up to +5 V . The two lower bits of the PA port (PAO and PA1) also serve as edge detect inputs with maskable interrupts.

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.

System Memory Map


R6500/1 Block Diagram

## INSTRUCTION SET - ALPHABETIC SEQUENCE

ADC Add Memory to Accumulator with Carry
AND "AND" Memory with Accumulator
ASL Shift left One Bit (Memory or Accumulator)
BCC Branch on Carry Clear
BCS Branch on Carry Set
BEO Branch on Result Zero
BIT Test Bits in Memory with Accumulator
BMI Branch on Result Minus
BNE Branch on Result not Zero
BPL Branch on Result Plus
BRK Force Break
BVC Branch on Overflow Clear
BVS Branch on Overflow Set
CLC Clear Carry Flag
CLD Clear Decimal Mode
CLI Clear Interrupt Disable Bit
CLV Clear Overflow Etag
CMP Compare Memory and Accumulator
CPX Compare Memory and Index $X$
CPY Compare Memory and Index $Y$
DEC Decrement Memory by One
DEX Decrement Index $X$ by One
DEY Decrement Index Y by One
EOR "Exclusive-or" Memory with Accumulator
INC Increment Memory by One
INX Increment Index $X$ by One
INY Increment Index $Y$ by One
JMP Jump to New Location
JSR Jump to New Location Saving Return Address

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)
NOP No operation
ORA 'OR" Memory with Accumulator
PHA Push Accumulator on Stack
PHP Push Processor Status on Stack
PLA Pull Accumulator from Stack
PLP Pull Processor Status from Stack
ROL Rotate One Bit Left (Memory or Accumulator)
ROR Rotate One Bit Right (Memory or Accumulator)
RTI Return from Interrupt
RTS Return from Subroutine
SBC Subtract Memory from Accumulator with Borrow
SEC Set Carry Flag
SED Set Decimal Mode
SEI Set Interrupt Disable Status
STA Store Accumulator in Memory
STX Store Index $X$ in Memory
STY Store Index Y in Memory
TAX Transfer Accumulator to Index $X$
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
TYA Transfer Index $Y$ to Accumulator

## ADDRESSING MODES

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

IMMEDIATE ADDRESSING - In immediate addressing, the operand is contained in the second byte of the instruction, with no further memory addressing required.

ABSOLUTE ADDRESSING - 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.

ZERO PAGE ADDRESSING - The zero page instructions allow for shorter code and execution times by only fetching 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 - ( $X, Y$ indexing) - This form of addressing is used in conjunction 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 8 bits of memory and crossing of page boundaries does not occur.

INDEXED ABSOLUTE ADDRESSING - ( $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 multiple fields resulting in reduced coding and execution time.

IMPLIED ADDRESSING - In the implied addressing mode, the address containing the operand is implicitly stated in the operation code of the instruction.
RELATIVE ADDRESSING - 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 $\mathbf{- 1 2 8}$ to +127 bytes from the next instruction.

INDEXED INDIRECT ADDRESSING - In indexed indirect addressing (referred to as (Indirect, XI), 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 is 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 - 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 is 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 - 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 is contained in the third byte of the instruction. The contents of the fully specified memory location is 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.


| VRRE 1 | 40 | T ${ }^{\text {NMI }}$ |
| :---: | :---: | :---: |
| PD7 ${ }^{2}$ | 39 | 己 $\overline{\text { PES }}$ |
| PDG ${ }^{\text {c }}$ | 38 | Pao |
| PD5 ${ }^{-1}$ | 37 | PPa1 |
| PD4 ${ }^{5}$ | 36 | صPa2 |
| PD3 ${ }^{\text {c }}$ | 35 | PPa3 |
| PD2 ${ }^{\text {c }}$ | 34 | Paa4 |
| PD1 ${ }^{\text {¢ }}$ | 33 | Pas |
| Pdo ${ }^{\text {co }}$ | 32 | صPa6 |
| XTLI ${ }^{10}$ | 31 | PPa7 |
| xtLo 11 | 30 | Pvcc |
| vss ${ }^{12}$ | 29 | Р8во |
| PC7 ${ }^{13}$ | 28 | صP81 |
| PC6 ${ }^{14}$ | 27 |  |
| PC5 15 | 26 | P83 |
| PC4 ${ }^{16}$ | 25 | $\mathrm{PB}^{\text {P }}$ |
| PC3 ${ }^{17}$ | 24 | PP85 |
| PC2 5 | 23 | P86 |
| PC1 19 | 22 | P87 |
| PCO 20 | 21 | DCNtR |

Pin Configuration

## Packaging Diagram

TIMING CHARACTERISTICS
yopont outmut tmems


RAO ANO PAI EDGE DETECT TIMIMG


## SPECIFICATIONS

## Maximum Ratings

| Pating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage <br> Input Voltage <br> Operating Temperature Range <br> Commercial <br> Industrial <br> Storage Temperature Range | $\begin{aligned} & v_{C C} \\ & v_{\text {in }} \\ & T^{\prime} \\ & T_{\text {stg }} \end{aligned}$ | $\begin{aligned} & -0.3 \text { to }+7.0 \\ & -0.3 \text { to }+7.0 \\ & 0 \text { to }+70 \\ & -40 \text { to }+85 \\ & -55 \text { to }+150 \end{aligned}$ | Vdc <br> Vdc <br> ${ }^{\circ} \mathrm{C}$ <br> ${ }^{\circ} \mathrm{C}$ |

This device contains 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 higher than maximum rated voltages to this circuit

Static D.C. Characteristics $\mathbf{V}_{\mathbf{C C}}=5 \mathrm{~V} \pm 10 \%$ for R6500/1, $\mathrm{V}_{\mathrm{Cc}}=5 \mathrm{~V} \pm 5 \%$ for R6500/1A)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipation (Outputs High) $\begin{array}{r} 0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{array}$ | $P_{D}$ | - | 500 550 | - | mW |
| RAM Standby Voltage (Retention Mode) | $V_{\text {RR }}$ | 3.5 | - | $V_{C C}$ | Vde |
| RAM Standby Current (Retention Mode) $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | ${ }^{\prime}$ RR | - | 10 | - | mAdc |
| $40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |  | - | 12 | - |  |
| Input High Voltage (Normal Operating Levels) | $V_{\text {IH }}$ | +2.0 | - | $\mathrm{V}_{\text {cc }}$ | Vde |
| Input Low Voltage (Normal Operating Levels) | $V_{\text {IL }}$ | -0.3 | - | $+0.8$ | Vde |
| Input Leakage Current | IIN |  |  |  | $\mu \mathrm{Adc}$ |
| $V_{i n}=0 \text { to } \frac{5.0}{\text { RES }}, \mathrm{Vdc}$ |  |  | $\pm 1.0$ | $\pm 2.5$ |  |
| Input High Voltage (XTLI) | $V_{\text {IHXT }}$ | +4.0 | - | VCC | Vdc |
| Input Low Voltage (XTLI) | VILXT | -0.3 | - | +0.8 | Vde |
| Input Low Current ( $\mathrm{V}_{\text {IL }}=0.4 \mathrm{Vdc}$ ) | IIL | - | -1.0 | -1.6 | mAdc |
| Output High Voltage | VOH |  |  |  |  |
| $\left(V_{\text {CC }}=\mathrm{min}, 1_{\text {Load }}=-100 \mu \mathrm{Adc}\right)$ |  | -2.4 | - | - | Vdc |
| Output High Voltage ( $\mathrm{V}_{\mathrm{CC}}=\mathrm{min}$ ) | Vcmos | VCC-30\% | - | - | Vdc |
| Output Low Voltage | VOL |  |  |  |  |
| $\left(V_{\text {CC }}=\mathrm{min}, \mathrm{I}_{\text {Load }}=1.6 \mathrm{mAdc}\right.$ ) |  | - | - | +0.4 | Vdc |
| Output High Current (Sourcing) | ${ }^{\prime} \mathrm{OH}$ |  |  |  |  |
| ( $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{Vdc}$ ) |  | - 100 |  | - | $\mu$ Adc |
| Output Low Current (Sinking) | IOL | 1.6 |  |  |  |
| ( $\left.\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{Vdc}\right)$ Input Capacitance | $\mathrm{C}_{\text {in }}$ | 1.6 | - | - | pF |
| $\begin{aligned} & \left(V_{\text {in }}-0, T_{A}=25^{\circ} \mathrm{C}, f=1.0 \mathrm{MHz}\right) \\ & \text { PA, PB, PC, PD, CNTR } \\ & \times \text { TLI, XTLO } \end{aligned}$ |  | - | - | 10 50 |  |
| Output Capacitance | $C_{\text {out }}$ |  |  |  |  |
| $\left(V_{\text {in }}-0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right.$ ) |  | - | - | 10 | pF |
| 1/O Port Resistance | $\mathbf{R}_{L}$ | 3.0 | 6.0 | 11.5 | $K \Omega$ |
| PAO-PA7, PBO-PB7, PC0-PC7. PDO-PD7, CNTR |  |  |  |  |  |

NOTE: Negative sign indicates outward current flow, positive indicates inward flow.
AC Characteristics $\left(V_{C C}=5 V \pm 10 \%\right.$ for $R 6500 / 1, V_{C C}=5 V \pm 5 \%$ for $\left.R 6500 / 1 A\right)$.


| instructions |  | Immedare |  |  | As50LITE |  |  | zere page |  |  |  |  | Implied |  |  |  |  |  |  | 2 pagex |  | ass. x |  |  |  | melative |  | Imorect |  | 2 Page. r |  | ${ }_{\text {coocs }}^{\text {cmor siatus }}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| mnemonic | opramion | OP |  |  | OP | $\square$ | $\cdots{ }^{-1}$ | P |  |  | T | - 0 | OP $n$ | n | OP | $\cdots$ | ${ }^{\circ} \mathrm{P}$ | T | O | OP ${ }^{1}$ |  | OP | I | 1.10 | OP $n$ | - OP | n. ${ }^{\text {. }}$ | OP | n. | OP $n$ | - $\frac{7}{N}$ | $\frac{6543210}{1-1}$ | Monic. |
| $\begin{aligned} & \text { ADC } \\ & \text { AND } \\ & \text { ASL } \\ & \text { ACC } \\ & \text { OCS } \\ & \hline \end{aligned}$ |  | 29 | 2 |  | $\begin{aligned} & 50 \\ & 20 \\ & 0 \mathrm{OE} \end{aligned}$ | 4 <br> 4 <br> 4 <br> 3 <br> 3 | 3 65 <br> 3 25 <br> 3 06 | 5 3 | 2 | OA | 2 | 1 |  |  |  |  | 2 71 <br> 2 31 | 5 |  | $\begin{array}{\|l\|l\|} \hline 75 & 4 \\ 35 & 4 \\ 16 & 6 \end{array}$ | 4  <br> 4  <br> 4  <br>  2 <br> 2  | $\left.\begin{array}{\|c\|} \hline 70 \\ 30 \\ 1 E \end{array} \right\rvert\,$ | 4 |  | 79 39 | 900 | $\begin{array}{lll}2 & 2 \\ 2 & 2\end{array}$ |  |  |  |  |  | AOC <br> $A N D$ <br> $A S L$ <br> BCC <br> BCS |
| $\begin{aligned} & \hline \text { BEO } \\ & \text { BIT } \\ & \text { BMI } \\ & \text { BNE } \\ & \text { BPL } \end{aligned}$ | $\begin{array}{ll} \hline \text { BRANCHONZ }=1 & \text { (2) } \\ \text { AAM } \\ \text { BRANCHON }=1 & \\ \text { BRANCH ON }=0 & (2) \\ \text { BRANCH ON }=0 & \text { (2) } \end{array}$ |  |  |  | 2 C | 3 | 324 | 4 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | F0 | $\begin{array}{\|l\|l} \hline 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ 2 & 2 \\ \hline \end{array}$ |  |  |  |  |  |  |
| $\begin{aligned} & \hline \text { BRK } \\ & \text { BVC } \\ & \text { BVS } \\ & \text { cLc } \\ & \text { CLO } \\ & \hline \end{aligned}$ | $\begin{array}{ll\|} \hline \text { BREAK } \\ \text { BRANCH ONV }=0 & \text { (2) } \\ \text { BRANCH ONV }=1 & \text { (21 } \\ 0-C & \\ 0 \rightarrow 0 & \\ \hline \end{array}$ |  |  |  |  |  |  |  |  |  |  |  |  | 1 1 <br>   <br> 2 1 <br> 2 1 <br> 2 1 |  |  |  |  |  |  |  |  |  |  |  | 50 | $\begin{array}{lll}2 & 2 \\ 2 & 2\end{array}$ |  |  |  |  |  | $\begin{aligned} & \text { B.AK } \\ & \text { BVC } \\ & \text { BVS } \\ & \text { CLC } \\ & \text { CLO } \end{aligned}$ |
| $\begin{aligned} & \hline \mathrm{CLI} \\ & \mathrm{CLV} \\ & \mathrm{CMP} \\ & \mathrm{CPX} \\ & \mathrm{CPY} \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \rightarrow 1 \\ & 0-V \\ & A-M \\ & X-M \\ & Y-M \\ & \hline \end{aligned}$ |  | 2 |  | $\left.\begin{array}{\|l\|} \mathrm{co} \\ \mathrm{Ec} \\ \mathrm{cc} \end{array} \right\rvert\,$ | 4 <br> 4 <br> 4 <br> 4 <br> 3 <br> 3 | $\begin{array}{ll}3 & \mathrm{CS} \\ 3 & \mathrm{E4} \\ 3 & \mathrm{C4} \\ & \\ & \end{array}$ | 5 3 <br> 4 3 | 1 2 2 2 | 2 |  |  |  |  | C' | 52 | 201 | , 5 | 2 dos | OS 4 | 2 | OD | 4 |  | 09.4 | 3 |  |  |  |  |  |  |  |
| $\begin{aligned} & \hline \text { DEC } \\ & \text { DEX } \\ & \text { DEY } \\ & \text { EOR } \\ & \text { INC } \\ & \hline \end{aligned}$ | $\begin{array}{ll} \hline M-1+M & \\ x-1+x & \\ Y-1+Y & \\ A Y M-A & (1) \\ M+1-M & \\ \hline \end{array}$ | 49 | 2 |  |  | 6  <br> 4  <br> 4 3 <br> 6 3 |  |  | 2 | 2 |  |  |  |  | 4 | 6 | 2 | 5 |  |  |  |  |  |  | 59. | 3 |  |  |  |  |  |  | DEC |
| $\begin{aligned} & \text { INX } \\ & \text { INY } \\ & \text { JMP } \\ & \text { JSR } \\ & \text { LOA } \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline x+1-x \\ & y+1-y \\ & \text { JUMP TO NEWLOC } \\ & \text { JUMP SUB } \\ & M \rightarrow A \end{aligned}$ | ${ }^{\text {A }}$ 9 | 2 |  |  | 3 3 <br> 6 3 <br> 4 3 | 3 3 3 ${ }_{\text {AS }}$ |  | ${ }_{2}$ |  |  |  |  | $2{ }_{2}{ }^{2}$, | A1 |  | 2.81 | 15 |  | 85 |  | B0 | ¢ |  | 89. | - |  | 6 C | 53 |  |  |  |  |
| $\begin{aligned} & \text { LDX } \\ & \text { LDY } \\ & \text { LSA } \\ & \text { NOP } \\ & \text { ORA } \\ & \hline \end{aligned}$ |  | ${ }^{A_{2}}{ }^{10}$ | 2 |  | $\begin{aligned} & A E \\ & A C \\ & A E \\ & A E \\ & 00 \end{aligned}$ |  | $\begin{array}{\|l\|l\|} \hline 3 & A 6 \\ 3 & A 4 \\ 3 & 46 \\ \hline & \\ \hline & \\ \hline \end{array}$ |  | $2$ |  | 2 | , | $\mathrm{EA}^{2}$ | 2. |  |  |  |  |  |  | $\begin{array}{l\|l} 4 & 2 \\ 6 & 2 \\ 2 & 2 \\ 4 & 2 \end{array}$ |  |  | $\begin{array}{\|l\|l\|} \hline & 9 E \\ 3 & \\ 3 & \\ \hline & 19 \\ \hline \end{array}$ |  |  |  |  |  | 85 | $2 \begin{aligned} & 2 \\ & \\ & \\ & \\ & \\ & \\ & \\ & \end{aligned}$ |  | $\begin{aligned} & \hline \text { LOX } \\ & \text { LOY } \\ & \text { LSR } \\ & \text { NOP } \\ & \text { ORA } \\ & \hline \end{aligned}$ |
| $\begin{aligned} & \mathrm{PHA} \\ & \mathrm{PHP} \\ & \mathrm{PLA} \\ & \mathrm{PLP} \\ & \mathrm{AOL} \\ & \hline \end{aligned}$ |  |  |  |  |  |  |  | 6 |  |  | 2 |  |  | 3 ${ }_{3}^{\prime}$ <br> 4  <br> 4 1 |  |  |  |  |  | 366 |  |  | \% |  |  |  |  |  |  |  |  |  | PHA <br> PHP <br> PLA <br> PLP <br> ROL <br> AOA |
| $\begin{align*} & \hline \text { ROR } \\ & \text { CTH } \\ & \text { RTS } \\ & \text { SBC }  \tag{1}\\ & \text { SEC } \\ & \text { SEO } \end{align*}$ | C[ RTRNINT htan sub $\begin{aligned} & A-M-\bar{C}-A \\ & 1-C \\ & i \rightarrow 0 \end{aligned}$ | E9 | 2 |  |  | ${ }_{6}^{6}{ }_{4}^{3}$ |  | 5 | $2$ |  | 2 |  | 40 6 <br> 60 6 <br>  68 <br> 38 2 <br> F8, 2 | 6 1 <br> 6 1 <br> 2 1 <br> 2 1 | $\epsilon_{1}$ | 6 | 2 F | 5 | $\int_{2}^{76}$ | $\begin{array}{\|c\|c} \hline 76 & 6 \\ \hline F 5 & 4 \end{array}$ | $\begin{array}{l\|l} 6 & 2 \\ 4 & 2 \\ 4 \end{array}$ | $\begin{gathered} 2 / \mathrm{TE} \\ 2^{2} \\ \hline \mathrm{FO} \end{gathered}$ |  | $\begin{aligned} & 3 \\ & 3 \end{aligned}$ | f9 | 3 |  |  |  |  |  |  | AOR <br> RTI <br> RTS <br> SBC <br> SEC <br> SEO <br> SEC |
| SEEI STA STA STr TAX Star | P-1 $A \rightarrow M$ $X \rightarrow M$ $H \rightarrow M$ $A-X$ |  |  |  | $\left\|\begin{array}{l} \mathrm{BD} \\ \mathrm{BE} \\ \mathrm{AC} \end{array}\right\|$ | 4 <br> 4 <br> 4 <br> 4 <br> 4 <br> 3 | 3 85 <br> 3 86 <br> 3 84 <br>  84 <br>   | 5 | 2 2 2 | 2 |  |  |  |  | 81 | 6 | 291 | 6. |  |  | 42 | 90 | 5 | 39 | 99 | 3 |  |  |  | 96 | 2 | . . $\cdots$ $\cdots$ | SEE <br> STA <br> STA <br> STA <br> STY <br> TAX <br> HAY |
|  | $\begin{aligned} & A-y \\ & s-x \\ & x \rightarrow A \\ & x \rightarrow s \\ & y \rightarrow A \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  | AA 22 | 2 1 <br> 2 , <br> 2 , <br> 2 1 <br> 2 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | TAX <br> TAY <br> TSX <br> TXA <br> TXS <br> TYA |
|  |  |  |  |  |  |  |  | $\begin{aligned} & \text { ISCRO } \\ & \text { sTos. } \\ & \text { TOD } \\ & \hline \end{aligned}$ |  | zero | age <br> RES |  |  |  |  |  |  |  |  | ```indEX x INDEX Y accumulator memory pereffectiveadoress memory Pen stack pointea``` |  |  |  |  |  |  | $\stackrel{\wedge}{v}$ |  | ADD <br> subtract <br> AND <br> OA <br> EXCLUSIVE OA |  |  | M; MEMOAY BITT <br> $M_{0}$ MEMORY BITG <br> $n$ NO. CYCLES <br>   <br> no. BYTES  |  |



|  | ORDERING INFORMATION |  |  |
| :---: | :---: | :---: | :---: |
| Order | Package <br> Type | Frequency <br> Option | Temperature <br> Range |
| R650/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}$ |

## SIGNAL DESCRIPTIONS

All R6500/1 interface signals are provided in the Emulator device. While the Emulator pin assignments are different from the R6500/ 1 in order to accommodate the 64 -pin Emulator package, the interface electrical characteristics are identical. The Emulator device provides 24 additional signals to route the address bus (12 lines), the data bus ( 8 lines), and control signals ( 4 lines) off the chip for connection to external memory.

## MEMORY MAP

An additional 1024 bytes of memory (400-7FF) are addressable in the Emulator device to support software development.

| $\phi 2=1$ | 64 | $\square \times$ TLO |
| :---: | :---: | :---: |
| vss ${ }^{1}$ | 63 | РхтL! |
| RDYE3 | 62 | R/ |
| AES -4 | 69 | PPCO |
| Nाला ${ }^{5}$ | 60 | PPC1 |
| sVnc ${ }^{\text {a }}$ | 59 | PC2 |
| PB7C | 58 | $\mathrm{PPC3}^{\text {Pra }}$ |
| PB6 ${ }^{8}$ | B7 | PPC4 |
| PB5 ${ }^{\text {a }}$ | 56 | Pcs |
| P84 ${ }^{10}$ | 58 | PPCs |
| P83 11 | 54 | PPC7 |
| P82 ${ }^{12}$ | 53 | $\square 00$ |
| P81県 | 52 | ص01 |
| P80 14 | 61 | D2 |
| PA7C ${ }^{15}$ | 50 | ص03 |
| PA6 - ${ }^{16}$ | 49 | D4 |
| PAS ${ }^{17}$ | 48 | ص05 |
| PA4 ${ }^{-18}$ | 47 | 卫ס6 |
| PA3 ${ }^{19}$ | 48 | - |
| PA2 ${ }^{-1} 20$ | 45 | $\square \mathrm{PD7}$ |
| PA1E ${ }^{21}$ | 44 | Pos |
| PAOC ${ }^{22}$ | 43 | PPDS |
| VAR - ${ }^{23}$ | 42 | Pro4 |
| CNTR $\mathrm{H}^{24}$ | 41 | Pro3 |
| A0- ${ }^{25}$ | 40 | $\square \mathrm{PD2}$ |
| A15 ${ }^{20}$ | 39 | $\square \mathrm{PO} 1$ |
| A2 ${ }^{-17}$ | 38 | P PDo |
| A3-128 | 37 | PA11 |
| $44{ }^{-12}$ | 36 | Pa10 |
| 45 - 30 | 35 | as |
| $46{ }^{41}$ | 34 | [ A8 |
| A7 ${ }^{-12}$ | 33 | صvcc |

## R6500/IE Pin Configuration

## R6500 Microcomputer System DATA SHEET SUPPLEMENT

## R6500/1E EMULATOR DEVICE

## EXTERNAL FREQUENCY REFERENCE

The external frequency reference may be a crystal or a clock the RC option is not available in the Emulator device.

## I/O PORT PULLUPS

The R6500/1E has the internal I/O port pullup resistance only.

R6500/1E DEVICE ADDITIONAL SIGNALS

| Signal |
| :--- |
| Name |
| $R / \bar{W}$ |

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 any cycle except a write cycle. A negative transition to the low state during the $\phi 2$ clock low pulse will halt the CPU with the address lines containing the current address being fatched. If RDY is low during a write cycle, it is ignored until the following read operation. This condition will remain through a subsequent $\mathbf{\Phi} 2$ clock pulse in which the RDY line is low.
Sync. The Sync signal is provided to identify those cycles in which the CPU is performing an OP CODE fetch. SYNC goes high during $\phi 2$ clock-low pulse during an OP CODE fetch and stays high for the remainder of that cycle. If the RDY line is pulled low during the $\phi 2$ clock low pulse in which SYNC went high, the CPU will halt in ite current state and will remain in that state untll the RDY line goes high. Using this technique, the SYNC signal can be used to control RDY to cause single instruction execution.
\$2 1 Phase 2 ( $\phi 2$ ) clock pulse. Data transfer can take place only during $\$ 2$ clock pulse.
A0-A11 25-32 Address Bus Lines. The address bus buffers on 34-37 the R6500/1E are push/pull type drivers capable of driving at least 130 pf and one standard TTL load. The address bus always contains known data. The addressing technique 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 addresses are also placed on these lines.

DO-D7 53-46
Data Bus Lines. All transfers of instructions and data between the CPU and external mernory 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.

Ports A, B, C and D and the CNTR line in R6500/1E are initialized to the logic high state two $\varnothing \mathbf{2}$ clock cycles earlier than in the $R 6500 / 1$. It is still required, however, that the $\overline{\operatorname{RES}}$ line to the $R 6500 / 1 \mathrm{E}$ be held low for at least eight $\boldsymbol{\phi} 2$ clock cycles after $V_{\text {CC }}$ reaches operating range.


## TYPICAL R6500/1E PROGRAM MEMORY INTERCONNECTIONS

Shown below are two typical connections between the R6500/1E and program memory (in this case, type 2716 and 2708 PROMS). Example 1 shows a connection to a 2 K 2716 PROM. Since the R6500/1 has a 2 K ROM capacity, the contents of the PROM could be masked directly into the production R6500/1 ROM.

Example 2 shows a connection to 3 K of 2708 PROMS. The extra 1 K PROM allows expanded or additional programs be used during R6500/1 firmware development. The production program, however, must be reduced to 2 K maximum (between addresses 800 and FFF) before committing to R6500/1 ROM.

EXAMPLE 1: R6500/1E Connected to One 2716 PROM (2K Bytes)


Memory Map


Truth Table

| Address |  | PROM Select |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A11 | A10 | $2708 \mathrm{No.3}$ <br> $\overline{\mathrm{CE}}$ | $2708 \mathrm{No.2}$ <br> $\overline{\mathrm{CE}}$ | $2808 \mathrm{No.1}$ <br> $\overline{\mathrm{CE}}$ | Selected <br> Address Range |
| 0 | 0 | 1 | 1 | 1 | $000-3 \mathrm{FF}$ |
| 0 | 1 | 1 | 1 | 0 | 400.7 FF |
| 1 | 0 | 1 | 0 | 1 | $800-\mathrm{BFF}$ |
| 1 | 1 | 0 | 1 | 1 | C00-FFF |

R6500/1 EMULATOR DEVICE TIMING

| Signal | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| R/W setup time from CPU | $T_{\text {RWS }}$ |  | 300 |  | 200 | ns |
| Address setup time from CPU | $\mathrm{T}_{\mathrm{ADS}}$ |  | 300 |  | 200 | ns |
| Memory read access time | $\mathrm{T}_{\text {ACC }}$ |  | 525 |  | 225 | ns |
| Data stabilization time | $T_{\text {DSU }}$ | 150 |  | 75 |  | ns |
| Data hold time - Read | $\mathrm{T}_{\mathrm{HR}}$ | 10 |  | 10 |  | ns |
| Data hold time - Write | $\mathrm{T}_{\mathrm{HW}}$ | 30 |  | 30 |  | ns |
| Data delay time from CPU | $T_{\text {MDS }}$ |  | 200 |  | 150 | ns |
| RDY setup time | $\mathrm{T}_{\text {RDY }}$ | 100 |  | 50 |  | ns |
| SYNC delay time from CPU | $\mathrm{T}_{\text {SYNC }}$ |  | 350 |  | 175 | ns |
| Address hold time | $T_{H A}$ | 30 |  | 30 |  | ns |
| $\mathrm{R} / \overline{\mathrm{W}}$ hold time | THRW | 30 |  | 30 |  | ns |
| Cycle Time | $\mathrm{T}_{\text {CYC }}$ | 1.0 | 10.0 | 0.5 | 10.0 | $\mu s$ |

R6500/1E TIMING DIAGRAMS
PHASE 2 ( $\phi 2$ ) TIMING REFERENCE

R6500/1E DETAILED MEMORY MAP


NOTES
(1) Additional 1024 bytes are decoded for external memory addressing by the R6500/1E Emulator Device. This area can be used during debug. but cannot be used in a masked ROM R6500/1.
2) 1/O command only; i.e., no stored data.
(3) Clears Counter Overflow - Bit 7 in Control Register
(4) CAUTION: The R6500/IE allows RAM mapping into $040-07 \mathrm{~F}$
$100.13 \mathrm{~F}, 140 \cdot 17 \mathrm{~F}, 200-23 \mathrm{~F}, 240 \cdot 27 \mathrm{~F}, 300-33 \mathrm{~F}$, and $34 \mathrm{~g}-37 \mathrm{~F}$; as well as 000.03 F . The production R6500/1, however allows RAM mapping only at $000-03 \mathrm{~F}$.

## ELECTRICAL CHARACTERISTICS

$\left(\mathrm{v}_{\mathrm{CC}}=5.0 \pm 5 \%, \mathrm{v}_{\mathrm{SS}}=0 . \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\right)$

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Threshold Voltage DO-D7, RDY, | $\mathrm{V}_{\mathrm{IHT}}$ | $\mathrm{VSS}^{+2.4}$ | - | - | Vde |
| Input Low Threshold Voltage DO-D7, RDY, | $V_{\text {ILT }}$ | - | - | $\mathrm{V}_{\mathrm{SS}}+0.8$ | Vde |
| Three State (Off State) Input Current $\left(\mathrm{V}=0.4 \text { to } 2.4 \mathrm{~V} . \mathrm{V}_{\mathrm{Cc}}=5.25 \mathrm{~V}\right)$ <br> DO-D7 | 'TSI | - - | - | 10 | $\mu \mathrm{A}$ |
| Output High Voltage $\begin{aligned} & { }^{\prime}{ }_{\text {LOAD }}=100 \mu \mathrm{Adc}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \text { ) } \\ & \text { DO-D7,SYNC, AO-A11, R/W}, \phi 2 \end{aligned}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\text {SS }}+2.4$ | - | - | Vde |
| Output Low Voltage $\begin{aligned} & \text { (I LOAD }=1.6 \text { mAdc, } V_{C C}=4.75 \mathrm{~V} \text { ) } \\ & \text { DO-D7. SYNC, AO-A11, } \mathrm{R} / \overline{\mathrm{W}} . \phi 2 \end{aligned}$ | $\mathrm{v}_{\mathrm{OL}}$ | - | - | $\mathrm{V}_{\text {SS }}+0.6$ | Vdc |
| Power Dissipation | $P_{\text {D }}$ | - | 0.75 | 1.20 | W |
| Capacitance $\begin{aligned} & \quad\left(V_{\text {in }}=0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right) \\ & \text { RDY } \\ & \text { DO-D7 } \\ & \text { AO-A11, R/ } \bar{W}, \text { SYNC } \\ & \text { ©2 } \end{aligned}$ | $\begin{aligned} & \mathrm{c} \\ & \mathrm{c}_{\text {in }} \\ & \mathrm{C}_{\text {out }} \\ & \mathrm{C}_{\phi 2} \end{aligned}$ | - | $50$ | $\begin{aligned} & 10 \\ & 15 \\ & 12 \\ & 80 \end{aligned}$ | pF |
| I/O Port Pull-up Resistance | $\mathrm{H}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | kohm |



NOTE: PIN NO. 1 IS IN LOWER LEFT CORNER WHEN SYMBOLIZATION IS IN NORMAL ORIENTATION

Packaging Diagram

## INTRODUCTION <br> The Rockwell R6500/1EB Backpack Emulator is the PROM prototyping version of the 8 -bit, masked-ROM R6500/1 one-chip microcomputer. Like the R6500/1, the R6500/1EB is totally upward/downward compatible with all members of the R6500 family. The R6500/1EB is designed to accept standard 5 -volt, 24-pin PROMs, 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.

R6500/1EB ВАСКРАСК EMULATOR

The R6500/1EB has the same pinouts as the masked-ROM 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 Data Sheet (Rockwell Document No. 29000051) 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.

ORDERING INFORMATION

| ORDER <br> NUMBER | MEMORY CAPACITY | COMPATIBLE MEMORIES | TEMPERATURE RANGE |
| :---: | :---: | :---: | :---: |
| R6500/1EB. 1 | 2K | $\begin{aligned} & 2716,2516, \\ & 82 S 2708, \\ & 2316 B \end{aligned}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| R6500/1EB-2 | 3K | $\begin{aligned} & 2532,2332, \\ & 8252708 \end{aligned}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| R6500/1EB-3 | 3 K | $\begin{aligned} & 2732, \\ & 82 S 2708 \end{aligned}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| R6500/1EB-4 | 1K | $\begin{aligned} & 2758, \\ & 8252708 \end{aligned}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |

## PRODUCT SUPPORT

The R6500/1EB Backpack Emulator is just one of the products that Rockwell offers to facilitate system and program development for the R6500/1. Additional support products include the R6500/1E, a 64-pin emulator device with interface lines for connecting external memory. Another support product is the R6500/1 Evaluation Module, which has 40 R6500/1-compatible pins and provision for inserting external memory.

Further, the SYSTEM 65 Microcomputer Development System 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. SYSTEM 65 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 2 K ROM of the R6500/1. In addition to support products, Rockwell offers regularly-secheduled designers courses at regional centers.


The available support products include:

- SYSTEM 65 Microcomputer Development System

P/N S65.101

- PROM Programmer Module
- 1-MHz R6500/1 Personality Module

P/N M65-040

- MHz R6500/1 Personality Module
/N M65-081
P/N M65-082
- 1-MHz R6500/1 Emulator Device

P/N R6500/1EC

- 2-MHz R6500/1 Emulator Device

P/N R6500/1EAC
P/N M65-089

## 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, PROMs, ROMs
- 4 K memories $-2532,2732,2332$ ( 3 K bytes addressable)
- 2K memories - 2716,2516,2316B

1 K memories - 2758, 82S2708

- Use as prototyping tool or for low volume production
- 3 K bytes of memory capacity ( $1 \mathrm{~K}, 2 \mathrm{~K}, 4 \mathrm{~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 extenal time base
- Single +5 V power supply


## R6500/1EB CONFIGURATIONS

The R6500/1EB is available in four different versions, to accommodate various 24 -pin 1 K . 2 K - and 4 K -memories. All four versions provide 64 bytes of RAM and I/O, as well as 24 signals to support the external memory "backpack" socket. The 24 backpack signals differ somewhat between versions (due to memory pin differences) but always consist of the address bus ( 12 lines), the data bus ( 8 lines) and the $\overline{O E}, \mathrm{Vcc}$, Vrr and Vss signals (one line each). See Interface Diagram.

The external memories must always occupy the upper 1 K of available memory (addresses 800 through FFF) for implementation of interrupt vectors. See Memory Map. The R6500/1EB provides a read block to the external memory where internal RAM or I/O are located at the same addresses as that occupied by external memory.

## EXTERNAL FREQUENCY REFERENCE

The external frequency reference may be a crystal or a clock - the RC option is not available in the emulator device.

## I/O PORT PULLUPS

The R6500/1EB has the internal $1 / O$ port pullup resistance only.

## TEST MODE DELETED

The test mode of the R6500/1 is not available on the R6500/1EB.

## R6500/1EB I/O PORT INITIALIZATION

Ports A, B, C, and D and the CNTR line in the R6500/1EB are initialized to the logic high state two 02 clock cycles earlier than in the R6500/1. The RES line to the R6500/1EB must, however, still be held low for at least eight $\emptyset 2$ clock cycles after Vcc reaches operating range. See timing diagram.

## RAM MAPPING

The R6500/1EB allows RAM mapping into 040-07F, 100-13F, 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-03 \mathrm{~F}$ The production R6500/1, however, allows RAM mapping only at $000-03 \mathrm{~F}$. This means that a write to location 40, for example, will write to location 0 in the R6500/1EB, and to invalid RAM in the R6500/1 production port.

R6500/1EB BACKPACK MEMORY SIGNAL DESCRIPTIU.

| SIGNAL NAME | PIN NO. | DESCRIPTION |
| :---: | :---: | :---: |
| DO-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 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 |
| AO-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. |
| A10 | 19 S | Address Bus Line 10. This address line has the same characteristics and functions as Lines AOA9. However, in the R6500/1EB-4, pin 19S is tied to Vss instead of to the address bus. |
| A11 | 18S+21S | Address Bus Line 11. This address line has the same characteristics and function as Lines A0-A9. In the R6500/1EB-1 and -4 versions, A11 is inverted by a standard TTL inverter before reach. ing pin 18S. In the R6500/1EB-2, A11 is connected directly to pin 18S. In the R6500/1EB-3. A11 is routed to pin 21 S and pin 18 S is tied to Vss. |
| $\overline{O E}$ | 205 | Memory Enable Line. This signal provides the output enable for the memory to place informa. tion 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}}$. |
| Vcc | 245 | Main Power Supply +5 V . This pin is tied directly to pin 30 ( Vcc ). |
| Vpp | 215 | Main Power Supply +5 V . This pin is tied directly to pin 30 (Vce), except in the R6500/1EB-3, where it is tied to A11. During backup power, power is supplied only to the RAM memory, and not to the PROMs. |
| Vss | 12 S | Signa: and Power Ground (zero volts). This pin is tied directly to pin 12 (Vss). |



-See R6500/1E8 Detailed Memory Map

R6500/1EB DEVICE TIMING

| Signal | Symbol | 1 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. |  |
| $\overline{\mathrm{OE}}$ setup time from CPU | ${ }^{\text {T OES }}$ |  | 300 | ns |
| Address setup time from CPU | ${ }^{T} \text { ADS }$ |  | 300 | ns |
| Memory read access time | $T_{\text {ACC }}$ |  | 525 | ns |
| Data stabilization time | $T_{\text {DSU }}$ | 150 |  | ns |
| Data hold time - Read | $\mathrm{T}_{\mathrm{HR}}$ | 10 |  | ns |
| Address hold time | $\mathrm{T}_{\mathrm{HA}}$ | 30 |  | ns |
| $\overline{\text { OE }}$ hold time | $\mathrm{T}_{\text {HOE }}$ | 30 |  | ns |
| Cycle Time | ${ }^{T}$ CYC | 1.0 | 10.0 | $\mu \mathrm{s}$ |



R6500/1EB I/O Port Initialization Timing Diagram


## notes

(1) Additional 1024 bytes are decoded for external memory addressing by the R6500/1EB Emulator Device. This area can be used during debug. the R6500/1EB Emulator Device. This area can b
(2) 1/O command onty: i.e., no stored data.
(3) Clears Counter Overflow - Bit 7 in Control Register
(4) CAUTION: The R6500/1EB allows RAM mapping into 040-07F 100-13F, 140-17F, 200-23F, 240-27 F, 300-33F, and 340-37 F: as well as $000 \cdot 03 F$. The production R6500/1, however allows RAM mapping only at $000-03 F$.


## ELECTRICAL CHARACTERISTICS

$\left(V_{C C}=5.0 \pm 5 \%, V_{S S}=0, T_{A}=25^{\circ} \mathrm{C}\right)$

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Threshold Voltage D0-D7 | $V_{\text {IHT }}$ | $\mathrm{V}_{\mathrm{SS}}+2.4$ | - | - | Vdc |
| Input Low Threshold Voltage DO-D7 | $V_{\text {ILT }}$ | - | - | $\mathrm{V}_{S S}+0.8$ | Vdc |
| Three-State (Off State) Input Current $\begin{aligned} & \left(\mathrm{V}=0.4 \text { to } 2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}\right) \\ & \mathrm{DO}-\mathrm{D} 7 \end{aligned}$ | ${ }^{\prime} \mathrm{TSI}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Output High Voltage $\begin{aligned} & \left(1{ }_{\text {LOAD }}=100 \mu \text { Adc, } V_{C C}=4.75 \mathrm{~V}\right) \\ & \text { DO-D7, AO-A11, } \overline{O E} \end{aligned}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{SS}}+2.4$ | - | - | Vdc |
| Output Low Voltage $\begin{aligned} & \left(1_{\text {LOAD }}=1.6 \mathrm{mAdc}, V_{C C}=4.75 \mathrm{~V}\right) \\ & \text { DO-D7, AO-A11, } \overline{O E} \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | $\mathrm{V}_{\text {SS }}+0.6$ | Vdc |
| Power Dissipation | ${ }^{P}$ | - | 0.80 | 1.30 | W |
| Capacitance $\begin{aligned} & \quad\left(\mathrm{V}_{\text {in }}=0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right) \\ & \text { DO-D7 } \\ & \text { AO-A11 } \end{aligned}$ | C $\begin{aligned} & c_{\text {in }} \\ & c_{\text {out }} \end{aligned}$ | - | - | $\begin{aligned} & 15 \\ & 12 \end{aligned}$ | pF |
| 1/O Port Pull-up Resistance | $\mathrm{R}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | kohm |



## PART NUMBER

# R6500 Microcomputer System PRODUCT PREVIEW 

## R6500/1-11 ONE-CHIP MICROCOMPUTER

## INTRODUCTION

The Rockwell R6500/1-11 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/1-11 consists of an enhanced 6502 CPU, an internal clock oscillator, 3072 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.

## DEVELOPMENT SUPPORT

To allow prototype circuit development, Rockwell offers a PROM-compatible 64-pin Emulator device. This device, the R6500/2-11, provides all R6500/1-11 interface lines, plus the address bus, data bus and control lines to interface with external memory. The R6500/2-11 may also be used as a CPU-RAM-I/O counter device in multichip systems.
Rockwell supports development of the R6500/1-11 with the System 65 Microcomputer Development System and the R6500/1-11 Personality Module. Complete in-circuit emulation with the R6500/1-11 Personality Module allows total system test and evaluation.


[^0]Interface Diagram

## FEATURES

- Enhanced 6502 CPU
-Four new 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
- 192-byte static RAM
- 32 bidirectional, TTL-compatible V/O lines (four ports)
- 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 measurement
-Pulse generation
-Interval timer
-Event counter
- Serial port
-Full-duplex asynchronous operation mode
-Synchronous shift register mode
-Selectable 5- to 8 -bit characters
-Wake-up feature
—Programmable bit rates to 62.5 bits $/ \mathrm{sec}$ (@ 2 MHz )
- Four edge-sensitive lines; two positive, two negative
- Ten interrupts
—Reset
-Non-maskable
-Four extemal, edge-sensitive
-Two counter
-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 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
- NMOS-3 silicon gate, depletion load technology
- Single +5 V power supply
- 16 mW stand-by power for 32 bytes of the 192-byte RAM
- 40-pin DIP


## ELECTRICAL SPECIFICATIONS

## Maximum Ratings

| Rating | Symboi | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{\text {cc }}$ | -0.3 to +7.0 | Vdc |
| Input Voitage | $V_{\text {in }}$ | -0.3 to +7.0 | Vdc |
| Operating Temperature Range, Commercial Industrial | T | $\begin{array}{r} 0 \text { to }+70 \\ -40 \text { to }+85 \\ \hline \end{array}$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $\mathrm{T}_{\text {utg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

This device contains 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 higher than maximum rated voltages to this circuit.
D. C. Characteristics $\left(V_{c c}-5 V \pm 5 \% V_{s s}-0\right)$

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipation (Outputs High) <br> Commercial @ $\mathbf{2 5}{ }^{\circ} \mathrm{C}$ <br> Industrial @ 25 ${ }^{\circ} \mathrm{C}$ | $P_{0}$ | $-$ |  | $\begin{aligned} & 1000 \\ & 1200 \end{aligned}$ | mW |
| RAM Standby Voltage (Retention Mode) | $V_{\text {nn }}$ | 3.0 | - | $V_{\text {cc }}$ | $V \mathrm{dc}$ |
| PAM Standby Current (Retention Mode) <br> Commercial @ $25^{\circ} \mathrm{C}$ <br> Industrial @ $25^{\circ} \mathrm{C}$ | $I_{\text {k }}$ | - | $5.2$ | - | madc |
| Input High Voltage (Except XTLI) | $\mathrm{V}_{\mathbf{H}}$ | +2.0 | - | $V_{c c}$ | Vdc |
| Input High Voltage (XTLI) | $\mathrm{V}_{\mathrm{H}}$ | +4.0 | - | $V_{c c}$ | Vdc |
| Input Low Voltage | $V_{\text {IL }}$ | -0.3 | - | +0.8 | Vdc |
| Input Leakage Current (RES, NMI) $V_{\text {in }}=0 \text { to } 5.0 \mathrm{Vdc}$ | lım |  | $\pm 1.0$ | $\pm 2.5$ | $\mu A d c$ |
| Input Low Current PA, PB, PC, PD $\left(V_{i l}=0.4 \mathrm{Vdc}\right)$ | In | - | -1.0 | -1.6 | mAdc |
| Output High Voltage Except XTLO $\left(I_{\text {Loed }}=.100 \mu \mathrm{Adc}\right)$ | $\mathrm{V}_{\text {OH }}$ | +2.4 | - | - | Vdc |
| $\begin{aligned} & \text { Output Low Voltage } \\ & \qquad\left(I_{\text {Lous }}=1.6 \mathrm{mAdc}\right) \end{aligned}$ | $V_{a}$ | - | - | +0.4 | Vdc |
| Input Capacitance $\left(V_{\text {in }}-0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{t}=1.0 \mathrm{MHz}\right)$ <br> PA, PB, PC, PD <br> XTLI, XTLO | $C_{\text {In }}$ | - | 一 | $\begin{aligned} & 10 \\ & 50 \\ & \hline \end{aligned}$ | pF |
| VO Port Pull-Up Resistance PAO-PA7, PB0-PB7, PCO-PC7, PD0-PD7 | $\mathrm{P}_{4}$ | 3.0 | 6.0 | 11.5 | $\mathrm{K} \Omega$ |

NOTE: Negative sign indicates outward current fiow, positive indicates inward flow.
AC Characteristics ( $\mathrm{V}_{\mathrm{cc}}-5 \mathrm{~V} \pm 5 \% \mathrm{~V}_{\mathrm{ss}}$ - 0 )

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| XTLI Input Clock Cycle Time | $\mathrm{T}_{\text {ere }}$ | 0.500 | 5.0 | 0.250 | 5.0 | $\mu \mathrm{sec}$ |
| Intemal Write to Peripheral Data Valid (TTL) | Trow | 1.0 |  | 0.5 |  | $\mu \mathrm{sec}$ |
| Peripheral Data Setup Time | $\mathrm{T}_{\text {rosu }}$ | 400 |  | 200 |  | nsec |
| Count and Edge Detect Pulse Width | $\mathrm{T}_{\text {w }}$ | 1.0 |  | 0.5 |  | $\mu \mathrm{sec}$ |

## R6500 Microcomputer System PRODUCT PREVIEW

## R6500/1-11Q ONE-CHIP MICROCOMPUTER

## INTRODUCTION

The Rockwell R6500/1-11Q 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/1-11Q consists of an enhanced 6502 CPU, an internal clock oscillator, 3072 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, 56 bidirectional input/output lines (including four edgesensitive lines and input latching on one 8 -bit port), a full-duplex serial VO channel, ten interrupts and bus expandability.

## DEVELOPMENT SUPPORT

To allow prototype circuit development, Rockwell offers a PROMcompatible 64-pin Emulator device. This device, the R6500/2-11, provides all R6500/1-11Q interface lines (except Ports E, F and G), plus the address bus, data bus and control lines to interface with external memory. The R6500/2-11 may also be used as a CPU-RAMVO counter device in multichip systems.

-MULTIPLEXED FUNCTIȮN PINS (Software Selectable)
Interface Diagram

Rockwell supports development of the R6500/1-11Q with the System 65 Microcomputer Development System and the R6500/1-11 Personality Module. Complete in-circuit emulation with the R6500/ 1-11Q Personality Module allows total system test and evaluation.

## FEATURES

- Enhanced 6502 CPU
-Four new 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
- 192-byte static RAM
- 56 bidirectional, TTL-compatible I/O lines (seven ports)
- One 8-bit port may be tri-stated under software control
- One 8-bit port has Darlington drive capability
- One 8-bit port with programmable latched input
- Two 16-bit programmable counter/timers, with latches
-Pulse measurement
-Pulse generation
- Interval timer
-Event counter
- Serial port
-Full-duplex asynchronous operation mode
-Synchronous shift register mode
-Selectable 5- to 8-bit characters
-Wake-up feature
—Programmable bit rates to 62.5 bits/sec (@ 2 MHz )
- Four edge-sensitive lines; two positive, two negative
- Ten interrupts
-Reset
-Non-maskable
-Four extemal, edge-sensitive
- Two counter
-Serial data received
-Serial data transmitted
- Bus expandable to 16 K bytes of extemal memory
- Flexible clock circuitry
$-2-\mathrm{MHz}$ or $1-\mathrm{MHz}$ internal operation
-Internal clock with extemal 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
- NMOS-3 silicon gate, depletion load technology
- Single +5V power supply
- 16 mW stand-by power for 32 bytes of the 192-byte RAM
- 64-pin QUIP


## ELECTRICAL SPECIFICATIONS

Maximum Ratinga

| Rating | Symbol |  |  |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $V_{c \mathrm{C}}$ | Unit |  |
| Input Voltage | $V_{\text {in }}$ | -0.3 to +7.0 |  |
| Operating Temperature Range, Commercial |  |  |  |
|  | Industriai | T | -0.3 to +7.0 |
| Storage Temperature Range | 0 Vdc |  |  |

This device contains 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 higher than maximum rated voltages to this circuit.
D.C. Characteristice $\left(V_{C C}=5 \mathrm{~V} \pm 5 \% V_{c c}=0\right.$ )

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipation (Outputs High) Commercial @ $25^{\circ} \mathrm{C}$ Industrial @ $25^{\circ} \mathrm{C}$ | $P_{\text {D }}$ | - |  | $\begin{aligned} & 1000 \\ & 1200 \end{aligned}$ | mW |
| RAM Standby Voltage (Retention Mode) | $V_{\text {AR }}$ | 3.0 | - | $V_{\text {cc }}$ | Vdc |
| RAM Standby Current (Retention Mode) Commercial @ $25^{\circ} \mathrm{C}$ Industrial @ $25^{\circ} \mathrm{C}$ | $\mathrm{I}_{\text {RR }}$ |  | $\begin{aligned} & 4 \\ & 5.2 \end{aligned}$ |  | madc |
| Input High Voltage (Except XTLI) | $V_{\text {IH }}$ | +2.0 | - | $V_{c c}$ | Voc |
| Input High Voltage (XTLI) | $V_{\text {IH }}$ | +4.0 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Input Low Voltage | $V_{\text {IL }}$ | -0.3 | - | +0.8 | Vode |
| Input Leakage Current (RES, NMI) $V_{1 \mathrm{n}}=0 \text { to } 5.0 \mathrm{Vdc}$ | $\mathrm{I}_{\text {IN }}$ |  | $\pm 1.0$ | $\pm 2.5$ | $\mu \mathrm{Adc}$ |
| Input Low Current PA, PB, PC, PD, PF, and PG $\left(V_{11}=0.4 \mathrm{Vdc}\right)$ | IIL | - | -1.0 | -1.6 | mAdc |
| Output High Voltage Except XTLO $\left(l_{\text {Load }}=.100 \mu \mathrm{Adc}\right)$ | $\mathrm{V}_{\mathrm{OH}}$ | +2.4 | - | - | Vde |
| Output Low Voltage $\left(l_{\text {Load }}=1.6 \mathrm{mAdc}\right)$ | VoL | - | - | +0.4 | Voc |
| Dartington Current Drive, PEO~PE7 $\left(\mathrm{V}_{0}=1.5 \mathrm{Vdc}\right)$ | $\mathrm{IOH}^{\text {}}$ | -1.0 | - | - | made |
| $\begin{aligned} & \text { Output Low Voltage, PEO~PE7 } \\ & \text { (Loasd }=10 \mathrm{mAdc} \text { sink) } \end{aligned}$ | Vou | - | - | 1.0 | Vdc |
| Input Capacitance $\left(V_{\text {in }}-0, T_{A}=25^{\circ} \mathrm{C}, f=1.0 \mathrm{MHz}\right)$ <br> $\mathrm{PA}, \mathrm{PB}, \mathrm{PC}, \mathrm{PD}, \mathrm{PF}$, and PG XTLI, XTLO | $\mathrm{C}_{\text {in }}$ | 二 | 三 | $\begin{aligned} & 10 \\ & 50 \\ & \hline \end{aligned}$ | pF |
| VO Port Pull-Up Resistance <br> PAO-PA7, PBO-PB7, PCO-PC7, PDO-PD7, PFO-PF7 \& PGO-PG7 | $\mathrm{R}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | $\mathrm{K} \Omega$ |

NOTE: Negative sign indicates outward current flow, positive indicates imward flow.
AC Characterlatice $N_{C C}=5 \mathrm{~V} \pm 5 \% \mathrm{~V}_{\mathrm{SS}}=0$ )

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| XTLI Input Clock Cycle Time | T cyc | 0.500 | 5.0 | 0.250 | 5.0 | $\mu \mathrm{sec}$ |
| Internal Write to Peripheral Data Valid (TTL) | Tpow | 1.0 |  | 0.5 |  | $\mu \mathrm{sec}$ |
| Peripheral Data Setup Time | TpDSU | 400 |  | 200 |  | nsec |
| Count and Edge Detect Pulse Width | $\mathrm{T}_{\text {PW }}$ | 1.0 |  | 0.5 |  | $\mu \mathrm{sec}$ |

## R6500 Microcomputer System PRODUCT PREVIEW

## R6500/2-11 EXTENDED MICROPROCESSOR

## INTRODUCTION

The Rockwell R6500/2-11 is a CPU-//O-RAM-counter/timer device on a single chip. Interfacing it with extemal memory makes a powerful two-chip microcomputer system. The R6500/2-11 features an enhanced 6502 instruction set that is software-compatible with all members of the R6500 family.

The R6500/2-11 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 and ten interrupts.

## DEVELOPMENT SUPPORT

The R6500/2-11 can be used to support development of both the R6500/1-11 and R6500/1-11Q single-chip microcomputers. These microcomputer devices are described in Rockwell Documents 29000 D64 and 29000 D65, respectively. Rockwell also offers development support, including in-circuit emulation, with the System 65 Microcomputer Development System and the R6500/1-11 Personality Module.


## FEATURES

- Enhanced 6502 CPU
-Four new 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
-65K-byte addressing
- 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 with programmable latched input
- Two 16-bit programmable counter/timers, with latches
--Pulse measurement
-Pulse generation
-Interval timer
-Event counter
- Serial port
-Full-duplex asynchronous operation mode
-Synchronous shift register mode
-Selectable 5- to 8 -bit characters
-Wake-up feature
—Programmable bit rates to 62.5 bits/sec (@ 2 MHz )
- Four edge-sensitive lines; two positive, two negative
- Ten interrupts
-Reset
-Non-maskable
-Four external, edge-sensitive
-Two counter
-Serial data received
-Serial data transmitted
- Flexible clock circuitry
-2-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
- NMOS-3 silicon gate, depletion load technology
- Single +5V power supply
- 16 mW stand-by power for 32 bytes of the 192-byte RAM
- 64-pin QUIP
- Rockwell Intemational Corpoation 1980
All Rights Reserved
Printed in U.S.A.

Printed in U.S.A.

## ELECTRICAL SPECIFICATIONS

Maxdmum Rating:

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{\text {cc }}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $V_{\text {In }}$ | -0.3 to +7.0 | Vdc |
| Operating Temperature Range, Commercial Industrial | T | $\begin{array}{r} 0 \text { to }+70 \\ -40 \text { to }+85 \end{array}$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $\mathrm{T}_{\text {sto }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

This device contains 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 higher than maximum rated voltages to this circuit.
D. C. Characterlatica $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \% \mathrm{~V}_{\mathrm{SS}}=0$ )

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipation (Outputs High) Commercial @ $25^{\circ} \mathrm{C}$ Industrial @ $\mathbf{2 5}^{\circ} \mathrm{C}$ | $P_{\text {D }}$ | $-$ |  | $\begin{aligned} & 1000 \\ & 1200 \end{aligned}$ | mW |
| RAM Standoy Voltage (Retèntion Mode) | $V_{\text {RA }}$ | 3.0 | - | $\mathrm{V}_{\text {cc }}$ | Vdc |
| RAM Standby Current (Retention Mode) Commercial @ $25^{\circ} \mathrm{C}$ Industrial @ $25^{\circ} \mathrm{C}$ | $\mathrm{I}_{\text {fR }}$ |  | $\begin{aligned} & 4 \\ & 5.2 \end{aligned}$ | - | mWdc |
| Input High Voltage Except XTLI | $\mathrm{V}_{\text {IH }}$ | +2.0 | - | $V_{\text {cc }}$ | Vdc |
| Input High Voltage (XTLI) | $V_{\text {IH }}$ | +4.0 | - | $V_{\text {cc }}$ | Vdc |
| Input Low Voltage | $\mathrm{V}_{12}$ | -0.3 | - | +0.8 | Vbc |
| Input Leakage Current (RES, NMI) $V_{\text {in }}=0 \text { to } 5.0 \mathrm{Vdc}$ | IN |  | $\pm 1.0$ | $\pm 2.5$ | $\mu \mathrm{Adc}$ |
| Input Low Current PA, PB, PC, PD $\left(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{Vdc}\right)$ | IIL | - | -1.0 | -1.6 | mWdc |
| Output High Voltage Except XTLO $\left(\mathrm{l}_{\text {Load }}=.100 \mu \mathrm{AdC}\right)$ | $\mathrm{V}_{\mathrm{OH}}$ | +2.4 | - | - | Vdc |
| Output Low Voltage ( $\mathrm{l}_{\text {Load }}=1.6 \mathrm{mAdc}$ ) | VaL | - | - | +0.4 | Vdc |
| Input Capacitance $\begin{aligned} & \left.\mathrm{V}_{\mathrm{In}}-0, T_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{t}=1.0 \mathrm{MHz}\right) \\ & \text { PA, PB, PC, PD } \\ & \text { XTLI, XTLO } \end{aligned}$ | $\mathrm{C}_{\text {in }}$ | - | - | $\begin{aligned} & 10 \\ & 50 \end{aligned}$ | pF |
| I/O Port Pull-Up Resistance PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7 | $\mathbf{R}_{\mathbf{L}}$ | 3.0 | 6.0 | 11.5 | K $\Omega$ |

NOTE: Negative sign indicates outward current flow, positive indicates inward flow.
AC Characteristica ( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \% \mathrm{~V}_{\mathrm{ss}}=0$ )

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| XTLI Input Clock Cyde Time | $\mathrm{T}_{\text {cyc }}$ | 0.500 | 5.0 | 0.250 | 5.0 | $\mu \mathrm{sec}$ |
| Internal Write to Peripheral Data Valid (TTL) | $T_{\text {Pow }}$ | 1.0 |  | 0.5 |  | $\mu \mathrm{sec}$ |
| Peripheral Data Setup Time | Tposu | 400 |  | 200 |  | nsec |
| Count and Edge Detect Pulse Width | $T_{\text {PW }}$ | 1.0 |  | 0.5 |  | $\mu \mathrm{sec}$ |

유욷으를

## R6500 Microcomputer System DATA SHEET

## PERIPHERAL INTERFACE ADAPTER (PIA)

## DESCRIPTION

The R6520 Peripheral Interface Adapter 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 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 $\dot{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 for "hand-shaking" data between the processor and a peripheral device.

Ordering information
Order Number: R6520 - - Temperature Range No suffix $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$E=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Industrial)
MT $=-55^{\circ} \mathrm{C}$ to $+125^{\circ} \mathrm{C}$
(Military)
M $=$ MIL-STD-883, Class B
$C=$ Ceramic
$\mathrm{P}=$ Plastic
(Not Available for
M or MT suffix)
Frequency Range:
No suffix $=1 \mathrm{MHz}$
$A=2 \mathrm{MHz}$
NOTE: Contact your local Rockwell Representative concerning availability.


Basic R6520 Interface Diagram

## SUMMARY OF R6520 OPERATION

See Rockwell Microcomputer Hardware Manual for detailed description of R6520 operation.

## CA1/CB1 Control

| CRA (CRB) |  | Active Transition of Input Signal* | IRQA (IRQB) Interrupt Outputs |
| :---: | :---: | :---: | :---: |
| Bit 1 | Bit 0 |  |  |
| 0 | 0 | Negative | Disable.- remain high |
| 0 | 1 | Negative | Enable - goes low when bit 7 in CRA (CRB) is set by active transition of signal on CA1 (CB1) |
| 1 | 0 | Positive | Disable - remain high |
| 1 | 1 | Positive | Enable - as explained above |

*Note: Bit 7 of CRA (CRB) will be set to a logic 1 by an active transition of the CA1 (CB1) signal. This is independent of the state of Bit 0 in CRA (CRB).

CA2/CB2 Input Modes

| CRA (CRB) |  |  | Active Transition of Input Signal* | IRQA (IRQB) Interrupt Output |
| :---: | :---: | :---: | :---: | :---: |
| Bit 5 | Bit 4 | Bit 3 |  |  |
| 0 | 0 | 0 | Negative | Disable - remains high |
| 0 | 0 | 1 | Negative | Enable - goes low when bit 6 in CRA (CRB) is set by active transition of signal on CA2 (CB2) |
| 0 | 1 | 0 | Positive | Disable - remains high |
| 0 | 1 | 1 | Positive | Enable - as explained above |

Note: Bit 6 of CRA (CRB) will be set to a logic 1 by an active transition of the CA2 (CB2) signal. This is independent of the state of Bit 3 in CRA (CRB).

CA2 Output Modes

| CRA |  |  | Mode | Description |
| :---: | :---: | :---: | :---: | :---: |
| Bit 5 | Bit 4 | Bit 3 |  |  |
| 1 | 0 | 0 | 'Handshake" on Read | CA2 is set high on an active transition of the CA1 interrupt input signal and set low by a microprocessor "Read A Data" operation. This allows positive control of data transfers from the peripheral device to the microprocessor. |
| 1 | 0 | 1 | Pulse Output | CA2 goes low for one cycle after a "Read A Data" operation. This pulse can be used to signal the peripheral device that data was taken. |
| 1 | 1 | 0 | Manual Output | CA2 set low |
| 1 | 1 | 1 | Manual Output | CA2 set high |

CB2 Output Modes

| CRB |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Bit 5 | Bit 4 | Bit 3 | Mode |  |
| 1 | 0 | 0 | "Handshake" <br> on Write | CB2 is set low on microprocessor 'Write B Data" operation and is set high by an active <br> transition of the CB1 interrupt input signal. This allows positive control of data trans- <br> fers from the microprocessor to the peripheral device. <br> CB2 goes low for one cycle after a microprocessor "Write B Data" operation. This <br> can be used to signal the peripheral device that data is available. <br> 1 |
| 1 | 1 | 1 | Pulse Output | Manual Output <br> 1 |

## A.C. CHARACTERISTICS

Read Timing Characteristics (Loading 130 pF and one TTL load)

| Characteristics | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Delay Time, Address valid to Enable positive transition | $T_{\text {AEW }}$ | 180 | - | 90 | - | ns |
| Delay Time, Enable positive transition to Data valid on bus | TEDR | - | 395 | - | 190 | ns |
| Peripheral Data Setup Time | $\mathrm{T}_{\text {PDSU }}$ | 300 | - | 150 | - | ns |
| Data Bus Hold Time | $\mathrm{T}_{\text {HR }}$ | 10 | - | 10 | - | ns |
| Delay Time, Enable negative transition to CA2 negative transition | ${ }^{T}$ CA2 | - | 1.0 | - | 0.5 | $\mu \mathrm{s}$ |
| Delay Time, Enable negative transition to CA2 positive transition | $\mathrm{T}_{\text {RS1 }}$ | - | 1.0 | - | 0.5 | $\mu \mathrm{s}$ |
| Rise and Fall Time for CA1 and CA2 input signals | $t_{r}, t_{f}$ | - | 1.0 | - | 0.5 | $\mu \mathrm{s}$ |
| Delay Time from CA1 active transition to CA2 positive transition | $\mathrm{T}_{\text {RS2 }}$ | - | 2.0 | - | 1.0 | $\mu \mathrm{s}$ |
| Rise and Fall Time for Enable input | $t_{r E}, t_{f E}$ | - | 25 | - | 25 | ns |

Write Timing Characteristics

| Characteristics | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Enable Pulse Width | $\mathrm{T}_{\mathrm{E}}$ | 0.470 | 25 | 0.235 | 25 | $\mu s$ |
| Delay Time, Address valid to Enable positive transition | ${ }^{\text {T }}$ AEW | 180 | - | 90 | - | ns |
| Delay Time, Data valid to Enable negative transition | $T_{\text {DSU }}$ | 300 | - | 150 | - | ns |
| Delay Time, Read/Write negative transition to Enable positive transition | $T_{\text {WE }}$ | 130 | - | 65 | - | ns |
| Data Bus Hold Time | $\mathrm{T}_{\text {HW }}$ | 10 | - | 10 | - | ns |
| Delay Time, Enable negative transition to Peripheral Data valid | $\mathrm{T}_{\text {PDW }}$ | - | 1.0 | - | 0.5 | $\mu s$ |
| Delay Time, Enable negative transition to Peripheral Data valid $\text { CMOS } \quad\left(V_{C C}-30 \%\right) \text { PAO-PA7.CA2 }$ | ${ }^{\text {cmos }}$ | - | 2.0 | - | 1.0 | $\mu \mathrm{s}$ |
| Delay Time, Enable positive transition to CB2 negative transition | ${ }^{T}$ CB2 | - | 1.0 | - | 0.5 | $\mu \mathrm{s}$ |
| Delay Time, Peripheral Data valid to CB2 negative transition | ${ }^{T}$ DC | 0 | 1.5 | 0 | 0.75 | $\mu \mathrm{s}$ |
| Delay Time, Enable positive transition to CB2 positive transition | $\mathrm{T}_{\text {RS1 }}$ | - | 1.0 | - | 0.5 | $\mu \mathrm{S}$ |
| Rise and Fall Time for CB1 and CB2 input signals | $t^{\prime}, t_{f}$ | - | 1.0 | - | 0.5 | $\mu \mathrm{s}$ |
| Delay Time, CB1 active transition to CB2 positive transition | $\mathrm{T}_{\text {RS2 }}$ | - | 2.0 | - | 1.0 | $\mu \mathrm{s}$ |



Read Timing Characteristics


Write Timing Characteristics

SPECIFICATIONS
Maximum Ratings

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage <br> Input Voltage <br> Operating Temperature Range <br> Commercial <br> Industrial <br> Military <br> Storage Temperature Range | $\begin{aligned} & v_{\mathrm{cc}} \\ & v_{\text {in }} \\ & T^{\prime} \\ & T_{\text {STG }} \end{aligned}$ | $\begin{aligned} & -0.3 \text { to }+7.0 \\ & -0.3 \text { to }+7.0 \\ & 0 \text { to }+70 \\ & -40 \text { to }+85 \\ & -55 \text { to }+125 \\ & -55 \text { to }+150 \end{aligned}$ |  |

This device contains 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 higher than maximum rated voltages to this circuit.
Static D.C. Characteristics
$\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0, T_{A}=25^{\circ} \mathrm{C}\right.$ unless otherwise noted)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage (Normal Operating Levels) | $\mathrm{V}_{\text {IH }}$ | +2.0 | - | $\mathrm{V}_{\text {cc }}$ | Vdc |
| Input Low Voltage (Normal Operating Levels) | $V_{\text {LL }}$ | -0.3 | - | +0.8 | $V \mathrm{dc}$ |
| Input Threshold Voltage | $V_{\text {IT }}$ | 0.8 | - | 2.0 | $V \mathrm{dc}$ |
| Input Leakage Current | $I_{\text {in }}$ |  |  |  | $\mu \mathrm{Adc}$ |
| $\begin{aligned} & v_{\text {in }}=0 \text { to } 5.0 \mathrm{Vdc} \\ & R / W, \overline{\text { Reset }, ~ R S O ~}, R S 1, C S 0, C S 1, \overline{C S} 2, C A 1, C B 1, \Phi 2 \end{aligned}$ |  | - | $\pm 1.0$ | $\pm 2.5$ |  |
| Three-State (Off State Input Current) $\left(V_{\text {in }}=0.4 \text { to } 2.4 \mathrm{Vdc}, V_{C C}=\max \right) \quad \text { D0-D7, PBO-PB7,CB2 }$ | ${ }^{\text {ITSI }}$ | - | $\pm 2.0$ | $\pm 10$ | $\mu$ Adc |
| Input High Current <br> $\left(\mathrm{V}_{1 \mathrm{H}}=2.4 \mathrm{Vdc}\right)$ <br> PAO-PA7, CA2 | ${ }^{1} \mathrm{H}$ | . 100 | -250 | - | $\mu \mathrm{Adc}$ |
| Input Low Current $\left(V_{I L}=0.4 \mathrm{Vdc}\right)$ <br> PAO-PA7, CA2 | IIL | - | -1.0 | -1.6 | mAdc |
| Output High Voltage $\left(V_{C C}=\min , l_{\text {Load }}=-100 \mu \mathrm{Adc}\right)$ | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | - | Vdc |
| Output Low Voltage $\left(\mathrm{V}_{\mathrm{CC}}=\mathrm{min}, \mathrm{I}_{\text {Load }}=1.6 \mathrm{mAdc}\right)$ | $v_{\mathrm{OL}}$ | - | - | +0.4 | Vdc |
| Output High Current (Sourcing) $\left(\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{Vdc}\right)$ | ${ }^{1} \mathrm{OH}$ | -100 | -1000 | - | $\mu \mathrm{Adc}$ |
| ( $\mathrm{V}_{\mathrm{O}}=1.5 \mathrm{Vdc}$, the current for driving other than TTL, e.g., Darlington Base) PBO-PB7.CB2 |  | -1.0 | $-2.5$ | - | mAdc |
| Output Low Current (Sinking) $\left(\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{Vdc}\right)$ | ${ }^{\prime} \mathrm{OL}$ | 1.6 | - | - | mAdc |
| Output Leakage Current (Off State) $\quad \overline{\mathrm{ROA}}, \overline{\mathrm{IROB}}$ | ${ }^{\text {off }}$ | - | 1.0 | 10 | $\mu \mathrm{Adc}$ |
| Power Dissipation | $P_{\text {D }}$ | - | 200 | 500 | mW |
| Input Capacitance $\left(\mathrm{V}_{\text {in }}-0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$ | $C_{\text {in }}$ |  |  |  | pF |
| in .. A DO-D7, PA0-PA7, PB0-PB7, CA2, CB2 |  | - | - | 10 |  |
| R/W, हeset, RSO, RS1, CSO, CS1, $\overline{\mathrm{CS} 2}$, |  | - | - | $7.0$ |  |
| Output Capacitance $\left(V_{\text {in }}-0 . T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$ | $C_{\text {out }}$ | - | - | 10 | pF |

NOTE: Negative sign indicates outward current flow, positive indicates inward flow.

# R6500 Microcomputer System DATA SHEET 

## VERSATILE INTERFACE ADAPTER（VIA）

－Two 8－Bit Bidirectional I／O Ports
－Two 16－Bit Programmable Timer／Counters
－Serial Data Port
－Single＋5V Power Supply
－TTL Compatible
－CMOS Compatible Peripheral Controi Lines
－Expanded＂Handshake＂Capability Allows Positive Control of Data Transfers Between Processor and Peripheral Devices
－Latched Output and Input Registers
－ $1 \mathbf{M H z}$ and 2 MHz Operation

The R6522 Versatile Interface Adapter（VIA）is a very flexible I／O control device．In addition，this de－ vice contains a pair of very powerful 16 －bit interval timers，a serial－to－parallel／parallel－to－serial shift re－ gister and input data latching on the peripheral ports． Expanded handshaking capability allows control of bi－directional data transfers between VIA＇s in multiple processor systems．
Control of peripheral devices is handled primarily through two 8 －bit bi－directional ports．Each line can
be programmed as either an input or an output．Several peripheral I／O lines can be controlled directly．from the interval timers for generating programmable fre－ quency square waves or for counting externally gen－ erated pulses．To facilitate control of the many power－ ful features of this chip，an interrupt flag register，an interrupt enable register and a pair of function con－ trol registers are provided．


Figure 1．R6522 Block Diagram

R6522/R6522A

## SPECIFICATIONS

## Maximum Ratings

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{C C}$ | -0.3 to +7.0 | Vde |
| Input Voltage | VIN | -0.3 to +7.0 | $V d c$ |
| Operating Temperature Range | $T$ |  | ${ }^{\circ} \mathrm{C}$ |
| Commercial |  | 0 to +70 |  |
| Industrial |  | . 40 to +85 |  |
| Military |  | -55 to +125 |  |
| Storage Temperature Range | TSTG | -55 to $0+150$ | ${ }^{\circ} \mathrm{C}$ |

This device contains 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 higher than maximum rated voltages.

ELECTRICAL CHARACTERISTICS ( $V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0-70^{\circ} \mathrm{C}$ unless otherwise noted)

| Symbol | Characteristic | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage (all except $\phi$ 2) | 2.4 | $V_{\text {cc }}$ | V |
| $\mathrm{V}_{\mathrm{CH}}$ | Clock High Voltage | 2.4 | $\mathrm{V}_{\mathrm{cc}}$ | V |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.3 | 0.4 | V |
| IIN | Input Leakage Current - $\mathrm{V}_{\text {IN }}=0$ to 5 Vdc R/W, $\overline{\text { RES }}$, RSO, RS1, RS2, RS3, CS1, $\overline{\mathrm{CS} 2}$, CA1, $\Phi$ 2 | - | $\pm 2.5$ | $\mu \mathrm{A}$ |
| ${ }_{\text {ITSI }}$ | $\begin{aligned} & \text { Off-state Input Current }-V_{I N}=.4 \text { to } 2.4 \mathrm{~V} \\ & V_{C C}=M a x, D 0 \text { to } D 7 \end{aligned}$ | - | $\pm 10$ | $\mu \mathrm{A}$ |
| $I_{\text {IH }}$ | Input High Current $-V_{1 H}=2.4 \mathrm{~V}$ PA0-PA7, CA2, PB0-PB7, CB1, CB2 | -100 | - | $\mu \mathrm{A}$ |
| IIL | Input Low Current $-V_{1 L}=0.4 \mathrm{Vdc}$ PA0-PA7, CA2, PB0-PB7, CB1, CB2 | - | -1.6 | mA |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage $V_{C C}=\min , I_{\text {load }}=-100 \mu \mathrm{Adc}$ <br> PA0-PA7, CA2, PB0-PB7, CB1, CB2 | 2.4 | - | V |
| V OL | Output Low Voltage $V_{C C}=\min , I_{\text {load }}=1.6 \mathrm{mAdc}$ | - | 0.4 | V |
| $\mathrm{IOH}^{\text {d }}$ | Output High Current (Sourcing) $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V}(\mathrm{PBO}-\mathrm{PB} 7) \end{aligned}$ | $\begin{array}{r} -100 \\ -1.0 \\ \hline \end{array}$ | $-$ | $\begin{array}{r} \mu \mathrm{A} \\ \mathrm{~mA} \\ \hline \end{array}$ |
| IOL | Output Low Current (Sinking) $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{Vdc}$ | 1.6 | - | mA |
| loff | Output Leakage Current (Off state) IRQ | - | 10 | $\mu \mathrm{A}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance $-\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ <br>  DO-D7, PAO-PA7, CA1, CA2, PBO-PB7) <br> (CB1, CB2) <br> ( $\Phi 2$ Input) | $\begin{aligned} & \text { - } \\ & \text { - } \end{aligned}$ | $\begin{aligned} & 7.0 \\ & 10 \\ & 20 \\ & \hline \end{aligned}$ | pF <br> pF <br> pF |
| Cout | Output Capacitance $-\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ | - | 10 | pF |
| $\mathrm{P}_{\mathrm{D}}$ | Power Dissipation | - | 700 | mW |



Figure 2. Test Load (for all Dynamic Parameters)


Figure 3. Read Timing Characteristics

READ TIMING CHARACTERISTICS (FIGURE 3)

| Symbol | Parameter | R6522 |  | R6522A |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| TCY | Cycle Time | 1 | 50 | 0.5 | 50 | $\mu \mathrm{s}$ |
| $\mathrm{T}_{\text {ACR }}$ | Address Set-Up Time | 180 | - | 90 | - | ns |
| TCAR | Address Hold Time | 0 | - | 0 | - | ns |
| TPCR | Peripheral Data Set-Up Time | 300 | - | 300 | - | ns |
| TCDR | Data Bus Delay Time | - | 340 | - | 200 | ns |
| $\mathrm{T}_{\mathrm{HR}}$ | Data Bus Hold Time | 10 | - | 10 | - | ns |

NOTE: $\mathrm{tr}, \mathrm{tf}=10$ to 30 ns .


Figure 4. Write Timing Characteristics

WRITE TIMING CHARACTERISTICS (FIGURE 4)

| Symbol | Parameter | R6522 |  | R6522A |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | - Max. | Min. | Max. |  |
| $\mathrm{T}_{\mathrm{Cr}}$ | Cycle Time | 1 | 50 | 0.50 | 50 | $\mu \mathrm{s}$ |
| $\mathrm{T}_{\mathrm{C}}$ | ¢2 Pulse Width | 0.44 | 25 | 0.22 | 25 | $\mu \mathrm{s}$ |
| $\mathrm{T}_{\text {ACW }}$ | Address Set-Up Time | 180 | - | 90 | - | ns |
| TCAW | Address Hold Time | 0 | - | 0 | - | ns |
| Twcw | R/ $\bar{W}$ Set-Up Time | 180 | - | 90 | - | ns |
| TCww | R/ $\bar{W}$ Hold Time | 0 | - | 0 | - | ns |
| TDCW | Data Bus Set-Up Time | 300 | - | 200 | - | ns |
| THW | Data Bus Hold Time | 10 | - | 10 | - | ns |
| $\mathrm{T}_{\text {cPW }}$ | Peripheral Data Delay Time | - | 1.0 | - | 1.0 | $\mu \mathrm{s}$ |
| Tcmos | Peripheral Data Delay Time to CMOS Levels | - | 2.0 | - | 2.0 | $\mu \mathrm{s}$ |

NOTE: $\mathrm{tr}, \mathrm{tf}=10$ to 30 ns .

R6522/R6522A

PERIPHERAL INTERFACE CHARACTERISTICS

| Symbol | Characteristic | Min. | Max. | Unit | Figure |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{tr}_{\mathrm{r}}, \mathrm{tff}$ | Rise and Fall Time for CA1, CB1, CA2, and CB2 Input Signa!s | - | 1.0 | $\mu \mathrm{s}$ | - |
| TCA2 | Delay Time, Clock Negative Transition to CA2 Negative Transition (read handshake or pulse mode) | - | 1.0 | $\mu \mathrm{s}$ | 5a, 5b |
| $\mathrm{T}_{\text {RSt }}$ | Delay Time, Clock Negative Transition to CA2 Positive Transition (pulse mode) | - | 1.0 | $\mu \mathrm{s}$ | 53 |
| $\mathrm{T}_{\text {RS2 }}$ | Delay Time, CA1 Active Transition to CA2 Positive Transition (handshake mode) | - | 2.0 | $\mu \mathrm{s}$ | 5b |
| TWHS | Delay Time, Clock Positive Transition to CA2 or CB2 Negative Transition (write handshake) | 0.05 | 1.0 | $\mu \mathrm{s}$ | $5 \mathrm{c}, 5 \mathrm{~d}$ |
| TDS | Delay Time, Peripheral Data Valid to CB2 Negative Transition | 0.20 | 1.5 | $\mu \mathrm{s}$ | 5c, 5d |
| T $\mathrm{RS3}$ | Delay Time, Clock Positive Transition to CA2 or CB2 Positive Transition (pulse mode) | - | 1.0 | $\mu \mathrm{s}$ | 5 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}$ | 5d |
| $T_{21}$ | Delay Time Required from CA2 Output to CA1 Active Transition (handshake mode) | 400 | - | ns | 5d |
| $T_{\text {IL }}$ | Set-up Time, Peripheral Data Valid to CA1 or CB1 Active Transition (input latching) | 300 | - | ns | 5 e |
| TSR1 | Shift-Out Delay Time - Time from $\phi_{2}$ Falling Edge to CB2 Data Out | - | 300 | ns | $5 f$ |
| TSR2 | Shift-In Setup Time - Time from CB2 Data In to $\phi_{2}$ Rising Edge | 300 | - | ns | 59 |
| TSR3 | External Shift Clock (CB1) Setup Time Relative To $\phi_{2}$ Trailing Edge | 100 | $\mathrm{T}_{\mathrm{CY}}$ | ns | 59 |
| TIPW | Pulse Width - PB6 Input Pulse | 2 | - | $\mu \mathrm{s}$ | $5 i$ |
| TICW | Pulse Width - CB1 Input Clock | 2 | - | $\mu \mathrm{s}$ | 5 h |
| 1 IPS | Pulse Spacing - PB6 Input Pulse | 2 | - | $\mu s$ | $5 i$ |
| IICS | Pulse Spacing - CB1 Input Pulse | 2 | - | $\mu \mathrm{s}$ | $5 h$ |



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


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


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


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


Figure 5e. Peripheral Data Input Latching Timing


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


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


Figure 5h. External Shift Clock Timing
$\qquad$

## PIN DESCRIPTIONS

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

The reset input clears all internal registers to logic 0 (except T1 and T2 latches and counters and the Shift Register). This places all peripheral interface lines in the input state, disables the timers, shift register, etc. and disables interrupting from the chip.

## $\phi 2$ (Input Clock)

The input clock is the system $\phi 2$ clock and is used to trigger all data transfers between the system processor and the R6522.

## R $\bar{W}$ (Read/Write)

The direction of the data transfers between the R6522 and the system processor is controlled by the $R / \bar{W}$ line. If R/W is low, data will be transferred out of the processor into the selected R6522 register (write operation). If $R / W$ is high and the chip is selected, data will be transferred out of the R6522 (read operation).

## DB0-DB7 (Data Bus)

The eight bi-directional data bus lines are used to transfer data between the R6522 and the system processor. During read cycles, the contents of the selected R6522 register are placed on the data bus lines and transferred into the processor. During write cycles, these lines are high-impedance inputs and data is transferred from the processor into the selected register. When the R6522 is unselected, the data bus lines are high-impedance.

## CS1, CS2 (Chip Selects)

The two chip select inputs are normally connected to processor address lines either directly or through decoding. The selected R6522 register will be accessed when CS1 is high and $\overline{\mathrm{CS} 2}$ is low.

## RSO-RS3 (Register Selects)

The four Register Select inputs permit the system processor to select one of the 16 internal registers of the R6522, as shown in Figure 6.

| Register Number | RS Coding |  |  |  | Register Desig. | Description |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS3 | RS2 | RS1 | RSO |  | Write | Read |
| 0 | 0 | 0 | 0 | 0 | ORB/IRB | Output Register " $B$ " | Input Register "B" |
| 1 | 0 | 0 | 0 | 1 | ORA/IRA | Output Register " ${ }^{\text {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 |  |
| $\varepsilon$ | 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 Fiag Register |  |
| 14 | 1 | 1 | 1 | 0 | IER | Interrupt Enable Register |  |
| 15 | 1 | 1 | 1 | 1 | ORA/IRA | Same as Reg 1 Except No "Handshake" |  |

Figure 6. R6522 Internal Register Summary

## $\overline{\mathrm{RQ}}$ (Interrupt Request)

The Interrupt Request output goes low whenever an internal interrupt flag is set and the corresponding interrupt enable bit is a logic 1 . This output is " r . endrain" to allow the interrupt request signal to be "wire-or'ed" with other equivalent signals in the system.

## PA0-PA7 (Peripheral A Port)

The Peripheral A port consists of 8 lines which can be individually programmed to act as inputs or outputs under control of a Data Direction Register. The polarity of output pins is controlled by an Output Register and input data may be latched into an internal register under control of the CA1 line. All of these modes of operation are controlled by the system processor through the internal control registers. These lines represent one standard TTL load in the input mode and will drive one standard TTL load in the output mode. Figure 7 illustrates the output circuit.

## CA1, CA2 (Peripheral A Control Lines)

The two Peripheral A control lines act as interrupt inputs or as handshake outputs. Each line controls an internal interrupt flag with a corresponding interrupt enable bit. In addition, CA1 controls the latching of data on Peripheral A port input lines. CA1 is a high. impedance input only while CA2 represents one standard TTL load in the input mode. CA2 will drive one standard TTL load in the output mode.


Figure 7. Peripheral A Port Output Circuit

## PB0-PB7 (Peripheral B Port)

The Peripheral B port consists of eight bi-directional lines which are controlled by an output register and a data direction register in much the same manner as the

PA port. In addition, the polarity of the PB7 output signal can be contrclled by one of the interval timers while the second timer can be programmed to count pulses on the PB6 pin. Peripheral B lines represent one standard TTL load in the input mode and will drive one standard TTL load in the output mode. In addj. tion, they are capable of sourcing 1.0 mA at 1.5 VDC in the output mode to allow the outputs to directly drive Darlington transistor circuits. Figure 8 is the circuit schematic.

## CB1, CB2 (Peripheral B Control Lines)

The Peripheral B control lines act as interrupt inputs or as handshake outputs. As with CA1 and CA2, each line controls an interrupt flag with a corresponding interrupt enable bit. In addition, these lines act as a serial port under control of the Shift Register. These lines represent one standard TTL load in the input mode and will drive one standard TTL load in the output mode. Unlike PBO-PB7, CB1 and CB2 cannot drive Darlington transistor circuits.


Figure 8. Peripheral B Port Output Circuit

## FUNCTIONAL DESCRIPTION

Port A and Port B Operation
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 an Input Register (IRA, IRB). When the pin is programmed as an output, the voltage on the pin is controlled by the cor-
responding 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, huwever, 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 9,10 , and 11 illustrate the formats of the port registers. In addition, the input latching modes are selected by the Auxiliary Control Register (Figure 16.)

## Handshake Control of Data Transfers

The R6522 allows positive control of data transfers between the system processor and peripheral devices

## REG 0 - ORB/IRB



OUTPUT REGISTEA " $B$ " (ORB) OR
INPUT REGISTER "B" (ORB)

| Data Direction Selection | WRITE | READ |
| :---: | :---: | :---: |
| DDRB = "1" OUTPUT) | MPU writes Output Level (ORB) | MPU reads output register bit in ORB Pin level has no affect. |
| DDRB = "0" (INPUT) (Input tatching disabled) | MPU writes into ORB, but no effect on pin level, untid DORB changed. | MPU reads input level on $P B$ pin. |
| DDRB = "0" (INPUT) (Input latching enabled) |  | MPU readsIRB bit, which is the level of the P8 pin at the tume of the last CB1 active transition |

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

REG 1 - ORA/IRA


OUTPUT REGISTER "A" (ORA)
or
INPUT REGISTER "A" IIRAI

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

REG 2 (DDRB) AND REG 3 (DDRA)

"0" ASSOCIATED PB/PA PIN IS AN INPUT (HIGH-MPEDANCE)
" $\uparrow$ " ASSOCIATED PB/PA PIN IS AN OUTPUT. WHOSELEVEL IS OETERMINEDBY ORB ORA REGISTER BIT

Figure 11. Data Direction Registers (DDRB, DDRA)
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 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.


Figure 12. Read Handshake Timing (Port A, Only)


Figure 13. Write Handshake Timing

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 12 which illustrates the normal Read Handshaking sequence.

## 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 cleaning the "Data Ready" output. This sequence is shown in Figure 13.

Selection of operating modes for CA1, CA2, CB1, and CB2 is accomplished by the Peripheral Control Register (Figure 14).

## Timer Operation

Interval Timer T1 consists of two 8 -bit latches and a 16 -bit counter. The latches are used to store data which is to be loaded into the counter. After loading, the counter decrements at $\$ 2$ clock rate. Upon reaching zero, an interrupt flag will be set, and $\overrightarrow{I R Q}$ will go low if the interrupt is enabled. The timer will then disable any further interrupts, or will automatically transfer the contents of the latches into the counter and will continue to decrement. In addition, the timer may be programmed to invert the output signal on a peripheral pin each time it "times-out". Each of these modes is discussed separately below.
The T1 counter is depicted in Figure 15 and the latches in Figure 16.

REG 12 - PERIPHERAL CONTROL REGISTER


Figure 14. CA1, CA2, CB1, CB2 Control

Two bits are provided in the Auxiliary Control Register (bits 6 and 7) to allow selection of the T1 oper-
ating modes. The four possible modes are depicted in Figure 17.

REG 5 - TIMER 1 HIGH-ORDER COUNTER

WRITE - 8 BITS LOADEO INTO TI HIGH.ORDER LATCHES. ALSO, AT THIS TIME BOTH LATCHES. ALSO, AT THIS TIME BO
HIGH AND LOWORDER LATCHES TRANSFERRED INTO TI COUNTER TII INTERRUPT FLAG ALSO IS RESET. READ - 8 BITS FROM TI HIGH ORDER COUNTER TRANSFERRED TO MPU


REG 4 - TIMER 1 LOW-ORDER COUNTER


WRite - 8 bits loaded into tilow order LATCHES. LATCH CONTENTS ARE
TRANSFERRED INTO LOW.ORDER
COUNTER AT THE TIME THE HIGH. COUNTER AT THE TIME THE HIGH.
ORDER COUNTER IS LOADED IREG
REAO - 8BITS FROM TI LOW ORDER COUNTER TRANSFERRED TO MPU. IN ADDITION T1 INTERRUPT FLAG IS RESET (8IT 6 IN INTERRUPT FLAG REGISTER).

Figure 15. T1 Counter Registers


Figure 16. T1 Latch Registers

REG 11 - AUXILIARY CONTROL REGISTER


Figure 17. Auxiliary Control Register
Note: 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 when the processor writes into the high order counter. 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 counter.


Figure 18. Timer 1 and Timer 2 One-Shot Mode Timing

## Timer 1 One-Shot Mode

The interval timer ene-shot mode allows generation of 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 ( $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.
In the one-shot mode, writing into the high order latch 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, 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 phase two 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.

Timing for the R6522 interval timer one-shot modes is shown in Figure 18.

## Timer 1 Free-Run Mode

The most important advantage associated with the latches in T 1 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 "freerunning" mode.

In the free-running mode, the interrupt flag is set and the signal on PB7 is inverted each time the counter reaches zero. However, instead of continuing to decrement from zero after a time-out, 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, 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 free-running mode with the output enabled. In this mode, the signal on PB7 is inverted and the interrupt flag is set with each time-out. 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. Timing for the free-running mode is shown in Figure 19.


Note: 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 the other is 0 , then PB7 functions as a normal output pin, controlled by ORB bit 7.

Figure 19. Timer 1 Free-Run Mode Timing

## Timer 2 Operation

Timer 2 operates as an interval timer (in the "oneslot" mode only), or as a counter for counting negative pulses on the PB6 peripheral pin. A single control bit is provided in the Auxiliary Control Register to select between these two modes. This timer is comprised of a "write-only" low-order latch (T2L-L), a "read-only" low-order counter and a read/write high order counter. The counter registers act as a 16 -bit counter which decrements at $\Phi 2$ rate. Figure 20 illustrates the T2 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 will be disabled after initial time-out so that it will not be set by the counter continuing to decrement through zero. The processor must rewrite T2C-H to enable setting of the interrupt flag. The interrupt flag is cleared by reading $\mathrm{T} 2 \mathrm{C}-\mathrm{L}$ or by writing T2C-H. Timing for this operation is shown in Figure 18.

REG 8 - TIMER 2 LOW-ORDER COUNTER


WRITE - 8 Bits LOADED INTO T2 LOW-ORDER latches.
READ - BBITS FROM T2 LOW ORDER COUNTER TRANSFERRED TO MPU. T2 INTERRUPT FLAG IS RESET.

REG 9 - TIMER 2 HIGH-ORDER COUNTER


WRITE - BBITS LOADED INTO T2 HIGH-ORDER
COUNTER. ALSO. LOW-ORDER LATCHES
TRANSFERRED TO LOW ORDER
COUNTER. IN ADDITION, T2 INTERRUPT
LAG IS RESET
READ - 8 BITS FROM T2 HIGH ORDER COUNTER TRANSFERRED TO MPU

Figure 20. T2 Counter Registers

## Timer 2 Pulse Counting Mode

In the pulse counting mode, T2 serves primarily to count a predetermined number of negative-going pulses on PB6. This is accomplished by first loading a number into T2. 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 will be set when T2 reaches zero. At this time the counter will continue to decrement with each pulse on PB6. However, it is necessary to rewrite T2C-H to allow the interrupt flag to set on subsequent down-counting operations. Timing for this mode is shown in Figure 21. The pulse must be low on the leading edge of ゆ2.

## 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. 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 22 illustrates the configuration of the SR data bits and the SR control bits of the ACR.

Figures 23 and 24 illustrate the operation of the various shift register modes.

## Interrupt Operation

Controlling interrupts within the R 6522 involves three principal operations. These are flagging the interrupts, enabling interrupts and signaling to the processor that an active interrupt exists within the chip. Interrupt flags are set by interrupting conditions which exist within the chip or on inputs to the chip. 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. This is accomplished by reading the flag register into the processor accumulator, shifting this register either right or left and then using conditional branch instructions to detect an active interrupt.
Associated with each interrupt flag is an interrupt enable bit. 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.

In the R6522, all the interrupt flags are contained in one register. 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.


Figure 21. Timer 2 Pulse Counting Mode

REG 10 - SHIFT REGISTER


NOTES:

1. WHEN SHIFTING OUT BIT 7 IS THE FIRST BIT

OUT AND SIMULTANEOUSLY IS ROTATED BACK INTO BITO.
2. WHEN SHIFTING IN. BITS INITIALLY ENTER

WHEN SHIFTING IN. BITS INITIALLY ENTE
BIT O AND ARE SHIFTED TOWARDS BIT 7 .

REG 11 - AUXILIARY CONTROL REGISTER


SHIFT REGISTER MODE CONTROL

| 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 12 |
| 0 | 1 | 1 | SHIFT IN UNDER CONTROL OF EXT CLK |
| 1 | 0 | 0 | SHIFT OUT FREE RUNNINE AT T2 RATE |
| 1 | 0 | 1 | SHIFT OUT UNDER CONTROL OF T2 |
| 1 | 1 | 0 | SHIFT OUT UNDER CONTROL OF 12 |
| 1 | 1 | 1 | SHIFT OUT UNDER CONTROL OF EXT CLK |

Figure 22. SR and ACR Control Bits

SR Disabled (000)
The 000 mode is used to disable the Shift Register. In this mode the microprocessor can write or read the SR, but the shifting operation is disabled and operation of CB1 and CB2 is controlled by the appropriate bits in the Peripheral Control Register (PCR). In this mode the SR Interrupt Flag is disabled (held to a logic 0).

## Shift in Under Control of T2 (001)

In the 001 mode the shifting rate is controlled by the low order 8 bits of $T 2$. 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 writing or reading the shift register. Data is shifted first into the low order bit of SR and is then shifted into the next higher order bit of the shift register on the negative-going edge of each clock pulse. The input data should change before the positive-going edge of the CB1 clock pulse. This data is shifted into the shift register during the $\phi_{2}$ clock cycle following the positive-going edge of the CB1 clock pulse. After 8 CB 1 clock pulses, the shift register interrupt flag will be set and $\overline{\mathrm{RO}}$ will go low.


## Shift in Under Control of $\phi_{2}$ (010)

In mode 010 the shift rate is a direct function of the system clock frequency. 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 $\phi_{2}$ clock pulse. After 8 clock pulses, the shift register interrupt flag will be set, and the output clock pulses on CB1 will stop.


Shift in Under Control of External CB1 Clock (011)
In mode 011 CB1 becomes an input. 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. However, the shift register counter does not stop the shifting operation; it acts simply as a pulse counter. 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.


Figure 23. Shift Register Input Modes

## Shift Out Free-Running at T2 Rate (100)

Mode 100 is very similar to mode 101 in which the shifting rate is set by T2. However, in mode 100 the SR Counter does not stop the shifting operation. 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.


Shift Out Under Control of T2 (101)
In mode 101 the shift rate is controlled by T2 (as in the previous mode). 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 s'iifting is disabled, the SR Interrupt Flag is set and CB2 remains at the last data level.


Shift Out Under Control of $\phi_{\mathbf{2}}$ (110)
In mode 110, the shift rate is controlled by the $\phi_{2}$ system clock.


Shift Out Under Control of External CB1 Clock (111)
In mode 111 shifting is controlled by pulses applied to the CB1 pin by an external device. 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 bogin 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 24. Shift Register Output Modes

The Interrupt Flag Register (IFR) and Interrupt Enable Register (IER) are depicted in Figures 25 and 26, respectively.
The 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 IRO output. This bit corresponds to the logic function: IRQ = IFR6 $\times$ IER6 + IFR5 $\times$ IER5 + IFR4 $\times$ IER4 + IFR3 $\times$ IER3 + IFR2 $\times$ IER2 + IFR1 $\times$ IER1 + IFRO $\times$ IERO. Note: $X=$ logic $A N D,+=$ 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.

REG 13 - INTERRUPT FLAG REGISTER


- IF THE CA2/CB2 CONTROL IN THE PCR IS SELECTED AS
"INDEPENDENT" INTERRUPT INPUT. THEN READING OR
WRITING THE OUTPUT REGISTER ORAIORB WILL NOT
CLEAR THE FLAG BIT. INSTEAD. THE BIT MUST BE
CLEARED BY WRITING INTO THE IFR, AS OESCRIBED
PREVIOUSLY.
Figure 25. Interrupt Flag Register (IFR)

For each interrupt flag in IFR, there is a corresponding bit in the Interrupt Enable Register. The system processor can be set or clear selected bits in this register to facilitate controlling individual interrupts without affecting others. This is accomplished
by writing to address 1110 (IER address). 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.
Setting selected bits in the Interrupt Enable Register is accomplished by writing to the same address with bit 7 in the data word set to a logic 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 processor can read the contents of this register by placing the proper address on the register select and chip select inputs with the R/W line high. Bit 7 will be read as a logic 0.

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 \cdots$. THEN EACH "I"IN BITS $0-6$ ENABLES THE CORRESPONDING INTERRUPT.
3. IF A READ OF THIS REGISTER IS DONE, BIT 7 WILL BE " 0 " AND ALL OTHER BITS WILL REFLECT THEIR ENABLE/DISABLE STATE.

Figure 26. Interrupt Enable Register (IER)

PACKAGE OUTLINE


PIN CONFIGURATION

| VSS 1 | 1 | 40 | CAI |
| :---: | :---: | :---: | :---: |
| ${ }^{P A O} \square^{2}$ | 2 | 39 | $\square \mathrm{CAL}$ |
| PA1 ${ }^{\text {a }}$ | 3 | 38 | ] RSO |
| PAZ $0_{4}$ | 4 | 37 | RSI |
| PA3 $\square_{5}$ | 5 | 36 | RS2 |
| PA4 6 | 6 | 35 | RS3 |
| PAS 7 | 7 | 34 | ¢ E ĖS |
| PAG 8 | 8 | 33 | $]$ Do |
| PA) 9 | 9 | 32 | 01 |
| Pbo $\square_{10}$ | 10 R6522 | 31 | D2 |
| PB1 11 | 11 | 30 | D3 |
| $\mathrm{PB} 22-12^{\text {d }}$ | 12 | 29 | 104 |
| PB3 ${ }_{1}$ | 13 | 23 | D 5 |
| PB4 ${ }^{14}$ | 14 | 27 | 06 |
| P8S $C^{2}$ | 15 | 26 | 07 |
| P66 16 | 16 | 25 | H2 |
| P87 $\mathrm{d}_{17}$ | 17 | 24 | CS |
| csi 18 | 18 | 23 | CS2 |
| c82 19 | 19 | 22 | R/W |
| $v_{\text {cc }}{ }^{20}$ | 20 | 21 | IRō |

Ordering Information

| Order <br> Number | Package <br> Type | Frequency | Temperature <br> Range |
| :--- | :--- | :--- | :--- |
| R6522P | Plastic | 1 MHz | $0{ }^{\circ} \mathrm{C}$ to $+70{ }^{\circ} \mathrm{C} \mathrm{C}$ |
| R6522AP | Plastic | 2 MHz | $0{ }^{\circ} \mathrm{C}$ to $+70{ }^{\circ} \mathrm{C}$ |
| R6522C | Ceramic | 1 MHz | $0{ }^{\circ} \mathrm{C}$ to $+700^{\circ} \mathrm{C}$ |
| R6522AC | Ceramic | 2 MHz | $0{ }^{\circ} \mathrm{C}$ to $+700^{\circ} \mathrm{C}$ |
| R6522PE | Plastic | 1 MHz | $-40{ }^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ |
| R6522APE | Plastic | 2 MHz | $-40{ }^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ |
| R6522CE | Ceramic | 1 MHz | $-40{ }^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ |
| R6522ACE | Ceramic | 2 MHz | $-40{ }^{\circ} \mathrm{C}$ to $+85{ }^{\circ} \mathrm{C}$ |

# R6500 Microcomputer System DATA SHEET 

## CRT CONTROLLER (CRTC)

## DESCRIPTION

The R6545-1 CRT Controller (CRTC) is designed to interface an 8 -bit microprocessor to CRT raster scan video displays, and adds an advanced CRT controller to the established and expanding line of R6500 products.

The R6545-1 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-1 is that the refresh memory may be addressed in either straight binary or by row/column.

Other functions in the R6545-1 include an intemal 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 intemal 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. 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 $\mathbf{6 0 ~ H z}$ refresh rate. The intemal status register may be used to monitor the R6545-1 operation. The RES input allows the CRTC-generated field rate to be dynamically-synctronized with line frequency jitter.

## ORDERING INFORMATION

| Part <br> Number | Package <br> Type | Frequency | Temperature <br> Range |
| :--- | :--- | :--- | :--- |
| R6545-1P | Plastic | 1 MHz | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| R6545-1AP | Plastic | 2 MHz | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| R6545-1C | Ceramic | 1 MHz | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| R6545-1AC | Ceramic | 2 MHz | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |

## FEATURES

- Compatible with 8-bit microprocessors
- Up to 2.5 MHz character clock operation
- 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)
- Non-interlaced scan
- $50 / 60 \mathrm{~Hz}$ operation
- Fully programmable cursor
- Light pen registér
- Addresses refresh RAM to 16 K characters
- No external DMA required
- Internal status register
- 40-Pin ceramic or plastic DIP
- Pin-compatible with MC6845
- Single $+5 \pm 5 \%$ Volt Power Supply

R6545-1 Pin Configuration

## INTERFACE SIGNAL DESCRIPTION

## CPU INTERFACE

## \$2 (Phase 2 Clock)

The input clock is the system Phase 2 ( $\phi_{2}$ ) clock and is used to trigger all data transfers between the system processor (CPU) and the R6545-1. Since there is no maximum limit to the allowable $\phi 2$ clock time, it is not necessary for it to be a continuous clock. This capability permits the R6545-1 to be easily interfaced to non-6500 compatible microprocessors.

## R/W (Read/Write)

The R/W input signal generated by the processor is used to control the direction of data transfers. A high on the R/W pin allows the processor to read the data supplied by the R6545-1, a low on the R/W pin allows data on data lines DO-D7 to be written into the R6545-1.

## $\overline{\mathrm{CS}}$ (Chip Select)

The Chip Select input is normally connected to the processor address bus either directly or through a decoder. The R6545-1 is selected when CS is low.

## RS (Register Select)

The Register Select input is used to access intemal registers. A low on this pin permits writes ( $R / W=$ low) into the Address Register and reads ( $\mathrm{R} / \mathrm{W}=$ high) from the Status Register. The contents of the Address Register is the identity of the register accessed when RS is high.

## D0-D7 (Data Bus)

D0-D7 are the eight data lines used to transfer data between the processor and the R6545-1. These lines are bidirectional and are normally high-impedance except during read cycles when the chip is selected ( $C S=$ low).

## VIDEO INTERFACE

## HSYNC (Horizontal Sync)

The HSYNC signal is an active-high output used to determine the horizontal position of displayed text. 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 signal is an active high output used to determine the vertical position of displayed text. Like HSYNC, VSYNC may be used to drive a CRT monitor or composite video generation circuits. VSYNC time position and width are both programmable.

## DISPLAY ENABLE (Display Enable)

The DISPLAY ENABLE signal is an active-high output used to indicate when the R6545-1 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 are used to generate the DISPLAY ENABLE signal. DISPLAY ENABLE can be delayed one character time by setting bit 4 of R8 equal to 1 .

## CURSOR (Cursor Coincidence)

The CURSOR signal is an active-high output used to indicate when the scan coincides with the programmed cursor position. The cursor position may be programmed to be any character in the address field. Furthermore, within the character, the cursor may be programmed to be any block of scan lines, since the start scan line and the end scan line are both programmable. The cursor position may be delayed by one character time by setting Bit 5 of R8 to $A$ " 1 ".

## LPEN (Light Pen Strobe)

The LPEN signal is an edge-sensitive input used to load the internal Light Pen Register with the contents of the Refresh Scan Counter at the time the active edge occurs. The active edge of LPEN is the low-to-high transition.

## CCLK (Clock)

The CCLK signal is the character timing clock input and is used as the time base for all internal count/control functions.

## RES

The $\overline{\text { RES }}$ signal is an active-low input used to initialize all internal scan counter circuits. When RES is low, all internal counters are stopped and cleared, all scan and video outputs are low, and control registers are unaffected. RES must stay low for at least one CCLK period. All scan timing is initiated when RES goes high. In this way, RES can be used to synchronize display frame timing with line frequency. $\overline{\mathrm{AES}}$ may also be used to 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 signals are active-high outputs used to 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 MAO-MA13:
In the straight binary mode (R8, Mode Control, bit $2=" 0$ "), characters are stored in successive memory locations. Thus, the software must be designed such that row and column character coordinates are translated into sequentially-numbered addresses. In the row/column mode (R8, Mode Control, bit $2=$ "1"), MAO-MA7 become column addresses CC0-CC7 and MA8MA13 become row addresses CR0-CR5. In this case, the software can manipulate 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 mem-ory-efficient binary address scheme.

## RA0-RA4 (Raster Address Lines)

These 5 signals are active-high outputs used to 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.

INTERNAL REGISTER ORGANIZATION

| $\overline{\mathbf{C S}}$ | RS | Address Register |  |  |  |  | Reg. No. | Register Name | Register Units | $\begin{aligned} & \text { Read } \\ & \text { (R/W }= \\ & \text { High) } \end{aligned}$ | $\begin{aligned} & \text { Write } \\ & (\mathrm{R} / \bar{W}= \\ & \text { Low) } \end{aligned}$ | Register Bit |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1 | X | X | $x$ | $x$ | $x$ | x | $x$ |  |  |  |  | 7 | / | $\sqrt{6}$ | , | 7 |  |  |  |
| 0 | 0 | X | $x$ | $x$ | $x$ | x | X | Address Register | Register No. |  | $\checkmark$ |  |  |  | 4 | 3 | 2 | 1 | 0 |
| 0 | 0 | X | x | x | $\times$ | x | $\times$ | Status Register | - | $\checkmark$ |  | 7 | 6 | 5 | 7 | , |  |  |  |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | RO | Horizontal Total Char | No. of Characters/Row |  | V | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 0 | 0 | 0 | 1 | R1 | Horizontal Displayed Char | No. of Characters/Row |  | $V$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 0 | 0 | 1 | 0 | R2 | Horizontal Sync Position | Character Position |  | $\checkmark$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 0 | 0 | 1 | 1 | R3 | YSYNC, HSYNC Widths | No. of Scan Lines, Characters |  | $\checkmark$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 0 | 1 | 0 | 0 | R4 | Vertical Total Rows | No. of Character Rows |  | $\downarrow$ | 1 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 0 | 1 | 0 | 1 | R5 | Vertical Total Adjust Lines | No. of Scan Lines |  | V | , | 7 | 7 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 0 | 1 | 1 | 0 | R6 | Vertical Displayed Rows | No. of Character Rows |  | $\checkmark$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | R7 | Vertical Sync Position | No. of Character Rows |  | $\checkmark$ | $\square$ | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 1 | 0 | 0 | 0 | R8 | Mode Control | - |  | $\checkmark$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 1 | 0 | 0 | 1 | R9 | Scan Line | No. of Scan Lines |  | $V$ | 7 | 2 |  | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 1 | 0 | 1 | 0 | R10 | Cursor Start Line | Scan Line No. |  | $\checkmark$ | , | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 1 | 0 | 1 | 1 | R11 | Cursor End Line | Scan Line No. |  | $V$ |  | - | < | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 1 | 1 | 0 | 0 | R12 | Display Start Address (H) | -- |  | $V$ | $\square$ | $\square$ | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 1 | 1 | 0 | 1 | R13 | Display Start Address (L) | - |  | $V$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 1 | 1 | 1 | 0 | R14 | Cursor Position Address (H) | - | $V$ | $V$ | 7 | - | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 0 | 1 | 1 | 1 | 1 | R15 | Cursor Position Address (L) | - | $V$ | $V$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 1 | 0 | 0 | 0 | 0 | R16 | Light Pen Register (H) | - | $V$ |  | 2 | 7 | 5 | 4 | 3 | 2 | 1 | 0 |
| 0 | 1 | 1 | 0 | 0 | 0 | 1 | R17 | Light Pen Register (L) | - | $\checkmark$ |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |

Table 1. Overall Register Structure and Addressing


R 6545-1 Interface Diagram

## INTERNAL REGISTER DESCRIPTION

## ADDRESS REGISTER

This 5 -bit write-only register is used as a "pointer" to direct CRTC/CPU data transfers within the CRTC. Its contents is the number of the desired register ( $0-17$ ). When $\overline{\mathrm{CS}}$ and RS are low, then this register may be loaded; when $\overline{\mathrm{CS}}$ is low and RS is high, then the register selected is the one whose identity is stored in this address register.

## STATUS REGISTER (SR)

This 8 -bit register contains the status of the CRTC. Only two bits are assigned, as follows:


NOTE: The Status Register takes the State, | - | 0 | 1 | - | $-[-\|-\|$ | - |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | immediately after power ( ${ }^{\prime} \mathrm{CC}$ ) turn-on.

## RO-HORIZONTAL TOTAL CHARACTERS

This 8-bit write-only register contains the total of displayed and non-displayed characters, minus one, per horizontal line. The frequency of HSYNC is thus determined by this register.

## R1—HORIZONTAL DISPLAYED CHARACTERS

This 8 -bit write-only register contains the number of displayed characters per horizontal line.

## R2-HORIZONTAL SYNC POSITION

This 8 -bit write-only register contains the position of the horizontal SYNC 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

This 8 -bit write-only register contains the widths of both HSYNC and VSYNC, as follows:


Control of these parameters allows the R6545-1 to be interfaced to 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

The Vertical Total Register is a 7 -bit register containing 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 $\overline{R E S}$ may be used to provide absolute synchronism.

## R5-VERTICAL TOTAL LINE ADJUST

The Vertical Total Line Adjust Register (R5) is a 5 -bit write-only register containing 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

This 7 -bit write-only register contains the number of displayed character rows in each frame.

## R7-VERTICAL SYNC POSITION

This 7 -bit write-only register is used to select the character row time at which the vertical SYNC pulse is desired to occur and, thus, is used to position the displayed text in the vertical direction.

## R8-MODE CONTROL (MC)

This 8 -bit write-only register selects the operating modes of the R6545-1, as follows:


## R9—ROW SCAN LINES

This 5 -bit write-only register contains the number of scan lines, minus one, per character row, including spacing.

## R10-CURSOR START LINE R11-CURSOR END 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:

| Bit | Bit |
| :---: | :---: |
| 6 |  |
|  | 5 |
| 0 | 0 |
| 0 | 1 |
| 1 | 0 |
| 1 |  |
|  |  |

Cursor Blink Mode
Display Cursor Continuously Blank Cursor Continuously Blink Cursor at $1 / 16$ Field Rate Blink Cursor at $1 / 32$ Field Rate

## R12-DISPLAY START ADDRESS HIGH R13-DISPLAY START ADDRESS LOW

These registers form a 14 -bit register whose contents is the memory address of the first character of the displayed scan (the character on the top left of the video display, as in Figure 1). Subsequent memory addresses are generated by the R6545-1 as a result of CCLK input pulses. Scrolling of the display is accomplished by changing R12 and R13 to the memory address associated with the first character of the desired line of text to be displayed first. Entire pages of text may be scrolled or changed as well via R12 and R13.


Figure 1. Video Display Format

## R14-CURSOR POSITION HIGH R15-CURSOR POSITION LOW

These registers form a 14 -bit register whose contents is 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.

## R16-LIGHT PEN HIGH <br> R17-LIGHT PEN LOW

These registers form a 14-bit register whose contents is 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.

## REGISTER FORMATS

Register pairs R12/R13, R14/R15, and R16/R17 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.

## DESCRIPTION OF OPERATION

## VIDEO DISPLAY

Figure 1 indicates the relationship of the various program registers in the R6545-1 and the resultant video display.

Non-displayed areas of the Video Display are used 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 are used to 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

## Shared Memory Mode (R8, bit $3=$ " 0 ")

In this mode, the Refresh RAM address lines (MAO-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 external 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 (CRO-CR5).

## ADDRESSING MODES

## Row/Column

In this mode, the CRTC address lines (MAO-MA13) are generated as 8 column (MAO-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.

## Binary

In this mode, the CRTC address lines are straight binary and no compression circuits are needed. However, software complexity is increased since the CRT characters cannot be stored in terms of their row and column locations, but must be sequential.

## USE OF DYNAMIC RAM FOR REFRESH MEMORY

The R6545-1 permits the 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 2 illustrates Refresh RAM addressing for the case of binary addressing for 80 columns and 24 rows with 10 non-displayed columns and 10 non-displayed rows.


Figure 2. Memory Addressing Example (80 x 24)

## CURSOR OPERATION

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.

Bits 5 and 6 in the Cursor Start Line High Register (R10) control the cursor display and blink rate as follows:

| Bit 6 | Bit 5 | Cursor Operating Mode |
| :---: | :---: | :--- |
| 0 | 0 | Display Cursor Continuously |
| 0 | 1 | Blank Cursor Continuously |
| 1 | 0 | Blink Cursor at $1 / 16$ Field Rate |
| 1 | 1 | Blink Cursor at $1 / 32$ Field Rate |

The cursor of up to 32 characters in height can be displayed on and between the scan lines as loaded into the Cursor Start Line (R10) and Cursor End Line (R11) Registers.

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 16 K character positions. Hardware paging and data scrolling is thus allowed without loss of cursor position. Figure 3 is an example of the display cursor scan line.


Figure 3. Cursor Display Scan Line Control Examples

MPU WRITE TIMING CHARACTERISTICS

| Characteristic | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Cycle Time | ${ }^{T}$ CYC | 1.0 | - | 0.5 | - | $\mu s$ |
| 02 Pulse Width | ${ }^{T} \mathrm{C}$ | 440 | - | 200 | - | ns |
| Address Set-Up Time | $T_{A C W}$ | 180 | - | 90 | - | ns |
| Address Hold Time | ${ }^{T}$ CAH | 0 | - | 0 | - | ns |
| R/ $\bar{W}$ Set-Up Time | $T_{\text {WCW }}$ | 180 | - | 90 | - | ns |
| $\mathrm{R} \overline{\mathcal{W}}$ Hold Time | ${ }^{T}$ CWH | 0 | - | 0 | - | ns |
| Data Bus Set-Up Time | T ${ }_{\text {DCW }}$ | 265 | - | 100 | - | ns |
| Data Bus Hold Time | $\mathrm{T}_{\mathrm{HW}}$ | 10 | - | 10 | - | ns |

( $t_{r}$ and $t_{f}=10$ to 30 ns )

WRITE CYCLE


## MPU READ TIMING CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0\right.$ to $70^{\circ} \mathrm{C}$, unless otherwise noted)

| Characteristic | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Cycle Time | ${ }^{T} \mathrm{CYC}$ | 1.0 | - | 0.5 | - | $\mu s$ |
| 02 Pulse Width |  | 440 | - | 200 | - | ns |
| Address Set-Up Time | ${ }^{T}$ ACR | 180 | - | 90 | - | ns |
| Address Hold Time | ${ }^{T}$ CAR | 0 | - | 0 | - | ns |
| R/W Set.Up Time | $T_{\text {WCR }}$ | 180 | - | 90 | - | ns |
| Read Access Time | ${ }^{\top}$ CDR | - | 340 | - | 150 | ns |
| Read Hold Time | $T_{\text {HA }}$ | 10 | - | 10 | - | ns |
| Data Bus Active Time (Invalid Data) | ${ }^{T}$ CDA | 40 | - | 40 | - | ns |

( $\mathrm{t}_{\mathrm{r}}$ and $\mathrm{t}_{\mathrm{f}}=10$ to 30 ns )

READ CYCLE


## MEMORY AND VIDEO INTERFACE CHARACTERISTICS

${ }^{(1 v} C C=50 \mathrm{~V}+5 \%, T_{A}=0$ to $20^{\circ} \mathrm{C}$. uniess otherwise noted)

| Characteristics | Symbol | 1 MHz |  | 2 MHz |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Char Clock Crele Time | ${ }^{\top} \mathrm{CcY}$ | 04 | 40 | 0.4 | 40 | $\mu \mathrm{s}$ |
| Char Cluck Pulse Width | ${ }^{\top} \mathrm{CCH}$ | 200 |  | 200 | $\cdots$ | ns |
| MAO-MA 13 Propagation Delay | $\mathrm{T}_{\text {MAD }}$ | - | 300 | - | 300 | ns |
| haO RA4 Propagation Delay | $T_{\text {Tha }}$ | * | 300 | - | 300 | ns |
| DISPLAY ENABLE Prop. Delay | ${ }^{\text {T }}$ | - | 450 | - | 450 | ns |
| HYSNC Propagation Delay | ${ }^{\text {THSD }}$ | - | 450 | - | 450 | ns |
| VSYNC Propagation | ${ }^{T}$ VSD | - | 450 | - | 450 | ns |
| Cursor Propagation Delay | ${ }^{\top}$ CDO | - | 450 | - | 450 | ns |
| LPEN Strobe Width | ${ }^{T}$ LPH | 150 | - | 150 | - | ns |
| - LPEN io CCLEK Deray | ${ }^{\text {L }}$ LP ${ }_{\text {L }}$ | 20 |  | 20 | - | $n s$ |
| CCLK to LPEN Detay | ${ }^{\text {L LP2 }}$ | 0 | - | 0 | - | ns |



LIGHT PEN STROBE TIMING DEFINITIONS

CCLK


NOTE:
SLASH AREA DEFINES THE "WINDOW" IN WHICH AN
LPEN POSITIVE EDGE WILL CAUSE ADDRESS $N+2$ TO
LOAD INTO LIGHT PEN REGISTER. TRANSITIONS ON
EITHER SIDE OF THIS "WINDOW" WILL RESULT in
UNPREDICTABLE VALUES BEING LOADED INTO THE
LIGHT PEN REGISTER.

## SPECIFICATIONS

Maximum Ratings

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $v_{\text {cc }}$ | -0.3 to +7.0 | Vde |
| Input Voltage | $V_{\text {IN }}$ | . 0.3 to +7.0 | $V \mathrm{dc}$ |
| Operating Temperature Range | ${ }^{\text {T OP }}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | ${ }^{\text {T STG }}$ | . 55 to 150 | ${ }^{\circ} \mathrm{C}$ |

All inputs contain protection circuitry to prevent damage due to high static discharges. Care should be taken to prevent unnecessary application of voltages in excess of the allowable limits.

## Electrical Characteristics

$\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0.70^{\circ} \mathrm{C}\right.$, unless otherwise noted)

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $V_{\text {IH }}$ | 2.0 | ${ }^{\mathrm{V}} \mathrm{CC}$ | $V \mathrm{dc}$ |
| Input Low Voltage | $V_{\text {IL }}$ | 0.3 | 0.8 | $V$ dc |
| Input Leakage (02, R/W, $\overline{\mathrm{RES}}, \overline{C S}, \mathrm{RS}, \mathrm{LPEN}, \mathrm{CCLK}$ ) | ${ }_{1} 1 \mathrm{~N}$ | - | 2.5 | $\mu \mathrm{Adc}$ |
| Three-State Input Leakage (DO-D7) |  |  |  |  |
| $\left(\mathrm{V}_{1 \mathrm{~N}}=0.4\right.$ to 2.4 V$)$ | ${ }^{\text {I TSI }}$ | - | 10.0 | $\mu \mathrm{Adc}$ |
| Output High Voltage |  |  |  |  |
| $\prime_{\text {LOAD }}=205 \mu \mathrm{Adc}$ (D0.D7) | $v^{\mathrm{OH}}$ | 2.4 | - | Vdc |
| ${ }^{1}$ LOAD $=100 \mu \mathrm{Adc}$ (all others) |  |  |  |  |
| Output Low Voltage |  |  |  |  |
| $\mathrm{I}_{\text {LOAD }}=1.6 \mathrm{mAdc}$ | $v_{\text {OL }}$ | - | 0.4 | Vdc |
| Power Dissipation | $P_{\text {D }}$ | - | 1000 | mW |
| Input Capacitance |  |  |  |  |
| 02, R $\bar{W}, \overline{\mathrm{RES}}, \overline{\mathrm{CS}}, \mathrm{RS}, \mathrm{LPEN}, \mathrm{CCLK}$ | $\mathrm{C}_{\text {IN }}$ | - | 10.0 | pF |
| D0-D7 |  | - | 12.5 | pF |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | - | 10.0 | pF |

## TEST LOAD



R=11K $\Omega$ FOR DO-D7
$=24 K \Omega$ FOR ALL OTHER OUTPUTS PRODUCT DESCRIPTION

# R6551 Asynchronous Communications Interface Adapter (ACIA) 

## SECTION 1 INTRODUCTION

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 R6551 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 the external clock rate. The R6551 has programmable word lengths of $5,6,7$, or 8 bits; even, odd, or no parity; $1,1-1 / 2$, or 2 stop bits.

The R6551 is designed for maximum programmed control from the CPU, to simplify hardware implementation. Three separate registers permit the CPU 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 $\overline{R T S}$ line, receiver interrupt control, and the state of the $\overline{D T R}$ line.

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

The Status Register incicates the states of the $\overline{\mathrm{IRQ}}$, $\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 R6551 Transmit and Receiver circuits.

## FEATURES

- Compatible with 8-bit microprocessors
- Full duplex operation with buffered receiver and transmitter
- Dato 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 ectio mode
- Two chip selects
- 2 MHz or 1 MHz operation
- Single $5 \mathrm{~V} \pm 5 \%$ power supply
- 28-pin plastic or ceramic DIP
- Full TIL compatibility


## SECTION 2 <br> R6551 INTERFACE REOUIREMENTS

This section describes the interface requirements for the R6551 ACIA. Figure 2-1 is the Interface Diagram and Figure 2-2 shows the pin-out configuration for the R6551.


Figure 2-1. R6551 INTERFACE DIAGRAM

### 2.1 MICROPROCESSOR INTERFACE SIGNAL DESCRIPTION

## $\overline{\operatorname{RES}}$ (Reset) (4)

During system initialization a low on the $\overline{\operatorname{RES}}$ input will cause a hardware reset to occur. The Command Register and the Control Register will be cleared. The Status Register will be cleared with the exception of the indications of Data Set Ready and Data Carrier Detect, which are externally controlled by the $\overline{D S R}$ and DCD lines, and the transmitter Empty bit, which will be set. $\overline{R E S}$ must be held low for one $\varnothing 2$ clock cycle for a reset to occur.

## $\boldsymbol{\sigma 2}$ (Input Clock) (27)

The input clock is the system $\varnothing 2$ clock and is used to clock all data transfers between the system microprocessor and the R6551.


Figure 2-2. R6551 PIN CONFIGURATION

R/ $\bar{W}$ (Read/Write) (28)
The $R / \bar{W}$ input, generated by the microprocessor, is used to control the direction of data transfers. A high on the $R / \bar{W}$ pin allows the processor to read the data supplied by the R6551, a low allows a write to the R6551.

## $\overline{\mathrm{IRO}}$ (Interrupt Request) (26)

The $\overline{I R Q}$ 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, $\stackrel{\rightharpoonup}{\mathrm{I} Q}$ goes low when an interrupt occurs.

## D0-D7 (Data Bus) (18-25)

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

## CSO, $\overline{\operatorname{CS} 1}$ (Chip Selects)(2,3)

The two chip select inputs are normally connected to the processor address lines either directly or through decoders. The R6551 is selected when CSO is high and $\overline{C S 1}$ is low.

## RS0. CS1 (Register Selects)(13.14)

The two register select lines are normalty connected to the processor address lines to allow the processor to select the various R6551 internal registers. The following table shows the internal register select coding.

| RS1 | RS0 | Write | Read |
| :---: | :---: | :---: | :---: |
| 0 | 0 | Transmit Data <br> Register | Receiver Data <br> Register |
| 0 | 1 | Programmed <br> Reset (Data is <br> "Don't Care ") | Status Register |
| 1 | 0 | Command Register |  |
| 1 | 1 | Control Register |  |

Only the Command and Control registers are read/write. 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 ( $\overline{\mathrm{RES}}$ ); these differences are shown in Figures 3-2, 3-3, and 3-4.

### 2.2 ACIA/MODEM INTERFACE SIGNAL DESCRIPTION

## XTLI, XTLO (Crystal Pins) (6, 7)

These pins are normally directly connected to the external crystal ( 1.8432 MHz ) used to derive the various baud rates (see Section 4.5). Alternatively, an externally generated clock may be used to drive the XTLI pin, in which case the XILO pin must float. XILI is the input pin for the transmit clock.

## TxD (Transmit Data) (10)

The $T_{x} D$ output line is used to transfer serial NRZ (nonreturn-to-zero) data to the modem. The LSB (least significant bit) 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 under control of an external clock. This selection is made by programming the Control Register.

## RxD (Receive Data) (12)

The $R \times D$ input line is used to transfer serial NRZ data into the ACIA from the modem, LSB first. The receiver data
rate is either the programmed baud rate or under the control of an externally generated receiver clock. The selection is made by programming the Control Register.

## RxC (Receive Clock) (5)

The $R \times C$ is a bi-directional pin which serves as either the receiver $16 \times$ 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.

## $\overline{\mathrm{RTS}}$ (Request to Send) (8)

The $\overline{R T S}$ output pin is used to control the modem from the processor. The state of the $\overline{R T S}$ pin is determined by the contents of the Command Register.

## $\overline{\mathrm{CTS}}$ (Clear to Send) (9)

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

## $\overline{\text { DTR }}$ (Data Terminal Ready) (11)

This output pin is used to indicate the status of the R6551 to the modem. A low on $\overline{D T R}$ indicates the R6551 is enabled, a high indicates it is disabled. The processor controls this pin via bit 0 of the Command Register.

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

The $\overline{D S R}$ input pin is used to indicate to the R6551 the status of the modem. A low indicates the "ready" state and a high, "not-ready".

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

The $\overline{D C D}$ input pin is used to indicate to the R6551 the status of the carrier-detect output of the modem. A low indicates that the modem carrier signal is present and a high, that it is not.

# SECTION 3 <br> INTERNAL ORGANIZATION 

This section provides a functional description of the R6551. A block diagram of the R6551 is presented in Figure 3-1.


Figure 3-1. INTERNAL ORGANIZATION

### 3.1 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 high and the chip is selected, the Data Bus Buffer passes the data from the system data lines to the R6551 internal data bus. When the $R / \bar{W}$ line is low and the chip is selected, the Data Bus Buffer writes the data from the internal data bus to the system data bus.

### 3.2 INTERRUPT LOGIC

The Interrupt Logic will cause the $\overline{I R Q}$ 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{D C D}$ ) 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.

### 3.3 I/O CONTROL

The 1/O Control Logic controls the selection of internal registers in preparation 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 and Chip Select and Read/Write lines as described in Table 2-3 previously.

### 3.4 TIMING AND CONTROL

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

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{R E S}$ ) line goes low. See the individual register description for the state of the registers following a hardware reset.

### 3.5 TRANSMITTER AND RECEIVER DATA REGISTERS

These registers are used as temporary data storage for the R6551 Transmit and Receive Circuits. Both the Transmitter and Receiver are selected by a Register Select 0 (RSO) and Register Select 1 (RSI) low condition. The Read/Write 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.

### 3.6 STATUS REGISTER

Figure 3-2 indicates the format of the R6551 Status Register. A description of each status bit follows.


Figure 3-2. STATUS RE GISTER FORMAT

### 3.6.1 Receiver Data Register Full (Bit 3)

This bits goes to a "I" when the R655I transfers data from the Receiver Shift Register to the Receiver Data Register, and goes to a " 0 " when the processor reads the Receiver Data Register.

### 3.6.2 Transmitter Data Register Empty (Bit 4)

This bits goes to a "1" when the R6551 transfers data from the Transmitter Data Register to the Transmitter Shift Register, and goes to a "0" when the processor writes new data onto the Transmitter Data Register.

### 3.6.3 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 R6551. A "0" indicates a low level (true condition) and a " $l$ " indicates a high (false). Whenever either of these inputs change state, an immediate processor interrupt occurs, unless the R6551 is disabled (bit 0 of the Command Register is a " 0 "). When the interrupt occurs, the status bits will indicate the levels of the inputs immediately after the change of state occurred. Subsequent level changes will not affect the status bits until the Status Register is interrogated by the processor. At that time, another interrupt will immediately occur and the status bits will reflect the new input levels.

### 3.6.4 Framing Error (Bit 1), Overrun (2), and Parity Error (Bit 0)

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.

### 3.6.5 Interrupt (Bit 7)

This bit goes to a "0" when the Status Register has been read by the processor, and goes to a " 1 " whenever any kind of interrupt occurs.

### 3.7 CONTROL REGISTER

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

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

These bits, set by the processor, 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 as shown in Figure 3-3.


Figure 3-3. R6551 CONTROL REGISTER

### 3.7.2 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 as shown in Figure 3-3.

### 3.7.3 Word Length (Bits 5, 6)

These bits determine the word length to be used $(5,6,7$ or 8 bits). Figure 3-3 shows the configuration for each number of bits desired.

### 3.7.4 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-1 / 2$ stop bits if the word length is 5 with no parity selected, I stop bit if the word length is 8 with parity selected, and 2 stop bits in all other configurations.

### 3.8 COMMAND REGISTER

The Command Register controls specific modes and functions.

### 3.8.1 Data Terminal Ready (Bit 0)

This bit enables all selected interrupts and controls the state of the Data Terminal Ready ( $\overline{D T R}$ ) line. A " 0 " indicates the microcomputer system is not ready by setting the $\overline{D T R}$ line high. A "1" indicates the microcomputer system is ready by setting the $\overline{D T R}$ line low.

### 3.8.2 Receiver Interrupt Control (Bit 1)

This bit disables the Receiver from generating an interrupt when set to a "l". The Receiver interrupt is enabled when this bit is set to a " 0 " and Bit 0 is set to a " 1 ".

### 3.8.3 Transmitter Interrupt Control (Bits 2, 3)

These bits control the state of the Ready to Send ( $\overline{R T S}$ ) line and the Transmitter interrupt. Figure 3-4 shows the various configurations of the RTS line and Transmit Interrupt bit settings.

### 3.8.4 Receiver Echo Mode (Bit 4)

This bit enables the Receiver Echo Mode. Bits 2 and 3 must also be zero. In the Receiver Echo Mode, the Transmitter returns each transmission received by the Receiver delayed by one-half bit time. A "l" enables the Receiver Echo Mode. A "0" bit disables the mode.

### 3.8.5 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.


Figure 3-4. R6551 COMMAND REGISTER

### 3.8.6 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). Figure 3-4 shows the possible bit configurations for the Parity Mode Control bits.

### 3.9 TRANSMITTER AND RECEIVER

Bits $0-3$ of the Control Register select divisor used to generate the baud rate for the Transmitter. If the Receiver clock is to use the same baud rate as the transmitter, then $\mathrm{R} \times \mathrm{C}$ becomes an output and can be used to slave other circuits to the R6551. Figure 3-5 shows the transmitter and Receiver layout.


Figure 3-5. TRANSMITTER/RECEIVER CLOCK CIRCUITS

## SECTION 4 <br> OPERATION

### 4.1 TRANSMITTER AND RECEIVER OPERATION

### 4.1.1 Continuous Data Transmit (Figure 4-1)

In the normal operating mode, the processor interrupt ( (IRQ) is used to signal when the R 6551 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 R6551, 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 4-1. CONTINUOUS DATA TRANSMIT

### 4.1.2 Continuous Data Receive (Figure 4-2)

Similar to the above case, the normal mode is to generate a processor interrupt when the R 6551 has received a full data word. This occurs at about the 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 4-2. CONTINUOUS DATA RECEIVE

### 4.1.3 Transmit Data Register Not Loaded by Processor (Figure 4-3)

If the processor is unable to load the Transmit Data Register in the allocated time, then the $T \times D$ line will go to the "MARK" condition until the data is loaded. Processor 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 4-3. TRANSMIT DATA REGISTER NOT LOADED BY PROCESSOR

### 4.1.4 Effect of $\overline{\mathrm{CTS}}$ on Transmitter (Figure 4-4)

$\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. This is covered later in this note. $\overline{C T S}$ is a transmit control line only, and has no effect on the R6551 Receiver Operation.


Figure 4-4. EFFECT OF CTS ON TRANSMITTER

### 4.1.5 Effect of Overrun on Receiver

(Figure 4-5)

See 4. 1. 2 for normal Receiver operation. If the processor does not read the Receiver data Register in the allocated time, then, when the following 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 4-5. EFFECT OF OVERRUN ON RECEIVER

### 4.1.6 Echo Mode Timing (Figure 4-6)

In Echo Mode, the $T_{x} D$ line re-transmits the data on the
$R \times D$ line, delayed by $1 / 2$ of the bit time.


Figure 4-6. ECHO MODE TIMING

### 4.1.7 Effect of $\overline{\text { CTS }}$ on Echo Mode Operation (Figure 4-7)

See 4.1.4 for the effect of $\overline{C T S}$ on the Transmitter. Receiver operation is unaffected by CTS, so, in Echo Mode, the Transmitter is affected in the same way as 4.1.4. In this
case, however, the processor interrupts signify that the Receiver Data Register is full, so the processor has no way of knowing that the Transmitter has ceased to echo.


Figure 4-7. EFFECT OF CTS ON ECHO MODE

### 4.1.8 Overrun in Echo Mode (Figure 4-8)

If Overrun occurs in Echo Mode, the Receiver is affected the same way as described in 4.1.5. For the re-transmitted data, when overrun occurs, the T×D line goes to the
"MARK" condition until the first Start Bit after the Receiver Data Register is read by the processor.


Figure 4-8. OVERRUN IN ECHO MODE

### 4.1.9 Framing Error (Figure 4-9)

Framing Error is caused by the absence of Stop Bit(s) on received data. The status bit is set when the processor interrupt occurs. Subsequent data words are tested for Framing Error separately, so the status bit will always reflect the last data word received.


Figure 4-9. FRAMING ERROR

### 4.1.10 Effect of $\overline{\mathrm{DCD}}$ on Receiver (Figure 4-10)

$\overline{D C D}$ is a modem output used to indicate the status of the carrier-frequency-detection circuit of the modem. This line goes high for a loss of carrier. Normally, when this occurs, the modem will stop transmitting data ( $R \times D$ on the R6551) some time later. The R6551 will cause a processor interrupt whenever $\overline{\mathrm{DCD}}$ changes state and will indicate this condition via 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 R6551 automatically checks the level of the $\overline{D C D}$ line, and if it has changed, another interrupt occurs.


Figure 4-10. EFFECT OF $\overline{D C D}$ ON RECEIVER

### 4.1.11 Timing with 1-1/2 Stop Bits (Figure 4-11)

It is possible to select $1-1 / 2$ Stop Bits, but this occurs only for 5-bit data words with no parity bit. In this case, the processor interrupt for Receiver Data Register Full occurs in halfway through the trailing half-Stop Bit.


Figure 4-11. TIMING WITH 1-1/2 STOP BITS

### 4.1.12 Transmit Continuous "BREAK"

 (Figure 4-12)This mode is selected via the R6551 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, on immediate Stop Bit will be generated and transmission will resume.


Figure 4-12. TRANSMIT CONTINUOUS "BREAK"

### 4.1.13 Receive Continuous "BREAK"

 (Figure 4-13)In the event the modem transmits continuous "BREAK" characters, the R6551 will terminate receiving. Reception will resume only after a Stop Bit is encountered by the R6551.


Figure 4-13. RECEIVE CONTINUOUS "BREAK"

### 4.2 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 R6551 should be interrogated, as follows:
I. Read Status Register

This operation automatically clears Bit 7 ( $\overline{I R Q}$ ). Subsequent transitions on $\overline{D S R}$ and $\overline{D C D}$ will cause another interrupt.
2. Check IRQ Bit

If not set, interrupt source is not the R6551.
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)

Only if Receiver Data Register is full.
6. Check TDRE (Bit 4)

Check for Transmitter Data Register Empty.
7. If none of the above, then $\overline{\mathrm{CTS}}$ must have gone to the FALSE (high) state.

### 4.3 PROGRAMMED RESET OPERATION

A program reset occurs when the processor performs a write operation to the R6551 with RSO low and RSI high. The program reset operates somewhat different from the hardware reset ( $\overline{\operatorname{RES}}$ pin) and is described as follows:

1. Internal registers are not completely cleared. The data sheet indicates 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{I R Q}$ 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{\mathrm{DCD}}$ and $\overline{\mathrm{DSR}}$ interrupts 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.

### 4.4 MISCELLANEOUS NOTES ON OPERATION

1. If Echo Mode is selected, $\overline{R T S}$ goes low.
2. If Bit 0 of Command Register is " 0 " (disabled), then:
a) All interrupts disabled, including those caused by $\overline{D C D}$ and $\overline{D S R}$ transitions.
b) Transmitter disabled immediately.
c) Receiver disabled, but a character currently being received will be completed first.
3. Odd parity occurs when the sum of all the "l" 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 is used to generate parity error for the Status Register.
5. Transmitter and Receiver may be in full operation simultaneously. This is "full-duplex" mode.
6. If the $R \times D$ line inadvertently goes low and then high right after a Stop Bit, the R6551 does not interpret this as a Start Bit, but samples the line again halfway into the bit to determine if it is a true Start Bit or a false one. For false Start Bit detection, the R6551 does not begin to receive data, instead, only a true Start Bit initiates receiver operation.
7. Precautions to consider with the crystal oscillator circuit:
a) The external crystal to be used should be a "series" mode crystal.
b) The XTALI input may be used a an external clock input. The unused pin must be floating and may not be used for any other function.
8. $\overline{\mathrm{DCD}}$ and $\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 either to GND or $V_{c c}$.

### 4.5 GENERATION OF NON-STANDARD BAUD RATES

### 4.5.1 Divisors

The internal counter/divider circuit selects the appropriate divisor for the crystal frequency by means of bits $0-3$ of the R6551 Control Register.

The divisors, then, are determined by bits $0-3$ in the Control Register and their values are shown in Figure 4-14.

### 4.5.2 Generating Other Baud Rates

By using a different crystal, other 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 R6551 with an offchip oscillator to achieve the same thing. In this case, XTALI (pin 6) must be the clock input and XTALO (pin 7) must be a no-connect.

| CONTROL REGISTER BITS | $\begin{aligned} & \text { DIVISOR SELECTED } \\ & \text { FOR THE } \\ & \text { INTERNAL COUNTER } \end{aligned}$ | BAUD RATE GENERATED WITH 1.8432 MHz CRYSTAL | BAUD RATE GENERATED WITHACRYSTAL OF FREQUENCY (F) |
| :---: | :---: | :---: | :---: |
| $3-20$ |  |  |  |
| 0 0 000 | No Divisor Selected | $16 \times$ External Clock at Pin $\mathrm{A} \times \mathrm{C}$ | $16 \times$ External Clock at $\operatorname{Pin} \mathrm{A} \times \mathrm{C}$ |
| 0 | 36.864 | $\frac{18432 \times 10^{6}}{36.864}=50$ | $\frac{F}{36.864}$ |
| $0 \quad 0 \quad 10$ | 24.576 | $\frac{18432 \times 10^{6}}{24.576}=75$ | $\frac{F}{24.576}$ |
| 0 | 16.769 | $\frac{18432}{16.769}=10992$ | $\begin{gathered} F \\ 16.769 \end{gathered}$ |
| 0100 | 13.704 | $\frac{18432 \times 10^{6}}{13.704}=13451$ | $\frac{F}{13.704}$ |
| $0 \begin{array}{llll}0 & 1 & 0 & 1\end{array}$ | 12.288 | $1 \frac{8432 \times 10^{6}}{12.288}=150$ | $-\frac{F}{12.288}$ |
| 0 1 1 1 0 | 6.144 | $\frac{1.8432 \times 10^{6}}{6,144}=300$ | $\frac{F}{6.144}$ |
| $0 \quad 1111$ | 3.072 | $\frac{1.8432 \times 10^{4}}{3.072}=600$ | $\frac{F}{3.072}$ |
| 10000 | 1.536 | $\frac{1.8432 \times 10^{6}}{1.536}=1.200$ | - 1.536 |
| $1 \begin{array}{llll}1 & 0 & 0 & 1\end{array}$ | 1.024 | $\frac{18432 \times 10^{6}}{1.024}=1.800$ | $\frac{F}{1.024}$ |
| 1010 | 768 | $\frac{1.8432 \times 10^{6}}{768}=2.400$ | F 768 |
| 1010 | 512 | $\frac{1.8432 \times 10^{4}}{512}=3.600$ | $\begin{gathered} F \\ \hline 512 \\ \hline \end{gathered}$ |
| 1100 | 384 | $\frac{1.8432 \times 10^{6}}{384}=4.800$ | $\frac{F}{384}$ |
| $1 \begin{array}{llll}1 & 1 & 0 & 1\end{array}$ | 256 | $\frac{1.8432 \times 10^{4}}{256}=7.200$ | $\frac{F}{256}$ |
| 1110 | 192 | $\frac{1.8432 \times 10^{6}}{192}=9.600$ | $\frac{F}{192}$ |
| 1111 | 96 | $\frac{1.8432 \times 10^{6}}{96}=19.200$ | $\frac{F}{96}$ |

Figure 4-14. DIVISOR SELECTION FOR THE R6551

### 4.6 DIAGNOSTIC LOOP-BACK OPERATING MODES

A simplified block diagram for a system incorporating an R6551 ACIA is shown in Figure 4-15.


Figure 4-15. SIMPLIFIED SYSTEM DIAGRAM

Occosionally it may be desirable to include in the system a facility for "loop-back" diagnostic testing, of which there are two kinds:

## 1. Local Loop-Back

Loop-back from the point of view of the processor. In this case, 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.
2. Remote Loop-Back

Loop-back from the point of view of the Data Link and Modem. In this case, the processor, itself, is disconnected and all received data is immediately retransmitted, so the system on the other end of the Data Link may operate independent of the local system.

The R6551 does not contain automatic loop-back operating modes, but they may be implemented with the addition of a small amount of external circuitry.

Figure 4-16 indicates the necessary logic to be used with the R6551.

The LLB line is the positive-true signal to enable local loop-back operation. Essentially, LLB $=$ high does the following:

1. Disables outputs $T \times D, \overline{D T R}$, and $\overline{R T S}$ (to Modem).
2. Disables inputs $R \times D, \overline{D C D}, \overline{C T S}, \overline{D S R}$ (from Modem).
3. Connects transmitter outputs to respective receiver inputs:
a) $I \times D$ to $R \times D$
b) $\overline{D T R}$ to $\overline{D C D}$
c) $\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 loop-back diagnostic testing.


Figure 4-16. LOOP-BACK CIRCUIT SCHEMATIC

Remote loop-back does not require this circuitry, so LLB must be set low. However, the processor must select the following:

1. Control Register bit 4 must be "l", so that the transmitter clock $=$ receiver clock .
2. Command Register bit 4 must be " 1 " to select Echo Mode.
3. Command Register bits 3 and 2 must be " 1 " and " 0 ", respectively to disable $\overline{\mathbb{R} Q}$ interrupt to transmitter.
4. Command Register bit 1 must be " 0 " to disable $\overline{\mathrm{IRQ}}$ interrupt for receiver.

In this way, the system re-transmits received data without any effect on the local system.

## 4.7 $\overline{D C D}$ AND $\overline{D S R}$ AS SWITCH SENSE INPUTS

The R6551 (Asynchronous Communication Interface Adapter) has several special-purpose control pins. Among them are the input signals, $\overline{\mathrm{DCD}}$ (Data Carrier Detect) and $\overline{\text { DSR }}$ (Data Set Ready). The normal functions of these pins are adequately described in the R6551 data sheet and are not covered here. However, it is possible to use these pins as switch sense inputs; that is, as input pins used to detect the state of switches or circuit jumpers in the system.

An important requirement of the use of $\overline{D C D}$ and $\overline{D S R}$ as sense inputs is that they must not normally change state during system operation. If they do, and if the R6551 is enabled, then immediate processor interrupts will occur and normal operation will be interrupted. If, however, these pins are connected to switches or circuit-board jumper wires which do not change state during operation, then they can be sensed by the processor and may be used to select special operating modes.

The circuit connections are quite simple and are outlined in Figure 4-17.


Figure 4-17. CIRCUIT CONNECTIONS FOR $\overline{D C D}$ AND $\overline{D S R}$

Note that pull-up resistors are required, since $\overline{D C D}$ and $\overline{D S R}$ are high-impedance inputs on the R6551.

In order to sense the state of the inputs, it is necessary to do the following:

1. Disable the R6551 by setting bit 0 of the Command Register to a " 0 ".
2. Read the R6551 Status Register. Bits 5 and 6 will then indicate the levels on $\overline{D C D}$ and $\overline{D S R}$, respectively. $A$ " 0 " is a low level and a " 1 " is a high.

As long as the R6551 is disabled, the Status Register will reflect the levels on the pins and no interrupts will occur, even if the pins change state. However, if the R6551 is enabled, then changes of state of the $\overline{D C D}$ and $\overline{D S R}$ levels cause immediate interrupts and the Status Register indicates the levels taken on the interrupt. Subsequent level changes are not indicated by the Status Register until the interrupt is serviced. Thus, it is not convenient to use DCD and DSR as general switching inputs, but they may easily be used as inputs which do not change regularly.

## APPENDIX CHARACTERISTICS AND RATINGS

## READ/WRITE CYCLE CHARACTERISTICS

$\left(V_{C C}=5.0 \vee \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0\right.$ to $70^{\circ} \mathrm{C}$. unless otherwise noted)

| Characteristic | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Cycle Time | ${ }^{1} \mathrm{CYC}$ | 1.0 | 40 | 0.5 | 40 | $\mu \mathrm{s}$ |
| 02 Pulse Width | ${ }^{4} \mathrm{C}$ | 400 | - | 200 | - | ns |
| Address Set. Up Time | ${ }^{1} \mathrm{AC}$ | 120 | - | 70 | - | ns |
| Address Hold Time | ${ }^{1} \mathrm{CAH}$ | 0 | - | 0 | - | ns |
| R/W Set-Up Time | twC | 120 | -- | 70 | - | ns |
| R/W Hold Time | ${ }^{1} \mathrm{CWH}$ | 0 | - | 0 | - | ns |
| Data Bus Set-Up Time | tocw | 150 | - | 60 | - | ns |
| Data Bus Hold Time | ${ }^{\text {t HW }}$ | 20 | - | 20 | - | ns |
| Read Access Time (Valid Data) | ${ }^{1} \mathrm{CDR}$ | - | 200 | - | 150 | ns |
| Read Hold Time | ${ }^{\text {i HR }}$ | 20 | - | 20 | - | ns |
| Bus Active Time (Invalid Data) | ${ }^{1}$ CDA | 40 | - | 40 | -- | ns |

$\left(\mathrm{t}_{\mathrm{r}}\right.$ and $\mathrm{t}_{\mathrm{f}}=10$ to 30 ns )


Read Timing Characteristics

TRANSMIT/RECEIVE CHARACTERISTICS

| Characteristic | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Transmit/Receive Clock Rate | ${ }^{\text {' }} \mathrm{CCY}$ | 400* | - | 400* | - | ns |
| Transmit/Receive Clock High Time | ${ }^{t} \mathrm{CH}$ | 175 | - | 175 | $\cdots$ | ns |
| Transmit/Receive Clock Low Time | ${ }^{1} \mathrm{CL}$ | 175 | - | 175 | - | ns |
| XTLI to $T \times D$ Propagation Delay | ${ }^{1} \mathrm{DD}$ | - | 500 | - | . 500 | ns |
| $\overline{\text { RTS }}$ Propagation Delay | ${ }^{\text {t OLY }}$ | - | 500 | - | 500 | ns |
| $\overline{\text { IRQ Propagation }}$ Delay (Clear) | ${ }^{\text {tina }}$ | - | 500 | - | 500 | ns |

( $t_{r}, t_{f}=10$ to 30 ns )
*The baud rate with externat clocking is: Baud Rate $=\frac{1}{16 \times T_{\mathrm{CCY}}}$
XTLI
(TRANSMIT
CLOCK INPUT)


Transmit Timing with External Clock


NOTE: RxD rate is $\mathbf{1 / 1 6} \mathrm{RxC}$ rate

Receive External Clock Timing

## PACKAGE OUTLINES

28 LEAD CERAMIC


28 LEAD PLASTIC


## SPECIFICATIONS

## Maximum Ratings

| Rating | Symbol | Value | Unit |
| :--- | :--- | :--- | :--- |
| Supply Voltage | $V_{C C}$ | -0.3 to +7.0 | $V_{d c}$ |
| Input Voltage | $V_{\text {in }}$ | -0.3 to +7.0 | $V_{d c}$ |
| Operating Temperature | $T$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | TSTG | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

This device contains input protection against damage due to high static voltages or electric fields; however, precautions should be taken to avoid application of voltages higher than the maximum rating.

## Electrical Characteristics

$\left(V_{C C}=5.0 \pm 5 \%, T_{A}=0-70^{\circ} \mathrm{C}\right.$, unless otherwise noted)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage (Except XTLI and XTLO) (XTLI and XTLO) | $\mathrm{V}_{\text {IH }}$ | $\begin{aligned} & 2.0 \\ & 2.4 \end{aligned}$ | - | $\begin{aligned} & v_{C C} \\ & v_{C C} \end{aligned}$ | $\checkmark$ |
| Input Low Voltage (Except XTLI and XTLO) (XTLI and XTLO) | VIL | $V_{S S}$. <br> $V_{S S}$ |  | $\begin{aligned} & 0.8 \\ & 0.4 \end{aligned}$ | V |
| Input Leakage Current: $V_{I N}=0$ to 5 V . <br> ( $02, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{RES}}, \mathrm{CSO}, \overline{\mathrm{CS} 1, R S O}, \mathrm{RS} 1, \overline{\mathrm{CTS}}, R \times D, \overline{\mathrm{DCD}}, \overline{\mathrm{DSR}}$ ) | IIN | - |  | $\pm 2.5$ | $\mu \mathrm{A}$ |
| Input Leakage Current for High Impedance State (Three State) | ITSI | - |  | $\pm 10.0$ | $\mu \mathrm{A}$ |
| Output High Voltage: 'LOAD $=-100 \mu \mathrm{~A}$ (D0-D7, T×D, $\mathrm{R} \times \mathrm{C}, \overline{\mathrm{RTS}}, \overline{\mathrm{DTR}}$ ) | VOH | 2.4 | - | -. | $\checkmark$ |
| Output Low Voltage: I LOAD $=1.6 \mathrm{~mA}$ (DO-D7), T×D, R×C, $\overline{R T S}, \overline{D T R}, \overline{\mathrm{IRO}}$ ) | $\mathrm{V}_{\mathrm{OL}}$ | -- | - | 0.4 | $\checkmark$ |
| Output High Current (Sourcing): $\mathrm{VOH}_{\mathrm{OH}}=2.4 \mathrm{~V}$ (D0-D7. T×D. R×C, $\overline{R T S}, \overline{D T R}$ ) | ${ }^{1} \mathrm{OH}$ | $-100$ |  | - | $\mu \mathrm{A}$ |
| Output Low Current (Sinking): $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ (DO-D7, T×D, R×C, $\overline{R T S}, \overline{D T R}, \overline{\mathrm{RO}}$ ) | IOL | 1.6 | - | - | mA |
| Output Leakage Current (off state): $\mathrm{V}_{\text {OUT }}=5 \mathrm{~V}(\underline{\mathrm{IRO}})$ | IOFF | - |  | 10.0 | $\mu \mathrm{A}$ |
| Clock Capacitance ( $\mathbf{Q}^{\text {2 }}$ | $\mathrm{C}_{\text {CLK }}$ | - | - | 20 | pF |
| Input Capacitance (except XTLI and XTLO) | $\mathrm{CIN}^{\text {IN }}$ | - | - | 10 | pF |
| Output Capacitance | COUT | - | - | 10 | pF |
| Power Dissipation | PD | - | 170 | 300 | mW |

앙을

# DATA SHEET 

Controls EPSON Dot-Matrix Impact Printers:
Model 210
Model 220
Model 240
Model 511L
Model 512
Model 522
Model 541L
Model 542

- Minimal Support Circuitry Required
- On-Chip $5 \times 7$ Dot-Matrix Character Generation
- 96 Standard Upper and Lower Case ASCII Characters $(7$ Bit Code)
- Six Special ASCII Characters (7 Bit Code)
- Up to 10 ASCII Commands Accepted (Printer Dependent)
- Selectable Serial or Parallel Input Data Operation
- Centronics Standard Parallel Interface
- Seven Data Lines Plus Data Strobe and Input Drive Input
- Busy and Acknowledge Output
- RS-232C Serial Interface
- Baud Rate from 50 to 7200 Bits per Second
- Received Data and Data Set Ready Input
- Data Terminal Ready Output
- Single $+5 \mathrm{~V} \pm 10 \%$ power supply
- 40 pin plastic or ceramic DIP
- 1 MHz operation ( 2 MHz external crystal)

| VRR | 1 | 40 | $\square \mathrm{VCC}(+5 \mathrm{Vdc})$ |
| :---: | :---: | :---: | :---: |
| $\overline{\text { PCL3 }}$ | 2 | 39 | $\square$ RES |
| PCL2 | 3 | 38 | PPTR TIM |
| $\overline{\text { PCLI }}$ | 4 | 37 | $\square \overline{D S} / \overline{R S D}$ |
| NC | 5 | 36 | SER SEL |
| PM1 | 6 | 35 | $\square \overline{\mathrm{PRT}}$ |
| SER DET | 7 | 34 | $\square \mathrm{PM} 2$ |
| $\overline{\text { ACK }}$ | 8 | 33 | PM3 |
| BUSY/DTP | 9 | 32 | RR |
| XTLI | 10 | 31 | ) $\dot{R} / \mathrm{L} / \mathrm{RL}$ |
| XTLO | 11 | 30 | VCC |
| VSS | 12 | 29 | 3 DLI |
| $\overline{M D S}$ | 13 | 28 | DL2 |
| PS7 | 14 | 27 | DL3 |
| $\overline{\text { PS6 }}$ | 15 | 26 | 1 DL4 |
| PS5 | 16 | 25 | $1 \mathrm{DL5}$ |
| PS4 | 17 | 24 | 3 DL6 |
| PS3 | 18 | 23 | DL7 |
| $\overline{\text { PS2 }}$ | 19 | 22 | - INP/DSR |
| PS1 | 20 | 21 | SER CLK |

R6592 Pin Configuration


R6592 Interface Diagram

Specifications subject to change without notice

## INTERFACE SIGNALS

PRINTER SOLENOID 1 (PS1)
PRINTER SOLENOID 2 ( $\overline{\mathrm{PS} 2}$ )
PRINTER SOLENOID 3 (PS3)
PRINTER SOLENOID 4 ( $\overline{\text { PS4 }}$ )
PRINTER SOLENOID 5 ( $\overline{\text { PS5 }}$ )
PRINTER SOLENOID 6 ( $\overline{\mathrm{PS} 6}$ )
Active low output signals used to command seven constant current print head solenoid drivers. When tow, the respective solenoid will be energized to print a dot; and when high, the solenoid will be deenergized to not print a dot. Each solenoid line corresponds to a dot position on the seven row print head. Line PS1 corresponds to the 10 p dot and $\overline{\mathrm{PS7}}$ corresponds to the bottom dot. The output lines are activated by the positive edge of the timing signal (TIM). The TIM signal should also be used to gate PS1 through PS7 to the current drivers and to de-energize the current driver inputs within $600 \pm 20 \mu \mathrm{sec}$ of the start of the TIM signal by means of a one-shot flip-flop.

PRINTER CONTROL LINE 1 ( $\overline{\text { PCL1 }})$
PRINTER CONTROL LINE $2(\overline{\text { PCL2 }})$ PRINTER CONTROL LINE 3 ( $\overline{\text { PCL3 }}$ )

Active low output control lines used to issue various non-print commands to the printer. These lines are inputs to +24 V drivers. When low, these lines cause magnets to be energized in the printer; when high, the magnets are to be de-energized. These lines are assigned to specific signals depending upon printer model:

| Printer <br> Model | R6592 Signal Name |  |  |
| :---: | :---: | :---: | :---: |
|  | PCL1 | PCL. 2 | PCL3 |
| 210 | NA | Paper Feed | Change Color |
| 220 | Paper Feed (R) | Paper Feed (L) |  |
| 240 | NA | Paper Feed | Slip Release |
| 511 L | NA | Paper Feed | NA |
| 512 | NA | Paper Feed | NA |
| 522 | Paper Feed (R) | Paper Feed (L) | Stamp \& Cut Paper |
| 541 L | NA | Paper Feed | Paper Release |
| 542 | NA | Paper Feed | Paper Release |
| $N A=$ Not Assigned |  |  |  |

## TIMING (TIM) <br> RESET LEFT ( $\overline{R L} / R L$ ) <br> RESET RIGHT ( $\overline{\mathrm{RR}}$ )

Input signals used to indicate print cycle Timing. The R6592 initiates a print cycle on the leading edge (positive transition) of the TIM signal information to the R6592. The RESET signals are active low for the 500 series ( $\overline{R R}$ and $\overline{R L}$ ) and are active high for the 200 series (RL). The printer timing and reset lines are assigned as follows:

| Printer <br> Mode! | R6592 Signal |  |  |
| :---: | :---: | :---: | :---: |
|  | TIM | $\overline{R L} / \mathbf{R L}$ | $\overline{\mathrm{RR}}$ |
| 210 | T Detector | R Detector (RL) | NA |
| 220 | T Detector | R Detector (RL) | NA |
| 240 | T Detector | R Detector (RL) | NA |
| 511L | Timing Signal | Reset Signal R-L ( $\overline{\mathrm{RL}})$ | NA |
| 512 | Timing Signal | Reset Signal R-L ( $\overline{\mathrm{RL}})$ | Reset Signal R-R ( $\overline{\mathrm{RR}})$ |
| 522 | Timing Signal | Reset Signal R-L ( $\overline{\mathrm{RL}})$ | Reset Signal R.R ( $\overline{\mathrm{RR}})$ |
| 541L | Timing Signa! | Reset Signal R-L ( $\overline{\mathrm{RL}}$ ) | NA |
| 542 | Timing Signal | Reset Signal R-L ( $\overline{\mathrm{RL}})$ | Reset Signal R-R ( $\overline{\mathrm{RR}})$ |

See Detail Timing Diagrams in Printer Specifications.

## MOTOR DRIVE SIGNAL ( $\overline{M D S}$ )

Active low output signal used to control application of power from a driver circuit to the printer motor. When high, the motor drive is turned off and when low, the motor drive is turned on. The driver circuit for the 500 series must supply 10 to 30 ma at TTL. levels. The driver circuit for the $\mathbf{2 0 0}$ series must additionally provide motor braking.

PRINTER MODEL 1 (PM1)
PRINTER MODEL 2 (PM2)
PRINTER MODEL 3 (PM3)
Encoded input lines used to determine which printer model is connected to the R6592. A connection to GND (low) causes " 0 " to be read. An open input (high) causes logic " 1 " to be read. The encoding for the printer model is:

| Printer <br> Model | Printer Model Line |  |  |
| :--- | :---: | :---: | :---: |
|  | PM3 | PM2 | PM1 |
|  | 0 | 0 | 0 |
| 220 | 0 | 0 | 1 |
| 240 | 0 | 1 | 0 |
| 511 L | 0 | 1 | 1 |
| 512 | 1 | 0 | 0 |
| 522 | 1 | 0 | 1 |
| 541 L | 1 | 1 | 0 |
| 542 | 1 | 1 | 1 |

## PRINT ( $\overline{\text { PRT }}$ )

Active low input line used to command R6592 to print a line. When low (GND) print commands will continue to be issued. If the print buffer is partially filled, a line will be printed. Line feeds will subsequently be issued while $\overline{\mathrm{PRT}}$ is low. When high (open), print commands will not be issued.

## SERIAL SELECT (SER SEL)

Active high input line used to indicate the desired data transmission mode to the R6592. When high (open), input data will be received and processed from the serial interface (RS-232C). When tow (GND), input data will be received and processed from the parallel interface (Centronics).

If both transmission modes are to be implemented but not simultaneously), the SER SEL line should be used to select either serial or parallel signals through multiplexer circuits. If either serial or parallel data transmission is exclusively used, multiplexing of the indicated serial/parallel signals is not required.

DATA LINE 1/BAUD RATE 1 (DLI/BR1)
DATA LINE 2/BAUD RATE 2 (DL2/BR2)
DATA LINE 3/BAUD RATE 3 (DL.3/BR3)
DATA LINE 4/BAUD RATE 4 (DL4/BR4)
Active high input signals used as parallel data lines if parallel data transfer mode is selected, or used as baud rate select lines if serial data transfer mode is selected.

If paralle! data transfer mode is selected (SER SEL = low) these lines represent four of the seven total data lines (see below). DL1/BR1 represents the least significant bit when ASClI characters are decoded.

If serial data transfer mode is selected (SER SEL = high), the data transfer baud rate in bits per second is:

| Baud | Data Line/Baud Rate Line |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | DL4/BR4 | DL3/BR3 | DL2/BR2 | DL1/BR1 |
| 50 | 0 | 0 | 0 | 0 |
| 75 | 0 | 0 | 0 | 1 |
| 110 | 0 | 0 | 1 | 0 |
| 135 | 0 | 0 | 1 | 1 |
| 150 | 0 | 1 | 0 | 0 |
| 300 | 0 | 1 | 0 | 1 |
| 600 | 0 | 1 | 1 | 0 |
| 1200 | 0 | 1 | 1 | 1 |
| 1800 | 1 | 0 | 0 | 0 |
| 2400 | 1 | 0 | 0 | 1 |
| 3600 | 1 | 0 | 1 | 0 |
| 4800 | 1 | 0 | 1 | 1 |
| $7200 *$ | 1 | 1 | 0 | 0 |

Note: $1=$ High (open), $0=$ Low (GND).
*Data cannot be sent to the R6592 while the print head is moving.

DATA LINE 5 (DL3)
DATA LINE 6 (DL4)
DATA LINE 7 (DL7)
Active high input signals used as data lines when parallel data transfer mode is selected (SER SEL = low). DL7 represents the most significant bit (MSB) when ASCII characters are decoded. Not used when serial data transfer mode is selected (SER SEL = high).

## INPUT PRIME (产)/DATA SET READY (DSR)

Input line multiplexed between a parallel communications control line (INPUT PRIME) and a serial communications control line (DATA SET READY).

If the parallel data transfer mode is selected (SER SEL = low), this line is assigned to $\overline{\operatorname{INPUT}} \mathrm{PRIME}$ ( $\overline{\mathrm{PP}}$ ). When $\overline{\mathrm{P}} / \mathrm{DSR}$ is high, the R6592 issues prints commands to the printer in a normal fashion. When $\overline{\mathrm{P}} /$ DSR is low, the R6592 will disable printing. This line can, therefore, be used as a print disable line to selected printers in a multiprinter system.

If the serial data transfer mode is selected (SER SEL = high), the line is assigned to DATA SET READY (DSR). When high, DSR indicates that the transmitter is operative and the R6592 will accept data. When low, DSR indicates that the transmitter is not ready to operate and the R6592 will not accept serial data.

## $\overline{\text { DATA STROBE }}$ ( $\overline{\mathrm{DS}}$ )/ $\overline{\text { RECEIVED SERIAL DATA }}$ ( $\overline{R S D}$ )

Input line multiplexed between a parallel communications control line ( $\overline{\text { DATASTROBE }}$ ) and the serial communications data line ( $\overline{\text { RECEIVED }}$ SERIAL DATAI.

If the parallel data transfer mode is selected (SER SEL = low), this line is assigned to the $\overline{D A T A}$ STROBE $(\overline{D S})$. When $\overline{D S}$ goes low, the R6592 detects the negative transition, and samples the data on the parallel data lines. The data must be present on the data lines for at least $50 \mu \mathrm{sec}$ after $\overline{\mathrm{DS}}$ goes low.

If the serial data transfer mode is selected (SER SEL = high), the line is assigned to $\overline{R E C E I V E D}$ SERIAL DATA ( $\overline{R S D}$ ). The data is processed in accordance with the selected baud rate. The data must be converted from RS-232 logic levels to R6592 logic levels. The R6592 logic state is inverted from RS-232 logic state.

## BUSY/DATA TERMINAL READY (BUSY/DTR)

Output line multiplexed between a parallel communication control line (BUSY) and a serial communication control line (DATTA TERMINAL READY).

If the parallel data transfer mode is selected (SER SEL = low), this line is assigned to BUSY. When high, BUSY indicates that the R6592 cannot receive data. When low, BUSY indicates that the R6592 is ready to receive data. BUSY is switched high during character print and while non-print commands are being processed.

If the serial data transfer mode is selected (SER SEL = high), this line is assigned to $\overline{\text { DATA TERMINAL READY }}(\overline{\mathrm{DTR}})$. When high, $\overline{\mathrm{DTR}}$ indicates that the R6592 cannot receive data. When low, $\overline{\mathrm{DTR}}$ indicates that the R6592 is ready to receive data. $\overline{\mathrm{DTR}}$ is switched high during character print and while non-print commands are being processed.

## $\overline{\text { ACKNOWLEDGE }}(\overline{\text { ACK }})$

Active low output signal used to inform the parallel data transmitter that an input character has been received. $\overline{\mathrm{ACK}}$ is switched low for $5 \mu \mathrm{sec}$ to indicate receipt of a character.

## SERIAL CLOCK (SER CLK)

A bi-directional line used to detect the start of the received serial data and to then clock in the serial data bits. When DET ENA is low, this line monitors the input serial data stream for the start bit. When the leading (falling) edge of the start bit is detected, the DET ENA is switched high and this line is switched to an output. Output pulses are generated on this line to clock the received serial data into the R6592 at the selected baud rate.

## SERIAL DETECT ENABLE (DET ENA)

Active high output used to enable the received serial data onto the SER CLK line. Upon detection of the received serial start bit, this line is switched low to disable the received serial data from being placed on the SER CLK line.

## PRIMARY POWER (VCC)

R6592 primary power supply: $+5 \mathrm{~V} \pm 10 \%$. Supplies power to CPU, I/O, timer and supporting circuitry.

## RAM POWER (VRR)

R6592 RAM power supply: $+5 \mathrm{~V} \pm 10 \%$. Supplies power to the internal R6592 RAM. This line should be connected to VCC power supply.

## SIGNAL GROUND (VSS)

R6592 power and signal ground.

## XTLI

Input from 2 MHz crystal.

## XTLO

Output to 2 MHz crystal.

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

Active low signal used to reset and initialize the R6592. Must be held low for at least $8 \mu \mathrm{sec}$ after VCC reaches operating voltage and the clock frequency on XTLO has stabilized.

Standard 96 Character 5x7 Matrix Dot Patterns

|  | $\begin{aligned} & \text { 21 }{ }^{21}{ }^{\circ}{ }^{\circ}{ }^{\circ}{ }^{\circ}{ }^{\circ}{ }^{\circ} \mathrm{o} \\ & \text { 品品品 } \end{aligned}$ |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 28 | 29 | 2A | 2B | 2 C | 20 | 2E | 2 F |
| 煰品品 | 碞㗊品 | 品品品 | 㗊品品 | 品品品 | 㗊品品 | 㗊品品 | 吅㗊䀎 |
| 哭品品 | 器枵品 | 砣噳 | 品品品 | 煰㗊 | 品品品 | 煰㗊 | 㗊唂 |
| 器㗊品 | 品品品 | 㖂噩 | 啚啅 | 品讍 | 㗊品 | 㗊品 | 踄品 |
| 30 | － 31 |  | －0000 | －0000 |  | －0000 | － 37 |
| 郘昭品 | 吅里品 |  | －${ }^{\text {3 }}$ 鴚 | 品品 | － H $^{\text {ana }}$ | 36 |  |
| 喊嚧 | 郘㗊 | 枵㗊 | 㗊品品 | 號 | \％ | 䖍品 | 吅㗊哭 |
| 炽品 | 㗊㗊 | 踇品 | 煰品 |  | 㗊品 | 歇誯 | 㗊㗊 |
| 吅哭品 |  | 馉哭品 | 器品咢 | 吅㗊品 | 哭品部 | 詔品品 | 䠩㗊 |
| gisu | 39 | 3A | 3 B | 3 C | 3D | ${ }^{3 \mathrm{E}}$ | ${ }^{3 F}$ |
| 踄品 |  | 㗊品品 | 枵品品 | 器眙 | 品㗊品 | 㫛品 | 枵枵 |
| 枵㽞 |  | 㗊品 | 煰品品 | 嗗㗊品 | 昭品 | 㗊品 | 呂品㗊 |
|  | 枵踄 | 器㗊 | 噳㗊 |  | 路品 |  | 品㗊 |
| 40 | 41 | 42 | 43 | 44 | 45 | 46 | 47 |
|  | 呂鳥枵 | 昭駱 | 噳㫛 | 缹㗊㗊 |  | 咕硈 |  |
| 晆部 | －80 | 㫛品品 | 哭品 | 聐品 | －${ }^{\text {P }}$ | 品品 | \％${ }^{\text {a }}$ |
| 枵品品 |  | 㫛哭 | 路㗊 | 吅㗊 | 㫛品 | 晧品 | 吅㗊 |
|  | －808＊ | － |  | － | \％ | －8000 |  |
| ${ }_{48}^{48}$ | 49 | 4A | 48 | 4 C | 4D | 4 E | ${ }^{4 F}$ |
| 聐品 | 品砫品 | 枵骂品 | 鲾品品 | 部品品 | 易品 | H90品 | 品睘硈 |
| 明品 | 品枵 | 品噳 | 明哭品 | 噳品 | 獸咢 |  | 昭噳 |
| 㫛品 | 㗊哭品 | 㗊品品 |  |  | 器㗊 | 昭號 |  |
| 50 | 51 | 52 | 53 | 54 | 55 | 56 | 57 |
| 撂部品 |  | 㶕說 | 品最噳 | 哭 |  | 昭㗊 |  |
| － | －808品 | 㗐品 | 噳哭 | 吅路 | 㫛 |  | －${ }^{\text {品品 }}$ |
| 聐品 | 㙏品 |  | 吕品踣 | 枵噩 | 砤品 | 碞嵒 | －${ }^{\text {明品 }}$ |
| －0000 | － | －008． | － | 80080 | 무ํ | 品路 | Watat |
| － | 59 |  |  | 5 | 5 5 | 5 E | 5 F |
| 骂品品 | 㫛品 | 暒硣 | H08⿰⿱口⿰口口⿵⿰丿⿺⿻⿻一㇂㇒丶𠃌灬丶 | 年品品 | 吅枵部 |  | 㗊品品 |
| 品㗊 | 蹋品 | 啧趷 | 铝品 | 品呂品 | 吅㗊 | 枵㗊 | 㗊品 |
| 器路 | 㗊㗊 | 모몸ㅁㅁㅁㅁㅁ | ＂ | 㗊㗊品 | 煰品 | 枵踄 | 枵品品 |
| 60 | 61 |  | 63 |  | 65 | 66 | 67 |
| 㗊品品 | 㗊㗊 | 聐品 | 㗊品品 | 㗊品： | 品品品 | 骂哣 | 㗊㗊 |
| 吅品品 | 噳枵 | 蹋㪊 | 咀品 | 碞號 | 噳品 | 㚗哭器 | 噳噳 |
| 器㗊 | 啧䠞 | 啚㗊 | 㫛品 | 聐品 |  |  |  |
| 吅路 |  |  | 號品品 |  | 부ํ | 㙱㗊 | 品哭品 |
|  | 69 | 6A | 6B | 6 C | 6D | 6 E | 6 F |
| 㫛品 | 枵㗊品 |  | 㙏品品 | 器㗊 | 吅㗊品 | 㗊品品 | 㗊㗊品 |
| －${ }^{\text {最品品 }}$ | 碞哭 | 枵器 | 聐品 | 吅㗊 |  |  |  |
|  | 枵噳 | 噩品 |  | 枵趷 | 號 | 喦 | 踄㗊 |
|  |  |  |  |  |  | － | － |
|  | 71 | 72 | 73 | 74 | 75 | 76 | 77 |
| 品品品 | 㗊品品 | 㗊㗊 | 㗊㗊品 |  | 㗊㗊品 | 㗊㗊 | 㗊㗊品 |
| 㫛品 | 噳䀎 | 品枵品 | 噳品 | 枵㗊品 | 吅䠦 | 聐品怘 | 器號 |
| 噳品 | 碞骂 | 鲴品 | 䖍品 | 㬽品 | 品 | 品品㫛 | 踇號 |
| － | 器哭 | － | 哭品品 |  | 器碞 | 吅碞品 | 枵噳 |
| 78 | 79 | 7A | 7B | 7 C | 70 | 7 E |  |
| 㗊品 | 㗊㗊 | 品㗊品 | 㗊詔 | 吅里品 | 品哭品 | 品 |  |
| 号品品 | 铝品 |  | 枵㗊 | 品駞 | 品噳 | 噳䬰 |  |
| 品哭 | 嚧品 |  | 枵㗊 | 品㗊 | 品品品 |  |  |
| 吅品品 | 哭㗊品 | 䛧品 | 㗊哭品 | 吅踄 | 㗊噩 | 㗊品 |  |

Special 6 Character 5×7 Matrix Dot Patterns

| 5A | 58 | 5C | 50 | 5E | 5 F |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 昌昭品 | 98000 | －900080 |  |  | 무유ำ |
| 硡昭 | grogo | gopo | 8090 |  | Q0900 |
| 0090 | 口1900 | 口19 |  |  |  |
|  | 圽最品吅 | 品碞 | －0800 | － | 口1090 |
| 吅䭪 | 品昭吅 |  | －gego |  | 吅碛 |
| 吅影品 |  |  | 品輷号 | 品碞品 | 硡品员 |
| YEN | POUND | ONE－HALF | CENT | NO TAX | TAX |




ASCII 7-Bit Code Character Set Table

| LSD | MSD | $\begin{gathered} 0 \\ 000 \end{gathered}$ | $\begin{gathered} 1 \\ 001 \end{gathered}$ | $\begin{gathered} 2 \\ 010 \end{gathered}$ | $\begin{gathered} 3 \\ 011 \end{gathered}$ | $\begin{gathered} 4 \\ 100 \end{gathered}$ | $\begin{gathered} 5 \\ 101 \end{gathered}$ | $\begin{gathered} 6 \\ 110 \end{gathered}$ | $\begin{gathered} 7 \\ 111 \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0000 |  |  | SP | 0 | @ | P |  | p |
| 1 | 0001 |  | DC1 | ! | 1 | A | 0 | a | q |
| 2 | 0010 |  | DC2 | " | 2 | B | R | b | r |
| 3 | 0011 |  | DC3 | \# | 3 | C | S | c | $s$ |
| 4 | 0100 |  | DC4 | \$ | 4 | D | T | d | $t$ |
| 5 | 0101 |  |  | \% | 5 | E | U | e | u |
| 6 | 0110 |  |  | \& | 6 | F | V | $f$ | $v$ |
| 7 | 0111 |  |  | , | 7 | G | W | 9 | w |
| 8 | 1000 |  | CAN | 1 | 8 | H | X | h | $\times$ |
| 9 | 1001 |  |  | ) | 9 | 1 | $Y$ | i | V |
| A | 1010 | LF | $\geqslant$ | * | : | $J$ | $z$ | i | $z$ |
| B | 1011 | VT | t | + | ; | K | 1 | k | \{ |
| C | 1100 | FF | 12 | , | < | L | 1 | 1 | 1 |
| D | 1101 | CR | $\downarrow$ | - | = | M | ] | m | \} |
| E | 1110 |  | $\underset{T}{N}$ | - | > | $N$ | $\uparrow$ | $n$ | $\sim$ |
| F | 1111 |  | $\begin{gathered} \mathrm{T} \\ \mathrm{X} \end{gathered}$ | 1 | ? | 0 | $\leftarrow$ | - | DEL |


| LF | - | Line Feed |
| :---: | :---: | :---: |
| VT | - | Vertical Tabulation |
| FF | - | Form Feed |
| CR | - | Carriage Return |
| DC1 | - | Device Control 1 |
| DC2 | - | Device Control 2 |
| DC3 | - | Device Control 3 |
| DC4 | - | Device Control 4 |
| CAN | - | Cancel |
| Y | - | Yen |
| t | - | Pound |
| $\downarrow$ | - | Cent |
| ${ }_{1}$ | - | One-Half |
| $\begin{aligned} & \mathrm{N} \\ & \mathrm{~T} \end{aligned}$ | - | No Tax |
| $\begin{aligned} & \mathrm{T} \\ & \mathrm{X} \end{aligned}$ | - | Tax |

Note: Valid control commands are dependent upon printer model.

## Parallel Data Interface



PARALLEL INTERFACE
R6592 INTERFACE
*NOT REQUIRED IF PARALLEL DATA IS HELD FOR $\geqslant 50 \mu \mathrm{~S}$ AFTER LEADING EDGE OF $\overline{D S}$ OR UNTIL $\overline{A C K}$ IS RECEIVED.

Parallel Data Timing


Serial Data Interface


Serial Data Timing


SERIAL DETECT ENABLE (DET ENA)


SERIAL CLOCK (SER CLK)


RECEIVED SERIAL. DATA (RSD)


DATA TERMINAL READY (DTR)


The R6592 is designed to meet the interface requirements stated in the following printer specifications:

Model-210 Impact Dot Matrix Mini-Printer (Preliminary) Rev. 4, AUGUST 30, 1978

Model-220 Impact Dot Matrix Mini-Printer, SEPTEMBER 18, 1978
Model-240 Impact Dot Matrix Mini-Printer, SEPTEMBER 18, 1978

Model-511L Impact Dot Matrix Printer (Enlarged Character) Revision 1, JULY 13, 1978

Model 512 Dot-Matrix Impact Printer (P512DF), APRIL. 10, 1978 Model 522 Dot-Matrix Impact Printer (P522DF), MARCH 1, 1978

Model 541L Impact Dot Matrix Printer (Enlarged Character) Revision 1. JULY 19, 1978

Model 542 Dot-Matrix Impact Printer (P542DF), MARCH 1, 1978

For further printer information, contact

EPSON America, Inc 23844 Hawthorne Blvd. Ltd Torrance, CA 90505
Phone: (213) 378-2220
TWX: 910-344-7390
C. Itoh Electronics, Inc.

5301 Beethoven Street
Los Angeles, Calif. 90066
Phone: (213) 390.7778
Telex: WU 65-2451
C. Itoh Electronics, Inc. 280 Park Avenue

New York, New York, 10017
Phone: (212) 682-0420
Telex: WUD.12-5059


R6592 Plastic Packaging Diagram

## SPECIFICATIONS

Maximum Ratings

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $v_{\text {cc }}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $v_{\text {in }}$ | -0.3 to +7.0 | Voc |
| Operating Temperature Range |  |  | ${ }^{\circ} \mathrm{C}$ |
|  |  | 0 to +70 |  |
| Storage Temperature Range | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

This device contains 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 higher than maximum rated voltages to this circuit.

Static D.C. Characteristics $V_{C C}=5 \mathrm{~V} \pm 10 \%$

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipation (Outputs High) | $P_{\text {D }}$ | - | 500 | - | mW |
| Input High Voltage (Normal Operating Levels) | $V_{\text {IH }}$ | $+2.0$ | - | ${ }^{\text {cc }}$ | $V \mathrm{dc}$ |
| Input Low Voltage (Normal Operating Levels) | $V_{\text {IL }}$ | -0.3 | - | +0.8 | Vdc |
| Input Threshold Voltage | $V_{\text {IT }}$ | 0.8 | - | 2.0 | Vdc |
| Input Leakage Current | ${ }_{1} \mathrm{IN}$ |  |  |  | $\mu \mathrm{Adc}$ |
| $V_{\text {in }}=0 \text { to } 5.0 \mathrm{Vdc}$ |  | - | $\pm 1.0$ | $\pm 2.5$ |  |
| Input High Voltage (XTLI) | $V_{\text {IHXT }}$ | +4.0 | - | $v_{\text {cc }}$ | Vdc |
| Input Low Voltage (XTL) | $V_{\text {ILXT }}$ | -0.3 | - | +0.8 | Vdc |
| Input Low Current | ${ }_{1}$ IL |  |  |  |  |
| $\left(\mathrm{V}_{1 \mathrm{~L}}=0.4 \mathrm{Vdc}\right)$ |  | - | -1.0 | -1.6 | mAdc |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ |  |  |  |  |
| $\left(V_{C C}=\min , I_{\text {Load }}=-100 \mu \mathrm{Adc}\right)$ |  | 2.4 | - | - | Vdc |
| Output Low Voltage | $\mathrm{v}_{\mathrm{OL}}$ |  |  |  |  |
| $\left(V_{C C}=\min , I_{\text {Load }}=1.6 \mathrm{mAdc}\right.$ ) |  | - | - | +0.4 | Vdc |
| Output High Current (Sourcing) | ${ }^{1} \mathrm{OH}$ |  |  |  |  |
| $\left(\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{Vdc}\right)$ |  | -100 |  | - | $\mu \mathrm{Adc}$ |
| Output Low Current (Sinking) | ${ }^{\prime} \mathrm{OL}$ |  |  |  |  |
| $\left(\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{Vdc}\right)$ |  | 1.6 | - | - | mAdc |
| Input Capacitance | $c_{\text {in }}$ |  |  |  | pF |
| $\left(\mathrm{V}_{\text {in }}-0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$ |  |  |  |  |  |
| Pins 2-9, 13-29 and 31-38 |  | - | - | 10 |  |
| XTLI, XTLO |  | - | - | 50 |  |
| Output Capacitance | $\mathrm{C}_{\text {out }}$ |  |  |  |  |
| $\left(\mathrm{V}_{\text {in }} \cdot 0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{t}=1.0 \mathrm{MHz}\right)$ |  | - | - | 10 | pF |

NOTE: Negative sign indicates outward current flow, positive indicates inward flow.

## ROM-RAM-I/O-INTERVAL TIMER DEVICE (RRIOT)

## SYSTEM ABSTRACT

The 8-bit R6500 microcomputer system is produced with N. channel, Silicon-Gate technology. Its performance speeds are enhanced by advanced system architecture. Its innovative architecture results in smaller chips - the semiconductor threshold to cost-effectivity. System cost-effectivity is further enhanced by providing a family of 10 software-compatible microprocessor (CPU) devices. Rockwell also provides memory and I/O devices that further enhance the cost-effectivity of the R 6500 microcom puter system . . . as well as low-cost design aids and documentation.

## DESCRIPTION

The R6530 is designed to operate in conjunction with the R6500 Microprocessor Family. It is comprised of a mask programmable $1024 \times 8$ ROM, a $64 \times 8$ static RAM, two software controlled 8 bit bidirectional data ports allowing direct interfacing between the microprocessor unit and peripheral devices, and a software programmable interval timer with interrupt, capable of timing in various intervals from 1 to $\mathbf{2 6 2 , 1 4 4}$ clock periods.

FEATURES

- 8 bit bidirectional Data Bus for direct communication with the microprocessor
- $1024 \times 8$ ROM
- $64 \times 8$ static RAM
- Two 8 bit bidirectional data ports for interface to peripherals
- Two programmable Data Direction Registers
- Programmable Interval Timer
- Programmable Interval Timer Interrupt
- TTL \& CMOS compatible peripheral lines
- Peripheral pins with Direct Transistor Drive Capability
- High Impedance Three-State Data Bus
- Allows up to 7 K contiguous bytes of ROM with no external decoding

Ordering Information

| Order <br> Number | Package <br> Type | Temparature <br> Range |
| :---: | :---: | :---: |
| R6530P | Plastic | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| R6530C | Ceramic | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |

A custom number will be assigned by Rockwell.


$$
\begin{aligned}
& \text { DIRECTION } \\
& \text { REGISTER }
\end{aligned}
$$




## INTERFACE SIGNAL DESCRIPTION

## Reset (RES)

During system initialization a Logic " 0 " on the $\overline{\mathrm{RES}}$ input will cause a zeroing of all four I/O registers. This in turn will cause all $1 / 0$ 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{\mathrm{AES}}$ signal must be held low for at least one clock period when reset is required.

## Read/Write (R/W)

The R/W signal is supplied by the microprocessor and is used to control the transfer of data to and from the microprocessor and the R6530. A high on the R/W pin allows the processor to read (with proper addressing) the data supplied by the R6530. A low on the R/W pin allows a write (with proper addressing) to the R6530.

## Interrupt Request ( $\overline{\mathbf{R O}}$ )

The $\overline{\mathrm{RQ}} \mathrm{pin}$ is an interrupt pin from the interval timer. This same pin, if not used as an interrupt, can be used as a peripheral I/O pin (PB7). When used as an interrupt, the pin should be set up as an input by the Data Direction Register. The pin will be normally high with a low indicating an interrupt from the R6530. An external pull-up device is not required; however, if collector-OR'd with other devices, the internal pullup may be omitted with a mask option.

## Data Bus (D0-D7)

The R6530 has eight bidirectional data pins (D0-D7). These pins connect to the system's data lines and allow transfer of data to and from the microprocessor. The output buffers remain in the off state except when selected for a Read operation.

## Peripheral Data Ports

The R6530 has 16 pins available for peripheral 1/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, PA0-PA7 and PB0-PB7. PB5, PB6 and PB7 also have other uses which are discussed in later sections. The pins are set up as an input by writing a " 0 ' into the corresponding bit of the Data Direction Register. A " 1 " into the Data Direction Register will cause its corresponding bit to be an output. When in the input mode, the Peripheral Data 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 unit reads the peripheral pin. When the peripheral device gets information from the R6530 it receives data stored in the Output Register. The microprocessor will read correct informition if the peripheral lines are greater than 2.0 volts (for a " 1 ") or less than 0.8 volts (for a " 0 ") as the peripheral pins are all TTL compatible.

## Address Lines (AO-A9)

There are 10 address pins (AO.A9). In addition, there is the ROM Select pin (RSO). Further, pins PB5 and PB6 are mask programmable, and can be used either individually or together as chip selects. When used as peripheral data pins they cannot be used as chip selects.

## INTERNAL ORGANIZATION

The R6530 is divided into four basic sections: RAM, ROM, I/O and Timer. The RAM and ROM interface directly with the microprocessor through the system data bus and address lines. The $1 / O$ section consists of two 8 bit halves. Each half contains a Data Direction Register (DDR) and an Output Register.

## ROM 1 K Byte ( 8 K Bits)

The 8 K ROM is in a $1024 \times 8$ configuration. Address lines AO-A9, as well as RSO are needed to address the entire ROM. With the addition of CS1 and CS2, seven R6530's may be addressed, giving $7168 \times 8$ bits of contiguous ROM.

## RAM - 64 Bytes ( 512 Bits)

A $64 \times 8$ static RAM is contained on the R6530. It is addressed by A0.A5 (Byte Select), RS0, A6, A7, A8, A9 and, depending on the number of chips in the system, CS1 and CS2.

## Internal Peripheral Registers

There are four internal registers, two data direction registers and two output registers. The two data direction registers ( $A$ side and $B$ sidel control the direction of the data into and out of the peripherat pins. A " 1 " written into the Data Direction Register sets up the corresponding peripheral buffer pin as an output. Therefore, anything then written into the Output Register will appear on that corresponding peripheral pin. A " 0 " written into the DDR inhibits the output buffer from transmitting data from the Output Register. For example, a " 1 " loaded into Data Direction Register A, position 3, sets up peripheral pin PA3 as an output. If a " 0 " had been loaded. PA3 would be configured as an input and remain in the high state. The two Data Output Registers are used to latch data from the Data Bus during a Write operation until the peripheral device can read the data supplied by the microprocessor.

During a Read operation the microprocessor is reading the peripheral data pins. For the peripheral data pins which are programmed as outputs the microprocessor will read the corresponding data bits of the Output Register. The only way the Output Register data can be changed is by a microprocessor Write operation. The Output Register is not affected by a Read of the data on the peripheral pins.

## Interval Timer

The Timer section of the R6530 contains three basic parts: prescale divide down register, programmable 8 -bit register and interrupt logic.

The interval timer can be programmed to count up to 256 time intervals. Each time interval can be either $1 \mathrm{~T}, 8 \mathrm{~T}, 64 \mathrm{~T}$ or 1024 T increments, where $T$ is the system clock period. When a full count is reached, an interrupt flag is set to a logic " 1 ". After the interrupt flag is set the internal clock begins counting down to a maximum of -255T. 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 255 T .

The 8 bit system Data Bus is used to transfer data to and from the Interval Timer. If a count of 52 time intervals were to be counted the pattern 00110100 would be put on the Data Bus and written into the Interval Timer Register.

At the same time that data is being written to the Interval Timer, the counting interval ( $1,8,64$ or 1024 T ) is decoded from address lines $A 0$ and $A 1$. During a Read or Write operation address line A3 controls the interrupt capability of PB7, i.e., $A_{3}=1$ enables IRQ on PB7, $A_{3}=0$ disables IRQ on PB7. When PB7 is to be used as an interrupt flag with the interval timer it should be pro grammed as an input. If PB7 is enabled by A3 and an interrupt occurs PB7 will go low. When the timer 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 down to 00000000 on the next count time an interrupt will occur and the counter will read $\begin{array}{lllllll}1 & 1 & 1 & 1 & 1\end{array}$. After interrupt, the Timer Register decrements at a divide by " 1 " rate of the system clock. If after interrupt, the timer is read and a value of 11100100 is read, the time since interrupt is 27 T . The value read is in one's complement.

```
Value read = 111100100
Complement = 0 0 0 1 1 0 1 1=27
```

Thus, to arrive at the total elapsed time, merely do a one's complement and 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 $417 \mathrm{~T}+27 \mathrm{~T}=444 \mathrm{~T}$, assuming the value read after interrupt was 11100100.

After the interrupt, whenever the timer is written or read the interrupt is reset. However, the reading of the timer at the same time the interrupt occurs will not reset the interrupt flag. When the interrupt flag is read on DB7 all other DB outputs (DB0 thru DB6) go to " 0 ".

When reading the timer after an interrupt, A3 should be low so as to disable the $\overline{\mathrm{RQ}} \mathrm{pin}$. This is done so as to avoid future interrupts until after another Write timer operation.


Basic Elements of Interval Timer


WRITE T $\qquad$
$\overline{\text { IRO }}$

1. Data written into interval timer is $00110100=5210$
2. Data in Interval timer is $00011001=25_{10}$
$52 \cdot \frac{213}{8}-1=52-26-1=25$
3. Data in Interval timer is $00000000=0_{10}$
$52 \cdot \frac{415}{8}-1=52-51-1=0$
4. Interrupt has occurred at 02 pulse \#416

Data in Interval timer = 111111111
5. Data in Interval timer is 10101100 two's complement is $010 \begin{array}{llllll}1 & 0 & 0 & 1 & 1=83 \\ 10\end{array}$ $83+(52 \times 8)+1=500_{10}$

## ADDRESSING

Addressing of the R6530 offers many variations to the user for greater flexibility. The user may configure his system with RAM in lower memory, ROM in higher memory, and I/O registers with interval timers between the extremes. There are 10 address lines (A0-A9). In addition, there is the possibility of 3 additional address lines to be used as chip-selects and to distinguish between ROM, RAM, I/O and interval timer. Two of the additional lines are chip-selects 1 and 2 (CS1 and CS2). The chip-select pins can also be PB5 and PB6. Whether the pins are used as chip-selects or peripheral I/O pins is a mask option and must be specified when ordering the part. Both pins act independently of each other in that either or both pins may be designated as a chipselect. The third additional address line is RSO. The R6502 and R6530 in a 2-chip system would use RSO to distinguish between ROM and non-ROM sections of the R6530. With the addressing pins available, a total of 7 K contiguous ROM may be addressed with no external decode. Below is an example of a 1 -chip and a 7 -chip R6530 Addressing Scheme.

## One-Chip Addressing

A 1-chip system decode for the R6530 is illustrated on the top of the following page:

## Seven-Chip Addressing

In the 7 -chip system the objective would be to have 7 K of contiguous ROM, with RAM in low order memory. The 7 K of ROM could be placed between addresses 65,535 and 1024. For this case, assume A13, A14 and A15 are all 1 when addressing ROM, and 0 when addressing RAM or $1 / 0$. This would place the 7 K ROM between addresses 65,535 and 58,367 . The 2 pins designated as chip-select or 1/O would be masked programmed as chip-select pins. Pin RSO would be connected to address line A10. Pins CS1 and CS2 would be connected to address lines A11 and A12 respectively. See illustration below.
The two examples shown would allow addressing of the ROM and RAM; however, once the I/O or timer has been addressed, further decoding is necessary to select which of the 1/O registers are desired, as well as the coding of the interval timer.

## I/O Register - Timer Addressing

Addressing Decode for 1/O Register and Timer illustrates the address decoding for the internal elements and timer programming. Address lines $A 2$ distinguishes $1 / O$ registers from the timer. When $A 2$ is high and I/O timer select is high, the I/O registers are addressed. Once the $1 / O$ registers are addressed, address lines A1 and $A O$ decode the desired register.

When the timer is selected $A 1$ and $A 0$ decode the divide by matrix. In addition, Address A3 is used to enable the interrupt flag to PB7.

R6530 Seven Chip Addressing Scheme
The addressing of the ROM select, RAM select and I/O Timer select lines would be as follows:

|  |  | $\begin{aligned} & \mathrm{CS} 2 \\ & \mathrm{~A} 12 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { CS1 } \\ & \text { A11 } \end{aligned}$ | $\begin{aligned} & \text { RSO } \\ & \text { A } 10 \end{aligned}$ | A9 | A8 | A7 | A6 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R6530 \#1. | ROM SELECT | 0 | 0 | 1 | $\times$ | $x$ | $x$ | x |
|  | RAM SELECT | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | I/O TIMER | 0 | 0 | 0 | 1 | 0 | 0 | 0 |
| R6530 \#2, | ROM SELECT | 0 | 1 | 0 | $\times$ | $x$ | $x$ | X |
|  | RAM SELECT | 0 | 0 | 0 | 0 | 0 | 0 | 1 |
|  | I/O TIMER | 0 | 0 | 0 | 1 | 0 | 0 | 1 |
| R6530 \#3, | ROM SELECT | 0 | 1 | 1 | x | X | X | x |
|  | RAM SELECT | 0 | 0 | 0 | 0 | 0 | 1 | 0 |
|  | I/O TIMER | 0 | 0 | 0 | 1 | 0 | 1 | 0 |
| $R 6530$ \#4, | ROM SELECT | 1 | 0 | 0 | $\times$ | $x$ | X | X |
|  | RAM SELECT | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
|  | I/O TIMER | 0 | 0 | 0 | 1 | 0 | 1 | 1 |
| $R 6530$ \#5, | ROM SELECT | 1 | 0 | 1 | $\times$ | X | x | X |
|  | RAM SELECT | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
|  | I/O TIMER | 0 | 0 | 0 | 1 | 1 | 0 | 0 |
| R6530 \#6, | ROM SELECT | 1 | 1 | 0 | $\times$ | x | $x$ | x |
|  | RAM SELECT | 0 | 0 | 0 | 0 | 1 | 0 | 1 |
|  | I/O TIMER | 0 | 0 | 0 | 1 | 1 | 0 | 1 |
| R6530 \#7. | ROM SELECT | 1 | 1 | 1 | $\times$ | x | $x$ | X |
|  | RAM SELECT | 0 | 0 | 0 | 0 | 1 | 1 | 0 |
|  | I/O TIMER | 0 | 0 | 0 | 1 | 1 | 1 | 0 |



Addressing Decode for I/O Register and Timer

## Addressing Decode

|  | ROM Select | RAM Select | 1/O Timer Select | R/W | A3 | A2 | A1 | A0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read ROM | 1 | 0 | 0 | 1 | $x$ | $x$ | $x$ | $x$ |
| Write RAM | 0 | 1 | 0 | 0 | $x$ | $x$ | X | x |
| Read RAM | 0 | 1 | 0 | 1 | $x$ | $x$ | $x$ | $\times$ |
| Write DDRA | 0 | 0 | 1 | 0 | $x$ | 0 | 0 | 1 |
| Read DDRA | 0 | 0 | 1 | 1 | $x$ | 0 | 0 | 1 |
| Write DDRB | 0 | 0 | 1 | 0 | $x$ | 0 | 1 | 1 |
| Read DDRB | 0 | 0 | 1 | 1 | $x$ | 0 | 1 | 1 |
| Write Per. Reg. A | 0 | 0 | 1 | 0 | $x$ | 0 | 0 | 0 |
| Read Per. Reg. A | 0 | 0 | 1 | 1 | $x$ | 0 | 0 | 0 |
| Write Per. Reg. B | 0 | 0 | 1 | 0 | $x$ | 0 | 1 | 0 |
| Read Per. Reg. B | 0 | 0 | 1 | 1 | $x$ | 0 | 1 | 0 |
| Write Timer |  |  |  |  |  |  |  |  |
| $\div 1 T$ | 0 | 0 | 1 | 0 | * | 1 | 0 | 0 |
| $\div 8 \mathrm{~T}$ | 0 | 0 | 1 | 0 | * | 1 | 0 | 1 |
| $\div 64 T$ | 0 | 0 | 1 | 0 | * | 1 | 1 | 0 |
| $\div 1024 \mathrm{~T}$ | 0 | 0 | 1 | 0 | * | 1 | 1 | 1 |
| Read Timer | 0 | 0 | 1 | 1 | * | 1 | $x$ | 0 |
| Read Interrupt Flag | 0 | 0 | 1 | 1 | X | 1 | X | 1 |

$\begin{aligned} * A_{3} & =1 \text { Enables IRQ to PB7 } \\ A_{3} & =0 \text { Disables IRQ to PB7 }\end{aligned}$

Write Timing Characteristics

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Clock Period | ${ }^{T_{C Y C}}$ | 1 |  | 10 | $\mu \mathrm{S}$ |
| Rise \& Fall Times | $T_{R}{ }^{\prime} T_{F}$ |  |  | 25 | ns |
| Clock Pulse Width | ${ }^{T} \mathrm{C}$ | 470 |  |  | ns |
| R/W valid before positive transition of clock | $T_{W C W}$ | 180 |  |  | ns |
| Address valid before positive transition of clock | ${ }^{\top} A C W$ | 180 |  |  | ns |
| Data Bus valid before negative transition of clock | ${ }^{\text {T }}$ DCW | 300 |  |  | ns |
| Data Bus Hold Time | $T_{\text {HW }}$ | 10 |  |  | ns |
| Peripheral data valid after negative transition of clock | ${ }^{\text {T }}$ CPW |  |  | 1 | $\mu \mathrm{S}$ |
| Peripheral data valid after negative transition of clock driving CMOS (Level = VCC - 30\%) | ${ }^{\text {T CMOS }}$ |  |  | 2 | $\mu \mathrm{S}$ |

Read Timing Characteristics

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| R/W valid before positive transition of clock | TWCR | 180 |  | 395 | ns |
| Address valid before positive transition of clock | ${ }^{T}$ ACR | 180 |  |  | ns |
| Peripheral data valid before positive transition of clock | $\mathrm{T}_{\text {PCR }}$ | 300 |  |  | ns |
| Data Bus valid after positive transition of clock | ${ }^{T}$ |  |  |  | ns |
| Data Bus Hold Time | $T_{\text {HR }}$ | 10 |  |  | ns |
| IRQ (Interval Timer Interrupt) valid before positive transition of clock | $\mathrm{T}_{1 \mathrm{C}}$ | 200 |  |  | ns |

Loading $=30 \mathrm{pF}+1$ TTL load for PAO-PA7, PBO-PB7
$=130 \mathrm{pF}+1 \mathrm{TTL}$ load for D0-D7


Write Timing Characteristics


Read Timing Characteristics

## PROGRAMMING INSTRUCTIONS

The Rockwell R6530 utilizes computer aided techniques to manufacture and test custom bit patterns. The custom bit pattern and address information is supplied on mini-floppy diskettes prepared on the SYSTEM 65, or paper tape, or standard 80 -column computer cards in the format described below.

Alt addresses and related output patterns must be completely defined. Mask options should be noted on the ROM order form and in the title cards.

## Title Cards

A set of six Title Cards should accompany each data deck. These cards give our computer programs additional information necessary to accurately produce high density ROMS. These six Title Cards must contain the following information:

|  | Column | Information |
| :---: | :---: | :---: |
| First Card | 1.30 | Customer Name |
|  | 31-50 | Customer Part Number |
|  | 60.72 | Rockwell Order Number |
|  |  | (Example: R6530XX) |
| Second Card |  | Customer Contact Name, |
|  |  | Customer Contact Phone Number |
| Third Card (2) |  | $\operatorname{Pin} 17=\overline{\mathrm{RQ}} / \mathrm{PB} 7$ with Pull-up or $\overline{\mathrm{IRQ}} /$ PB7 without Pull-up. |
|  |  | Pin $18=$ CS 1 or PB6, |
|  |  | Pin $19=$ CS2 or PB5 |
|  |  | (Example: Pin $17=$ IRQ NO PULL-UP, PIN $18=$ CS1, PIN $19=$ PB5 |
| Fourth Card (2) | (1) | $\begin{aligned} & \text { ROM SEL, RSO }=X, C S 1=X, C S 2=X \\ & (E x a m p l e: ~ R O M ~ S E L, C S 1=H, R S 0=H, \\ & C S 2=N) \end{aligned}$ |
| Fifth Card (2) | (1) | $\begin{aligned} & \text { RAM SEL, RSO }=X, C S 1=X, C S 2=X, \\ & A 9=X, A 8=X, A 7=X, H 6=X \end{aligned}$ |
|  |  | $\begin{aligned} & \text { (Example: } R A M \text { SEL, CS1 }=L, C S 2=N \text {, } \\ & \text { RSO }=L, A 9=L, A 8=N, A 7=H, \\ & A 6=H) \end{aligned}$ |

NOTE:
$\overrightarrow{\mathrm{IRO}}$ is keypunched as IRQ

| Sixth Card | (1) $1 / O S E L, R S O=X, C S 1=X, C S 2=X$, |
| :--- | :--- |
| (2) | $A 9=X, A 8=X, A 7=X, A 6=X$ |
|  | (Example: $1 / O S E L, C S 1=L, R S O=L$, |
|  | $C S 2=N, A 9=H, A 8=H, A 7=H$, |
|  | $A 6=H)$ |

(1) $\mathrm{X}=\mathrm{H}$ or L or N
$H=+2.4$ Volts $L=+0.4$ Volts $N=$ No Effect
(2) Free Format - Delimiters are commas or blanks

## Data Card Format

The required data card format is generated by the Cross Assembler. All addresses are coded in hexadecimal form 10 through FFFF). All output words are coded both in binary and octal forms. Output 8 (DB7) is the MSB, and Output 1 (DB0) is the LSB.

The format for all cards in a file, except the last card, is as follows:

$$
; 3 S_{2} S_{1} S_{0} \measuredangle N_{1} N_{0} \measuredangle A_{3} A_{2} A_{1} A_{0} \underbrace{D_{1} D_{0} D_{1} D_{0}}_{1} \underbrace{}_{2} X_{3} X_{2} X_{1} X_{0}
$$

The format for the last card in a file is as follows:
;40000
EXAMPLE:
;301101 $100000696465647564796400604 C 04704 C 0479054 F$ ; $301: 021000104 C 0461647164296425643564396400200463$ ; $3000310003724642 C 4 C C 400000200000000000000000104$ ; 40 OLO

## Paper Tape Format

Rockwell can accept ROM coding in paper tape prepared using SYSTEM 65, Cross Assembler or AIM 65 output. Mask options shou'd be noted on the ROM order form. The format for paper tape is as follows:
$: N_{1} J_{0} A_{3} A_{2} A_{1} A_{0} \underbrace{D_{1} D_{0} D_{1} D_{0}}_{1} x_{2} x_{2} x_{1} x_{0} C R L F$

The format for the last record in a file is as follows:
$; 00 C_{3} C_{2} C_{1} C_{0} X_{3} x_{2} X_{1} x_{0}$
NOTE 1

1. $00=$ zero bytes of data in this record. This identifies this as the final record in a file.
2. $\mathrm{C}_{3} \mathrm{C}_{2} \mathrm{C}_{1} \mathrm{C}_{0}=$ the total number of records (in hexadecimal) in this file, including the last record.
3. The valid record is identified by the starting delimitor (;) and terminated by the check sum $\left(X_{3} X_{2} X_{1} X_{0}\right)$. All other characters such as the CR and LF are not processed. The next semi-colon initiates the next record.

## EXAMPLE:

;18FIOOCA86004CDOF OFDF9212D21FF2920BF2161FSF7FFb5?D6? 2000411 ;18FU18E564672DFD7575E5DOOOCF4112F8009251980200539192F20C98 ;18F030080802890810DE12D894189AC2830E9800FBB6232F087F650AA5 ;0000030003

Unless otherwise stated, the field definitions are defined as follows:

1. All Characters ( $N, A, D, X$ ) are the ASCIl characters 0 through $F$, each representing a hexadecimal (hex) digit.
2. ; is a record mark indicating the start of a record.
3. $N_{1} N_{0}=$ the number of bytes of data in this record (in hex). Each pair of hex characters ( $D_{1} D_{0}$ ) represents a singie byte in the record.
4. $A_{3} A_{2} A_{1} A_{0}=$ the hex starting address for the record. $A_{3}$ rep resents address bits 15 through 12, etc. The 8 -bit byte represented by $\left(D_{1} D_{0}\right)_{1}$ stored in address $A_{3} A_{2} A_{1} A_{0} ;\left(D_{1} D_{0}\right)_{2}$ stored in $\left(A_{3} A_{2} A_{1} A_{0}\right)+1$, etc.
5. $\left(D_{1} D_{0}\right)=$ two hex digits representing an 8 -bit byte of data. ( $\mathrm{D}_{1}=$ high-order 4 binary bits and $\mathrm{D}_{0}=$ low-order 4 bits). A maximum of 18 (hex) or 24 (decimal) bytes of data per record is permitted.
6. $X_{3} x_{2} x_{1} x_{0}=$ record check sum. This is the hex sum of all characters in the record, excluding the record mark and the check sum characters. To generate the check sum, each byte of data (represented by two ASCII characters), is treated as 8 binary bits. The binary sum of these 8 -bit bytes is truncated to 16 binary bits ( 4 hex digits) and is then represented in the record as four ASCII characters $\left(\mathrm{X}_{3} \mathrm{X}_{2} \mathrm{X}_{1} \mathrm{X}_{0}\right)$.
7. $S_{2} S_{1} S_{0}=$ the hex sequence number for the card record.
8. $C R=A S C I I$ character for Carriage return.
9. $L F=A S C$ II character for line feed.
10. $\not b=$ Space character

## Mini-Floppy Diskette Format

Rockwell can accept ROM coding on mini-floppy diskettes prepared using the SYSTEM 65 Assembler output. The format is similar to the Paper Tape format shown in the preceding paragraph. Title card information should be recorded using the file name "TITLE." Data information should be recorded using the file name "DATA." Mask options should be noted on the ROM Order form.


Packaging Diagram


Pin Configuration

## SPECIFICATIONS

## Maximum Ratings

| Rating | Symbol | Voltage | Unit |
| :---: | :---: | :---: | :---: |
| Supplv Voltage | vcc | -0.3 to +7.0 | $v$ |
| Input/Output Voltage | $V_{\text {IN }}$ | - 0.3 to +7.0 | $v$ |
| Operating Temperature Range | ${ }^{T}$ OP | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | ${ }^{\text {T STG }}$ | - 55 to +150 | ${ }^{\circ} \mathrm{C}$ |

All inputs contain protection circuitry to prevent damage due to high static charges. Care should be exercised to prevent unnecessary application of voltage outside the specification range.

## Electrical Characteristics

(VCC $=5.0 \%, \mathrm{VSS}=0 \mathrm{~V}, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}$ )

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $V_{1 H}$ | $v_{S S}+2.4$ |  | VCC | V |
| Input Low Voltage | $V_{\text {IL }}$ | $\mathrm{V}_{\text {SS }}-0.3$ |  | $V_{\text {SS }}+0.4$ | V |
| Input Leakage Current; $V_{I N}=V_{S S}+5 V$ A0.A9, RS, R/W, $\overline{\text { RES }}, 02$, PB6* $P$ P $5 *$ | $\mathrm{I}_{1 \mathrm{~N}}$ |  | 1.0 | 2.5 | $\mu \mathrm{A}$ |
| Input Leakage Current for High Impedance State (Three State): $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ to 2.4 V ; D0-D7 | ${ }^{\prime}$ TSI |  | $\pm 1.0$ | $\pm 10.0$ | $\mu \mathrm{A}$ |
| Input High Current: $V{ }^{N}=2.4 \mathrm{~V}$ PAO-PA7, PBO-PB7 | ${ }^{1} 1 \mathrm{H}$ | -100. | -300. |  | $\mu \mathrm{A}$ |
| Input Low Current; $V_{I N}=0.4 \mathrm{~V}$ PAO-PA7, PBO-PB7 | ${ }^{\text {IIL }}$ |  | $\cdot 1.0$ | -1.6 | MA |
| Output High Voltage $\begin{gathered} V C C=M I N, I_{\text {LOAD }} \leqslant-100 \mu A(P A O-P A 7, \text { PBO-PB7, DO-D7) } \\ I_{\text {LOAD }} \leqslant-3 \mathrm{MA}(P A O-P B 0) \end{gathered}$ | ${ }^{\text {V OH }}$ | $\begin{aligned} & V S S+2.4 \\ & \text { VSS }+1.5 \end{aligned}$ |  |  | V |
| Output Low Voltage $V C C=\text { MIN, } I_{\text {LOAD }} \leqslant 1.6 \mathrm{MA}$ | $\mathrm{V}_{\mathrm{OL}}$ |  |  | $V S S+0.4$ | V |
| Output High Current (Sourcing): <br> $V O H \geqslant 2.4 V$ (PAO-PA7, PBO-PB7, DO-D7) <br> $\geqslant 1.5 \mathrm{~V}$ Available for other than TTL <br> (Darlingtons) (PBO, PB7) | ${ }^{1} \mathrm{OH}$ | $\begin{aligned} & -100 \\ & -3.0 \end{aligned}$ | $\begin{aligned} & -1000 \\ & -5.0 \end{aligned}$ |  | $\underset{M A}{\mu A}$ |
| Output Low Current (Sinking): VOL $\leqslant 0.4 \mathrm{~V}$ (PAO-PA7) <br> (PBO-PB7) | ${ }^{1} \mathrm{OL}$ | 1.6 |  |  | MA |
| Clock Input Capacitance | $\mathrm{C}_{\text {clk }}$ |  |  | 30 | pF |
| Input Capacitance | $C_{\text {IN }}$ |  |  | 10 | pF |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ |  |  | 10 | pF |
| Power Dissipation | $P_{\text {D }}$ |  | 500 | 1000 | MW |

*When programmed as address pins All values are D.C. readings

## R6500 Microcomputer System DATA SHEET

## ROM-RAM-I/O-COUNTER (RRIOC)

## SYSTEM ABSTRACT

The ROM-RAM-I/O Counter (RRIOC), Part Number Fi6531, further enhances the costeffectivity of the R6500 NMOS 8 -bit microcomputer system by providing a powerful, flexible twochip minimum system option. Produced with N-channel depletion load, silicon gate technology, the R6500 system employs advanced architecture, including 13 instruction addressing modes to achieve third generation pertormance speeds and smaller chips, the key to lower hardware and design costs. Included in the R6500 system are 10 software-compatible microprocessor (CPU) options, a growing number of memory and I/O devices, a very efficient, low-cost SYSTEM 65 development aid and complete documentation.

## DESCRIPTION

The R6531 is primarily designed to provide innovative Equipment Designers with a wide span of two-chip minimum systems in combination with the R6500 family of 10 CPUs. It can also be combined in a variety of multi-chip system configurations with other R6531's, ROMs, RAMs and other I/O devices.
There are two R6531 versions: a 40 -pin dual-in-line package; another with expanded I/O in a compact 52 -pin quad-in-line package - see Table 1. Both versions contain a $2048 \times 8$ maskprogrammable ROM, a $128 \times 8$ static RAM, a software programmable multi-mode counter, an 8 -bit serial data channel, and 15 bidirectional data lines (two ports) with a handshake control mode and four interrupt inputs. The 52 -pin version has an 8 -bit output port and a 4 -bit input port for a total of 27 I/O lines. Several mask options are available tp provide a RAM standby power pin and chip selects for multi-chip systems - see Figure 1. Prototyping circuits are available in both the 40 - and 52 -pin packages, and in 1. and $2-\mathrm{MHz}$ versions. They are offered as part numbers R6531-098 and R6531-098A for the 40-pin part, and as part numbers R6531-099 and R6531-099A for the 52-pin part.

## FEATURES

- $2048 \times 8$ mask programmable ROM
- $128 \times 8$ static RAM
- 16-bit multi-mode counter/latch
- interval timer (one shot or free running)
- pulse generator (one shot or free running)
- event counter
- external trigger
- 8-bit serial channel
- TTL compatible I/O, drive one TTL load
- $\mathbf{1 5}$ bidirectional I/O lines ( 2 ports - $\mathbf{4 0}$ pin package)
- Expansion 8-bit output port and 4-bit input port (52 pin package)
- I/O handshake control
- Four edge sensitive interrupt inputs
- 2 MHz or 1 MHz operation
- Single +5 V power supply

Table 1 Ordering Information


NOTE: Contact your local Rockwelt representative for availability.


R6531 Block Diagram



52-Pin Configuration R65310, VRR Option


Figure 1. R6531 Pin Configuration Options

## INTERFACE SIGNALS

## RESET ( $\overline{R E S}$ )

This active low signal is used to initialize the R6531. It clears all internal registers (except the counter and serial registers) to logic zero. This action places all bidirectional I/O lines in the input state and the Port C outputs in the high state. The timer, shift register, and interrupts are disabled. The $\overline{\operatorname{RES}}$ signal must be low for at least four clock periods when reset is required.

## ADDRESS BUS (A0.A11) AND CHIP SELECTS (CS1-CS3)

Memory and register selection is accomplished using the 12 address lines and, in multiple device systems, also using one or more of the three Chip Select mask options. When PB4, PB5, or PD2 are chosen as chip selects, they cannot be used as peripheral I/O pins.

## DATA BUS (D0-D7)

The R6531 has eight data bus lines, which allow data to be transferred to or from the microprocessor. The output buffers remain in the offstate except when the R6531 is selected for a read operation.

## READ/WRITE (R/W)

The R/W signal is supplied by the microprocessor and is used to control the transfer of data to and from the microprocessor and the R6531. A high on the R/W pin allows the processor to read (with proper addressing) the data supplied by the R6531. A low on the $R / \bar{W}$ pin allows a write (with proper addressing) to the R6531.

## PERIPHERAL DATA PORTS (PA0-PA7, PB0-PB6, PC0-PC7, PD0-PD3)

Both versions of the R6531 have 15 pins available for peripheral I/O operations. Each pin is software programmable to act as an input or an output. The pins are grouped into an 8-bit port, PAO-PA7, and a 7-bit port, PBO-PB6. The lines of the PB port may serve other functions. Ports PA and PB have associated data direction registers.

The expanded I/O of the 52 -pin version provides an 8 -bit output only port, PCO-PC7, and a 4 -bit input only port, PDO-PD3. PD2 and PD3 may be assigned other functions as described herein.

The outputs are push/pull type drivers capable of driving a single TTL load. When inputs are selected the drivers float. If PB6 is programmed as the $\overline{1 R Q}$ request output, the line is driven low and requires an external pull-up, thus allowing the wire OR-ing of $\overline{I R O}$ from other devices.

## RAM RETENTION VOLTAGE (VRR)

A separate pin for a power supply for the read/write memory is avaitable as a mask option. This allows the retention of RAM data by using a battery back-up for the RAM only. Pin PB6 in the 40 -pin version or PD3 in the 52-pin version is mask programmable as the VRR pin. Address line A10 must be held in the logic state which deselects RAM (user-defined) in order to protect the RAM data when VCC falls betow the specified level or is turned off.

## INTERNAL ORGANIZATION

The R6531 is divided into three basic functions: ROM, RAM, and I/O. The selection of any one of these three is accomplished by issuing the appropriate address information on the address bus when the chip is selected.

## ADDRESSING

Addressing of the R6531 offers many variations to the user for system configuration flexibility. Combination with other R6531's, ROMs, RAMs or $1 / O$ devices is possible without need for external address decoding. Each of the three basic functions on the device has its own decode mask for unique selection.

The specific address ranges and chip selects are defined by the user and are dependent on the number of chips in the system. The programmed options to be fixed by masking are:


The $X, Y$, and $Z$ bits may be selected as high, low or no effect.

The chip select pins are also discrete I/O pins PB5, PB4, and PD2. The pins are independent of each other in that any one may be used as a chip select. The user specifies as mask options which pins are to be used as I/O and which as chip selects.

## ROM - 2K BYTES (16K BITS)

The 16 K ROM is a $2048 \times 8$ bit configuration. An address on lines A0.A10 uniquelv selects one byte of ROM. Additionally, address line A11 and the chip selects are required to select the ROM function on a given chip. In a system with multiple R6531's, the CS1, CS2, and CS3 mask options allow up to seven devices with 14 K bytes of ROM without the need for external decoding.

## RAM - 128 BYTES (1024 BITS)

The $128 \times 8$ static RAM of a given R6531 is addressed by lines AO-A6. Additionallv, address lines A7-A11 and chip selects CS1, CS2, and CS3 provide selection of the RAM section of the device as well as the device itself when additional RAM devices or R6531's are in the system

## R6531 40 PIN PROTOTYPING CIRCUIT

Prototyping circuits R6531.098 (1 MHz) and R6531-098A ( 2 MH ) are packaged in a 40-pin dual in-line package that has the same pinouts as the 40-pin R6531 with PB6 option. In this prototyping circuit the ROM is disabled and there is no VRR option.

Access codes for this prototyping circuit are shown in the table below.

| R6531-098 Function | Chip <br> Selects |  | Address Inputs (A0-A11) |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | CS2 | CS1 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| RAM | N | $N$ | L | L | L | N | L |  | 28 | R | M | De | ode |  |
| 1/0 | N | N | L | H | H | H | L | L | L | L |  | D | co |  |

In the above table, $N$ means No Effect, H means High $(2.0$ volts or greaterl and $L$ means Low ( 0.8 volt or less).

## R6531 52-PIN PROTOTYPING CIRCUIT

Prototyping circuits R6531-099 (1 MHz) and R6531-099A ( 2 MHz ) are packaged in the 52-pin quad in-line package, with VRR option PD2 is used as a chip select (CS3), and PB4 and PB5 are available as I/O lines.

Access codes for the prototyping circuit are shown in the table below.

| R6531-099 Function | Chip <br> Selects |  |  | Address Inputs (A0.A11) |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | CS3 | CS2 | CS1 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| ROM | H | N | N | H | 2 K ROM Decode |  |  |  |  |  |  |  |  |  |  |
| RAM | L | N | N | L | $L$ | L | N | L | 128 RAM Decode |  |  |  |  |  |  |
| 1/0 | L | N | N | L | H | H | H | L | L | L | L |  | D | ec |  |

The 128 words of RAM have been mapped into the first half of both Page 0 and Page 1, to accomodate zero page addressing and stack operations. The full 1/O capabilities described for the R653t are available in the prototyping circuit, except that I/O lines PD2 and PD3 are dedicated to the VRR and CS3 mask options.

## INPUT/OUTPUT

The input/output section is comprised of the data ports, direction registers, counter and associated latches, control registers, and interrupt registers. These I/O functions are all accessible by the R6502 CPU's instruction set using address bits AO-A3 for the specific function of the device. Address bits A4-A11 and CS1, CS2, and CS3 additionally may be decoded to select a given R6531 device in a multichip system. The addresses of the 15 internal peripheral registers are:


## Peripheral Control Register (PCR)

## INTERRUPT ENABLE AND FLAG REGISTERS

Two registers are provided for interrupt control. Corresponding b in the enable and flag registers are logically ANDed to set the Interru Request Pending flag. If the pending flag is set and PB6 is selected an IRO Request Output, then PB6 will be set low to request the R651 CPU to service IRQ.

The interrupt enable bits are set or reset by writing into the Interrul Enable Register. The interrupt flag bits IFRO-IFR6 can be cleart directly by writing a byte to the flag register which has 1 's in tho bit positions to be cleared.

IFR4 and IFR5 may also be cleared by reading or writing the Port or Serial Data Registers respectively. IFR6 may also be cleared $t$ reading the lower counter with I/O address hex 4 or writing the upp latch with I/O addresses hex 5 or 7 .

These registers and their bit assignments are:


## PERIPHERAL DATA PORTS

Each line of the 8-bit data Port A may be individually selected as an input or output. Associated with the port is Data Direction Register Port A (ODRA). Each line of the 7 -bit date Port $B$ may be individually selected as an input or an output. This port also has a Data Direction Register (DDRB). The two data direction registers (A and B) control the direction of the data into and out of the peripheral pins. A " 1 " written into the Data Direction Register sets up the corresponding peripheral pin as an output. Therefore, anything written into the data register will appear on that corresponding peripheral pin. A " 0 " written into the ODR inhibits the output buffer from transmitting data from the data register. For example, a " 1 " loaded into DDRA, position 3, sets up peripheral pin PA3 as an output. If a " 0 " had been loaded, PA3 would be configured as an input and would be in a float state.

Note that when lines in the PB port are used alternately as control lines for other on-chip functions, Direction Register B must also be loaded to set up the proper direction - the Control Registers have no effect on data direction.

The 8 -bit data Port $C$ is an output only port. The 4 -bit data Port $D$ is an input only port.

For those lines being used as outputs, the data registers are used to latch data from the Data Bus during a Write operation so the peripheral device can read the data supplied by the microprocessor.

For the lines being used as inputs, the microprocessor is reading the peripheral data pins. For the peripheral data pins which are programmed as outputs the microprocessor will read the corresponding data bits of the Output data.

## EDGE DETECT LOGIC

Operating in paraltel with the I/O operation of PBO-PB3 is edge detect logic that is enabled by Peripheral Control Register bits 1 and 2. PCR1 enables logic that upon detection of a negative edge on PBO or PB1 will set a corresponding flag in the Interrupt Flag Register. PCR2 enables logic that upon detection of a positive edge on PB2 or PB3 will set corresponding flags in the Interrupt Flag Register. If corresponding bits are set in the Interrupt Enable Register, then the Interrupt Request Pending flag will be set.

## MULTI-MODE COUNTER/LATCH

The R6531 contains a 16 -bit counter with an associated 16 -bit latch whose modes are software selectable by setting appropriate bits in the Auxiliafy Control Register. The latch holds the counter preset value and all 16 bits download to the counter simultaneously upon command (1/O address hex 5) of the software or automatically in free run modes upon overflow of the counter. The counter is a decrementing counter and causes the setting of a flag in the Interrupt Flag Register when it overflows. This interrupt flag, bit 6, is logically ANDed with a corresponding counter overflow interrupt enabled bit to set the Interrupt Request Pending flag. The Auxiliary Control Register is used to set four basic modes which specify the source of the count information, and to select two mode modifiers that apply equally to the three active modes.

Mode 0 - Counter Off
Mode 1 - Event Counter - counts external event inputs Inegative transitions) at PB5

Mode 2 - Interval Timer - counts $\emptyset 2$ system clock pulses.
Mode 3 - External Trigger - counts D2 system clock pulses starting with a negative transition on PB5.

Mode Modifier A - Pulse Generation Control - causes the output level on PB4 to switch low each time the counter is loaded using I/O address hex. 5. At counter overflow, PB4 switches high. If in the free run mode, PB4 continues to toggle at each subsequent counter overflow; otherwise there are no further transitions until the counter is reactivated by the software.

Mode Modifier B - Free Run Control - causes the full 16 -bit latch to be downloaded to the counter, continues to count, and sets the counter overflow flag bit every time the counter overflows. Otherwise the counter is a one shot mode in which the counter overflow flag is set one time only until the counter is reactivated by the software.

## SERIAL DATA CHANNEL

The R6531 has an 8 -bit serial channel. PB2 and PB3 are software selectable as the serial clock (SCLK) and serial data (SDIO) lines respectively.

The software sets Auxiliary Control Register bits 4 and 5 to enable the serial channel and to specify the source of the shift clock. Selection of the internal clock will shift data at one half the system 02 clock rate. If the external clock is used, data may be shifted at any sate up to one half the system 02 clock rate. In the external clock mode, the counter may be operated in the free run pulse generator mode using the CNTO line externally connected to the SCLK line to provide the desired shift rate.

Auxiliary Control Register bit 6 sets the serial data direction. Data are shifted in or out, most significant bit first, under control of the shift clock.

In the external clock mode, the completion of eight shifts of the serial register will set bit 5 of the interrupt flag register. If the corresponding bit of the Interrupt Enable Register is also set an Interrupt Request Pending flag will be set.

## HANDSHAKE OPERATIONS

PB0 and PB1 may be used as handshake control lines for date transmissions over Port PA; see PCR definition. PBO is a control input, PB1 is a control output. PB1 switches low on a read or write to Port PA , and switches high in response to a negative transition on PBO .

IFR4 in the Flag Register is set by a negative transition on PBO, and cleared by a Read or Write to Port PA; see Handshake Timing Diagram for timing details.



R6531 Serial Timing




Write Timing Characteristics

| Characteristic | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Clock Period | ${ }^{T} \mathrm{CYC}$ | 1 | 10 | 0.5 | 10 | $\mu s$ |
| Rise \& Fall Times | $T_{R}{ }^{\prime} T_{F}$ |  | 25 |  | 15 | ns |
| Clock Pulse Width | ${ }^{T} \mathrm{C}$ | 470 |  | 235 |  | ns |
| $\mathrm{R} / \overline{\mathrm{W}}$ valid before positive transition of clock | $T_{\text {WCW }}$ | 180 |  | 120 |  | ns |
| Address valid before positive transition of clock | ${ }^{\text {T }}$ ACW | 180 |  | 120 |  | ns |
| Data Bus valid before negative transition of clock | ${ }^{\text {T }}$ DCW | 270 |  | 135 |  | ns |
| Data Bus Hold Time | $\mathrm{T}_{\text {HW }}$ | 10 |  | 10 |  | ns |
| Peripheral data valid after negative transition of clock | ${ }^{T}$ CPW |  | 900 |  | 450 | ns |

Read Timing Characteristics

| Characteristic | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| $\mathrm{R} / \bar{W}$ valid before positive transition of clock | $T_{\text {WCR }}$ | 180 |  | 120 |  | ns |
| Address valid before positive transition of clock | $T_{A C R}$ | 180 |  | 120 |  | ns |
| Peripheral data valid before positive transition of clock | $T_{P C R}$ | 270 |  | 135 |  | ns |
| Data Bus valid after positive transition of clock | $\mathrm{T}_{\text {CDR }}$ |  | 350 |  | 180 | ns |
| Data Bus Hold Time | $T_{H R}$ | 10 |  | 10 |  | ns |
| IRQ valid after negative transition of clock | $\mathrm{T}_{\text {IC }}$ |  | 900 |  | 450 | ns |

Loading $=100 \mathrm{pF}+1 \mathrm{TTL}$ load for PAO-PA7, PB0-PB6, PCO-PC7
$=100 \mathrm{pF}+1$ TTL load for D0-D7 (R6531A)
$=130 \mathrm{pF}+1 \mathrm{TTL}$ load for DO-D7 (R6531)


Write Timing Characteristics


Read Timing Characteristics

## SPECIFICATIONS

## Maximum Ratings

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage <br> Input Voltage <br> Operating Temperature Range <br> Commercial <br> Industrial <br> Storage Temperature Range | $V_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Vdc |  |  |  |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |

This device contains 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 higher than maximum rated voltages to this circuit.

## Electrical Characteristics

(VCC $=5 \mathrm{~V} \pm 10 \%$ for R6531, $\mathrm{VCC}=5 \mathrm{~V} \pm 5 \%$ for R6531A)

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\text {IH }}$ | 2.0 | VCC | V |
| Input Low Voltage | $\bar{v}_{\text {IL }}$ | -0.3 | +0.8 | V |
| Input Leakage Current; $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\mathrm{SS}}+5 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=+5 \mathrm{~V}$ AO-A11, CS1.CS3 R/W, $\overline{\text { RES }}, \phi 2$, PDO-PD3 | ${ }^{1} \mathrm{IN}$ |  | 2.5 | $\mu \mathrm{A}$ |
| Leakage Current for High Impedance State, $\mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V}$ (Three State); $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ to 2.4 V ; D0-D7. PAO-PA7, PB0-PB6 | ${ }^{\prime}$ TSI |  | $\pm 10.0$ | $\mu \mathrm{A}$ |
| Output High Voltage $V C C=M I N, I_{\text {LOAD }} \leqslant-200 \mu \mathrm{~A}(\mathrm{PAO}-\mathrm{PA} 7, \mathrm{~PB}-\mathrm{PB} 6, \mathrm{D} 0-\mathrm{D} 7)$ | $\mathrm{V}_{\mathrm{OH}}$ | VSS + 2.4 |  | V |
| Output Low Voltage $\mathrm{VCC}=\mathrm{MIN}, \mathrm{I}_{\mathrm{LOAD}} \leqslant 2.1 \mathrm{~mA}$ | $\mathrm{V}_{\mathrm{OL}}$ |  | VSS + 0.4 . | V |
| Output High Current (Sourcing); $\mathrm{VOH} \geqslant 2.4 \mathrm{~V}(\mathrm{PAO}-\mathrm{PA} 7, \mathrm{PBO}-\mathrm{PB} 6, \mathrm{PCO}-\mathrm{PC} 7, \text { PDO-PD3, DO-D7) }$ | ${ }^{\prime} \mathrm{OH}$ | -200 |  | $\mu \mathrm{A}$ |
| $\begin{array}{r} \text { Output Low Current (Sinking): } \mathrm{V}_{\mathrm{OL}} \leqslant 0.4 \mathrm{~V} \text { (PAO-PA7) } \\ \text { (PBO-PB6) } \\ \text { (PC0-PC7) } \end{array}$ | ${ }^{1} \mathrm{OL}$ | 2.1 |  | mA |
| Clock Input Capacitance, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | ${ }^{\text {c }}$ Clk |  | 20 | pF |
| Input Capacitance, $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V}$ | $\mathrm{C}_{\text {IN }}$ |  | 10 | pF |
| Output Capacitance, $\mathrm{V}_{C C}=5 \mathrm{~V}$, chip deselected | $\mathrm{C}_{\text {OUT }}$ |  | 10 | pF |
| Power Dissipation | ${ }^{P_{D}}$ |  | 1.0 | W |

*When programmed as address pins
All values are D.C. readings

| RAM, I/O, INTERVAL <br> SYSTEM ABSTRACT <br> The 8 -bit R6500 microcomputer system is produced with N Channel, Silicon-Gate technology. its performance speeds are enhanced by advanced system architecture which enables multiple addressing. Its innovative architecture results in smaller chips the semiconductor threshold to cost-effectivity. System costeffectivity is further enhanced by providing a family of 10 softwarecompatible microprocessor (CPU) devices. Rockwell also provides memory and I/O devices that further enhance the costeffectivity of the R6500 microcomputer system-. . as well as low-cost design aids and documentation. |  |  |
| :---: | :---: | :---: |
|  |  |  |
|  |  |  |

## DESCRIPTION

The R6532 is designed to operate in conjunction with 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

- 8 bit bidirectional Data Bus for direct communication with the microprocessor
- $128 \times 8$ static RAM
- Two 8 bit bidirectional data ports for interface to peripherals
- Two programmable Data Direction Registers
- Programmable Interval Timer Interrupt
- TTL \& CMOS compatible peripheral lines
- Peripheral pins with Direct Transistor Drive Capability
- High Impedance Three-State Data Bus
- Programmable edge-sensitive interrupt

Ordering Information

| Order <br> Number | Package <br> Type | Temperature <br> Range |
| :--- | :--- | :--- |
|  | Plastic | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| R6532C | Ceramic | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |



R6532 Block Diagram

## INTERFACE SIGNAL DESCRIPTION

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

During system initialization a logic " 0 " on the $\overline{\operatorname{RES}}$ input will cause a zeroing of all four $1 / O$ registers. This in turn will cause all 1/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{\mathrm{RES}}$ signal. The $\overline{\mathrm{RES}}$ signal must be held low for at least two clock periods when reset is required.

## Read/Write (R/W)

The R/W signal is supplied by the microprocessor and is used to control the transfer of data to and from the microprocessor and 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 ( $\overline{\mathrm{RO}}$ )

The $\overline{\mathrm{IRQ}}$ 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 3 K pull-up resistor is required. The $\overline{\mathrm{IRO}}$ pin may be activated by a transition on PA7 or timeout of the interval timer.

## Data Bus (DO.D7)

The R6532 has eight bidirectional data pins (D0-D7). These pins connect to the system's data lines and allow transfer of data to and from the microprocessor array. The output buffers remain in the off state except when the R6532 is selected for a Read operation.

## Peripheral Data Ports (PAO-PA7, PB0-PB7)

The R6532 has 16 pins available for peripheral $1 / 0$ operations. Each pin is individually software programmable to act as either an input or an output. The 16 pins are divided into 28 -bit ports, PAO-PA7 and PBO-PB7. PA7 also has other uses which are discussed in later sections. The pins are set up as an input by writing a " 0 " into the corresponding bit of the data direction register. A " 1 " into the data direction register will cause 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 unit reads the peripheral pin. When the peripheral device gets information from the R6532 it receives data stored in the output register. The microprocessor will read correct 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 PBO-PB7 are also capable of sourcing 3 ma at 1.5 V , thus making them capable of Darlington drive.

## Address Lines (AO-A6)

There are 7 address pins. In addition to these 7 , there is the $\overline{\text { RAM }}$ $\overline{\text { SELECT }}(\overline{\mathrm{RS}}$ ) pin. The pins AO.A6 and RAM SELECT are always used as addressing pins. There are two additional pins which are used as CHIP SELECTS. They are pins CS1 and $\overline{\mathrm{CS} 2}$.

## 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 an Output Register.

## RAM - 128 Bytes (1024 Bits)

The $128 \times 8$ Read/Write memory acts as a conventional static RAM. Data can be written into the RAM from the microprocessor by selecting the chip ( $C S 1=1, \overline{\mathrm{CS} 2}=0)$ and by setting $\overline{\mathrm{RS}}$ to a logic $0(0,4 \mathrm{~V})$. Address lines $A 0$ through $A 6$ are the used to select the desired byte of storage.

## Internal Peripheral Registers

The Peripheral A $1 / 0$ port 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 Data Direction Register (DDRA) causes the corresponding line of the PA port to act as an indut. A logic one causes the corresponding PA line to act as an output. The voltage on any line programmed to be an output is determined by the corresponding bit in the Output Register (ORA).
Data is read directly from the PA pins during any read operation. For any output pin, the data transferred into the processor will be the same as that contained in the Output 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 Output 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 peripheral pin to act as an output.
In addition to acting as a peripheral 1/O line, the PA7 line can be used as an edge-detecting input. In this mode, an active transition will set the internal interrupt fleg (bit 6 of the Interrupt Flag register). Setting the interrupt flag will cause $\overline{\operatorname{RO}}$ 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.
Setting of the PA7 interrupt flag will occur on an active transition even if the pin is being used as a normal input or as a peripheral control output. The flag will also be set by an active transition if interrupting from PA7 is disabled. The reset signal ( $\overline{\mathrm{RES}}$ ) will disable the PA7 interrupt and will set the active transition to negative (high to low). During the system initialization routine, it is possible to set the interrupt flag by a negative transition. It may also be set by changing the polarity of the active interrupt. It is therefore recommended that the interrupt flag be cleared before enabling interrupting from PA7.
Clearing of the PA7 interrupt Flag occurs when the micorprocessor reads the Interrupt Flag Register.
The operation of the Peripheral B Input/Output port is exactly the same as the normal $1 / O$ operation of the Peripheral $A$ port. 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 Data Direction register (DDRB). In the output mode, the voltage on a peripheral pin is controlled by the Output Register (ORB).

The primary difference between the PA and the PB ports is in the operation of the output buffers which drive these pins. The PB 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 PB" operation, sufficient logic is provided in the chip to allow the microprocessor to read the Output Register instead of reading the peripheral pin as on the PA port.

When the timer has counted thru 00000000 on the next count time an interrupt will occur and the counter will read 11111111 . After interrupt, the timer register decrements at a divide by " 1 " rate of the system clock. If after interrupt, the timer is read and a value of 11100100 is read, the time since interrupt is 27 T . The value read is in two's complement, but remember that interrupt occurred on count number one. Therefore, we must subtract 1 .

| Value read | 11100010 |
| :---: | :---: |
| Complement | $=000111011$ |
| ADD 1 | $=00011100=28$ Equals two's complement of register |
| SUB 1 | $=00011011=27$ |

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 $001101100(=52)$. With a divide by 8 , total time to interrupt is $(52 \times 8)+1=417 \mathrm{~T}$. Total elapsed time would be $416 T+27 T=443 T$, assuming the value read after interrupt was 111100100.
After the interrupt, whenever the timer is written or read the interrupt is reset. 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 ( $D 7$ for the timer, D6 for the edge detect) data bus lines DO-D5 go to 0 .
When reading the timer after an interrupt, A3 should be low so as to disable the $\overline{\overline{1 R O}}$ pin. This is done so as to avoid future interrupts until after another Write timer operation.


Basic Elements of Interval Timer


Write Timing Characteristics

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Clock Period | ${ }^{T} \mathrm{CYC}$ | 1 |  | 10 | $\mu \mathrm{S}$ |
| Rise \& Fall Times | $T_{R}{ }^{\prime} T_{F}$ |  |  | 25 | ns |
| Clock Pulse Width | ${ }^{T_{C}}$ | 470 |  |  | ns |
| R/W valid before positive transition of clock | $T_{\text {WCW }}$ | 180 |  |  | ns |
| Address valid before positive transition of clock | ${ }^{\top} A C W$ | 180 |  |  | ns |
| Data Bus valid before negative transition of clock | $T_{\text {DCW }}$ | 300 |  |  | ns |
| Data Bus Hold Time | $T_{H W}$ | 10 |  |  | ns |
| Peripheral data valid after negative transition of clock | ${ }^{\top} \mathrm{CPW}$ |  |  | 1 | $\mu \mathrm{S}$ |
| Peripheral data valid after negative transition of clock driving CMOS (Level = VCC - 30\%) | ${ }^{T}$ cmos |  |  | 2 | $\mu \mathrm{S}$ |

Read Timing Characteristics

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{R} / \mathrm{W}$ valid before positive transition of clock | $T_{\text {WCR }}$ | 180 |  | 395 | ns |
| Address valid before positive transition of clock | $T_{A C R}$ | 180 |  |  | ns |
| Peripheral data valid before positive transition of clock | $T_{P C R}$ | 300 |  |  | ns |
| Data Bus valid after positive transition of clock | ${ }^{\top} \mathrm{CDR}$ |  |  |  | ns |
| Data Bus Hold Time | $T_{H R}$ | 10 |  |  | ns |
| IRQ (Interval Timer Interrupt) valid before positive transition of clock | $T_{1 C}$ | 200 |  |  | ns |

Loading $=30 \mathrm{pF}+1$ TTL load for PAO-PA7, PBO-PB7 $=130 \mathrm{pF}+1 \mathrm{TTL}$ load for DO-D7


Write Timing Characteristics


Read Timing Characteristics

RAM Addressing
$\overline{\mathrm{RS}}=0$
AO-A6 select RAM address

I/O Addressing
$\overline{R S}=1 \quad A 2=0$
$R / W=1$ to read, 0 to write

|  | A1 | AO |
| :--- | :--- | :--- |
| PA data | 0 | 0 |
| PA data direction | 0 | 1 |
| PB data | 1 | 0 |
| PB data direction | 1 | 1 |

Write Edge Detect Control
$\overline{R S}, A 2=1 R / W, A 4=0$
A1 $=1$, enable interrupt from PA7
$A 1=0$, disable interrupt from PA7
$A 0=1$, positive edge detect (PA7)
$A 0=0$, negative edge detect (PA7)

Read and Clear Interrupt Flag
$\overline{\mathrm{RS}}, \mathrm{R} / \mathrm{W}, \mathrm{A} 2, \mathrm{~A} 0=1$
Bit $7=$ Timer Flag
Bit $6=$ PA7 Flag
Read Interval Timer
$\overline{R S}, A 4, A 2, R / W, A O=1$
Read Interval Timer Overflow
$\overline{R S}, A 4, A 2, R / W=1, A O=0$

Write Count to Interval Timer
$\overline{\mathrm{RS}}, \mathrm{A} 4, \mathrm{~A} 2=1, R / W=0$
A1 $\quad \mathrm{AO}$

| $\div 1$ | 0 | 0 |
| :--- | :--- | :--- |
| $\div 8$ | 0 | 1 |
| $\div 64$ | 1 | 0 |
| $\div 1024$ | 1 | 1 |


| A 3 | $=1$, enable timer interrupt |
| ---: | :--- |
| A3 | $=0$, disable timer interrupt |
| NOTE: | For all operations $\mathrm{CS} 1=1, \overline{\mathrm{CS} 2}=0$. |




## SPECIFICATIONS

## Maximum Ratings

| Rating | Symbol | Voltage | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | VCC | -0.3 to +7.0 | V |
| Input/Output Voltage | $V_{\text {IN }}$ | -0.3 to +7.0 | V |
| Operating Temperature Range | Top | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | ${ }^{\text {TSTG }}$ | . 55 to +150 | ${ }^{\circ} \mathrm{C}$ |

All inputs contain protection circuitry to prevent damage due to high static charges. Care should be exercised to prevent unnecessary application of voltage outside the specification range.

## Electrical Characteristics

(VCC $=5.0 \%, \mathrm{VSS}=0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ )

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $V_{\text {IH }}$ | $\mathrm{V}_{\text {SS }}+2.4$ |  | VCC | $V$ |
| Input Low Voltage | $V_{\text {IL }}$ | $v_{\text {SS }}-0.3$ |  | $v_{\text {SS }}+0.4$ | $\checkmark$ |
| Input Leakage Current; $V_{I N}=V_{S S}+5 \mathrm{~V}$ AD A6, RS, R/W, $\overline{R E S}, \phi 2, C S 1, \overline{C S} 2$ | 1 N |  | 1.0 | 2.5 | $\mu \mathrm{A}$ |
| Input Leakage Current for High Impedance State (Three State); $V_{I N}=0.4 \mathrm{~V}$ to $2.4 \mathrm{~V} ; 00.07$ | ${ }^{\text {ITSI }}$ |  | $\pm 1.0$ | $\pm 10.0$ | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { Input High Current: } \mathrm{V}_{\text {IN }}=2.4 \mathrm{~V} \\ & \text { PAO-PA7, PBO.PB7 } \end{aligned}$ | ${ }_{1} \mathrm{H}$ | -100. | -300. |  | $\mu \mathrm{A}$ |
| Input Low Current; $V_{I N}=0.4 \mathrm{~V}$ PAO-PA7. PBO-PB7 | IIL |  | -1.0 | -1.6 | MA |
| $\begin{aligned} & \text { Output High Voltage } \\ & \text { VCC= MIN, I LOAD } \leqslant-100 \mu A(P A O-P A 7, \text { PBO-PB7, DO-D } 7) \\ & \qquad \text { LLOAD }^{\leqslant-3 M A(P B O-P B 7)} \end{aligned}$ | $v_{\mathrm{OH}}$ | $\begin{aligned} & V S S+2.4 \\ & V S S+1.5 \end{aligned}$ |  |  | V |
| Output Low Voltage $V C C=M I N, I_{\text {LOAD }} \leqslant 1.6 \text { MA }(D 0-D 7)$ | $v_{\text {OL }}$ |  |  | VSS + 0.4 | V |
| Output High Current (Sourcing); <br> $\mathrm{VOH} \geqslant 2.4 \mathrm{~V}$ (PAO-PA7, PBO-PB7, DO-D7) <br> $\geqslant 1.5 \mathrm{~V}$ Available for other than TTL (Darlingtons) (PBO-PB7) | ${ }^{\prime} \mathrm{OH}$ | $\begin{aligned} & -100 \\ & -3.0 \end{aligned}$ | $\begin{aligned} & -1000 \\ & -5.0 \end{aligned}$ |  | ${ }_{M A}^{\mu A}$ |
| Output Low Current (Sinking); VOL $\leqslant 0.4 \mathrm{~V}$ (PAO-PA7) | ${ }^{\prime} \mathrm{OL}$ | 1.6 |  |  | MA |
| Clock Input Capacitance | $\mathrm{c}_{\text {cık }}$ |  |  | 30 | pF |
| Input Capacitance | $c_{\text {in }}$ |  |  | 10 | pF |
| Output Capacitance | $\mathrm{c}_{\text {OUT }}$ |  |  | 10 | pF |
| Power Dissipation | $P_{\text {D }}$ |  | 500 | 1000 | mW |

All values are D.C. readings

AIM 65
MICRO-
COMPUTER

## Rockwell AMM 65n-giftea

## System Applications Connector

44 -pin comnector lets you connect peripherals interfaced with AiM 65 's versatile 110 capabilities - for example one or two cassette tape recorders, a Teletypewnter (20ma current loop) switches and sensors using serial and parallef THL-level interfaces, timing and control functions via built-in 16 -bit timericounter systemfunctions, and more.


Large, 20-Character Alphanumeric Display
High contrast. 16 -segment characters for optimum readability 64. character ASCll format.

54-Key Alphanumeric Terminal-Style Keyboard functions.

Among personal computers, AlM 65 stars as the professionals microcomputer lt's gifted with professional features for those seriousiy inierested in applying or leaming microprocessors.

And its priced so low that most everybody can afford it.
Third-generation processor architecture, versatile, broad interfacing capabitites, expandable memory; minicomputer like instructions, mult-mode addressing, interactive self-prompting soltware; on-board ptinter and dis-
play. AlM 65 is the prolessionals microcomputer for systen development and products, the amateur's headstart for pro fessional leatning.

Harnessed for work, AlM 65 as a "bare-board" micro computer out-performs in its price category - and in mucl higher priced categories - as an intelligent, programmablt stand-alone or terminal controller or processor. By itself it: an economically feasible system for small-volume product or one-of-a-kind work projects.

## 



## Third-Generation, High Performance 1-MHz 6502 Microprocessor

The 6502 is quickly becoming the world's most popular CPU: has minicomputer-like features. More details on Page 6

## Full-Bus System Expansion Connector

44-pin connector extends address, data, control bus: tets you add on prototyping boards, PROM programmer, addtional memory boards, Hoppy disk. Rockwell bubble memory modules. Rockwell modular modem analog interface boards and other subsystem modules.

As the beginner's choice for professional learning. AlM 35 's gifted features are exploited through inspired software,

AIM 65 's available software includes easily-leamed asily-used BASIC. But AlM 65 also makes easy the masterng of microcomputer fundamentals. Its software gives you elf-prompting program entry and listing, single-step deugging and other development leatures normally found nly on equipment costing thousands of dollars; AIM 65 osts but hundreds

No comparable microcomputer has an on-board printer Yet hard copies of exercises are mandatory for learning and teaching program development.

Study AlM 65 's gifted professional features and inspired software Note that its generally priced lower than most personal computers and its price is only a fraction of those of data terminals, Youll quickly see why AIM 65 is the choice of practicing professionals, and of beginners seriously intent on becoming professionals.

# Rockwell AMM 65._imspired 

AIM 65's gifted features are realized by its owners through truly inspired software which is made available as "firmware" contained on ROMs. Software packages include:

## Advanced Interactive Monitor

The heart of AIM 65's software, this program provides you with a comprehensive set of single-keystroke commands -- see "Monitor Commands" at right.

All commands are self-prompting: each displays an appropriate message when more information is required, or if you happen to make a mistake, an error code is displayed.


Self prompting program development.
Included in the Interactive Monitor is a Mnemonic Assembler program that translates instructions in simple three-letter abbreviations (called "mnemonics") that we humans easily understand, into binary codes that the microprocessor understands. The Mnemonic Assembler frees you from hassling with the confusing array of hexadecimal "opcodes" that most low-priced microcomputers use.


Mnemonic input for an addtion program.
With only the Interactive Monitor installed, you can assemble simple microcomputer programs based on mnemonic entries. This is the best way to start learning how a microcomputer "thinks."

AIM 65's Interactive Monitor contains single-stroke commands enabling you to interface with a powerful but simple-to-use Text Editor, or with higher level programming languages - Symbolic Assembler, BASIC interpreter, PL/ 65 Compller - all of which are available now and are described later - and with other higher level languages whose firmware is being developed. Applicable commands are shown at right,

While the Mnemonic and Symbolic Assembler gives aspiring professionals easier-understanding of the fundamentals of programming, the higher level languages facilitate and speed up the process. An analogy is that assembly
language programming is like building a house with boards and nails, while high level language programming is like using pre-fabricated sections.

Examples of the programming simplicity that AlM 65's Interactive Monitor software gives you, are the following functions you can command with single keystrokes:
$\square$ Print step-by-step program listings on the on-board printer or on an attached TTY or terminal:
D Display and change selected Registers and Memory:
$\square$ Set breakpoints, and trace program execution for debugging in single-step modes;
$\square$ Transfer data from attached TY or cassette recorders, including manipulating programs from one tape to another;
$\square$ Store programs in on-board or external RAM, ROM. PROM. or in other external memories such as tapes, floppy disks. bubbles, etc.

## Text Editor

This program is stored as firmware on the same ROMs containing the Interactive Monitor. It gives you the advantages of displayed or printed program entries and listings which are translated by the Symbolic Assembler and the PL/ 65 Compiler into machine codes. It also gives you superior debug capabilities. Most of the Text Editor's commands - see right -are word-processor-ike. The Text Editor even includes a command that automatically locates instructions. comments and labeis in the program being developed.

With the Text Editor, you can add, delete and change instructions anywhere in the program without affecting any other portion.


Symbolic input to the Text Editor for same addition program.

## Symbolic Assembler

Firmware is contained on a separate ROM. The Symbolic Assembler software gives practicing professionals a highls efficient means for developing the most complex programs permitting the shortcutting of programming time and doc umentation by assigning labels to instructions, subroutine: and data locations.

At the same time, it introduces students to the fundamen tals of microcomputer programming in a basically simple fashion.

## professional software.

The software inspiration in the AIM 65 approach is that the Interactive Monitor and the Text Editor work together with the Symbolic Assembler to provide displayed and printed details of entries, listings and debug operations.


BASIC version of the same addition program.

## BASIC Interpreter

Firmware is contained on separate ROMs. AIM 65's highlevel BASIC is the most effective 8 K version developed by Microsoft,

The practicing professional will use BASIC to speed up programming microcomputers designed as systems for many computational and processing applications;

BASIC, which stands for Beginner's All-purpose Symbolic Instructions Code, is also the easy-use language offered by most amateur personal computers for fun and games. Which says that when you want diversion from professional work or learning, your AIM 65's ready.

BASIC is universally recognized as the most easily learned computer programming language. Even a complete microprocessor novice should be able to begin writing BASIC programs after only a few hours of study.


PLi65 version of the same addition program.

## PL/65 Compiler

Firmware is contained on two separate ROMs. PL/65 is a high-level language that practicing professionals and advanced students use when large programs have to be developed very rapidly - where software development costs are important.

## Rockwell's Future Software Plans

Rockwell is developing firmware for the AIM 65 that will provide owners with high-level languages facilitating a variety of development projects.

## Single-Keystroke Monitor Commands

Major Function Entry
(RESET Button)-Enter and initialize Monitor
ESC-Re-enter Monitor
E-Enter and initialize Text Editor
T -Re-enter Text Editor
N-Enter Symbolic Assembler
5 - Enter and initialize BASIC Interpreter
6 -Re-enter BASIC Interpreter
Instruction Entry and Disassembly
1 - Enter mnemonic instruction entry mode
K-Disassemble memory
Display/Alter Registers and Memory

*     - Alter Program Counter to (address)

A - Alter Accumulator to (byte)
$X$-Alter $X$ Register to (byte)
$Y$-Alter Y Register to (byte)
$P$-Alter Processor Status to (byte)
S - Alter Stack Pointer to (byte)
R-Display all registers
M-Display four memory locations, starting at (address)
(SPACE)-Display next four memory locations
I-Alter current memory location

## Manipulate Breakpoints

\#-Clear all breakpoints
4 - Toggle breakpoint enable on/off
B - Set one to four breakpoint addresses
? -Display breakpoint addresses
Control Instruction/Trace
G - Execute user's program
$Z$ - Toggle instruction trace mode on/off
$V$-Toggle register trace mode on/off
H - Trace Program Counter history
Control Peripheral Devices
L-Load object code into memory from peripherall/O device
D-Dump object code to peripheral //O device
1 -Toggle Tape 1 control on/off
2 - Toggle Tape 2 control on/off
3.-Verify tape checksum

CTRL PRINT-Toggle Printer on/off
LF-Line Feed
PRINT-Print Display contents
Call User-Defined Functions
F1-Call User Function 1
F2 - Call User Function 2
F3-Call User Function 3
Text Editor Commands
$R$-Read lines into text buffer from peripheral 10 device
1 -Insert line into text buffer from Keyboard
$K$-Delete current line of text
(SPACE)-Display current line of text
L-List lines of text to peripheral $1 / O$ device
U-Move up one line
D-Move down one line
T-Go to top line of text
B-Go to bottom line of text
$F$-Find character string
C -Change character string
Q-Quit Text Editor, return to Monitor

## Rockwel/ A/M65...more fe



Directly hook un one of two cassette recorciers

## Third-Generation R6500 Microprocessor System

Functional heart of the AlM 65 microcomputer is an R6502 CPU (Central Processing Unit). The high-performance 8-bit R6502 has 65K-byte memory addressability and the power of a 56 -command, 13 -addressing mode, minicomputer-like instruction sel.

The R6502 is supported with selected R6500 microprocessor family devices to implement AlM 65's internal system and to provide versatile, used-dedicated applications interfaces.

An R6522 Versatile Interface Adapter (VIA) provides NM 65 users with two Input/Output (IIO) ports, each with eight lines, an 8 -bit serial l/O port, and access to two on-chip 16-bit interval-timer/event counters.

## Broad Applications Options

This I/O capability gives you an amazingly broad range of applications options, You can easily interface with sensors

and switches to perform item or batch response functions. You can readily include D-A/A-D converters and provide audio and other functions in an AIM 65-based system. (AIM 65 has a nine octave music synthesis capability.)

An Application Note is available so that you can interface AIM 65 to a CRT monitor or TV set.

Ingenious professionals also use AIM 65's inspired software to increase its applications potentials. For example, one engineer uses the Text Editor to list and look up stored telephone numbers so that his AIM 65 functions as an automatic telephone dialler.

AIM 65's l/O abilities also allow you to directly hook up one or two cassette recorders. One use of cassette recorders is permanently storing programs you develop for bookkeeping, home environmental and security controt, student education, etc. When you want to use your AIM 65 for a special purpose, you simply load the applicable taped program into RAM.

## lures forprofessionals.



## :xpansion Motherboard Available <br> or System Add-On Modules

asily attached to AIM 65's full-bus System Expansion jonnector is a Motherboard with five slots that hold many tandard and special modules available from Motorola, urr-Brown. Rockwell and other manufacturers.

AlM 65's Expansion Connector and Motherboard carry ie microcomputers full system bus lines - address, data nd control - fully buffered to provide ample drive capacity. ddress decode logic for mapping internal and external ddresses in 4 K -byte increments is provided.

Using the Expansion Connector and/or the Motheroard, you can readily enlarge your system to include PROM rogrammer module. PROM modules, floppy disk controller odule, RAM modules and other subsystem modules.


Expansion motherboard pugs on to connewtot

For developing and prototyping systems, you can add Prototyping and Personality Boards designed for the Rockwell SYSTEM 65 ( 6502 microprocessor) and the Motorola EXORciser ( 6800 microprocessor).

To convert your processor or controller into an intelligent terminal, you can easily add a Rockwell R24 Modular Modem ( 2400 bps ) or slower board modems. This means you can use your AIM 65 to "talk" over ordinary telephone lines to other computers or other AIM 65s.

And your AIM 65 is now ready to let you use the emerging memory generation - Bubble Domain Memories. Under available software control, your AIM 65 can address all 128 K -bytes of a Rockwell Bubble Memory module, providing you with a magnificent file directory.

# Rockwel/ A/M 65-ufor working 



Professionally witten texts.
fessional understanding of microprocessing and microcomputers. 2) 6502 Software Design - 270 pages; tutorial book by L. J. Scanlon; gives a step-by-step approach to programming 6502 microprocessor-based computers in assembly language, with special emphasis on the AIM 65.

## Rockwell Keeps You Current

Your purchase of AlM 65 entitles you to become a subscriber to Interactive, a professional newsletter Rockwell publishes regularly to keep AIM 65 owners up to date on innovative design ideas, programming shortcuts and other professional applications data. Subscription price is minimal,

Applications Notes
Rockwell is continually producing Applications Notes which

## and learning professionals.



Professional teaching and learning.
are available to AlM 65 owners at no charge. New Applications Notes will be described in issues of Interactive. Typical of existing Applications Notes are: "Interfacing KIM4 to AIM 65"-Document R6500 N11; "Using KIM-1 Tapes with AlM 65"-R6500 N19; "Preparing an AIM 65 BASIC Program for PROM/ROM Operation"-R6500 N15; "SYSTEM 65 to AIM 65 Interface"--R6500 N04, "A CRT Monitor or TV Interface for AIM 65"-R6500 N12; "R232C Interface for AIM 65*-R6500 N08.

## Professional Teaching and Learning

AIM 65 is tops in any class for microprocessor learning. And its special educational features come at a low price school budgets can afford. Its on-board printer produces hard copies of exercises for easy checking by student and instruc-


Protessional microcomputer development
tor. Interactive Monitor software prompts students each step of the way in learn-through-doing education.

## Microcomputer Design Caurses

Rockwell offers 6500 microcomputer design courses that include using the AIM 65. For details; schedules, locations, contact Rockwell Offices-see back cover of this brochure.

## Professional Microcomputer Development

Now for a few hundred dollars - instead of many thousands -AlM 65 functions as a complete programming and system development aid. Personality modules are available You can develop your program in RAM, store it on tape or floppy disk for debugging and prototyping, then transfer it into PROM for field testing.

## Rockwell A/M 65..fo

Process control and management, chemical mixing and control, test equipment and instrumentation, data logging and computing... AlM 65 as a "bare-board" microcomputer is already being used in an astonishing variety of work assignments.

For a few hundred dollars, the "bare-board" AIM 65 gives you dedicated or programmable controllers or processing systems that duplicate functions now being performed with minicomputers costing thousands of dollars.

And today the "bare-board" AIM 65 has proved to be economically feasible as the implementing system of control and processing products designed for low-volume use. (100 units a year is a generalized rule of thumb, but do your own calculations.)

Rockwell's Applications Engineers will be happy to consult with you on contemplated programs. Call the nearest Rockwell Office listed on the back cover of this brochure.

Bare-Board AIM 65 Is Now Being Used in Low-Volume Products Like:

| Electronic Components Testers | Radio Burst Testers |
| :--- | :--- |
| Energy Management Systems | Machine Tool Controllers |
| Card and Badge Readers | Digital Plotting Systems |
| Chemical Mixing Controllers | Coin Counters |
| Hotel Wake-Up Systems | Medical Equipment |
| Manufacturing Controllers | Postal Scales |
| Industrial Appliance Controllers | Label Printers |

AIM 65 Lets Professional Imaginations Fly but Keeps Product Costs on the Ground...

## orofessional work.

Designed in Days instead of Months... Costing Hundreds instead of Thousands of Dollars ... AlM 65-based Systems Record, File, Retrieve, Analyze, Compare Data... Monitor and Control Processes and Operations


Programmable Machinirg Controlter.



AIM 65 with a milion bits of Rockwell bubbie memory


AIM 65
The Professional's Microcomputer... more of the power in ROCKWELL MICROPOWER

[^1]power in your hands

| Rockwell | R6500 Microcomputer System <br> PRODUCT DESCRIPTION |
| :---: | :---: |
| AIM 65 EXPANSION MOTHERBOARD |  |

## OVERVIEW

The AIM 65 Expansion Motherboard（Part No．A65－009）is used to extend the AIM 65 system bus to external add－on modules．Its five on－board connectors support all modules designed for Rock－ well＇s SYSTEM 65 or Motorola＇s Exorcisor ${ }^{(8)}$ ，as well as other modules offered by Rockwell，Motorola，Burr－Brown and a variety of other manufacturers．

The AIM 65 system bus lines（address，data and control）are buffered to provide ample drive capability．Address decode logic for mapping internal and external addresses in 4 K －byte increments is also provided．
（B）＂Exorcisor＂is a registered trademark of Motorola．Inc．

## FEATURES

－AIM 65 bus expansion
－Accepts up to five compatible modules
－Address selection in 4 K －byte increments
－System bus lines are fully buffered
－DMA logic provided

## FUNCTIONAL DESCRIPTION

In reading the following text，refer to the attached schematic， PA00－X143．

The Address Bus lines AO－A 15 and Control Bus lines 02，SYNC， $R / \bar{W}$ and $\emptyset 1$ from the AIM 65 are buffered with 8 T97 devices Z3，Z4， $\mathrm{Z5}$ and Z6．The Data Bus lines DO－D7 are buffered and inverted with 8T26A devices $Z 1$ and Z2．The address，data and $R / \bar{W}$ lines are controlled by the external DMA line．If DMA is high，the address，data and $R / W$ buffers are enabled to drive．If $\overline{D M A}$ is low，these buffers are placed in the off state，allowing an external controller to drive the address，data and $R / \bar{W}$ lines．The remaining buffered lines，$\emptyset 1, ~ \emptyset 2$ and SYNC，are unaffected by the state of DMA．

Control lines RDY，$\overline{\operatorname{RES}}, \overline{\mathrm{NMI}}, \overline{\mathrm{RQ}}$ and S．O．are unbuffered，but are brought directly to the AIM 65 Expansion Connector．

Address decoding is provided on the AIM 65 Expansion Mother－ board．Device Z10（SN74159）is used to decode the four high－ order address lines，A12－A15．The one－of－16 outputs are con－ nected to a set of 16 switches，S1 and S2．When one or more of the switches are closed／opened，the decode logic $(Z 11, Z 7, Z 8$ and Z9）enables／disables Data Bus drivers Z1 and Z2．The R $\bar{M}$ line determines the direction of data flow．


## SWITCHES AND JUMPERS

## Internal/External Address Selection Switches

Sixteen switches on the AIM 65 Expansion Motherboard permit the user to define whether each 4 K -byte portion of the system address space is internal or external to the AIM 65 . When a switch is set to ON, its corresponding $4 K$ address range is external li.e., on the AIM 65 Expansion Motherboard). Conversely, when a switch is set to OFF, its corresponding $4 K$ address range is internal (i.e., on the AIM 65 Microcomputer). Table 1 shows the address range corresponding to each switch on the Expansion Motherboard.

CAUTION

Be careful in assigning external address space, since it may conflict with internal functions of the AlM 65. See Section 7.3 .2 of the AIM 65 User's Guide for AIM 65 address assignments.

Table 1. Address Selection Table

| Switch | Address Range (Hex) |
| ---: | :---: |
| $\mathrm{S} 2 \cdot 1$ | 0000 to OFFF |
| -2 | 1000 to 1FFF |
| -3 | 2000 to 2FFF |
| -4 | 3000 to 3FFF |
| -5 | 4000 to 4FFF |
| -6 | 5000 to 5FFF |
| -7 | 6000 to 6FFF |
| -8 | 7000 to 7FFF |
|  |  |
| S 1.8 | 8000 to 8FFF |
| -7 | 9000 to 9FFF |
| -6 | A000 to AFFF |
| -5 | B000 to BFFF |
| -4 | C000 to CFFF |
| -3 | D000 to DFFF |
| -2 | E000 to EFFF |
| -1 | F000 to FFFF |

## DC Power Selection Jumpers

Power for the AIM 65 Expansion Motherboard can be supplied in either of two ways. For add-on modules with current requirements of less than 0.5 amp , the DC power $(+5,+12$ and $-12 \mathrm{Vdc})$ brought in on AIM 65 Expansion Connector J3 is adequate. For higher current requirements, DC power should be supplied through Expansion Connector power strip TB1, and Jumpers W1 ( +5 Vdc ). W2 ( +12 Vdc ) and $\mathrm{W} 3(-12 \mathrm{Vdc})$ should be removed.

## 02 Clock Jumper

AIM 65 Expansion Motherbeard connectors J2 through J6 provide the 02 clock on Pin J. This clock signal can be optionally provided on Pin L as well, by installing Jumper W4 on the Expansion Motherboard.

## INSTALLATION

The following procedure should be used to install the AIM 65 Expan. sion Motherboard onto the AIM 65 Microcomputer:

1. Mount the ten supplied card guides on the AIM 65 Expansion Motherboard with the screws provided (two screws per guide), with one card guide on each end of connectors J2 through J6.
2. The kit includes five self-adhesive rubber feet. Instalt a rubber foot in each corner of the Expansion Motherboard, and one foot in the center.
3. Remove jumpers $W 1, W 2$ and $W 3$, if required. See DC Power Selection Jumpers.
4. Certain add-on modules access the 02 clock on Pin L. Install Jumper W4 if your add-on modules have this requirement.
5. Connect Expansion Motherboard Connector P 1 to AIM 65 Expan. sion Connector J3.

## CAUTION

Never install or remove the AIM 65 Expansion Motherboard or add-on modules with system power on. It may cause damage to the AIM 65, the Expansion Module or the add-on module.
6. Install the add-on modules into any of the slots on the AIM 65 Expansion Motherboard, J2 through J6, with the component side of each add-on module facing the AIM 65.
7. Configure address selection Switches S1 and S2, as appropriate to your system. See Internal/External Address Selection Switches.
8. Apply power to the AIM 65 and, if required, to the AIM 65 Expansion Motherboard.


## USING MULTIPLE EXPANSION MOTHERBOARD

Edge connector 11 on the AIM 65 Expansion Motherboard permits you to install additional Expansion Motherboards in your system. The pinouts on J 1 are the same as on P1, except that the Data Bus sig. nals are inverted on J1. Therefore, on each additional Expansion Motherboard the socketed Data Bus driver devices, Zt and 22 , must be replaced with the 8 T 28 noninverting drivers before installing those Expansion Motherboards in the system.

Further, address selection switches S1 and S2 on the first Expansion Motherboard must have all external address ranges of its own, as well as all subsequent modules, selected. Similarly, the second Expansion Motherboard must have all external address ranges of its own and sub sequent modules selected, and so on.

For example, consider a system with three AIM 65 Expansion Mother boards. In this system, addresses $\$ 4000$ through \$4FFF are dedicated to devices on Expansion Motherboard \#1 (the Module connected to the AIM 65), addresses $\$ 7000$ through $\$ 8 F F F$ are dedicated to devices on Expansion Motherboard \#2 and addresses $\$ 9000$ through $\$ 9 F F F$ are dedicated to devices on Expansion Motherboard \#3. The switch settings for the three Expansion Motherboards are as follows:

- On Expansion Motherboard \#1, Switches S2-5, S2-8, S1-8 and S1-7 must be ON; all other switches must be OFF.
- On Expansion Motherboard \#2, Switches S2-8, St-8, and S1-7 must be ON; all other switches must be OFF.
- On Expansion Motherboard \#3, Switches S1-7 must be ON; al other switches must be OFF.


## EXPANSION MOTHERBOARD PIN ASSIGNMENTS

## Connectors P1 and J1

Connector P1, the interface to the AJM 65 microcomputer, is a 44 -pin connector with pin assignments given in Table 2.

The same bus signals are extended out to Edge Connector J 1 on the AIM 65 Expansion Motherboard except that the Data Bus signals DO through $D 7$ on connector pins 15 through 8 are presented in inverted form ( $\overline{\mathrm{DO}}-\overline{\mathrm{D} 7}$ ) on Connector J 1 .

## Connectors J2 through J6

Table 3 shows the pin assignments for Connectors J1 through J6 on the AIM 65 Expansion Motherboard. Unused pin locations are interconnected on Connectors J2 through J6.

Table 2. Pin Assignments for Connector P1

| PIN | SIGNAL | PIN | SIGNAL |
| :---: | :---: | :---: | :---: |
| 22 | GND | $z$ | RAM R/W |
| 21 | +5V | Y | $\overline{92}$ |
| 20 | CSA | X | TEST |
| 19 | CS9 | W | R/V |
| 18 | CS8 | $\checkmark$ | SYS R/W |
| 17 | +12V | U | SYS 92 |
| 16 | -12V | T | A 15 |
| 15 | DO | S | A14 |
| 14 | D1 | R | A13 |
| 13 | D2 | P | A12 |
| 12 | D3 | N | A11 |
| 11 | D4 | M | A10 |
| 10 | D5 | L | A9 |
| 9 | D6 | K | A8 |
| 8 | D7 | $J$ | A7 |
| 7 | RES | H | A6 |
| 6 | NMI | F | A5 |
| 5 | S.O. | E | A4 |
| 4 | IRO | D | A3 |
| 3 | 01 | C | A2 |
| 2 | RDY | B | A1 |
| 1 | SYNC | A | A0 |

Table 3. Pin Assignments for Connectors J2-J6

| Pin No. | Name | Pin No. | Name | Pin No. | Name | Pin No. | Name |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $+5 \mathrm{VDC}$ | 23 |  | A | +5VDC | $\bar{A}$ | SYNC |
| 2 | +5VDC | 24 | GND | B | +5 VDC | B | GND |
| 3 | +5 VDC | 25 |  | C | +5VDC | $\overline{\mathrm{C}}$ | S. O. |
| 4 |  | 26 | GND | D | IRQ | $\overline{\mathrm{D}}$ | DMA |
| 5 | $\overline{\text { RES }}$ | 27 | RDY | E | $\overline{\text { NMI }}$ | E |  |
| 6 | R/W | 28 | WP7* | F |  | F |  |
| 7 | 01. | 29 | D1 | H | GND | H | D3 |
| 8 | GND | 30 | $\overline{\mathrm{D} 5}$ | $J$ | 02 | J | D7 |
| 9 | GND | 31 | $\overline{\text { DO }}$ | K | GND | K | D2 |
| 10 | ** | 32 | $\overline{\mathrm{D4}}$ | L | (02)** | L | $\overline{\text { D6 }}$ |
| 11 | -12 VDC | 33 | A 15 | M | -12 VDC | $\bar{M}$ | A14 |
| 12 |  | 34 | A12 | N |  | $\bar{N}$ | A13 |
| 13 |  | 35 | A11 | P |  | $\bar{p}$ | A10 |
| 14 |  | 36 | A8 | R |  | $\bar{R}$ | A9 |
| 15 |  | 37 | A7 | S |  | S | A6 |
| 16 | +12 VDC | 38 | A4 | r | $+12 \mathrm{VDC}$ | T | A5 |
| 17 |  | 39 | A3 | U |  | U | A2 |
| 18 |  | 40 | A0 | V |  | $\overline{\text { V }}$ | A1 |
| 19 | WP4* | 41 | GND | W |  | $\bar{W}$ | GND |
| 20 | WP5* | 42 | GND | X | WP ${ }^{*}$ | $\bar{X}$ | GND |
| 21 |  | 43 | GND | $Y$ | WP3* | $\bar{Y}$ | GND |
| 22 | WP6* |  |  | Z | WP2* |  |  |

"Tied directly to ground, disabling write-protect feature.

* -If jumper W4 installed
*     * 3 K null-up RESISTOR to +5 VDC.


## SPECIFICATIONS

Motherboard Dimensions:
Expansion Capacity:
Interfaces:
Edge Connectors:
Expansion Connectors:
Operating Temperature:
Power Requirements (Module Only):
11.3 in. $\times 8.95$ in.

Five modules
AIM 65 and SYSTEM 65 compatible
44 pins on 0.156 in. centers
86 pins on 0.156 in. centers
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$+5 \mathrm{Vdc} \pm 5 \%$ @ 0.8 amp

## LOGIC LEVELS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$

| Characteristic | Symbol | Min | Max | Unit | Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Inputs |  |  |  |  |  |
| A0.A15, D0.D7.02.01. SYNC, R/W | $V_{\text {IL }}$ |  | 0.8 | $v$ | ${ }_{1} \mathrm{IL}=.400 \mu \mathrm{~A}$ |
| $\overline{\mathrm{DO}} \cdot \overline{\mathrm{D7}}$ | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | ${ }^{\text {cc }}$ | V | $1_{1 H}=40 \mu \mathrm{~A}$ |
| Outputs |  |  |  |  |  |
| D0.07 | $\mathrm{V}_{\mathrm{OL}}$ |  | 0.5 | $v$ | $\mathrm{I}_{\mathrm{OL}}=20 \mathrm{ma}$ |
|  | ${ }^{\mathrm{OH}}$ | 2.4 |  | $\checkmark$ | ${ }^{1} \mathrm{OH}=-2 \mathrm{~mA}$ |
| $\overline{\mathrm{DO}} \cdot \overline{\mathrm{D7}}$ | $v^{\text {OL }}$ |  | 0.5 | V | ${ }^{1} \mathrm{OL}=48 \mathrm{ma}$ |
|  | $\mathrm{v}_{\mathrm{OH}}$ | 2.4 |  | $v$ | ${ }^{1} \mathrm{OH}=10 \mathrm{ma}$ |
| A0.A15, 02, 01 | $\mathrm{v}_{\mathrm{OL}}$ |  | 0.5 | v | $\mathrm{I}_{\mathrm{OL}}=48 \mathrm{ma}$ |
| SYNC, R/W | $\mathrm{v}_{\mathrm{OH}}$ | 2.4 |  | V | ${ }^{\prime} \mathrm{OH}=-5.2 \mathrm{ma}$ |

## PART NUMBER

 A65－901
## AIM 65 DATA SHEET

## AIM 65 PROM PROGRAMMER AND CO－ED MODULE

The AIM 65 PROM Programmer and CO－ED Module （A65－901）programs 1 K －， 2 K －，and 4 K －byte PROMs that can be installed in the AIM 65 or in a Microflex 65 16K PROM／ROM Module．The PROM Programmer provides check，program，verify and read functions．

The utility of the Module is enhanced through the in－ cluded Object Code Editor（CO－ED）．CO－ED allows you to edit object code in much the same way as you can edit source code for the AIM 65 Assembler，using AIM 65＇s Text Editor．With CO－ED，patches can be made directly in your program without having to go through the time－consuming process of re－assembling．

The AIM 65 PROM Programmer and CO－ED Module also supports data load，verify and dump with offset functions．And the Module plugs directly into the AIM 65 Expansion Connector．

## FEATURES

－Plugs directly onto the AIM 65 Expansion Connector
－Programs the following 5 volt PROMs（or equivalents）：
－Intel 2758， 2716 and 2732
－TI TMS 2508， 2516 and 2532
－Provides programming functions to check，program， verify and read PROM
－Includes utility functions to load，verify，dump，fill and and invert memory
－Incorporates object code editor（CO－ED）functions to control program pointers；search for operands，jumps／． branches and strings；and to modify instructions with automatic address adjustment
－ 1 K bytes of Static RAM are included to allow single－ pass programming of a 4 K －byte PROM when used with a 4 K RAM version of AIM 65
－Zero insertion force（ZIF）socket for PROM being programmed
－On－board DC／DC Converter allows +5 V －onl；operation
－Fully assembled，tested and warranted


## FUNCTIONAL DESCRIPTION

The R6520 Peripheral Interface Adapter (PIA) is the primary interface device between the AIM 65 Expansion Connector and the 24-pin Zero Insertion Force PROM socket and control , circuits. During PROM programming, PROM address, PROM data and programming control signals are transmitted to the PIA on the AIM 65 Expansion Connector data lines. During PROM check, verify and read operations, only PROM address and control signals are issued to the PIA from the AIM 65.

Four PIA I/O Lines carry the most significant address signals to the PROM. Eight other PIA I/O lines multiplex the PROM data and least significant address signals. One output line controls the Tri-State Data Latch. Five other PIA I/O Lines control the Power Switches.

During PROM programming, PROM data is transferred to the tri-state Data Latch, which drives the latched data to the PROM. The PROM address is then sent to the PROM on the eight multiplexed data/address lines and the four dedicated address lines. The Power Switches are then turned on to apply the proper voltage levels for the required time duration to transfer the 8 -bits of data into one PROM location. The process is repeated until the specified PROM address range is fully programmed. The tri-state Data Buffer is disabled during programming.

During PROM read operations, the PIA sets the address lines to the PROM. The tri-state Data Buffer drives the PROM data onto the AIM 65 Expansion Connector data lines. The Data Latch is disabled at this time.

The Power Switches drive +5 V or +26 V onto three PROM socket programming lines depending on the PROM type selected.

The 4K R2332 ROM contains the PROM Programmer and CO-ED firmware.

1 K bytes of on-board RAM are provided for use by the PROM Programmer and CO-ED software. The RAM is mapped from \$1000. $\$ 13 \mathrm{FF}$ to provide contiguous addressing from the top of a $4 K$ RAM AIM 65.

The Address Decode circuitry generates individual chip select signals to the RAM, ROM, PłA and the Data Buffer.

The PROM Programmer and CO-ED Module may be powered from the AIM 65 or from an external +5 V power supply. A DC/DC Voltage Converter generates +30 V from +5 V . The +30 V is regulated to +26 V for on-board use. The +30 V may be connected to an external power supply to minimize current drain on the +5 V supply.


AIM 65 PROM Programmer and CO-ED Module Block Diagram

AIM 65 Expansion Connector Pin Assignments

| Top (Component Side) |  |  |  | Bottom (Solder Side) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Signal Mnemonic | Signal Name | Inpu:/ Output | Pin | Pin | Signal Mnemonic | Signal Name | Input/ Output |
| SYNC | - Sync | 0 | 1 | A | AO | Address 8it 0 | 1 |
| RDY | -Ready | 1 | 2 | B | A 1 | Address Bit 1 | 1 |
| ¢ 1 | - Phase 1 Clock | 0 | 3 | C | A2 | Address Bit 2 | 1 |
| $\overline{\text { IRO }}$ | - Interrupt Request | 1 | 4 | 0 | A3 | Address Bit 3 | 1 |
| S.O. | - Set Overflow | 1 | 5 | E | A4 | Address Bit 4 | 1 |
| $\overline{\text { NMI }}$ | - Non-Maskable Interrupt | 1 | 6 | F | A5 | Address Bit 5 | 1 |
| $\overline{\mathbf{R E S}}$ | Reset | 1 | 7 | H | A6 | Address Bit 6 | 1 |
| D) | Data Bit 7 | 1/0 | 8 | J | A7 | Address Bit 7 | 1 |
| D6 | Data Bit 6 | 1/0 | 9 | K | A8 | Address Bit 8 | 1 |
| D5 | Data Bit 5 | 1/0 | 10 | L | A9 | Address Bit 9 | 1 |
| D4 | Data Bit 4 | 1/0 | 11 | M | A10 | Address Bit 10 | 1 |
| D3 | Data Bit 3 | 1/0 | 12 | N | Al1 | Address Bit 11 | 1 |
| D2 | Data Bit 2 | 1/0 | 13 | P | A12 | Address Bit 12 | 1 |
| 01 | Data Bit 1 | 1/0 | 14 | R | A13 | Address Bit 13 | 1 |
| DO | Data Bit 0 | 1/0 | 15 | S | A14 | Address Bit 14 | 1 |
| . 12 V | $\cdot 12 \mathrm{Vdc}$ |  | 16 | $T$ | A15 | Address Bit 15 | 1 |
| +12V | $\cdot+12 \mathrm{Vdc}$ |  | 17 | U | SYS 92 | System Phase 2 Clock | 0 |
| $\overline{\text { CS8 }}$ | Chip Select 8 | 0 | 18 | $v$ | SYS R/W | System Read/Write | 0 |
| $\overline{\mathrm{CS9}}$ | Chip Select 9 | 0 | 19 | w | R/W | Read/Write "Not" | 0 |
| $\overline{\text { CSA }}$ | - Chip Select A | 0 | 20 | $\times$ | TEST | Test | 0 |
| +5V | +5 Vdc |  | 21 | $Y$ | $\overline{\phi 2}$ | Phase 2 Clock "Not" | 0 |
| GND | Ground |  | 22 | $z$ | RAM R $\bar{W}$ | RAM Read/Write | 0 |

NOTE:

- = Not used on this module.

PROM Programmer Commands

| Category | Command | Function |
| :---: | :---: | :---: |
| ENTRY/EXIT | F1 <br> F2 <br> ESC | ENTER PROM PROGRAMMER RE-ENTER PROM PROGRAMMER ESCAPE TO MONITOR |
| BASE ADDRESS | $\begin{aligned} & \mathrm{B} \\ & 0 \end{aligned}$ | PROM BASE ADDRESS RAM BASE ADDRESS |
| PROM | $\begin{aligned} & C \\ & P \\ & V \\ & R \end{aligned}$ | CHECK PROM PROGRAM PROM VERIFY PROM READ PROM |
| MEMORY | $\begin{aligned} & \mathrm{L} \\ & \mathrm{~T} \\ & \mathrm{D} \\ & \mathrm{M} \\ & \mathrm{I} \\ & \hline \end{aligned}$ | LOAD MEMORY VERIFY MEMORY DUMP MEMORY FILLMEMORY INVERT MEMORY |
| RECORDER CONTROL | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | TOGGLE RECORDER CONTROL LINE 1 ON/OFF TOGGLE RECORDER CONTROL LINE 2 ON/OFF |

CO-ED Commands

| Category | Command | Function |
| :---: | :---: | :---: |
| ENTRYIEXIT | F3 1 ESC | $\begin{aligned} & \text { ENTER CO-ED } \\ & \text { EXIT CO-ED } \\ & \text { ESCAPE TOMONITOR } \\ & \hline \end{aligned}$ |
| POINTER CONTROL | $\begin{gathered} W \\ T \\ B \\ U \\ D \\ G \\ X \end{gathered}$ | LOCATE PROGRAM <br> MOVE TO TOP OF PROGRAM <br> MOVE TO BOTTOM OF PROGRAM <br> MOVE UP ONE INSTRUCTION <br> MOVE DOWN ONE INSTRUCTION <br> GO TO ADDRESS <br> EXCHANGE POINTERS |
| SEARCH | $\begin{aligned} & \text { F } \\ & \text { J } \\ & \text { S } \end{aligned}$ | FIND AN OPERAND <br> FIND JUMPS AND BRANCHES <br> FIND A STRING |
| PROGRAM MODIFICATION | $\begin{aligned} & 1 \\ & \$ \\ & A \\ & C \\ & M \\ & R \end{aligned}$ | INSERT AN INSTRUCTION STRIKEOUT AN INSTRUCTION ADJUST INSTRUCTION BLOCK CHANGE INSTRUCTION MOVE INSTRUCTION/DATA BLOCK RELOCATE |
| UTILITY | $\begin{aligned} & ! \\ & \mathrm{K} \end{aligned}$ | FILL MEMORY DISASSEMBLE MEMORY |

PROM Programmer and CO-ED Module Physical and Electrical Characteristics

| Characteristic | Value |
| :---: | :---: |
| Dimensions |  |
| Width | $4.4 \mathrm{in} .(111 \mathrm{~mm})$ |
| Length | $6.3 \mathrm{in} .(160 \mathrm{~mm})$ |
| Height | 0.75 in . $(19 \mathrm{~mm}$ ) |
| Weight | $5.3 \mathrm{oz} .(150 \mathrm{~g})$ |
| Environment |  |
| Operating Temperature Storage Temperature Relative Humidity | $\begin{aligned} & 0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \\ & 0 \% \text { to } 85 \% \text { (without condensation) } \end{aligned}$ |
| Power Requirements |  |
| With DC/DC Converter | $+5 \mathrm{~V} \pm 5 \%, 1.1 \mathrm{~A}(5.5 \mathrm{~W})$-- Maximum |
| Without DC/DC Converter | $+5 \mathrm{~V} \pm 5 \%, 0.75 \mathrm{~A}(3.75 \mathrm{~W})$ - Maximum |
|  | $+30 \mathrm{~V} \pm 5 \%, 0.04 \mathrm{~A}(1.2 \mathrm{~W})$ - Maximum |
| Memory Map |  |
| User RAM: | \$1000-\$13FF |
| 1/O: | \$8800-\$8FFF |
| ROM: | \$9000-\$9FFF |

- APPLICATION ORIENTED
- EXTENSIBLE LANGUAGE
- OVER 200 PRE-DEFINED FUNCTIONS
- INTERACTIVE COMPILATION
- REVERSE POLISH NOTATION
- ROM RESIDENT
- COMPACT MEMORY USAGE
- HIGH SPEED EXECUTION
- EASY DEBUGGING
- STACK IMPLEMENTATION
- SHORTENS SOFTWARE DEVELOPMENT TIME
- BUILD-IN STRUCTURED ASSEMBLER

AIM 65 Forth is a unique programming language that is well suited to a variety of applications. Because it was originally developed for real-time control applications, Forth has features that make it ideal for machine and process control, energy management, data acquisition, automatic testing, robotics and other applications where assembly language was previously considered to be the only possible language choice.

## Forth vs. Other Languages

Forth actually provides the best of two worlds. It has the looping and branching constructs of high-level languages (DO . . LOOP, BEGIN. . . END, IF . . THEN and IF . . ELSE ... THEN) and the code efficiency of machine and assembly languages. And programmers will be pleased to know that Forth allows you to specify addresses, operands and data in hexadecimal, octal, binary or any other number base from two to 40-a distinct advantage over languages like Basic, where all information must be in decimal.

In most time-critical applications, at least part of the program must be written in assembly language. AIM 65 Forth has a built-in 6502 macro assembler, and lets you drop into assembly language at almost any point in your program, without separate assembly and load steps or awkward machine level linkage. Forth programs typically run up to ten times faster than other interpretive languages, and can even approach the speed of machine language programs for some applications.

## Developing Forth Programs

Forth is built on subroutine-like functions, called "words." These words are linked together to form a "dictionary," which is the central core of the language. Writing a program in Forth consists of using several predefined words to define each new word. Once the new word has been added to the system dictionary, it becomes as much a part of the language as any other word that has been previously defined. In this way new features and extensions can be added by simply defining one or more new words. Adding new teatures to conventional languages like Basic or Pascal requires the language system to be completely reassembled or recompiled.

Forth is a stack-oriented language, and is programmed in Reverse Polish Notation (RPN), the notation that is used in Hewlett-Packard scientific calculators. Using a data stack is an extremely efficient way of passing vart ables back and forth between operations. A data stack eliminates the need to tie up memory locations with variable tables, and allows you to use only as much memory as you need.

Forth programs are developed using "top-down/bottom-up" techniques. That is, the programmer begins by defining the program in very general terms, then systematically breaks these definitions down into more and more detailed sub-modules. When the lowest levels of sub-modules have been defined, he starts coding, in Forth, at those levels, working back up toward the top of the program, in pyramid fashion. Each sub-module is a stand-alone component of the program, and can be completely debugged without having the complete program in the system. This type of software development is difficult, if not impossible, to do with most other high-level languages.

## A Forth Example Program

As an example of a Forth application, suppose we have a chemical processing plant that includes two holding tanks that pump into a mixing tank. When the mixing tank is full, both pumps must shut off and allow the liquid to mix for ten minutes. Here's a block diagram of this part of the system:


The functional steps needed to perform the operation are:

1. Start Pump \#1
2. Start Pump \#2
3. Wait until the Mixing Tank is fuil
4. Stop Pump \#1
5. Stop Pump \#2
6. Mix for 10 minutes

With the major operations now defined, we can begin writing our Forth program. Let's call the program MIX-BATCH. It would look like this:

## : MIX-BATCH

START-PUMP1
START-PUMP2
WAIT-TIL-TANK-FULL
STOP-PUMP1
STOP-PUMP2
FOR-10-MINUTES
MIX :


#### Abstract

Notice how similar this program is to our functional breakdown. It's also very readable. The colon (:) tells Forth that we are defining a new word; MIX-BATCH, in this case. The semicolon (;) on the last line, after MIX, indicates the end of the definition. The words between MIX-BATCH and the semicolon represent the operations that will be performed when the word MIX-BATCH is executed. All of these words-START-PUMP1, STARTPUMP2, WAIT-TIL-TANK-FULL, and so on-must have been previously defined using AIM 65 Forth words or other, user-defined words.

For instance, START-PUMP1 may be constructed from two general input/ output control words for the AIM 65's user-dedicated R6522 VIA, as follows: : START-PUMP1 PORTB1=OUTPUT SET-B1=HIGH : In this definition, PORTB1 = OUTPUT establishes Bit 1 of the VIA as an output and SET-B1 $=$ HIGH sets the output to a +5 V level, which turns on the pump motor. Either of these words (or any other Forth words) could be de-


fined in either Forth or assembly language. Existing assembly language programs and subroutines may be directly used by Forth.

## What You Get With AIM 65 Forth

AIM 65 Forth is contained on two 4 K ROMs, which plug into sockets on the AIM 65 board. Because Forth uses memory and VO so efficiently, complex programs can be developed on AIM 65 with just 4 K bytes of RAM and one cassette recorder. Forth also comes with a complete and easy-to-use reference manual. For more information, or to order AIM 65 Forth (Part No. A65-050), contact

Marketing Services
ROCKWELL INTERNATIONAL
P.O. Box 3669, RC55

Anaheim, CA 92803
or call 800/854-8099 (in California, 800/422-4230).

## AIM 65 FORTH WORDS

ni $=16$-bit signed number on the stack di $=32$-bit signed number on the stack $u i=16$-bit unsigned number on the stack
( n 1 is the deepest value). (d1 is the deepest value).
(u1 is the deepest value).

## STACK MANIPULATION



## AIM 65 FORTH WORDS (con't)

CONTROL STRUCTURES
DO . . . LOOP
DO . . LOOP
I
LEAVE
BEGIN . . UNTIL
BEGIN...WHILE
... REPEAT
BEGIN...AGAIN
IF ... THEN

IF . . . ELSE . . . THEN

Set up loop, given index range.
Like DO . . . LOOP, but adds stack value to index.
Place current index value on stack.
Terminate loop at next LOOP or + LOOP.
Loop back to BEGIN until true at UNTIL.
Loop while true at WHILE; REPEAT loops
unconditionally to BEGIN.
Unconditional loop.
If top of stack true, execute following clause THEN continue; otherwise continue at THEN.
If top of stack true, execute ELSE clause THEN continue; otherwise execute following clause, THEN continue.

## INPUT-OUTPUT

CR
SPACE
SPACES
DUMP
TYPE
?TERMINAL
KEY
EMIT
EXPECT
WORD
IN
HOLD
BAUD
BL
C/L
B/SCR
QUERY

## ID.

## MEMORY

@

$\mathrm{C}!$
$?$
$+!$
CMOVE
FILL
ERASE
BLANKS
TOGGLE

Carriage return.
Type one space.
Type $n$ spaces.
Print text string (terminated by ").
Dump n2 words starting at address.
Type string of n1 characters starting at address n 2 .
True if terminal break request present.
Read key, put ASCII value on stack.
Output ASCII value from stack.
Read n1 characters from input to address n2.
Read one word from input stream, until delimiter.
User variable contained within TIB.
Waits for KEY.
Set BAUD rate.
Output a SPACE character.
Number of characters/line.
Pointer to terminal input buffer start address.
Number of blocks/editing screen.
Input text from terminal.
Print <name> from name \# field address (nfa).

Fetch value addressed by top of stack.
Store $n 1$ at address $n 2$.
Fetch one byte only.
Store one byte only.
Print contents of address.
Add second number on stack to contents of address on top.
Move n3 bytes starting at address n 1 to area starting at address n2.
Put byte $n 3$ into $n 2$ bytes starting at address $\mathrm{n1}$.
Fill n2 bytes in memory with zeroes, beginning at address $n 1$.
Fill n 2 bytes in memory with blanks, beginning
at address $n 1$.
Mask memory with bit pattem.

OUTPUT FORMATTING

| NUMBER | Convert string at address to double-precision number. |
| :---: | :---: |
| <\# | Start output string. |
| \# | Convert next digit of double-precision number and add character to output string. |
| \#S | Convert all significant digits of doubleprecision number to output string. |
| SIGN | Insert sign of n into output string. |
| \# > | Terminate output string (ready for TYPE). |
| HOLD | Insert ASCII character into output string. |
| HLD | Hold pointer, user variable. |
| - TRAILING | Suppress trailing blanks. |
| .LINE | Display line of text from mass storage. |
| COUNT | Change length of byte string to type form. Print number on top of stack. |
| . R | Print number n 1 right justified n 2 places. |
| D. | Print double-precision number n2 nl . |
| D.R. | Print double-precision number n2 n1 right justified n3 places. |
| DPL | Number of digits to the right of decimal point. |

## MONITOR \& CASSETTE I/O

COLD
MON
?TTY
CHAIN
CLOSE
?IN
?OUT
GET
PUT
READ
WRITE
SOURCE
FINIS
$-\mathrm{CR}$

VIRTUAL STORAGE
LOAD
BLOCK
B/BUF
BLK
SCR
UPDATE
FLUSH
EMPTY-BUFFERS
+BUF
BUFFER
R/W
USE
FIRST
OFFSET
PREV

AIM 65 FORTH cold start.
Exit to AIM 65 Monitor.
Switch: true = TTY; false $=$ KB .
Chain tape file.
Close tape file.
Set to active input device (AID).
Set to active output device (AOD)
Input a character from the AID.
Output a character to the AOD.
Input n2 characters from AID to address n1.
Output n2 characters to AOD at address n1.
Compile from the AID.
Terminate compile from SOURCE.
Output CA to printer only.

Load mass storage screen
(compile or execute).
Read mass storage block to memory address.
System constant giving mass storage block
size in bytes.
System variable containing current block number.
System variable containing current screen number.
Mark last buffer accessed as updated.
Write all updated buffers to mass storage.
Erase all buffers.
Increment buffer address.
Fetch next memory buffer.
User read/write linkage.
Variable containing address of next buffer.
Leaves address of first block buffer.
User variable block offset to mass storage.
Variable containing address of latest buffer.

## AIM 65 FORTH WORDS (con’t)

## MISCELLANEOUS AND SYSTEM

| (<comment> ) | Begin comment (terminate by right <br> parentheses on same line). |
| :--- | :--- |
| IN | System variable containing offset into input <br> buffer. |
| Lop of memory. |  |
| LIMIT | Clear return stack and return to terminal. |
| COMPILER-TEXT INTERPRETER |  |

DICTIONARY CONTROL
FORGET HERE

ALLOT
TASK
-FIND
DP
C.
'PAD

DEFINING WORDS
: <name>
VARIABLE < name>
CONSTANT < name>
CODE <name>
;CODE
<BUILDS . . . DOES>
CREATE
USER

Begin colon definition of <name>.
End colon definition.
Create a variable named < name> when initial value $n$; returns address when executed.
Create a constant named <name> with value n ; returns value when executed.
Begin definition of assembly-language primitive operation named < name>.
Used to create a new defining word, with execution-time "code routine" for this data type in assembly.
Used to create a new defining word, with execution-time routine for this data type in higher-level FORTH.
Create a dictionary header.
Create a user variable.

VOCABULARIES

CONTEXT
CURRENT
FORTH
ASSEMBLER
VOCABULARY <name>
VLIST
VOC-LINK

SECURITY
ABORT
ERROR
MESSAGE

## WARNING

FENCE
WIDTH

PRIMITIVES

| OBRANCH | Run-time conditional branch. |
| :--- | :--- |
| BRANCH | Run-time unconditional branch. |
| PUT | Stores registers and jumps to next. |
| ENCLOSE | Text scanning primitive used by WORD. |
| RO | Location of retum Stack. |
| RPI | Initializes return Stack. |
| SO | Initial value of stack pointer. |
| SP! | Initialize stack pointer. |
| NEXT | The FORTH virtual machine. |

## Software Development is Fast and Easy With...

PL/65
A High-Level Language for the
AIM 65 Advanced Interactive Microcomputer

- PL65 Resembles PL/1 and Algol
- PL65 ROMs Plug into AIM 65 Board
- Generates 6500 Assembly Language, for PostCompilation Editing and Assembling
- Upward-Compatible With System 65 PL/65
- Has Control Structures for Conditional and Iterative Looping
- Drop Down to Assembly Language, For Optimal Coding Efficiency

In Rockwell's AIM 65, you have not only a low-cost, general-purpose microcomputer, but also the basis for a cost-efficient, low-end development system. By coupling AIM 65 with the advanced PL/65 Compiler option (Rockwell Part No. A65-030), you're even further ahead with valuable savings in time, effort and cost.
Resembling PL/1 and ALGOL in general form, PL/65 is designed to improve your productivity and efficiency by simplifying the overall software development effort.
The coding is easier, since PL/65's powerful, high level language statements enable you to implement even complex applications with minimal programming.
Program readability is enhanced by the self-documenting nature of PL65.
This results in programs that are easier to understand. These programs are easier to update, too, which means lower maintenance costs.

## PL/65 = Software Simplification

All language features are aimed at improving productivity by simplifying software development. PL/65's structured programming support features encourage modular program design, and its general control structure for conditional and lierative looping allows the language to be applied to highly structured programs.

## Coding Flexibility...When You Need It Most

PL/65 allows you to freely mix assembly language instructions in portions of the program where timing or code optimization requirements are critical.
This flexibility carries through the compile cycle: The PL65 compiler outputs source code to AIM 65's optional assembler, rather than object code. You'll be able to enhance or debug at the assembler level and indeed to drop into assembly language whenever you desire. PL/65 thereby provides the structuring potential and programming simplicity of a high-level language, while retaining the power and flexibility of an assembler.

## The PL/65 Package

PL65 for AIM 65 (Part No. A65-030) comes on two pre-programmed 4 K -byte ROMs, and is supplied with a comprehensive PL/65 User's Manual. It's available now from your local Rockwell Distributor. For the name of your nearest Distributor, call toll-free 800-854-8099 (within California, 800-422-4230).
For more information on PL65, SYSTEM 65, AIM 65, or the rapidly growing family of R6500 products, contact

ROCKWELL INTERNATIONAL
P.O. Box 3669, RC55

Anaheim, CA 92803
Attn: Marketing Services, D/727

| PL/65 Language Statements |  |
| :---: | :---: |
| Declaration | Specification |
| DECLARE | ENTRY |
| DEFINE | EXIT |
| DATA | TFILE |
|  | DFILE |
| Assignment | Conditional Execution |
|  |  |
| Direct Single | IF-THEN-ELSE |
| Byte Move |  |
| Indirect Single | Branching |
| Byte Move |  |
| Direct Multiple |  |
| Byte Move | GOTO |
|  | CALL |
| Imperative | RETURN |
|  | RTI |
| SHIFT | BREAK |
| ROTATE | HALT |
| ASSEMBLY CODE | Block |
| INC |  |
| INCW | BEGIN |
| DEC | DO |
| DECW | END |
| STACK | Miscellaneous |
| UNSTACK | Comment |
| Looping | Tab |
| FOR-TO-BY |  |
| WHILE |  |

RM65
BOARD PRODUCTS

# Rockwell RM65 Modular MFrocomputer 

A family of compact size, board-level products. Cut costs . . . increase productivity

## Rockwell International

The Rockwel RM 65 microcomputer consists of hardware modules and software packages designed for OEM and end-user applicatlons. The modules are compact functionally-oriented boards that provide state-of-the-art performance at off-the-shelf cost. The software packages include high level language interpreters and peripheral orivers

The RM 65 microcomputer provides an "already complete" flexible design concept that atiows you fo build, and expand, a system exactly to your needs. By using standard hardware and softwafe, you reduce engineering costs, shorten product introduction cycles, buy only what you need as you need it.


## Single Board Compu

RM65-1000
The Single Board Computer is the configurations. This single module inc static RAM, 16 K bytes PROM/ROM C 8-bit parallel ports with handshake con serial shift register. This module alon makes a custom RM 65 microcompu

## Modules

8K Static RAM Module
RM65-3108, RM65-3108N
Static RAM memory configurable as one 8192 byte block or as two 4096 byte blocks. On buard switches select bank and address assignments. (RM65-3108N less RAM devices)

## 32K Dynamic RAM Module

RM65-3132, RM65-3132N
32.768 bytes of dynamic RAM, transparent refresh maintains performance. Bank selection in 16 K blocks, address in 4 K blocks, switch selectable. (RM65-3132N less RAM devices)

CRT Controller (CRTC) Module
RM65-5102
Provides an $\operatorname{R6545}$ CRT device for timing and control, 2 K bytes refresh RAM and 2 K bytes ROM software. The module outputs HSYNC, VSYNC, and video signals as well as composite video Provides alphanumeric and limited graphics characters.
IEEE-488 Bus Controller Module
RM65-7102
Implements standard general purpose interface bus, communicates with up to 15 peripherais. On-board ROM software implements talk. listen, and controller functions

## 16K PROM/ROM Module

RM65-3216
Socketed to accept $2 \mathrm{~K}, 4 \mathrm{~K}$ or 8 K 24 -pin-devices up to a total of 16 K bytes of memory. May be assigned to one of two memory banks, switch selectable in 4 K byte sections.
Floppy Disk Controller (FDC) Module
RM65-5101
Controls up to four $8^{\prime \prime}$ single density or $51 / 4^{\prime \prime}$ single or double density disk drives, single or double sided. Software in on-board 4K ROM.

General Purpose Input/Output and Timer Module
RM65-5222
Total of 40 buffered $1 / 0$ lines. Two R6522 devices provide four 8 -bit parallel ports with hand-shake, four multi-mode 16 -bit timers. two 8 -bit shift registers.
Asynchronous Communications Interface Adapter (ACIA) Module RM65-5451
For RS232C serial intertace. Two R6551 ACIA devices control two independent RS232C ports with programmable rates from 50 to 19,200 baud. 20 ma TY interface. Handshake for modems.

## Modules

## licrocomputer <br> ed, when you need it • Cut design costs , cost AIM 65 development system

int for all RM 65 microcomputer opular R6502 CPU with 2 K bytes of d an R6522 VIA which provides two hulti-mode 16 -bit timers and an 8 -bit e or more memory or $1 / 0$ modules.


## Software

Software drivers for peripheral 1/0 devices and higher level language interpreters make fitting the RM 65 microcomputer to your application both easy and flexible. You can interface directly with the software orivers or the programmable devices. You can turn your RM 65 microcomputer into a BASIC machine.
CRT Controller Software Package
CRT driver, screen generation and test subroutines.

## FDC Software Package

Disk driver, file management and test subroutines.
IEEE-488 Software Package
Subroutines implement 1978 standards and module test.
BASIC Run Time Software Package
Directly compatible with AIM 65 BASIC, 8 K byte ROM resident. Universally recogrized as the most easily learned programming language.

## Accessories

4-, 8-, and 16-Slol Card Cages
RM55-7004, RM65-7008, RM65-7016
Modules insert into card cage, edge or pin connector style mother boards, power supplies connect to screw-down terminals.
Single Card Adapter
RM65-7101
Attach a single RM 65 module to the AIM 65 microcomputer.
Adapter/Buffer Module
RM65-7104
Allows connection of multiple RM 65 modules to the AIM 65 microcomputer
Cable Driver Adapter/Buffer
RM65-7116
Remotely locate RM 65 modules from AIM 65.


## Design Prototyping Module

RM65-7201
Allows custom circuit fabrication. Power and return lines pre-routed through module. Plated-through hole pattern permits manual or automatic wire-wrap.
Extender Module
RM65-7211
Maintains electrical continuity with RM 65 bus white troubleshooting, extends any module outside the card cage.

## AIM 65 Microcomputer

The low-cost AlM 65 microcomputer can be used as a complete development system for the RM 65 microcomputer. The AIM 65 functionally replaces the Single Board Computer for in circuit evaluation of the RM 65 microcomputer system in the application. The PROM Programmer and CO-ED module, BASIC interpreter, PL/ 65 compiler and 2-pass assembler are all options.

## SYSTEM 65 Development System

SYSTEM 65 offers the more traditional microprocessor development system. SYSTEM 65 comes with dual floppy disk drives, RS232C interface, parallel interface to printers, plus debug, text editor and two-pass assembler. Options include PL/65 compiler, BASIC interpreter, PROM programmer and User 65 module.

## SINGLE BOARD COMPUTER (SBC) MODULE

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state-of-the-art performance, compact size, modular design and low cost. Software for RM 65 systems can be developed in R6500 Assembly Language, PL/65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot. The 64 -line RM 65 Bus offers memory addressing up to 128 K bytes, high immunity to electrical noise and includes growth provisions for user functions. A selection of card cages provides packaging flexibility. RM 65 products may also be used with Rockwell's AIM 65 Microcomputer for product development and for a broad variety of portable or desktop microcomputer applications.

## PRODUCT OVERVIEW

The Single Board Computer Module (SBC) allows users to design their products into compact modular stacks. The SBC module plugs into a single slot in an RM 65 card cage/motherboard and controls other memory and I/O modules. The heart of the SBC modute is an R6502 CPU, which is capable of addressing 65 K bytes of memory. In addition, the SBC module contains bank address logic which allows addressing of one or two 65 K byte memory banks. Sockets on the module accept up to 16 K bytes of PROM/ROM. 2 K bytes of static RAM are also provided.

An R6522 Versatile Interface Adapter (VIA) provides two 8 -bit parallel I/O data lines, two 2 bit control lines, two countertimers and an 8-bit shift register. On-board switches assign memory sections to 4 K byte blocks. All address, data and control lines are buffered.

## FEATURES

- Compact size - about $4^{\prime \prime} \times 61 / 2^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Edge connector and Eurocard versions
- On-board R6502 CPU
- 2 K of 2114 static RAM
- Two sockets for up to 16 K PROM/ROM
- Supports the following PROM/ROM or equivalents
- TI TMS 2516, TMS 2532 and Motorola MCM 68764 PROMs - Rockwell R2316, R2332, or R2364 ROMs
- R6522 Versatile Interface Adapter (VIA) and I'O Interface
- Fully Buffered Address, Data, and Control lines for RM 65 Bus
- Separate switches allow RAM, PROM/ROM, and VIA to be individually dedicated to one or two 65K byte memory banks
- Jumpers allow selection of the following
- $2 \mathrm{~K}, 4 \mathrm{~K}$ or 8 K PROM/ROMs
- RAM, PROM/ROM and I/O starting address to 4 K byte boundary
- On-board or External bank addressing source
- Programmable DMA Terminate
- On-board or external clock source
- +5 V operation
- Fully assembled, tested and warranted


Eurocard Version RM65-1000E

## FUNCTIONAL DESCRIPTION

The Clock Circuit uses a crystal-controlled oscillator to provide a stable $1 . \mathrm{MHz}$ clock reference. A jumper selects between the internah clock reference or an external clock (to 1 MHz ) as the source for the R6502 and the derived system clock.

The Reset Control circuit conditions the Reset signal to drive the R6502 Reset line. A reset can be generated by either the on-board reset pushbutton or an external switch. This circuitry also generates a reset automatically, upon power-up.

The R6502 Central Processing Unit (CPU) is the heart of the SBC Module and any interfacing Modules connected to the RM 65 Bus. The R6502 controls all program execution by means of the address, data, control, and timing lines. All internal R6502 operations are synchronized to the clock source.

The Bank Select Control circuit detects when the SBC Module's assigned memory bank is addressed, by comparing the Bank Address signal to the Bank Select Enable and Bank Select switches. The Bank Select Enable Switches allow all on-board PROM/ROM, RAM, \& VIA to be independently assigned common to both Bank 0 (lower $\mathbf{3} 5 \mathrm{~K}$ ) and Bank 1 (upper 65K) or dedicated to either Bank 0 or Bank 1, depending on the Bank Select switches. A jumper allows the Bank Address signal to be driven by the on-board R6522 VIA or from another module.

The Base Address Decoder uses the six most-significant address bits and the Base Address Jumpers to generate chip selects for the on-board PROM/ROM, RAM, and VIA. The RAM and VIA can be independently mapped into any 4 K block of the selected 65 K bank. The PROM/ ROMs may be mapped into any $4 K$ or 8 K block of the selected bank.

The 16K PROM/ROM section has two sockets which can accept 2 K , 4 K or 8 K PROM/ROM devices. The size and type of PROM or ROM
is specified by the Base Address selection jumpers and the PROM/ ROM type jumpers.

The 2K RAM section uses four $1 \mathrm{~K} \times 4$ RAM devices to provide onboard read/write memory.

The R6522 Versatile Interface Adapter (VIA) provides input-output capability to the SBC Module. The VIA provides two 8 -bit I/O ports each with two control lines. Both ports and control lines are brought out to a connector for user applications.

The SBC Module can control up to 15 additional support modules by means of the RM 65 Bus. There are three groups of signals on the RM 65 Bus: data, address, and control.

The Data Transceivers invert and transfer eight bits of parallel data between the SBC Module and the RM 65 bus. The direction of the transceivers is controlled by the read/write signal from the R6502. The transceivers are disabled when the on-board PROM/ROM RAM, or VIA is addressed or when the Bus Float signal from the RM 65 Bus is active.

The Address Buffers invert and transfer 16 parallel address bits from the SBC Module to the RM 65 bus.

The Control Buffers buffer all control and clock signals between the SBC Module and the RM 65 bus. The Non-Maskable Interrupt, Interrupt Request, Set Overflow, External Clock ( $\emptyset 0$ ), Ready and Bus Float input lines are buffered coming from the RM 65 bus into the SBC Module. The DMA Terminate, Reset and Phase 1 Clock ( 01 ) output lines are always driven from the SBC Module onto the RM 65 Bus. The other six output lines for Read/Write, Phase 2 Clock, sync, and Bank Address are also buffered, but are tri-stated (disabled) when the Bus Float signal is active.


SBC Block Diagram


SBC Module Physical and Electrical Characteristics

| Characteristic | Value |  |
| :---: | :---: | :---: |
| Physical characteristics (See Notes) | Edge Connector Version | Eurocard Version |
| Width | 3.9 in . 100 mm ) | 3.9 in . (100 mm) |
| Length | $6.5 \mathrm{in} .(164 \mathrm{~mm})$ | $6.3 \mathrm{in} .(160 \mathrm{~mm})$ |
| Height | 0.56 in . (14 mm) | $0.56 \mathrm{in} .(14 \mathrm{~mm})$ |
| Weight | $5.3 \mathrm{oz} .(150 \mathrm{~g})$ | $5.6 \mathrm{oz} .(160 \mathrm{~g})$ |
| Environment |  |  |
| Operating Temperature | $\begin{aligned} & 0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ & 0 \% \text { to } 85 \% \text { (without condensation) } \end{aligned}$ |  |
| Storage Temperature |  |  |
| Relative Humidity |  |  |
| Power Requirements | $\begin{array}{rl} +5 \mathrm{Vdc} \pm 5 \% & 0.75 \mathrm{~A}(3.5 \mathrm{~W})-\text { Typical } \\ & 1.2 \mathrm{~A}(6.0 \mathrm{~W})-\text { Maximum } \end{array}$ |  |
|  |  |  |
| RM 65 Bus Interface |  |  |
| Edge Connector Version | 72 -pin edge connector ( 0.100 in . centers) <br> 64 -pin plug ( 0.100 in . centers) per DIN 41612 (Row B not installed) |  |
| Eurocard Connector Version |  |  |
| 1/O Connector | $40-\mathrm{pin} 3 \mathrm{M}$ mass termination ( 0.100 in . centers) |  |
| RESET Switch Connector | 2 vertical pins ( 0.3 in . high) on 0.200 in . center |  |

## NOTES:

1. The height includes the maximum values for component height above the board surface ( 0.4 in . for populated modules), printed circuit board thickness ( 0.062 in. ), and pin extension through the bottom of the module ( 0.1 in .).
2. The length does not include extensions beyond the edge of the module due to connectors or the module ejector.
3. The Eurocard dimensions conform to DIN 41612.



## RM 65

 DATA SHEET
## FLOPPY DISK CONTROLLER (FDC) MODULE

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state-of-the-art performance, compact size, modular design and low cost. Software for RM 65 systems can be developed in R6500 Assembly Language, PL/65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot. The 64 -line RM 65 Bus offers memory addressing up to 128 K bytes, high immunity to electrical noise and includes growth provisions for user functions. A selection of card cages provides packaging flexibility. RM 65 products may also be used with Rockwell's AIM 65 Microcomputer for product development and for a broad variety of portable or desktop microcomputer applications.

## PRODUCT OVERVIEW

The RM 65 Floppy Disk Controller (FDC) Module controls up to four standard ( $8^{\prime \prime}$ ) or mini- $\left(51_{4}^{\prime \prime}\right)$ floppy disk drives, single or double sided, soft sectored with either single density (FM) or double density (MFM) format. Software control of media density allows single or double density disks to be used in any connected drives.

Two DIP headers configure the FDC to interface with either standard or mini-floppy disk drives. An on-board jumper selects single or double sided drives and a switch disables on-board ROM. The FDC directly interfaces to most popular drives with only switch and/or header changes. Bank Select and Bank Select Enable switches allow the FDC module to be dedicated to one of two 65 K memory banks or assigned common to both banks. The FDC module I/O can be assigned to any page ( 256 bytes) using a standard PROM if the ROM is deselected.

## FEATURES

- Compact size - about $4^{\prime \prime} \times 61 /{ }^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Edge Connector and Eurocard versions
- RM 65 Bus compatible
- Buffered address, data and control lines
- Supports single or double sided, standard or mini-floppy disk drives
- Controls up to four disk drives
- Interfaces directly to Shugart SA-850 or SA-450 disk drives, with user options for other popular floppy disk drives
- Supports single-density IBM 3740 (FM) or double-density IBM System 34 (MFM) formats
- DMA data transfer capability
- Supports interrupt-driven or polled operation
- Bipolar PROM Base Address decoding
- Switches or jumpers for
- Bank Selection to one or two banks
- Double or Single sided operation
- Select or deselect ROM
- Module disable
- On-board header configures $1 / O$ for $8^{\prime \prime}$ or $51^{\prime \prime}$ drive interface
- On-board Program ROM containing disk utility and file management functions
- Fully assembled, tested and warranted.


## ORDERING INFORMATION

The Floppy Disk Controller Module is available in an Edge Connector version (RM65-5101) and a Eurocard version (RM655101E).

(C) Rockwell International Corporation 1981

All Rights Reserved
Printed in U.S.A.

Specifications subject to
change without notice
Document No. RMA65 N15 March 1981

## FUNCTIONAL DESCRIPTION

The Data Transceivers invert and transfer 8-bits of parallel data between the FDC module and the RM 65 bus, based on control signals from the Base Address Decoder and the Control Buffers. The read/write control line determines the direction, while the bus active enables the Data Transceivers.

The Address Buffers invert and transfer 12 of the 16 parallel address lines from the RM 65 bus to the Base Address Decoder, the Program ROM and the Floppy Disk Controller (FDC) device.

The Control Buffers invert and transfer phase 2 clock, reset, and read/ write control signals from the RM 65 bus onto the module.

The Bank Select Control circuit detects when the module's assigned memory bank is addressed by comparing the bank address signal from the RM 65 bus to the Bank Select and Bank Select Enable switches. The Bank Select Enable switch assigns the module to be active in common memory (both Bank 0 and Bank 1) or only in the Bank set by the Bank Select switch (either Bank 0 or Bank 1).

The Interrupt and DMA Control circuit enables operation in either an interrupt driven mode or under DMA control. Both Interrupt generation and DMA requests can be disabled under program control. The DMA request is jumper selectable for either of two DMA request lines connected to the RM 65 bus.

The Base Address Decoder, with the Base Address Select PROM, the Bank Select Control circuit, the ROM Disable switch, and the phase 2 and read/write signals control device selection on the module. The Base Address Select PROM compares the eight most significant address lines to the programmed addresses to generate device select signals to the Program ROM and the I/O devices. The ROM Disable switch assigns the module to be active either in a 256 byte page (disabled) or in a 4 K byte block (enabled). A separate Module Disable switch allows the entire module to be disabled.

When the ROM is disabled, only the.1/O devices are active, in the 256 byte page that matches all eight Base Address Select bits. For the I/O devices, the three least significant address lines, along with the phase 2 clock and read/write control signals, drive register select lines to the FDC device, and device select lines to the Drive Status Buffer and Drive Control Register.

When the ROM is enabled, the module is active in the 4 K byte block that matches the four most significant Base Address select bits. The program ROM is selected except when the address matches the four least significant Base Address Select bits, in which case the I/O device select lines are selected.

The Controller Clock derives a reference frequency for the FDC device from a crystal controlled oscillator. The frequency is 1 MHz or 2 MHz , depending on the Drive Configuration Header position.

The FDC device, in conjunction with the Data Separator and Precompensation Circuitry, interfaces the RM 65 bus to the, Floppy Disk
medium. The circuitry supports $51^{\prime \prime}$ or $8^{\prime \prime}$, single or double sided disk drives, with choice of single or double density, soft sector formats. The FDC features powerful commands, including single or multiple record read/write with selectable record lengths. Write precompensation circuitry ensures reliable data recovery in double density formats. The Precompensation jumper selects precompensation on all tracks, only on tracks 44 and greater, or no precompensation at all.

The Drive Configuration header selects the $1 / O$ connector and FDC circuitry for either $5 \frac{1}{4}$ " mini-floppy or $8^{\prime \prime}$ standard floppy disk formats. The 50 -pin 1/O receptacle connects the FDC module to a mass terminated cable connected to the installed disk drives. A 34 -pin cable and mating connector can be used to connect the $5 \%^{\prime \prime}$ mini-floppy drives while a 50 -pin cable and mating connector is needed to connect to the 8 " floppy drives.

The Drive Status Buffer allows detection of the Drive Configuration header and Single/Double Sided Drive jumper positions, as well as selected density and side information.

The Drive Control Register provides control of the side and drive selection, motor on, head load, double density, and interrupt disable. The Active Side 0 Level jumper allows the use of various drives without modification.

The Ready State Generator provides wait states as required by the FDC device.

The Program ROM contains the firmware to support operations with up to four disk drives (single or double side, single or double density), including:

Format a Disk
Read or Write a Sector
Seek or Verify Seek of a Track
Re-zero the Head
Read or Write Multiple Sectors
Read or Write a Track
Turn Motor On or Off
Select or De-select any Drive
Read I.D.
Reset

Included file management routines support up to 44 files on any disk side, independent of the disk size or density. These routines include:

Initialize or List a Directory
Create, Delete, or Rename a File Name
Open, Close, or Purge a File
Read from or Write to a File
Write a Modified Sector
Copy File
Copy Disk


Floppy Disk Controller Module Block Diagram

I/O Connector Pin Assignments

| FDC Module I/O Connector Pin | Standard Floppy Disk Drive Interface Cable Connector |  | Mini-Floppy Disk Drive Interface Cable Connector (2) |  |
| :---: | :---: | :---: | :---: | :---: |
|  | Pin | Signal Name | Pin | Signal Name |
| 2 | 2 | Track $>43$ (Remex \& MFE or equivalents) |  |  |
| 4 | 4 | N.C. |  |  |
| 6 | 6 | N.C. |  |  |
| 8 | 8 | Track $>43$ (Caldisk or equivalents) |  |  |
| 10 | 10 | N.C. |  |  |
| 12 | 12 | N.C. |  |  |
| 14 | 14 | 2nd Side Select |  |  |
| 16 | 16 | N.C. |  |  |
| 18 | 18 | Head Load | 2 | N.C. |
| 20 | 20 | Index | 4 | N.C. |
| 22 | 22 | Drive Ready | 6 | Drive Select \#4 |
| 24 | 24 | N.C. | 8 | Index |
| 26 | 26 | Drive Select \#1 | 10 | Drive Select \#1 |
| 28 | 28 | Drive Select \#2 | 12 | Drive Select \#2 |
| 30 | 30 | Drive Select \#3 | 14 | Drive Select \#3 |
| 32 | 32 | Drive Select \#4 | 16 | Motor On |
| 34 | 34 | Direction In | 18 | Direction In |
| 36 | 36 | Step Pulse | 20 | Step Pulse |
| 38 | 38 | Write Data | 22 | Write Data |
| 40 | 40 | Write Gate | 24 | Write Gate |
| 42 | 42 | Track Zero | 26 | Track Zero |
| 44 | 44 | Write Protected | 28 | Write Protected |
| 46 | 46 | Read Data | 30 | Read Data |
| 48 | 48 | N.C. | 32 | 2nd Side Select |
| 50 | 50 | N.C. | 34 | N.C. |

## NOTES:

1. All odd numbered pins are GND
2. Pin 1 of the 34 -pin mini-floppy disk drive interface cable connector should be keyed to pin 17 of the FDC module I/O connector.

| RM 65 Bus Pin Assignments |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| Signal <br> Mnemonic | Signal Name | Pin | Pin | Signal Mnemonic | Signal Name |
| $+5 \mathrm{~V}$ <br> GND <br> BADR/ <br> GND <br> BA13/ <br> BA11/ <br> BA10/ <br> BA8/ <br> GND <br> BA5/ <br> BA3/ <br> BA2 1 <br> BAO/ <br> GND <br> BSO <br> BRDY <br> $+12 \mathrm{~V} /+\mathrm{V}$ <br> GND <br> BDMT/ <br> $B R / W /$ <br> GND <br> BIRQ/ <br> Bø2I <br> Bø2 <br> BD7/ <br> GND <br> BD4/ <br> BD2l <br> BD1/ <br> $+5 \mathrm{~V}$ <br> $+5 \mathrm{~V}$ | Not Connected (See Note) <br> +5 Vdc Line (See Note) <br> Ground <br> Buffered Bank Address <br> Ground <br> Buffered Address Bit 13 <br> Buffered Address Bit 11 <br> Buffered Address Bit 10 <br> Buffered Address Bit 8 <br> Ground <br> Buffered Address Bit 5 <br> Buffered Address Bit 3 <br> Buffered Address 8it 2 <br> Buffered Address Bit 0 <br> Ground <br> *Buffered Set Overflow <br> Buffered Ready <br> * User Spare 1 <br> $+12 \mathrm{Vdc}$ <br> Ground Line <br> * Buffered DMA Terminate <br> * User Spare 3 <br> Buffered Read/Write "Not" <br> * System Spare <br> Ground <br> Buffered Interrupt Request <br> Buffered Phase 2 "Not" Clock <br> *Buffered Phase 2 Clock <br> Buffered Data Bit 7 <br> Ground <br> Buffered Data Bit 4 <br> Buffered Data Bit 2 <br> Buffered Data Bit 1 <br> $+5 \mathrm{Vdc}$ <br> +5 Vdc (See Note) <br> Not Connected (See Note) |  |  | $+5 \mathrm{~V}$ <br> $+5 \mathrm{~V}$ <br> 8A15/ <br> BA14/ <br> BA12/ <br> GND <br> BA9/ <br> BA7/ <br> BA6/ <br> BA4/ <br> GND <br> BA1/ <br> Bø1 <br> BSYNC <br> BDRQ1/ <br> GND <br> -12V/.V <br> BFLT/ <br> Bбо <br> GND <br> BDRO2/ <br> $B R / W$ <br> BACT/ <br> BNMI/ <br> GND <br> BRES/ <br> BD6/ <br> BD5/ <br> BD3/ <br> GND <br> BDO/ <br> GND <br> $+5 \mathrm{~V}$ | Not Connected (See Note) <br> +5 Vdc (See Note) <br> $+5 \mathrm{Vdc}$ <br> Buffered Address Bit 15 <br> Buffered Address Bit 14 <br> Buffered Address Bit 12 <br> Ground <br> Buffered Address Bit 9 <br> Buffered Address Bit 7 <br> Buffered Address Bit 6 <br> Buffered Address Bit 4 <br> Ground <br> Buffered Address Bit 1 <br> *Buffered Pinase 1 Clock <br> *Buffered Sync <br> Buffered DMA Request 1 <br> Ground <br> *. $12 \mathrm{Vdc} /-\mathrm{V}$ <br> * User Spare 2 <br> * Buffered Bus Float <br> *Buffered External Phase 0 Clock <br> Ground <br> Buffered DMA Request 2 <br> * Buffered Read/Write <br> Buffered Bus Active <br> *Buffered Non-Maskable Interrupt <br> Ground <br> Buffered Reset <br> Buffered Data Bit 6 <br> Buffered Data Bit 5 <br> Buffered Data Bit 3 <br> Ground <br> Buffered Data Bit 0 <br> Ground <br> $+5 \mathrm{Vdc}($ See Note) <br> Not Connected (See Note) |
| NOTE <br> Pins Wa, Wc, $\mathrm{Xa}, \mathrm{Xc}, \mathrm{Ya}, \mathrm{Yc}, \mathrm{Za}$ and Zc are not used on Eurocard version. <br> *Not used on this module |  |  |  |  |  |

Floppy Disk Controller (FDC) Module Physical and Electrical Characteristics

| Characteristic | Value |  |
| :---: | :---: | :---: |
| Physical Characteristics (See Notes) | Edge Connector | Eurocard |
| Width | 3.9 in . ( 100 mm ) | $3.9 \mathrm{in}.(100 \mathrm{~mm})$ |
| Length | $6.5 \mathrm{in} .(164 \mathrm{~mm})$ | $6.3 \mathrm{in}.(160 \mathrm{~mm})$ |
| Height | 0.56 in . $(14 \mathrm{~mm})$ | 0.56 in . (14 mm) |
| Weight | 4.8 oz . (135 g) | 5.2 oz. (145 g) |
| Environment |  |  |
| Operating Temperature | $\begin{aligned} & 0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ <br> $0 \%$ to $85 \%$ (Without condensation) |  |
| Storage Temperature |  |  |
| Relative Humidity |  |  |
| Power Requirements | $\begin{array}{r} +5 \mathrm{Vdc} \pm 5 \% @ 600 \mathrm{~mA} \text { - Typical } \\ 900 \mathrm{~mA} \text { - Maximum } \end{array}$ |  |
|  | $+12 \mathrm{Vdc} \pm 5 \%$ @ 60 mA - Typical 100 mA - Maximum |  |
| RM 65 Bus interface |  |  |
| Edge Connector Version | 72-pin edge connector ( 0.100 in . centers) |  |
| Eurocard Version | 64 -pin plug ( 0.100 in . centers) per DIN 41612 (Row b not installed) |  |
| I/O Interface | 50 -pin mass terminated connector ( 0.100 in. centers) Mates with I\&B/Ansley Part No. 609-5001M or equivalent |  |

## NOTES:

1. The height includes the maximum values for component height above the board surface ( 0.4 in . for populated modules), printed circuit board thickness ( 0.062 in ).), and pin extension through the bottom of the module ( 0.1 in .).
2. The length does not include the added extension due to the module ejector.
3. The Eurocard dimensions conform to DIN 41612.


Module Dimensions

## RM 65 DATA SHEET

## ASYNCHRONOUS COMMUNICATIONS INTERFACE ADAPTER (ACIA) MODULE

RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state-of-the-art performance, compact size, modular design and low cost. Software for RM 65 systems can be developed in R6500 Assembly Language, PL/65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot. The 64 -line RM 65 Bus offers memory addressing up to 128 K bytes, high immunity to electrical noise and includes growth provisions for user functions. A selection of card cages provides packaging flexibility. RM 65 products may also be used with Rockwell's AIM 65 Microcomputer for product development and for a broad variety of portabie or desktop microcomputer applications.

## ORDERING INFORMATION

The ACIA. Module is available in an Edge Connector version (RM65-5451) and a Eurocard version (RM65-5451E).

## FEATURES

- Compact size - Approximately $4^{\prime \prime} \times 61^{\prime \prime \prime} \cdot(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Buffered address, data and control lines
- Two-independent channels
- On-board 1.8432 MHz crystal frequency reference
- Programmable baud rate selection of 15 different rates (50, 75, $109.92,134.58,150,300,600,1200,1800,2400,3600$, 4800, 7200, 9600, or 19,200 bits per second)
- Programmable control of:
- Word length (5, 6, 7 or 8 bits)
- Number of stop bits (1, 11/2, 2)
- Parity (odd, even or none)
- Address select switch allows the starting address of the serial channel I/O to be assigned to a page boundary.
- On-board DC/DC Converter allows +5V only operation for RS-232 interface.


## PRODUCT OVERVIEW

The Asynchronous Communications Interface Adapter (ACIA) Module interfaces two independent, asynchronous serial 1/O channels to the RM 65 Bus. Each channel may operate as a data terminal or a data set, as selected by jumpers on the module. Both RS-232C and 20 ma TTY current loop interfaces are provided on Channel No: 1. An RS-232C interface is provided on Channel No. 2.

Each 1/O channel performs serial-to-parallel and paraltel-toserial data conversons using an R6551 Asynchronous Communication Interface Adapter (ACIA). Both receiver and transmitter may operate with a programmable word length of 5, 6, 7, or 8 bits. Further, each channel can transmit and receive at 15 different program-selectable rates, between 50 and 19,200 baud. The receive rate is the same as the transmit rate.


Eurocard Version
RM65-5451E


Edge Connector Version RM65-5451

Specifications subject to
change without notice
Document No. RMAES NOS
Rev. 1, Merch 1881

## FUNCTIONAL DESCRIPTION

The Data Transceivers invert and transfer 8-bits of parallel data between the R6551 ACIA devices and the RM 65 Bus depending on the state of the transceiver enable and read/write signals. During a write operation, the data received from the bus are written into the addressed ACIA device. During a read operation, the data read from the addressed ACIA device are driven onto the bus. When the ACIA module is not addressed, the transceivers are disabled.

The Address Buffers invert and transfer the three least significant address lines to the ACIA devices. Two lines generate the register address while one line selects one of the two ACIA devices

The Control Buffers invert and drive the bank address, clock and read/ write signals from the bus onto the module and drive the bus active and interrupt request lines onto the bus.

The ACIA module may be assigned to common banks (both Bank 0 and Bank 1) or to a dedicated bank (either Bank 0 or Bank 1), depending on the Bank Select and Bank Select Enable switch positions. The Bank Select Control circuit detects when the ACIA module is bankaddressed, by comparing the bank address control signal from the RM 65 Bus with the Bank Select switch position. If a match occurs and the Bank Select Enable switch is on, base address decoding is enabled.

The Base Address Buffer/Comparator buffers the eight most significant address lines from the bus and compares them to the Base Address Select switches. When a match occurs, the ACIA module is enabled.

Two R6551 ACIA devices convert data from serial-to-parallel format for input to the RM 65 Bus and from paralle1-to-serial format for output from the bus. Each ACIA device contains a programmable control register to allow baud rate, word length and the number of stop bits to be programmed. A command register allows ACIA interrupt and parity modes to be specified under program control. A status register may be interrogated to determine the status of the data transfer and the cause for an interrupt request.

The RS-232 Interface circuit contains line receivers and line drivers, to convert signals from internal TTL levels to external RS-232C levels. Jumpers are provided to specify Data Set or Data Terminal operation. Jumpers are also provided to simulate RS-232 control signals that are not available from the interfacing equipment.

Opto-couplers in the TTY Interface circuit provide 20 ma current loop sourcing and sinking between the ACIA module and an external TTY.

A 1.8432 MHz crystal generates the data transmission frequency reference, which the ACIA devices convert to the desired baud rate under program control.

The DC/DC Converter generates $\pm 12 \mathrm{Vdc}$ from +5 Vdc for RS-232 operation.

## Power Source for TTY Operation

For TTY operation, the $\pm 12 \mathrm{Vdc}$ must be obtained from the RM 65 Bus, by removing the DC/DC voltage converter and installing two jumpers.


ACIA Module Block Diagram

| RM 65 Bus Pin Assignments |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bottom (Solder Sida) |  |  |  | Top (Component Side) |  |  |  |
| Signal Mnemonic | Signal Name | Input/ <br> Output | Pin | Pin | Signal Mnemonic | Signal Name | Input Output |
|  | Not Connected (See Note) |  | Wa | Wc |  | Not Connected (See Note) |  |
| +5V | +5 Vodc Line (See Note) |  | Xa | Xc | $+5 \mathrm{~V}$ | +5 Vdc (See Note) |  |
| GND | Ground |  | 1a | 1 c | +5V | +5 Vdc |  |
| BADR/ | Buffered Bank Address | 1 | 2a | 2 c | BA15/ | Buffered Address Bit 15 | 1 |
| GND | Ground |  | 3a | 3 c | BA14/ | Buffered Address Bit 14 | 1 |
| BA13/ | Buffered Address Bit 13 | 1 | 4a | 4 c | BA12/ | Buffered Address Bit 12 | 1 |
| BA11/ | Buffered Address Bit 11 | 1 | 5 a | 5 c | GND | Ground |  |
| BA10/ | Buffered Address Bit 10 | 1 | 6 a | 6 c | BA9/ | Buffered Address Bit 9 | 1 |
| BAB/ | Buffered Address Bit 8 | 1 | 7a | 7 c | BA7/ | *Buffered Address Bit 7 |  |
| GND | Ground |  | 8 a | 8 c | BA6/ | -Buffered Address Bit 6 |  |
| BA5/ | *Buffered Address Bit 5 |  | 9a | 9 c | BA4/ | -Buffered Address Bit 4 |  |
| BA3/ | *Buffered Address Bit 3 |  | 10a | 10c | GND | Ground |  |
| BA2I | Buffered Address Bit 2 | 1 | 11a | 11c | BAI/ | Buffered Address Bit 1 | 1 |
| BAO/ | Buffered Address Bit 0 | 1 | 12a | 12c | B $\chi_{1}$ | -Buffered Phase 1 Clock |  |
| GND | Ground |  | 13a | 13c | BSYNC | *Buffered Sync |  |
| BSO | *Buffered Set Overflow |  | 14a | 14c | BDRQ1/ | Buffered DMA Request 1 |  |
| BRDY | -Buffered Ready |  | 15a | 15c | GND | Ground |  |
|  | - User Spare 1 |  | 16a | 16c | -12V/-V | -12 Vde/-V |  |
| $+12 \mathrm{~V} /+\mathrm{V}$ | +12 Vdc/+V |  | 17a | 17c |  | - User Spare 2 |  |
| GND | Ground Line |  | 18a | 18c | BFLT/ | -Buffered Bus Float |  |
| BDMT/ | - Buffered DMA Terminate |  | 19a | 19c | Bф0 | *Buffered External Phase 0 Clock |  |
|  | - User Spare 3 |  | 20a | 20 c | GND | Ground |  |
| BR/WI | Buffered Read/Write 'Not" | 1 | 21a | 21c | BDRQ2/ | -Buffered DMA Request 2 |  |
|  | -Systern Spare |  | 22a | 22c | $B R / \bar{W}$ | -Buffered Read/Write |  |
| GND | Ground |  | 23a | 23c | BACT/ | Buffered Bus Active | 0 |
| BIRQ/ | Buffered Interrupt Request | 0 | 24a | 24c | BNMI/ | -Buffered Non-Maskable Interrupt |  |
| B $\mathrm{C}_{21}$ | Buffered Phase 2 "Not" Clock | 1 | 25a | 25c | GND | Ground |  |
| Bø2 | - Buffered Phase 2 Clock |  | 26a | 26c | BRES/ | Buffered Reset | 1 |
| B07/ | Buffered Data Bit 7 | 1/0 | 27a | 27c | BD6/ | Buffered Data Bit 6 | 1/0 |
| GND | Ground |  | 28a | 28c | BD5/ | Buffered Data Bit 5 | 1/0 |
| BD4/ | Buffered Data Bit 4 | 1/0 | 29a | 29c | BD3/ | Buffered Data Bit 3 | 1/0 |
| BD2/ | Buffered Data Bit 2 | 1/0 | 30a | 30 c | GND | Ground |  |
| BD1/ | Buffered Data Bit 1 | 1/0 | 31a | 31c | BDO/ | Buffered Data Bit 0 | 1/0 |
| +5V | +5 Vdc |  | 32a | 32c | GND | Ground |  |
| $+5 \mathrm{~V}$ | +5 Vdc (See Note) |  | Ya | Yc | +5V | +5 Vdc (See Note) |  |
|  | Not Connected (See Note) |  | Za | Zc |  | Not Connected (See Note) |  |
| NOTE <br> Pins Wa, Wc, $X_{a}, X_{c}, Y_{a}, Y_{c}, Z_{a}, Z_{c}$ are not used on the Eurocard version. <br> - Not used on this module. |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |

I/O Connector J1 - TTY Interface

| Pin | Signal <br> Mnemonic | Signal Neme |  |
| :---: | :---: | :---: | :---: |
| 1 | RTS | Request-To-Send | 0 |
| 2 | TD | Transmit Data | 0 |
| 3 | RD | Receive Data | 1 |
| 4 | $-12 V$ | -12 Vdc | 1 |

I/O Connector J2 and J3 - RS-232 Interface

| Pin | Signal Mnemonic | Signal Name | Input/Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | Data Sot | Data Terminal |
| 1 | GND | Ground |  |  |
| 2 | $\overline{T D}$ | Transmit Data | 1 | $\bigcirc$ |
| 3 | RD | Receive Data | 0 | - |
| 4 | RTS | Request-To-Send | , | - |
| 5 | CTS | Clear-To-Send | 0 | 1 |
| 6 | DSR | Data-Set-Ready | 0 | 1 |
| 8 | DCD | Ground ${ }^{\text {Data-Carrier-Detected }}$ |  |  |
| 9.19 |  | Not Used | 0 | 1 |
| $\begin{aligned} & 20 \\ & 21.26 \end{aligned}$ | DTR | Data-Terminal-Ready Not Used | 1 | $\bigcirc$ |

ACIA Module Physical and Electrical Characteristics

| : Characteristics | Value |  |
| :---: | :---: | :---: |
| Physical Characteristics (See Notes): |  |  |
| Width |  |  |
| Length |  |  |
| Height |  |  |
| Weight |  |  |
| Environment |  |  |
| Operating Temperature |  |  |
| Storage Temperature |  |  |
| Relative Humidity |  |  |
| Power Requirements |  |  |
| RS-232 Interface Operation, |  |  |
| with DC/DC Converter |  |  |
| TTY Operation, without DC/DC |  |  |
| Converter |  |  |
|  |  |  |
| RM 65 Bus Interface |  |  |
| Edge Connector Version |  |  |
| Eurocard Version |  |  |
|  |  |  |
| 1/O Interface |  |  |
| RS-232 |  |  |
| TTY |  |  |

NOTES:

1. The height includes the maximum values for component height above the board surface 10.4 in. for populated modules), printed circuit board thickness $(0.062 \mathrm{in}$.$) , and pin extension through the bottom of the module (0.1 \mathrm{in}$.
2. The length does not include extensions beyond the edge of the module due to connectors or the module ejector.
3. The Eurocard dimensions conform to DIN 41612.


# RM 65 DATA SHEET 

## GENERAL PURPOSE INPUT/OUTPUT \& TIMER (GPIO \& TIMER) MODULE

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state-of-the-art performance, compact size, modular design and low cost. Software for RM 65 systems can be developed in R6500 Assembly Language, PL/65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot. The 64 -line RM 65 Bus offers memory addressing up to 128 K bytes, high immunity to electrical noise and includes growth provisions for user functions. A selection of card cages provides packaging flexibility. RM 65 products may also be used with Rockwell's AIM 65 Microcomputer for product development and for a broad variety of portable or desktop microcomputer applications.

## PRODUCT OVERVIEW

The RM 65 GPIO \& Timer Module provides a parallel I/O interface to the RM 65 Bus. Two R6522 Versatile Interface Adapter (VIA) devices provide four 8 -bit bidirectional data ports and four 2 -bit control ports; 40 1/O lines in all. Two multi-mode 16 -bit timer/ counters extend the versatility of the module. All I/O lines are TTL buffered.

The GPIO \& Timer Module I/O can be assigned either to one of two 65K byte memory banks or common to both banks. Eight
switches allow $1 / O$ addresses to be set to any page ( 256 bytes). Eight switches (two per I/O port) manually set the I/O transceiver data direction or allow software control using the associated port control lines. Twelve jumpers specify the direction of the control lines.

## ORDERING INFORMATION

The GPIO \& Timer Module is available in an Edge Connector version (RM65-5222) and a Eurocard version (RM-5222E).

## FEATURES

- Compact size - about $4^{\prime \prime} \times 61^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Edge connector or Eurocard version
- RM 65 Bus compatible
- Fully buffered address, data and control bus interface lines
- Fully buffered data and control I/O lines
- Four 8-bit parallel bidirectional data ports
- Four 2-bit control ports
- Four programmable 16 -bit counter/timers
- Two 8-bit shift registers for synchronous serial communications
- Manually or software-controlled data line direction
- Jumper-selectable control line direction
- Bank select switches assign I/O addresses to one or two 65K banks
- I/O base address switch selectable to a page boundary
- Four I/O connectors
- 45 V operation


## Eurocard Version

RM65-5222E

- Fully assembled, tested and warranted


Printed in U.S.A.

Specifications subject to
chenge without notice
Document Mo. RMAGE N12
Rav. 1, merch 1981

## FUNCTIONAL DESCRIPTION

The heart of the GPIO \& Timer module is two R6522 Versatile Interface Adapter (VIA) devices. Each VIA provides two 8 -bit bidirectional input/output ports, four I/O control lines, two fully programmable 16 -bit timer/counters and an 8 -bit shift register for serial interface. There is also control of interrupt generation from independent I/O conditions.

The two 8 -bit input/output peripheral ports are fully bidirectional. Data direction registers allow each peripheral pin to independently act as either an input or an output. The four control lines can also be used for I/O or can provide handshaking for the associated data ports. Each control input can be programmed to interrupt the microprocessor on detection of a rising or falling edge.

The two 16 -bit counter/timers are capable of many complex timing and counting functions. One timer provides four modes of operation: free running, with pulsed or toggled output, one-shot interval timer with a low-level output on a peripheral port line, or one-shot interval timer with a toggle output on a peripheral port line. The three modes of the second $\mathbf{1 6}$-bit timer provide a one-shot interval timer, a count of external pulses, or a clock for serial shift register. The shift register can shift in, or shift out, data at the system clock rate, the timer clock rate, or an external clock rate. Both timers and the shift register can be programmed to interrupt the microprocessor upon time-out or shift completion.

The Data Transceivers invert and buffer 8-bits of parallel data between the RM 65 Bus and the two R6522 VIA devices. The Data Transceivers are enabled when a valid address is present at the Base Address Decoders. During a read operation, data is transferred from the addressed R6522 to the RM 65 Bus. During a write operation, data is transferred from the RM 65 Bus to the addressed R6522.

The Address Buffers invert the five least significant address bits used to select the R6522 devices and registers.

The Bank Control circuit detects when the GPIO \& Timer Module's assigned memory bank is addressed by comparing the bank address signal from the RM 65 Bus to the Bank Select Enable and Bank Select switches. The Bank Select Enable switch allows the module to be assigned common to either both banks, or to Bank 0 (lower 65K) or Bank 1 (upper 65K) depending on the Bank Select switch.

The Control Buffers drive read/write, phase 2 clock, and reset signals from the RM 65 Bus to the GPIO \& Timer Module. The interrupt request and bus active signals are driven from the GPIO \& Timer Module.

The Base Address Decoders use the eight most significant address lines to assign the 32 I/O addresses to a page ( 256 bytes) boundary. When an address is within range of the Base Address switches and the Bank Control is enabled, a chip select is generated to one of the $\mathbf{R 6 5 2 2}$ devices.

Twelve Control Direction Jumpers allow the three bidirectional control lines (CA1, CB1, and CB2) on each R6522 to be configured for either input or output mode.

Four I/O Direction Switches provide dilection control to each of the Port I/O transceivers. Four Programmed/Manual Select switches allow the direction control to be established from the Direction Control switches in the Manual mode or from a R6522 control line in the Programmed mode.

The I/O Transceivers buffer each of four 8-bit I/O ports. The direction is determined by the Direction Contrcl logic. There are also eight buffers provided for the control lines ( 2 per I/O port), six of which can be configured for input or output as determined by the Handshake Direction Buffers.


GPIO \& Timer Module Block Diagram


All I/O data and control signals are brought out to four connectors that will each accept a 20 -pin mass terminated ribbon cable \{cable and mass terminated connectors are not supplied with the GPIO \& Timer Module). Each connector is dedicated to one port with 8 data, 2 control and 10 ground lines.


GPIO \& Timer Module Physical and Electrical Characteristics

| Characteristic | Value |  |
| :---: | :---: | :---: |
| Physical characteristics (See Notes) |  |  |
| Width |  |  |
| Length |  |  |
| Height |  |  |
| Weight |  |  |
| Environment |  |  |
| Operating Temperature |  |  |
| Storage Temperature |  |  |
| Relative Humidity |  |  |
| Power Requirements |  |  |
|  |  |  |
| RM 65 Bus Interface |  |  |
| Edge Connector Version |  |  |
| Eurocard Version |  |  |
| 1/O Interface |  |  |
| I/O Connectors (4) |  |  |

## NOTES:

1. The height includes the maximum values for component height above the board surface ( 0.4 in . for populated modules), printed circuit board thickness ( 0.062 in .), and pin extension through the bottom of the module ( 0.1 in. ).
2. The length does not include extensions beyond the edge of the module due to connectors or the module ejector.
3. The Eurocard dimensions conform to DIN 41612.
4. The module dimensions are referenced to:


Module Dimensions

## RM 65 DATA SHEET

## IEEE-488 BUS INTERFACE MODULE

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state-of-the-art performance; compact size, modular design and low cost. Software for RM 65 systems can be developed in R6500 Assembly Language, PL/65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot. The 64 -line RM 65 Bus offers memory addressing up to 128 K bytes, high immunity to electrical noise and includes growth provisions for user functions. A selection of card cages provides packaging flexibility. RM 65 products may also be used with Rockwell's AIM 65 Microcomputer for product development and for a broad variety of portable or desktop microcomputer applications.

## PRODUCT OVERVIEW

The RM 65 JEEE-488 Bus Interface Module connects an AIM 65 or RM 65 SBC based system to the IEEE-488 General Purpose Interface Bus (GPIB). Complete controller, talker and listener functions, as defined in the IEEE-488, 1978 Standard, are implemented. The module also supports extended addressing and multiple bus controllers. On-board ROM firmware implements all 12 functions specified by the interface standard. Features not defined in the standard, but also supported, include manual talk or listen disable, dual primary addressing, and an external trigger line. Switches select the Device Talk/Listen Address, Enable Dual Primary Addressing Mode, Disable Talk, Disable Listen, and Sys tem Controller mode. The bus interface transceivers meet the electrical specifications of the IEEE-488 interface standard. An 8 -inch ribbon cable mates the IEEE-488 module to the IEEE-488 bus with a standard 24 -pin connector.

Standard RM 65 features include switches to dedicate the module to one of two 65 K byte memory banks, or to assign it common to both banks. A jumper allows the on-board ROM to be enabled or disabled. Base address select switches allow the module I/O address to be assigned to any page ( 256 bytes) if the ROM is disabled.

## ORDERING INFORMATION

The IEEE-488 Bus Interface Module is available in an Edge Connector version (RM65-7102) and a Eurocard version (RM65. 7102E).

## FEATURES

- Compact size - about $4^{\prime \prime} \times 612^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Edge Connector and Eurocard versions
- RM 65 Bus compatible
- Buffered address, data and control lines
- Listen, talk, and controller functions
- IEEE-488, 1978 standard fully implemented
- Uses TI 9914 GPIB Adapter device
- On-board ROM contains bus protocol and utility firmware
- Switches for
- Device Talk/Listen Address
- Disable Talk
- Disable Listen
- Enable Dual Primary Addressing mode
- System Controller
- Base Address to page boundary for 1/O
- Bank Selection to one or both 65K banks
- Jumper for ROM enable/disable
- LEDs show current address register coñtents
- Supports DMA data transfers
- +5 V operation
- Fully assembled, tested and warranted


[^2]
## FUNCTIONAL DESCRIPTION

The Data Transceivers invert and transfer 8 -bits of parallel data between the IEEE-488 Bus Interface Module and the RM 65 bus, based on data direction signals from the Base Address Decoder.

The Address Buffers invert and transfer the 16 -bit parallel address lines from the RM 65 bus to the Base Address Decoders, to the R2332 ROM and to the GPIB Adapter.

The Control Buffers invert and transfer phase 2 clock, reset, and read/ write control signals from the RM 65 bus onto the module. The interrupt request is buffered and driven onto the RM 65 bus.

The Bank Select Control circuit detects when the module's assigned memory bank is addressed by comparing the bank address signal from the RM 65 bus to the Bank Select and Bank Select Enable switches. The Bank Select Enable switch allows the board to reside in common memory (both Bank 0 and Bank 1) or only in the Bank set by the Bank Select switch (either Bank 0 or Bank 1).

The DMA Control circuit allows DMA requests from the TI 9914 GPIB Adapter device to be driven on the RM 65 bus or disabled under program control. This line is jumper selectable for either of two DMA request lines on the RM 65 bus.

The Base Address Decoder compares the eight most significant address lines to the eight Base Address switches. The ROM Disable jumper allows the module to be active in a 4 K block when enabled or active in a page ( 256 locations) when disabled. When an address for the selected bank matches the four most significant switches and the ROM is enabled, the Data Transceivers are enabled and the bus active signal is generated. When this address also matches the four least significant switches the GPIB Adapter and I/O are selected. When there is no match on the four least significant switches, the ROM is selected. When the GPIB Adapter and I/O are selected, the four least significant address lines, phase 2 clocks, and read/write control lines are used to derive register selects for the GPIB Adapter, device selects for the GPIB Status Latch, GPIB Sense Buffers, System Controller Select, and

DMA Control Circuits. The read/write control lines also determine the direction for the Data Transceivers.

The TMS 9914 GPIB Adapter device provides hardware control of the 1EEE-488 bus interface, using firmware subroutines provided in ROM. All bus interface lines are buffered by the GPIB Data and Control Transceivers, to conform to the electrical specifications of the IEEE488 Standard. These lines are brought out through a cable to a standard IEEE-488 connector. An additional connector provides an external trigger output not defined by the IEEE 488 Standard.

The System Controller Select circuit allows manual selection of System Controller capabilities in multiple controller configurations.

The GPIB Sense Buffer allows the GPIB Sense Switches to be read for Device Talk/Listen Address, Talk or Listen Disable, and Dual Primary Address Mode selection. The GPIB Status Latch latches the positions of the GPIB Sense Switches and displays them on the GPIB Status Indicators. This allows a visual verification of the Device Talk/Listen Address and Operating modes.

## On-Board Program ROM Firmware

The Program ROM firmware completely supports all 12 Bus functions described in the IEEE-488, 1978 Standard, as well as features of the TMS 9914 GPIB Adapter device not defined in the Standard. These utility functions make both the Bus protocol and the GPIB Adapter device transparent to the programmer. The firmware, organized as subroutines, is linked to the user program through a jump table. Many of these routines are interrupt-driven, to minimize the processor time in servicing the module. User-alterable vectors and parameters are located in RAM, to allow custom applications. Output data or commands for the Bus are handled as tables, easing the set-up and transfer of information. Extensive error checking by the utility subroutines aliow resident or user-provided error handling routines to ensure proper operation of the module, the IEEE-488 Bus and status of data transfer. Two self-test routines verify proper module operation.


IEEE-488 Bus Interface Module Block Diagram

## External Trigger Pin Assignments

| Pin | Signal Mnemonic | Signal Name | Input/Output |
| :---: | :---: | :---: | :---: |
| 1 | TRIG | Trigger Out | O |
| 2 | GND | Ground |  |

IEEE-488 Bus Interface Connector Pin Assignments

| Pin | $\begin{array}{c}\text { Signal } \\ \text { Mnemonic }\end{array}$ | $\begin{array}{l}\text { Signal Name }\end{array}$ | $\begin{array}{c}\text { Input/ } \\ \text { Output }\end{array}$ | Pin | $\begin{array}{c}\text { Signal } \\ \text { Mnemonic }\end{array}$ | Signat Name |
| :---: | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Output |  |  |  |  |  |  |$]$


| RM 65 Bus Pin Assignments |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| Signal Mnemonic | Signal Name | Pin | Pin | Signal Mnemonic | Signal Name |
|  | Not Connected (See Note) | Wa | Wc |  | Not Connected (See Note) |
| +5V | +5 Vdc Line (See Note) | Xa | Xc | +5V | +5 Vdc (See Note) |
| GND | Ground | 1 a | 1 c | +5V | +5 Vdc |
| BADR/ | Buffered Bank Address | 2a | 2c | BA15/ | Buffered Address Bit 15 |
| GND | Ground | 3 a | 3 c | BA14/ | Buffered Address Bit 14 |
| BA13/ | Buffered Address Bit 13 | 4 a | 4 c | BA12/ | Buffered Address Bit 12 |
| BA11/ | Buffered Address Bit 11 | 5 a | 5 c | GND | Ground |
| 8 810/ | Buffered Address Bit 10 | 6 a | 6 c | BA91 | Buffered Address Bit 9 |
| BA8/ | Buffered Address Bit 8 | 7 a | 76 | BA7/ | Buffered Address Bit 7 |
| GND | Ground | 8 a | 8 c | BA6/ | Buffered Address Bit 6 |
| BA5/ | Buffered Address Bit 5 | 9 a | 9c | BA4/ | Buffered Address Bit 4 |
| BA3/ | Buffered Address Bit 3 | 10a | 10c | GND | Ground |
| BA2) | Butfered Address Bit 2 | 11 a | 11 c | BA1/ | Buffered Address Bit 1 |
| BAO/ | Buffered Address Bit 0 | 12a | 12c | B\$1 | - Buffered Phase 1 Clock |
| GND | Ground | 13a | 13c | BSYNC | - Buffered Sync |
| BSO | - Buffered Set Overflow | 14a | 14 c | BDRQ1/ | Buffered DMA Request 1 |
| BRDY | - Buffered Ready | 15a | 15c | GND | Ground |
|  | - User Spare 1 | 16a | 16c | . $12 \mathrm{~V} / \mathrm{V}$ | *. $12 \mathrm{Vdc} /-\mathrm{V}$ |
| +12V/+V | - $+12 \mathrm{Vdc} /+\mathrm{V}$ | 17a | 17c |  | - User Spare 2 |
| GND | Ground | 18a | 18 c | BFLT/ | - Buffered Bus Float |
| BDMT/ | - Buffered DMA Terminate | 19a | 19c | B\%o | - Buffered External Phase O Clock |
|  | - User Spare 3 | 20a | 20c | GND | Ground |
| BR/W/ | Buffered Read/Write "Not" | 21a | 21c | BDRQ2/ | Buffered DMA Request 2 |
|  | - System Spare | 22a | 22c | BR/W | Buffered Read/Write |
| GND | Ground | 23a | 23 c | BACT/ | Buifered Bus Active |
| BIRO/ | Bulfered Interrupt Request | 24a | 24c | BNMI/ | * Buffered Non-Maskable Interrupt |
| Bه2/ | Bulfered Phase 2 "Not" Clock | 25a | $25 c$ | GND | Ground |
| Bø2 | Buffered Phase 2 Clock | 26a | 26c | BRES/ | Buffered Reset |
| 807/ | Buffered Data Bit 7 | 27a | 27c | BD6/ | Butfered Data Bit 6 |
| GND | Ground | 28a | 28c | BD5/ | Buffered Data Bit 5 |
| BD4/ | Buffered Data Bit 4 | 29a | 29c | BD3/ | Buffered Data Bit 3 |
| BD2 1 | Butfered Data Bit 2 | 30a | 30c | GND | Ground |
| BD1/ | Buffered Data Bit 1 | 31a | 31 c | BDO/ | Bulfered Data Bit 0 |
| $+5 \mathrm{~V}$ | +5 Vdc | 32a | 32c | GND | Ground |
| $+5 \mathrm{~V}$ | +5 Vdc (See Note) | Ya | Yc | +5V | +5 Vdc (See Note) |
|  | Not Connected (See Note) | Za | Zc |  | Not Connected (See Note) |
| NOTE <br> Pins Wa, Wc, $X_{a}, X_{c}, Y_{a}, Y_{c}, Z_{a}$ and $Z c$ are not used on Eurocard version. <br> * Not used on this module. |  |  |  |  |  |
|  |  |  |  |  |  |

IEEE-488 Bus Interface Module Physical and Electrical Characteristics

| Characteristic | Value |
| :---: | :---: |
| Physical Characteristics (See Notes) <br> Width <br> Length <br> Height <br> Weight <br> Environment <br> Operating Temperature <br> Storage Temperature <br> Relative Humidity <br> Power Requirements <br> RM 65 Bus Interface <br> Edge Connector Version <br> Eurocard Version <br> Module <br> 1/O Interface <br> Cable Receptacle <br> Trigger Connector <br> IEEE-488 Bus Interface Cable <br> IEEE-488 Bus Connector <br> Modute Connector <br> Cable Length <br> Type <br> Number of Conductors <br> Wire Size |  |

NOTES:

1. The height includes the maximum values for component height above the board surface $\mathbf{0 . 4} \mathrm{in}$. for populated modules), printed circuit board thickness ( 0.062 in .) and pin extension through the bottom of the module $(0.1 \mathrm{in}$.).
2. The length does not include the added extension due to the module ejector
3. The Eurocard dimensions conform to DIN 41612.


## PART NUMBER RM65-3108(E)

RM 65
DATA SHEET

## 8K STATIC RAM MODULE

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state-of-the-art performance, compact size, modular design and low cost. Software for RM 65 systems can be developed in R6500 Assembly Language, PL/65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot. The 64 -line RM 65 Bus offers memory addressing up to 128 K bytes, high immunity to electrical noise and includes growth provisions for user functions. A selection of card cages provides packaging flexibility. RM 65 products may also be used with Rockwell's AIM 65 Microcomputer for product development and for a broad variety of portable or desktop microcomputer applications.

## ORDERING INFORMATION

The 8K Static RAM Module is available in an Edge Connector version (RM65-3108) and a Eurocard version (RM65-3108E). These modules may also be ordered without the RAM devices installed, as part numbers RM65-3108N and RM65-3108NE, respectively.

## FEATURES

- Compact size - about $4^{\prime \prime} \times 61^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Edge Connector and Eurocard versions
- RM 65 Bus compatible
- Buffered address, data and control lines
- Two separately addressable 4 K byte sections
- $\mathbf{1 6}$ socketed 2114 static RAM devices
- Write-protect switch for each memory section
- Bank Select and Enable switches
- +5 V operation
- Fully assembled, tested and warranted.


## PRODUCT OVERVIEW

The RM 658 K Static RAM Module contains 81928 -bit bytes of Random Access Memory (RAM), in sixteen 2114 static RAM devices. The memory is arranged as two separately addressable 4 K memory sections. The starting address of each 4 K section is, selectable by on-board address switches. A Bank Select switch allows the RAM module to be assigned to one of two 64 K memory banks.

[^3]
## FUNCTIONAL DESCRIPTION

8 K bytes of static 2114 RAM are divided into two separately address. able 4 K blocks. Two devices per 1 K bytes are required since each device is $1 \mathrm{~K} \times 4$ bits.

The Data Transceivers invert and transfer 8-bits of parallel data between the RAM devices and the RM 65 Bus, based on data direction signals from the Data Transceiver Control Circuit.

The Address Buffers invert and transfer 16 address bits from the RM 65 Bus to the RAM devices, to the Base Address Decoders and to the Chip Select Decoder.

The Control Buffers invert and transfer phase 2 clock and read/write control signals from the RM 65 Bus onto the RAM module, and drive the bus active signal onto the RM 65 Bus.

The Bank Select Controller detects when the RAM module's assigned memory bank is addressed, by comparing the bank address signal from the RM 65 Bus to the settings of the Bank Select and Bank Select Enable switches. If the addressed bank is the same as the selected memory bank, an enable signal is sent to the Chip Select Decoder.

Two Base Address Decoders detect when either 4 K RAM Section 11 or 2) is addressed, by comparing the address lines to Base Address Select switch settings. When a match occurs, an enable signal is sent to the Chip Select Decoder.

The Chip Select Decoder uses outputs from the Bank Select Controi circuit, the Base Address Decoders, and the PROM/ROM size jumpers as well as address lines A11 and A10 to generate one of eight chip select lines to the RAM devices. A signal indicating that a chip select line is active is also sent to the Write Control and Data Transceiver Control circuits.

The Write Control circuit generates the write enable signals to the RAM devices and to the Data Transceiver Control circuit. If the corresponding write protect switch is off, the write enable signal is activated. If the Write Protect switch is on, the Data Transceivers are disabled.

The Data Transceiver Control circuit determines whether a valid read or write operation is in progress, and provides transceiver enable and data direction signals to the Data Transceivers. The Data Transceivers are enabled if both the bank address and the address lines correspond to the selected bank and a selected base address, respectively.


8K Static RAM Module Block Diagram


8K Static RAM Module Physical and Electrical Characteristics


## NOTES:

1. The height includes the maximum values for component height above the board surface ( 0.4 in . for populated modules), printed circuit board thickness ( 0.062 in .), and pin extension through the bottom of the module ( 0.1 in .) .
2. The length does not include the added extension due to the module ejector.
3. The Eurocard dimensions conform to DIN 41612.


## RM 65 DATA SHEET

## 32K DYNAMIC RAM MODULE

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state－of－the－art performance，compact size，modular design and low cost． Software for RM 65 systems can be developed in R6500 Assembly Language，PL／65，BASIC and FORTH．Both BASIC and FORTH are available in ROM and can be incorporated into the user＇s system．

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot．The 64 －line RM 65 Bus offers memory addressing up to 128 K bytes，high immunity to electrical noise and includes growth pro－ visions for user functions．A selection of card cages provides packaging flexibility．RM 65 products may also be used with Rockwell＇s AIM 65 Microcomputer for product development and for a broad variety of portable or desktop microcomputer applications．

## PRODUCT OVERVIEW

The 32 K Dynamic RAM module provides 32 K bytes of read／write memory using 1616 K bit $\times 1$ dynamic RAM（DRAM）devices Two bank select switches allow the board to be dedicated to either one of two 65 K Banks，or to be assigned common to both banks．A 24 －pin DIP header allows each of the eight 4 K sections to be independently mapped into any 4 K block of the selected 65 K bank．The independent addressing of blocks provides flexi－ bility with system memory maps．An on－board switch allows the entire board to be write－protected．

All refreshing of the dynamic RAM chips is automatic and com－ pletely transparent to the RM 65 Bus，thus providing low power performance at no loss of bus speed．


Eurocard Version
RM65－3132E

## FEATURES

－Compact size－about $4^{\prime \prime} \times 61 / 4^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
－Edge connector or Eurocard Versions
－RM 65 bus compatible
－Buffered data，address，and control lines
－Internal Refresh controller is completely transparent to the Microflex 65 bus
－On－board switch allows write protection
－Base Address Header allows each 4 K memory section to be assigned to any 4 K block as a selected bank
－Bank select switches allow the entire board to be mapped into either or both 65 K banks
－On－board DC－DC converter for -5 volt power supply
－Requires +5 and +12 volt power from the RM 65 bus
－Fully assembled，tested，and warranted

## ORDERING INFORMATION

The 32 K Dynamic RAM is available in an Edge Connector ver－ sion（RM65－3132）and a Eurocard version（RM65－3132E）．These modules may also be ordered without the RAM devices installed， as part numbers RM65－3132N and RM65－3132NE，respectively．


## FUNCTIONAL DESCRIPTION

The Data Transceivers invert and transfer 8 -bit parallel data between the selected DRAMs to the RM 65 bus. During a read operation, data from the DRAMs are latched and driven by the transceivers onto the RM 65 bus. During a write operation, data from the RM 65 bus drives the DRAMs. The transceivers are disabled when the module is not addressed.

The Address Buffers invert and transfer 16 -bit parallel address lines from the RM 65 bus into the DRAM module.

The Bank Select Control circuit detects when the DRAM module's assigned memory bank is addressed by comparing the bank address signal from the RM 65 bus to the Bank Select and Bank Select Enable switches. The Bank Select Enable switch allows the board to reside in common memory (both Bank 0 and Bank 1) or only in the Bank set by the Bank Select switch (either Bank 0 or Bank 1).

The Control Buffers buffer the control and timing signals used from the RM 65 bus.

The DRAM devices require 3 voltages. Two of these ( +5 and +12 volts) are available directly from the RM 65 bus. The third voltage ( -5 volts) is generated on board with a DC/DC converter.

The Address Decoder uses the four MSB address lines to decode and enable one of 16 lines, each of which correspond to 4 K blocks. The Base Address Selection Jumpers are placed in a 28 pin socket which consists of 16 lines from the Address Decoder, four lines from +5 volts, and 8 lines to the Base Address Encoder. The Base Address Selection is made by connecting each of the eight encoder inputs to any one of the 16 decoder outputs or to +5 volts. This allows each 4 K block to
be addressed anywhere in the selected 65 K memory bank or disabled. The Base Address Encoder produces a 3 bit code for the enabled line and an additional signal for any line active (Board Select). The 3 bit code from the encoder becomes the 3 MSB address bits for the Memory Address Multiplexer. The Board Select line and a valid Bank Select signal are used to enable the Memory Controller and Data Transceivers, as well as create a Data Bus Active Signal.

The Write Control logic uses the Write Protect switch and the Read/ Write line to enable writing into the DRAMs. If the Write Protect switch is off, the Read/Write signal is transferred directly to the Memory Controller. If the Write Protect switch is on, the Memory Controller forces a read operation so that the contents of the DRAMs will not be altered.

The Timing Control generates all the clocks required by the Memory Controller, Memory Address Multiplexer, and the Refresh Clock. The Refresh Clock generates a refresh cycle for every seven RM 65 clock cycles.

The Memory Controller uses the clocks derived in the timing control to sequence the signals to the DRAM devices. During normal read or write cycles, the Memory Controller allows Row Address, then Column Address information to be applied to the addressed DRAMs and generates the read/write signal. When a refresh is required, the timing is controlled so that the refresh is transparent to the RM 65 bus.

The Memory Address Multiplexer and Refresh Counter multiplexes Row, Column, or Refresh Addresses onto the DRAM address lines in response to the Memory Controller. There is also a Refresh Counter which is incremented by the Refresh Clock.


32K Dynamic RAM Block Diagram

| RM 65 Bus Pin Assignments |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| Signal Mnemonic | Signal Name | Pin | Pin | Signal <br> Mnemonic | Signal Name |
| $+5 \mathrm{~V}$ <br> GND <br> BADR/ <br> GND <br> BA13/ <br> BA11/ <br> BA10/ <br> BA8/ <br> GND <br> BA5/ <br> BA3/ <br> BA2/ <br> BAO/ <br> GND <br> BSO <br> BRDY <br> $+12 \mathrm{~V} /+\mathrm{V}$ <br> GND <br> BDMT/ <br> BR/W/ <br> GND <br> BIRQ/ <br> Bø2/ <br> Bø2 <br> BD7/ <br> GND <br> BD4/ <br> BD2/ <br> BD1/ <br> $+5 \mathrm{~V}$ <br> $+5 \mathrm{~V}$ | Not Connected (See Note) <br> +5 Vdc Line (See Note) <br> Ground <br> Buffered Bank Address <br> Ground <br> Buffered Address Bit 13 <br> Buffered Address Bit 11 <br> Buffered Address Bit 10 <br> Buffered Address Bit 8 <br> Ground <br> Buffered Address Bit 5 <br> Buffered Address Bit 3 <br> Buffered Address Bit 2 <br> Buffered Address Bit 0 <br> Ground <br> *Buffered Set Overflow <br> * Buffered Ready <br> * User Spare 1 $+12 \mathrm{Vdc} /+\mathrm{V}$ <br> Ground Line <br> - Buffered DMA Terminate <br> - User Spare 3 <br> Buffered Read/Write "Not" <br> * System Spare <br> Ground <br> - Buffered Interrupt Request <br> Buffered Phase 2 "Not" Clock <br> *Buffered Phase 2 Clock <br> Buffered Data Bit 7 <br> Ground <br> Buffered Data Bit 4 <br> Buffered Data Bit 2 <br> Buffered Data Bit 1 <br> $+5 \mathrm{Vdc}$ <br> +5 Vdc (See Note) <br> Not Connected (See Note) |  |  | $+5 \mathrm{~V}$ <br> $+5 \mathrm{~V}$ <br> BA15/ <br> BA14/ <br> BA12/ <br> GND <br> BA9/ <br> BA7/ <br> BA6/ <br> BA4/ <br> GND <br> BA1/ <br> B $\emptyset 1$ <br> BSYNC <br> BDRQ1/ <br> GND <br> $-12 \mathrm{~V} /-\mathrm{V}$ <br> BFLT/ <br> B\%0 <br> GND <br> BDRQ2/ <br> $B R / W$ <br> BACT/ <br> BNMI/ <br> GND <br> BRES/ <br> BD6/ <br> BD5/ <br> BD3/ <br> GND <br> BDO/ <br> GND <br> $+5 \mathrm{~V}$ | Not Connected (See Note) <br> +5 Vdc (See Note) <br> $+5 \mathrm{Vdc}$ <br> Buffered Address Bit 15 <br> Buffered Address Bit 14 <br> Buffered Address Bit 12 <br> Ground <br> Buffered Address Bit 9 <br> Butfered Address Bit 7 <br> Buffered Address Bit 6 <br> Buffered Address Bit 4 <br> Ground <br> Buffered Address Bit 1 <br> * Buffered Phase 1 Clock <br> - Buffered Sync <br> *Buffered DMA Request 1 <br> Ground <br> - $12 \mathrm{Vdc} /-\mathrm{V}$ <br> - User Spare 2 <br> - Buffered Bus Fioat <br> -Buffered External Phase 0 Clock <br> Ground <br> *Buffered DMA Request 2 <br> Buffered Read/Write <br> Buffered Bus Active <br> *Buffered Non-Maskable Interrupt <br> Ground <br> - Buffered Reset <br> Buffered Data Bit 6 <br> Buffered Data Bit 5 <br> Buffered Data Bit 3 <br> Ground <br> Buffered Data Bit 0 <br> Ground <br> +5 Vdc (See Note) <br> Not Connected (See Note) |
| NOTE <br> Pins Wa, Wc, Xa, Xc, Ya, Yc, Za and Zc are not used on Eurocard version. <br> *Not used on this module |  |  |  |  |  |

32K Dynamic RAM Module Physical and Electrical Characteristics

| Characteristic | Value |  |
| :---: | :---: | :---: |
| Physical Characteristics (see note) | Edge Connector Version | Eurocard Version |
| Width | $3.9 \mathrm{in}$. ( 100 mm ) | 3.9 in . ( 100 mm ) |
| Length | $6.5 \mathrm{in} .(165 \mathrm{~mm})$ | $6.3 \mathrm{in} .(160 \mathrm{~mm})$ |
| Height | 0.56 in . ( 14 mm ) | $0.56 \mathrm{in} .(14 \mathrm{~mm})$ |
| Weight | $4.4 \mathrm{oz} .(125 \mathrm{~g})$ | 4.5 oz . (140 g ) |
| Environment |  |  |
| Operating Temperature | $\begin{aligned} & 0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \end{aligned}$ <br> $0 \%$ to $85 \%$ (without condensation) |  |
| Storage Temperature |  |  |
| Relative Humidity |  |  |
| Power Requirements | $\begin{aligned} & +5 \mathrm{Vdc} \pm 5 \% 1.4 \mathrm{~A}(7.0 \mathrm{~W}) \text { - Maximum } \\ & +12 \mathrm{Vdc} \pm 5 \% 170 \mathrm{~mA}(2.1 \mathrm{~W}) \text { - Maximum } \end{aligned}$ |  |
| RM 65 Bus Interface |  |  |
| Edge Connector Version | 72 -pin edge connector ( 0.100 in . centers) <br> 64 -pin plug ( 0.100 in . centers) per DIN 41612 (Row b not installed) |  |
| Eurocard Version |  |  |

NOTES:

1. The height includes the maximum values for component height above the board surface ( 0.4 in. for populated modules), printed circuit board thickness 10.062 in .) , and pin extension through the bottom of the module ( 0.1 in. ).
2. The length does not include extensions beyond the edge of the module due to connectors or the module ejector.
3. The Eurocard dimensions conform to DIN 41612.


## PART NUMBER RM65-3216(E)

## RM 65 DATA SHEET

## 16K PROM/ROM MODULE

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state-of-the-art performance, compact size, modular design and low cost. Software for RM 65 systems can be developed in R6500 Assembly Language, PL/65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot. The 64 -line RM 65 Bus offers memory addressing up to 128 K bytes, high immunity to electrical noise and includes growth provisions for user functions. A selection of card cages provides packaging flexibility. RM 65 products may also be used with Rockwell's AIM 65 Microcomputer for product development and for a broad variety of portable or desktop microcomputer applications.

## ORDERING INFORMATION

The 16 K PROM/ROM Module is available in an Edge Connector version (RM65-3216) and a Eurocard version (RM65-3216E).

FEATURES

- Compact size - about $4^{\prime \prime} \times 61 / 4 " ~_{1 \prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Edge connector and Eurocard versions
- RM 65 Bus compatible
- Buffered address, data and control lines
- Supports the following PROMs/ROMs or equivalents: Intel 2716 or 2732 PROMs TI TMS 2516 or 2532 PROMs Rockwell R2316, R2332 or R2364 ROMs
- Low-power PROM operation selectable by individual socket jumpers
- Jumpers allow selection of $2 \mathrm{~K}, 4 \mathrm{~K}$ or 8 K byte devices
- Starting address selectable for each of four 4 K memory blocks
- Separate switch allows 8 K to be dedicated to one or two memory bank operation
- +5V operation
- Fully assembled, tested and warranted.


## PRODUCT OVERVIEW

The RM 65 16K PROM/ROM Module has eight, 24-pin sockets to accept up to 16 K bytes of either programmable read-only memory (PROM) or masked read-only memory (ROM) devices. On-board jumpers permit selection of $2 \mathrm{~K}, 4 \mathrm{~K}$ or 8 K byte PROM/ROM devices. Switches allow setting of the starting address for independent 4 K byte blocks of memory. All 16 K bytes can be assigned to two memory banks, or 8 K can be assigned to common memory while the other 8 K can be dedicated to one or two 65 K memory banks. Low power operation is jumper selectable for PROMs that have this option.


Eurocard Version
RM65-3216E

Edge Connector Version RM65-3216


## FUNCTIONAL DESCRIPTION

The PROM/ROM module has eight 24 -pin sockets which can accept up to 16 K of either $2 \mathrm{~K}, 4 \mathrm{~K}$, or 8 K PROM or ROM.

The Data Buffers invert and transfer 8-bits of parallel data from the selected PROM/ROM devices to the RM 65 Bus during read operations.

The Control Buffers invert and transfer phase 2 clock, and read/write control signals from the RM 65 Bus onto the PROM/ROM module, and drive the bus active signal onto the RM 65 Bus.

The Bank Select control circuit detects when the PROM/ ROM module's assigned memory bank is addressed, by comparing the bank address signal from the RM 65 Bus to the Bank Select and Bank Select Enable switches. The Bank Select Enable switch allows 8 K of the PROM/ROM to be common memory (addressable in both Bank 0 and Bank 1)
while the remaining 8 K is assigned either to Bank 0 or Bank 1 , as determined by the Bank Select switch.

Four Base Address Decoders allow 4 K PROM/ROM sections to be independently addressed on any 4 K boundary within the selected bank. When an address falls within any section (per the Base Address switches), an enable signal is sent to the Chip Select Decoder.

The Chip Select Decoder uses outputs from the Bank Select Control circuit, the Base Address Decoders, and the PROM/ ROM size jumpers as well as the address lines to generate chip selects to the PROM/ROM devices. The PROM/ROM type jumpers route the chip select lines to the correct pins on the PROM/ROM sockets.

The Data Buffer Control circuit enables the Data Buffers during a read operation when an address corresponding to a selected base address is decoded and the selected PROM/ROM memory bank is addressed.


16K PROM/ROM Module Block Diagram


16K PROM/ROM Module Physical and Electrical Characteristics


## NOTES:

1. The height includes the maximum values for component height above the board surface ( 0.4 in . for populated modules), printed circuit board thickness ( 0.062 in .), and pin extension through the bottom of the module ( 0.1 in .).
2. The length does not include the added extension due to the module ejector.
3. The Eurocard dimensions conform to DIN 41612.


# $\triangle$ Rockwell <br> <br> RM 65 <br> <br> RM 65 DATA SHEET 

 DATA SHEET}

## SINGLE CARD ADAPTER

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state-of-theart performance, compact size, modular design and low cost. Software for RM 65 systems can be developed in R6500 Assembly Language, PL/65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot. The 64 line RM 65 Bus offers memory addressing up to 128 K bytes, high immunity to electrical noise and includes growth provisions for user functions. A selection of card cages provides packaging flexibility. RM 65 products may also be used with Rockwell's AIM 65 Microcomputer for product development and for a broad variety of portable or desktop microcomputer applications.

## ORDERING INFORMATION

The Single Card Adapter is available in an Edge Connector version (RM65-7101) and a Eurocard version (RM65-7101E).


## FEATURES

- Drives one RM 65 Bus-compatible module
- Provision for power and ground routing
- Extends address, data and control lines
- Edge connector and Eurocard versions
- Fully assembled, tested and warranted


## PRODUCT OVERVIEW

The RM 65 Single-Card Adapter allows one RM 65 Bus compatible module to be connected to the AIM 65 Master Module, through the AlM 65 Expansion connector. The Adapter routes the AIM 65 address, data and control lines from the AIM 65 Expansion connector pin assignments to the RM 65. Bus pin assignments. Drive circuitry is included on the address and data lines.


Edge Connector Version
RM65-7101

## FUNCTIONAL DESCRIPTION

The Single Card Adapter interfaces AIM 65 Expansion Connector signals to an attached RM 65 Bus receptacle. Data and address lines are buffered, whereas control lines are directly wired. All signals are routed from the AIM 65 Expansion Connector positions to corresponding RM 65 Bus receptacle pin positions. Ground is connected to the interspersed RM 65 Bus GND pins.

The Data Transceivers invert and drive 8 -bits of parallel data between the AIM 65 Expansion Connector and the RM 65 Bus interface. During a write operation, data received from the AIM 65 Expansion Connector are driven into the interfacing RM 65 module. During a read operation, data read from the RM 65 module are transmitted into the AIM 65. When the RM 65 module is not addressed, the transceivers are disabled.

The Address Buffers invert and buffer 16 parallel address

## POWER CONNECTION

## +5V Power Connection

The +5 V required for the Single Card Adapter can be provided from the AIM 65 microcomputer through the AIM 65 Expansion Connector or directly from an external power supply through a connection to the on-board terminal board (TB1). Jumper $\mathrm{A} / \mathrm{B}$ routes the +5 V power from the selected source.

## CAUTION

Turn off the external power supply before connecting power leads to the Single Card Adapter.

## AIM $65+5 V$ Power Source Connection

(1) Install Jumper $A / B$ in the $A$ position.
(2) Disconnect the +5 V lead of the external power supply from the +5 V connection on TB1.

## WARNING

If the mating RM 65 module draws over 0.5 A , the external connection to +5 V must be used or the Alin 65 Master Module may be damaged.
bits from the AIM 65 to the connected RM 65 module. The bank address line is held high to address Bank 0 (lower 65 K ) in the interfacing RM 65 module.

Eleven control and timing signals are directly connected between the AIM 65 Expansion Connector and the RM 65 module. The read/write, phase 2 clock, phase 1 clock, sync and reset AIM 65 output lines are routed directly to the RM 65 receptacle. The ready, interrupt request, set overflow and non-maskable interrupt lines from the RM 65 receptacle are connected straight through to the AIM 65 Expansion Connector interface.

A terminal block allows external $+5 \mathrm{~V},+12 \mathrm{~V} /+\mathrm{V}$, and $-12 \mathrm{~V} /-\mathrm{V}$ power supplies to be connected as required. An on-board jumper allows the +5 V for the RM 65 module to originate from the AIM 65 Expansion Connector or from the external +5 V power supply.

## External +5 V Power Source Connection

(1) Install Jumper $A / B$ in the $B$ position.
(2) Connect the +5 V lead from the external power supply to the +5 V connection on TB1.
(3) Connect the ground lead from the external +5 V power supply to either of the two GND connections on TB1.

## $\pm 12 \mathrm{~V} / \pm \mathrm{V}$ Power Connection

Connection points are provided on TB1 for $\pm 12 \mathrm{Vdc}$, or other voltages, as required by the mating RM 65 module.
(1) Connect the $+12 \mathrm{~V} /+\mathrm{V}$ lead from the external power supply to the TB1 connection marked +15 V or +V . This terminal is connected to connector J 1 pin 17a.
(2) Connect the $-12 \mathrm{~V} /-\mathrm{V}$ lead from the external power supply to the TB1 connection marked -15 V or -V . This terminal is connected to connector J 1 pin 16 c .

## INSTALLING THE SINGLE CARD ADAPTER

Before installing the module, ensure that it is not damaged and is free of grease, dirt, liquid or other foreign material.

## CAUTION

Prior to module installation, turn off power to the AIM 65 and, if applicable, the optional external +5 V and/or $\pm 12 \mathrm{~V} / \pm \mathrm{V}$ power supply input to the Adapter.
a. Align pin 1 of J 3 on the SCA with pin 1 of the Expansion Connector on the AIM 65 Master Module (component side up).
b. Carefully insert the Adapter into the Expansion Connector.
c. Press in firmly until all pins are securely seated.
d. Install the RM 65 module into the J1 connector on the Adapter using installation procedures described in the documentation for the particular module. Ensure that Bank Select switches on the add-on module are positioned to Bank Select 0 or Bank Select Disable, as appropriate.
e. Turn on power to the AIM 65 and, if applicable, turn on external +5 Vdc and/or $\pm 12 \mathrm{~V} / \pm \mathrm{V}$ to the SCA module.

## REMOVING THE SINGLE CARD ADAPTER

a. Turn off power to the AIM 65 and if applicable, to the external $\pm 12 \mathrm{~V} / \pm \mathrm{V}$ power supplies.
b. Pull the Adapter straight back while moving it slightly from side to side to disconnect it from the AIM 65 Expansion Connector.


Single Card Adapter Block Diagram



NOTE: LNLESS OTHERWISE SPECIFIED

1. REF ASSSY DWG PAIO-DDIO

2 PINS $1 a, 3 a, 5 c, 8 a, 10 c, 13 a, 15 c, 18 a, 20 c, 23 a, 25 c, 28 a, 30 c$, 32C SHALL BE CONNECTED TO GROUND.
3. PINS $/ 1,3 Z a$ ON ELIRO CONNECTOR AND PINS $x_{a} x_{c}, y_{a}, y_{c}$, IC,SZa ON US. CONNECTOR SHALL BETIED TO +5 V .


| RM 65 Bus Pin Assignments |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bottom (Solder Side) |  |  |  | Top (Component Side) |  |  |  |
| Signal Mnemonic | Signal Name | Input/ Output | Pin | Pin | Signal Mnemonic | Signal Name | Input/ Output |
|  | Not Connected (See Note) |  | Wa | Wc |  | Not Connected (See Note) |  |
| +5V | +5 Vdc Line (See Note) |  | Xa | Xc | $+5 \mathrm{~V}$ | +5 Vdc (See Note) |  |
| GND | Ground |  | 1a | 1 c | +5V | +5 Vdc |  |
| BADR/ | Buffered Bank Address | 0 | 2a | 2c | BA15/ | Buffered Address Bit 15 | 0 |
| GND | Ground |  | 3 a | 3 c | BA14/ | Buffered Address Bit 14 | 0 |
| BA13/ | Buffered Address Bit 13 | 0 | 4a | 4 c | BA12/ | Buffered Address Bit 12 | 0 |
| BA11/ | Buffered Address Bit 11 | 0 | 5 a | 5 c | GND | Ground |  |
| BA10/ | Buffered Address Bit 10 | 0 | 6 a | 6 c | BA9/ | Buffered Address Bit 9 | 0 |
| BA8/ | Buffered Address Bit 8 | 0 | 7 a | 7 c | BA7/ | Buffered Address Bit 7 | 0 |
| GND | Ground |  | 8 a | 8 c | BA6/ | Buffered Address Bit 6 | 0 |
| BA5/ | Buffered Address Bit 5 | 0 | 9a | 9c | BA4/ | Buffered Address Bit 4 | 0 |
| BA3/ | Buffered Address Bit 3 | 0 | 10a | 10c | GND | Ground |  |
| BA2/ | Buffered Address Bit 2 | 0 | 11a | 11c | BA1/ | Buffered Address Bit 1 | 0 |
| BAO/ | Buffered Address Bit 0 | 0 | 12a | 12c | Bø1 | Buffered Phase 1 Clock | 0 |
| GND | Ground |  | 13a | 13c | BSYNC | Buffered Sync | 0 |
| BSO | Buffered Set Overflow | 1 | 14a | 14c | BDRQ1/ | *Buffered DMA Request 1 |  |
| BRDY | Buffered Ready | 1 | 15a | 15c | GND | Ground |  |
|  | * User Spare 1 |  | 16a | 16c | -12V/-V | -12 Vdc/-V |  |
| $+12 \mathrm{~V} /+\mathrm{V}$ | +12 Vdc/+V |  | 17a | 17c |  | * User Spare 2 |  |
| GND | Ground Line |  | 18a | 18c | BFLT/ | *Buffered Bus Float |  |
| BDMT/ | *Buffered DMA Terminate |  | 19a | 19c | Bøо | *Buffered External Phase 0 Clock |  |
|  | *User Spare 3 |  | 20a | 20c | GND | Ground |  |
| $B R / \bar{W} /$ | Buffered Read/Write 'Not" | 0 | 21a | 21c | BDRO2/ | *Buffered DMA Request 2 |  |
|  | *System Spare |  | 22a | 22c | $B R / \bar{W}$ | Buffered Read/Write | 0 |
| GND | Ground |  | 23a | 23c | BACT/ | Buffered Bus Active | 1 |
| BIRQ/ | Buffered Interrupt Request | 1 | 24a | 24c | BNMI/ | Buffered Non-Maskable Interrupt | 1 |
| B $\boldsymbol{\beta} 21^{1}$ | Buffered Phase 2 "Not" Clock | 0 | 25a | 25c | GND | Ground |  |
| Bø2 | Buffered Phase 2 Clock | $\bigcirc$ | 26a | 26c | BRES/ | Buffered Reset | 0 |
| BD71 | Buffered Data Bit 7 | 1/0 | 27a | 27c | BD6/ | Buffered Data Bit 6 | 1/0 |
| GND | Ground |  | 28a | 28c | BD5/ | Buffered Data Bit 5 | 1/O |
| BD4/ | Buffered Data Bit 4 | 1/0 | 29a | 29c | BD3/ | Buffered Data Bit 3 | 1/0 |
| BD2/ | Buffered Data Bit 2 | 1/0 | 30a | 30 c | GND | Ground |  |
| BD1/ | Buffered Data Bit 1 | 1/0 | 31a | 31c | BDO/ | Buffered Data Bit 0 | 1/0 |
| +5V | +5 Vdc |  | 32a | 32c | GND | Ground |  |
| +5V | +5 Vdc (See Note) |  | Ya | Yc | +5V | +5 Vdc (See Note) |  |
|  | *Not Connected (See Note) |  | Za | Zc |  | Not Connected (See Note) |  |
| NOTE <br> Pins Wa, Wc, $\mathrm{Xa}, \mathrm{Xc}, \mathrm{Ya}, \mathrm{Yc}, \mathrm{Za}, \mathrm{Zc}$ are not used on the Eurocard version. <br> *Not used on this module. |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |

AIM 65 Expansion Connector Pin Assignments

| Top (Component Side) |  |  |  | Bottom (Solder Side) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Signal Mnemonic | Signal Name | Input/ Output | Pin | Pin | Signal Mnemonic | Signal Name | Input/ <br> Output |
| SYNC | Sync | 1 | 1 | A | AO | Address Bit 0 | 1 |
| RDY | Ready | 0 | 2 | B | A1 | Address Bit 1 | 1 |
| 01 | Phase 1 Clock | 1 | 3 | C | A2 | Address Bit 2 | 1 |
| $\overline{\text { IRO }}$ | Interrupt Request | 0 | 4 | D | A3 | Address Bit 3 | 1 |
| S.O. | Set Overflow | 0 | 5 | E | A4 | Address Bit 4 | 1 |
| NMI | Non-Maskable Interrupt | 0 | 6 | F | A5 | Address Bit 5 | 1 |
| $\overline{\text { RES }}$ | Reset | 1 | 7 | H | A6 | Address Bit 6 | 1 |
| D7 | Data Bit 7 | 1/0 | 8 | $\checkmark$ | A7 | Address Bit 7 | 1 |
| D6 | Data Bit 6 | 1/0 | 9 | K | A8 | Address Bit 8 | 1 |
| D5 | Data Bit 5 | 1/0 | 10 | $L$ | A9 | Address Bit 9 | 1 |
| D4 | Data Bit 4 | 1/0 | 11 | M | A10 | Address Bit 10 | 1 |
| D3 | Data Bit 3 | 1/0 | 12 | N | A11 | Address Bit 11 | 1 |
| D2 | Data Bit 2 | 1/0 | 13 | P | A12 | Address Bit 12 | 1 |
| D1 | Data Bit 1 | IJO | 14 | R | A13 | Address Bit 13 | 1 |
| D0 | Data Bit 0 | 1/0 | 15 | S | A14 | Address Bit 14 | 1 |
| -12V | *-12 Vdc |  | 16 | T | A15 | Address Bit 15 | 1 |
| $+12 \mathrm{~V}$ | * +12 Vdc |  | 17 | U | SYS 02 | System Phase 2 Clock | 1 |
| C-58 | * Chip Select 8 |  | 18 | V | SYS R/W | System Read/Write | 1 |
| $\overline{\text { CS9 }}$ | *Chip Select 9 |  | 19 | w | R/W | Read/Write "Not" | 1 |
| $\overline{\text { CSA }}$ | * Chip Select A |  | 20 | X | *TEST | Test |  |
| +5V | +5 Vdc |  | 21 | $Y$ | $\bar{\emptyset} 2$ | Phase 2 Clock "Not" | 1 |
| GND | Ground |  | 22 | Z | *RAM R/W | RAM Read/Write |  |

NOTE:

* = Not used on this module.

Single Card Adapter Module Physical and Electrical Characteristics

\begin{tabular}{|c|c|c|}
\hline Characteristic \& \multicolumn{2}{|c|}{Value} <br>
\hline \multicolumn{3}{|l|}{Physical Characteristics (See Notes)} <br>
\hline \& Edge Connector \& Eurocard <br>
\hline Width \& 4.4 in. (111 mm) \& $4.4 \mathrm{in} .(111 \mathrm{~mm})$ <br>
\hline Length \& 3.7 in . $(93 \mathrm{~mm})$ \& $3.7 \mathrm{in} .(93 \mathrm{~mm})$ <br>
\hline Height \& $0.56 \mathrm{in} .(14 \mathrm{~mm}$ ) \& 0.56 in . ( 14 mm ) <br>
\hline Weight \& 3.2 oz . (95 g) \& 3.0 oz . (90 g) <br>
\hline \multicolumn{3}{|l|}{Environment} <br>
\hline Operating Temperature \& \multicolumn{2}{|l|}{\multirow[t]{2}{*}{$$
\begin{aligned}
& 0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\
& -40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C}
\end{aligned}
$$}} <br>
\hline Storage Temperature \& \& <br>
\hline Relative Humidity \& \multicolumn{2}{|l|}{0\% to 85\% (without condensation)} <br>
\hline \multirow[t]{2}{*}{Power Requirements} \& \multicolumn{2}{|l|}{\multirow[t]{2}{*}{$+5 \mathrm{~V} \pm 5 \% 110 \mathrm{~mA}(0.55 \mathrm{~W})$ - Typical

$200 \mathrm{~mA}(1.00 \mathrm{~W})$ - Maximum}} <br>
\hline \& \& <br>
\hline \multicolumn{3}{|l|}{Interface} <br>
\hline AIM 65 Expansion Connector \& 22/44 - edge receptac \& 156 in. centers) <br>
\hline RM 65 Bus \& \& <br>
\hline Edge Connector Version \& 72-pin edge receptacl ( 0.100 in . centers) \& <br>
\hline Eurocard Version \& 64-pin receptacle 10.1 (Row b is not install \& centers) per DIN 41612 <br>
\hline
\end{tabular}

## NOTES:

1. The height includes the maximum values for component height above the board surface ( 0.4 in . for populated modules), printed circuit board thickness ( 0.062 in .), and pin extension through the bottom of the module ( 0.1 in .).
2. The length does not include extensions beyond the edge of the module due to connectors.


Module Dimensions

## RM 65 DATA SHEET

## ADAPTER/BUFFER

RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state-of-theart performance, compact size, modular design and low cost. Software for RM 65 systems can be developed in R6500 Assembly Language, PL/65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot. The 64line RM 65 Bus offers memory addressing up to 128 K bytes, high immunity to electrical noise and includes growth provisions for user functions. A selection of card cages provides packaging flexibility. RM 65 products may also be used with Rockwell's AIM 65 Microcomputer for product development and for a broad variety of portable or desktop microcomputer applications.

## ORDERING INFORMATION

The Adapter/Buffer is available in an Edge Connector Version (RM65-7104) and a Eurocard version (RM657104E).

## FEATURES

- RM 65 Bus Compatible
- Buffered address data and control lines
- Drives up to 15 modules
- Edge connector and Eurocard versions
- Fully assembled, tested and warranted


## PRODUCT OVERVIEW

The Adapter/Buffer extends the RM 65 Bus from the AIM 65 Expansion Connector to a compatible motherboard that is situated up to 16 inches away. Included circuitry permits the Adapter/Buffer to drive up to 15 RM 65 Bus-compatible modules. (The similar Cable Driver Adapter/Buffer, Part Number RM65-7116, pro: vides the same drive capability for applications in which the motherboard is up to six feet from the Expansion Connector.)

The Adapter/Buffer consists of an adapter module, a buffer module and two 16 -inch interconnect cables. Both cables are flexible, so the motherboard may be installed in a wide variety of locations and orientations relative to the AIM 65.


## FUNCTIONAL DESCRIPTION

The Adapter/Buffer consists of two modules and two interconnect cables. The Adapter module connects to the AIM 65 Expansion connector and the Buffer module connects to an RM 65 Bus motherboard receptacle.

The Adapter module transfers data, address and control lines from AIM 65 Expansion Connector to the interconnect cables. The eight data and 16 address lines are routed directly, without buffering. The read/write, clock, sync and reset AIM 65 output control lines are also routed directly through the Adapter. The ready, set overflow, interrupt request and non-maskable interrupt AIM 65 input lines are buffered on the module.

Two 16 -inch 40 conductor flat ribbon cables connect the Adapter module to the Buffer module. The cables are mass terminated at each end, and are permanently attached to the interfacing module.

The Buffer module buffers and routes all interface signals between the interconnect cables and the RM 65 Bus connector.

The Data Transceivers invert and drive 8-bits of parallel data. During a write operation, data received from the cables are driven onto the RM 65 Bus. During a read operation, data received from the RM 65 Bus are driven onto the cables. The
bus active signal enables the Transceivers. When the bus float signal is active, the Transceivers are disabled.

The Address Buffers invert and transfer 16 parallel address lines from the interconnect cable to the RM 65 Bus. When the bus float signal is active, the Buffers are disabled.

Jumper E1 selects the source for the bank address line (BADR/) - either the buffer module or an external module. When the buffer module is the source (position A), the bank address line is held high to address Bank 0 (Lower 65 K ) on the Bus; this line is disabled when the bus float line is active. For an external source (position B), the bank address line is not used by the buffer module, and must be controlled by another module on the Bus.

The seven read/write, clock, sync and reset lines from the cables to the bus are buffered by the Control Drivers. All of these lines, except reset and phase 1 , are disabled when the bus float line is active. The ready, set overflow, interrupt request and non-maskable lines from the bus to the interconnect cables are also buffered by the Control Drivers.

Jumper E2 selects the source for the DMA Terminate line (BDMT/) - either the buffer module or an external module. When the buffer module is the source (position A), the DMA terminate line is held high (inactive). For an external source (position B), the DMA terminate line is not used by the buffer module, and must be controlled by another module on the bus.

## INSTALLATION

## Installing the Adapter/Buffer

Before installing the module, ensure that it is not damaged and is free of grease, dirt, liquid or other foreign material.
a. Before installing the Adapter/Buffer, turn off power to the AIM 65 and the interfacing RM 65 Bus motherboard.
b. Configure Jumpers E1 and E2, per the Functional Description.
c. Align the Adapter module connector J 3 pin 1 with the AIM 65 Expansion Connector J3 pin 1.
d. Plug the Adapter module onto the Expansion Connector. Press in firmly on the end of module until all pins are securely seated.
e. Install connector P1 of the Buffer module into the desired slot on the mating RM 65 Bus motherboard.

## CAUTION

RM 65 Bus connectors are keyed to prevent improper module connection. If the module does not insert into the receptacle with moderate pressure applied, check the orientation and connector alignment of the module. Forcing the module improperly into the receptacle may damage the receptacle and/or the module.
f. Apply power to the AIM 65 and to the mating RM 65 Bus motherboard.

## Removing the Adapter/Buffer

a. Turn off power to the AIM 65 and to the RM 65 Bus motherboard.
b. Lift up on the Buffer module ejector tab to release the module from the mating RM 65 Bus receptacle. Pull the module straight back until it is free from the card slot guides.
c. Pull back on the Adapter module while moving it slightly from side to side until it is free from the AIM 65 Expansion Connector.




## Norenulctss ormentise smicirara



(5) TLL EVEN numben ans ( 2 TwRU \&0) SNALL as

TIED TO GNO.
4. ALL CAPACITORS ARE . TOUF $320 \%$, 50 V .

| Adapter Module to AIM 65 Expansion Connector Pin Assignments |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Top (Component Side) |  |  |  | Bottom (Solder Side) |  |  |  |
| Signal Mnemonic | Signal Name | Input/ Output | Pin | Pin | Signal Mnemonic | Signal Name | Input/ <br> Output |
| SYNC | SYNC | 1 | 1 | A | AO | Address Bit 0 | 1 |
| RDY | Ready | 0 | 2 | B | A1 | Address Bit 1 | 1 |
| 01 | Phase 1 Clock | 1 | 3 | C | A2 | Address Bit 2 | 1 |
| IRO | Interrupt Request | 0 | 4 | D | A3 | Address Bit 3 | 1 |
| S.O. | Set Overflow | 0 | 5 | E | A4 | Address Bit 4 | 1 |
| NMI | Non-Maskable Interrupt | 0 | 6 | F | A5 | Address Bit 5 | 1 |
| $\overline{\mathrm{RES}}$ | Reset | 0 | 7 | H | A6 | Address Bit 6 | 1 |
| D7 | Data Bit 7 | 1/0 | 8 | J | A7 | Address Bit 7 | 1 |
| D6 | Data Bit 6 | 1/0 | 9 | K | A8 | Address Bit 8 | 1 |
| D5 | Data Bit 5 | 1/0 | 10 | L | A9 | Address Bit 9 | 1 |
| D4 | Data Bit 4 | 1/0 | 11 | M | A 10 | Address Bit 10 | 1 |
| D3 | Data Bit 3 | 1/0 | 12 | N | A11 | Address Bit 11 | 1 |
| D2 | Data Bit 2 | 1/0 | 13 | P | A 12 | Address Bit 12 | 1 |
| D1 | Data Bit 1 | 1/0 | 14 | R | A13 | Address Bit 13 | 1 |
| D0 | Data Bit 0 | 1/0 | 15 | S | A14 | Address Bit 14 | 1 |
| -12V | *-12 Vdc |  | 16 | $T$ | A15 | Address Bit 15 | 1 |
| +12V | * +12 Vdc |  | 17 | U | SYS 02 | System Phase 2 Clock | 1 |
| $\overline{\mathrm{CS} 8}$ | *Chip Select 8 |  | 18 | V | SYSR/W | System Read/Write | 1 |
| $\overline{\text { CS9 }}$ | * Chip Select 9 |  | 19 | W | $\overline{R / W}$ | Read/Write "Not" | 1 |
| $\overline{\operatorname{CSA}}$ | * Chip Select A |  | 20 | X | TEST | *Test |  |
| +5V | +5 Vdc |  | 21 | Y |  | Phase 2 Clock "Not" | 1 |
| GND | Ground |  | 22 | Z | RAM R/W | *RAM Read/Write |  |
| NOTE: <br> * $=$ Not used on this module. |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |



Adapter/Buffer Block Diagram

Adapter/Buffer Physical and Electrical Characteristics

| Characteristics | Value |
| :---: | :---: |
| Dimension (See Notes) |  |
| Adapter Module |  |
| Width | $4.4 \mathrm{in} .(111 \mathrm{~mm})$ |
| Length | $2.6 \mathrm{in} .(67 \mathrm{~mm})$ |
| Height | 0.56 in . ( 14 mm ) |
| Buffer Module | Edge Connector Eurocard |
| Width | $3.9 \mathrm{in} .(100 \mathrm{~mm}) \quad 3.9 \mathrm{in} .(100 \mathrm{~mm})$ |
| Length | $6.5 \mathrm{in} .(164 \mathrm{~mm}) \quad 6.3 \mathrm{in} .(160 \mathrm{~mm})$ |
| Height | $0.56 \mathrm{in} .(14 \mathrm{~mm}) \quad 0.56 \mathrm{in} .(14 \mathrm{~mm})$ |
| Weight | $6.9 \mathrm{oz} .(195 \mathrm{~g}) \quad 7.2 \mathrm{oz} .(205 \mathrm{~g})$ |
| Power |  |
| Adapter Module | +5V $\pm 5 \% 30 \mathrm{~mA}(0.15 \mathrm{~W})-$ Typical |
|  | $50 \mathrm{~mA}(0.25 \mathrm{~W})$ - Maximum |
| Buffer Module | $+5 \mathrm{~V} \pm 5 \% 190 \mathrm{~mA}(0.95 \mathrm{~W})$ - Typical $330 \mathrm{~mA}(1.7 \mathrm{~W})$ - Maximum |
| Environment |  |
| Operating Temperature | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage Temperature | $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ |
| Relative Humidity | 0\% to 85\% (without condensation) |
| Propagation Time | 20 ns - Maximum |
| Interface Connectors |  |
| AIM 65 Expansion Connector | 22/44 - edge receptacle ( 0.156 in. centers) |
| RM 65 Bus |  |
| Edge Connector Version | 72-pin edge connector ( 0.100 in . centers) |
| Eurocard Version | 64 -pin plug ( 0.100 in. centers) per DIN 41612 (Row b is not installed) |
| Interface Cables |  |
| Number of Cables | Two |
| Cable Length | 16 inches |
| Type | Flat ribbon |
| Number of conductors per cable | 40 |
| Wire Size | \#28 AWG |

NOTES:

1. The height includes the maximum values for component height above the board surface ( 0.4 in . for populated modules), printed circuit board thickness ( 0.062 in .), and pin extension through the bottom of the module ( 0.1 in .)
2. The length does not include extensions beyond the edge of the module due to connectors or the module ejector.
3. The Eurocard dimensions conform to DIN 41612.

## ADAPTER MODULE



## BUFFER MODULE



Module Dimensions

## PART NUMBER RM65-7116(E)

## 1 Rockwell <br> RM 65 DATA SHEET

## CABLE DRIVER ADAPTER/BUFFER

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state-of-theart performance, compact size, modular design and low cost. Software for RM 65 systems can be developed in R6500 Assembly Language, PL/65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot. The 64 line RM 65 Bus offers memory addressing up to 128 K bytes, high immunity to electrical noise and includes growth provisions for user functions. A selection of card cages provides packaging flexibility. RM 65 products may also be used with Rockwell's AIM 65 Microcomputer for product development and for a broad variety of portable or desktop microcomputer applications.

## ORDERING INFORMATION

The Cable Driver Adapter/Buffer is available in an Edge Connector Version (RM65-7116) and a Eurocard version (RM65-7116E).

## FEATURES

- RM 65 Bus compatible
- Buffered address data and control lines
- Drives up to 15 modules
- Long cable for distances of up to 6 feet
- Edge connector and Eurocard versions
- Fully assembled, tested and warranted


## PRODUCT OVERVIEW

The Cable Driver Adapter/Buffer extends the RM 65 Bus from the AIM 65 Expansion Connector to a compatible motherboard that is situated up to six feet away. Included circuitry permits the Cable Driver Adapter/Buffer to drive up to 15 RM 65 Bus-compatible modules. (The similar Adapter/Buffer, Part Number RM65-7104, provides the same drive capability for applications in which the motherboard need not be more than 16 inches from the Expansion Connector.)

The Cable Driver Adapter/Buffer consists of a cable driver adapter module, a buffer module, and two 6 -foot interconnect cables. Both cables are flexible, so the motherboard may be installed in a wide variety of locations and orientations relative to the AIM 65.


Eurocard Version
RM65-7116E


Edge Connector Version RM65-7116

Specifications subject to
change without notice

## FUNCTIONAL DESCRIPTION

The Cable Driver Adapter/Buffer consists of two modules and two interconnect cables. The Adapter Module connects to the AIM 65 Expansion connector and the Buffer module connects to an RM 65 Bus motherboard receptacle.

The Cable Driver Adapter module buffers data, address and control lines between the AIM 65 Expansion Connector and the interconnect cables.

The Data Transceivers drive 8 -bits of parallel data. During a write operation, data received from the AIM 65 are driven onto the cables. During a read operation, data received from the cables are driven into the AIM 65. The bus active signal enables the Data Transceivers.

The Address Buffers drive 16 -bits of parallel data from the AIM 65 onto the cables.

The Control Buffers transfer the timing and control signals between the AIM 65 and the cables. The seven read/write, clock, sync, and reset lines are driven from the AIM 65 onto the cables. The four ready, set overflow, interrupt request and non-maskable interrupt lines are driven from the cables onto the AIM 65.

Two 6 -foot 40 conductor flat ribbon cables connect the Cable Driver Adapter module to the Buffer module. The cables are mass terminated at each end, and are permanently attached to the interfacing module.

The Buffer module buffers and routes all interface signals between the interconnect cables and the RM 65 Bus connector.

The Data Transceivers invert and drive 8 -bits of parallel data. During a write operation, data received from the cables are driven onto the RM 65 Bus. During a read operation, data received from the RM 65 Bus are driven onto the cables. The bus active signal enables the Transceivers. When the bus float signal is active, the Transceivers are disabled.

The Address Buffers invert and transfer. 16 parallel address lines from the interconnect cable to the RM 65 Bus. When the bus float signal is active, the Buffers are disabled.

Jumper E1 selects the source for the bank address line (BADR/) - either the buffer module or an external module. When the buffer module is the source (position A), the bank address line is held high to address Bank 0 (lower 65K) on the Bus; this line is disabled when the bus float line is active. For an external source (position B), the bank address line is not used by the buffer module, and must be controlled by another module on the Bus.

The seven read/write, clock, sync and reset lines from the cables to the bus are buffered by the Control Buffers. All of these lines, except reset and phase 1 , are disabled when the bus float line is active. The ready, set overflow, interrupt request and non-maskable lines from the bus to the interconnect cables are also buffered by the Control Buffers.

Jumper E2 selects the source for the DMA Terminate line (BDMT/) - either the buffer module or an external module. When the buffer module is the source (position A), the DMA terminate line is held high (inactive). For an external source (position B), the DMA terminate line is not used by the buffer module, and must be controlled by another module on the bus.

## INSTALLATION

## Installing the Cable Driver Adapter/Buffer

Before installing the module, ensure that it is not damaged and is free of grease, dirt, liquid or other foreign material.
a. Before installing the Cable Driver Adapter/Buffer, turn off power to the AIM 65 and the interfacing RM 65 Bus motherboard.
b. Configure Jumpers E1 and E2, per the Functional Description.
c. Align Cable Driver Adapter module connector J3 pin 1 with the AIM 65 Expansion Connector J 3 pin 1.
d. Plug the Cable Driver Adapter module onto the Expan. sion Connector. Press in firmly on the end of module until all pins are securely seated.
e. Install connector P1 of the Buffer module into the desired slot on the mating RM 65 Bus motherboard.

## CAUTION

RM 65 Bus connectors are keyed to prevent improper module connection. If the module does not insert into the receptacle with moderate pressure applied, check the orientation and connector alignment of the module. Forcing the module improperly into the receptacle may damage the receptacle and/or the module.
f. Apply power to the AIM 65 and to the mating RM 65 Bus motherboard.

## Removing the Cable Driver Adapter/Buffer

a. Turn off power to the AIM 65 and to the RM 65 Bus motherboard.
b. Lift up on the Buffer module ejector tab to release the module from the mating RM 65 Bus receptacle. Pull the module straight back until it is free from the card slot guides.
c. Pull back on the Cable Driver module while moving it slightly from side to side until it is free from the AIM 65 Expansion Connector.

| Buffer Module to RM 65 Bus Connector Pin Assignments |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bottom (Solder Side) |  |  |  | Top (Component Side) |  |  |  |
| Signal Mnemonic | Signal Name | Input/ Output | Pin | Pin | Signal Mnemonic | Signal Name | Input/ Output |
|  | Not Connected (See Note) |  | Wa | Wc |  | Not Connected (See Note) |  |
| +5V | +5 Vdc Line (See Note) |  | Xa | Xc | +5V | +5 Vdc (See Note) |  |
| GND | Ground |  | 1 a | 1 c | $+5 \mathrm{~V}$ | +5 Vdc |  |
| BADR/ | Buffered Bank Address | 0 | 2a | 2 c | BA15/ | Buffered Address Bit 15 | 0 |
| GND | Ground |  | 3a | 3 c | BA14/ | Buffered Address Bit 14 | 0 |
| BA13/ | Buffered Address Bit 13 | 0 | 4 a | 4 c | BA12/ | Buffered Address Bit 12 | 0 |
| BA11/ | Buffered Address Bit 11 | 0 | 5 a | 5 c | GND | Ground |  |
| BA10/ | Buffered Address Bit 10 | 0 | 6 a | 6 c | BA9/ | Buffered Address Bit 9 | 0 |
| BA8/ | Buffered Address Bit 8 | 0 | 7 a | 7 c | BA7/ | Buffered Address Bit 7 | 0 |
| GND | Ground |  | 8 a | 8 c | BA6/ | Buffered Address Bit 6 | 0 |
| BA5/ | Buffered Address Bit 5 | 0 | 9 a | 9c | BA4/ | Buffered Address Bit 4 | 0 |
| BA3/ | Buffered Address Bit 3 | 0 | 10a | 10c | GND | Ground |  |
| BA2/ | Buffered Address Bit 2 | 0 | 11a | 11c | BA1/ | Buffered Address Bit 1 | 0 |
| BAO/ | Buffered Address Bit 0 | 0 | 12a | 12c | B $\chi_{1}$ | Buffered Phase 1 Clock | 0 |
| GND | Ground |  | 13a | 13c | BSYNC | Buffered Sync | 0 |
| BSO | Buffered Set Overflow | 1 | 14a | 14c | BDRQ1/ | *Buffered DMA Request 1 |  |
| BRDY | Buffered Ready | 1 | 15a | 15c | GND | Ground |  |
|  | * User Spare 1 |  | 16a | 16c | -12V/-V | *-12 Vdc/-V |  |
| $+12 \mathrm{~V} /+\mathrm{V}$ | *+12 Vdc/+V |  | 17a | 17c |  | * User Spare 2 |  |
| GND | Ground Line |  | 18a | 18c | BFLT/ | Buffered Bus Float | 1 |
| BDMT/ | Buffered DMA Terminate |  | 19a | 19c | Bфо | *Buffered External Phase 0 Clock |  |
|  | * User Spare 3 |  | 20a | 20c | GND | Ground |  |
| $B R / W /$ | Buffered Read/Write "Not" | 0 | 21a | 21c | BDRQ2/ | *Buffered DMA Request 2 |  |
|  | *System Spare |  | 22a | 22c | BR/W | Buffered Read/Write | 0 |
| GND | Ground |  | 23a | 23c | BACT/ | Buffered Bus Active | 1 |
| BIRQ/ | Buffered Interrupt Request | 1 | 24a | 24c | BNMI/ | Buffered Non-Maskable Interrupt | 1 |
| B $\square_{2 /}$ | Buffered Phase 2 "Not" Clock | 0 | 25a | 25 c | GND | Ground |  |
| Bø2 | Buffered Phase 2 Clock | 0 | 26a | 26c | 8RES/ | Buffered Reset | 0 |
| BD7/ | Buffered Data Bit 7 | 1/0 | 27a | 27c | BD6/ | Buffered Data Bit 6 | 1/0 |
| GND | Ground |  | 28a | 28c | BD5/ | Buffered Data Bit 5 | 1/0 |
| BD4/ | Buffered Data Bit 4 | 1/0 | 29a | 29c | BD3/ | Buffered Data Bit 3 | 1/0 |
| BD2/ | Buffered Data Bit 2 | 1/0 | 30a | 30 c | GND | Ground |  |
| BD1/ | Buffered Data Bit 1 | 1/0 | 31a | 31c | BDO/ | Buffered Data Bit 0 | 1/0 |
| +5V | $+5 \mathrm{Vdc}$ |  | 32a | 32c | GND | Ground |  |
| $+5 \mathrm{~V}$ | +5 Vdc (See Note) |  | Ya | Yc | +5V | +5 Vdc (See Note) |  |
|  | Not Connected (See Note) |  | Za | Zc |  | Not Connected (See Note) |  |
| NOTE <br> Pins Wa, Wc, Xa, Xc, Ya, Yc, Za, Zc are not used on the Eurocard version. <br> *Not used on this module. |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |



wotelunless atneriwise specirice



(3) ALL EVEN HUMBER PINS ( 2 TNPU 40) SHALL $\operatorname{se}$

TIFD TO GND.
4. ALL CAPACITORS ARE . IOUF $\$ 20 \%$, sor.

| Cable Driver Adapter Module to AIM 65 Expansion Connector Pin Assignments |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Top (Component Side) |  |  |  | Bottom (Solder Side) |  |  |  |
| Signal Mnemonic | Signal Name | Input/ <br> Output | Pin | Pin | Signal Mnemonic | Signal Name | Input/ Output |
| SYNC RDY <br> 01 <br> $\overline{\text { IRO }}$ <br> s.O. <br> $\overline{\text { NMI }}$ <br> $\overline{\text { RES }}$ <br> D7 <br> D6 <br> D5 <br> D4 <br> D3 <br> D2 <br> D1 <br> D0 <br> $-12 \mathrm{~V}$ <br> $+12 \mathrm{~V}$ <br> $\overline{\text { CS8 }}$ <br> $\overline{\mathrm{CS} 9}$ <br> $\overline{\text { CSA }}$ <br> $+5 \mathrm{~V}$ <br> GND | SYNC <br> Ready <br> Phase 1 Clock <br> Interrupt Request <br> Set Overflow <br> Non-Maskable Interrupt <br> Reset <br> Data Bit 7 <br> Data Bit 6 <br> Data Bit 5 <br> Data Bit 4 <br> Data Bit 3 <br> Data Bit 2 <br> Data Bit 1 <br> Data Bit 0 <br> *-12 Vdc <br> * +12 Vdc <br> *Chip Select 8 <br> *Chip Select 9 <br> *Chip Select A $+5 \mathrm{Vdc}$ <br> Ground | $\begin{aligned} & 1 \\ & 0 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \\ & 1 / 0 \end{aligned}$ | $\begin{array}{r} 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 7 \\ 8 \\ 9 \\ 10 \\ 11 \\ 12 \\ 13 \\ 14 \\ 15 \\ 16 \\ 17 \\ 18 \\ 19 \\ 20 \\ 21 \\ 22 \end{array}$ | $\begin{aligned} & A \\ & \mathrm{~B} \\ & \mathrm{C} \\ & \mathrm{D} \\ & \mathrm{E} \\ & \mathrm{~F} \\ & \mathrm{H} \\ & \mathrm{~J} \\ & \mathrm{~K} \\ & \mathrm{~L} \\ & \mathrm{M} \\ & \mathrm{~N} \\ & \mathrm{P} \\ & \mathrm{R} \\ & \mathrm{~S} \\ & \mathrm{~T} \\ & \mathrm{U} \\ & \mathrm{~V} \\ & \mathrm{~W} \\ & \mathrm{X} \\ & \mathrm{Y} \\ & \mathrm{Z} \end{aligned}$ | A0 <br> A1 <br> A2 <br> A3 <br> A4 <br> A5 <br> A6 <br> A7 <br> A8 <br> A9 <br> A10 <br> A11 <br> A12 <br> A13 <br> A14 <br> A15 <br> SYS $0_{2}$ <br> $\frac{S Y S}{R / \bar{W}} R$ <br> TEST <br> $\overline{0}$ <br> RAM R/W | Address Bit 0 <br> Address Bit 1 <br> Address Bit 2 <br> Address Bit 3 <br> Address Bit 4 <br> Address Bit 5 <br> Address Bit 6 <br> Address Bit 7 <br> Address Bit 8 <br> Address Bit 9 <br> Address Bit 10 <br> Address Bit 11 <br> Address Bit 12 <br> Address Bit 13 <br> Address Bit 14 <br> Address Bit 15 <br> System Phase 2 Clock <br> System Read/Write <br> Read/Write "Not" <br> *Test <br> Phase 2 Clock "Not" <br> *RAM Read/Write | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ |
| NOTE: <br> * $=$ Not used | is module. |  |  |  |  |  |  |



Cable Driver Adapter/Buffer Block Diagram

Cable Driver Adapter/Buffer Physical and Electrical Characteristics

| Characteristics | Value |
| :---: | :---: |
| Dimension (See Notes) <br> Cable Driver Adapter Module |  |
|  |  |
| Width | 4.4 in . $(111 \mathrm{~mm})$ <br> $5 \mathrm{in} .(127 \mathrm{~mm})$ |
| Length |  |
| Height | $0.56 \mathrm{in} .(14 \mathrm{~mm})$ |
| Buffer Module | Edge Connector Eurocard |
| Width | $3.9 \mathrm{in} .(100 \mathrm{~mm}) \quad 3.9 \mathrm{in} .(100 \mathrm{~mm})$ |
| Length | $6.5 \mathrm{in} .(164 \mathrm{~mm}) \quad 6.3 \mathrm{in} .(160 \mathrm{~mm})$ |
| Height | $0.56 \mathrm{in} .(14 \mathrm{~mm}) \quad 0.56 \mathrm{in} .(14 \mathrm{~mm})$ |
| Weight | $1.0 \mathrm{lb}(450 \mathrm{~g})$ |
| Power |  |
| Cable Driver Adapter Module | $\begin{array}{r} +5 \mathrm{~V} \pm 5 \% 30 \mathrm{~mA}(0.15 \mathrm{~W}) \text { - Typical } \\ 275 \mathrm{~mA}(0.25 \mathrm{~W}) \text { - Maximum } \end{array}$ |
|  |  |
| Buffer Module | $+5 \mathrm{~V} \pm 5 \% 190 \mathrm{~mA}(0.95 \mathrm{~W})$ - Typical $330 \mathrm{~mA}(1.7 \mathrm{~W})$ - Maximum |
| Environment |  |
| Operating Temperature | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| Storage Temperature | $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ |
| Relative Humidity | 0\% to $85 \%$ (without condensation) |
| Propagation Time | 50 ns - Maximum |
| Interface Connectors |  |
| AIM 65 Expansion Connector | 22/44 - edge receptacle ( 0.156 in. centers) |
| RM 65 Bus |  |
| Edge Connector Version | 72-pin edge connector ( 0.100 in. centers) |
| Eurocard Version | 64-pin plug ( 0.100 in. centers) per DIN 41612 (Row b is not installed) |
| Interface Cables |  |
| Number of Cables | Two |
| Cable Length | 6 feet |
| Type | Flat ribbon |
| Number of conductors per cable | 40 |
| Wire Size | \#28 AWG |

notes:

1. The height includes the maximum values for component height above the board surface ( 0.4 in . for populated modules), printed circuit board thickness ( 0.062 in .), and pin extension through the bottom of the module ( 0.1 in .)
2. The length does not include extensions beyond the edge of the module due to connectors or the module ejector.
3. The Eurocard dimensions conform to DIN 41612.

## CABLE DRIVER ADAPTER MODULE



BUFFER MODULE


Module Dimensions

## RM 65 DATA SHEET

## DESIGN PROTOTYPING MODULE

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state－of－the－art performance，compact size，modular design and low cost． Software for RM 65 systems．can be developed in R6500 Assembly Language，PL／65，BASIC and FORTH．Both BASIC and FORTH are available in ROM and can be incorporated into the user＇s system．

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot．The 64 －line RM 65 Bus offers memory addressing up to 128 K bytes，high immunity to electrical noise and includes growth pro－ visions for user functions．A selection of card cages provides packaging flexibility．RM 65 products may also be used with Rockwell＇s AIM 65 Microcomputer for product development and for a broad variety of portable or desktop microcomputer applications．

## ORDERING INFORMATION

The Design Prototyping Module is available in an Edge Connector version（RM65－7201）and a Eurocard version （RM65－7201E）．

## FEATURES

－Compact size－approximately $4^{\prime \prime} \times 6 \%^{\prime \prime}(100 \mathrm{~mm} \times$ 160 mm ）
－Provision for mounting mass－terminated cable con－ nectors
－All wire－wrap holes pre－drilled on 0.100 in ．centers
－Provision for installing decoupling capacitors
－Spacing for $0.300,0.400$ and 0.600 in ．wide com－ ponents
－+5 V and ground extended throughout the module
－tsolated power strips allow connection to other sup－ ply voltages
－Edge Connector and Eurocard versions

## PRODUCT OVERVIEW

The Design Prototyping Module allows you to develop custom application circuits for installation in any RM 65 motherboard．

Power and return lines are prerouted throughout the mod－ ule．Plated－through holes，spaced beside the power lines， permit wire－wrap sockets to be installed．The hole pattern allows manual or automatic wire－wrapping．The holes at the $1 / O$ end of the module accept a variety of wire－wrap flat ribbon cable connectors．Additional pre－drilled holes permit mounting of decoupling capacitors．

Edge Connector Version RM65－7201
© Rockwell International Corporation 1981
All Rights Reserved
Printed in U．S．A．

Specifications subject to
change without notice
Document No．RMAES N08
Rev．2，March 1981


[^4]F/T = FEEDTHROUGH HOLES

| RM 65 Bus Connector Pin Assignments |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| Signal <br> Mnemonic | Signal Name | Pin | Pin | Signal <br> Mnemonic | Signal Name |
|  | Not Connected (See Note) | Wa | Wc |  | Not Connected (See Note) |
| +5V | +5 Vdc Line (See Note) | Xa | $x_{c}$ | $+5 \mathrm{~V}$ | +5 Vdc (See Note) |
| GND | Ground | 1 a | tc | $+5 \mathrm{~V}$ | +5 Vdc |
| BADR/ | Buffered Bank Address | 2a | 2 c | BA15/ | Buffered Address Bit 15 |
| GND | Ground | 3a | 3 c | BA14/ | Buffered Address Bit 14 |
| BA13/ | Bulfered Address Bit 13 | 4 a | 4 c | BA12/ | Buffered Address Bit 12 |
| BAII/ | Buffered Address Bit 11 | 5 | 5 c | GND | Ground |
| BA10/ | Buffered Address Bit 10 | 6 a | 6 c | BA9/ | Buffered Address Bit 9 |
| BA8/ | Buffered Address Bit 8 | 7 a | 7 c | BA7/ | Buffered Address Bit 7 |
| GND | Ground | 8 a | 8 c | BA6/ | Buffered Address Bit 6 |
| BA5/ | Buffered Address Bit 5 | 9 a | 9 c | BA4/ | Buffered Address Bit 4 |
| BA3/ | Buffered Address Bit 3 | 10a | 10c | GND | Ground |
| BA2/ | Buffered Address Bit 2 | 11a | 11 c | BA1/ | Buffered Address Bit 1 |
| BAO/ | Buffered Address Bit 0 | 12a | 12 c | 8ø1 | Buffered Phase 1 Clock |
| GND | Ground | 13a | 13c | BSYNC | Buffered Sync |
| BSo | Buffered Set Overflow | 14a | 14 c | BDRQ1/ | Buffered DMA Request 1 |
| BROY | Buffered Ready | 15a | 15 c | GND | Ground |
|  | User Spare 1 | 16a | 16c | . $12 \mathrm{~V} / \mathrm{V}$ | $.12 \mathrm{Vac} / \mathrm{V}$ |
| +12V/+V | +12 Vdc/+V | 17a | 17 c |  | User Spare 2 |
| GNO | Ground Line | 18a | 18 c | BFLT/ | Buffered Bus Float |
| BDMT/ | Buffered DMA Terminate | 19a | 19c | Bø0 | Buffered External Phase 0 Clock |
|  | User Spare 3 | 20a | 20c | GND | Ground |
| BR/W/ | Buffered Read/Write "Not" | 213 | 21 c | BDRQ2/ | Buffered DMA Request 2 |
|  | System Spare | 22a | 22c | BR/W | Buffered Read/Write |
| GND | Ground | 23a | 23 c | BACT/ | Buffered Bus Active |
| BIRQ/ | Buffered Interrupt Request | 24a | 24 c | 8NMI/ | Buffered Non-Maskable Interrupt |
| Bø21 | Buffered Phase 2 "Not" Clock | 25a | 25c | GND | Ground |
| B92 | Buffered Phase 2 Clock | 26a | 26 c | BRES/ | Buffered Reset |
| BD7/ | Buffered Data Bit 7 | 27a | 27c | B06/ | Buffered Data Bit 6 |
| GND | Ground | 28a | 28 c | BD5/ | Buffered Data Bit 5 |
| B041 | Buffered Data Bit 4 | 29a | 29c | BD3/ | Buffered Data Bit 3 |
| BD2/ | Buffered Data Bit 2 | 30a | 30 c | GND | Ground |
| BD1/ | Buffered Data Bit 1 | 31a | 31 c | BDO/ | Buffered Data Bit 0 |
| $+5 \mathrm{~V}$ | +5 Vdc | 32a | 32 c | GND | Ground |
| +5V | +5 Vac (See Note) | Ya | Yc | $+5 \mathrm{~V}$ | +5 Vdc (See Note) |
|  | Not Connected (See Note) | Za | zc |  | Not Connected (See Note) |
| NOTE <br> Pins Wa, Wc, $\mathrm{Xa}_{\mathrm{a}}, \mathrm{X}_{\mathrm{c}}, Y_{\mathrm{a}}, Y_{c}, \mathrm{Z}_{\mathrm{a}}$ and Zc are not used on Eurocard version. |  |  |  |  |  |
|  |  |  |  |  |  |

## INSTALLATION

1. Solder jumpers between the isolated power strips and the power $(+5 \mathrm{~V},+12 \mathrm{~V} /+\mathrm{V}$, or $-12 \mathrm{~V} /-\mathrm{V})$ traces as required.

## CAUTION

> Before proceeding, ensure that the power strips are not shorted to GND.
2. Solder power filter capacitors as required between the power strips and GND.
3. Install and wire components on the Design Prototype Module:
a. Insert wire wrap sockets into the desired holes. Solder two pins (on opposite ends of the socket) to the associated feedthrough to hold the socket in place.
b. Insert the solder stakes for mounting of discrete components, power connection and test points into the desired holes and solder to the associated feedthroughs.
c. Insert and solder individual or strip stakes into connector holes for all RM 65 bus signals used on the module.
d. Wire wrap wires between the protruding pins and other pins or power/GND treces as required.
4. Double check the hookup to ensure proper connection.

## CAUTION

Ensure that no power lines are shortad to GND before installation into the RM 65 bus. Shorting power to ground may damage your circuitry, module, power supply and/or interfacing modules unless proper current limiting protection is provided.
5. Install components into sockets as required.
6. Remove power from the RM 65 bus.

## CAUTION

Never install or remove modules with power on it may cause damage to your module and/or host system.
7. Insert the module in the RM 65 Bus motherboard or single card adapter receptacle.
8. Apply power to the RM 65 bus.

Design Prototyping Module Physical and Electrical Characteristics

| Characteristic | Value |  |
| :---: | :---: | :---: |
| Physical Characteristics (See Notes): | Edge Connector Version | Eurocard Version |
| Width | $3.9 \mathrm{in}.(100 \mathrm{~mm})$ | 3.9 in . $(100 \mathrm{~mm})$ |
| Length | $6.5 \mathrm{in} .(164 \mathrm{~mm})$ | 6.3 in . (160 mm) |
| Height | 0.06 in . ( 1.6 mm ) | 0.56 in . ( 14 mm ) |
| Weight | 2.0 02. (55 g) | 2.5 oz ( 65 g ) |
| RM 65 Bus Interface |  |  |
| Edge Connector | 72-pin edge connector ( 0.100 in . centers) 64 -pin plug ( 0.100 in. centers) per DIN 41612 (Row b is not installed) |  |
| Eurocard |  |  |
| Component Mounting Area: |  |  |
| Number of Component Hole Columns: | 36 |  |
| Number of Component Hole Rows: | 36 |  |
| Number of +5 V power strips: | 6 |  |
| Number of isolated power strips: | 4 |  |
| Number of ground strips: | 9 |  |
| Vertical hole spacing: | 0.100 in . |  |
| Horizontal hole spacing: | 0.100 in . |  |

## NOTES:

1. The height includes the maximum values for component height above the board suface ( 0.4 in . for populated modules). printed circuit board thickness ( 0.062 in.), and pin extension through the bottom of the module ( 0.1 in .).
2. The length does not inciude the added extensions due to the module ejector.
3. The Eurocard dimensions conform to DIN 41612.


## RM 65 DATA SHEET

## EXTENDER MODULE

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state－of－the－art performance，compact size，modular design and low cost． Software for RM 65 systems can be developed in R6500 Assembly Language，PL／65，BASIC and FORTH．Both BASIC and FORTH are available in ROM and can be incorporated into the user＇s system．

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot．The 64 －line RM 65 Bus offers memory addressing up to 128 K bytes，high immunity to electrical noise and includes growth pro－ visions for user functions．A selection of card cages provides packaging flexibility．RM 65 products may also be used with Rockwell＇s AIM 65 Microcomputer for product development and for a broad variety of portable． or desktop microcomputer applications．

## ORDERING INFORMATION

The Extender Module is available in an Edge Connector version（RM65－7211）and a Eurocard version（RM65－ 7211E）．

## FEATURES

－Extends all RM 65 Bus Lines
－Terminals for GND and +5 V
－Edge and Eurocard Connector versions
－Assembled，tested and warranted

## PRODUCT OVERVIEW

The RM 65 Extender Module physically extends a module that is electrically connected to an RM 65 motherboard． This simplifies signal tracing and troubleshooting by． providing access to the module outside of its card cage or enclosure．

The RM 65 Extender Module consists of a series of bus lines connecting the RM 65 connector plug on one end， to an RM 65 compatible connector receptacle on the other end．The lines are connected pin－for－pin between the plug and receptacle．


## INSTALLATION

## 1. Turn power off to the RM 65 bus.

## CAUTION

Never install or remove modules with power on it may cause damage to the host system or the modules being connected or disconnected.
2. Remove module to be extended from the RM 65 card cage (if present).
3. Insert the Extender Module in a vacant card slot in the card cage and connect it to the motherboard.
4. Connect the module to be extended to J1 of the Extender Module.

## CAUTION

Be sure the extended module is properly supported to prevent damage to the module and/or the Extender Module.
5. Apply power to the RM 65 bus.

Extender Module Physical and Electrical Characteristics

| Characteristics | Value |  |
| :---: | :---: | :---: |
| Physical Characteristics (see Notes) | Edge Connector | Eurocard |
| Width | $3.9 \mathrm{in} .(100 \mathrm{~mm})$ | 3.9 in . ( 100 mm ) |
| Length | $7.3 \mathrm{in} .(184 \mathrm{~mm})$ | . 7.4 in . (187 mm) |
| Height | 0.56 in . ( 14 mm ) | 0.56 in . (14 mm) |
|  | 3.2 oz (90 g) | $3.2 \mathrm{oz}(90 \mathrm{~g})$ |
| RM 65 Bus Interface: | 72 -pin edge connector ( 0.100 in . centers) 64 pin plug ( 0.100 in. centers) per DIN 41612 (Row b is not used) |  |
| Eurocard |  |  |
| RM 65 Module Interface: |  |  |
| Edge Connector | 72-pin plug (0.100 |  |
| Eurocard | 64 -pin plug ( 0.100 <br> (Row b is not | per DIN 41612 |

## NOTES:

1. The height includes the maximum values for component height above the board surface ( 0.4 in . for populated modules), printed circuit board thickness ( 0.062 in.), and pin extension through the bottom of the module $(0.1$ in.).
2. The length does not include the added extension due to the module ejector.
3. The Eurocard dimensions conform to DIN 41612.


Module Dimensions

## PART NUMBER <br> RM65－7004（E）

## Q）Rockwell <br> RM 65 <br> DATA SHEET

## 4－SLOT PIGGYBACK MODULE STACK（PMS）

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state－of－the－ art performance，compact size，modular design and low cost．Software for RM 65 systems can be developed in R6500 Assembly Language，PL／65，BASIC and FORTH． Both BASIC and FORTH are available in ROM and can be incorporated into the user＇s system．

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot．The 64 －line RM 65 Bus offers memory addressing up to 128 K bytes， high immunity to electrical noise and includes growth provisions for user functions．A set of card cages allows a broad variety of packaging options．RM 65 products may also be used with Rockwell＇s AIM 65 Advanced Interactive Microcomputer for product development and desktop microcomputer applications．

## PRODUCT OVERVIEW

The 4－slot Piggyback Module Stack（PMS）consists of a 4－slot RM 65 Bus compatible motherboard in a card cage． Memory，I／O or special functions may be added to AIM 65 by use of the PMS．When connected to the AIM 65 through the Buffer／Adapter Module，the PMS may be mounted over，under，or behind the AIM 65 in a variety of orientations to meet unique application requirements． The form factor of the PMS allows low profile placement in a table top or terminal style enclosure．

## ORDERING INFORMATION

Rockwell offers all RM 65 modules in both Edge Con－ nector and Eurocard versions．If you plan to use Edge Connector modules，order the RM65－7004 model of the Piggyback Module Stack．Conversely，if you plan to use Eurocard modules，order the RM65－7004E model of the Piggyback Module Stack．

## FEATURES

－4－slot card cage with integral module guides
－Rugged，but lightweight construction
－Accepts axial module cooling fan
－Screw－down terminals for connecting external power（ $+5 \mathrm{~V},+12 \mathrm{~V} /+\mathrm{V},-12 \mathrm{~V} / \mathrm{V}, \mathrm{GND}$ ）
－Predrilled holes for various mounting configura－ tions．
－Assembled，tested and warranted．

| RM 65 Bus Pin Assignments |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| Signal Mnemonic | Signal Name | Pin | Pin | Signal Mnemonic | Signal Name |
|  | Not Connected (See Note) | Wa | Wc |  | Not Connected (See Note) |
| +5V | +5 Vdc Line (See Note) | Xa | Xc | +5V | +5 Vdc (See Note) |
| GND | Ground | 1a | 1c | +5V | $+5 \mathrm{Vdc}$ |
| BADR/ | Buffered Bank Address | 2a | 2c | BA15/ | Buffered Address Bit 15 |
| GND | Ground | 3a | 3 c | BA14/ | Buffered Address Bit 14 |
| BA13/ | Buffered Addresṣ Bit 13 | 40 | 4 c | BA12/ | Buffered Address Bit 12 |
| BA11/ | Buffered Address Bit 11 | 5 a | 5 c | GND | Ground |
| BA10/ | Buffered Address Bit 10 | 6 a | 6 c | BA91 | Buffered Address Bit 9 |
| BA8/ | Buffered Address Bit 8 | 7a | 7c | BA7I | Buffered Address Bit 7 |
| GND | Ground | 8 a | 8 c | BA6/ | Buffered Address Bit 6 |
| BA5/ | Buffered Address Bit 5 | 9a | 9 c | BA4/ | Buffered Address Bit 4 |
| BA3/ | Buffered Address Bit 3 | 10a | 10c | GND | Ground |
| BA2/ | Buffered Address Bit 2 | 11a | 11c | BA1/ | Buffered Address Bit 1 |
| BAO/ | Buffered Address Bit 0 | 12a | 12c | Bø1 | Buffered Phase 1 Clock |
| GND | Ground | 13a | 13c | BSYNC | Buffered Sync |
| BSO | Buffered Set Overflow | 14a | 14c | BDRQ1/ | Buffered DMA Request 1 |
| BRDY | Buffered Ready | 15a | 15c | GND | Ground |
|  | User Spare 1 | 16a | 16c | . $12 \mathrm{~V} / \mathrm{V} \mathrm{V}$ | -12 Vdc/-V |
| +12V/+V | +12 Vdc/+V | 17a | 17c |  | User Spare 2 |
| GND | Ground Line | 18a | 18c | BFLT/ | Buffered Bus Float |
| BDMT/ | Buffered DMA Terminate | 19a | 19c | B00 | Buffered External Phase 0 Clock |
|  | User Spare 3 | 20a | 20c | GND | Ground |
| BR/W/ | Buffered Read/Write "Not" | 21a | 21c | BDRQ2/ | Buffered DMA Request 2 |
|  | System Spare | 22a | 22c | BR/W | Buffered Read/Write |
| GND | Ground | 23a | 23c | BACT/ | Buffered Bus Active |
| BIRQ/ | Buffered Interrupt Request | 24a | 24c | BNMI/ | Buffered Non-Maskable Interrupt |
| B02/ | Buffered Phase 2 "Not" Clock | 25a | 25c | GND | Ground |
| 802 | Buffered Phase 2 Clock | 26a | 26c | BRES/ | Buffered Reset |
| BD71 | Buffered Data Bit 7 | 27a | 27c | BD6/ | Buffered Data Bit 6 |
| GND | Ground | 28a | 28c | BD5/ | Buffered Data Bit 5 |
| BD4/ | Buffered Data Bit 4 | 29a | 29c | BD3/ | Buffered Data Bit 3 |
| BD2/ | Buffered Data Bit 2 | 30a | 30c | GND | Ground |
| BD1/ | Buffered Data Bit 1 | 31a | 31c | BDO/ | Buffered Data Bit 0 |
| +5V | +5 Vdc | 32a | 32c | GND | Ground |
| +5V | +5 Vdc (See Note) | Ya | Yc | +5V | +5 Vdc (See Note) |
|  | Not Connected (See Note) | Za | Zc |  | Not Connected (See Note) |
| NOTE |  |  |  |  |  |
| Pins Wa, W | c, Ya, Yc, Za and Zc are not used | rocard |  |  |  |

## INSTALLATION

1. Connect power to TB1. The power lines should be long enough to allow the PMS to be oriented and positioned as required.

## WARNING

Ensure that the external power supplies are turned off before connecting to TB-1.
a. Connect $+5 V$ from an external power supply to the terminal marked " +5 ". " +5 " is connected to all +5 V pins on all module receptacles.
b. Connect GND from the power supply to either terminal marked " $G$ ". Both of these terminals are connected to all GND pins on all module receptacles.
c. Connect $+\mathbf{1 2 V} /+V$ from an external power supply to the terminal marked " $+V$ ". " $+V$ " is connected to Pin 17a on each module receptacle.
d. Connect GND from the $+12 \mathrm{~V} /+\mathrm{V}$ power supply to either " G " terminal.
e. Comect $-12 \mathrm{~V} /-\mathrm{V}$ from an external power supply to the terminal marked " $-V$ ". " $-V$ " is connected to Pin 16 c on each module receptacle.
f. Connect GND from the $-12 \mathrm{~V} /-\mathrm{V}$ power supply to either " G " terminal.
2. Install the PMS in the desired position. Mounting holes are provided to allow attachment at the top or bottom of the PMS.

## CAUTION

Ensure that neither the left nor right side of the PMS is blocked such that the flow of forced cooling air is impeded.

## NOTE

If the PMS is positioned on the AIM 65 Master Module, ensure that the PMS feet rest in areas free of components.
3. Attach an axial cooling fan to the left side of the PMS. Connect the cooling fan power leads to the required power supply.
4. To install a module in the PMS:

## CAUTION

Ensure that power is turned off to the PMS motherboard before installing a module.
a. Position the module, component side up, in front of the desired card slot.
Card slot No. 1 (top-most slot) has 0.85 inch of component clearance whereas the other three slots are on 0.6 inch centers. If a module is higher than 0.4 inches above the surface of the module, install it in card slot No. 1.
b. Insert the module into the card guide and slide the module straight in until it touches the mating motherboard receptacle.

## NOTE

The card slot guides may be snug on the inserted module.
c. Ensure that the module connector is positioned properly against the mating receptacle.
d. Press in firmly on the exposed edge of the module until it is firmly seated.
5. To remove a module from the PMS:

## CAUTION

Remove power from the PMS motherboard before removing a module.
a. Lift up on the module ejector tab, if installed; otherwise grasp the exposed edge of the module and pull, to release the module from the mating receptacle.
b. Pult the module straight back until it is free from the card slot guides.

RECOMMENDED 3-5/8" COOLING FANS

ETRI Inc
(704) 289-5423

- Model 760-99×W-182-11115* 115 VAC, $50 / 60 \mathrm{~Hz}, 6$ watts 2500 RPM, 30 CFM 10 oz .
- Model 760-99xW-181-11220* 220 VAC, $50 / 60 \mathrm{~Hz}, 6$ watts 2500 RPM, 30 CFM 10 oz .
*Requires plug-in power cord, 30" long Model 760-9601-6.

ROTRON Inc
(914) 657-6661

- Model WA2F79**

115 VAC, $50 / 60 \mathrm{~Hz}, 13$ watts 3000 RPM, 33 CFM 9 oz .

- Model WA2F77**

220 VAC, $50 / 60 \mathrm{~Hz}, 13$ watts
3000 RPM, 33 CFM
9 oz .
"*Includes two 6" power leads.

| CHARACTERISTICS | VALUE |  |
| :---: | :---: | :---: |
| Outer Dimensions: |  |  |
| Width | 4.96 in. | (126 mm) |
| Length | 8.00 in. | (203 mm) |
| Height | 3.89 in. | $(99 \mathrm{~mm})$ |
| Module Separation: |  |  |
| Slot 1: Center line to Inside |  |  |
| Other Stots: Centerline to |  |  |
| Centerline | 0.6 in. | (15 mm) |
| Weight | 13 oz . | $(370 \mathrm{~g})$ |



## PART NUMBER RM65-7008(E)

## OR Rockwell <br> RM 65 DATA SHEET

## 8-SLOT CARD CAGE

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state-of-theart performance, compact size, modular design and low cost. Software for RM 65 systems can be developed in R6500 Assembly Language, PL/65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot. The 64 -line RM 65 Bus offers memory addressing up to 128K bytes, high immunity to electrical noise and includes growth provisions for user functions. A set of card cages allows a broad variety of packaging options. RM 65 products may also be used with Rockwell's AIM 65 Advanced Interactive Microcomputer for product development and desktop microcomputer applications.

## PRODUCT OVERVIEW

The 8-slot card cage consists of an 8 -slot RM 65 Bus compatible motherboard in a card cage. Memory, I/O or special functions may be added to AIM 65 by use of the 8 -siot card cage. When connected to the AIM 65 through the Buffer/Adapter Module, the card cage may be mounted over, under, or behind the AIM 65 in a variety of orientations to meet unique application requirements. The form factor of the 8 -slot card cage allows low profile placement in a table top or terminal style enclosure.

## ORDERING INFORMATION

Rockwell offers all RM 65 modules in both Edge Connector and Eurocard versions. If you plan to use Edge Connector modules, order the RM65-7008 model of the 8 -card cage. Conversely, if you plan to use Eurocard modules, order the RM65-7008E model of the 8 -slot card cage.

## FEATURES

- 8-slot card cage with integral module guides
- Rugged, but lightweight construction
- Accepts axial module cooling fan
- Screw-down terminals for connecting external power ( $+5 \mathrm{~V},+12 \mathrm{~V} /+\mathrm{V},-12 \mathrm{~V} /-\mathrm{V}, \mathrm{GND}$ )
- Predrilled holes for various mounting configurations
- Assembled, tested and warranted
- Removable jumpers on motherboard support $\pm 12 \mathrm{~V}$ as well as $\pm \mathrm{V}$.


## 




## INSTALLATION

1. Connect power to TB1 and/or TB2. The power lines should be long enough to allow the card cage to be oriented and positioned as required.

## WARNING

Ensure that the external power supplies are turned off before connecting to TB-1 or TB-2.
a. Connect +5 V from an external power supply to either terminal marked " +5 ". " +5 " is connected to all +5 V pins on all module receptacles.
b. Connect GND from the power supply to either terminal marked " $G$ ". Both of these terminals are connected to all GND pins on all module receptacles.
c. Connect $+12 \mathrm{~V} /+\mathrm{V}$ from an external power supply to the terminal marked " $+V$ ". " $+V$ " is connected to Pin 17a on each module receptacle.

## NOTES

1. If both +12 V and +V (e.g., +15 V ) are required, remove the soldered jumper corresponding to pin 17 a between receptacle 3 and 4 on the soldered side of the motherboard. Connect +12 V to TB1 if three or less modules require +12 V , or to TB2 if more than three modules require +12 V . Connect +V to the other terminal strip.
2. If the jumper has been removed and only one voltage is required (i.e., +12 V or +V ), connect the power lead to both TB1 and TB2.
d. Connect GND from the $+12 \mathrm{~V} /+\mathrm{V}$ power supply to either "G" terminal.
e. Connect $-12 \mathrm{~V} /-\mathrm{V}$ from an external power supply to the terminal marked " $-V$ ". " $-V$ " is connected to Pin $16 c$ on each module receptacie.

## NOTES

1. If both -12 V and -V (e.g., -15 V ) are required, remove the soldered jumper corresponding to pin 16 c between receptacle 3 and 4 on the soldered side of the motherboard. Connect -12 V to TB1 if three or less modules require -12 V or to TB2 if more than three modules require -12 V . Connect $-V$ to the other terminal strip.
2. If the jumper has been removed and only one voltage is required (i.e., -12 V or -V ) connect the power lead to both TB1 and TB2.
f. Connect GND from the $-12 \mathrm{~V} /-\mathrm{V}$ power supply to either "G" terminal.
3. Install the card cage in the desired position. Mounting holes are provided to allow attachment at the top or bottom of the card cage.

## CAUTION

> Ensure that neither the left nor right side of the card cage is blocked such that the flow of forced cooling air is impeded.
3. To install a module in the card cage:

CAUTION
Ensure that power is turned off to the card cage motherboard before installing a module.
a. Position the module, component side facing TB1 end, in front of the desired card slot.

Card slot No. 1 (slot closest to TB1) has 0.85 inch of component clearance whereas the other seven slots are 0.6 inch centers. If a module is higher than 0.4 inch above the surface of the module, install it in card slot No. 1.

## CAUTION

If $\pm 12 \mathrm{~V}$ and $\pm \mathrm{V}$ have been connected to different terminal strips (TB1 or TB2), ensure that any modules requiring $\pm 12 \mathrm{~V}$ or $\pm \mathrm{V}$ are installed in the slots corresponding to the proper voltage.
b. Insert the module into the card guide and slide the module straight in until it touches the mating motherboard receptacle.

## NOTE

The card slot guides may be snug on the inserted modula.
c. Ensure that the module connector is positioned properly against the mating receptacle.

## CAUTION

A key is installed in each edge connector receptacle between pin 5 and pin 6. Forcing an edge connector module without a corresponding slot in the plug may damage the receptacle and/or the module.
d. Press in firmly on the exposed edge of the module until it is firmly seated.
4. To remove a module from the card cage:

## CAUTION

Remove power from the card cage motherboard before removing a module.
a. Lift up on the module ejector tab, if installed; otherwise grasp the exposed edge of the module and pull, to release the module from the mating receptacie.
b. Pull the module straight back until it is free from the card slot guides.

Module Specification Table

| Characteristics | Value |
| :---: | :---: |
| Outer Dimensions |  |
| Width |  |
| Length | $4.96 \mathrm{in} .(126 \mathrm{~mm})$ |
| Height | $8.00 \mathrm{in} .(203 \mathrm{~mm})$ |
| Module Separation: |  |
| Slot 1: Center line to Inside Top Cover | $6.40 \mathrm{in} .(162.6 \mathrm{~mm})$ |
| Other Slots: Centerline to Centerline | $0.85 \mathrm{in} .(22 \mathrm{~mm})$ |
| Weight | $0.6 \mathrm{in} .(15 \mathrm{~mm})$ |



## PART NUMBER RM65-7016(E)

## RM 65 DATA SHEET

## 16-SLOT CARD CAGE

## RM 65

The RM 65 product line is designed for OEM and end user microcomputer applications requiring state-of-the-art performance, compact size, modular design and low cost. Software for RM 65 systems can be developed in R6500 Assembly Language, PL/65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

The RM 65 product line uses a motherboard interconnect concept and accepts any card in any slot. The 64 -line RM 65 Bus offers memory addressing up to 128 K bytes, high immunity to electrical noise and includes growth provisions for user functions. A set of card cages allows a broad variety of packaging options. RM 65 products may also be used with Rockwell's AIM 65 Advanced Interactive Microcomputer for product development and desktop microcomputer applications.

## PRODUCT OVERVIEW

The 16 -slot card cage consists of a 16 -slot RM 65 Bus compatible motherboard in a card cage. Memory, I/O or special functions may be added to AIM 65 by use of the 16 -slot card cage. When connected to the AIM 65 through the Adapter/Buffer, the card cage may be mounted over, under, or behind the AIM 65 in a variety of orientations to meet unique application requirements. The form factor of the 16 -slot card cage allows low profile placement in a table top or terminal style enclosure.

## ORDERING INFORMATION

Rockwell offers all RM $65^{\circ}$ modules in both Edge Connector and Eurocard versions. If you plan to use Edge Connector modules, order the RM65-7016 model of the card cage. Conversely, if you plan to use Eurocard modules, order the RM65-7016E model of the card cage.

## FEATURES

- 16-slot card cage with integral module guides
- Rugged, yet lightweight construction
- Screw-down terminals for connecting external power ( $+5 \mathrm{~V},+12 \mathrm{~V} /+\mathrm{V},-12 \mathrm{~V} /-\mathrm{V}, \mathrm{GND}$ )
- Predrilled holes for various mounting configurations
- Assembled, tested and warranted
- Removable jumpers on motherboard support $\pm 12 \mathrm{~V}$ as well as $\pm \mathrm{V}$.


Specifications subject to change without notice


## INSTALLATION

1. Connect power to TB1 and/or TB2. The power lines should be long enough to allow the card cage to be oriented and positioned as required.

## WARNING

Ensure that the external power supplies are turned off before connecting to TB-1 or TB-2.
a. Connect +5 V from an external power supply to either terminal marked " +5 ". " +5 " is connected to all +5 V pins on all module receptacles.
b. Connect GND from the power supply to either terminal marked " $G$ ". Both of these terminals are connected to all GND pins on all module receptacles.
c. Connect $+12 \mathrm{~V} /+\mathrm{V}$ from an external power supply to the terminal marked " $+V$ ". " $+V$ " is connected to Pin 17a on each module receptacle.

## NOTES

1. If both +12 V and +V (e.g., +15 V ) are required, remove the soldered jumper corresponding to pin 17a between receptacle 6 and 7 on the soldered side of the motherboard. Connect +12 V to TB1 if six or less modules require +12 V , or to TB2 if more than six modules require +12 V . Connect +V to the other terminal strip.
2. If the jumper has been removed and only one voltage is required (i.e., +12 V or +V ). connect the power lead to both TB 1 and TB2.
d. Connect GND from the $+12 \mathrm{~V} /+\mathrm{V}$ power supply to either " $G$ " terminal.
e. Connect $-12 \mathrm{~V} /-\mathrm{V}$ from an external power supply to the terminal marked " $-V$ ". " $-V$ " is connected to Pin $16 c$ on each module receptacle.

## NOTES

1. If both -12 V and -V (e.g., -15 V ) are required, remove the soldered jumper corresponding to pin 16 c between receptacle 6 and 7 on the soldered side of the motherboard. Connect -12 V to TB1 if six or less modules require -12 V or to TB2 if more than six modules require -12 V . Connect -V to the other terminal strip.
2. If the jumper has been removed and only one voltage is required (i.e., -12 V or -V ) connect the power lead to both TB1 and TB2.
f. Connect GND from the $-12 \mathrm{~V} /-\mathrm{V}$ power supply to either "G" terminal.
3. Install the card cage in the desired position. Mounting holes are provided to allow attachment at the top or bottom of the card cage.

## CAUTION

Ensure that adequate cooling is provided to keep the temperature of the installed modules within specified operating limits.
3. To install a module in the card cage:

## CAUTION

Ensure that power is turned off to the card cage motherboard before installing a module.
a. Position the module, component side facing TB1 end, in front of the desired card slot.

Card slot No. 1 (slot closest to TB1) has 0.85 inch of component clearance whereas the other fifteen slots are 0.6 inch centers. If a module is higher than 0.4 inch above the surface of the module, install it in card slot No. 1.

## CAUTION

If $\pm 12 \mathrm{~V}$ and $\pm \mathrm{V}$ have been connected to different terminal strips (TB1 or TB2), ensure that any modules requiring $\pm 12 \mathrm{~V}$ or $\pm V$ are installed in the slots corresponding t the proper voltage.
b. Insert the module into the card guide and slide the module straight in until it touches the mating motherboard receptacle.

## NOTE

The card slot guides may be snug on the inserted module.
c. Ensure that the module connector is positioned properly against the mating receptacle.

## CAUTION

A key is installed in each edge connector receptacle between pin 5 and pin 6. Forcing an edge connector module without a corresponding slot in the plug may damage the receptacle and/or the module.
d. Press in firmly on the exposed edge of the module until it is firmly seated.
4. To remove a module from the card cage:

## CAUTION

Remove power from the card cage motherboard before removing a module.
a. Lift up on the module ejector tab, if installed; otherwise grasp the exposed edge of the module and pull, to release the module from the mating receptacle.
b. Pull the module straight back until it is free from the card slot guides.

Module Specification Table

| Characteristics | Value |
| :---: | :---: |
| Outer Dimensions |  |
| Width |  |
| Length |  |
| Height | $4.96 \mathrm{in} .(126 \mathrm{~mm})$ |
| Module Separation: | $8.00 \mathrm{in} .(203 \mathrm{~mm})$ |
| Slot 1: Center line to Inside Top Cover |  |
| Other Slots: Centerline to Centerline | $11.20 \mathrm{in} .(285 \mathrm{~mm})$ |
| Weight | $0.85 \mathrm{in} .(22 \mathrm{~mm})$ |



SYSTEM 65
DEVELOPMENT
SYSTEM

The Third-Generation
R6500 Microcomputer System
Puts the Economics on Your Side . . .
Rockwell Adds
Solid Development Support
with the


MICROCOMPUTER DEVELOPMENT SYSTEM

(1) Rockwell 0 Rockwell 0 Rockwell 1 Rockwell 1 Rockwell R Rockwell Rockwell


SYSTEM 65 has been designed by Rockwell to meet all of the development needs of the R6500 Microcomputer System.

Rockwell
1 Rockwell

## We Think It's More Practical than Any Other Microcomputer Development System ... And with a Disk Operating System at Under \$5500, You Know the Price is Right . . .

Rockwell has included in the SYSTEM 65 every design requirement we've encountered in our long microprocessor experience. (We've been selling microprocessors since 1972, and most industry analysts rate us among the technology's leaders.)

We designed SYSTEM 65 around Rockwell's powerful R6502 CPU. We included two mini-floppy disk drives and a 16 K byte static NMOS RAM memory for your software. And we didn't cheat you out of any of this program storage. Our lineoriented, symbolic Text Editor with character and string functions, and our two-pass Assembler and symbolic Debug/Monitor Package are totally stored in ROM. The disk and RAM storage is yours to use.

We made our system software commands easy to use - they're initiated with a single keystroke and they automatically send back meaningful prompts if any additional information is required.

From intimate knowledge of the interfacing requirements Designers encounter during microcomputer development, we included RS-232C and current loop interfaces to accept serial input terminals with operating speeds of between 110 baud and 9600 baud. We added an 8 -bit parallel port to permit automatic interfacing to high-speed printers. And because we know how the imaginations of Designers grow as they work with a microcomputer system as versatile as the R6500, we provided six vacant slots in the SYSTEM 65 chassis so that system memory and I/O capability can be expanded at will.

## Here's a Summary of Reasons Why SYSTEM 65 is Just What You're Looking For . . .

- Rockwell R6502 microprocessor (CPU) operates at 1 MHz or (optionally) 2 MHz , and has 65 K byte addressing and multi-level interrupts.
- Dual, user-dedicated mini-floppy disk drives. Each drive has a 60 -file, 78 K byte storage capacity
User-dedicated 16K byte static RAM memory, expandable in 16 K byte increments
- Integral power supply
- System firmware resides in static ROM, fast operation with no loading or reloading required
- Symbolic Text Editor performs line, string and character editing functions
- Two-pass Assembler can accept source input from either RAM memory or disk and direct object output to any system device
- Symbolic Debug/Monitor package operates in single step or real-time
- Eight software breakpoints, for debugging
- Hardware breakpoint on any fetch, read or write to a specified memory location. Scope sync pulse on rear panel connector with each occurance of hardware breakpoint, for real-time debugging.
- Individual RS-232C and current loop interfaces support serial input terminals from 110 baud to 9600 baud
- 8 -bit parallel port provides automatic support of high-speed printers for hard copy
- Six vacant circuit board slots tied to system bus, for memory and I/O expaṇsion

[^5]
## Here Are the SYSTEM 65's Hardware Details

The SYSTEM 65 enclosure contains four printed circuit modules:

- CPU Module holds the R6502 microprocessor and its supporting circuits, and serial baud rate select switch
- Monitor Module contains 1K bytes of static RAM and 14 K bytes of static ROM, which holds all system software
- RAM Memory Module contains 16K bytes of user-dedicated static RAM
- I/O Module provides the hardware interface to the system input/output devices
Note that since all RAM memory is static, the processor is not required to provide the clock and strobe functions associated with dynamic memory.

The SYSTEM 65 enclosure also has six vacant slots, which allow users to add any combination of memory and I/O interfaces in building a customized development system.

The built-in mini-floppy disk drives can each hold up to 60 files with a per drive storage capacity of 78 K bytes. Like the RAM memory, the mini-floppy disk drives are $100 \%$ user-dedicated.

The RUN/STEP switch on the front panel allows you to select either single step execution or realtime execution of programs.

The back panel has four device connectors: an 8 -bit parallel port for connecting a high-speed printer, an RS-232C serial interface connector, a current loop serial interface connector and a scope sync connector. The CPU Module has a rotary switch to select any of eight baud rates - 110, $150,300,600,1200,2400,4800$ or 9600 baud for compatability with the serial input/output device.

## And Rockwell offers these options to SYSTEM 65:

- PL/65 High-Level Language
- USER 65 in-circuit emulation option
- PROM Programmer Module, for programming a 2704/2708/2716/2758 PROM device from the front panel socket
- R6500/1 Personality option, for developing with the R6500/1. single-chip microcomputer
- 16K x 8 Static RAM Modules
- PROM/ROM Module, accepts 2316/2332 ROM or 2708/2716/2758 PROM devices
- Wire-wrap Design Prototyping Module
- Extender Card for circuit probing

Here Are the SYSTEM 65's Software Details

## The Text Editor

The SYSTEM 65 Text Editor is used to prepare user programs for assembly. The Text Editor writes the program source code into RAM memory from any system device and, when editing has been completed, writes it to any system device. The editing operation can include line editing, string editing and character editing.
The line-oriented commands provide overall control in finding lines to be edited, and specify the system devices for input and output of text. The string-oriented commands can be used to insert program source code into memory, or to search for an existing character string - perhaps a program label or a certain opcode/operand combination and (if desired) provide a substitute for that string. The character-oriented commands provide control over the cursor position on a line and a character delete command.

## Text Editor Command Summary

## Line-Oriented Commands

R - Read lines into text buffer from [device]
I - Insert one line from system terminal
K - Delete [count] lines of text, starting with current line
U - Backspace [count] lines of text
D - Advance [count] lines of text
T - Go to top (beginning) line of text; i.e., re-enter Text Editor

B - Go to bottom (last) line of text
L - List [count] lines on [output device]
? - Show address of current and last lines
G - Go to line [number]
(sp) - Show current line

## String-Oriented Commands

F - Find [string], starting with current line
C - Find [string], starting with current line, and change it to [string]
A - Add [string] to line, starting with current cursor position
Character-Oriented Commands
1 - Delete current character

+     - Advance cursor [count] positions
-     - Backspace cursor [count] positions

Miscellaneous
Q - Exit to Debug


## The Assembler

The SYSTEM 65 Assembler is a two-pass assembler that includes the option to list only the errors detected, if any. This "errors-only" option generates a display of all source statements that contain syntax errors, unresolved references and the like. With the results of this quick check, the Text Editor can be used to make the proper corrections before the Assembler generates the full assembly listing, symbol table and object code. The "errors-only" option can prove to be quite a timeand paper-saver.

The Assembler can accept input from either RAM memory or disk, and has a powerful chaining feature that allows multiple disk files of a large program to be assembled in one operation. These files may reside on either disk, or even on a disk that has not been mounted (the Assembler will direct you to mount it).

For output, the Assembler gives the user complete control over the extent of the listing, which system device will receive the output and whether the entire text of ASCII strings is to be output.

## The Debug/Monitor Package

The SYSTEM 65 Debug/Monitor package provides a comprehensive set of easy-to-use commands and functions for debugging development programs in either single step or real-time mode.

The register commands allow you to display the current contents of the Processor registers, and to selectively alter any of these registers.
The memory commands allow you to display the contents of memory in blocks of eight locations, to alter one or more consecutive locations and to write protect any 8 K block of addresses in memory. Further, memory can be loaded from or output to any system device.
Debug also has a compliment of breakpoints, to give you an easy way to trace program execution. Upon encountering a breakpoint the program displays a symbolic disassembly of the label (if any), opcode and operand field at the breakpoint location. This important feature ties the symbol table, created by the Assembler, with the Debug software. This means that all debugging is done at the assembler language level - without the need to plod through machine code printouts. There are eight software breakpoints and one hardware breakpoint (in addition to the BRK instruction in the R6500 instruction set).

The Debug command set includes all the commands necessary to set and clear software breakpoints, as well as to enable and disable them.

Debug also makes disk management virtually transparent, reducing functions like initializing, compressing, opening and deleting files to single keystroke commands.

## Debug/Monitor Command Summary

Invoke Assembler/Editor

E - Enter Text Editor
T - Re-enter Text Editor, to edit current source
N - Invoke Assembler

## Display/Alter Registers

R - Display registers (Program Counter, Accumulator, X, Y, Status and Stack Pointer)

*     - Alter Program Counter to [address]

A - Alter Accumulator to [byte]
X - Alter $X$ Register to [byte]
Y - Alter Y Register to [byie]
P - Alter Processor Status to [byte]
S - Alter Stack Pointer to [byte]

## Display/Alter Memory

M - Display eight memory locations, starting with [address]
(sp) - Display next eight memory locations
/ - Alter current memory locations, starting with [address]
W - Display/alter write protect status

## Load/Dump Memory

L - Load object code into memory from [input device]
D - Dump memory from [address] to [address[ to [output device]

## Manipulate Breakpoints

\# - Clear all software breakpoints
4 - Toggle software breakpoint enable on/off
B - Set/clear software breakpoint addresses
? - Display software breakpoint addresses
C - Display/alter hardware breakpoint

## Control Execution/Trap

G - Execute user's program, at currect Program Counter address
Z - Toggle instruction trace mode on/off
V - Toggle register printout on trapping on/off
J - Print register header
H - Display trace history stack, 10 addresses

## Disk Functions

1 - Special disk functions (compress, list, rename, recover, initialize)
2 - List disk directory
3 - Delete file

## Program Development - The Easy SYSTEM 65 Way

SYSTEM 65 means productivity by making your program development easy from start to finish. The flowchart at the right shows you how it's done.

After designing the program and writing the source code, you will be using the Text Editor to enter the code into RAM memory. Like all system software, the Text Editor is resident in the system ROM, so there is no need to load it from any external source. The Text Editor is line-oriented, but also has string and character manipulation functions. It includes the capability of searching for a specified character string - for example, a label or an opcode-and-operand combination - and replacing it with a different string.

If a program is small relative to available memory (most programs will fit in the standard 16 K bytes of RAM) it can remain there through the editing, assembling and debugging processes. Very large programs are usually developed in pieces, stored on disk, and later linked together by the Assembler. SYSTEM 65 is designed to permit easy communication with disk, by handling all files by their logical names and automatically creating each file when its filename is first used.

With the source code entered and edited (and if necessary stored on disk), it can now be assembled. The SYSTEM 65 resident Assembler is called by a single key stroke. The Assembler is a two-pass assembler that includes the option to list only the errors detected. This "errors-only" option is usually used as a first quick, easy check on the integrity of your program. If errors are found, they can be corrected by recalling the Text Editor.

When all errors have been eliminated, the Assembler is used to generate a full assembly listing, symbol table and object code. At this point the symbolic Debug program is used to test and correct the program. Debug may use the symbol table produced by the Assembler, so your original source code labels can be carried through to the debug process. When the program is in completed form and error-free, you can run one more assembly to generate a listing for documentation purposes. The object output can also be put on PROM via the optional PROM Programmer, or sent to Rockwell for storage on ROM.


## Where to Get More on SYSTEM 65

To order SYSTEM 65, or to get a copy of the SYSTEM 65 User's Manual (nominal $\$ 5$ charge), contact the nearest Rockwell office or distributor listed on the back of this brochure. For in-depth assistance, obtain the name of your nearest Rockwell sales representative from any Rockwell office.


# R6500 Microcomputer System PRODUCT DESCRIPTION 

## USER 65 OPTION

## OVERVIEW

The USER 65 permits users who are developing R6500-based products to extend the full power of SYSTEM 65 inta their equipment for in-circuit emulation. Available in both 1- and $2-\mathrm{MHz}$ versions (M65-001 and 002), USER 65 supports all ten R6500 CPU's.

USER 65 consists of two modules - a Host Module and a Buffer Module - and two interconnect cables. The USER 65 Host Module replaces the CPU Module in the SYSTEM 65 chassis; it performs all CPU Module functions, plus several external functions. The USER 65 Buffer Module extends the SYSTEM 65 bus lines (address, data and control) to the user equipment.

## FUNCTIONAL DESCRIPTION

## USER 65 HOST MODULE

The USER 65 Host Module (shown in block diagram form in Figure 1) replaces the CPU Module in the SYSTEM 65 chassis. It is capable of performing all functions of the CPU Module, plus external address selection, automatic power up, and external clock selection. The schematic of the Host Module is PS00. $\times 183$. The Host Module interface signals are listed in Table 1.

The heart of the Host Module is the R6502 (Z11) microprocessor. It controls all functions of the SYSTEM 65 and the user's external equipment. Crystal Y 1 ( 1 or 2 MHz ) generates the internal clock for the R6502 CPU. Switch S3 is used to select either the internal generated clock or an externally provided clock input.

The Host Module has automatic power-up circuit consisting of an NE555 timer (Z3) and associated discrete capacitors and resistors. This circuit will generate a 100 msec reset pulse following power-up.


Figure 1.USER 65 Host Module Functional Block Diagram


The Host Module also contains the RS-232C and TTY baud rate generator circuitry. Crystal Y2 $(1.8432 \mathrm{MHz})$ and baud rate generator MC14411 (Z13) generate a baud rate clock. The Clock rate is multiplied by $16(\times 16)$ to provide a selectable output baud rate from 110 to 9600 . Switch S4 and the SN74152 (Z12) select the baud rate. This output is then provided to the SYSTEM 65 bus to be used by the Monitor Module.

The internal/external address selection is based on a decode of A15-A12, using an SN74159N (Z1) decoder. This device has sixteen active low outputs. Eaçh output represents a 4 K address space and is selected by Switches S1 and S2. The outputs are ORed together and inverted by SN7406 (Z2). This enable signal is then gated with $\mathrm{R} \bar{N}$ signal to form a READ signal and a WRITE signal, which are used in the USER 65 Buffer Module.

The address lines and control tines $61, \not \subset 2, \overline{D M A}$, and SYNC are buffered with I.C.'s 8 T97 (Z8-Z10, Z5). The data lines are inverted and buffered with I.C.8T26 (Z6, Z7). All of these lines are brought to the SYSTEM 65 bus and are also taken out to the USER 65 Buffer Module through series terminators (Ai-A4).

The Control lines S.O., RDY, $\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}, \overline{\mathrm{I} Q}$ are brought to the SYSTEM 65 bus and are also brought from the USER 65 Host Module, then buffered with open collector buffers SN7407(Z15). These inputs come only from the user's equipment; the RESET switch on the front panel will not reset the external equipment.

SYSTEM 65 bus line $\overline{D M A}$ is used to control the address and data bus lines. This line is pulled up internally with a 3 K resistor. By pulling $\overline{\mathrm{DMA}}$ low, the address, data and R/W lines are set to the float state, allowing an external board to control them for DMA operations. The DMA line does not stop the CPU - this must be done by controlling the RDY line as outlined in the R6500 Microprocessor Data Sheet (29000 D39).

[^6]Table 1. USER 65 Host Board to Buffer Board Interface Signals

Note: Even-numbered pins are connected to Ground.

| CONNECTOR J1 |  | CONNECTOR J2 |  |
| :---: | :---: | :---: | :---: |
| PIN | SIGNAL | PIN | SIGNAL |
| 1 | A0 | 1 | EXT. CLOCK |
| 3 | A1 | 3 | $\not \varnothing_{2}$ |
| 5 | A2 | 5 | $\phi_{1}$ |
| 7 | A3 | 7 | GATED READ |
| 9 | A4 | 9 | GATED WRITE |
| 11 | A5 | 11 | $\overline{\mathrm{D7}}$ |
| 13 | A6 | 13 | D6 |
| 15 | A7 | 15 | $\overline{\text { D5 }}$ |
| 17 | A8 | 17. | $\overline{\mathrm{D4}}$ |
| 19 | A9 | 19 | D3 |
| 21 | A10 | 21 | $\overline{\text { D } 2}$ |
| 23 | A11 | 23 | $\overline{\mathrm{D} 1}$ |
| 25 | A12 | 25 | DO |
| 27 | A13 | 27 | $+5 \mathrm{~V}$ |
| 29 | A14 | 29 | $+5 \mathrm{~V}$ |
| 31 | A15 | 31 | +5V |
| 33 | SYNC | 33 | $+5 \mathrm{~V}$ |
| 35 | R/W | 35 | +5V |
| 37 | RDY | 37 | $+5 \mathrm{~V}$ |
| 39 | RESET | 39 | $+5 \mathrm{~V}$ |
| 41 | $\overline{\mathrm{NMI}}$ |  |  |
| 43 | IRO |  |  |
| 45 | So |  |  |

## USER 65 BUFFER MODULE

The USER 65 Buffer Module receives the address, data and control lines from the USER 65 Host Module, buffers these signals and interfaces them to the user's equipment. Figure 2 is a block diagram. The schematic of the USER 65 Buffer Board is P500-X193.

The address lines, SYNC and R/W lines are buffered with I.C.'s 8 T97 (Z1-Z3). The control lines RDY, $\overrightarrow{\operatorname{RES}}, \overline{\mathrm{NMI}}, \overrightarrow{\mathrm{RQ}}$, and S.O. are buffered with open collector I.C.'s SN7407 (Z4). The data lines are inverted and buffered with I.C.'s 8T26A (Z7 and Z8). They have series terminators of 150 ohms (Z9).

The 01 and 02 clocks are buffered by 8 T97 (25). To use an external clock, jumper $N$ must be installed. To use 01 , jumper $M$ must be instalted. The DBE signal is provided for use during emulation of the R6512 CPU. This line has an internal pullup resistor of 3 K . When brought low it will disable the data bus drivers.

Two other signals, READ and WRITE, are buffered by Z5. The READ signal is generated by the Host Module and is high when the $R \bar{W}$ line is high and an external address is active. The WRITE signal, also generated by the Host Module, is high when $R \bar{W}$ line is low and an external address is active. These two lines control the data bus buffers $\mathrm{Z7}$ and $\mathbf{Z 8}$.


Figure 2. USER 65 Buffer Module Functional Block Diagram

## USER 65 CABLES

The cable assembly supplied with the USER 65 option provides the signal paths between the USER 65 Host and Buffer Modules, and between the Buffer Module and the user's equipment. Since the USER 65 option is designed to emulate all versions of the R6500 Family of CPU's, both a 40 -pin cable and two 28 -pin types of cables are provided.

## INSTALLATION

## USER 65 HOST MODULE INSTALLATION

Install the USER 65 Host Module in the SYSTEM 65 as follows:

## 1. Turn SYSTEM 65 power off.

## CAUTION

Never install or remove modules with SYSTEM 65 power on it may cause damage to the module and/or to the system.
2. Remove the top cover of the SYSTEM 65.
3. Remove the CPU Module.
4. Set switches S1, S2, S3 and S4 on the USER 65 Host Module per Table 2. The switch positions are shown in Figure 3.
5. Plug the USER 65 Host Module into any convenient slot in the SYSTEM 65 chassis.
6. Route the cables from the Buffer Module through the back panel of SYSTEM 65, through the slot provided.
7. Connect the 40 - and 50 -pin cables from the Buffer Module to the top of the Host Module (the connectors are keyed with arrows).
8. Set switches S1 and S2 on the RAM Module per Tables $\mathbf{3}$ and 4 to enable/disable and to select the address range of the internal SYSTEM 65 RAM.

NOTE
If external RAM addresses are selected on the USER 65 and the same addresses are selected and enabled on the SYSTEM 65 internal RAM board(s), the internal RAM will override and prevent proper operation of the external RAM.
9. Install the top cover of the SYSTEM 65.


Figure 3. USER 65 Host and Buffer Modules

Table 2. USER 65 Host Module Switches

| SWITCH | FUNCTION |
| :---: | :---: |
| S1/S2 | ADDRESS SELECT <br> These switches determine whether address selection is internal or external for each 4 K byte portion of memory space. External memory is selected when the switch is ON, internal memory is selected when the switch is OFF. |
| S3 | CLOCK SELECT <br> Switch S3 selects either the SYSTEM 65 clock (INT) or an external, user-supplied clock (EXT). If an external supplied clock is used, the frequency must be 1 or $2 \mathrm{MHz}+1 \%$ if operation of the SYSTEM 65 mini-floppy disks is required. It must always be a TTL level, square wave, clock input. |
| S4 | BAUD RATE SELECT <br> This switch determines the baud rate for either the RS-232C or TTY ports. Switch settings are: |

Table 3. RAM Module Enable/Disable Switch Definition

| Switch S1/S2-4 Position | RAM Enable/Disable State |
| :---: | :--- |
| Up | RAM Disabled (Deselected) |
| Down | RAM Enabled (Selected) |

Table 4. RAM Address Range Select Switch Settings

| Switch S1/S2 Position |  |  | 8K Address Range Selected |
| :---: | :---: | :---: | :---: |
| -1 | -2 | -3 |  |
| Up | Up | Up | \$0000 - \$1FFF |
| Down | Up | Up | \$2000 - \$3FFF |
| Up | Down | Up | \$4000 - \$5FFF |
| Down | Down | Up | \$6000 - \$7FFF |
| Up | Up | Down | \$8000 - \$9FFF |
| Down | Up | Down | \$A000- \$8FFF |
| Up | Down | Down | \$C000- \$DFFF |
| Down | Down | Down | \$E000- \$FFFF |

Note: " $U p$ " is toward the top edge of the module

## USER 65 BUFFER MODULE INSTALLATION

Since the Buffer Module is designed to support all CPU's in the R6500 family, specific jumpers or straps must be inserted to support the exact CPU being emulated. Table 5 gives the strapping requirements. Jumper locations are shown in Figure 3.

The Buffer Module has two modes for the R/W line. For 40 -pin CPU emulation (R6502 and R6512), the R/W line is connected to the user's equipment as is. Since the 28 -pin CPU's do not provide all the address lines to the user's equipment, address conflicts can occur during SYS. TEM 65 Monitor execution. A gated R/W line is provided to prevent these conflicts; this line is normally high, and goes low only when an external address is present and $\mathrm{R} / \mathrm{W}$ is low.

The Buffer Module also has straps for clock selection. One strap allows the $\varnothing_{1}$ (OUT) signal to go to the user's equipment. The other strap is used to allow an external clock [ $\varnothing 0$ (IN) or $\varnothing 2$ (IN)] to be used. Switch S3 on the Host Module must be set to EXT when the external clock is used.

The Buffer Module is provided with three sockets and three cables. The 40 -pin socket (J3) should be used for either of the 40-pin CPU's, R6502 or R6512. The cable labeled PS00-D603-001 should be used to connect from J3 to the user's equipment. The other two sockets (J4 and J5) are for use with the 28 -pin CPU's. Table 5 correlates the socket and 28 pin cable to be used for each of the 28 -pin CPU versions.

The DBE (Data Bus Enable) line for the R6512 is available to the user's equipment. There is an internal 3 K pullup resistor in the Buffer Module, so it can be left open if desired. To disable the data output drivers, pull the DBE line low.

The installation procedure is:

1. Remove the top of the USER 65 Buffer Module assembly.
2. Insert the desired jumpers, per Table 5.
3. Connect either the 40 -pin cable to plug J3 or the 28 -pin cable to plug J4 or J5, as appropriate.
4. Reinstall the top of the Buffer Module assembly.
5. Plug the free connector of the cable into the user's equipment.

## NOTE

Any conductive foam must be removed from the CPU plug pins to allow proper SYSTEM 65 operation even when the CPU plug is not connected to user equipment.
6. Turn SYSTEM 65 and user's equipment power on.

Table 5. USER 65 Buffer Module
Connection Requirements
$\begin{array}{|c|c|l|l|l|l|}\hline \begin{array}{c}\text { User } \\ \text { Equipment } \\ \text { CPU }\end{array} & \begin{array}{c}\text { Buffer } \\ \text { Module } \\ \text { Socket }\end{array} & \begin{array}{c}\text { Cable To } \\ \text { User Equipment }\end{array} & & & \text { Jumper }\end{array}$ Signal $\left.\begin{array}{c}\text { User's } \\ \text { CPU } \\ \text { Pin }\end{array}\right]$
*Jumper $N$ is required with an external clock. Switch S3 on the USER 65 Host Module must be positioned to the EXT position when the extended clock or frequency reference is used.

## USER 65 TYPICAL APPLICATION

A typical application for the USER 65 option is depicted in Figure 4.
The user's system may include any combination of ROM's, PROM's, RAM's, I/O devices, and a 40 or 28 -pin CPU socket. For emulation purposes, the USER 65 option is instatled in the CPU socket instead of a CPU. The user must provide page $0(\$ 0000-\$ 00 F F)$ and page 1 ( $\$ 0100$ \$01FF) either internally or externally for use by the SYSTEM 65 Monitor. For system development purposes, the user's ROM may be emulated with one or more RAM modules provided in the SYSTEM 65 chassis. This permits easy manipulation, debugging, and reassembly of the user's program during the development phase. For editing and assembling of the source program, the user may use the SYSTEM 65 RAM or may provide his own RAM modules externally.

The USER 65 option may be used with the SYSTEM 65 Monitor enabled or disabled. With SYSTEM 65 Monitor enabled, the full resources of the .SYSTEM 65 Monitor are available for program checkout and debugging. In this mode the SYSTEM 65 uses addresses \$COOO-\$FFFF; these addresses cannot be used by the programmer.


Figure 4. USER 65 Option Hook-up

## USER 65 HOST AND BUFFER MODULE SPECIFICATIONS

Common Specifications
Operating Frequency: $1 \mathbf{M H z}$ or $2 \mathbf{M H z}$
Operating Temperature: $0^{\circ}$ to $70^{\circ} \mathrm{C}$

Power Requirements: +5 VDC $\pm 5 \%$ @ 1.5A

Host Module Specifications
Module Dimensions: 9.75 in . wide $\times \mathbf{7 . 5 0}$ iñ" high

Edge Contacts: 86 pins on 0.156 in. centers
Edge Contact Signals: SYSTEM 65 compatible
Buffer Module Specifications
Module Dimensions: 4.125 in. wide $\times 7.375 \mathrm{in}$. high
Cable Lengths:

| To | SYSTEM 65 | 60 in. |
| :--- | :--- | :--- |
| To User Equipment | 12 in. |  |

## R6500 Microcomputer System PRODUCT DESCRIPTION

## R6500／1 EVALUATION MODULE

## INTRODUCTION

The R6500／1 Evaluation Module allows a computer program developed for R6500／1 Single Chip Microcomputer to be executed in a stand－alone man－ ner using the R6500／1EAC Emulator Device and an associated PROM．With this capability，the computer program can be validated before being masked into the R6500／1 ROM．

The R6500／1 Evaluation Module consists of：
－An R6500／1 Emulator Board containing
－One R6500／1EAC Emulator Device
－One $2-\mathrm{MHz}$ crystal
－One 7404 Hex Inverter
－Seven jumper positions
－One 24 －pin socket for a PROM
－A 40－conductor ribbon cable terminated at each end with a 40 －pin connector

## REFERENCE DOCUMENTS

R6500／1 One－Chip Microcomputer Data Sheet， 29000 D51
R6500／1E Emulator Device Data Supplement， 29000 D51S
R6500／1 One－Chip Microcomputer Product
Description， 29650 NN8
Document 29000 D51S describes operational differences between the R6500／1 Microcomputer and the R6500／1E Emulator Device

## INSTALLATION PROCEDURE

## CAUTION

Ensure power is disconnected from the R6500／1 socket in the user cir－ cuit belore connecting the R6500／1 Evaluation Module or damage may occur to the user circuit and／or the R6500／1 Evaluation Module．

1．Plug the PROM containing the R6500／1E program into socket $Z 2$ while carefully observing the Pin 1 position．Any of the following PROMs（or compatible equivalents）may be used：

PROM NO．OF BYTES INSTALLED ADDRESS RANGE

| Intel 2716 | 2 K | $\$ 800-\$ F F F$ |
| :--- | :--- | :--- |
| TI TMS2516 | 2 K | $\$ 800-\$ F F F$ |
| Intel 2732 | $4 K$ | $\$ 400-\$ F F F^{*}$ |
| TI TMS2532． | 4 K | $\$ 400-\$ F F F^{*}$ |

＊Addresses $\$ 400$－\＄FFF may be used only with the R6500／1E and are not available in the R6500／1 ROM．Note that only the upper 3 K bytes of a 4 K － byte PROM may be used．


2．Install the jumpers as foliows：
a．Jumpers D and E－Clock Select
Jumpers D and E select the desired crystal or clock configuration．

| FREQUENCY REFERENCE | JUMPER |  |
| :--- | :---: | :---: |
|  | D | E |
| R6500／1 Emulator Module | OUT | OUT |
| Crystal |  |  |
| User Circuit Crysta＊＊ | $\mathbb{N}$ | IN |
| User Circuit Clock＊ | $\mathbb{N}$ | OUT |
|  |  |  |

－Disconnect Crystal Y1 from the R6500／1E Emulator Device by unsoldering the crystal leads from posts E1 and E2．Users who install a 4 MHz crystal must use a PROM with an access time less than 225 ns ．
b．Jumpers A，B，C，F，and G－PROM Select
Jumpers A，B，C，F and G configure the Emulator Module to operate with the desired PROM．

| PROM | JUMPERS |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | A | B | C | F | G |  |
| 2516 | IN | OUT | OUT | OUT | IN |  |
| 2716 | IN | OUT | OUT | OUT | IN |  |
| 2532 | OUT | IN | OUT | OUT | IN |  |
| 2732 | OUT | OUT | $\mathbb{N}$ | $\mathbb{N}$ | OUT |  |

3．Connect the R6500／1 Emulator Module to the user circuit in either of two ways：
a．Connect P1 of the interface cable into J 1 of the R6500／1 Emulator Module and J 1 of the interface cable into the R6500／1 socket in the user circuit．
b．Directly connect the extended pins of J 1 on the R6500／1 Emulator Module into the R6500／1 socket in the user circuit．

4．Apply power to the user circuit．


NOTE : IINLESS DTHERWISE SFECIFIED

1. REFERENCE ASSEMBLY DRAWING PSOI-DIOO
(2) USED ON -OO1 ASSY
(3) USED ON -OII ASSY
(4) -OOI ASSEMBLY REQUIRES A PROM DEV/CE WITH ACCESS TMAE LESS THAN 225ns


## JUMPER DESCRIPTION

| JUMPER A -- Connects address line A11 to pin 18 of the PROM after inverting for 2716 operation. |
| :---: |
| JUMPER B - Connects address line A11 directly to pin 18 of the PROM for 2532 operation. |
| JUMPER C -- Connects GND to pin 18 of the PROM for 2732 operation. |
| JUMPER D - Connects the high side of the external clock or crystal to pin 63 (XTLI) of the R6500/1E Emulator Device. |
| JUMPER E - Connects the low side of the external clock or crystal to pin 64 (XTLO) of the R6500/1E Emulator Device. |
| JUMPER F - Connects address line A11 to pin 21 of the PROM for 2732 operation. |
| MPER G - Connects +5 V to pin 21 of the PROM for 2716 or 2532 operation. |

PROM SOCKET INTERFACE SIGNALS

| PROM <br> Socket Pin Number | PROM Device Type |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} \text { TI } \\ \text { TMS2532 } \end{gathered}$ | $\begin{aligned} & \text { INTEL } \\ & 2732 \end{aligned}$ | $\begin{gathered} \text { TI } \\ \text { TMS2516 } \end{gathered}$ | $\begin{gathered} \text { INTEL } \\ 2716 \end{gathered}$ |
| 1 | A7 | A7 | A7 | A7 |
| 2 | A6 | A6 | A6 | A6 |
| 3 | A5 | A5 | A5 | A5 |
| 4 | A4 | A4 | A4 | A4 |
| 5 | A3 | A3 | A3 | A3 |
| 6 | A2 | A2 | A2 | A2 |
| 7 | A1 | A1 | A1 | A1 |
| 8 | A0 | A0 | A0 | A0 |
| 9 | Q1 | 00 | 01 | 00 |
| 10 | Q2 | 01 | Q2 | 01 |
| 11 | Q3 | 02 | 03 | 02 |
| 12 | VSS | GND | VSS | GND |
| 13 | Q4 | O3 | Q4 | O3 |
| 14 | Q5 | 04 | Q5 | 04 |
| 15 | 06 | 05 | Q6 | 05 |
| 16 | 07 | 06 | Q7 | 06 |
| 17 | Q8 | 07 | Q8 | 07 |
| 18 | A11 | $\overline{C E}$ | PD/PGM | $\overline{C E / P G M}$ |
| 19 | A10 | A 10 | A10 | A10 |
| 20 | PD/ $/ \overline{\mathrm{PGM}}$ | $\overline{\text { OEIVPP }}$ | $\overline{\mathrm{CS}}$ | $\overline{O E}$ |
| 21 | VPP | A11 | VPP | VPP |
| 22 | A9 | A9 | A9 | A9 |
| 23 | A8 | AB | A8 | A8 |
| 24 | VCC | VCC | VCC | vcc |

## COMPONENT DESCRIPTION

Connector J 1 - Connector with extended pins that allows the R6500/1 Evaluation Module to be directly plugged into the R6500/ 1 connector in the user circuit or to be connected to the user circuit R6500/1 connector through the 40 conductor interface cable assembly.

Socket $\mathrm{Z1}$-64-pin DIP socket that contains the R6500/1 EAC 2-MHz Emulator Device.

Socket $\mathrm{Z2}-24$-pin DIP socket, which accepts the user-supplied program PROM

Crystal Y1 - A 2-MHz crystal, which is used to operate the R6500/ 1EAC Emulator Device at 1 MHz .

Inverter Z3 - Inverts R/W to provide a low on pin 20 of the PROM when R/W is high.

- Inverts A11 when jumper A is installed to provide a luw on pin 18 ( $\overline{\mathrm{CS}}$ ) when 2716 is used.

Capacitors C1, C2 and C3-Bypass Capacitors.

Test Point TP1—Test point to monitor ø2.
Test Point TP2-Test point to monitor SYNC.
Test Point TP3-Test point to monitor $\mathbf{R} / \bar{W}$.
Post E1-Crystal solder post to XTLI
Post E2-Crystal solder post to XTLO.

# 0 Rockwell <br> <br> OVERVIEW <br> <br> OVERVIEW <br> The Static RAM Module contains $16 \mathrm{~K}(16,384)$ bytes of Random Access Memory（RAM），implemented with 32 R21．14 $1024 \times 4$ Static RAM devices．The Module also includes address decoding and selection，write protection and data buffering circuitry． 

R6500 Microcomputer System PRODUCT DESCRIPTION

## 16K STATIC RAM MODULE

The Module＇s 16 K bytes of RAM memory are segmented into two independent 8 K－byte sections．Each $8 K$ section is controlled by an enable／disable switch and three address range select switches， located at the top of the Module．Each 8 K section can be inde－ pendently write－protected via special lines．

The Static RAM Module is directly compatible with Rockwell＇s SYSTEM 65 Microcomputer Development System，and can be used to increase the System＇s read／write memory capacity from 16 K bytes to 48 K bytes，without hardware modification．The Module may also be installed into user－designed equipment，via the Auxiliary Card Cage．

## FEATURES

－SYSTEM 65 compatible
－Available in 1 MHz （ 450 ns access）and 2 MHz （250 ns access）versions．
－ 16 K bytes of Random Access Memory，with two indepen－ dent 8 K sections
－Separate write protect capability for each 8 K section
－Static－no clocks or strobes required
－ 9.75 in．$\times 6.00$ in．module
－Single +5 V supply


## FUNCTIONAL＇DESCRIPTION

In reading the text to follow，refer to the Functional Block Dia－ gram below and the attached schematics：
－PSOO－X131，the -001 assembly of the RAM Module
－PSOO－X133，the－071 assembly of the RAM Module
The edge connector pin assignments for the RAM Module are compatible with the Motherboard pin assignments given in Sec－ tion 4 of the SYSTEM 65 User＇s Manual（Document No． 29650 N35）．

The RAM Module＇s 16 K bytes of read／write memory are pro－ vided by 32 R2114 $1024 \times 4$ bit Static RAM devices．

Address Buffers Z47，Z46 and Z33 and Data Buffers Z32 and Z45 present a single TTL load to the Motherboard edge con－ nector．The data signals are inverted to make them compatible with the SYSTEM 65 Data Bus（D0－D7）．

Module Switches S1 and S2 provide independent 8 K RAM section enable／disable and address selection．S1－4 and S2－4 permit each 8 K section of RAM to be enabled or disabled．S1－1，－2 and－3 and S2－1，-2 and -3 select the base address to which the respective 8 K sections will respond．These switch settings are compared to upper address bits A13，A14 and A15 in Address Comparator devices $\mathrm{Z10}$ and Z21．The Comparator outputs enable or disable 1－of－8 Decoder devices $\mathbf{Z 9}$ and $\mathbf{Z 2 0}$ to provide the input chip select signals to the two 8K RAM sections．

Write protection is controlled by seven Write Protect lines，WP1－ WP7，one line for each 8 K section of memory（the towest section， addresses $\$ 0000-\$ 1 F F F$ ，may not be write protected；note that Z48－2 is tied to ground to permanently enable writing to this section）．A low voltage on WP1－WP7 enables writing into the associated 8K section．

When the Address Comparator enables the RAM Device Select Decoders．Address Select switches S1－1 through S1－3 and S2－1 through S2－3 are used by $\mathbf{Z 3 5}$ and $\mathbf{Z 3 6}$ to select one of the seven Write Protect lines．The selected line controls the RAM Write Control signals，Z34－6 and Z34－8．


RAM Module Functional Block Diagram

## INSTALLATION

The procedure below should be used to install 16K Static RAM Modules in the SYSTEM 65 or, with appropriate changes, in an Auxiliary Card Cage.

1. Turn SYSTEM 65 power off.

## CAUTION

Never install or remove modules with SYSTEM 65 pówer on - It may cause damage to the module and/or to the System.
2. Remove the top cover of the SYSTEM 65.
3. The RAM Module has two banks of switches - S1 and S2 one bank for each 8 K section of RAM. Using Tables 1 and 2, select the enable/disable and address range characteristics for each 8 K section.

## NOTES

For proper SYSTEM 65 operation . . .
a. Page 0 (address range $\$ 0000-\$ 00 \mathrm{FF}$ ) and Page 1 ( $\$ 0100$ \$01FF) must be provided in RAM - either internal RAM or external RAM as interfaced by USER 65 or its equivalent.
b. RAM addresses in the range $\$$ C000-\$FFFF are used by the SYSTEM 65 Monitor Board, and must not be enabled in RAM Modules.
4. Insert the RAM Modute(s) into any vacant stot(s) in the SYSTEM 65 chassis.
5. Install the top cover of the SYSTEM 65.
6. Turn SYSTEM 65 power on.

Table 1. RAM Enable/Disable Switch Settings

| Switch S1/S2-4 Position | RAM Enable/Disable State |
| :---: | :--- |
| Up (Off) | RAM Disabled (Deselected) |
| Down (On) | RAM Enabled (Selected) |

Table 2. RAM Address Range Select Switch Settings

| Switch S1/S2 Position |  |  | 8K Address Range Selected |
| :---: | :---: | :---: | :---: |
| - 1 | -2 | 3 |  |
| Up | Up | Up | \$0000 - \$1FFF |
| Down | Up | Up | \$2000 - \$3FFF |
| Up | Down | Up | \$4000 - \$5FFF |
| Down | Down | Up | \$6000 - \$7FFF |
| Up | Up | Down | \$8000 - \$9FFF |
| Down | Up | Down | \$A000 - \$8FFF |
| Up | Down | Down | \$C000 - \$DFFF |
| Down | Down | Down | \$E000 - \$FFFF |

NOTE: "Up" is toward the top edge of the Module.

## SPECIFICATIONS

| Memory Size: | 16K bytes |
| :---: | :---: |
| Word Length: | 8 bits |
| Interface: | SYSTEM 65 compatible |
| Max. Access Time: | 450 ns (P/N M65-031) |
|  | $250 \mathrm{~ns}(\mathrm{P} / \mathrm{N}$ M65-032) |
| Module Components: | 32 R2114 Static $1024 \times 4$-bit RAM devices |
| Module Dimensions: | 9.75 in . wide $\times 6.00 \mathrm{in}$. high |
| Edge Connector: | 86 pins on $0.156-\mathrm{in}$. centers |
| Operating Temperature: | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| Power Requirements: | +5 VDC $\pm 5 \%$ @ 3.0 amps (typical) |

## LOGIC LEVELS

$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \neq 5 \%$

| Characteristic | Symbol | Min | Max | Unit | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Inputs ( $\overline{00}-\overline{D 7}$ ), A0-A15, WP1-WP7. 02, R/W) |  |  |  |  |  |
| Input Low Voltage | $V_{\text {IL }}$ |  | 0.8 | V | $\mathrm{I}_{\mathrm{IL}}=400 \mu \mathrm{a}$ |
| Input High Voltage | $V_{\text {IH }}$ | 2.0 | ${ }^{\text {cc }}$ | $\checkmark$ | $\mathrm{I}_{\mathrm{IH}}=40 \mu \mathrm{a}$ |
| Outputs ( $\overline{\mathrm{DO}}-\overline{\mathrm{DF}}$ ) |  |  |  |  |  |
| Output Low Voltage | $\mathrm{v}_{\mathrm{OL}}$ |  | 0.5 | $v$ | ${ }^{\prime} \mathrm{OL}=48 \mathrm{ma}$ |
| Output High Voltage | $v_{\mathrm{OH}}$ | 2.4 | ${ }^{\text {cce }}$ | V | ${ }^{\prime} \mathrm{OH}=10 \mathrm{ma}$ |

## R6500 Microcomputer System PRODUCT DESCRIPTION

## PROM PROGRAMMER MODULE

## OVERVIEW

The PROM Programmer Module provides SYSTEM 65 users with a means to program, verify, read and check Programmable Read Only Memory (PROM) devices, and supports 2704, 2708, 2716, 2516, 2532 and 2758 devices. The PROM Programmer Module connects directly to the PROM Socket on the front panel of the SYSTEM 65 chassis, via supplied cable.

The Module is supplied with a mini-floppy diskette which holds a set of software routines that allow the user to check a PROM for proper initialization, program the PROM from SYSTEM 65 memory, verify the PROM with SYSTEM 65 memory, and read the contents of the PROM into memory. Utility functions to load, verify and dump memory are also supplied.

## FEATURES

- SYSTEM 65 compatible
- Supports programming of 2704, 2708, 2516, 2532, 2716 (Intel and Texas Instruments) and 2758 PROM devices.
- Comes with software on mini-floppy diskette


## FUNCTIONAL DESCRIPTION

In reading the text to follow, refer to the Functional Block Diagram in Figure 1 and the attached schematic, PSOO-X201. The edge connector pin assignments for the PROM Programmer Module are identical to the Motherboard pin assignments given in Section 4 of the SYSTEM 65 User's Manual (Document No. 29650 N35).

Table 1 summarizes the PROM Socket interface, and applies to both the PROM socket located on the PROM Programmer Module and the PROM socket located on the SYSTEM 65 front panel.

The PROM Programmer Module consists of two R6520 Peripheral Interface Adapters (PIAs), data buffers, address decoders, 26 V power supply, level shifters and power-up circuitry.


The power-up circuitry (Z9) generates an automatic reset during power-up. A reset signal may also come from the Reset line of the SYSTEM 65 Bus.

The PROM Programmer Module contains data bus buffers, Z 12 and $Z 13$, to provide a logical inversion and a single TTL load to the SYSTEM 65 bus signals. The two R6520 PIAs, $Z 5$ and Z8, are used to store the address, data and control information for the PROM device. The address, Read/Write $(R / \bar{W})$, and $\phi 2$ signals are buffered and decoded by Z10, Z11, Z14, Z15 and Z16. PIA No. 1 is addressed at locations $\$$ C018-\$C01B. PIA No. 2 is addressed at locations \$CO1C-\$C01F.

The PROM device receives address lines A0-A9 and data lines DO-D7 directly from the PIA devices. The program lines (see Table 1. PROM socket pin nos. 18, 19 and 20) are level-shifted to provide either $0 \mathrm{~V},+5 \mathrm{~V},+12 \mathrm{~V},+25 \mathrm{~V}$ or +26 V to the PROM device, depending on the device type. The 26 -volt power is generated from the +5 -volt power through a DC-DC converter, Z6, and an adjustable voltage regulator, Z1. Relays XR1 through XR4 are used to switch the power lines (see Table 1, PROM socket pin nos. 21 and 23) to $+5 \mathrm{~V},+12 \mathrm{~V}$ and -5 V to the PROM device, depending on the device type. The .5 V power is generated from the -12 V power line through a voltage regulator, Q9.


Note: All examples were prepared using SYSTEM 65 Operating System Version 3

Figure 1. PROM Programmer Functional Block Diagram

Table 1. SYSTEM 65 PROM Socket Interface Summary

| PROM <br> Socket Pin Number | PROM Device Type |  |  |  |  |  |  | $\begin{array}{\|c} \hline \text { Connector } \\ \text { J1 } \\ \text { Pin } \\ \text { Number } \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 2704 | $\begin{aligned} & \text { Intel } \\ & 2708 \end{aligned}$ | Intel <br> 2758 | $\begin{aligned} & \text { Intol } \\ & 2716 \end{aligned}$ | $\begin{gathered} \text { T.I. } \\ 2716 \end{gathered}$ | $\begin{aligned} & \text { T.1. } \\ & 2516 \end{aligned}$ | $\begin{gathered} \text { т.I. } \\ 2532 \end{gathered}$ |  |
| 1 | A7 | A7 | A] | A7 | A7 | A] | A) | 21 |
| 2 | A6 | A6 | A6 | A6 | A6 | A6 | A6 | 19 |
| 3 | A5 | A5 | A5 | A5 | A5 | A5 | A5 | 17 |
| 4 | A4 | A 4 | A4 | A4 | A4 | A4 | A4 | 15 |
| 5 | A3 | A3 | A3 | A3 | A3 | A3 | A3 | 23 |
| 6 | A2 | A2 | A2 | A2 | A2 | A2 | A2 | 25 |
| 7 | A1 | A1 | A1 | A1 | A) | A1 | A1 | 26 |
| 8 | AO | AO | AO | A 0 | AO | AO | AO | 24 |
| 9 | Do | DO | DO | D0 | 01 | 01 | 01 | 22 |
| 10 | D1 | D1 | D1 | D1 | 02 | 02 | 02 | 20 |
| 11 | D2 | D2 | D2 | D2 | 03 | 03 | 03 | 18 |
| 12 | GNO | GND | GND | GND | vSs | vss | vss | 16 |
| 13 | D3 | 03 | D3 | D3 | 04 | 0.4 | 04 | 10 |
| 14 | D4 | 04 | D4 | D4 | 05 | 05 | 05 | 8 |
| 15 | D5 | D5 | D5 | 05 | 06 | 06 | 06 | 6 |
| 16 | 06 | D6 | D6 | D6 | 07 | 07 | 07 | 2 |
| 17 | D7 | D7 | D7 | 07 | 08 | 08 | 08 | 4 |
| 18 | PGM | PGM | $\overline{C E} / \mathrm{PGM}$ | $\overline{\mathrm{CE} / P G M}$ | CS/PGM | PD/PGM | Al1 | 13 |
| 19 | voo | VDD | GND | A 10 | VDO | A 10 | A10 | 11 |
| 20 | CSTWE | CSTWE | $\overrightarrow{O E}$ | $\overline{O E}$ | A 10 | $\overline{\mathrm{CS}}$ | PO/PGM | 9 |
| 21 | vB8 | VBB | VPP | VPP | vBb | VPP | VPP | 7 |
| 22 | GND | A9 | A9 | A9 | A9 | A9 | A9 | 5 |
| 23 | A8 | A8 | As . | A8 | A8 | A8 | AB | 3 |
| 24 | vcc | vcc | VCC | VCC | $V C C(P E)$ | Vcc | VCC | 1 |

## MODULE INSTALLATION

Install the PROM Programmer Mortule as foltows:

1. Turn SYSTEM 65 power off.

## CAUTION

Never install or remove modules with SYSTEM 65 power on it may cause damage to the module and/or to the System.
2. Remove the top cover of the SYSTEM 65 .
3. Insert the PROM Programmer Module into any vacant slot in the SYSTEM 65 chassis.
4. Connect one end of the supplied cable to the connector on top of the PROM Programmer Module and the other end to the conmector mounted on the inside front panel of SYSTEM 65. Observe the correct polarity of the plugs and sockets; i.e., align the arrows marked on the plugs and sockets.
5. Install the top cover of the SYSTEM 65.
6. Set the SYSTEM 65 RUN/STEP Switch to RUN

## NOTE

The PROM Programmer will not operate properly if the RUN/STEP Switch is in the STEP position.

## 7. Turn SYSTEM 65 power on.

8. The PROM Programmer Module has an automatic reset feature. The standard power-up message should appear on the system terminal device at power-on. A manually-initiated reset may, however, be performed whenever required.

## PROM DEVICE INSERTION/REMOVAL CAUTION

The PROM device is fragile, and dropping, twisting or uneven pressure may break it. Never press down on the window area of the chip

The PROM device may be inserted into SYSTEM 65 front panel socket or into the socket located on the PROM Programmer Module.

## CAUTION

Only one PROM device should be installed at a time -- in either the SYSTEM 65 socket or the PROM Programmer Module socket. Programming with PROM devices installed in both locations mav cause erroneous results and/or damage to the PROM.

## PROM INSERTION/REMOVAL ON THE SYSTEM 65 FRONT PANEL

To insert the PROM device:

1. Push the PROM socket lever out from the SYSTEM 65 front panel, to release pin pressure.
2. Position the PROM device in front of the socket, being careful to observe the Pin 1 location.

## CAUTION

Incorrect PROM installation may cause PROM damage and/or may blow Fuses F1 and F2 on the PROM Programmer Module.
3. Insert the PROM into the socket, then push up and in on the socket lever to apply pressure to the pins.
To remove the PROM device, grasp the PROM device at each end, then push the socket lever away from the SYSTEM 65 front panel to release pin pressure.

## PROM INSERTION/REMOVAL ON <br> PROM PROGRAMMER MODULE

To insert the PROM device, position the PROM device in front of the socket, being careful to observe the PIN 1 location.

## CAUTION

Incorrect PROM installation may cause PROM damage and/or may blow Fuses F1 and F2 on the PROM Programmer Module.

With the PROM properly oriented, gently start all pins evenly into the socket pin guides. Then press firmly and evenly on the device lavoiding contact with the light window) until the device is securely seated.

To remove the PROM device, exert an even, upward force on both sides of the device while counteracting with a lesser, evenly-applied downward force. This will prevent the PROM device from popping out one side and bending or breaking pins still engaged at the other end of the socket.

## OPERATION

The PROM Programmer software allows checking, reading, verifying and programming $2704,2708,2758,2516,2532$ or 2716 type devices. The data/instructions are copied to/from the SYSTEM 65 RAM memory in the address range specified by the user. The user can then transfer this information to/from the diskette (or other $1 / 0$ device) using SYSTEM 65 software routines.

## LOADING THE PROM PROGRAMMER ROUTINES

There is one PROM programmer object file supplied on the PROM Programmer diskette, PROM" $n$, where " $n$ " is the program release revision letter. File PROM*n occupies from $\$ 0200$ to $\$ 0 F F F$. User programs can be loaded starting at $\$ 1000$. To load the PROM* $n$ program, use the SYSTEM 65 Load Command L. Then enter the file name ( $\mathrm{PROM}{ }^{*} \mathrm{n}$ ) and disk drive number desired. Since the PROM* $n$ program may occupy the same memory area in which user's data may reside, an offset may be applied to the user's data to locate it to $\$ 1000$ or above (See Load, Verify and Dump functions with offset). PROM*n. uses page 0 ( $\$ 0080-\$ 009 A)$ and page 1 ( $\$ 0100-\$ 01 F F)$.

## NOTE

The SYSTEM 65 RUN/STEP switch must be in the Run position for PROM programming.

After the program is loaded, use the five (5) key to start the PROM Programmer routines for a 1 MHz system or the six ( $\dot{6}$ ) key for a 2 MHz system. The 5 (or 6) key may also be used for reentry into the PROM Programmer routines. Once the routines are entered, the only way to exit back to the SYSTEM 65 monitor is to press the ESC key, if the program is waiting for input, or the Reset switch.

The PROM Programmer PROGRAM PROM (P) and VERIFY PROM (V) functions require that the data to be programmed and/or verified be in RAM memory prior to execution. If the program data resides on diskette (or other media), use the SYSTEM 65 Monitor L command to load the object code into memory before entering the PROM programmer functions with key 5 (or 6). Alternatively, use the PROM Programmer L command to load the program data with optional offset after the PROM Programmer functions have been entered.

## PROM PROGRAMMER OPERATION

Before entering any of the PROM Programmer functions to follow, ensure that the required PROM device is installed in the desired PROM socket - the SYSTEM 65 front panel socket or the PROM Programmer Module's PROM socket - per the PROM Device Insertion/Removal instructions. The PROM Programmer functions may be entered in the absence of an installed PROM device, but this may cause verify errors.

## CAUTIONS

1. Insert a PROM device only when SYSTEM 65 power is on and either the Monitor prompt ( $<$ ) or the PROM Programmer prompt $(=)$ is the last character displayed on the system terminal. Failure to do so may cause damage to the PROM device.
2. DC power to the PROM device installed in the PROM socket is set to zero upon SYSTEM 65 power-up or depression of the Reset switch. During a PROM Programmer function, DC power is supplied to the PROM socket after entry of the last address, then the commanded PROM programming function is performed. The DC power is removed upon completion of the programming function, before the next PROM Programmer prompt character $\Leftrightarrow$ ) is displayed.

Once started, the routines will ask the user for certain information. This information should be entered on the system terminal. For numbers or addresses, type in the number followed by a space 0 . carriage return to terminate the number. Leading zeros are not necessary. Only the last four digits of the number are used. If a mistake is made before pressing the space bar or carriage return, reenter the correct number (all four digits). If a mistake is made after entering a number, exit the PROM Programmer routines using the ESC key or Reset switch on the front panel and restart with key 5 (or 6). If an invalid command or number is entered the routines will print WHAT? and ask you to reenter.

Figure 2 is an example of a PROM Programmer load and initialization along with the user's response.

Next, the data to be copied to the PROM device can be loaded using the L command. In this example, the file USERIN was loaded. Type 5 (or 6) to start the routines. Next, enter the device type. If a 2716 was entered, the message TMS 2716 (Texas Instruments) PROM? will be printed. Enter Y for yes or N for no. The routines will reprint the device type for verification each time a new function is requested. A single character should now be entered to indicate the function requested as outlined in the subsequent text.

CONE
(5)

PROM FRGÜRGMMER FOR 1 MHZ SVSTEM (VER E)
ENTER 2794, 2708, 2758, 2716, 2516, 2532
ENTER
$=2716$
${ }_{\text {TMS }} \mathbf{N} 2716$ FRCM?
$=\mathrm{N}$
*********************
DEVICE TYFE
2716
ENTER FROM COMMHND: VERIFY(V),FROGRAM(P),RERO(R), OR CHECK(C)
OR MEMOR' COMMFND: VERIFY(F), LOAD (L), DUMP (D), MEM FILL (M), INVERT(I)

## Figure 2. Power-Up and Loarling Responses

## PROM PROGRAMMER RE-ENTRY

After initialization by the (5) or (6) entry and selection of a PROM type, the PROM Programmer function may be re-entered from the SYSTEM 65 Monitor by typing 7. This allows the Monitor to be entered from the PROM Programmer to perform utility functions then the PROM Programmer quickly re-entered to continue PROM operations. Initial entry using key 5 or 6 must be used, however, to change PROM type selection. The message WHAT? will be displayed if Key 7 is typed prior to initialization of the PROM Programmer function.

## ADDRESS SELECTION

The addresses entered are the hexadecimal locations of the RAM memory used for checking, programming, reading, or verifying. The upper address bits are then stripped off to form the address for the PROM devices. In general, the addresses must comply with the following restrictions:

1. Cannot be Page $0(\$ 0000-\$ 00 F F)$ or Page $1(\$ 0100-\$ 01 \mathrm{FF})$.
2. Cannot overlap the PROM Programmer routine for file name PROM* n ( $\$ 0200-\$ 0 F F F$ ).
3. The last address must be greater than or equal to the first address entered.
4. The address range from first to last must not exceed the size of the PROM being programmed.

In addition, there are further restrictions on certain PROM devices, imposed by the PROM manufacturer. The 2704, 2708, and TI TMS2716 must be programmed using their total address space during one programming. This means that the 2704, 2708, and TI TMS2716 must start on a $1 / 2 \mathrm{~K}, 1 \mathrm{~K}$ or 2 K address boundary, respectively. They also have to extend $1 / 2 \mathrm{~K}, 1 \mathrm{~K}$ or 2 K bytes in length, respectively. The 2516 , 2532, 2758 and Intel 2716 do not have this requirement. Therefore, single byte or multi-bytes may be programmed within the address range of the device. The routines are designed to check for any invalid address entered and will print WHAT? and ask for the address again.

## PROGRAM FUNCTION (THE P COMMAND)

The Program Function ( $P$ ) loads the contents of SYSTEM 65 memory into PROM. It is entered by pressing the P key in response to the ENTER command message. The routines will ask where any errors detected during verifying should be printed. This is indicated by the message ERROR LIST OUT=. Enter any of the standard I/O device characters (space for CRT, P for Printer, etc.).

After the first and last address is entered, the routines will check to
see if the PROM is initialized. Since these PROMs are initialized to an all-ones condition by placing them under an ultraviolet light, a check is made prior to programming for an all-one's condition. If any zero is detected in the bounds of the address range entered, the messages PROM NOT INITIALIZED and CONTINUE $Y$ or $N$ will be printed. The user has the option of aborting the programming (type $\mathbf{N}$ for no) and initializing the PROM properly or continuing with the programming by typing the $Y$ (yes) key.

It is possible to change a 1 to 0 with the PROM programmer, but the PROM must be exposed to an ultraviolet light to set the bits back to one's according to the respective manufacturer's specifications. If the PROM is initialized or " $Y$ " entered, a star will be printed every $1-5$ seconds, indicating programming in progress. After programming, the message VERIFYING will be printed and the PROM device will be verified against the specified RAM locations. This is automatically done every time. If there are no errors detected, the message DONE will be printed and the next operation requested. Any errors detected will be printed on the selected I/O device.

Figure 3 shows an example of the Program Function.

## NOTES

1. A verification error showing a series of 1 's in a specific PROM bit position after programming may indicate a poor connector contact caused by improper PROM installation in the PROM socket. See the PROM Device Insertion/Removal instructions.
2. If fuse Ft or F2 on the PROM Programmer Module is blown, the PROM may not verify correctly. Verify that both are good if a verify error occurs.
```
PROM FROGRAMMER FOR 1 MHZ SYSTEM (VER E)
ENTER 2704, 27e8. 2758, 2716. 2516, 2532
T2716
TMS
2716 PROM?
TMS
\(=N\)
```


## ************

```
DEY1C
2716
**************
ENTER PROM COMMAND: VERIFY(V),PROGRFM(P),REAU(R),OR CHECK(C) OR MEMORY COMMFND: VERIFY(F), LORD(L), VUMF (D), MEM FILL(M), INVERT (I)
PR
ERROR LIST
OUT = L
ENTER FIRST RODRESS
ENTER LAST ADORESS
-27FF
PROM NOT INITIALIZE
PROM NOT INITIALI
CONTINUE \(Y\) OR N)
CONT INUE (Y OR N)
- 4
DONE
VERIFYING
DONE
*********************
DEVICE TYPE=
2716
ENTER PROM COMMAND: VERIFY(V), PROGRAM(P), READ(R), OR CHECK(C) OR MEMORY COMMFND: VERIFY(F),LOFO (L), DUMF (D), MEM FILL(M), INVERT (I)
```


## Figure 3. Program Function Example

## VERIFY FUNCTION (THE V COMMAND)

The Verify Function (V) verifies the contents of the PROM with the contents of SYSTEM 65 RAM. It is entered by pressing the $V$ key in response to the ENTEER command message.

The routines will request where any errors detected should be printed. This is indicated by the message ERROR LIST OUT=. Enter any of the standard I/O device characters defined in the SYSTEM 65 User's Manual (space for CRT, P for Printer, etc.). Next, type in the first and last addresses. As soon as the last address is entered, power will be applied to the PROM device and the contents of the PROM compared to the respective content of the RAM. If no errors are found, the message DONE will be printed, and the next operation requested. If errors are detected, the address, contents of PROM, and contents of RAM in disagreement will be displayed/printed on the selected I/O device. Figure 4 shows an example of the Verify Function with errors.

```
P5) PRM PROGRAMMER FOR 1 MHZ SYSTEM (VER E)
ENTER 2704, 2708,2758, 2716, 2516,2532
=271
TMS 2716 FROM?
**********************
DEVICE TYPE=
2716
ENTER PROM COMMPAND: VERIFY(V),PROGRAM(P),RERD(R),OR CHECK(C)
OR MEMORY COMMAND: VERIFY(F),LORD(L), DUMP(D),MEM FILL(M), INYERT<I)
=V VERIFY
ERROR LIST
ENTER FIRST RODRESS
=1000
\begin{subarray}{c}{\mathrm{ ENTERF LAST RODRESS}}\\{\mathrm{ NTFF}}\end{subarray}
ERROR
ADOR PROM RAM
1800
l7FF C8 15
DONE
***********************
2716
ENTER PROM COMMRND: VERIFY(V),FROGRAM(P),READ(R),OR CHECK(C)
    OR MEMORY COMMANO: VERIFY(F),LOAD(L), DUMP (D),MEM FILL(M), INVERT <I)
```

Figure 4. Verify Function Example with Errors

## READ FUNCTION (THE R COMMAND)

The Read Function (R) reads the contents of PROM into SYSTEM 65. RAM. It is entered by pressing the R kev in response to the ENTER command message.

After the first and last addresses are entered, power will be applied to the PROM and the contents copied into the specified RAM locations. When completed, the message DONE will be printed and the next operation requested. Figure 5 shows an example of a Read Function.

The PROM Programmer READ function reads program data into SYSTEM 65 RAM memory from PROM. After reading is complete, save the PROM data on diskette (or other media) using the SYSTEM 65 Monitor D Command after exiting the PROM Programmer functions. Alternatively, use the PROM Programmer D command to dump the data with optional offset before the PROM Programmer functions are exited. The amount to be stored or loaded at one time is limited only by the RAM locations available.

[^7]Figure 5. Read Function Example

## CHECK FUNCTION (THE C COMMAND)

The Check Function (C) is used to check that the PROM is initialized. It is entered by pressing the C key in response to the ENTER command message.

After the first and last addresses are entered, power is applied to the device and all specified locations are checked for \$FF. The message PROM NOT INITIALIZED will be printed if all locations do not contain \$FF. The message DONE will be printed when the Check Function is complete.

Figure 6 is an example of a successful Check Function.

```
fROM fROGRATMMER FOR 1 MHZ SYSTEM (VER E)
ENTER 2704. 2708, 2758, 2716.2516.2532
=2716
TMS 2716 FROM?
=N
**********************
LEVICE TYPE=
2716
ENTER PROM COMMFIND: VERIFY(V),FROGRAM(P),READ(R),OR CHECK<C)
OR MEMORY COMMAND: VERIFY(F),LOFL(L),DUMP(D),MEM FILL(M), INVERT<I)
*C
ENTER FIRST RODRESS
=1006
ENTER LAST GIODRESS
=17FF
PRGM NOT INITIALIZED
vONE
LEVICE TYFE=
2716
**********************
ENTER PROM COMMAND VERIFY(V), PFOGRAM(F), RERO(R),OR CHECK(C)
    GR MEITOR'Y COMMAND VERIFY(F), LOFD(L), DUMP(O), MEM FILL(M), INVERT(I)
```

Figure 6. Check Function Example

## LOAD MEMORY WITH OFFSET FUNCTION (THE L COMMAND)

The Load Memory with Offset Function (L) copies data from an input object code file into memory addresses offset by an entered amount from the addresses on the input file. The entered offset value is additive with carry from bit 15 ignored, e.g.;

| Input File <br> Address | Offset <br> Value |  | Address in <br> Memory |
| :---: | :--- | :---: | :---: |
|  |  |  |  |
| $\$ 1000$ |  |  | $\$ 1000$ |
| $\$ 1000$ | $\$ 2000$ | $\$ 3000$ |  |
| $\$ 7000$ | $\$ 2000$ | $\$ 1000$ |  |
| $\$ E 000$ | $\$ 2000$ | $\$ 1000$ |  |

Figure 7 is an example of the Load Memory with Offset Function.

## (5)

(VECH PFOGAMER FUR 1 MHZ SYSTEM (VER E)
ENTER 2784, 2788, 2758, 2716, 2516, 2532
TMS 2716 FRGM?
=N
EVIG**************
VEVICE TVPE=
2716
ENTER FRCM COMMAND VERIFY(V),PROGRAM(P),RERO(R), OR CHECK(C)
OF MEMGRY COMMFNO VERIFY(F), LOFG(L), OUMP (D), MEM FILL (M), INVERT (1)
=L
GFFSET=D000 JN=F FILE=RIMBAS DISK=2
*********************
DEVICE TVPE
2716

2716 TVFL
ENTER PROM COMMANO VERIFY(V),PROGRAM(P),RERO(R), OR CHECK (C)
OR MEMORY COMMFHO VERIFY(F), LQAO(L), DUMF (D), MEM FILL(M), INVERT (1)
Figure 7. Load Memory with Offset Function Example

## VERIFY MEMORY WITH OFFSET FUNCTION (THE F COMMAND)

The Verify Memory with Offset, Function (F) compares the contents of an object code file with the contents of memory at addresses in memory offset by an entered amount from the addresses on the reference object code file. The entered offset is additive in the same manner as the Load with Offset function. The contents of both memory (MEM) and reference file (FILE) are displayed/printed along with the address (ADDR) if any differences in value are detected.

Figure 8 is an example of the Verify Memory with Offset Function showing two detected errors.

```
C5>
PROM PROGRAMMER FOR 1 MHZ SVSTEM (VER E)
ENTER 2704, 2708, 2758, 2716, 2516, 2532
2716
TMS 2716 PROM?
-N
***********************
DEVICE TYPE=
2716
ENTER PROM COMMAND: VERIFY(V),PROGRAM(P),RERD(R),OR CHECK(C)
OR MEMURY COMMAFND: VERIFY(F),LOFHO(L),DUMP(D),MEM FILL(M),INYERT(I)
-F
OFFSET=DA00 IN=F FILE=AIMBAS OISK=2
ERROR LIST
OT=L AODR/MEM/FILE
2000 E0 50 2200 4C 52
DEVICE TYPE=
2716
ENTER PROM COMMRNO: VERIFY(V),FROGRAM(P),REFO(R),OR CHECK(C)
OR MEMULRY COMMANDD: VERIFY(F),LOFD(L),DUMF(D),MEM FILL(M),INVERT<I)
```

Figure 8. Verify Memory with Offset Function Example with Errors

## DUMP MEMORY WITH OFFSET FUNCTION (THE D COMMAND)

The Dump Memory with Offset Function (D) copies data from memory to an output object code file with addresses in the output fite offset an entered amount from the addresses in memory. The entered offset value is additive from the output file to memory with carry from bit 15 ignored; e.9.:

| Output File <br> Address (FROM <br> Ad | Offset <br> Value |  | Address in <br> Memory |
| :---: | :--- | :--- | :---: |
|  |  |  | $\$ 1000$ |
| $\$ 1000$ | $\$ 4000$ | $\$ 0000$ | $\$ 1000$ |
| $\$ 1000$ | $\$ 8000$ | $\$ 9000$ |  |
| $\$ A 000$ | $\$ 1000$ | $\$ B 000$ |  |

Figure 9 is an example of the Dump Memory with Offset Function.

```
PROM PROGRAMMER FOR 1 MHZ SYSTEM (VER E)
ENTER 2764, 2761, 2758, 2716, 2516.2532
2716
MS 2716 PROM
N
**********************
*************
2716
ENTER FROM COMMRNO: VERIFY(V),PROGRAM(P),RERD(R),OR CHECK(C)
OR MEMGRY COMMAND: VERIFY(F),LOFO(L),DUYP(D),MEM FILL(M), INVERT(I)
=0
FFSET=0000 OUY=F FILE=PRMOUT DISK=2
FROM=48ea TO=47FF
MORE ?N
***********
DEVICE TYPE=
2716
ENTER FROM COMMAND: VERIFY(V),PROGRAM<P),RERD(R),OR CHECK(C)
OR MEMORY COHMFWDD: VERIFY(F),LOFD (L), DUMP (D), MEM FILL (M), INGERT (I)
```

Figure 9. Dump Memory with Offset Function Example

## MEMORY FILL FUNCTION (THE M COMMAND)

The Memory Fill Function (M) allows a user selected range of RAM to be initialized to an entered bit pattern. The desired PROM object code can then be loaded. All unloaded memory in the PROM address range will remain initialized with the previously filled bit pattern. This allows PROM codes over a total PROM address range to be easily verified without invalid data errors being indicated due to random bit patterns in unused addresses.

Figure 10 is an example of the Memory Fill Function. Enter the bit pattern to be loaded in hexadecimal in response to the MEM FILL= prompt. The last two digits entered will be accepted. Terminate the entry with a carriage return. Then enter the starting and ending addresses in hexadecimal of the RAM to be filled. Terminate entries with a carriage return. The last four digits entered will be accepted.

```
<<>M
```



```
TMS 2716 PROM
-N
*********************
DEVICE TYPE*
2716
********************
ENTER FROM COMMANO: VERIFY(V), PROGRAM(P), REAO(R),OR CHECK(C)
OT MEMOFY COMMFANO VERIFY(F),LOAD(L), DUMP(D),MEM FILL(M), INVERT(I)
MM
FRCM=1000 TO=13FF
*********************
\mathrm{ levice tYFE:}
2716
ENTER FROM COMMENO VERIFY(V),FROGRGM(P), READ(R),OR CHECK(C)
    ENTER PROMM COMMANO VERIFY(V), FROGRGM(P), READ(R),OR CHECK(C)
```


## INVERT MEMORY (THE I COMMAND)

The Invert Memory Function (1) allows selected bits to be inverted within a selected address range. This function allows the contents of RAM to be easily one's complemented if the PROM code is to be inverted from the ROM code.

Figure 11 is an example of the Invert Memory Function. Enter the bit pattern to be exclusively or'ed with memory. A " 1 "' in a bit position will invert the bit value while a " 0 " will leave the bit value unchanged. Enter "FF" to invert all bit values and " 00 " to invert none of the bit values. Terminate the entry with a carriage return. The last two digits entered will be accepted. Enter the starting and ending addresses as described for the MEM FILL function.

〈SROM PROGRAMMER FOR 1 MHZ SYSTEM (VER E)
ENTER 2784, 2788, 2758. 2716, 2516. 2532
2716
$\underset{\sim N}{T M S} 2716$ PROM?
$-\mathrm{N}$
*********************
DEVICE TYPE=
2716
ENTER PROM COMMAND: VERIFY(V), PROGRAM(P), RERD(R), OR CHECK(C) OR MEMORY COMMAND: VERIFY(F), LOFD (L), DUMP (D), MEM FILL (M), INVERT(I)
INVERT BITS=FF
FROM=1600 TO=13FF
*********************
DEVICE TYPE=
2716
ENTER PROM COMMAND: VERIFY(V), PROGRAM (P), READ (R), OR CHECK (C) OR MEMOFY COHMFND: VERIFY(F), LOAD(L), DUMP (D), MEM FILL(M), INVERT (1)

Figure 10. Memory Fill Function Example

## SPECIFICATIONS

PROM Devices Supported:
Programming Time (approximately):

Interface:

Module Dimensions:

Edge Connector:
Operating Temperature:

Power Requirements:

Fuse Description:

2704, 2708, 2758, Intel 2716 and Texas Instruments 2716

2704-100 sec.
$2708-200 \mathrm{sec}$.
2758 - 60 sec .
Intel 2716 - 120 sec.
T.I. $2716-400 \mathrm{sec}$.

2516-120 sec.
2532-240 sec.

SYSTEM 65 compatible
9.75 in , wide $\times 6.00 \mathrm{in}$. high

86 pins on $0.156-i n$. centers
$0^{\circ}$ to $+70^{\circ} \mathrm{C}$
+5 VDC $\pm 5 \%$ @ 750 ma (fused at 2 amps)
+12 VDC $+5 \%$ @ 50 ma (fused at $1 / 2 \mathrm{amp}$ )
$-12 \mathrm{VDC} \pm 5 \%$ @ 50 ma .
F1 - AGC $1 / 2 \mathrm{~A}-250 \mathrm{~V}$ (Bussman)
F2 - AGC 2A-250V (Bussman)

## OVERVIEW

The PROM/ROM Module (Part Number M65-045) permits system read only memory to be increased by up to 16 K bytes. The Module provides 1624 -pin DIP sockets for accepting industrystandard 2708, 2716 or 2758 PROM devices, or 2316 or 2332 ROM devices. PROMs and ROMs cannot be mixed on the Module.

The PROM/ROM Module's 16 K -byte address space is segmented into four independent 4 K -byte sections. Each 4 K -byte section is provided with a switch for selecting its base address. Further, each socket has an individual enable/disable switch, providing resolution down to 1 K bytes.

## FEATURES

- SYSTEM 65 compatible
- 16K-byte read only memory capacity
- Accepts 2708, 2716 or 2758 PROM devices
- Accepts 2316 or 2332 ROM devices
- Sockets can be individually enabled/disabled
- Base address is switch-selectable for each 4K-byte address space
- Single +5 V supply



## FUNCTIONAL DESCRIPTION

In reading the text to follow, refer to the Functional Block Diagram below and the attached schematics:

- PSOO-X-141, the -001 version of the PROM/ROM Module
- PSOO-X-143, the $\mathbf{0 1 1}$ version of the PROM/ROM Module

The edge connector pin assignments for the PROM/ROM Module are identical to the Motherboard pin assignments given in Section 4 of the SYSTEM 65 User's Manual (Document No. 29650 N35).

The PROM/ROM Module comes with 16 sockets for accepting the following types of memory devices:

- Up to four 2332 ROMs, or
- Up to eight 2316 ROMs, or
- Up to eight 2716 PROMs, or
- Up to 162708 or 2758 PROMs

The address switches on the Module are set in accordance with the type and number of PROM or ROM devices installed. Each socket may also be selected by a switch. Further, each 4 K address space also has a separate switch for selection of its base address. The Chip Select Logic specifies the PROM/ROM to be accessed and the address lines from the System bus select the memory location. The selected PROM/ROM device responds by placing 8 bits of data on the data lines ( $\overline{\mathrm{DO}}$ through $\overline{\mathrm{D7}}$ ) for transfer to the CPU.


PROM/ROM Module Functional Block Diagram

## SWITCHES AND JUMPERS

The PROM/ROM Module can accommodate a variety of standard PROM and ROM devices. The user must configure the Module for his specific application, and does so with various switches and jumpers on the Module itself.
The PROM/ROM Module has a total address space of 16 K bytes, divided into four 4 K -byte sections. Each 4 K section has a separate base address select switch, S3 through S6, which must be set to the desired hexadecimal value ( 0 -F). For example, if Switch S3 is set to C, the base address for Sockets $\mathbf{Z 4}, \mathbf{Z 5}, \mathbf{Z 6}$ and $\mathbf{Z 7}$ is $\$ \mathbf{C O 0 0}$ (where $\$$ indicates hexadecimal). Further, each individual socket can be enabled or disabled from driving the Data Bus by setting/resetting Switches S1 and S2.

There is a further restriction for ROMs: Since ROMs have chip selects, they will only work in the proper sockets with proper base address switch settings. For example, a 2316 ROM with CS3=1, CS2=0 and CS1=1 will work only in Socket $\mathbf{Z 2 2}$ (see Table 4) and with a selected base address value of $2,6, A$ or $E$.

As mentioned above, the PROM/ROM Module must also be jumperconfigured for the device being used. Jumper information is given with switch select tables. The function of each jumper is summarized in Table 1.

Table 1. PROM/ROM Board Jumper Functions

| Jumper No. | Jumper Function |
| :---: | :--- |
| 1 | Connects A12 to Pin 18 of all sockets |
| 2 | Enables 1 K address selection |
| 3 | Connects +12VDC to Pin 19 of all sockets |
| 4 | Enables 2 K address selection |
| 5 | Connects A13 to Pin 21 of all sockets |
| 6 | Connects A10 to Pin 19 of all sockets |
| 7 | Connects A11 to Pin 21 of all sockets |
| 8 | Connects +5 VDC to Pin 21 of all sockets |
| 9 | Connects A11 to Pin 18 of all sockets |
| 10 | Connects -5 VDC to Pin 21 of all sockets |
| 11 | Connects GND to Pin 18 of all sockets |
| 12 | Enables active low chip selects on Sockets Z7, Z14, Z22 and Z29 |

Table 2. Switch Settings for 2716 PROM Operation

| $\begin{gathered} \text { Base Address } \\ \text { (A15, A14, A13, A12) } \end{gathered}$ | Address Al1 | Socket | Enable/Disable Switch |
| :---: | :---: | :---: | :---: |
| S3 (0-F) | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { Z5 } \\ & \text { Z7 } \end{aligned}$ | $\begin{aligned} & \text { S1-2 } \\ & \text { S1-4 } \end{aligned}$ |
| S4 (0-F) | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { Z11 } \\ & \text { Z14 } \end{aligned}$ | $\begin{aligned} & \text { S1-6 } \\ & \text { S1-8 } \end{aligned}$ |
| S5 (0-F) | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \mathrm{Z} 18 \\ & \mathrm{Z} 22 \end{aligned}$ | $\begin{aligned} & \hline \text { S2-2 } \\ & \text { S2-4 } \end{aligned}$ |
| S6 (0-F) | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \hline \mathbf{Z 2 4} \\ & \text { Z29 } \end{aligned}$ | $\begin{aligned} & \hline \text { S2-6 } \\ & \text { S2-8 } \end{aligned}$ |

For 2716 PROMs, add Jumpers 4, 6, 8, 11 and 12.
Table 3. Switch Settings for 2708 or 2758 PROM Operations

| $\begin{gathered} \text { Base Address } \\ \text { (A15, A14, A13, A12) } \end{gathered}$ | Address A11 A10 |  | Socket | Enable/Disable Switch |
| :---: | :---: | :---: | :---: | :---: |
| S3 (0-F) | $\begin{aligned} & 0 \\ & 0 \\ & 1 . \\ & 1 . \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \mathrm{Z4} \\ & \mathrm{Z5} \\ & \mathrm{Z6} \\ & \mathrm{Z7} \end{aligned}$ | $\begin{aligned} & \text { Si-1 } \\ & \text { S1-2 } \\ & \text { S1-3 } \\ & \text { S1-4 } \end{aligned}$ |
| S4 (0-F) | 0 0 1 1 | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { Z10 } \\ & \text { Z11 } \\ & \text { Z13 } \\ & \text { Z14 } \end{aligned}$ | $\begin{aligned} & \hline \text { S1-5 } \\ & \text { S1.6 } \\ & \text { S1-7 } \\ & \text { S1-8 } \end{aligned}$ |
| S5 (0-F) | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { Z17 } \\ & \text { Z18 } \\ & \text { Z21 } \\ & \text { Z22 } \end{aligned}$ | $\begin{aligned} & \hline \text { S2-1 } \\ & \text { S2-2 } \\ & \text { S2-3 } \\ & \text { S2-4 } \end{aligned}$ |
| S6 (0-F) | 0 0 1 1 | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { Z23 } \\ & \text { Z24 } \\ & \text { Z28 } \\ & \text { Z29 } \end{aligned}$ | $\begin{aligned} & \mathrm{S} 2-5 \\ & \text { S2-6 } \\ & \text { S2-7 } \\ & \text { S2-8 } \end{aligned}$ |

For 2708 PROMs, add Jumpers 2, 3, 4, 11 and 12 and add Capacitors C6-C9, C14-C17, C21-C24, C29-C32, C37-C40, C45-C48, C52-C55 and C59C62. All capacitors are $0.1 \mu \mathrm{f}$.

For 2758 PROMs, add Jumpers 2, 8, 11 and 12 and jumper left post of Jumper 3 to right post of Jumper 4.

Table 4. Switch Settings for 2316 ROM Operation

| Base Address(A15, A14, A13, A12) | ROM Chip Selects* |  |  | Socket | Enable/Disable Switch |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { A13 } \\ & \text { CS3 } \end{aligned}$ |  | $\begin{aligned} & \text { A11 } \\ & \text { CS1 } \end{aligned}$ |  |  |
| S3 (0, 4, 8, C) | 0 | 0 | 0 | 25 | S1-2 |
|  | 0 | 0 | 1 | 27 | S1.4 |
| S4 (1, 5, 9, D) | 0 | 1 | 0 | 211 | S1.6 |
|  | 0 | 1 | 1 | 214 | S1-8 |
| S5 ( $2,6, A, E)$ | 1 | 0 | 0 | 218 | S2-2 |
|  | 1 | 0 | 1 | 222 | S2-4 |
| S6 (3, 7, B, F) | 1 | 1 | 0 | Z24 | S2-6 |
|  | 1 | 1 | 1 | Z29 | S2-8 |

- Assumes CS1=A11, CS2=A12 and CS3=A13

For 2316 ROMs, add Jumpers 1, 4, 5 and 6

Table 5. Switch Settings for 2332 ROM Operation

| Base Address <br> (A15, A14, A13, A12) | ROM Chip Selects* <br> A13 <br> S2 | A12 <br> S1 | Socket |
| :---: | :---: | :---: | :---: |

*Assumes S1=A12 and S2=A13
For 2332 ROMs, add Jumpers 2, 5, 6 and 9

## INSTALLATION

The procedure below should be used to install PROM/ROM Modules in the SYSTEM 65 chassis or, with appropriate changes, in an Auxiliary Card Cage.

1. Turn SYSTEM 65 power off.

## CAUTION

Never install or remove modules with SYSTEM 65 power on - it may cause damage to the module and/or to the System.
2. Remove the top copver of the SYSTEM 65 .
3. Set the switches on the PROM/ROM module per Tables 2 through 5. The base memory addresses are assigned by four hexadecimal switches, S3 through S6. Individual sockets are enabled/disabled by Switches S1 and S2.
4. Install the required jumpers per directions given with the switch table.
5. Install the required PROM or ROM devices in their appropriate sockets.
6. Insert the PROM/ROM Module(s) into any vacant slot(s) in the SYSTEM 65 chassis.
7. Install the top cover of the SYSTEM 65.
8. Turn SYSTEM 65 power on.

## SPECIFICATIONS

| Memory Capacity: | 16 K bytes |
| :--- | :--- |
| Word Length: | 8 bits |
| Interface: | SYSTEM 65 compatible |
| Module Components: | 1624 -pin DIP sockets |
| Module Dimensions: | 9.75 in. wide $\times 6.00 \mathrm{in}$. high |
| Edge Connector: | 86 pins on 0.156 -in. centers |
| Operating Temperature: | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| Power Requirements: | +5 VDC $+5 \% @ 500$ ma. with no devices <br> installed |

LOGIC LEVELS
$T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{C C}=+5 \mathrm{~V}+5 \%$

| Characteristic | Symbol | Min | Max | Unit | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Inputs $\overline{\text { ( }} \mathrm{OD}-\overline{D 7}, \mathrm{AO}$ A15, \$2, $\mathrm{R} / \overline{\mathrm{W}}$ ) |  |  |  |  |  |
| Input Low Voltage | $v_{\text {IL }}$ |  | 0.8 | $v$ | $\mathrm{I}_{\mathrm{IL}}=400 \mu \mathrm{a}$ |
| Input High Voltage | $V_{\text {IH }}$ | 2.0 | $\mathrm{V}_{\mathrm{cc}}$ | v | $\mathrm{I}_{\mathrm{IH}}=40 \mu \mathrm{a}$ |
| Outputs ( $\overline{00} \cdot \overline{07}$ ) |  |  |  |  |  |
| Output Low Voltage | $\mathrm{v}_{\mathrm{OL}}$ |  | 0.5 | $v$ | $\mathrm{I}^{\prime}=48 \mathrm{ma}$ |
| Output High Voltage | $\mathrm{v}_{\mathrm{OH}}$ | 2.4 | $\mathrm{V}_{\mathrm{cc}}$ | $v$ | ${ }^{\prime} \mathrm{OH}=10 \mathrm{ma}$ |

R6500 Microcomputer System PRODUCT DESCRIPTION

## DESIGN PROTOTYPING MODULE

## OVERVIEW

The Designing Prototyping Module (Part Numbier M65071) allows development of custom circuits for installation in either Rockwell's SYSTEM 65 Microcomputer Development System or in user-designed equipment, via the Auxiliary Card Cage.

This Module is a SYSTEM 65 -compatible printed circuit module with no mounted components, but with prerouted power bus and power return lines. Spaced beside the power lines are plated-through holes that permit wirewrap sockets to be installed. Additional holes, at the top edge of the Module, permit a variety of wire-wrap flat ribbon cable connectors to be installed.

The pin assignments for the Design Prototyping Module's 86 -pin edge connector are identical to the Motherboard pin assignments given in Section 4 of the SYSTEM 65 User's Manual (Document No. 29650 N35).

## INSTALLATION

The procedure below should be used to install a Design Prototyping Module in the SYSTEM 65 or, with appropriate changes, in an Auxiliary Card Cage.

1. Turn SYSTEM 65 power off.

## CAUTION

Never install or remove modules with SYSTEM 65 power on - it may cause damage to the module and/or to the System.
2. Remove the top cover of the SYSTEM 65.
3. Insert the Design Prototyping Module into any vacant slot in the SYSTEM 65 chassis.

## CAUTION

Installation of improperly-operating circuits may cause malfunction and/or damage to the SYSTEM 65.
4. Install the top cover of the SYSTEM 65.
5. Turn SYSTEM 65 power on.

## SPECIFICATIONS

Component Mounting Area:
Number of Component Rows: 14
Number of Hole Rows: 35
Vertical Hole Spacing:
Horizontal Hole Spacing:
Flat Ribbon Connector Mounting Area:
Number of Pins Per Connector
Module Dimensions:

Edge Connector:

46 holes on 0.1 -in. centers
35 holes on either 0.3-in. or 0.1 -in. centers

170
7.50 in. high $\times 9.75 \mathrm{in}$. wide $\times 0.062$ in. thick
86 pins on $0.156-\mathrm{in}$. centers


## R6500 Microcomputer System PRODUCT DESCRIPTION

## EXTENDER CARD

## OVERVIEW

The Extender Card is used to provide easy access to a printed circuit module installed in its system enclosure，for signal tracing or troubleshooting．In that context，the Extender Card consists of a series of bus lines connecting the Card＇s standard contact edge，on one end，and a connector used for accepting the stand－ ard contact edge of an 86 －pin system module．

This contact edge and the edge connector pins are connected pin－for－pin via the bus lines on the Card．Each of the bus lines is provided with a clip－on terminal to allow test equipment to be readily connected．With the module under test connected to the Extender Card and this assembly installed in the system＇s Auxiliary Card Cage or SYSTEM 65 chassis，the user is given free access to both sides of the module being tested．

The edge connector pin assignments for the SYSTEM 65 Mother－ board are given in Section 4 of the SYSTEM 65 User＇s Manual （Document No． 29650 N35）．

## SPECIFICATIONS

Edge Contacts：
Edge Connector：
Extender Card Dimensions

86 pins on $0.156-\mathrm{in}$ ．centers 86 pins on 0.156 －in．centers 9.75 in ．wide $\times 9.00 \mathrm{in}$ ．high $\times 0.062$ in．thick

## INSTALLATION

The procedure below should be used to install an Extender Card in the SYSTEM 65 chassis or，with appropriate changes，in an Auxiliary Card Cage．

1．Turn SYSTEM 65 power off．

## CAUTION

Never install or remove modules with SYSTEM 65 power on－it may cause damage to the module and／or to the System．

2．Remove the top cover of the SYSTEM 65.
3．Remove the desired circuit module from SYSTEM 65， if installed．

4．Insert the Extender Card into any vacant slot in the SYS． TEM 65 chassis．

5．Insert the desired circuit module into the plug on top of the Extender Card．

6．Turn SYSTEM 65 power on．


## Cut the Cost of Your System Development With ...

## Rockwell <br> R6500 Macro Assembler and Linking Loader

Macro Assembler Features<br>- Macro definition and call<br>- Absolute and relocatable object code<br>- Conditional assembly capability<br>- Symbol cross-reference table

## Linking Loader Features

- Interactive or command file input
- Generates load map and absolute object code

The R6500 Macro Assembler and Linking Loader (Part No. M65-650) is a minifloppy diskette-based software package to support the Rockwell SYSTEM 65 Microcomputer Development System. The R6500 Macro Assembler translates symbolic source code into absolute or relocatable object code.

The absolute code may be directly executed on any 6500 -family CPU-6502, 6503, 6504, etc. - or on the R6500/1 single-chip microcomputer. Absolute and relocatable object files generated by the Macro Assembler can be subsequently combined into a single object file, or "load module", using the Linking Loader. The Macro Assembler and Linking Loader are both written in assembly language, to maximize system efficiency.

## The Macro Assembler

The Macro Assembler has all of the features of SYSTEM 65's ROM-resident, two-pass assembler, plus a variety of additional features that are aimed at increasing your programming productivity. It enables a programmer to call repeatedly-used instruction sequences with a single "macro" statement. It also allows large programs to be developed in small, easy-to-handle modules.

And a conditional assembly feature permits sections of source code to be included in (or excluded from) the assembly, depending on certain user-specified parameters. Besides object code, the Macro Assembler generates a cross reference synbol table, which lists the memory address where each label is defined, and the line number of each instruction that references that label.

Assembler Directives
Assembly Listing Control

| .TTL | Title | .SKI | Skip |
| :--- | :--- | :--- | :--- |
| .SBTTL | Subtitle | .ERR | Error |
| .PAG | Page |  |  |

Source Flle Control
.END End of Assembly
.FILE Next File
INCL Include
Data Storage
BYTE
Initialize byte memory location
WORD Generate 16 -bit address
.DBYTE Generate 16-bit data word
.SBYTE Initialize ASCII string
Equate
$=\quad$ Assign value to symbol
Option Control
.OPT Option
LIST/NOLIST LISNINOGEN
ERR/NOERR
SYM/NOSYM CREFINOCREF

ABS
REL
MEM
TOC/NOTOC
OBJ/NOOBJ
MD/NOMD
ME/NOME
CCINOCC
PLEN
LLEN
FF/NOFF
CLS
RAD
Radix
$2,8,10$, or 16
Assembly listing Object code listing Error generation Symbol generation Cross reference generation
Absolute object code
Relocatable object
code
Absolute object code
to memory
Table of contents
Object code generation
Macro definition
Macro expansion
Conditional list
Page length
Line length
Form feed
Clear definitions

Relocation/LInking
DEF Internal definition
.REF External reference
.ZREF Zero page reference
PSECT Program section
.IDENT Module identification
Conditional
.IF
. ELS
.EIF
Condition
.EIF End of conditional
Macro
.MACRO Define Macro
ENDM End of macro definition
.MEXIT End of macro expansion
.NARG Number of passed arguments

## The Linking Loader

The Linking Loader combines independentlyassembled object modules (absolute or relocatable) into a single, executable object file. Linking commands can be entered interactively from the system terminal or from a previously-prepared command file.

## For More Information . . .

On the R6500 Macro Assembler and Linking Loader (Part No. M65-650), SYSTEM 65, AIM 65 or the rapidly growing family of R6500 products, contact

ROCKWELL INTERNATIONAL
P.O. Box 3669, RC55

## Linking Loader Dlrectives

ERR Errors destination
OBJ Object code generation
MAP Load map generation
CALS Symbol table location
SYM Global symbol table
DEBUG Debug symbol table
ORG Origin
ORDER Section order
DEF Symbol definition
LOAD Load code specification END Command file end

Anaheim, CA 92803
Attn: Marketing Services
or phone 714/632-3729.


## Now Rockwell Cuts The Low-Cost of R6500 Designing ...

## a <br> Rockwell

PL/65
A High-Level Language for the
R6500 Microprocessor Family


In Rockwell's SYSTEM 65, you have one of the industry's most cost-effective microcomputer development systems. By coupling SYSTEM 65 with the advanced low-cost PL65 Compiler option, you're even further ahead with valuable savings in time, effort and cost.
Resembling PL1 and ALGOL in general form, PL65 is designed to improve your productivity and efficiency by simplifying the overall software development effort.

The coding is easier, since PL/65's powerful, high level language statements enable you to implement even complex applications with minimal programming.

Program readability is enhanced by the self-documenting nature of PL/65. This results in programs that are easier to understand. These programs are easier to update, too, which means lower maintenance costs.

PL/65 = Software Simplification
All language features are aimed at improving productivity by simplifying software development. PL65's structured programming support features encourage modular program design, and its general control structure for conditional and iterative looping allows the language to be applied to highly structured programs.

Coding Flexibility . . . When You Need It Most
PL65 allows you to freely mix assembly language instructions in portions of the program where timing or code optimization requirements are critical.
This flexibility carries through the compile cycle: The PL/65 compiler outputs source code to SYSTEM 65's resident assembler, rather than object code. You'll be able to enhance or debug at the assembler level and indeed to drop into assembly language whenever you desire - a big plus in structured programming. PL65 thereby provides the structuring potential and programming simplicity of a high-level language, while retaining the power and flexibility of an assembler.

No "Hidden" Memory Costs With PL/65
And while other microcomputer high-level languages require adding more memory to the host development system, PL65 runs with only 16K bytes of RAM - and that comes standard with every SYSTEM 65 as do the dual minifloppy disk drives.

For PDP 11 Users
A PL65 Compiler and an R6500 cross-assembler are also available for installation using the RT-11 operating system.

## The PL./65 Package

A pre-programmed minifloppy diskette and the comprehensive PL65 User's Manual is available now from Rockwell and your local Hamilton/Avnet distributor.

For more information on PL65, SYSTEM 65, AIM 65, or the rapidly growing family of R6500 products, contact

ROCKWELL INTERNATIONAL
Microelectronic Devices
P.O. Box 3669

Anaheim, CA 92803
Attn: Marketing Services

> D/727 RC55
or phone 714/632-3729.

| PL/65 LANGUAGE STATEMENTS |  |
| :--- | :---: |
|  |  |
| Declaration | Specification |
| DECLARE | ENTRY |
| DEFINE | EXIT |
| DATA |  |
| Comment | Conditional |
|  |  |
| Assignment | IF-THEN-ELSE |
|  | IF-THEN |
| Single-Byte Move | BEGIN-END |
| Multiple-Byte Move | CASE |
|  |  |
| Imperative | Branching |
|  |  |
| SHIFT | GOTO |
| ROTATE | CALL |
| CLEAR | RETURN |
| SET | RTI |
| CODE | BREAK |
| HALT | Looping |
| WAIT | FOR-TO-BY |
| STACK |  |
| UNSTACK |  |
| INC |  |
| INCW |  |
| DEC |  |
| DECW |  |
| PULSE |  |

## 0 Rockwell

## R6500 Microcomputer System DATA SHEET

## 2048 X 8 STATIC READ ONLY MEMORY

DESCRIPTION
The R2316B and R2316E high performance read only memories are organized 2048 words by 8 bits with access times of less than 450 ns . These ROMs are designed to be compatible with all microprocessor and similar applications where high performance, large bit storage and simple interfacing are important design considerations. These devices offer TTL input and output levels with a minimum of 0.4 Volt noise immunity in conjunction with a +5 Volt power supply.

The R2316B and R2316E operate totally asynchronously. No clock input is required. The three programmable Chip Select inputs allow eight 16 K ROMs to be OR-tied without external decoding. The R2316E features a high-speed chip select response for use in time-critical applications such as multiplexed control lines. Both devices offer three-state output buffers for memory expansion.

Designed to replace two 2708 8K EPROMs, the R2316B and R2316E can eliminate the need to redesign printed circuit boards for volume mask programmed ROMs after prototyping with EPROMs.

## FEATURES

- $2048 \times 8$ Bit Organization
- Single +5Volt Supply
- Max. Access Time - 450 ns
- Totally Static Operation
- Completely TTL Compatible
- Three-State Outputs for Wire-OR Expansion
- Three Programmable Chip Selects
- Chip Select Times
- 250 ns max for R2316B
- 120 ns max for R2316E

Ordering Information
Order Number: $\mathbf{R 2 3 1 6}$
$B=2316 B$
$E=2316 E$



Block Diagram
Blan


## SPECIFICATIONS

## Maximum Ratings



This device contains input protection against damage due to high static voltages or electric fields; however, precautions should be taken to avoid application of voltages higher than the maximum rating.

## Electrical Characteristics

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%$ (unless otherwise specified)


Note 1: Input levels that swing more negative than -0.5 V may be clamped and may cause damage to the device.
Note 2: This parameter is periodically sampled and is not $100 \%$ tested.

## Timing Characteristics

$v_{C C}=5.0 \mathrm{~V} \pm 10 \%$ (unless otherwise specified)

|  | Parameter | R2316B |  | R2316E |  | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min | Max | Min | Max |  |  |
| ${ }^{\text {t }} \mathrm{ACC}$ | Address Access Time |  | $\begin{aligned} & 450 \\ & 475 \\ & 550 \end{aligned}$ |  | $\begin{aligned} & 450 \\ & 475 \\ & 550 \end{aligned}$ | ns | $\begin{aligned} & 0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to } 125^{\circ} \mathrm{C} \\ & \text { Output load: } 1 \text { TTL load and } 100 \mathrm{pF} \end{aligned}$ |
| ${ }^{\text {t }} \mathrm{CO}$ | Chip Select Delay |  | 250 |  | 120 . | ns |  |
| ${ }^{\text {t }}$ DF | Chip Deselect Delay | 10 | 250 |  |  | ns | Input transition time: 20 ns |
| ${ }^{\text {t }} \mathrm{OH}$ | Previous Data Valid After Address Change Delay | 20 |  | 20 |  | ns | Timing reference levels: <br> Input: 1.5 V <br> Output: 0.8 V and 2.0 V |

Timing Diagram


## Typical Characteristics



Packaging Diagram


Plastic Package


## DATA SHEET

## 4096 X 8 STATIC READ ONLY MEMORY

## DESCRIPTION

The R2332 is a high performance, 32,768-bit static Read Only Memory. organized as 4,096 eight-bit bytes. It is available in two versions: R2332-25, which has a 250-ns access time, and R2332.3, which has a 300 -ns access time. The device is an industry standard, 24 -pin, dual-in-line package, and is available in ceramic or low cost plastic packages. This fully static 32K ROM is compatible with all eight bit $N$-channel microprocessors including the R6500 family of microprocessors.

The R2332 operates totally asynchronously; no clock input is required. Two mask-programmable chip select inputs allow up to four R2332 32K ROMs to be OR-tied without external decoding. The device provides three-state output buffers for memory expansion. The R2332 offers TTL input and output levels with a minimum noise immunity of 0.4 volts.

## FEATURES

- 32,768 bits, organized in 4,096 8-bit words
- Max access time: $\mathbf{2 5 0}$ ns for R2332-25

300 ns for R2332-3

- Typical power dissipation is 350 mW
- Drives one TTL load and 100 pF
- Single +5 -volt power input
- Totally static operation, no clock input required
- Completely TTL compatible
- Two mask-programmable chip select inputs
- Three state outputs for memory expansion
- Identical cycle and access time



R2332 Block Diagram
Order Number: R2332.

$\mathrm{C}=$ Ceramic $\mathrm{P}=$ Plastic

- Access Time (Max):

$$
\begin{aligned}
25 & =250 \mathrm{nst} \mathrm{t}_{\mathrm{ACC}} \\
3 & =300 \mathrm{~ns} \mathrm{t}_{\mathrm{ACC}}
\end{aligned}
$$

NOTE: Contact your local Rockwell Representative for availability. Submit ROM codes using the Rockwell NMOS ROM Code Order Form, Document No. 29650 N8O.

## SPECIFICATIONS

## Maximum Ratings.

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage <br> Input Voltage <br> Operating Temperature <br> Commercial <br> Industrial <br> Storage Temperature | $\begin{aligned} & V_{\text {CC }} \\ & V_{\text {in }} \\ & T_{\text {STG }} \end{aligned}$ | $\begin{aligned} & -0.5 \text { to }+7.0 \\ & -0.5 \text { to }+7.0 \\ & 0 \text { to }+70 \\ & -40 \text { to }+85 \\ & -65 \text { to }+150 \end{aligned}$ | Vdc <br> Vdc <br> ${ }^{\circ} \mathrm{C}$ <br> ${ }^{\circ} \mathrm{C}$ |

This device contains input protection against damage due to high static voltages or electric fields; however, precautions should be taken to avoid application of voltages higher, than the maximum rating.

## Electrical Characteristics

$V_{C C}=5.0 \mathrm{~V} \pm 5 \%$ (unless otherwise specified)

| Symbol | Parameter | Min | Typ | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & v_{\mathrm{OH}} \\ & v_{\mathrm{OL}} \\ & v_{\mathrm{IH}} \\ & v_{\mathrm{IL}} \end{aligned}$ | Output HIGH Voltage <br> Output LOW Voltage <br> Input HIGH Voltage Input LOW Voltage | $\begin{array}{r} .2 .4 \\ 2.0 \\ -0.5 \end{array}$ |  | $\begin{aligned} & v_{\mathrm{Cc}} \\ & 0.4 \\ & v_{\mathrm{Cc}} \\ & 0.8 \end{aligned}$ | Volts <br> Volts <br> Volts <br> Volts | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A} . \\ & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA} \end{aligned}$ |
| $\begin{aligned} & \mathrm{I}_{\mathrm{LI}} \\ & \mathrm{I}_{\mathrm{LO}} \\ & { }^{2} \mathrm{CC} \end{aligned}$ | Input Load Current Output Leakage Current <br> Power Supply Current Commercial Temp Industrial Temp |  | $\begin{aligned} & 70 \\ & 70 \end{aligned}$ | $\begin{aligned} & 10 \\ & \pm 10 \\ & \\ & 135 \\ & 150 \end{aligned}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> mA | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, 0 \mathrm{~V} \leq \mathrm{V}_{\text {in }} \leq 5.25 \mathrm{~V} \\ & \text { Chip Deselected, } \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} \\ & \mathrm{~V}_{\text {out }}=+0.4 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| $\begin{aligned} & c_{1} \\ & c_{0} \end{aligned}$ | Input Capacitance <br> Output Capacitance |  |  | $\begin{aligned} & 7 \\ & 10 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, chip deselected, pin under test at $O V, T_{A}=25^{\circ} \mathrm{C}$, $\mathrm{f}=\mathbf{1} \mathrm{MHz}$ |

## Timing Characteristics

$V_{C C}=5.0 \mathrm{~V} \pm 5 \%$ (unless otherwise specified)

| Symbol | Parameter | $\begin{gathered} \text { R2332-25 } \\ \text { Max } \end{gathered}$ | $\underset{\text { Max }}{\text { R2332-3 }}$ | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{t} \mathrm{~A}$ | Address Access Time | 250 | 300 | ns | Output load: <br> 1 TTL load, 100 pf Input transition time: 20 ns |
| ${ }^{\text {t }} \mathrm{CO}$ | Chip Select Delay | 150 | 150 | ns | Timing reference levels: Input: 1.5 V |
| ${ }^{\text {t }}$ DF | Chip Deselect Delay | 150 | 150 | ns | Output: 0.8 V \& 2.0 V |

Timing


Typical Characteristics


Packaging Diagram


## DATA SHEET

## LOW-POWER $4096 \times 8$ STATIC READ ONLY MEMORY

## DESCRIPTION

The R2332-L, R2332-4L and R2332-35L are 32,768 -bit static Read Only Memories (ROMs), organized as 4,096 eight-bit bytes, that offer maximum access times of 450,400 and 350 nanoseconds, respectively. Like their high-speed counterparts, the R2332-25 and the R2332-3 (see Rockwell Document No. 29000 D48), these ROMs are in industry-standard, 24 pin, dual in-line packages, and are available in ceramic or low-cost plastic. However, R2332-xL series ROMs operate with a typical power dissipation of only $\mathbf{2 4 0} \mathrm{mW}$.

All three R2332-xL ROMs operate asynchronously, and require no clock input. Two mask-programmable chip select inputs allow up to four 32 K ROMs to be OR-tied without external decoding. These devices provide tri-state output buffers for memory expansion. The R2332-xL ROMs offer TTL input and output levels with a minimum noise immunity of 0.4 volts.

## FEATURES

- 32,768 bits, organized in 4,096 8-bit bytes
- Max access time: 450 ns for R2332-L

400 ns for R2332-4L
350 ns for R2332-35L

- Typical power dissipation is 240 mW
- Drives two TTL loads and 100 pF
- Single +5 -volt power input
- Totally static operation, no clock input required
- Completely TTL compatible
- Two mask-programmable chip select inputs
- Three state outputs for memory expansion
- Identical cycle and access time


R2332 Pin Configuration


Order Number:

## SPECIFICATIONS

Maximum Ratings

| Rating | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage <br> Input Voltage <br> Operating Temperature <br> Commercial <br> Industrial <br> Storage Temperature | $\begin{aligned} & V_{C C} \\ & V_{\text {in }} \\ & T_{\text {STG }} \end{aligned}$ | $\begin{aligned} & -0.5 \text { to }+7.0 \\ & -0.5 \text { to }+7.0 \\ & 0 \text { to }+70 \\ & -40 \text { to }+85 \\ & -65 \text { to }+150 \end{aligned}$ | $\begin{aligned} & \text { Vdc } \\ & \text { Vdc } \\ & { }^{\circ} \mathrm{C} \end{aligned}$ |

This device contains input protection against damage due to high static voltages or electric fields; however, precautions should be taken to avoid application of voltages higher than the maximum rating.

## Electrical Characteristics for R2332-L and R2332-4L

$V_{C C}=5.0 \mathrm{~V} \pm 10 \%$ (unless otherwise specified)

| Symbol | Parameter | Min | Typ | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $v_{\mathrm{OH}}$ <br> $v_{\mathrm{OL}}$ <br> $v_{I H}$ <br> $v_{\text {IL }}$ | Output HIGH Voltage Output LOW Voltage Input HIGH Voltage Input LOW Voltage | $\begin{aligned} & 2.4 \\ & 2.0 \\ & 0.5 \end{aligned}$ |  | $\begin{aligned} & v_{c c} \\ & 0.4 \\ & v_{c c} \\ & 0.8 \end{aligned}$ | Volts <br> Volts <br> Volts <br> Volts | $\begin{aligned} & \mathrm{v}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-240 \mu \mathrm{~A} \\ & \mathrm{v}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=3.7 \mathrm{~mA} \end{aligned}$ |
| $\begin{aligned} & \mathrm{I}_{\mathrm{LI}} \\ & \mathrm{I}_{\mathrm{LO}} \\ & \mathrm{I}_{\mathrm{C}} \end{aligned}$ | Input Load Current Output Leakage Current <br> Power Supply Current Commercial Temp Industrial Temp |  | $\begin{aligned} & 48 \\ & 48 \end{aligned}$ | $\begin{gathered} 10 \\ \pm 10 \\ \\ 87 \\ 101 \end{gathered}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> mA | $\begin{aligned} & V_{C C}=5.5 \mathrm{~V}, 0 \mathrm{~V} \leq \mathrm{V}_{\text {in }} \leq 5.5 \mathrm{~V} \\ & \text { Chip Deselected, } V_{\mathrm{CC}}=5.5 \mathrm{~V} . \\ & v_{\text {out }}=+0.4 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{CC}} \\ & \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ |
| $\begin{aligned} & c_{1} \\ & c_{0} \end{aligned}$ | Input Capacitance Output Capacitance |  |  | $\begin{aligned} & 7 \\ & 10 \end{aligned}$ |  | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$. chip deselected, pin under test at $0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$, $\mathrm{f}=1 \mathrm{MHz}$ |

Electrical Characteristics for R2332-35L
$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%$ (unless otherwise specified)

| Symbol | Parameter | Min | Typ | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & v_{\mathrm{OH}} \\ & \mathrm{v}_{\mathrm{OL}} \\ & \mathrm{v}_{\mathrm{IH}} \\ & \mathrm{v}_{\mathrm{IL}} \\ & \hline \end{aligned}$ | Output HIGH Voltage Output LOW Voltage Input HIGH Voltage Input LOW Voltage | $\begin{array}{r} 2.4 \\ \\ 2.0 \\ -0.5 \end{array}$ |  | $\begin{aligned} & v_{c c} \\ & 0.4 \\ & v_{c c} \\ & 0.8 \end{aligned}$ | Volts <br> Volts <br> Volts <br> Volts | $\begin{aligned} & \mathrm{v}_{\mathrm{CC}}=4.75 \mathrm{v}, \mathrm{I}_{\mathrm{OH}}=-240 \mu \mathrm{~A} \\ & \mathrm{v}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=3.7 \mathrm{~mA} \end{aligned}$ |
| $\begin{aligned} & \mathrm{I}_{\mathrm{LI}} \\ & \mathrm{I}_{\mathrm{LO}} \\ & \\ & \mathrm{I}_{\mathrm{CC}} \end{aligned}$ | Input Load Current Output Leakage Current <br> Power Supply Current Commercial Temp |  | 48 | $\begin{gathered} 10 \\ \pm 10 \\ 87 \end{gathered}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ mA | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}, 0 \mathrm{~V} \leq \mathrm{V}_{\text {in }} \leq 5.25 \mathrm{~V} \\ & \text { Chip Deselected, } \mathrm{v}_{\mathrm{CC}}=5.25 \mathrm{~V}, \\ & \mathrm{v}_{\text {out }}=+0.4 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{CC}} \\ & \mathrm{v}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| $\begin{aligned} & c_{1} \\ & c_{0} \end{aligned}$ | Input Capacitance Output Capacitance |  |  | $\begin{aligned} & 7 \\ & 10 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $V_{C C}=5.0 \mathrm{~V}$, chip deselected, pin under test at $0 V, T_{A}=25^{\circ} \mathrm{C}$, $\mathrm{f}=\mathbf{1} \mathrm{MHz}$ |

## Timing Characteristics

$V_{C C}=5.0 \mathrm{~V} \pm 10 \%$ for R2332-L and R2332-4L, $V_{C C}=5.0 \mathrm{~V} \pm 5 \%$ for R2332-35L

| Symbot | Parameter | $\begin{aligned} & \text { R2332-L } \\ & \text { Max } \end{aligned}$ | $\begin{gathered} \text { R2332-4L } \\ \text { Max } \end{gathered}$ | $\begin{gathered} \text { R2332.35L } \\ \text { Max } \end{gathered}$ | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ${ }^{t} \mathbf{A}$ | Address Access Time Commercial Temp Industrial Temp | $\begin{aligned} & 450 \\ & 450 \end{aligned}$ |  | $350$ | ns | Output load: <br> 2 TTL loads, 100 pF <br> Input transition time: 20 ns |
| ${ }^{t} \mathrm{CO}$ | Chip Select Delay | 120 | 120 | 120 | ns | Timing reference levels: Input: 1.5 V . |
| ${ }^{t} \mathrm{DF}$ | Chip Deselect Delay | 100 | 100 | 100 | ns | Output: 0.8 V \& 2.0V |



Packaging Diagram


Typical Characteristics



## PRODUCT PREVIEW

## 8192 X 8 STATIC READ ONLY MEMORY

The R2364A2, R2364A25 and R2364A3 are 65,536-bit static Read-Only Memories (ROMs), organized as 8,192 eight-bit bytes, that offer maximum access times of 200, 250 and 300 nanoseconds, respectively. These ROMs are in industrystandard 28 -pin, dual in-line packages, and are available in ceramic or low-cost plastic. These fully-static 64 K -bit ROMs are compatible with all eight-bit N -channel microprocessors, including the R6500 family of microprocessors.
All three R2364A ROMs operate totally asynchronously, and require no clock input. These devices provide tri-state output buffers for memory expansion. The R2364A ROMs offer TTL input and output levels with a minimum noise immunity of 0.4 volts.

The mask-programmable chip enable input ( E ) may be programmed to function as a chip select with no power down or as a chip select with power down (standby mode). The active level of the enable input is also programmable.

## FEATURES

- 65,536 bits, organized as 8,192 eight-bit bytes
- Max. access time: 200 ns for R2364A2

250 ns for R2364A25
300 ns for R2364A3

- Low typical power dissipation is 125 mW active, $\mathbf{3 7 . 5 \mathrm { mW }}$ standby
- Drives two TTL loads and $\mathbf{1 0 0}$ pf
- Single +5 -volt power input
- Totally static operation, no input clock required
- Completely TTL compatible
- Mask-programmable chip enable
- Three state outputs for memory expansion
- Identical cycle and access time

Ordering Information
Order Number: R2364A



R2364A Block Diagram


R2364A Pin Configuration

## SPECIFICATIONS

Maximum Ratings

| Rating | Symbol | Value | Unit |
| :---: | :--- | :--- | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}$ | -0.5 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.5 to +7.0 | Vdc |
| Operating Temperature | T | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Commercial |  | -40 to +85 |  |
| Industrial | $\mathrm{T}_{\text {sTG }}$ | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |

This device contains input protection against damage due to high static voltages or electric fields; however, precautions should be taken to avoid application of voltages higher than the maximum rating.

## Electrical Characteristics

$V_{c c}=5.0 \mathrm{~V} \pm 10 \%$ (unless otherwide specified)

| Symbol | Parameter | Min | Typ | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \\ & \mathrm{~V}_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{I}} \end{aligned}$ | Output HIGH Voltage Output LOW Voltage Input HIGH Voltage Input LOW Voltage | $\begin{array}{r} 2.4 \\ \\ 2.0 \\ -0.5 \end{array}$ |  | $\begin{aligned} & V_{c c} \\ & 0.4 \\ & V_{c c} \\ & 0.8 \end{aligned}$ | Volts <br> Volts <br> Volts <br> Volts | $\begin{aligned} & \mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{cc}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=3.3 \mathrm{~mA} \end{aligned}$ |
| $l_{1}$ <br> Ito <br> Icc <br> $I_{s b}$ | Input Load Current <br> Output Leakage Current <br> Power Supply Current, Active <br> Power Supply Current, Standby |  | $\begin{aligned} & 25 \\ & 7.5 \end{aligned}$ | $\begin{aligned} & 10 \\ & \pm 10 \\ & \\ & 55 \\ & 16 \end{aligned}$ | $\mu \mathrm{A}$ $\mu \mathrm{A}$ <br> mA mA | $V_{c c}=5.5 \mathrm{~V}, 0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {in }} \leqslant 5.5 \mathrm{~V}$ <br> Chip Deselected, $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}$, <br> $\mathrm{V}_{\text {out }}=+0.4 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{cc}}$ <br> $V_{c c}=5.5 \mathrm{~V},-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ <br> $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V},-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| C <br> Co | Input Capacitance <br> Output Capacitance |  | $5$ $7$ |  | pF <br> pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}$, chip deselected, pin under test at $0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ $f=1 \mathrm{MHz}$ |

## PRODUCT PREVIEW

## 8192 X 8 STATIC READ ONLY MEMORY

The R2364B2，R2364B25 and R2364B3 are 65，536－bit static Read－Only Memories（ROMs），organized as 8,192 eight－bit bytes，that offer maximum access times of 200， 250 and 300 nanoseconds，respectively．These ROMs are in industry－ standard 28 －pin，dual in－line packages，and are available in ceramic or low－cost plastic．These fully－static 64 K －bit ROMs are compatible with all eight－bit N －channel microprocessors， including the R6500 family of microprocessors．
All three R2364G ROMs operate totally asynchronously，and require no clock input．Three mask－programmable chip se－ lect inputs allow up to eight 64K ROMs to be OR－tied without external decoding．These devices provide tri－state output buffers for memory expansion．The R2364B ROMs offer TTL input and output levels with a minimum noise immunity of 0.4 volts．
The mask－programmable chip enable input（ $E$ ）may be pro－ grammed to function as a chip select with no power down or as a chip select with power down（standby mode）．The active level of the enable input is also programmable．

## FEATURES

－65，536 bits，organized as 8，192 eight－bit bytes
－Max．access time： 200 ns for R2364B2
250 ns for R2364B25
300 ns for R2364B3
－Low typical power dissipation is $\mathbf{1 2 5 ~ m W}$ active， $\mathbf{3 7 . 5} \mathbf{~ m W}$ standby
－Drives two TTL loads and 100 pf
－Single +5 －volt power input
－Totally static operation，no input clock required
－Completely TTL compatible
－Three mask－programmable chip select inputs
－Mask－programmable chip enable
－Three state outputs for memory expansion
－Identical cycle and access time
Ordering Information
Order Number：R2364B
L Temperature Range： No suffix $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ $E=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ （industrial）
－Package：
C＝Ceramic．
$\mathbf{P}=$ Plastic
Access Time（Max）：

$$
\begin{aligned}
2 & =200 \mathrm{~ns} t_{\text {ACC }} \\
25 & =250 \mathrm{~ns} t_{\text {AcC }} \\
3 & =300 \mathrm{~ns} t_{\text {Acc }}
\end{aligned}
$$



R2364B Block Diagram


R2364B Pin Configuration

## SPECIFICATIONS

## Maximum Ratings

| Rating | Symbol | Value | Unit |
| :---: | :--- | :--- | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}$ | -0.5 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.5 to +7.0 | Vdc |
| Operating Temperature | T | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Commercial |  | -40 to +85 |  |
| Industrial | $\mathrm{T}_{\text {sTG }}$ | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature |  |  |  |

This device contains input protection against damage due to high static voltages or electric fields; however, precautions should be taken to avoid application of voltages higher than the maximum rating.

## Electrical Characteristics

$V_{c c}=5.0 \mathrm{~V} \pm 10 \%$ (unless otherwide specified)

| Symbol | Parameter | Min | Typ | - Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {OH }}$ | Output HIGH Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{cc}}$ | Volts | $\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\text {oL }}$ | Output LOW Voltage |  |  | 0.4 | Volts | $\mathrm{V}_{\mathrm{cc}}=4.5 \mathrm{~V}, \mathrm{I}_{0 \mathrm{~L}}=3.3 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {IH }}$ | Input HIGH Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}$ | Volts |  |
| $\mathrm{V}_{11}$ | Input LOW Voltage | -0.5 |  | 0.8 | Volts |  |
| $I_{L}$ | Input Load Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}, 0 \mathrm{~V} \leqslant \mathrm{~V}_{\text {in }} \leqslant 5.5 \mathrm{~V}$ |
| $\mathrm{I}_{20}$ | Output Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | Chip Deselected, $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}$, $V_{\text {out }}=+0.4 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{cc}}$ |
| $I_{\text {cc }}$ | Power Supply Current, Active |  | 25 | 55 | mA | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V},-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| $\mathrm{I}_{\text {sb }}$ | Power Supply Current, Standby |  | 7.5 | 16 | mA | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V},-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| $\mathrm{C}_{1}$ | Input Capacitance |  | 5 |  |  | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}$, chip deselected, pin under test at $O V, T_{A}=25^{\circ} \mathrm{C}$ |
| Co | Output Capacitance |  | 7 |  | pF | $f=1 \mathrm{MHz}$ |



## GENERAL DESCRIPTION

The R8104 and R8114 devices are $1024 \times 8$ "byte-wide" static RAMs. Both devices are available with a maximum access time of 200,300 or 400 nanoseconds.

The non-latched write function allows input data to be stable after WE is asserted - a feature ideally suited for microprocessor applications. Chip Enable (CE) latches the address, while data-in is latched by the trailing edge of $\overline{\text { Write Enable ( }} \overline{W E}$ ). The devices provide common data input/output pins for connection to a data bus. It operates on a single +5 V power supply and all input/ outputs are TTL compatible. The device dissipates less than 30 mW when in standby mode with $\overline{\mathrm{CE}}$ negated.

## FEATURES

- 1024 bytes
- EPROM, PROM, ROM pinout compatible
- Non-latched Write Function
- Ideal for microprocessor applications
- Common I/O bus
- Single +5 V power supply
- 200, 300, 400 nsec access times
- Less than 30 mW power (disabled)
- Less than 135 mW power (enabled)
- Available in either 22-pin or 24-pin dual-in-line packages


Pin Configurations
Order
Number: R8104- or R8114- LPackage: $^{\text {P1 }}$
$\mathbf{C}=$ Ceramic
$P=$ Package
——Max. Enabled Current
No suffix $=50 \mathrm{~mA}$
$L=25 \mathrm{~mA}$

- Access Time (Max.)
$2=200 \mathrm{~ns}$
$3=300 \mathrm{~ns}$
$4=400 \mathrm{~ns}$


R8104/R8114 Block Diagram

Recommended Operating Conditions: $\left(T_{A M B}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| PARAMETER | SYMBOL | MIN | NOM | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{\text {CC }}$ | 4.75 | 5.0 | 5.25 | $V$ |
| Input High Level | $V_{\text {IH }}$ | 2.0 | - | 5.25 | $V$ |
| Input Low Leve! | $V_{\text {IL }}$ | -0.5 | - | 0.8 | $V$ |

DC Characteristics: $\mathrm{T}_{\mathrm{A}}=\mathbf{0}^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{CC}}=+5 \mathrm{~V} \pm 5 \%$, unless otherwise noted

| PARAMETER | SYMBOL | MIN | TYP | MAX | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Output HIGH Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | 5.25 | v | $\mathrm{I}^{\text {OH }}=\mathbf{- 2 0 0} \mu \mathrm{A}$ (NOTE 1) |
| Output LOW Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.4 | v | $1 \mathrm{OL}=2.1 \mathrm{~mA}$ (NOTE 2) |
| Output Leakage Current | 'lo | -10 | - | +10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OL }}=0.4 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}} \overline{\mathrm{CE}}=\overline{\mathrm{WE}}=2.0 \mathrm{~V}$ |
| Input Leakage Current | 'LI | -10 | - | +10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0$ to 5.25 V ( $\mathrm{A}_{n}, \mathrm{CE}, \mathrm{WE}$, Only) |
| Power Supply Current <br> (Device Disabled) 8104/8114 | ${ }^{\text {ICC1 }}$ | - | 5 | 10 | mA | $\overline{\mathrm{CE}} \geqslant 2.0 \mathrm{~V}$ |
| Power Supply Current (Device Enabled) 8104/8114 | Icc2 | - | 25 | 50 | mA | $\overline{\mathrm{CE}} \leqslant 0.8 \mathrm{~V}$ |
| Power Supply Current <br> (Device Disabled) 8104L/8114L | Icc1 | - | - | 5 | mA | $\overline{C E} \geq 2.0 \mathrm{~V}$ |
| Power Supply Current (Device Enabled) 8104L/8114L | ${ }^{\prime} \mathrm{CC} 2$ | - | - | 25 | mA | $\overline{\mathrm{CE}}<0.8 \mathrm{~V}$ |

$A C$ Characteristics: $T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{C}}=5 \mathrm{~V} \pm 5 \%$, unless otherwise noted
Read Cycle

| CHARACTERISTICS | SYMBOL | 8104/8114.2 |  | 8104/8114-3 |  | 8104/8114-4 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Cycle Time | ${ }^{T} \mathrm{C}$ | 350 | - | 450 | - | 700 | - | nS |
| Chip Enable Pulse Width | $T^{T}$ CE | 200 | $\infty$ | 300 | $\infty$ | 400 | $\infty$ | nS |
| Chip Enable Rise and Fall Time (NOTE 2) | ${ }^{\text {Ther, }}$ TCF | - | 100 | - | 100 | - | 100 | ns |
| Address Set Up Time | ${ }^{T}$ AS | 0 | - | 0 | - | 0 | - | nS |
| Access Time | ${ }^{T}$ A | - | 200 | - | 300 | - | 400 | nS |
| Address Hold Time | ${ }^{\top}$ AH | 100 | - | 100 | $-$ | 200 | - | ns |
| Output Hold Time | ${ }^{\top}$ 'OH | 20 | 100 | 20 | 100 | 20 | 100 | nS |
| Fecovery Time | $\mathrm{T}_{\mathrm{P}}$ | 130 | - | 130 | - | 280 | - | nS |

Write Cycle

| CHARACTERISTICS | SYMBOL | 8104/8114.2 |  | 8104/8114.3 |  | 8104/8114-4 |  | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX | MIN | MAX |  |
| Cycle Time | ${ }^{\text {T }}$ C | 350 | - | 450 | - | 700 | - | nS |
| Chip Enable Pulse Width | ${ }^{\text {T }}$ CE | 200 | $\infty$ | 300 | $\infty$ | 400 | $\infty$ | nS |
| Chip Enable Rise and Fall Time (NOTE 2) | $\mathrm{T}^{\text {CRR, }}$ TCF | - | 100 | - | 100 | $\bigcirc$ | 100 | nS |
| Address Set Up Time | ${ }^{T}$ AS | 0 | - | 0 | - | 0 | - | nS |
| Address Hold Time | ${ }^{T}$ AH | 100 | - | 100 | - | 200 | - | ns |
| Recovery Time | ${ }^{\text {T }}$ P | 130 | - | 130 | - | 280 | - | ns |
| Write Enable Pulse Width | ${ }^{\text {T }}$ WP | 175 | - | 175 | - | 225 | - | nS |
| Write Enable Delay Time | ${ }^{T}$ WD | - | 25 | - | 25 | - | 25 | ns |
| Write Data Hold Time | TDH | 15 | - | 15 | - | 15 | - | ns |
| Data Set Up Time | TDS | 75 | - | 75 | - | 100 | - | nS |

Capacitance

| PARAMETER | SYMBOL | MIN | MAX | UNIT | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input Capazitance <br> Output Capacitance | $\mathrm{C}_{\mathrm{iN}}$ | - | 5 | pF | $\overline{\mathrm{CE}}=2 \mathrm{~V}$ |
| $\mathrm{COUT}^{\prime}$ | - | 5 | pF | $\mathrm{V}_{1 / \mathrm{O}}=0.4 \mathrm{~V}$ |  |

NOTE 1: Output terminated per Test Output Load diagram. Any valid combination of input voltages, $\mathrm{V}_{\mathrm{CC}}$, and temperature
NOTE 2: Typical Chip Enable Rise and Fall Time (TCR and TCF) is 10 nS for Read and Write Cycle

## Absolute Maximum Ratings

(See NOTE 1) (Referenced to $\mathrm{V}_{\text {SS }}$ )

| Rating | Value | Unit |
| :--- | :--- | :--- |
| Voltage to Any Pin With Respect to VSS | -0.5 to +7.0 | Vdc |
| Power Dissipation | 1.6 (NOTE 2) | W |
| Current Into/From Output | 50 | mA |
| Operating Ambient | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Temperature Range (TAMB) |  |  |
| Storage Temperature (TSTOR) | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |

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.

NOTE 1: Permanent device damage may occur if ABSOLUTE MAXIMUM RATINGS are exceeded. Functional operation should be restricted to RECOMMENDED OPERATING CONDITIONS. Exposure to higher than recommended or maximum voltages for extended periods of time could affect device reliability.

NOTE 2: At $25^{\circ} \mathrm{C}$ Ambient Derate $13.5 \mathrm{~mW} /{ }^{\circ} \mathrm{C}$.



Test Output Load

## FUNCTIONAL DESCRIPTION

The R8104 and R8114 are 8192 -bit Static RAMs with memory cells organized in eight arrays of 128 rows by 8 columns ( $1024 \times 8$ bits). Each eight-bit byte is addressed by simultaneously decoding the $X$ addresses ( $A 3$ through A9) for the rows, and the $Y$ addresses (A0 through A2) for the columns. Data is written or read in parallet on eight common input/output pins. Operation of the 8104 and 8114 is controiled by Chip Enable ( $\overline{C E}$ ) and Write Enable ( $\bar{W} E$ ).

When $\overline{C E}$ is high, all outputs are in a high impedance state, and power is supplied only to the memory elements. When $\overline{\mathrm{CE}}$ is low, the memory is enabled for reading and writing.

The negative going edge of $\overline{C E}$ begins timing for a read or a write cycle. Address and $\overline{W E}$ must be stable for $T_{A S}$ prior to $\overline{C E}$ being asserted. Data on address pins A0-A9 are latched into "D" type flip-flops and no longer need to be held stable. $\overline{W E}$, however, must be held stable throughout the cycle. For a read cycle ( $\overline{W E}=$ high), data will be available on the data I/O pins within time $T_{A}$ of $\overline{\mathrm{CE}}$ asserted, and will remain valid until time $\mathrm{T}_{\mathrm{OH}}$ after $\overline{\mathrm{CE}}$ is negated.

For a write cycle ( $\overline{W E}=$ low), data being written must be stable for TDS prior to $\overline{C E}$ returning high, and must remain stable for time TDH.

## Truth Table

| $\overline{\mathrm{CE}}$ | $\overline{\text { WE }}$ | $1 / \mathbf{O}_{\mathrm{n}}$ | Status | Mode |
| :---: | :---: | :---: | :---: | :---: |
| H | Don't Care | High Z | Disabled | Standby |
| L | H | Data | Enabled | Read |
| L | L | L | Enabled | Write 0 |
| L | L | H | Enabled | Write 1 |

## PACKAGING DIMENSIONS

R8104 (22 Pin) Dimensions

## PLASTIC PACKAGE

| Dim. | Millimaters |  | Inches |  |
| :---: | ---: | ---: | ---: | ---: |
|  | Min | Max | Min | Max |
| A | 27.940 | 29.718 | 1.100 | 1.170 |
| B | 8.636 | 9.144 | 0.340 | 0.360 |
| C | 4.318 | 5.080 | 0.150 | 0.180 |
| D | 0.356 | 0.559 | 0.014 | 0.022 |
| E | 1.016 | 1.778 | 0.040 | 0.070 |
| F | 2.413 | 2.667 | 0.095 | 0.105 |
| G | 1.016 | 2.032 | 0.040 | 0.080 |
| H | 0.203 | 0.305 | 0.008 | 0.012 |
| J | 9.144 | 10.160 | 0.360 | 0.400 |
| K | 10.160 | REF. | 0.400 | REF. |
| L | 0.508 | 1.016 | 0.020 | 0.040 |
| M | 2.540 | 3.937 | 0.100 | 0.155 |



R8114 (24 Pin) Dimensions
PLASTIC PACKAGE

|  | Millimeters |  | Inches |  |
| :---: | ---: | ---: | ---: | ---: |
|  | Min | Max | Min | Max |
| A | 31.369 | 32.131 | 1.235 | 1.265 |
| B | 12.954 | 13.462 | 0.510 | 0.530 |
| C | 3.937 | 5.588 | 0.155 | 0.215 |
| D | 0.381 | 0.584 | 0.015 | 0.023 |
| E | 1.016 | 1.651 | 0.040 | 0.065 |
| F | 2.286 | 2.794 | 0.090 | 0.110 |
| G | 0.381 | 1.270 | 0.015 | 0.050 |
| H | 0.203 | 0.305 | 0.008 | 0.012 |
| J | 15.240 | 15.748 | 0.600 | 0.620 |
| K | 15.748 | 16.764 | 0.640 | 0.660 |
| L | 0.381 | 1.016 | 0.015 | 0.040 |
| M | 2.540 | 4.064 | 0.100 | 0.160 |

## Typical Outline Drawing




R68000 Microcomputer System PRODUCT DESCRIPTION

## 16-BIT MICROPROCESSING UNIT

Advances in semiconductor technology have provided the capability to place on a single silicon chip a microprocessor at least an order of magnitude higher in performance and circuit complexity than has been previously available. The R68000 is the first of a family of such VLSI microprocessors from Rockwell. It combines state-of-theart technology and advanced circuit design techniques with computer sciences to achieve an architecturally advanced 16 -bit microprocessor.

The resources available to the R68000 user consist of the following

- 32-Bit Data and Address Registers
- 16 Megabyte Direct Addressing Range
- 56 Powerful Instruction Types
- Operatoons on Five Main Data Types
- Memory Mapped I/O
- 14 Addressing Modes

As shown in the programming model, 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 (DO-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 (AO-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.

The R68000 microprocessor is available in three models:

- R68000C4 (4 MHz)
- R68000C6 (6 MHz)
- R68000C8 ( 8 MHz )


A 23-bit address bus provides a memory addressing range of greater than 16 megabytes. This large range of addressing capability, coupled with a memory management unit, allows large, modular programs to be developed and operated without resorting to cumbersome and time consuming software bookkeeping and paging techniques.
The status register contains the interrupt mask (eight levels available) as well as the condition codes; extend (X). negative (N), zero (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.

## STATUS REGISTER



Five basic data types are supported. These data types are:

- Bits
- BCD Digits (4-bits)
- Bytes (8-bits)
- Words (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 1, include six basic types:

- Register Direct
- Register Indirect
- Absolute
- Immediate
- Program Counter Relative
- Implied

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 1 - DATA ADDRESSING MODES

| Mode | Generation |
| :---: | :---: |
| Register Direct Addressing Data Register Direct Address Register Direct | $\begin{aligned} & E A=D n \\ & E A=A n \end{aligned}$ |
| Absolute Data Addressing Absolute Short Absolute Long | $\begin{aligned} & E A=(\text { Next Word }) \\ & E A=(\text { Next Two Words }) \end{aligned}$ |
| Program Counter Relative Addressing Relative with Offset <br> Relative with Index and Offset | $\begin{aligned} & E A=(P C)+d_{16} \\ & E A=(P C)+\left(X_{n}\right)+d_{8} \end{aligned}$ |
| Register Indirect Addressing <br> Register Indirect <br> Postincrement Register Indirect <br> Predecrement Register Indirect <br> Register Indirect with Offset <br> Indexed Register Indirect with Offset | $\begin{aligned} & E A=(A n) \\ & E A=(A n), A n-A n+N \\ & A n-A n-N, E A=(A n) \\ & E A=(A n)+d_{16} \\ & E A=(A n)+(X n)+d_{8} \end{aligned}$ |
| Immediate Data Addressing Immediate Quick Immediate | DATA $=$ Next Words) <br> Inherent Data |
| Implied Addreasing Implied Register | $E A=S R$, USP, SP, PC |

## NOTES:

$E A=$ Effective Address
$A_{n}=$ Address Register
Dn= Data Register
Xn = Address or Data Register used as Index Register
SR = Status Register
PC= Program Counter
( )=Contents of
$\mathrm{d}_{8}=$ Eight-bit Offset (displacement)
$\mathrm{d}_{16}=$ Sixteen-bit Offset (displacement)
$\mathrm{N}=1$ for Byte, 2 for Words and 4 for Long Words
$-=$ Replaces

The 68000 instruction set is shown in Table 2. Some additional instructions are variations, or subsets, of these and they appear in Table 3. 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).

TABLE 2 - INSTRUCTION SET

| Mnemonic | Description | Mnemonic | Description | Mnemonic | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ABCD | Add Decimal with Extend <br> Add <br> Logical And <br> Arithmetic Shift Left <br> Arithmetic Shift Right | $\begin{aligned} & \text { EOR } \\ & \text { EXG } \\ & \text { EXT } \end{aligned}$ | Exclusive Or Exchange Registers Sign Extend | PEA | Push Effective Address |
| ADD |  |  |  | RESET <br> ROL <br> ROR <br> ROXL <br> ROXR <br> RTE <br> RTR <br> RTS | 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 |
| AND |  |  |  |  |  |
| ASL |  | JMP | Jump |  |  |
| ASR |  | JSR | Jump to Subroutine |  |  |
| ${ }^{B} \mathrm{CC}$ BCHG BCLR BRA BSET BSR BTST | Branch Conditionally Bit Test and Change Bit Test and Clear Branch Always Bit Test and Set Branch to Subroutine Bit Test | LEA | Load Effective Address |  |  |
|  |  | LINK | Link Stack |  |  |
|  |  | LSL | Logical Shift Left |  |  |
|  |  | LSR | Logical Shift Right |  |  |
|  |  | MOVE MOVEM MOVEP MULS MULU | Move <br> Move Multiple Registers <br> Move Peripheral Data <br> Signed Multiply <br> Unsigned Multiply | SBCD <br> $\mathrm{S}_{\mathrm{CC}}$ STOP SUB SWAP | Subtract Decinal with Extend <br> Set Conditional <br> Stop <br> Subtract <br> Swap Data Register Halves |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
| $\begin{aligned} & \text { CHK } \\ & \text { CLR } \\ & \text { CMP } \\ & \hline \end{aligned}$ | Check Register Against Bounds Clear Operand Compare |  |  |  |  |
|  |  |  |  |  |  |
|  |  | $\begin{array}{\|l\|} \hline \text { NBCD } \\ \text { NEG } \\ \text { NOP } \\ \text { NOT } \\ \hline \end{array}$ | Negate Decimal with Extend Negate No Operation One's Complement | TAS | Test and Set Operand |
| $\begin{aligned} & \mathrm{DB} \mathrm{CC} \\ & \text { DIVS } \\ & \text { DIVU } \end{aligned}$ | Test Condition, Decrement and Branch <br> Signed Divide Unsigned Divide |  |  | TRAP | Trap |
|  |  |  |  | TRAPV | Trap on Overflow |
|  |  |  |  | TST | Test |
|  |  | OR | Logical Or | UNLK | Unlink |

TABLE 3 - VARIATIONS OF INSTRUCTION TYPES

| Instruction Type | Variation | Description | Instruction Type | Variation | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ADD | $\begin{array}{\|l} \hline \text { ADD } \\ \text { ADDA } \\ \text { ADDO } \\ \text { ADDI } \\ \text { ADDX } \end{array}$ | Add <br> Add Address <br> Add Quick <br> Add Immediate <br> Add with Extend | MOVE | MOVE MOVEA MOVEQ MOVE from SR MOVE to SR MOVE to CCR MOVE USP | Move <br> Move Address <br> Move Quick <br> Move from Status Register <br> Move to Status Register <br> Move to Condition Codes <br> Move User Stack Pointer |
| AND | $\begin{aligned} & \text { AND } \\ & \text { ANDI } \end{aligned}$ | Logical And And Immediate |  |  |  |
| CMP | $\begin{aligned} & \text { CMP } \\ & \text { CMPA } \end{aligned}$ | Compare Compare Address | NEG | $\begin{aligned} & \text { NEG } \\ & \text { NEGX } \end{aligned}$ | Negate <br> Negate with Extend |
|  | $\begin{aligned} & \text { CMPM } \\ & \text { CMPI } \end{aligned}$ | Compare Memory Compare Immediate | OR | $\begin{array}{\|l\|} \hline \text { OR } \\ \text { ORI } \end{array}$ | Logical Or Or Immediate |
| EOR | EOR <br> EORI | Exclusive Or Exclusive Or Immediate | SUB | $\begin{aligned} & \hline \text { SUB } \\ & \text { SUBA } \\ & \text { SUBI } \\ & \text { SUBO } \\ & \text { SUBX } \end{aligned}$ | Subtract <br> Subtract Address <br> Subtract Immediate <br> Subtract Quick <br> Subtract with Extend |

## DATA ORGANIZATION AND ADDRESSING CAPABILITIES

The following paragraphs describe the data organization and addressing capabilities of the 68000 .

## 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. All explicit instructions support byte, word or long word operands. Implicit instructions support some subset of all three sizes.

## 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.

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.

## 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 1. The low order byte has an odd address that is one count higher than the word address. Instructions and multibyte data are accessed only on word (even bytel 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 68000 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 2.

## ADDRESSING

Instructions for the 68000 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.

FIGURE 1 - WORD ORGANIZATION IN MEMORY


FIGURE 2 - DATA ORGANIZATION IN MEMORY
Bit Data
1 Byte $=8$ Bits


Integer Data
1 Byte = 8 Bits

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| MSB |  | Byte 0 |  |  | LSB |  |  |  | Byte 1 |  |  |  |  |  |
|  |  | Byte 2 |  |  |  |  |  |  |  | Byte 3 |  |  |  |  |

1 Word = 16 Bits

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| MSB |  |  |  |  |  |  | Word 0 |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

1 Long Word = 32 Bits

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 3 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB | Lon | Wor | - |  |  |  | ow |  |  |  |  |  |  |  | - |
| - - Long Word 1- - - - - - - - - - - - - - - |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Addresses
1 Address $=32$ Bits

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB |  | ress |  |  |  |  |  | der <br> der |  |  |  |  |  |  | - |
| - - Address 1 - - - - - - - - - - - - - - - |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| - - Address $2 \sim-\sim-\ldots-\ldots-\ldots-\ldots$ |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

MSB $=$ Most Significant Bit
LSB $=$ Least Significant Bit
Decimal Data
2 Binary Coded Decimal Digits $=1$ Byte

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSD BCD 0 BCD 1 LSD BCD 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  | BC |  |  |  |  |  |  |

MSD $=$ Most Significant Digit
LSD $=$ Least Significant Digit

## INSTRUCTION FORMAT.

Instructions are from one to five words in length, as shown in Figure 3. The length of the instruction and the operation to be performed is specified by the first word of the instruction which is called the operation word. 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.

## PROGRAMJDATA REFERENCES

The 68000 separates memory references into two classes: program references, and data references. Program references, as the name implies, are references to that section of memory that contains the program being executed. Data references refer to that section of memory that contains data. Generally, operand reads are from the data space. All operand writes are to the data space.

## 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.

## EFFECTIVE ADDRESS

Most instructions specify the location of an operand by using the effective address field in the operation word. For example, Figure 4 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 3. 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 the operand.

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 is classified 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 is classified as a data reference with the exception of the jump and jump to subroutine instructions.

Address Register Indirect With Index. This address mode requires one word of extension. The address of the operand

FIGURE 3 - INSTRUCTION FORMAT


FIGURE 4 - SINGLE-EFFECTIVE-ADDRESS
INSTRUCTION OPERATION WORD GENERAL FORMAT

is the sum of the address in the address register, the signextended 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 MODES. 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 is classified 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 is classified 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 is the sum of the address in the program counter and the sign-extended 16 -bit displacement integer in the extension word. The value in the program counter is the address of the extension word. The reference is classified as a program reference.

Program Counter With Index. This address mode requires one word of extension. The address is the sum of the address 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 is classified as a program reference.

Immediate Data. This address mode requires either one or two words of extension depending on the size of the operation.

Byte operation - operand is low order byte of extension word
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.
Condition Codes or Status Register. A selected set of instructions may reference the status register by means of the effective address field. These are:

$$
\begin{aligned}
& \text { ANDI to CCR } \\
& \text { AND to SR } \\
& \text { EORI to CCR } \\
& \text { EORI to SR } \\
& \text { ORI to CCR } \\
& \text { ORI to SR }
\end{aligned}
$$

## EFFECTIVE ADDRESS ENCODING SUMMARY

Table 4 is a summary of the effective addressing modes discussed in the previous paragraphs.

## 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). Table 5 provides a list of these instructions and the registers implied.

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, SSP is the active system stack pointer, and the USP cannot be referenced as an address register. If the S-bit indicates user state, the USP is the active system stack pointer, and the SSP cannot be referenced. Each system stack fills from high memory to low memory.

TABLE 4 - EFFECTIVE ADDRESS ENCODING SUMMARY

| Addressing Mode | Mode | Register |
| :--- | :---: | :---: |
| Data Register Direct | 000 | register number |
| Address Register Direct | 001 | register number |
| Address Register Indirect | 010 | register number |
| Address Register Indirect with <br> Postincrement | 011 | register number |
| Address Register Indirect with <br> Predecrement | 100 | register number |
| Address Register Indirect with <br> Displacement | 101 | register number |
| Address Register Indirect with <br> Index | 110 | register number |
| $\left.\begin{array}{\|l\|l\|}\text { Absolute Short } & 111 \\ \hline \text { Absolute Long } & 111\end{array}\right] 000$ |  |  |
| Program Counter with <br> Displacement | 111 | 010 |
| Program Counter with Index | 111 | 011 |
| Immediate or Status Register | 111 | 100 |

TABLE 5 - IMPLICIT INSTRUCTION REFERENCE SUMMARY

| Instruction | Implied <br> Register(s) |
| :--- | :---: |
| Branch Conditional (BCC), Branch Always (BRA) | PC |
| Branch to Subroutine (BSR) | PC, SP |
| Check Register against Bounds (CHK) | SSP, SR |
| Test Condition, Decrement and Branch (DBCC) | PC |
| Signed Divide (DIVS) | SSP, SR |
| Unsigned Divide (DIVU) | SSP, SR |
| Jump (JMP) | PC |
| Jump to Subroutine (JSR) | PC, SP |
| Link and Altocate (LINK) | SP |
| Move Condition Codes (MOVE CCR) | SR |
| Move Status Register (MOVE SR) | SR |
| Move User Stack Pointer (MOVE USP) | USP |
| Push Effective Address (PEA) | SP |
| Return from Exception (RTE) | PC, SP. SR |
| Return and Restore Condition Codes (RTR) | PC, SP, SR |
| Return from Subroutine (RTS) | PC, SP |
| Trap (TRAP) | SSP, SR |
| Trap on Overflow (TRAPV) | SSP, SR |
| Unlink (UNLK) | SP |

## INSTRUCTION SET SUMMARY

The following paragraphs contain an overview of the form and structure of the 68000 instruction set. The instructions form a set of tools that include all the machine functions to perform the following operations:

Data Movement<br>Integer Arithmetic<br>Logical<br>Shift and Rotate<br>Bit Manipulation<br>Binary Coded Decimal<br>Program Control<br>System Control

The complete range of instruction capabilities combined with the flexible addressing modes described previously provide a very flexible base for program development.

## DATA MOVEMENT OPERATIONS

The basic method of data acquisition (transfer and storage) is provided by the move (MOVE) instruction. 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 6 is a summary of the data movement operations.
table 6 - data movement operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| EXG | 32 | Rx $\rightarrow$ Ry |
| LEA | 32 | $E A \rightarrow A n$ |
| LINK | - | $\begin{gathered} A n \rightarrow S P @- \\ S P \rightarrow A n \\ S P+d \rightarrow S P \end{gathered}$ |
| MOVE | 8. 16, 32 | (EA) $\rightarrow$ EAd |
| MOVEM | 16, 32 | $(E A) \rightarrow A n, D n$ <br> $A n, D n \rightarrow E A$ |
| MOVEP | 16, 32 | $\begin{gathered} (E A) \rightarrow D n \\ D n \rightarrow E A \end{gathered}$ |
| MOVEQ | 8 | $f \mathrm{xxx} \rightarrow$ Dn |
| PEA | 32 | EA $\rightarrow$ SP@ - |
| SWAP | 32 | Dn[31:16] $\rightarrow$ Dn[15:0] |
| UNLK | - | $\begin{gathered} A n \rightarrow S p \\ S P @+\rightarrow A n \end{gathered}$ |

## NOTES:

$s=$ source
$d=$ destination
[ ]=bit numbers
@- = indirect with predecrement
$@+=$ indirect with postdecrement

## INTEGER ARITHMETIC OPERATIONS

The arithmetic operations 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, with data operations accepting all 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 test operand (TST) instruction that will set the condition codes as a result of a compare of the operand with zero is also available. Test and set (TAS) is a synchronization instruction useful in multiprocessor systems. Table 7 is a summary of the integer arithmetic operations.

TABLE 7 - INTEGER ARITHMETIC OPERATIONS
$\left.\begin{array}{|c|c|c|}\hline \text { Instruction } & \text { Operand Size } & \begin{array}{c}\text { Operation }\end{array} \\ \hline \text { ADD } & 8,16,32 & \begin{array}{c}\text { Dn + (EA) } \rightarrow \text { Dn } \\ (E A)+\text { Dn } \rightarrow \text { EA }\end{array} \\ (E A)+f x x \rightarrow \text { EA } \\ \text { An + (EA) } \rightarrow \text { An }\end{array}\right]$

NOTE: [ ]= bit number

## 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 8 is a summary of the logical operations.

TABLE 8 - LOGICAL OPERATIONS

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| AND | 8, 16, 32 | DnA(EA) $\rightarrow$ Dn $(E A) A D n \rightarrow E A$ (EA) $A / \mathrm{xxx} \rightarrow \mathrm{EA}$ |
| OR | 8, 16, 32 | Dn $v(E A\} \rightarrow$ Dn $(E A) \vee D n \rightarrow E A$ $(E A) \vee / x x x \rightarrow E A$ |
| EOR | 8, 16, 32 | $\begin{aligned} & (E A) \oplus D y \rightarrow E A \\ & (E A) \oplus f x x \rightarrow E A \end{aligned}$ |
| NOT | 8, 16, 32 | $-(E A) \rightarrow E A$ |

NOTE: ~ = invert

## SHIFT AND ROTATE OPERATIONS

Shift operations in both directions are provided by the 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 the instruction of one to eight bits, or 0 to 63 specified in a data register.

Memory shifts and rotates are for word operands only and allow only single-bit shifts or rotates.

Table 9 is a summary of the shift and rotate operations.

TABLE 9 - SHIFT AND ROTATE OPERATIONS


## BIT MANIPULATION OPERATIONS

Bit manipulation operations are accomplished using the following instructions: bit test (BTST), bit test and set (BSET), bit test and clear (BCLR), and bit test and change (BCHG). Table 10 is a summary of the bit manipulation operations. (Bit 2 of the status register is Z. )

TABLE 10 - BIT MANIPULATION OPERATIONS

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| BTST | 8,32 | - bit of $(E A) \rightarrow Z$ |
| BSET | 8,32 | - bit of $(E A) \rightarrow Z$ <br> $1 \rightarrow$ bit of $E A$ |
| BCLR | 8,32 | - bit of $(E A) \rightarrow Z$ <br> $0 \rightarrow$ bit of $E A$ |
| BCHG | 8,32 | - bit of $(E A) \rightarrow Z$ <br> - bit of $(E A) \rightarrow$ bit of $E A$ |

## BINARY CODED DECIMAL OPERATIONS

Multiprecision arithmetic operations on binary coded decimal numbers are accomplished using the following instructions: add decimal with extend (ABCD), subtract decimal with extend (SBCD), and negate decimal with extend (NBCD). Table 11 is a summary of the binary coded decimal operations.

TABLE 11 - BINARY CODED DECIMAL OPERATIONS

| Instruction | Operand <br> Size | Operation |
| :---: | :---: | :---: |
| $A B C D$ | 8 | $D \times 10+D y_{10}+X \rightarrow D x$ <br> $A x @-10+A y @-10+X \rightarrow A x @$ |
| $S B C D$ | 8 | $D \times 10-D y 10-X \rightarrow D x$ <br> $A x @-10-A y @-10-X \rightarrow A x @$ |
| $N B C D$ | 8 | $0-(E A)_{10}-X \rightarrow E A$ |

## PROGRAM CONTROL OPERATIONS

Program control operations are accomplished using a series of conditional and unconditional branch instructions and return instructions. These instructions are summarized in Table 12.

The conditional instructions provide setting and branching for the following conditions:

| CC - carry clear | LS - low or same |  |
| :--- | :--- | :--- |
| CS - carry set | LT - less than |  |
| EQ - equal | MI - minus |  |
| F - - never true | NE - not equal |  |
| GE - greater or equal | PL - plus |  |
| GT - greater than | T | - always true |
| HI - high | VC - no overflow |  |
| LE - less or equal | VS - overflow |  |

TABLE 12 - PROGRAM CONTROL OPERATIONS

| Instruction | Operation |
| :---: | :--- |
| Conditional | Branch conditionally (14 conditions) |
| BCC | 8- and 16-bit displacement |
| DBCC | Test condition, decrement, and branch <br> 16 -bit displacement |
| SCC | Set byte conditionally (16 conditions) |

## 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 13.

TABLE 13 - SYSTEM CONTROL OPERATIONS

| Instruction | Operation |
| :---: | :--- |
| Privileged |  |
| RESET | Reset external devices |
| RTE | Return from exception |
| STOP | Stop program execution |
| ORI to SR | Logical OR to status register |
| MOVE USP | Move user stack pointer |
| ANDI to SR | Logical AND to status register |
| EORI to SR | Logical EOR to status register |
| MOVE EA to SR | Load new status register |
| Trap Generating |  |
| TRAP | Trap |
| TRAPV | Trap on overflow |
| CHK | Check register against bounds |
| 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 |
| ORI to CCR | Logical OR to condition codes |
| MOVE SR to EA | Store status register |

## SIGNAL AND BUS OPERATION DESCRIPTION

The following paragraphs contain a brief description of the input and output signals. A discussion of bus operation during the various machine cycles and operations is also given.

## SIGNAL DESCRIPTION

The input and output signals can be functionally organized into the groups shown in Figure 5. The following paragraphs provide a brief description of the signals and also a reference (if applicable) to other paragraphs that contain more detail about the function being performed.

ADDRESS BUS (A1 THROUGH A23). This 23-bit, unidirectional, three-state bus is capable of addressing 8 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 provide information about what level interrupt is being serviced while address lines A4 through A23 are all set to a logic high.

DATA BUS (DO THROUGH D15). This 16 -bit, bidirectional, three-state bus is the general purpose data path. It can transfer and accept data in either word or byte length. During an interrupt acknowledge cycle, the external device supplies the vector number on data lines DO-D7.

ASYNCHRONOUS BUS CONTROL. Asynchronous data transfers are handied using the following control signals: address strobe, read/write, upper and lower data strobes, and data transfer acknowledge. These signals are explained in the following paragraphs.

FIGURE 5 - INPUT AND OUTPUT SIGNALS


Address Strobe ( $\overline{\mathrm{AS}}$ ). This signal indicates that there is a valid address on the address bus.

Read/Write ( $\mathrm{R} / \overline{\mathrm{W}}$ ). This signal 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{\mathrm{UDS}}, \overline{\mathrm{LDS}}$ ). These signals control the data on the data bus, as shown in Table 14. When the $R / \bar{W}$ line is high, the processor will read from the data bus as indicated. When the $\mathrm{R} / \overline{\mathrm{W}}$ line is low, the processor will write to the data bus as shown.

TABLE 14 - DATA STROBE CONTROL OF DATA BUS

| UDS | $\overline{\text { LDS }}$ | R/ $\overline{\mathrm{W}}$ | D8-D15 | D0-D7 |
| :---: | :---: | :---: | :---: | :---: |
| High | High | - | No valid data | No valid data |
| Low | Low | High | Valid data bits <br> $8-15$ | Valid data bits <br> $0-7$ |
| High | Low | High | No valid data | Valid data bits <br> $0-7$ |
| Low | High | High | Valid data bits <br> $8-15$ | No valid data |
| Low | Low | Low | Valid data bits <br> $8-15$ | Valid data bits <br> $0-7$ |
| High | Low | Low | Valid data bits <br> $0-7 *$ | Valid data bits <br> $0-7$ |
| Low | High | Low | Valid data bits <br> $8-15$ | Valid data bits <br> $8-15^{*}$ |

- These conditions are a result of current implementation and may not appear on future devices.

Data Transfer Acknowledge ( $\overline{\text { DTACK }}$ ). This input indicates that the data transfer is completed. When the processor recognizes DTACK during a read cycle, data is latched and the bus cycle terminated. When DTACK is recognized during a write cycle, the bus cycle is terminated.

BUS ARBITRATION CONTROL. These three signals form a bus arbitration circuit to determine which device will be the bus master device.

Bus Request ( $\overline{B R}$ ). This input is wire ORed with all other devices that could be bus masters. This input indicates to the processor that some other device desires to become the bus master.

Bus Grant ( $\overline{\mathrm{BG}}$ ). This 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{\text { BGACK }}$ ). This 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 has been received
2. address strobe is inactive which indicates that the microprocessor is not using the bus
3. data transfer acknowledge is inactive which indicates that either memory or the peripherals are not using the bus
4. bus grant acknowledge is inactive which indicates that no other device is still claiming bus mastership.

INTERRUPT CONTROL ( $\overline{\mathrm{PLL}}, \overline{\mathrm{IPL1}}, \overline{\mathrm{IPL}})$ ). 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. The least significant bit is given in IPLO and the most significant bit is contained in $\overline{\mathrm{PLL}}$.

SYSTEM CONTROL. The system control inputs are used to either reset or halt the processor and to indicate to the processor that bus errors have occurred. The three system control inputs are explained in the following paragraphs.

Bus Error ( $\overline{B E R R}$ ). This input informs the processor that there is a problem 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
4. other application dependent errors.

The bus error signal interacts with the 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{\text { RESET }})$. This bidirectional signal line acts to reset (initiate a system initialization sequence) the processor in response to an external reset signal. An internally generated reset (result of a RESET instruction) causes all external devices to be reset and the internal state of the processor is not affected. A total system reset (processor and external devices) is the result of external halt and reset signals applied at the same time. Refer to RESET OPERATION paragraph for additional information about reset operation.

Halt ( (IALT). When this bidirectional line is driven by an external device, it will cause the processor to stop at the completion of the current bus cycle. When the processor has been halted using this input, all control signals are inactive and all three-state lines are put in their high-impedance state. Refer to BUS ERROR AND HALT OPERATION paragraph for additional information about the interaction between the halt and bus error signals.
When the processor has stopped executing instructions, such as in a double bus fault condition, the halt line is driven by the processor to indicate to external devices that the processor has stopped.

R6500 PERIPHERAL CONTROL. These control signals are used to allow the interfacing of synchronous R6500 peripheral devices with the asynchronous 68000 . These signals are explained in the following paragraphs.

Enable (E). This is the standard enable signal commonly called $\emptyset 2$ in R6500 peripheral devices. The period for this output is ten 68000 clock periods (six clocks low; four clocks high).

Valid Peripheral Address (VPA). This 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}}$ ). This output is used to indicate to R6500 peripheral devices that there is a valid address on the address bus and the processor is synchronized to enable. This signal only responds to a valid peripheral address (VPA) input which indicates that the peripheral is a R6500 family device.

PROCESSOR STATUS (FCO, FC1, FC2). These function code outputs indicate the state (user or supervisor) and the
cycle type currently being executed, as shown in Table 15. The information indicated by the function code outputs is valid whenever address strobe ( $\overline{\mathrm{AS}}$ ) is active.

TABLE 15 - FUNCTION CODE OUTPUTS

| FC2 | FC1 | FC0 | Cycle Type |
| :---: | :---: | :---: | :---: |
| Low | Low | Low | UUndefined, Reserved) |
| Low | Low | High | User Data |
| Low | High | Low | User Program |
| Low | High | High | Undefined, Reserved) |
| High | Low | Low | (Undefined, Reserved) |
| High | Low | High | Supervisor Data |
| High | High | Low | Supervisor Program |
| High | High | High | Interrupt Acknowledge |

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 shall be a constant frequency.

SIGNAL SUMMARY. Table 16 is a summary of all the signals discussed in the previous paragraphs.

TABLE 16 - SIGNAL SUMMARY

| Signal Name | Mnemonic | Input/Output | Active State | Three State |
| :---: | :---: | :---: | :---: | :---: |
| Address Bus | A1-A23 | output | high | yes |
| Data Bus | D0-D15 | input/output | high | yes |
| Address Strobe | $\overline{\text { AS }}$ | output | low | yes |
| Read/Write | R/W | output | read-high write-low | yes |
| Upper and Lower Data Strobes | UDS, $\overline{\text { LDS }}$ | output | low | yes |
| Data Transfer Acknowledge | DTACR | input | low | no |
| Bus Request | $\overline{\mathrm{BR}}$ | input | low | no |
| Bus Grant | $\overline{\text { BG }}$ | output | low | no |
| Bus Grant Acknowledge | BGACR | input | low | no |
| Interrupt Priority Level | IPLO, IPL1, IPL2 | input | low | no |
| Bus Error | BERR | input | low | no |
| Reset | RESET | input/output | low | no ${ }^{\circ}$ |
| Halt | HALT | input/output | low | no* |
| Enable | E | output | high | no |
| Valid Mernory Address | $\overline{\text { VMA }}$ | output | low | yes |
| Valid Peripheral Address | $\overline{\text { VPA }}$ | input | low | no |
| Function Code Output | FC0, FC1, FC2 | output | high | yes |
| Clock | CLK | input | high | no |
| Power Input | $\mathrm{V}_{\mathrm{CC}}$ | input | - | - |
| Ground | GND | input | - | - |

- open drain


## 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 leads:

- Address Bus A1 through A23
- Data Bus D0 through D15
- Control Signals

The address and data buses are separate parallel buses used to 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 68000 for interlocked multiprocessor communications.

FIGURE 6 - WORD READ CYCLE FLOW CHART
BUS MASTER
SLAVE

Address, Device
1)
Set R/ $/ \bar{W}$ to Read
2)
3lace Address on A1-A23
3)


Input Data

1) Decode Address
2) Place Data on D0-D15
3) Assert Data Transfer Acknowledge

4) Latch Data
5) Negate $\overline{U D S}$ and $\overline{\mathrm{LDS}}$
6) Negate $\overline{A S}$


## NOTE

The terms assertion and negation will be used extensively. This is done to avoid confusion when dealing with a mixture of "active-low" and "active-high" signals. The term assert or assertion is used to indicate that a signal is active or true independent of whether that voltage is low or high. The term negate or negation is used to indicate that a signal is inactive or false.

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. If the instruction specifies a word lor double word) operation, the processor reads both bytes. 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. For byte operations, when the AO bit equals zero, the upper data strobe is issued. When the AO bit equals one, the lower data strobe is issued. When the data is received, the processor correctly positions it internally.
A word read cycle flow chart is given in Figure 6. A byte read cycle flow chart is given in Figure 7. Readcycle timing is given in Figure 8 and Figure 9 details word and byte read cycle operation.
figure 7 - byte read cycle flow chart

BUS MASTER
SLAVE

## Address Device

1) Set $R / \bar{W}$ to Read
2) Place Address on A1-A23
3) Place Function Code on FCO-FC2
4) Assert Address Strobe ( $\overline{\mathrm{AS}}$ )
5) Assert Upper Data Strobe ( $\overline{\mathrm{UDS}}$ ) or Lower Data Strobe (LDS) (based on AO)

6) Decode Address
7) Place Data on DO-D7 or D8-D15 (based on $\overline{U D \bar{S}}$ or $\overline{\mathrm{LDS}})$
8) Assert Data Transfer Acknowledge

9) Latch Data
10) Negate $\overline{U D S}$ or $\overline{\mathrm{LDS}}$
11) Negate $\overline{A S}$


FIGURE 8 - READ AND WRITE CYCLE TIMING DIAGRAM


FIGURE 9 - WORD AND BYTE READ CYCLE TIMING DIAGRAM


Write Cycle. During a write cycle, the processor sends data to memory or a peripheral device. The processor writes bytes of data in all cases. 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. For byte opera-
tions, when the AO bit equals zero, the upper data strobe is issued. When the $A 0$ bit equals one, the lower data strobe is issued. A word write cycle flow chart is given in Figure 10. A byte write cycle flow chart is given in Figure 11. Write cycle timing is given in Figure 8 and Figure 12 details word and byte write cycle operation.

FIGURE 10 - WORD WRITE CYCLE FLOW CHART
BUS MASTER
SLAVE

Address Device

1) Place Address on A1-A23
2) Place Function Code on $\mathrm{FCO}-\mathrm{FC} 2$
3) Assert Address Strobe ( $\overline{\mathrm{AS}}$ )
4) Set $R / \bar{W}$ to Write
5) Place Data on DO-D15
6) Assert Upper Data Strobe (UDS) and Lower Data Strobe ( $\overline{\mathrm{LDS}}$ )

Input Data

1) Decode Address
2) Store Data on D0-D15
3) Assert Data Transfer Acknowledge ( $\overline{\mathrm{DTACK}}$ )

Terminate Output Transfer

1) Negate $\overline{\overline{U D S}}$ and $\overline{\overline{D S S}}$
2) Negate $\overline{A S}$
3) Remove Data from D0-D15
4) Set R/W to Read

FIGURE 11 - BYTE WRITE CYCLE FLOW CHART
BUS MASTER
SLAVE
Address Device

1) Place Address on A1-A23
2) Place Function Code on FCO-FC2
3) Assert Address Strobe (AS)
4) Set R/W to Write
5) Place Data on D0-D7 or D8-D15 laccording to A 0$)$
6) Assert Upper Data Strobe ( $\overline{U D S}$ ) or Lower Data Strobe (LDS) (based on A0)

7) Decode Address
8) Store Data on DO-D7 if $\overline{L D S}$ is asserted Store Data on D8-D15 if $\overline{U D S}$ is asserted
9) Assert Data Transfer Acknowledge (DTACK)

Terminate Output Transfer

1) Negate $\overline{\overline{U D S}}$ and $\overline{\overline{L D S}}$
2) Negate $\overline{A S}$
3) Remove Data from DO-D7 or D8-D15
4) Set R/W to Read


FIGURE 12 - WORD AND BYTE WRITE CYCLE TIMING DIAGRAM


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 68000 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 proces-
sor environment. This instruction is the only instruction that uses the read-modify-write cycles and 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 13 and a timing diagram is given in Figure 14.

FIGURE 13 - READ-MODIFY-WRITE CYCLE FLOW CHART
BUS MASTER SLAVE
Address Device

1) Place Address on A1-A23
2) Set $R / \bar{W}$ to Read
3) Assert Address Strobe ( $\overline{\mathrm{AS}}$ )
4) Assert Upper Data Strobe ( $\overline{\mathrm{USS}}$ ) or Lower

Data Strobe ( $\overline{\mathrm{LDS}}$ )


FIGURE 14 - READ-MODIFY-WRITE CYCLE TIMING DIAGRAM


$$
K---- \text { Indivisible Cycle }-\infty-\infty \rightarrow 1
$$

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.
3. Acknowledging that mastership has been assumed.

Figure 15 is a flow chart showing the detail involved in a request from a single device. Figure 16 is a timing diagram for the same operations. 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 type of operation would be true for a system consisting of the processor and one device capable of bus mastership. In systems having a number of devices capable of bus mastership, the bus request line from each device is wire 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 signal is negated 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 it was negated. 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 15 - BUS ARBITRATION CYCLE FLOW.CHART PROCESSOR requesting device

1) Assert Bus $\frac{\text { Request the Bus }}{\text { Request }(\vec{B} R)}$
2) Assert Bus Request ( $\bar{B} \vec{R}$ )
$V$
Grant Bus Arbitration
3) Assert Bus Grant ( $\overline{\mathrm{BG}}$ )

4) External arbitration determines next bus master
5) Next bus master waits for current cycle to complete
6) Next bus master asserts Bus Grant Acknowledge ( $\overline{\mathrm{BGACK}}$ ) to become new master
7) Bus master negates $\overline{B R}$


Terminate Arbitration

1) Negate $\overline{\mathrm{BG}}$ land wait for $\overline{B G \overline{A C K}}$ to be negated)

Operate as Bus Master

1) Perform Data Transfers (Read and Write cycles) according to the same rules the processor uses.

Release Bus Mastership


Requesting the Bus. External devices capable of becoming bus masters request the bus by asserting the bus request ( $\overline{\mathrm{BR}}$ ) signal. This is a wire ORed signal lalthough it need not be constructed from open collector devices) that indicates to the processor that some external device requires control of the external bus. The processor is effectively at a lower bus priority level than the external device and will relinquish the bus after it has completed the last bus cycle it has started.

When 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 responded to noise inadvertently.

Receiving the Bus Grant. The processor asserts bus grant $(\overline{\mathrm{BG}})$ as soon as possible. Normally this is immediately after internal synchronization. The only exception to this 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 daisychained 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.

Acknowledgement of Mastership. Upon receiving a bus grant, the requesting device waits until address strobe, data transfer acknowledge, and bus grant acknowledge are negated before issuing its own BGACK. The negation of the address strobe indicates that the previous master has com-
pleted its cycle, the negation of bus grant acknowledge indicates that the previous master has released the bus. (While 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. Note that in some applications data transfer acknowledge might not enter into this function. General purpose devices would then be connected such that they were only dependent on address strobe. When bus grant acknowledge is issued the device is bus master until it negates bus grant acknowledge. Bus grant acknowledge should not be negated until after the bus cycle(s) is (are) completed. Bus mastership is terminated at the negation of bus grant acknowledge.
The bus request from the granted device should be dropped when bus grant acknowledge is asserted. If bus request is still asserted after bus grant acknowledge is negated, the processor performs another arbitration sequence and issues another bus grant. Note that the processor does not perform any external bus cycles before it re-asserts bus grant.

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.

Exception Sequence. The bus error exception sequence is entered when the processor receives a bus error signal and the halt pin is inactive. Figure 17 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
4. Executing the bus error handler routine

The stacking of the program counter and the status register is the same as if an interrupt had occurred. 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 the processor receives a bus error signal and the halt pin is being driven by an external device, the processor enters the re-run sequence. Figure 18 is a timing diagram for re-running the bus cycle.

The processor completes the bus cycle, then puts the address, data and function code output lines in the highimpedance state. The processor remains "halted," and will not run another bus cycle until the halt signal is removed by external logic. 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. The bus error signal should be removed before the halt signa! is removed.

FIGURE 17 - BUS ERROR TIMING DIAGRAM


FIGURE 18 - RE-RUN BUS CYCLE TIMING INFORMATION


## 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-and-Set operation is performed without ever releasing $\overline{\mathrm{AS}}$.

Halt Operation with No Bus Error. The halt input signal to the 68000 performs a Halt/Run/Single-Step function in a similar fashion to the M6800 halt function. The halt and run modes are somewhat self explanatory in that 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 is derived from correctly timed transitions on the halt signal input. It 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 19 details the timing required for correct single-step operations. Some care must be exercised to avoid harmful interactions between the bus error signal and the halt pin 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 the halt signal is active, most three-state signals are put in the high-impedance state. These include:

1. address lines
2. data lines
3. function code lines

This is required for correct performance of the re-run bus cycle operation.

Note that when the processor honors a request to halt, the function codes are put in the high-impedance state their buffer characteristics are the same as the address buffers). While the processor is honoring the halt request, bus arbitration performs as usual. That is, halting has no effect on bus arbitration. It is the bus arbitration function that removes the control signals from the bus.

The halt function and the hardware trace capability allow the hardware debugger to trace single bus cycles or single instructions one at a time. These processor capabilities, along with a software debugging package, give total debugging flexibility.

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. This is commonly referred to as a double bus fault. When a double bus fault occurs, the processor will 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.

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. Note also that 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 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 for 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.

FIGURE 19 - HALT SIGNAL TIMING CHARACTERISTICS


RESET OPERATION. The reset signal is a bidirectional signal that allows either the processor or an external signal to reset the system. Figure 20 is a timing diagrami for reset operations. Both the halt and the reset lines must be applied to ensure total reset of the processor.

When the reset and halt lines are driven by an external device, it is recognized as an entire system reset, including the processor. The processor responds by reading the reset vector table entry (vector number zero, address $\$ 000000$ ) and loads it 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. No other registers are affected by the reset sequence.
When a RESET sequence is executed, the processor drives the reset pin for 124 clock pulses. In this case, the processor is trying to reset the rest of the system. Therefore, there is no effect on the internal state of the processor. All of the processor's internal registers and the status register are unaffected by the execution of a RESET instruction. All external devices connected to the reset line should be reset at the completion of the RESET instruction.
When $V_{C C}$ is initially applied to the processor, an external reset must be applied to the reset pin for 100 milliseconds.

FIGURE 20 - RESET OPERATION TIMING DIAGRAM


## EXCEPTION PROCESSING

The following paragraphs describe the actions of the 68000 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. Finally, the sequence of memory references and actions taken by the processor on exception conditions is detailed.

## PROCESSING STATES

The 68000 is always one of three processing states: normal, exception, or halted. The normal processing state is that 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 memory 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 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.

## PRIVILEGE STATES

The processor operates in one of two states of privilege: the "user" state or the "supervisor" state. The privilege state determines which operations are legal, is used by the external memory management device to control and translate accesses, and is used to choose between the supervisor stack pointer and the user stack pointer in instruction references.

The privilege state is a mechanism for providing security in a computer system. Programs should access only their own code and data areas, and ought to be restricted from accessing information which they do not need and must not modify.

The privilege mechanism provides security 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. The operating system 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 the S-bit of the status register; if the S -bit is asserted (high), the processor is in the supervisor state. 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 the S-bit of the status register; if the S -bit is negated (low), the processor is executing instructions in the user state.

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, status register are privileged. To aid in debugging programs which are to be used as operating systems, the move to user stack pointer (MOVE USP) and move from user stack pointer (MOVE from USPI 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 the 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 at the address specified 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, 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 17 lists the classification of references.

TABLE 17 - REFERENCE CLASSIFICATION

| Function Code Output |  |  | Reference Class |
| :---: | :---: | :---: | :---: |
| FC2 | FC1 | FC0 |  |
| 0 | 0 | 0 | (Unassigned) |
| 0 | 0 | 1 | User Data |
| 0 | 1 | 0 | User Program |
| 0 | 1 | 1 | (Unassigned) |
| 1 | 0 | 0 | (Unassigned) |
| 1 | 0 | 1 | Supervisor Data |
| 1 | 1 | 0 | Supervisor Program |
| 1 | 1 | 1 | Interrupt Acknowledge |

## 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 context. 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 21), except for the reset

FIGURE 21 - EXCEPTION VECTOR FORMAT


FIGURE 22 - PERIPHERAL VECTOR NUMBER FORMAT


## Where:

$v 7$ is the MSB of the Vector Number $\mathbf{0}$ is the LSB of the Vector Number
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 eightbit number which, when multiplied 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 22) 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 23. The memory layout for exception vectors is given in Table 18.

As shown in Table 18, 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 by either internal or external causes. The externally generated exceptions are the interrupts and the bus error and reset requests. The interrupts are requests from peripheral devices for processor action while the bus error and reset inputs are used for access control and processor restart. The internally generated exceptions come from instructions, or from ad-

## FIGURE 23 - ADDRESS TRANSLATED FROM 8-BIT VECTOR NUMBER



TABLE 18 - EXCEPTION VECTOR ASSIGNMENT

| Vector Number(s) | Address |  |  | Assignment |
| :---: | :---: | :---: | :---: | :---: |
|  | Dec | Hex | Space |  |
| 0 | 0 | 000 | SP | Reset: Initial SSP |
| - | 4 | 004 | SP | Reset: Initial PC |
| 2 | 8 | 008 | SD | Bus Error |
| 3 | 12 | 00 C | SD | Address Error |
| 4 | 16 | 010 | SD | Illegal Instruction |
| 5 | 20 | 014 | SD | Zero Divide |
| 6 | 24 | 018 | SD | CHK Instruction |
| 7 | 28 | 01C | SD | TRAPV Instruction |
| 8 | 32 | 020 | SD | Privilege Violation |
| 9 | 36 | 024 | SD | Trace |
| 10 | 40 | 028 | SD | Line 1010 Emulator |
| 11 | 44 | 02C | SD | Line 1111 Emulator |
| 12* | 48 | 030 | SD | (Unassigned, reserved) |
| $13^{*}$ | 52 | 034 | SD | (Unassigned, reserved) |
| $14^{*}$ | 56 | 038 | SD | (Unassigned, reserved) |
| 15 | 60 | 03C | SD | (Unassigned, reserved) |
| 16-23* | 64 | O4C | SD | (Unassigned, reserved) |
|  | 95 | 05F |  | - |
| 24 | 96 | 060 | SD | Spurious Interrupt |
| 25 | 100 | 064 | SD | Level 1 Interrupt Autovector |
| 26 | 104 | 068 | SD | Level 2 Interrupt Autovector |
| 27 | 108 | 06C | SD | Level 3 Interrupt Autovector |
| 28 | 112 | 070 | SD | Level 4 Interrupt Autovector |
| 29 | 116 | 074 | SD | Leve! 5 Interrupt Autovector |
| 30 | 120 | 078 | SD | Level 6 Interrupt Autovector |
| 31 | 124 | 07C | SD | Level 7 Interrupt Autovector |
| 32-47 | 128 | 080 | SD | TRAP Instruction Vectors |
|  | 191 | OBF |  | - |
| 48-63* | 192 | OCO | SD | (Unassigned, reserved) |
|  | 255 | OFF |  | - |
| 64-255 | 256 | 100 | SD | User Interrupt Vectors |
|  | 1023 | 3FF |  | - |

*Vector numbers 12, 13, 14, 16 through 23 and 48 through 63 are reserved for future enhancements. No user peripheral devices should be assigned these numbers.
dress errors or tracing. The trap (TRAP), trap on overflow (TRAPV), check register against bounds (CHK) and divide (DIV) instructions all can 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.
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. 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 at the next minor cycle of the processor. 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 ocrur 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 bus error and then address 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.

The priority relation between two exceptions determines which is taken, or 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. A summary of exception grouping and priority is given in Table 19.

TABLE 19 - EXCEPTION GROUPING AND PRIORITY

| Group | Exception | Processing |
| :---: | :---: | :--- |
| 0 | Reset <br> Bus Error <br> Address Error | Exception processing begins at <br> the next minor cycle |
| 1 | Trace <br> Interrupt <br> Illegal <br> Privilege | Exception processing begins before <br> the next instruction |
| 2 | TRAP. TRAPV. <br> CHK. <br> Zero Divide | Exception processing is started by <br> normal instruction execution |

## EXCEPTION PROCESSING DETAILED DISCUSSION

Exceptions have a number of sources, and each exception has processing which is peculiar to it. 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 power-up/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, and 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 force 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, 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 24; a timing diagram is given in Figure 25.

FIGURE 24 - INTERRUPT ACKNOWLEDGE SEQUENCE FLOW CHART

## PROCESSOR INTERRUPTING DEVICE



1) Compare interrupt level in status register and wait for current instruction to complete
2) Place interrupt level on A1, A2, A3
3) Set R/W to read
4) Set function code to interrupt acknowledge
5) Assert address strobe ( $\overline{\mathrm{AS}}$ )
6) Assert lower data strobe ( $\overline{\mathrm{LDS}}$ )

7) Place vector number of D0-D7 2) Assert data transfer acknowledge (DTACK)


Acquire Vector Number

1) Latch vector number
2) Negate LDS
3) Negate $\overline{\mathrm{AS}}$

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.

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.
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. IIlegal instruction is the term used to refer 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.
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:

| STOP | AND (word) Immediate to SR |
| :--- | :--- |
| RESET | EOR (word) Immediate to SR |
| RTE | OR (word) Immediate to SR |
| MOVE to SR | MOVE USP |

TRACING. To aid in program development, the 68000 includes a facility to allow instruction by instruction tracing. In the trace state, after each instruction is executed an exception 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 ad-

FIGURE 26 - SUPERVISOR STACK ORDER


R/W (read/write): $w$ rite $=0$, read $=1 . I / N$ finstruction/not): instruction $=0$, not $=1$
dress 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 it is in the normal state or processing a Group 2 exception; the processor is not processing an instruction if it is processing a Group 0 or a Group 1 exception. Figure 26 illustrates how this information is organized on the supervisor stack. Although this information is not sufficient in general 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.

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.

## INTERFACE WITH R6500 PERIPHERALS

Rockwell's line of R6500 peripherals are directly compatible with the 68000. Some of these devices that are particularly useful are:

R6520 Peripheral Interface Adapter (PIA)
R6522 Versatile Interface Adapter (VIA)
R6545 CRT Controller
R6551 Asynchronous Communication Interface Adapter
To interface the synchronous R6500 peripherals with the asynchronous 68000, 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 27 is a flow chart of the interface operation between the processor and R6500 devices. 6800 peripherals are also compatible with the 68000 processor.

## DATA TRANSFER OPERATION

Three signals on the processor provide the R6500 interface. They are: enable (E), valid memory address (VMA), and valid peripheral address (VPA). Enable corresponds to the E or $\phi 2$ signal in existing R6500 systems. It is the bus clock used by the frequency clock that is one tenth of the incoming 68000 clock frequency. The timing of $E$ allows 1 MHz peripherals to be used with an 8 MHz 68000 . 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 VPA accesses on successive E pulses.

R6500 cycle timing is given in Figure 28. At state zero (SO) in the cycle, the address bus and function codes are in the high-impedance state. One half clock later, in state 1, the address bus and function code outputs are 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/W) signal is switched to low (write)

FIGURE 27 - R6500 INTERFACING FLOW CHART PROCESSOR SLAVE Initiate Cycle

1) The processor starts a normal Read or Write cycle

2) External hardware asserts Valid Peripheral Address (VPA)


Synchronize With Enable

1) The processor monitors Enable (E) untit it is low (Phase 11
2) The processor asserts Valid Memory Address (VMA)

3) The peripheral waits until $E$ is active and then transfers the data

4) The processor waits until Egoes low. On a Read cycle the data is latched as E goes low internally)
5) The processor negates $\overline{\mathrm{VMA}}$
6) The processor negates $\overline{A S}, \overline{U D S}$, and $\overline{\mathrm{LDS}}$


Start Next Cycle

## R68000C4•R68000C6•R68000C8

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 VPA. The VPA 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 $\phi 2$ transfer characteristics of the R6500 bus. Valid peripheral address is derived by decoding the address bus, conditioned by address strobe.
After the recognition of $\overline{V P A}$, the processor assures that the Enable ( E ) is low, by waiting if necessary, and subsequently asserts 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.

During a read cycle, the processor latches the peripheral 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. During a write cycle, the data bus is put in the highimpedance state and the read/write signal is switched high at this time. The peripheral logic must remove VPA within one clock aftef address strobe is negated.

Figure 29 shows the timing required by R 6500 peripherals, the timing specified for the R6500 and the corresponding timing for the 68000 . For further details on peripheral timing, consult the current data sheet for the peripheral of interest. Notice that the 68000 VMA is active low. This allows the processor to put its buses in the highimpedance state on DMA requests without inadvertently selecting peripherals.

FIGURE 28 - R6500 CYCLE OPERATION



## R68000C4•R68000C6•R68000C8

## INTERRUPT INTERFACE OPERATION

During an interrupt acknowledge cycle while the processor is fetching the vector, if $\overline{\mathrm{VPA}}$ is asserted, the 68000 will assert VMA and complete a normal R6500 read cycle as shown in Figure 30. The processor will then use an internally generated vector that is a function of the interrupt being serviced. This process is known as autovectoring. The seven autovectors are vector numbers 25 through 31 (decimal).

This operates in the same fashion (but is 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 68000'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 VMA is asserted during autovectoring, the R6500 peripheral address decoding should prevent unintended accesses.

FIGURE 30 - AUTOVECTOR OPERATION TIMING DIAGRAM


## INSTRUCTION SET

The following paragraphs provide information about the addressing categories and instruction set of the 68000 .

## 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 instruction 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

Alterable
If an effective address mode may be used to refer to memory operands, it is considered a memory addressing effective address mode.
If an effective address mode may be

Control used to refer to alterable (writeable) operands, it is considered an alterable addressing effective address mode.

If an effective address mode may be used to refer to memory operands without an associated size, it is considered a control addressing effective address mode.

Table 20 shows the various categories to which each of the effective address modes belong. Table 21 is the instruction set summary.

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.

TABLE 20 - EFFECTIVE ADDRESSING MODE CATEGORIES

| Effective Address Modes | Mode | Register | Data | Addressing Categories |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Mernory | Control | Alterable |
| Dn | 000 | register number | X | - | - | $X$ |
| An | 001 | register number | - | - | - | $x$ |
| An@ | 010 | register number | X | $x$ | X | X |
| An@ + | 011 | register number | X | X | - | X |
| An@ - | 100 | register number | X | X | - | $x$ |
| An@(d) | 101 | register number | X | X | X | X |
| An@(d, ix) | 110 | register number | X | X | X | X |
| xxx.W | 111 | 000 | X | X | X | X |
| xxx.L | 111 | 001 | X | $x$ | X | X |
| PC@(d) | 111 | 010 | X | X | X | - |
| PC@(d, ix) | 111 | 011 | X | X | X | - |
| Fxxx | 111 | 100 | $x$ | X | - | - |

TABLE 21 - INSTRUCTION SET

| Mnemonic | Description | Operation | Condition Codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | $\mathbf{X}$ | N | Z | V | C |
| ABCD | Add Decimal with Extend | (Destination) $10+(\text { Source })_{10} \rightarrow$ Destination | - | U | - | U | - |
| ADD | Add Binary | $($ Destination $)+($ Source $) \rightarrow$ Destination | - | - | - | - | - |
| ADDA | Add Address | $($ Destination $)+($ Source $) \rightarrow$ Destination | - | - | - | - | - |
| ADDI | Add Immediate | (Destination) + Immediate Data $\rightarrow$ Destination | - | - | - | - | - |
| ADDO | Add Quick | (Destination) + Immediate Data $\rightarrow$ Destination | - | - | - | - | - |
| ADDX | Add Extended | $($ Destination $)+($ Source $)+X \rightarrow$ Destination | - | - | - | - | - |
| AND | AND Logical | (Destination) $\Lambda$ (Source) $\rightarrow$ Destination | - | - | - | 0 | 0 |
| ANDI | AND Immediate | (Destination) $\Lambda$ Immediate Data $\rightarrow$ Destination | - | - | - | 0 | 0 |
| ASL, ASR | Arithmetic Shift | (Destination) Shifted by <count> $\rightarrow$ Destination | - | - | - | - | - |
| BCC | Branch Conditionally | If CC then $\mathrm{PC}+\mathrm{d} \rightarrow \mathrm{PC}$ | - | - | - | - | - |
| BCHG | Test a Bit and Change | $\begin{aligned} & -1<\text { bit number }>) \text { OF Destination } \rightarrow \text { } \\ & -1<\text { bit number }>) \text { OF Destination } \rightarrow \\ & <\text { bit number }>\text { OF Destination } \end{aligned}$ | - | - | - | - | - |
| BCLR | Test a Bit and Clear. | $\underset{\sim}{-1<\text { bit number }>) \text { OF Destination } \rightarrow z} \bar{Z}$ | - | - | - | - | - |
| BRA | Branch Always | $P C+d \rightarrow P C$ | - | - | - | - | - |
| BSET | Test a Bit and Set | $\sim$ (<bit number $>$ ) OF Destination $\rightarrow Z$ <br> $1 \rightarrow<$ bit number > OF Destination | - | - | - | - | - |
| BSR | Branch to Subroutine | PC $\rightarrow$ SP@-; PC + d $\rightarrow$ PC | - | - | - | - | - |
| BTST | Test a Bit | $\sim 1<$ bit number $>1$ OF Destination $\rightarrow Z$ | - | - | - | - | - |
| CHK | Check Register against Bounds | If $\mathrm{Dn}<0$ or $\mathrm{Dn}>1<\mathrm{ea}>1$ then TRAP | - | - | U | U | U |
| CLR | Clear an Operand | $0 \rightarrow$ Destination | - | 0 | 1 | 0 | 0 |
| CMP | Compare | (Destination) - (Source) | - | - | - | - | - |
| CMPA | Compare Address | (Destination) - (Source) | - | - | - | - | - |
| CMPI | Compare Immediate | (Destination) - Immediate Data | - | - | - | - | - |
| CMPM | Compare Memory | (Destination) - (Source) | - | - | - | - | - |
| 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}$ | - | - | - | - | - |
| DIVS | Signed Divide | (Destination)/(Source) $\rightarrow$ Destination | - | - | - | - | 0 |
| DIVU | Unsigned Divide | (Destination)/ (Source) $\rightarrow$ Destination | - | - | - | - | 0 |
| EOR | Exclusive OR Logical | (Destination) $\oplus$ (Source) $\rightarrow$ Destination | - | - | - | 0 | 0 |
| EORI | Exclusive OR Immediate | (Destination) $\oplus$ Immediate Data $\rightarrow$ Destination | - | - | - | 0 | 0 |
| EXG | Exchange Register | $\mathrm{Rx} \rightarrow \mathrm{Ry}$ | - | - | - | - | - |
| EXT | Sign Extend | (Destination) Sign-extended $\rightarrow$ Destination | - | - | - | 0 | 0 |
| JMP | Jump | Destination $\rightarrow$ PC | - | - | - | - | - |
| JSR | Jump to Subroutine | $\mathrm{PC} \rightarrow$ SP@-; Destination $\rightarrow$ PC | - | - | - | - | - |
| LEA | Load Effective Address | Destination $\rightarrow A_{n}$ | - | - | - | - | - |
| LINK | Link and Allocate | An $\rightarrow$ SP@-; SP $\rightarrow$ An; SP+d $\rightarrow$ SP | - | - | - | - | - |
| LSL, LSR | Logical Shift | (Destination) Shifted by <count> $\rightarrow$ Destination | - | - | - | 0 | - |
| MOVE | Move Data from Source to Destination | (Source) $\rightarrow$ Destination | - | - | - | 0 | 0 |
| MOVE to CCR | Move to Condition Code | (Source) $\rightarrow$.CCR | - | - | - | - | - |
| MOVE to SR | Move to the Status Register | (Source) $\rightarrow$ SR | - | - | - | - | - |


| - affected | 0 cleared |
| :--- | :--- |
| - unaffected | 1 set |

R68000C40R68000C60R68000C8

TABLE 21 - INSTRUCTION SET (CONTINUED)

| Mnemonic | Description | Operation | Condition Codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | x | N | Z | V | C |
| MOVE from SR | Move from the Status Register | SR $\rightarrow$ Destination | - | - | - | - | - |
| MOVE USP | Move User Stack Pointer | USP $\rightarrow$ An; An $\rightarrow$ USP | - | - | - | - | - |
| MOVEA | Move Address | (Source) $\rightarrow$ Destination | - | - | - | - | - |
| MOVEM | Move Multiple Registers | Registers $\rightarrow$ Destination (Source) $\rightarrow$ Registers | - | - | - | - | - |
| MOVEP | Move Peripheral Data | (Source) $\rightarrow$ Destination | - | - | - | - | - |
| MOVEQ | Move Quick | Immediate Data $\rightarrow$ Destination | - | - | - | 0 | 0 |
| MULS | Signed Multiply | (Destination) ${ }^{\circ}($ Source $) \rightarrow$ Destination | - |  | - | 0 | 0 |
| MULU | Unsigned Multiply | (Destination)* $\left.{ }^{\text {(Source }}\right) \rightarrow$ Destination | - | - | - | 0 | 0 |
| NBCD | Negate Decimal with Extend | $0-(\text { Destination })_{10-X} \rightarrow$ Destination | - | U | - | $U$ | - |
| NEG | Negate | $0-$ (Destination) $\rightarrow$ Destination |  | - | - | - | - |
| NEGX | Negate with Extend | $0-($ Destination $)-X \rightarrow$ Destination | - | - | - | $\cdot$ | - |
| NOP | No Operation | - | - | - | - | - | - |
| NOT | Logical Complement | $\sim$ (Destination) $\rightarrow$ Destination | - | - | - | 0 | 0 |
| OR | Inclusive OR Logical | (Destination) v (Source) $\rightarrow$ Destination | - | - | - | 0 | 0 |
| ORI | Inclusive OR Immediate | $($ Destination) $\vee$ Immediate Data $\rightarrow$ Destination | - | - | - | 0 | 0 |
| PEA | Push Effective Address | Destination $\rightarrow$ SP@- | - | - | - | - | - |
| RESET | Reset External Devices | - | - | - | - | - | - |
| ROL, ROR | Rotate (Without Extend) | (Destination) Rotated by <count> $\rightarrow$ Destination | - | - | - | 0 | - |
| ROXL, ROXR | Rotate with Extend | (Destination) Rotated by $<$ count $>\rightarrow$ Destination | - | - | - | 0 | $\bullet$ |
| RTE | Return from Exception | SP@ - $\rightarrow$ SR; SP@+ $\rightarrow$ PC | - | - | - | - | $\bullet$ |
| RTR | Return and Restore Condition Codes | SP@+ $\rightarrow$ CC; SP@+ $\rightarrow$ PC | - | - | - | - | - |
| RTS | Return from Subroutine | SP@+ $\rightarrow$ PC | - | - | - | - | - |
| SBCD | Subtract Decimal with Extend | (Destination) $1_{10}$ ( Source) $_{10-\mathrm{X} \rightarrow \text { Destination }}$ | - | U | - | U | - |
| SCC | Set According to Condition | If CC then 1 's $\rightarrow$ Destination else 0's $\rightarrow$ Destination | $\rightarrow$ | - | - | - | - |
| STOP | Load Status Register and Stop | Immediate Data $\rightarrow$ SR; STOP | - | - | - | - | $\bullet$ |
| SUB | Subtract Binary | $($ Destination - (Source) $\rightarrow$ Destination | - | - | - | - | - |
| SUBA | Subtract Address | $($ Destination - (Source) $\rightarrow$ Destination | - | - | - | - | - |
| SUBI | Subtract Immediate | (Destination) - Immediate Data $\rightarrow$ Destination | - | - | - | - | - |
| SUBQ | Subtract Quick | (Destination) - Immediate Data $\rightarrow$ Destination | - | - | - | - | - |
| SUBX | Subtract with Extend | (Destination) - (Source) - $\mathrm{X} \rightarrow$ Destination | - | - | - | - | $\bullet$ |
| SWAP | Swap Register Halves | Register [31:16] $\rightarrow$ Register [15:0] | - | - | - | 0 | 0 |
| TAS | Test and Set an Operand | (Destination) Tested $\rightarrow \mathrm{CC}$; $1 \rightarrow$ [7] OF Destination | - | - | - | 0 | 0 |
| TRAP | Trap | PC $\rightarrow$ SSP@-; SR $\rightarrow$ SSP@-: (Vector $\rightarrow$ PC | - | - | - | - | - |
| TRAPV | Trap on Overflow | If $V$ then TRAP | - | - | - | - | - |
| TST | Test an Operand | (Destination) Tested $\rightarrow$ CC | - | - | - | 0 | 0 |
| UNLK | Unlink | $A n \rightarrow S P ; S P @+\rightarrow A n$ | - | - | - | - | - |

[^8]
## 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 the memory cycle time is no greater than four periods of the external processor clock input, which prevents the insertion of wait states in the bus cycle. The number of bus read and write cycles for each instruction is also included with the timing data. This data 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.

NOTE
The number of periods includes instruction fetch and all applicable operand fetches and stores.

## EFFECTIVE ADDRESS OPERAND CALCULATION TIMING

Table 22 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.

## MOVE INSTRUCTION CLOCK PERIODS

Tables 23 and 24 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)$.

## STANDARD INSTRUCTION CLOCK PERIODS

The number of clock periods shown in Table 25 indicates 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 plus the number of read and write cycles must be added to those of the effective address calculation where indicated.

In Table 25, the headings have the following meanings: $A n=$ address register operand, $D n=$ data register operand, ea $=$ an operand specified by .an effective address, and $\mathrm{M}=$ memory effective address operand.

## IMMEDIATE INSTRUCTION CLOCK PERIODS

The number of clock periods shown in Table 26 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 of clock periods plus the number of read and write cycles must be added to those of the effective address calculation where indicated.

In Table 26, the headings have the following meanings: \# = immediate operand, $D n=$ data register operand, $\mathrm{M}=$ memory operand, and $\mathrm{SR}=$ status register.

## SINGLE OPERAND INSTRUCTION CLOCK PERIODS

Table 27 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 plus the number of read and write cycles must be added to those of the effective address calculation where indicated.

TABLE 22 - EFFECTIVE ADDRESS CALCULATION TIMING

| Addressing Mode |  | Byte, Word | Long |
| :---: | :---: | :---: | :---: |
| $\left\lvert\, \begin{aligned} & D_{n} \\ & A_{n} \end{aligned}\right.$ | Data Register Direct Register <br> Address Register Direct  | $\begin{aligned} & 0(0 / 0) \\ & 0(0 / 0) \end{aligned}$ | $\begin{aligned} & 0(0 / 0) \\ & 0(0 / 0) \end{aligned}$ |
| An@ An@ + | Address Register Indirect Memory Address Register Indirect with: Postincrement | $\begin{aligned} & 4(1 / 0) \\ & 4(1 / 0) \end{aligned}$ | $\begin{aligned} & 8(2 / 0) \\ & 8(2 / 0) \end{aligned}$ |
| An@ - <br> An@(d) | 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}$ |
| $\begin{aligned} & \text { An@(d, } i x)^{*} \\ & x x x . W \end{aligned}$ | Address Register Indirect with Index Absolute Short | $\begin{array}{r} \hline 10(2 / 0) \\ 812 / 0) \end{array}$ | $\begin{aligned} & 14(3 / 0) \\ & 12(3 / 0) \end{aligned}$ |
| $\begin{aligned} & x \times x . L \\ & \text { PC@(d) } \end{aligned}$ | Absolute Long <br> Program Counter with Displacement | $\begin{gathered} \hline 12(3 / 0) \\ 8(2 / 0) \end{gathered}$ | $\begin{aligned} & \hline 16(4 / 0) \\ & 12(3 / 0) \end{aligned}$ |
| $\begin{array}{\|l} \hline \text { PC@(d, ix)* } \\ \text { fxxx } \end{array}$ | Program Counter with Index Immediate | $\begin{array}{r} \hline 10(2 / 0) \\ 4(1 / 0) \\ \hline \end{array}$ | $\begin{array}{r} \hline 14(3 / 0) \\ 8(2 / 0) \\ \hline \end{array}$ |

[^9]TABLE 23 - MOVE BYTE AND WORD INSTRUCTION CLOCK PERIODS

| Source | Destination |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Dn | An | An@ | An@ + | An@ - | An@(d) | An@(d,ix) ${ }^{\text {a }}$ | xxx.W | x $\times$ ox.L |
| Dn | 4(1)/0) | 4(1/0) | 911/1) | 911/1) | 9(1/1) | 1312/11 | 15(2/1) | 13(2/1) | 17(3/1) |
| An | 411/0) | 4(1/0) | 911/1) | 9(1/1) | 9(1/1) | 13(2/1) | 15(2/1) | 13(2/1) | 17(3/1) |
| An@ | 812/0) | 8(2/0) | 1312/1) | 1312/1) | 13(2/1) | 1713/1) | 19(3/1) | 17(3/1) | 21(4/1) |
| An@ + | 812/0) | 8(2/0) | 13(2/1) | 13(2/1) | 13(2/1) | 17(3/r) | 1913/1) | 17(3/1) | 21(4/1) |
| An@ - | 10(2/0) | 10(2/0) | 15(2/1) | 1512/1) | 15(3/1) | 1913/11 | 2113/11 | 19(3/1) | 23(4/1) |
| An@(d) | 1213/0) | 12(3/0) | 17(3/1) | 1713/1) | 17(3/1) | 21/4/11 | 23(4/1) | 21/4/1) | 2515/1) |
| An@(d, ix)* | 14/3/0) | 14(3/0) | 19(3/1) | 1913/1) | 19(3/1) | 2314/11 | 25(4/1) | 23(4/1) | 27(5/1) |
| xxx.W | 12(3/0) | 12(3/0) | 17(3/1) | 17(3/1) | 17(3/1) | 21/4/1) | 23(4/1) | 21(4/1) | 2515/1) |
| xxx.L | 16/4/0) | 16(4/0) | 21(4/1) | 21(4/1) | 21(4/1) | 25(5/1) | 27(5/1) | 25(5/1) | 29(6/1) |
| PC@(d) | 12(3/0) | 12(3/0) | 17(3/1) | 17(3/1) | 17(3/1) | 21(4/1) | 23(4/1) | 21(4/1) | 2515/1) |
| PC@(d, ix)* | 1413/0) | 1413/0) | 19(3/1) | 19(3/1) | 19(3/1) | 23(4/1) | 25(4/1) | 23(4/1) | 27(5/1) |
| \$xxx | 8(2/0) | 8(2/0) | 1312/1) | 1312/1) | 13(2/1) | 1713/1) | 19(3/1) | 17(3/1) | 21(4/1) |

-The size of the index register (ix) does not affect execution time.

TABLE 24 - MOVE LONG INSTRUCTION CLOCK PERIODS

| Source | Destination |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Dn | An | An@ | An@ + | An@- | An@(d) | An@(d,ix)* | x0x.W | xou.L |
| Dn | 4(1/0) | 4(1/0) | 14(1/2) | 14(1/2) | 16(1/2) | 1812/2) | 20(2/2) | 18(2/2) | 22(3/2) |
| An | 4(1/0) | 4(1/0) | 14(1/2) | 14(1/2) | 16(1/2) | 1812/2) | 2012/2) | 18(2/2) | 22(3/2) |
| An@ | 12(3/0) | 1213/0) | 22(3/2) | 22(3/2) | 2213/2) | 26(4/2) | 2814/2) | 28(4/2) | 3015/2) |
| An@ + | 1213/0) | 12(3/0) | 22(3/2) | 22(3/2) | 22(3/2) | 28(4/6) | 28(4/2) | 28(4/2) | 30(5/2) |
| An@ - | 14(3/0) | 14(3/0) | 24(3/2) | 2413/2) | 24(3/2) | 2814/2). | 30(4/2) | 2814/2) | 32(5/2) |
| An@(d) | 16(4/0) | 1614/0) | 26(4/2) | 28(4/2) | 2614/2) | 30(5/2) | 32(5/2) | 3015/2) | 34(6/2) |
| An@(d, ix)* | 18(4/0) | 18(4/0) | 28(4/2) | 28(4/2) | 28(4/2) | 32(5/2) | 34(5/2) | 32(5/2) | 38(6/2) |
| xxx.W | 16(4/0) | 16/4/0) | 26(4/2) | 2614/2) | 26(4/2) | 30(5/2) | 32(5/2) | 3015/2) | 3416/2) |
| xxx.L. | 2015/0) | 2015/0) | 30(5/2) | 30(5/2) | 3015/2) | 34(6/2) | 36(6/2) | 34(6/2) | 38(7/2) |
| PC@(d) | 16(4/0) | 1614/0) | 26(4/2) | 26(4/2) | 26(4/2) | 3015/2) | 32(5/2) | 30(5/2) | 34(6/2) |
| PC@(d, ix)* | 18(4/0) | 18(4/0) | 28(4/2) | 28(4/2) | 28(4/2) | 32(5/2) | 34(5/2) | 32(5/2) | 3616/2) |
| \# $\mathrm{x} \times \mathrm{x}$ | 12(3/0) | 12(3/0) | 22(3/2) | 22(3/2) | 22(3/2) | 26(4/2) | 28(4/2) | 2614/2) | 3015/2) |

- The size of the index register (ix) does not affect execution time.

TABLE 25 - STANDARD INSTRUCTION CLOCK PERIODS

| Instruction | Size | op <ea>, An | op <ea>, Dn | op Dn, <M > |
| :---: | :---: | :---: | :---: | :---: |
| ADD | Byte, Word | $8(1 / 0)+$ | 4(1/0) + | 9(1/1)+ |
|  | Long | $6(1 / 0)+\cdots$ | $6(1 / 0)+\cdots$ | 14(1/2) + |
| AND | Byte, Word | - | $4(1 / 0)+$ | 9(1/1) + |
|  | Long | - | $6(1 / 0)+\cdots$ | 14(1/2) + |
| CMP | Byte, Word | $6(1 / 0)+$ | $4(1 / 0)+$ | - |
|  | Long | $6(1 / 0)+$ | $6(1 / 0)+$ | - |
| DIVS | - | - | $158(1 / 0)+{ }^{\circ}$ | - |
| DIVU | - | - | 140(1/0) + ${ }^{+}$ | - |
| EOR | Byte, Word | - | 4(1/0)*** | 9(1/1)+ |
|  | Long | - | 8(1/0)*** | 14(1/2) + |
| MULS | - | - | 7011/01+* | - |
| MULU | - | - | 70(1/0) + * | - |
| OR | Byte, Word | - | $4(1 / 0)+$ | 9(1/1)+ |
|  | Long | - | $6(1 / 0)+$ " | 14(1/2) + |
| SUB | Byte, Word | $8(1 / 0)+$ | $4(1 / 0)+$ | 9(1/1)+ |
|  | Long | $6(1 / 0)+*$ | $6(1 / 0)+$ ** | 14(1/2) + |

+ add effective address calculation time $\quad \cdots$ total of 8 clock periods for instruction if the effective address is register direct
- indicates maximum value $\quad \cdots$ only available effective address mode is data register direct

TABLE 28 - IMMEDIATE INSTRUCTION CLOCK PERIODS

| Instruction | Size | op 1, Dn | op 7, M | Op \%, SR |
| :---: | :---: | :---: | :---: | :---: |
| ADDI | Byte, Word | 8(2/0) | 13(2/1)+ | - |
|  | Long | 16/3/0) | 22(3/2) + | - |
| ADDQ | Byte, Word | 4(1/0) | $9(1 / 1)+$ | - |
|  | Long | $811 / 01$ | 14(1/2) + | - |
| ANDI | Byte, Word | 8(2/0) | 13(2/1)+ | 2013/0) |
|  | Long | 1613/0) | 22(3/2)+ | - |
| CMPI | Byte, Word | 8(2/0) | $8(2 / 0)+$ | - |
|  | Long | 14(3/0) | 12(3/0) + | - |
| EORI | Byte, Word | 8(2/0) | 13(2/1) + | 2013/0) |
|  | Long | 16(3/0) | 22(3/2) + | - |
| MOVEQ | Long | $4(1 / 0)$ | - | - |
| ORI | Byte, Word | $8(2 / 0)$ | 13(2/1) + | 2013/0) |
|  | Long | 16(3/0) | 22(3/2) + | - |
| SUBI | Byte, Word | 8(2/0) | 13(2/1)+ | - |
|  | Long | 1613/0) | 22(3/2) + | - |
| SUBQ | Byte, Word | 4(1/0) | $9(1 / 1)+$ | - |
|  | Long | $8(1 / 0)$ | 14(1/2)+ | - |

+ add effective address calculation time

TABLE 27 - SINGLE OPERAND INSTRUCTION CLOCK PERIODS

| Instruction | Size | Register | Mernory |
| :---: | :---: | :---: | :---: |
| CLR | Byte, Word | 4(1/0) | $9(1 / 1)+$ |
|  | Long | 6(1/0) | 14(1/2) + |
| NBCD | Byte | 6(1/0) | 9(1/1) + |
| NEG | Byte, Word | 4(1/0) | 9(1/1) + |
|  | Long | 611/0) | 14(1/2) + |
| NEGX | Byte, Word | 4(1/0) | $9(1 / 1)+$ |
|  | Long | 611/0) | 14(1/2) + |
| NOT | Byte, Word | 4(1/0) | $9(1 / 1)+$ |
|  | Long | 6(1/0) | 14(1/2) + |
| ScC | Byte, False | 4(1/0) | $9(1 / 1)+$ |
|  | Byte, True | 6(1/0) | $9(1 / 1)+$ |
| TAS | Byte | 4(1/0) | 11(1/1) + |
| TST | Byte, Word | 411/0) | 4(1/0) |
|  | Long | 4(1/0) | 4(1/0) + |

+ add effective address calculation time


## SHIFT/ROTATE INSTRUCTION CLOCK PERIODS

Table 28 indicates 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 plus the number of read and write cycles must be added to those of the effective address calculation where indicated.

## BIT MANIPULATION INSTRUCTION CLOCK PERIODS

Table 29 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 plus the number of read and write cycles must be added to those of the effective address calculation where indicated.

## CONDITIONAL INSTRUCTION CLOCK PERIODS

Table 30 indicates 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 plus the number of read and write cycles must be added to those of the effective address calculation where indicated.

## JMP, JSR, LEA, PEA, MOVEM INSTRUCTION CLOCK PERIODS

Table 31 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 28 - SHIFT/ROTATE INSTRUCTION CLOCK PERIODS

| Instruction | Size | Register | Memory |
| :---: | :---: | :---: | :---: |
| ASR, ASL | Byte, Word | $6+2 n(1 / 0)$ | $9(1 / 1)+$ |
|  | Long | $8+2 n(1 / 0)$ | - |
| LSR, LSL | Byte, Word | $6+2 n(1 / 0)$ | $9(1 / 1)+$ |
|  | Long | $8+2 n(1 / 0)$ | - |
| ROR, ROL | Byte, Word | $6+2 n(1 / 0)$ | $9(1 / 1)+$ |
|  | Long | $8+2 n(1 / 0)$ | - |
| ROXR, ROXL | Byte, Word | $6+2 n(1 / 0)$ | $9(1 / 1)+$ |
|  | Long | $8+2 n(1 / 0)$ | - |

TABLE 29 - BIT MANIPULATION INSTRUCTION CLOCK PERIODS

| Instruction | Size | Dymamic |  | Static |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  |  | Register | Memory | Register | Memory |
| BCHG | Byte | - | $9(1 / 1)+$ | - | $13(2 / 1)+$ |
|  | Long | $8(1 / 0)^{*}$ | - | $12(2 / 0)^{*}$ | - |
| BCLR | Byte | - | $9(1 / 1)+$ | - | $13(2 / 1)+$ |
|  | Long | $10(1 / 0)^{*}$ | - | $14(2 / 0)^{*}$ | - |
| BSET | Byte | - | $9(1 / 1)+$ | - | $13(2 / 1)+$ |
|  | Long | $8(1 / 0)^{*}$ | - | $12(2 / \sigma *$ | - |

+ add effective address calculation time
- indicates maximum value

TABLE 30 - CONDITIONAL INSTRUCTION CLOCK PERIODS

| Instruction | Displacement | Trap or Branch <br> Taken | Trap or Branch <br> Not Taken |
| :--- | :---: | :---: | :---: |
| BCC | Byte | $10(1 / 0)$ | $8(1 / 0)$ |
|  | Word | $10(1 / 0)$ | $12(2 / 0)$ |
| BRA | Byte | $10(1 / 0)$ | - |
|  | Word | $10(1 / 0)$ | - |
| DBCC | Byte | $20(2 / 21$ | - |
|  | Word | $20(2 / 2)$ | - |
| CHK | CC true | - | $12(2 / 0)$ |
| TRAP | CC false | $10(2 / 0)$ | $14(3 / 0)$ |
| TRAPV | - | $43(5 / 3)+*$ | $8(1 / 0)+$ |

+ add effective address calculation time
- indicates maximum value

TABLE 31 - JMP, JSR, LEA, PEA, MOVEM INSTRUCTION CLOCK PERIODS

| Instr | Size | An@ | An@ + | An@ - | An@(d) | An@(d, ix)* | xxx.W | xxx.L | PC@(d) | PC@(d, ix)* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| JMP | - | 8(2/0) | - | - | 10(2/0) | 14(3/0) | 10(2/0) | 12(3/0) | 10(2/0) | 14(3/0) |
| JSR | - | 1812/2) | - | - | 20(2/2) | 24(2/2) | 2012/2) | 2213/2) | 2012/2) | 24(2/2) |
| LEA | - | 4(1/0) | - | - | 8(2/0) | 12(2/0) | 812/0) | 12(3/0) | 8(2/0) | 1212/0) |
| PEA | - | 14(1/2) | - | - | 18(2/2) | 22(2/2) | 1812/2) | 22(3/2) | 18(2/2) | 2212/2) |
| MOVEM | Word | $\begin{array}{r} 12+4 n \\ (3+n / 0) \\ \hline \end{array}$ | $\begin{array}{r} 12+4 n \\ (3+n / 0) \\ \hline \end{array}$ |  | $\begin{array}{r} 16+4 n \\ (4+n / 0) \end{array}$ | $\begin{array}{r} 18+4 n \\ (4+n / 0) \end{array}$ | $\begin{array}{r} 16+4 n \\ (4+n / 0) \end{array}$ | $\begin{array}{r} 20+4 n \\ (5+n / 0) \end{array}$ | $\begin{array}{r} 16+4 n \\ (4+n / 0) \end{array}$ | $\begin{array}{r} 18+4 n \\ (4+n / 0) \end{array}$ |
| M - R | Long | $\begin{array}{r} 12+8 n \\ 13+2 n / 0) \\ \hline \end{array}$ | $\begin{array}{\|r} 12+8 n \\ 13+2 n / 01 \\ \hline \end{array}$ | - | $\begin{array}{r} 16+8 n \\ (4+2 n / 0) \\ \hline \end{array}$ | $\begin{array}{r} 18+8 n \\ (4+2 n / 0) \\ \hline \end{array}$ | $\begin{array}{r} 16+8 n \\ (4+2 n / 0) \\ \hline \end{array}$ | $\begin{array}{r} 20+8 n \\ (5+2 n / 0) \\ \hline \end{array}$ | $\begin{array}{r} 16+8 n \\ (4+2 n / 0) \\ \hline \end{array}$ | $\begin{array}{r} 18+8 n \\ (4+2 n / 0) \\ \hline \end{array}$ |
| MOVEM | Word | $\begin{aligned} & 8+5 n \\ & (2 / n) \end{aligned}$ | - | $\begin{aligned} & 8+5 n \\ & (2 / n) \end{aligned}$ | $\begin{array}{r} 12+5 n \\ (3 / n) \\ \hline \end{array}$ | $\begin{array}{r} 14+5 n \\ (3 / n) \\ \hline \end{array}$ | $\begin{array}{r} 12+5 n \\ (3 / n) \\ \hline \end{array}$ | $\begin{array}{r} 16+5 n \\ (4 / n) \\ \hline \end{array}$ | $-$ | - |
| $R-M$ | Long | $\begin{aligned} & 8+10 n \\ & (2 / 2 n) \\ & \hline \end{aligned}$ | - | $\begin{array}{r} 8+10 n \\ (2 / 2 n) \end{array}$ | $\begin{array}{r} 12+10 n \\ (3 / 2 n) \\ \hline \end{array}$ | $\begin{array}{r} 14+10 n \\ (3 / 2 n) \\ \hline \end{array}$ | $\begin{array}{r} 12+10 n \\ (3 / 2 n) \\ \hline \end{array}$ | $\begin{array}{r} 16+10 n \\ (4 / 2 n) \end{array}$ | - | - |

$n$ is the number of registers to move

- is the size of the index register (ix) does not affect the instruction's execution time

TABLE 32 - MULTI-PRECISION INSTRUCTION CLOCK PERIODS

| Instruction | Size | op Dn, Dn | op M, M |
| :--- | :---: | :---: | :---: |
| ADDX | Byte, Word | $4(1 / 0)$ | $19(3 / 1)$ |
|  | Long | $8(1 / 0)$ | $32(5 / 2)$ |
| CMPM | Byte, Word | - | $12(3 / 0)$ |
|  | Long | - | $20(5 / 0)$ |
| SUBX | Byte, Word | $4(1 / 0)$ | $19(3 / 1)$ |
|  | Long | $8(1 / 0)$ | $32(5 / 2)$ |
| ABCD | Byte | $6(1 / 0)$ | $19(3 / 1)$ |
| SBCD | Byte | $6(1 / 0)$ | $19(3 / 1)$ |

## MULTI-PRECISION INSTRUCTION CLOCK PERIODS

Table 32 indicates the number of clock periods for the multi-precision 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: ( $\mathrm{r} / \mathrm{w}$ ).

In Table 32, the headings have the following meanings: $\mathrm{Dn}=$ data register operand and $\mathrm{M}=$ memory operand

## MISCELLANEOUS INSTRUCTION CLOCK PERIODS

Table 33 indicates the number of clock periods for the following misceilaneous instructions. The number of bus
read and write cycles is shown in parenthesis as: $(\mathrm{r} / \mathrm{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.

## EXCEPTION PROCESSING CLOCK PERIODS

Table 34 indicates 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 handier routine. The number of bus read and write cycles is shown in parenthesis as: $(\mathrm{r} / \mathrm{w})$.

TABLE 33 - MISCELLANEOUS INSTRUCTION CLOCK PERIODS

| Instruction | Size | Register | Memory | Register - Mernory | Memory - Register |
| :---: | :---: | :---: | :---: | :---: | :---: |
| MOVE from SR | - | 6(1/0) | $9(1 / 1)+$ | - | - |
| MOVE to CCR | - | 12(2/0) | 12(2/0) + | - . | - |
| MOVE to SR | - | 12(2/0) | $12(2 / 0)+$ | - | - |
| MOVEP | Word | - | - | 18(2/2) | 16(4/0) |
|  | Long | - | - | $28(2 / 4)$ | 2416/0) |
| EXG | - | 6(1/0) | - | - | - |
| EXT | Word | 4(1/0) | - | - | - |
|  | Long | 4(1/0) | - | - | - |
| LINK | - | 1812/2) | - | - | - |
| MOVE from USP | - | 4(1/0) | - | - | - |
| MOVE to USP | - | 4(1/0) | - | - | - |
| NOP | - | 4(1/0) | - | - | - |
| RESET | - | 132(1/0) | - | - | - |
| RTE | - | 2015/0) | - | - | - |
| RTR | - | 20(5/0) | - | - | - |
| RTS | - | 16(4/0) | - | - | - |
| STOP | - | 4(0/0) | - | - | - |
| SWAP | - | 4(1/0) | - | - | - |
| UNLK | - | 12(3/0) | - | - | - |

+ add effective address calculation time

TABLE 34 - EXCEPTION PROCESSING CLOCK PERIODS

| Exception | Periods |
| :--- | :---: |
| Addrees Error | $\boxed{7(4 / 7)}$ |
| Bus Error | $57(4 / 7)$ |
| Interrupt | $47(5 / 3)^{*}$ |
| Illegal Instruction | $37(4 / 3)$ |
| Privileged Instruction | $37(4 / 3)$ |
| Trace | $37(4 / 3)$ |

-The interrupt acknowledge bus cycle is assumed to take four external clock periods

FIGURE 31 - AC ELECTRICAL WAVEFORMS
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.


NOTE 1: Setup time for the asynchronous inputs $\overline{B E R R}, \overline{B G A C K}$, $\overline{B R}, ~ D T A C R, ~ \overline{P L O}-\overline{\mathrm{PLL}}$, and VPA guarantees their recognition at the next falling edge of the clock.

NOTE 2: Waveform measurements for all inputs and outputs are specified at: logic high $=2.0$ volts, logic low $=0.8$ volts.

AC ELECTRICAL SPECIFICATIONS $\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}: \mathrm{T}_{A}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}$. Figure 31)

| Number | Characteristic | Symbol | $\begin{gathered} 4 \mathrm{MHZ} \\ \mathrm{R} 68000 \mathrm{C} 4 \end{gathered}$ |  | $\begin{gathered} 6 \mathrm{MHz} \\ \mathrm{R} 68000 \mathrm{C} 6 \end{gathered}$ |  | $\begin{gathered} 8 \mathrm{MHz} \\ \mathrm{R} 68000 \mathrm{CB} \\ \hline \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| 1 | Clock Period | $t_{\text {cyc }}$ | 250 | 500 | 167 | 500 | 125 | 500 | ns |
| 2 | Clock Width Low | ${ }^{1} \mathrm{CL}$ | 115 | 250 | 75 | 250 | 55 | 250 | ns |
| 3 | Clock Width High | $\mathrm{t}_{\mathrm{CH}}$ | 115 | 250 | 75 | 250 | 55 | 250 | ns |
| 4 | Clock Fall Time | $\mathrm{t}_{\mathrm{Cl}}$ | - | 10 | - | 10 | - | 10 | ns |
| 5 | Clock Rise Time | $\mathrm{tcr}^{\text {r }}$ | - | 10 | - | 10 | - | 10 | ns |
| 6 | Clock Low to Address/FC Valid | Itclav | - | 90 | - | 80 | - | 70 | ns |
| 7 | Clock High to Address/FC/Data High Impedance (maximum) | $\mathrm{t}_{\text {chazx }}$ | - | 120 | - | 100 | - | 80 | ns |
| 8 | Clock High to Address/FC Invalid (minimum) | tchazn | 20 | - | 20 | - | 20 | - | ns |
| $9{ }^{1}$ | Clock High to $\overline{A S}, \overline{D S}$ Low (maximum) | $\mathrm{t}_{\text {ChSLX }}$ | - | 80 | - | 70 | - | 60 | ns |
| 10 | Clock High to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low (minimum) | $\mathrm{t}_{\text {CHSLn }}$ | 20 | - | 20 | - | 20 | - | ns |
| $11^{2}$ | Address/FC Valid to $\overline{A S S}$, $\overline{\mathrm{DS}}$ (read) Low | tavSL | 55 | - | 35 | - | 30 | - | ns |
| $12^{1}$ | Clock Low to AS, $\overline{\mathrm{DS}}$ High | $\mathrm{t}_{\mathrm{CLSH}}$ | - | 90 | - | 80 | - | 70 | ns |
| $13^{2}$ | $\overline{\mathrm{AS}}$, $\overline{\mathrm{DS}}$ High to Address/FC Invalid | $\mathrm{t}_{\text {SHAZ }}$ | 60 | - | 40 | - | 30 | - | ns |
| $14^{2}$ | $\overline{A S}$, $\overline{D S}$ Width Low | $\mathrm{t}_{\text {SL }}$ | 285 | - | 170 | - | 115 | - | ns |
| $15^{2}$ | $\overline{\mathrm{AS}}$, $\overline{\mathrm{DS}}$ Width High | $\mathrm{t}_{\text {SH }}$ | 285 | - | 180 | - | 150 | - | ns |
| 16 | Clock High to $\overline{A S}$, $\overline{\mathrm{DS}}$ High Impedance | $\mathrm{t}_{\mathrm{CHSZ}}$ | - | 120 | - | 100 | - | 80 | ns |
| $17^{2}$ | $\overline{D S}$ High to R $\bar{W}$ High | $\mathrm{I}_{\text {SHAH }}$ | 60 | $\rightarrow$ | 50 | - | 40 | - | ns |
| 18 | Clock High to $\mathrm{R} / \overline{\mathrm{W}}$ High (maximum) | ${ }_{\text {t }}{ }_{\text {CHRH }}$ | - | 90 | - | 80 | - | 70 | ns |
| 19 | Clock High to R/W High (minimum) | ${ }^{\text {t }}$ Chran | 20 | - | 20 | - | 20 | - | ns |
| $20^{\prime}$ | Clock High to R/W Low | ${ }^{\text {cheral }}$ | - | 90 | - | 80 | - | 70 | ns |
| $21^{2}$ | Address/FC Valid to R/W Low | $t_{\text {AVAL }}$ | 45 | - | 25 | - | 20. | - | ns |
| $22^{2}$ | $\mathrm{R} \bar{W}$ Low to $\overline{\mathrm{DS}}$ Low (write) | $\mathrm{t}_{\text {RLSL }}$ | 200 | - | 140 | - | 80. | - | ns |
| 23 | Clock Low to Data Out Valid | tcloo | - | 90 | - | 80 | - | 70 | ns |
| 24 | Clock High to R/W, VMA High Impedance | $\mathrm{I}_{\text {chrz }}$ | - | 120 | - | 100 | - | 80 | ns |
| $25^{2}$ | $\overline{\mathrm{D}}$ S High to Data Out Invalid | $\mathrm{t}_{\text {SHOO }}$ | 60 | - | 40 | - | 30 | - | ns |
| $26^{2}$ | Data Out Valid to $\overline{\mathrm{DS}}$ Low (write) | toost | 55 | - | 35 | - | 30. | - | ns |
| 27 | Data In to Clock Low (set up time) | toicl | 30 | - | 25 | - | 15 | - | ns |
| $28^{2}$ | $\overline{\text { DS }}$ High to $\overline{\text { DTACK }}$ High | $\mathrm{I}_{\text {SHDAH }}$ | 0 | 240 | 0 | 160 | 0 | 120 | ns |
| 29 | $\overline{\text { DS }}$ High to Data Invalid (hotd time) | $\mathrm{t}_{\text {SHOI }}$ | 0 | - | 0 | - | 0 | - | ns |
| 30 | $\overline{A S}, \overline{D S}$ High to $\overline{B E R R}$ High | $\mathrm{t}_{\text {SHBEH }}$ | 0 | - | 0 | - | 0 | - | ns |
| $31^{2}$ | DTACK Low to Data In (setup time) | toaloi | - | 180 | - | 120 | - | 90 | ns |
| 32 | $\overline{\text { HALT }}$ and $\overline{\text { RESET }}$ Input Transition Time | $\mathrm{t}_{\text {RHr }}$ | 0 | 200 | 0 | 200 | 0 | 200 | ns |
| 33 | Clock High to $\overline{8 G}$ Low | ${ }^{\text {t }} \mathrm{CHGL}$ | - | 90 | - | 80 | - | 70 | ns |
| 34 | Clock High to $\overline{\mathrm{BG}}$ High | ${ }^{\text {t }} \mathrm{CHGH}$ | - | 90 | - | 80 | - | 70 | ns |
| 35 | $\overline{B A}$ Low to BG Low | $\mathrm{t}_{\text {BrLGL }}$ | 1.5 | 3.0 | 1.5 | 3.0 | 1.5 | 3.0 | clk. per. |
| 36 | $\overline{B R}$ High to $\overline{B G}$ High | $\mathrm{t}_{\text {BRHGH }}$ | 1.5 | 3.0 | 1.5 | 3.0 | 1.5 | 3.0 | clk. per. |
| 37 | $\overline{\text { BGACK }}$ Low to $\overline{\mathrm{BG}}$ High | $\mathrm{t}_{\text {Galgh }}$ | 1.5 | 3.0 | 1.5 | 30 | 1.5 | 3.0 | clk. per. |
| 38 | $\overline{\mathrm{BG}}$ Low to Bus High Impedance (with $\overline{\mathrm{AS}}$ high) | $\mathrm{t}_{\mathrm{GLZ}}$ | 0 | 1.5 | 0 | 1.5 | 0 | 1.5 | clk. per. |
| 39 | $\overline{\text { BG Width High }}$ | $\mathrm{t}_{\text {GH }}$ | 1.5 | - | 1.5 | - | 1.5 | - | clk. per. |
| 40 | Clock Low to VMA Low | ICLVML | - | 90 | - | 80 | - | 70 | ns |
| 41 | Clock Low to E Transition | ${ }_{\text {t CLE }}$ | - | 65 | - | 60 | - | 55 | ns |
| 42 | E Output Rise and Fall Time | terf | - | 25 | - | 25 | - | 25 | ns |
| $43^{2}$ | VMA Low to E High | IVMLEH | 325 | - | 240 | - | 200 | - | ns |
| 44 | $\overline{\text { AS, }}$ DS High to VPA High | $\mathrm{t}_{\text {SHVPH }}$ | 0 | 240 | 0 | 160 | 0 | 120 | ns |
| 45 | E Low to Address $\overline{\mathrm{VMA}} / \mathrm{FC}$ Invalid | telal | 55 | - | 35 | - | 30 | - | ns |
| 46 | BGACK Width | $t_{\text {BGL }}$ | 1.5 | - | 1.5 | - | 1.5 | - | clk. per. |
| 47 | Asynchronous Input Setup Time | ${ }_{\text {ASI }}$ | 30 | - | 25 | - | 20 | - | ns |
| 48 | $\overline{\text { BERR }}$ Low to DTTACK Low | $\mathrm{t}_{\text {BELDAL }}$ | 50 | - | 50 | - | 50 | - | ns |
| 49 | E Low to $\bar{A} \bar{S}, \overline{\mathrm{DS}}$ Invalid | telsi | -80 | - | -80 | - | -80 | - | ns |
| 50 | E Width High | $\mathrm{t}_{\text {EH }}$ | 900 | - | 600 | - | 450 | - | ns |
| 51 | E Width Low | $\mathrm{t}_{\text {EL }}$ | 1400 | - | 900 | - | 700 | - | ns |

NOTE 1: For a loading capacitance of less than or equal to 50 picofarads, subtract 5 nanoseconds from the values given in these columns

## FIGURE 32 - AC ELECTRICAL WAVEFORMS - BUS ARBITRATION

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.


AC ELECTRICAL SPECIFICATIONS-BUS ARBITRATION ( $\mathrm{V}_{D D}=5.0 \mathrm{VdC} \pm 50^{\circ} ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}: \mathrm{T}_{\mathrm{A}}=00^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$, Figure 32)

| Number | Characteristic | Symbol | $4 \mathrm{MHZ}$ |  | $6 \mathrm{MHz}$ |  | $\begin{gathered} 8 \mathrm{MHz} \\ 868000 \mathrm{CB} \\ \hline \end{gathered}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
| 33 | Clock High to $\overline{\mathrm{BG}}$ Low | $\mathrm{ICHGL}^{\text {che }}$ | - | 90 | - | 80 | - | 70 | ns |
| 34 | Clock High to $\overline{\text { EG }}$ High | ${ }^{\text {t }}{ }_{\text {CHGH }}$ | - | 90 | - | 80 | - | 70 | ns |
| 35 | $\overline{B R}$ Low to $\overline{B G}$ Low | t brlgl. | 1.5 | 3.0 | 1.5 | 3.0 | 1.5 | 3.0 | clk. per. |
| 36 | $\overline{\text { BR }}$ High to $\overline{B G}$ High | $\mathrm{t}_{\text {BRHGH }}$ | 1.5 | 3.0 | 1.5 | 3.0 | 1.5 | 3.0 | clk. per. |
| 37 | BGACK Low to $\overline{\mathrm{BG}}$ High | $\mathrm{I}_{\text {GALGH }}$ | 1.5 | 3.0 | 1.5 | 3.0 | 1.5 | 3.0 | cik. per. |
| 38 | $\overline{B G}$ Low to Bus High Impedance (with $\overline{A S}$ high) | $\mathrm{t}_{\mathrm{GLZ}}$ | 0 | 1.5 | 0 | 1.5 | 0 | 1.5 | clk. per. |
| 39 | BG Width High | $\mathrm{I}_{\mathrm{GH}}$ | 1.5 | - | 1.5 | - | 1.5 | - | clk. per. |
| 46 | BGACK Width | $\mathrm{I}_{\mathrm{BGL}}$ | 1.5 | - | 1.5 | - | 1.5 | - | clk. per. |

NOTE 1: Setup time for the asynchronous inputs $\overline{\mathrm{BERR}}, \overline{\mathrm{BGACK}}, \overline{\mathrm{BR}}$, $\overline{\text { DTACK }}$ IPLO•IPL2, and $\overline{V P A}$ guarantees their recognition at the next talling edge of the clock.

NOTE 2: Waveform measurements for all inputs and outputs are specified at: logic high $=2.0$ volts. logic low $=0.8$ volts.

ELECTRICAL CHARACTERISTICS ${ }^{(V)} \mathrm{CC}=5.0 \mathrm{Vdc} \pm 5 \% ; \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}$; $\mathrm{T}_{\mathrm{A}} 0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$, Figures $33,34,35$ )

figure 33 - reset test load
FIGURE 34 - HALT TEST LOAD


FIGURE 35 - TEST LOADS


FIGURE 36 - INPUT CLOCK WAVEFORM


MAXIMUM RATINGS

| Rating | 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 Range | $\mathrm{T}_{\mathrm{A}}$ | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to 150 | ${ }^{\circ} \mathrm{C}$ |

CLOCK TIMING (Figure 36)

| Characteristic | Symboi | 4 MHz |  | 6 MHz |  | 8 MHz |  | Unit Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | R68000C4 |  | R68000C6 |  | R68000C8 |  |  |
|  |  | Min | Max | Min | Max | Min | Max |  |
| Frequency of Operation | F | 2.0 | 4.0 | 2.0 | 6.0 | 2.0 | 8.0 | MHz |
| Cycle Time | ${ }^{\text {t }}$ cyc | 250 | 500 | 167 | 500 | 125 | 500 | ns. |
| Clock Pulse Width | $\begin{aligned} & \mathrm{t}_{\mathrm{t} L} \\ & { }^{\mathrm{CH}} \end{aligned}$ | $\begin{array}{\|l\|} \hline 115 \\ 115 \end{array}$ | $\begin{aligned} & 250 \\ & 250 \end{aligned}$ | $\begin{aligned} & 75 \\ & 75 \end{aligned}$ | $\begin{aligned} & 250 \\ & 250 \end{aligned}$ | $\begin{aligned} & 55 \\ & 55 \end{aligned}$ | $\begin{aligned} & 250 \\ & 250 \end{aligned}$ | ns |
| Rise and Fall Times | $\begin{aligned} & { }^{\mathrm{t}^{\mathrm{Cr}}} \\ & \mathrm{t}^{2} \end{aligned}$ | - | $\begin{aligned} & \hline 10 \\ & 10 \\ & \hline \end{aligned}$ | - | 10 10 | - | 10 10 | ns |

R68000C4•R68000C6•R68000C8


NOTES:

1. DIMENSION -A.IS DATUM.
2. POSITIONAL TOLERANCE FOR LEADS: | $\oplus \mid 0.25(0.010)$ | $(\mathbb{T}$ | $A @$ |
| :---: | :---: | :---: |
3. T. IS SEATING PLANE.
4. DIMENSION."L"TO CENTER OF LEADS WHEN FORMED PARALLEL.
5. DIMENSIONING AND TOLERANCING PER ANSI Y14.5, 1973.

|  | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |
| A | 80.52 | 82.04 | 3.170 | 3.230 |
| B | 22.25 | 22.96 | 0.876 | 0.904 |
| C | 3.05 | 4.32 | 0.120 | 0.170 |
| 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 |  |  |
| J | 0.20 | 0.33 | 0.008 | 0.013 |
| K | 2.54 | 4.19 | 0.100 | 0.165 |
| L | 22.61 | 23.11 | 0.890 | 0.910 |
| M | - | 100 | - | 100 |
| N | 1.02 | 1.52 | 0.040 | 0.060 |

## R68120




## MEMORY MANAGEMENT UNIT (MMU)

The R68451 Memory Management Unit (MMU) provides address translation and protection of the 16 megabyte addressing space of the R68000. The MMU can be accessed by any potential bus master, such as instruction set processors, or DMA controllers. Each bus master (or processor) in the R68000 family provides a function code and an address during each bus cycle. The function code specifies an address space while the address specifies a location within that address space. The function codes are provided by the R68000 to distinguish between program and data spaces as well as supervisor and user spaces. This separation of address spaces provides the basis of protection in an operating system. By simplifying the programming model of the address space, the MMU also increases the reliability of a complex multi-process system.

- Separates Address Spaces of System and User Resources
- Provides Write Protection
- Increases System Reliability
- Provides Efficient Memory Allocation
- Allows Interprocess Communication through Shared Resources
- Simplifies Programming Model of Address Space
- Minimizes Operating System Overhead with Quick Context Switches
- 32 Segments with Variable Segment Sizes
- Multiple MMU System Capability
- Supports both Paging and Segmentation
- DMA Compatible
- Provides Virtual Memory Support
- R68000 Rus Compatible



## MAPPING LOGICAL SEGMENTS TO PHYSICAL MEMORY



R68000 Microcomputer System PRODUCT PREVIEW

DIRECT MEMORY ACCESS CONTROLLER (DMAC)

The R68450 Direct Memory Access Controller (DMAC) offers the system designer unparalleled performance where both speed and flexibility in data transfer are required. Sophisticated chaining techniques, memory-to-memory block transfers, and variable bus bandwith utilization result in optimum data transfers. Internal 32-bit address registers provide upward software compatibility with future R68000 Family processors.

- Compatible with both R68000 Family and $6500 / 6800 \mathrm{Pe}$ ripherals
- Four, Fully-Independent Channels
- Single or Dual Address Transfers
- Byte, Word, or Long Word Transiers
- Memory-to-Memory Block Transfers
- Supports both Chained and Unchained Operations
- Transfer Rates up to 4 Megabytes Per Second
- Supports Vectored Interrupts
- Supports Array or Linked Array Chaining
- 16-Bit Data Bus
- Programmable Priorities


INTERNAL ORGANIZATION

${ }^{0} \begin{gathered}\text { Gevielal } \\ \text { Contiol Pegister }\end{gathered}$



## R68000 Microcomputer System PRODUCT PREVIEW

## MULTI-PROTOCOL COMMUNICATIONS CONTROLLER (MPCC)

The R68561 Multi-Protocol Communication Controller (MPCC) is a serial data communications interface for the R68000 Family. This device meets the basic interface requirements of asynchronous, bit- and byte-oriented synchronous communication protocols. To keep device count low, the MPCC also contains an internal crystal oscillator and baud rate generator.

- Complete Data Communications Interface
- Line Protocols:

Asynchronous
Bit-Oriented Synchronous (X.25, SDLC, HDLC)
Byte-Oriented Synchronous (BISYNC, DDCMP)

- Interface Compatible with R68450 DMAC
- Self Test Loop Mode
- Single 5-Volt Power Supply
- Full or Half Duplex Operation
- Multiple CRC Character Generation and Error Detection
- Internal Baud Rate Generator
- Internal Crystal Oscillator
- Complete Status Reporting Capability
- Buffered Transmit and Receive Registers
- Supports Vectored Interrupts
- R68000 Bus Compatible



PPS-4/1
PMOS $\mu \mathbf{C s}$

## when one-chip gets you more...It's a

 Rockwell PPS-4/1

The common component in uncommon success -
PPS-4/1 one-chip microcomputer


## Why a Rockwell One-Chip PPS-4/1 Microcomputer Gets You More...

## Lower Total System Cost

If you're designing manual-input equipment such as business machines, games, controllers or telephone terminals, Rockwell PPS-4/1 one-chip microcomputers have high promise of lowering your total system costs. These four-bit chips are so powerful they often fit applications where with ordinary one-chip microcomputers you'd need eight-bit devices at about twice the cost.
More than 10 million Rockwell one-chip microcomputers are in use worldwide. Study the chart at right. You'll quickly see why Rockwell PPS-4/1 microcomputers are so cost-conscious and so useful.

## Highlights of Features

Instruction efficiency: Typically, instructions are executed in one byte in one cycle and in 10 microseconds - all you need for manmachine interfacing.
Lots of I/O Ports: Including serial ports for easy cascading or combining with host systems, and some I/O ports will source up to 10 milliamps.
On-Chip Display Drives: Directly drive VF or LED displays. Battery Level Power: In a phrase, "CMOS power at PMOS prices." Low Cost Designing: Rockwell fully supports you with applications engineering, designers' classes and ready-to-go software packages.
And Much More: High immunity to noise; broad operating voltage tolerances, and high breakdown voltage.


## Applications Where Rockwell PPS-4/1 Microcomputers Get You More in End-Product Features for Less Cost

APPLIANCE CONTROLS

- General
- Microwave Ovens
- Ranges
- Blenders

AUTOMOTIVE FEATURES CONTROLS CASH REGISTERS, STAND-ALONE COIN CHANGER CONTROL
ENVIRONMENTAL CONTROL

- Intelligent Thermostat
- Heat Pump/Air Conditioner

EQUIPMENT CONTROLLERS

- Dot Matrix Printers
- Motor Controllers
- Keyboard-Display


## GAMES

- Hand-Held
- Arcade

GAS PUMPITRAFFIC CONTROLS
INSTRUMENTS, SIMPLE/SMART
LANGUAGE TRANSLATORS
MACHINE TOOL/PROCESS CONTROLS
RADIO

- Tuners
- Scanners

SCALES

- Commercial
- Consumer

SECURITY SYSTEMS
SMALL BUSINESS SYSTEMS

- Portable Data Entry
- Desk-Top Calculators


## TELEPHONE

- Auto-Dial
- Switching
- Answering Equipment

TIMERS/CLOCKS
TV TUNERS
UNIVERSAL LOGIC MODULE
UTILITY MONITORING EQUIPMENT


## Rockwell PPS-4/1 Microcomputers Get You More Through Low-Cost Design Approaches

## Prototype Devices

Rockwell provides a 64-pin DIP Emulation Device for each PPS-4/1 model. The Emulator is designed to interface with external PROM or ROM or RAM, and with peripherals of the total system. This enables you to test your system in real time, including software testing and debugging, and circuit hardware checking. You can even perform field analysis of the prototype equipment prior to submitting your ROM code for production.

## XPO-1 Evaluation Module

At the low end of software development operations, Rockwell provides a sophisticated evaluation module with hexadecimal keyboard. Designated XPO-1, this module can be used for software development with a PPS-4/1 Emulator device. It has the advantage of low price - below $\$ 500$. But developing a full program with it is time-consuming.

## SUMMARY OF PPS-4/1 ONE-CHIP MICROCOMPUTER MODELS <br> STANDARD MODELS <br> MM75 Has CPU, $640 \times 8$ ROM, $48 \times 4$ RAM, A75XX internal clock logic and 22 I/O lines. (A7699) <br> MM78 Has CPU, $2048 \times 8$ ROM, $128^{\circ} \times 4$ RAM, A78XX internal clock logic and 31 l/O lines. <br> (A7899) 42-pin quad in-line package. <br> LOW POWER/LOW VOLTAGE MODELS <br> MM76EL Has CPU, $1024 \times 8$ ROM, $48 \times 4$ RAM, B86XX internal clock logic and $31 / \mathrm{O}$ lines. (B8699) 40 -pin dual in-line package. <br> MM78L <br> Same internal features as MM78. 40-pin <br> M78LA Has CPU, $2048 \times 8$ ROM, $128 \times 4$ RAM, B90XX internal clock logic and 35 I/O lines (B9099) (including speaker and display I/O). 42-pin quad in-line package. <br> NOTE: PART NUMBERS IN BRACKETS ARE FOR PROTOTYPE DEVICES.



## PPS-4/1 Personality Subsystem

For fast, complete development of programs for PPS-4/1 devices, Rockwell has developed a PPS-4/1 Personality Subsystem for use with our SYSTEM 65 Development System.

The PPS-4/1 Personality Subsystem serves as a cross-assembler for all PPS-4/1 devices. Similarly it enables in-circuit emulation. Debugging capability of the subsystem is total, including breakpoints, trace, up load/down load, register alter, program memory alter and single stepping. Full prototyping of the endproduct's system and peripherals is also provided. This advanced development system, including SYSTEM 65, is priced well under \$10,000.

## Rockwell Services

Rockwell provides Applications Engineering assistance for all of its customers, usually at no cost. Designers' Courses are available. Rockwell is also ready to discuss designing your product's microelectronic system with its own resources. Module manufacturing is also available.

Rockwell PPS-4/1 One-Chip Microcomputers Give You More Because You Can Pick The Right Chip At The Right Price

| Features/Models | MM75 | MM78 | MM76EL | MM78L | MM78LA |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ROM (x 8) | 640 | 2048 | 1024 | 2048 | 2048 |
| RAM (x 4) | 48 | 128 | 48 | 128 | 128 |
| Speed ( $\mu \mathrm{s}$ ) | 12.5 | 12.5 | 10.0 | 10.0 | 10.0 |
| Total I/O Lines | 22 | 31 | 31 | 31 | 35 |
| Cond. Interrupt | $1+1^{*}$ | 2 | 2 | 2 | $1^{*}$ |
| Parallel Input | 4 | 8 | 8 | 8 | 8 |
| Parallel Output | - | - | - | - | 14 |
| Bidirectional Parallel | 8 | 8 | 8 | 8 | - |
| Discrete | 9 | 10 | 10 | 10 | 10 |
| Serial | - | 3 | 3 | 3 | - |
| Speaker | - | - | - | - | 3 |
| Programmable Logic Array (PLA) | $16 \times 8$ | - | $16 \times 8$ | - | $32 \times 14$ |
| Tone Generator Counter | - | - | - | - | 8-bit |
| Package (In-Line) | $\begin{array}{r} 28-\mathrm{pin} \\ \text { dual } \end{array}$ | 42-pin quad | 40-pin dual | 40-pin dual | 42-pin quad |
| Power | -15V@ 75 mw (typical) |  | -6.5 to -11V@15 mw (typical) |  |  |

*Multiplexed

# PARALLEL PROCESSING SYSTEM (PPS) DATA SHEET 

PPS-4/1 One-Chip Microcomputer Family

## MM75

one-chip microcomputer system

## INTRODUCTION

The Rockwell MM75 one-chip microcomputer is primarily designed to fit the lowest cost requirements of equipment designers. But in addition to cost advantage, it provides system functions not presently available in competitive micropjocessors.

On a single LSI chip, the MM75 provides a complete 4-bit parallel microcomputer system - versatile Central Processing Unit (CPU), Instruction Decode, Program Save Register, Program Memory (ROM), Data Memory (RAM), Program Counter (P), Data Address Register ( $B$ ), nine input/output discrete drivers/receivers, two 4 -bit parallel input/output channels, one 4 -bit parallel input channel, Interrupt and Control logic, and a self-contained Clock Generator circuit.

In addition to stand-alone system applications, the MM75 can be directly included in other multi-chip systems as a dedicated slave controller.

To facilitate system and program development, Rockwell provides powerful development aids listed under "Features" at right.

The MM75 is a member of the MM76 series of microcomputers. Consult the MM76 SERIES USER'S MANUAL for detailed hardware and software specifications (Document Number 29410N47). MM75 device codes may be submitted using the PMOS ROM CODE ORDER FORMS (Document Number 29000N33).

The MM75 may be ordered with combinations of the following features (not every combination is available).

Operating Temperature
$0^{\circ} \mathrm{C}$ to $+50^{\circ} \mathrm{C}$ (Consumer)
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Commercia!)
Maximum Negative Voltage
-30 Volts (Vacuum Fluorescent Drive)
-15 Volts (Standard)


PPS-4/1 MM75 Pin Configuration

## FEATURES

- 6408 -bit bytes of program memory ( 5120 bits)
- 48 4-bit data words ( 192 bits)
- 168 -bit word decode matrix (128 bits)
- Two interrupt request input lines
- TTL and CMOS compatible
- Arithmetic logic unit and four working registers
- 22 input/output ports
- Large instruction set - over 50 instructions
- Multifunction instructions increase throughput
- Single power supply operation ( -15 volts $\pm 5 \%$ )
- Low power ( 75 milliwatts typical, 125 milliwatts max)
- 28-pin, dual-in-line package
- Powerful development aids:
- SYSTEM 65 with built in mini-floppy disks and PPS-4/1 Personality subsystem
- XPO-1 Evaluation Microcomputer Module
-. Development Circuit (P/N A7699) provides address and/ device data lines so that the Program Memory can be in external PROM or RAM for emulating the MM75
- Training Courses are available
- International Applications Engineering Support


## FUNCTIONAL DESCRIPTION

## PROGRAM COUNTER (P) and SA REGISTER

The Program Counter contains the ROM address of the next program instruction. The address in the $P$ Register is automatically incremented each cycle time during normal operation to address the next instruction. In addition, instructions are available to alter the address in the P Register as necessary to fetch an instruction from any address in program memory.

After PO reset, the program counter contains address Hex 1 CO . This location must contain a NOP instruction.

The SA Register is a "save" register which saves the incremented value of current address in the $\mathbf{P}$ Register during subroutine execution. This provides a means of returning from a subroutine directly to the next instruction after the subroutine call.

## PROGRAM MEMORY - READ ONLY MEMORY (ROM)

The ROM provides 6408 -bit words of storage for instructions and constants required to operate the microcomputer. Under control of the Program Counter the ROM will read out the addressed instruction which is to be decoded and executed.

## INSTRUCTION DECODE

The Instruction Decode logic circuitry interprets the instructions pulled from ROM to provide contro: for data transfers, arithmetic operations, other processing functions and input/ output operations.

## DATA ADDRESS REGISTER (8)

The Data Address Register is 6 bits in length and is made up of two segments, B Upper (BU) and B Lower (BL). Data locations in RAM and the discrete input/output ports are addressed by the 4 bits in BL and the 2 bits in BU.

A number of multifunction instructions simultaneously modify B Upper and cause B Lower to be automatically incremented or decremented and tested for overflow or underflow.

## S REGISTER

The S Register is a 4-bit register which is used as a working register or an auxiliary storage register to the Accumulator. It can be used as a temporary storage register executing the XAS instruction.

## ACCUMULATOR and ARITHMETIC LOGIC UNIT

 (A, ALU, and C)The primary working register in the MM75 is the Accumulator (A). It is the Accumulator which ties with the Arithmetic Logic Unit (ALU) and the Carry flip-flop (C) to perform either binary or decimal arithmetic. Constants may be loaded into the Accumulator from the read only memory or variable data may be loaded from, or exchanged with the random access memory (RAM) under control of the Data Address Register (B). The Accumulator is also the primary path for 4 -bit parallel input or output data.

## CLOCK CONTROL (VC, OSCILLATOR)

The internal Oscillator and Clock circuit generates a four-Phase clock signal used for all internal logic functions. The A clock term is also brought out so external logic can be synchronized. The clock frequency is a nominal $90 \mathrm{kHz} \pm 40 \%$.

An external clock mask option is available. If this option is chosen, the A clock becomes the external clock input and VC must be tied to VDD through the appropriate resistor.

## DATA MEMORY (RAM)

The Random Access Memory (RAM) used for data memory contains 484 -bit words. Data memory can be used to buffer input or output values, hold intermediate results, or be used as a register for timers, counters, comparators, etc.

## A BUFFER

The contents of the Accumulator or 4 of the bits from the $16 \times 8$ Decode Matrix may be output for control, display, or data transfer functions through the A Buffer. The A Buffer holds the data for output until new data is received from the Accumulator or the Decode Matrix, or until the power is turned off.

## B BUFFER

The 4-bit B Buffer functions the same as the A Buffer except it outputs the other 4 bits of the $16 \times 8$ Decode Matrix. The $A$ and $B$ Buffers combined provide the full eight outputs for the Decode Matrix.

## CHANNEL 1 INPUT PORTS (PI1 through PI4)

The parallel input port PI1 through PI4 will be loaded into the Accumulator upon command. The receivers are TTL compatible and are synchronized (phase 1 time) so that asynchronous input signals may be used.

## CHANNEL A I/O PORTS (RI01 through RI04)

The four parallel input/output ports RI01 thru R104 provide a masked input capability and an output from either the $16 \times 8$ Decode Matrix or directly from the Accumulator.

## CHANNEL B I/O PORTS (RI05 through RI08)

The four parallel input/output ports of Channel B function the same as the four ports of Channel A. Together, they provide an 8 -bit parallel output. RIO8 also has the capability to be used as a conditional interrupt (INT1).

## CONDITIONAL INTERRUPTS (INTO and OPTIONAL INT1)

The conditional interrupts INTO and RIO8 (INT1) may be used to detect external signals and set internal control flip-flops. The receivers are TTL compatible and synchronized with INTO sampled at phase 3 and RI08 sampled at phase 1.

The conditional interrupts (edge detect) input lines in the PPS-4/1 family are very useful. The RIO8 line can be used in two ways as part of the parallel I/O Channel B or as the INT1 line. When used as an interrupt line, RIO8 will respond to the $\operatorname{INT1H}$ and DIN1 commands. When used as part of the bidirectional I/O Channel $B$, it is controlled with the IBM, OB and the SEG2 instructions.

DISCRETE INPUT/OUTPUT PORTS (DI/OO through DI/O8)
There are nine discrete input or output lines each of which can be controlled individually under program control. The receivers are fully synchronized so that asynchronous input signals may be used.

## $16 \times 8$ DECODE MATRIX

The Decode Matrix provides a means of decoding the contents of the Accumulator to provide an 8 -bit output suitable for driving various displays or other external devices. The user may define any code desired. The Development device for the MM75 has a $B C D$ to seven segment conversion provided. Accumulator contents of 0 thru $F$ produce 0 thru $9, A,-, P, d, E$ and blank respectively. The carry flip-flop controls one independent output line.

PPS-4/1 MM75 INSTRUCTION SET

| RAM Addressing Instructions |  |
| :---: | :---: |
| $\times A B$ | Exchange A with BL |
| LBA | Load BL from A |
| LB | Load $\mathrm{BU}=0, \mathrm{BL}=1 \mathrm{mmediate}$ |
| EOB | Exclusive OR BU |
| LBL | Load B Long |
| INCB | Increment B |
| DECB | Decrement $B$ |
| Bit Manipulation Instructions |  |
| SB | Set Bit |
| RB | Reset Bit |
| SKBF | Skip on Bit False |
| Register to Register Instructions |  |
| $\times$ AS | Exchange $A$ and $S$ |
| LSA | Load S from A |
| Register Memory Instructions |  |
| L | Load A from Memory |
| $\times$ | Exchange $A$ and Memory |
| XDSK | Exchange $A$ with Memory. Decrement BL and Skip if BL Counts to 15 |
| XNSK | Exchange $A$ with Memory. Increment $B L$ and Skip if BL Counts to 0 |
| Arithmetic Instructions |  |
| A | Add Memory to A |
| $A C$ | Add Memory with Carry to A |
| ACSK | Add Memory with Carry to A and Skip on No Carry-out |
| ASK | Add Memory to A and Skip on no Carry-out |
| DC | Decimal Correction |
| COM | Complement $A$ |
| RC | Reset Carry |
| SC | Set Carry |
| SKNC | Skip on No Carry |
| LAI | Load A with Immediate Field |
| AISK | Add Immediate and Skip on No Carry-out |
| Logical Comparison Instructions |  |
| SKMEA | Skip if Memory Equals $A$ |
| SKBEI | Skip if BL Equals Immediate Field |
| SKAEI | Skip it A Equals Immediate Field |


| Input/Qutput Instructions |  |
| :---: | :---: |
| SOS | Set Output Selected |
| ROS | Reset Output Selected |
| SKISL | Skip on Input Selected Low |
| IBM | Input Channel B ANDed with A |
| OB | Output from A to Channel B |
| IAM | Input Channel A ANDed with A |
| OA | Output from A to Channel A |
| 11 | Input Channel 1 |
| INT1H | Skip if INT1 Input (RI08) is Low |
| DIN1 | Skip if INT1 Flip-flop is Reset |
| INTOL | Skip if INTO Input is High |
| DINO | Skip if INTO Flip-flop is Reset |
| SEG 1 | Decoder Matrix to Channel A |
| SEG2 | Decoder Matrix to Channel B |
| Conditional Transfer Instructions |  |
| TC | Transfer on Carry Set |
| TNC | Transfer on No Carry Set |
| TLC | Transfer Long on Carry Set |
| TLNC | Transfer Long on No Carry Set |
| TBF | Transfer on Bit in Memory False |
| TBT | Transfer on Bit in Memory True |
| TLBF | Transfer Long on Bit in Memory False |
| TLBT | Transfer Long on Bit in Memory True |
| TE | Transfer on $A=$ Memory |
| TNE | Transfer on $A \neq$ Memory |
| TLE | Transfer Long on $A=$ Memory |
| TLNE | Transfer Long on $A \neq$ Memory |
| TIH | Transfer if Input High |
| TIL | Transfer if Input Low |
| TLIH | Transfer Long if Input High |
| TLIL | Transfer Long if Input Low |
| ROM Addressing Instructions |  |
| RT | Return from Subroutine |
| RTSK | Return and Skip |
| T | Transfer on Page |
| NOP | No Operation |
| TL | Transfer Long |
| TM | Transfer and Mark |
| TML | Transfer and Mark Long |



## SPECIFICATIONS

## OPERATING CHARACTERISTICS

Supply Voltage:
VDD $=-15$ Volts $\pm 5 \%$
(Logic " 1 " = most negative voltage $V_{\text {IL }}$ and $V_{\text {OL }}$.)
VSS = 0 Volts (Gnd.)
(Logic " 0 " = most positive voltage $\mathrm{V}_{\mathrm{IH}}$ and $\mathrm{V}_{\mathrm{OH}}$.)
System Operating Frequencies (Internal Clock):
$90 \mathrm{kHz} \pm 40 \%$ with external resistor
Max Operating Frequency (External Clock): 100 kHz

Device Power Consumption
75 mw , typical
Input Capacitance:
< 5 pf

Input Leakage:
$<10 \mu \mathrm{a}$
Open Drain Driver Leakage (R OFF):
$<10 \mu$ at maximum voltage
Operating Ambient Temperature (TA):
$0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (TA $=25^{\circ} \mathrm{C}$ unless otherwise specified.)
Storage Temperature:

$$
-55^{\circ} \mathrm{C} \text { to } 120^{\circ} \mathrm{C}
$$

## ABSOLUTE MAXIMUM VOLTAGE RATINGS (with respect to VSS)

Maximum negative voltage on any pin $\mathbf{- 3 0}$ volts (vacuum fluorescent drive).

Maximum negative voltage on any pin -15 volts (standard).
Maximum positive voltage on any pin +0.3 volts.

| INPUT/OUTPUT | SYMBOL | LIMITS (VSS = 0) |  |  | LIMITS (VSS $=+5 \mathrm{~V}$ ) |  |  | $\begin{aligned} & \text { TIMING } \\ & \text { (SAMPLE/ } \\ & \text { GOOD) } \end{aligned}$ | $\begin{gathered} \text { TEST } \\ \text { CONDITIONS } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP | MAX | MIN | TYP | MAX |  |  |
| Supply Current (Average) for VDD | IDD |  | 5 ma | 8 ma |  | 5 ma | 8 ma |  | $V D D=-15.75 \mathrm{~V}$ |
| Discrete //O's (1) | $V_{\text {IH }}$ | -1.0V |  | . 4.2 V | $+4.0 \mathrm{~V}$ | $+0.8 \mathrm{~V}$ |  | \$3-4 |  |
| DI/O O.DI/O 8 | $V_{\text {IL }}$ |  |  |  |  |  |  |  |  |
| DI/O 0.5 | RON | 500 ohms |  |  | 500 ohms |  |  | $\phi 4^{*}$ | 3.0 ma max |
| D1/O 6-8 | RON |  |  | 400 ohms |  |  | 400 ohms |  |  |
| Channel 1 Input | $\mathrm{V}_{\text {IH }}$ | -1.5V |  | -4.2V | $+3.5 \mathrm{~V}$ |  | $+0.8 \mathrm{~V}$ | \$1 | 6.0 ma max. |
| Pl1.PI4 | $V_{1 L}$ |  |  |  |  |  |  |  |  |
| 1/O Channel A (1) | $\mathrm{V}_{\text {IH }}$ | $\cdot 1.5 \mathrm{~V}$ |  | -4.2V | $+3.5 \mathrm{~V}$ |  | +0.8V | ¢3 |  |
| RI/O1-RI/O4 | $V_{1 L}$ |  |  |  |  |  |  |  |  |
|  | RON |  |  | 250 ohms |  |  | 250 ohms | ¢4* |  |
| 1/O Channel B (1) | $\mathrm{V}_{\text {IH }}$ | $\cdot 1.5 \mathrm{~V}$ |  | -4.2V | $+3.5 \mathrm{~V}$ |  | +0.8V | ¢ 3 | 6.0 ma max. |
| RI/O5.R1/O8 | $V_{\text {IL }}$ |  |  |  |  |  |  |  |  |
|  | RON |  |  | 250 ohms |  |  | 250 ohms | ¢4* |  |
| INTO (2) | $\mathrm{V}_{\text {IH }}$ | . 1.5 V |  | .4.2V | $+3.5 \mathrm{~V}$ |  | +0.8V | ¢ 3 | $C L=50 \mathrm{pf}$ (max) |
|  | $V_{\text {IL }}$ |  |  |  |  |  |  |  |  |
| Clock | $\mathrm{V}_{\mathrm{OH}}$ | -1.0V |  | -10.0V | +4.0V |  | . 5.0 V | -5.0V |  |
| vc |  |  |  |  |  |  |  |  | $56 \mathrm{~K} \pm 5 \%$ |
| PO | $\begin{aligned} & \hline V_{I H} \\ & v_{I L} \end{aligned}$ | 2.0V |  | -6.0V | +3.0V |  | -1.0V |  | Special circuit |
| "State established by $\phi 2$ (minimum impedance during $\phi 4$ ). <br> (1)These pins only tested for leakage: $<10 \mu \mathrm{a} @-30 \mathrm{~V}$. <br> (2)This pin only tested for leakage: $<10 \mu \mathrm{a} @ V_{D D}$. |  |  |  |  |  |  |  |  |  |

## PART NUMBER B86XX



# PARALLEL PROCESSING SYSTEM (PPS) DATA SHEET 

## PPS-4/1 One-Chip Microcomputer Family

## MM76EL

## low-voltage, low power one-chip microcomputer system

## SUMMARY

The Rockwell MM76EL microcomputer is a complete 4-bit parallel processing system. The MM76EL is a low voltage $(6.5$ to 11 volt range), very low power ( 15 milliwatts typical) version of the well known PPS-4/1 one-chip microcomputer. The MM76EL is especially desirable where low-cost battery operation as the primary or backup power source is required, or where power consumption or heat dissipation is a consideration, or where portability is required. The MM76EL is distinguished from competitive microprocessors by superior I/O capability, and by other functionat features identified on this page.

On a single LSI chip, the MM76EL provides a complete system consisting of a versatile Central Processing Unit (CPU), Instruction Decode, one Program Save Register, Program Memory (ROM), Data Memory (RAM). Program Counter (P), Data Address Register (B), 10 I/O discrete Drivers/Receivers, two 4 -bit paralle! I/O channels, two 4 -bit paraliel input channels, a Serial I/O port, Interrupt and Control logic, and a self-contained four-phase Clock Generator circuit.

In addition to stand-alone applications, the MM76EL can be directly included in other multi-chip systems as a dedicated controller or in other functions. Also, two or more MM76EL microcomputers can be directly combined to perform parallel processing. or control operations. In the design of families of end-products, a total range of features can be designed so that increasingly higher levels of performance can be produced by low-cost wiring changes and chip additions, minimizing design costs and production inventories.

The MM76EL may be ordered with combinations of the following features (not every combination is available)

Operating Temperature
$0^{\circ} \mathrm{C}$ to $+50^{\circ} \mathrm{C} \quad$ (Consumer)
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C} \quad$ (Commercial)
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Industrial)
Maximum Negative Voltage
-30 Volts (Vacuum Fluorescent Drive)
-11 Volts (Standard)
Nominal Internal Clock Frequency
$100 \mathrm{kHz}( \pm 30 \%)$ with VC to VDD

## ELECTRICAL FEATURES

- Battery Compatible ( -6.5 to -11.0 volt operation)
- Low Power - 15 milliwatts nominal @ -8.5 volts
- 4 Clock Modes including external crystal
- Low Impedance Drivers

DI/O - less than 100 ohm @ 10 ma
RIO - less than 250 ohm @ 6 ma

- Mask Programmed Pull-down Resistors on Outputs
- Mask Programmed Enhancement FET Pull-downs on Inputs


MM76EL Pin Configuration

## FUNCTIONAL FEATURES

- Standard 40-pin Dual-In-Line (DIP) package
- 10248 -bit bytes of program memory
- 484-bit words ( 192 bits) of data memory
- Clocked simultaneous serial input/output capability
- Externally controlled serial input/output capability
- Two interrupt request input lines
- TTL and CMOS compatible
- Arithmetic logic unit and four working registers
- 31 input/output ports
- Large instruction set - over 60 instructions
- Multifunction instructions increase throughput
- Single power supply operation ( -8.5 volts $-2.5,+2.0$ volts)
- Low power (15 milliwatts typical)
- Powerful development aids:
- SYSTEM 65 with built-in mini-floppy disks and PPS-4/1 Personality subsystem
- XPO-1 Evaluation Microcomputer Module
- Development Circuit (P/N B7699) provides address and data lines so that Program Memory can be in external PROM for emulation purposes
- Scheduled and Special Training Courses
- International Applications Engineering Support


## FUNCTIONAL DESCRIPTION

## PROGRAM COUNTER (P) AND SA REGISTER

The Program Counter contains the ROM address of the next program instruction. The address in the $P$ Register is automatically incremented each cycle time during normal operation to address the next instruction. In addition, instructions are available to alter the address in the $P$ Register as necessary to fetch an instruction from any address in program memory. After PO reset, the program counter contains address hex 3C0. This location must contain a NOP instruction.
The SA Register is a "save" register which saves the incremented value of current address in the $\mathbf{P}$ Register during subroutine execution. This provides a means of returning from a subroutine directly to the next instruction after the subroutine call.

## PROGRAM MEMORY - READ ONLY MEMORY (ROM)

The ROM provides 1024 bytes of storage for instructions and constants required to operate the microcomputer. Under control of the Program Counter the ROM will read out the addressed instruction which is to be decoded and executed.

## INSTRUCTION DECODE

The Instruction Decode logic circuitry interprets the instructions pulled from ROM to provide control for data transfers, arithmetic operations, other processing functions and input/output operations.

## DATA ADDRESS REGISTER (B)

The Data Address Register is 6 bits in length and is made up of two segments, B Upper (BU) and B Lower (BL). Data locations in RAM and the discrete input/output ports are addressed by the 4 bits in $B L$ and the 2 bits in $B U$.

A number of multifunction instructions simultaneously modify B Upper and cause B Lower to be automatically incremented or decremented and tested for overflow or underflow.

## ACCUMULATOR AND ARITHMETIC LOGIC UNIT (A, ALU, and C)

The primary working register in the MM76EL is the Accumulator (A). It is the Accumulator which ties with the Arithmetic Logic Unit (ALU) and the Carry flip-flop (C) to perform either binary or decimal arithmetic. Constants may be loaded into the Accumulator from the read only memory or variable data may be loaded from, or exchanged with the random access memory (RAM) under control of the Data Address Register (B). The Accumulator is also the primary path for 4-bit parallel or serial input or output data.

## DATA MEMORY (RAM)

The Random Access Memory (RAM) used for data memory contains 484 -bit words. Data memory can be used to buffer input or output values, hold intermediate results, or as a register for timers, counters, comparators, etc.

## CLOCK CONTROL (VC, XTLIN, XTLOUT, A, AND BP)

The internal Oscillator and Clock Circuit generates a four-phase $A$ and BP clock signal used for all internal logic functions. The $A$ and BP clock terms are also brought out so external logic can be synchronized. The clock for the MM76EL can be selected to operate in one of four modes as shown by the table below. These options are selected by control voltages applied to the VC and XTLIN pins.

## A BUFFER

The contents of the Accumulator or 4 of the bits from the $16 \times 8$ Decode Matrix may be output for control, display, or data transfer functions through the A Buffer. The A Buffer holds the data for output until new data is received from the Accumulator or the Decode Matrix, or until the power is turned off.

## B BUFFER

The 4 -bit B Buffer functions the same as the A Buffer except it outputs the other 4 bits of the $16 \times 8$ Decode Matrix. The $A$ and B Buffers combined provide the full eight outputs for the Decode Matrix.

## CHANNEL 1 INPUT PORTS (P11 through P14)

The parallel input port PII through PI4 will be loaded into the contents of the Accumulator upon command. The receivers are TTL compatible and are synchronized (phase 1 time) so that asynchronous input signals may be used.

CHANNEL 2 INPUT PORTS (PI5 through PI8)
The inverted state of the inputs at parallel input ports P15 thru PI8 will be loaded into the Accumulator upon command. The receivers are TTL compatible and are synchronized (phase 3 time) so that asynchronous input signals may be used.

## CHANNEL A I/O PORTS (RIO1 through RIO4)

The four parallel input/output ports RIO1 thru R1O4 provide a masked input capability and an output from either the $16 \times 8$ Decode Matrix or directly from the accumulator.

CHANNEL B I/O PORTS (RIO5 through RIO8)
The four parallel input/output ports of Channel B function the same as the four ports of Channel A. Together, they provide an 8 -bit parallel output.

## CONDITIONAL INTERRUPTS (INTO and INT1)

The conditional interrupts INTO and INT1 may be used to detect external signals and set internal control flip-flops. The receivers are TTL compatible and synchronized.

DISCRETE INPUT/OUTPUT PORTS (DI/O0 through DI/O9)
There are ten discrete input or output lines each of which can be controlled individually under program control. The receivers are fully synchronized so that asynchronous input signals may be used.

## $16 \times 8$ DECODE MATRIX

The Decode Matrix provides a means of decoding and contents of the Accumulator to provide an 8 -bit output suitable for driving various displays or other external devices. The user may define any code desired. The Development Circuit version of the MM76EL has a BCD to seven segment conversion provided. Accumulator contents of $O$ thru $F$ produce 0 thru $9, A,-, P, d, E$ and blank respectively. The carry flip-flop controls one independent output line.

S REGISTER - SERIAL INPUT/OUTPUT - SHIFT COUNTER
The $S$ register is a 4 -bit serial-in/serial-out, parallel exchange, register which is used as either an auxiliary storage register or buffer for the simultaneous serial input/output functions. The shift rate can be controlled either internally or externally.

| Mode | $V_{c}$ | Pins |  |  |  | Frequency |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | XTLIN | XTLOUT | A I/O | BP I/O |  |
| INTERNAL | ${ }^{*} \mathrm{~V}_{\mathrm{c}}$ | VSS | - | OUT | OUT | $100 \mathrm{kHz} \pm 30 \%$ @ 8.5V |
| EXTERNAL | GRD | CLOCK | - | OUT | OUT | $400-800 \mathrm{kHz} @ 8.0 \mathrm{~V}$ |
| CRYSTAL** | GRD | XTAL | XTAL | OUT | OUT | $\approx 800 \mathrm{kHz} @ 8.0 \mathrm{~V}$ |
| SLAVE | $V_{\text {DD }}$ | ${ }^{\text {OD }}$ | - | IN | IN | $50 \mathrm{kHz}-100 \mathrm{kHz}$ @ 8.5V |
| *Can be adjusted to vary frequency - Normally set to $V_{D D}$ <br> **Suggest Murata part number CSB800A4 with $2-120$ pF shunt capacitors. |  |  |  |  |  |  |

RAM Addressing Instructions
KAB Exchange $A$ with $B L$
LBA Load $B U=0, B L=1$ fromediate
$\begin{array}{ll}\text { LB } & \text { Exad } B U=0, B L=1 \\ E O B & \text { Exclusive OR BU }\end{array}$
$\begin{array}{ll}\text { LOB } & \text { Load B Long } \\ \text { LBL }\end{array}$
INCB Increment $B$
DECB Decrement B
Bit Manipulation Instructions
$\begin{array}{ll}\text { SB } & \text { Set Bit } \\ \text { RB } & \text { Reset Bit }\end{array}$
$\begin{array}{ll}\text { RBBF } & \text { Reset Bit } \\ \text { Skip on Bit False }\end{array}$
Register to Register Instructions
$\times A S$. Exchange $A$ and $S$
LSA Load S from A
Register Memory Instructions
$L \quad$ Load A from Memory
XDSK Exchange $A$ with Memory. Decrement BL and Skip if
XNSK Exchange $A$ with Memory.. Increment BL and Skip if $B L$ Counts to $O$

Arithmetic Instructions
AC Add Memory to A
ACSK Add Memory with Carry to A and Skip on No Carry-out
ASK Add Memory to A and Skip if No Carry Overflow
DC Decimal Correction
COM Complement A
RC Reset Carry
SC Set Carry
SKNC Skip on No Carry
AISK Add Immediate and Skip on No Carry-out
Logical Comparison Instructions
SKMEA Skip if Memory Equals A
SKBEI Skip if BL Equals Immediate Field
SKAEI Skip if A Equals Immediate Field

| Input/Output Instructions |  |
| :---: | :---: |
| SOS | Set Output Selected |
| ROS | Reset Output Selected |
| SKISL | Skip on Input Selected Low |
| IBM | Input Channel B ANDed with A |
| O8 | Output from A to Channel B |
| IAM | Input Channel A ANDed with A |
| OA | Output from $A$ to Channel $A$ |
| 105 | Serial Input/Output |
| 11 | Input Channel 1 |
| 12C | Inpur Channel 2 and Complement |
| INT1H | Skip if INT1 Input is Low |
| DIN1 | Skip if INT1 Flip-flop is Reset |
| INTOL | Skip if INTO Input is High |
| DINO | Skip if INTO Flip-flop is Reset |
| SEG 1 | Decoder Matrix Output to Channel A |
| SEG2 | Decoder Matrix Output to Channel B |
| Conditional Transfer Instructions |  |
| TC | Transfer on Carry Set |
| TNC | Transfer on No Carry Set |
| TLC | Transfer Long on Carry Set |
| TLNC | Transfer Long on No Carry Set |
| TBF | Transfer on Bit in Memory False |
| TBT | Transfer on Bit in Memory True |
| TLBF | Transfer Long on Bit in Memory False |
| TLBT | Transfer Long on Bit in Memory True |
| TE* | Transfer on $A=$ Mernory |
| TNE | Transfer on A $\neq$ Memory |
| TLE | Transfer Long on $A=$ Memory |
| TLNE | Transfer Long on A $\ddagger$ Memory |
| TIH | Transfer if Input High |
| TIL | Transfer if input Low |
| TLIH | Transfer Long if Input High |
| TLIL | Transfer Long if Input Low |
| ROM Addressing Instructions |  |
| RT | Return from Subroutine |
| RTSK | Return and Skip |
|  | Transfer on Page |
| NOP | No Operation |
| TL | Transfer Long |
| TM | Transfer and Mark |
| TML | Transfer and Mark Long |



## SPECIFICATIONS

## OPERATING CHARACTERISTICS

Supply Voltage:
$V_{D D}=-8.5$ Volts, $-1.5,+2.0$ Volts (MM76EL-1)
$V_{D D}=-8.5$ Volts, $-2.5,+2.0$ Volts (MM76EL)
(Logic " 1 " = most negative voltage $V_{I L}$ and $V_{O L}$.)
$\mathrm{V}_{\mathrm{SS}}=0 \mathrm{Volts}$ (Gnd)
(Logic " $\mathrm{O}^{\prime \prime}$ = most positive voltage $\mathrm{V}_{\mathrm{IH}}$ and $\mathrm{V}_{\mathrm{OH}}$.) System Operating Frequencies:
(1) Internal: 100 kHz Nominal at $V_{D D}=-8.5 \cdot \mathrm{~V}$
(2) External 800 kHz Crystal: 100 kHz

Device Power Consumption: 15 mw , typical

Input Capacitance: < 5 pf
Input Leakage: <10 $\mu \mathrm{a}$
Open Drain Driver Leakage (R OFF): $₹ 10 \mu$ at -30 Volts
Operating Ambient Temperature ( $T_{A}$ ):
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Commercial): MM76EL
$0^{\circ} \mathrm{C}$ to $+50^{\circ} \mathrm{C}$ (Consumer): MM76EL-1
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Industrial): MM76EL-2
Storage Temperature: $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
ABSOLUTE MAXIMUM VOLTAGE RATINGS (with respect to VSS)

Maximum negative voltage on any pin -30 Volts Maximum positive voltage on any pin +0.3 Volts

| INPUT/OUTPUT | SYMBOL | LIMITS IVSS - 01 |  |  | LIMITS (VSS $=$ +5VI' |  |  | $\begin{aligned} & \text { TIMING } \\ & \text { ISAMPLE/ } \\ & \text { GOOD) } \\ & \hline \end{aligned}$ | TEST CONOITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP | Max | MIN | TYP | Max |  |  |
| Supply Current (Average) for VDD | 100 | 1.75 ma 3 ma |  |  | 1.75 mm - 3 mm |  |  |  | Internal Clock |
|  |  |  | 3.0 ma | 6 ma |  | 3.0 ma | 6 ma |  |  |
| $\begin{aligned} & \text { Oiscrete 1/O's } \\ & \therefore 01 / 00.9 \end{aligned}$ | $\begin{array}{r} \hline V_{14} \\ v_{16} \\ \hline \end{array}$ | -1.0V | -4.2V |  | +4.0V | +0.8V |  | -3. 04 |  |
|  | RON |  |  | 100 ohms |  |  | 100 ohms | ¢4* | 10.0 mamax. |
| $\begin{gathered} \text { Channeet } 1 \text { Input } \\ \text { P1i-Pi4 } \end{gathered}$ | $\begin{aligned} & v_{1 H} \\ & v_{11} \end{aligned}$ | -1.5V | -4.2V |  | +3.5V | +0.8V |  | $\dagger 1$ | 0.0 mat max. |
| Channet 2 Input P15-P18 | $\begin{aligned} & V_{i H} \\ & V_{1 L} \end{aligned}$ | -1.5V | -4.2V |  | +3.5V | +0.8V |  | \$3 |  |
| $\begin{aligned} & \text { WOChannel A } \\ & \text { RIOT-RIO4 } \end{aligned}$ | $\begin{aligned} & v_{\text {IH }} \\ & v_{11} \end{aligned}$ | -1.5V | -4.2V |  | +3.5V | +0.8V |  | ¢4 |  |
|  | RON |  |  | 250 ohms |  |  | 250 ohms | \$4* | 6.0 ma max. |
| $\begin{aligned} & \text { 1/O Shanneli } 8 \\ & \text { RIOS-RIO8 } \end{aligned}$ | $\begin{aligned} & \hline \mathrm{V}_{\mathbf{I H}} \\ & \mathrm{v}_{\mathrm{IL}} \end{aligned}$ | -1.5V | -4.2V |  | +3.5V | +0.8V |  | ¢4 |  |
|  | RON |  |  | 250 omms | +4.0V |  | 250 ohmm | $04^{\circ}$ | 6.0 mamax. |
| DATAI | $\begin{aligned} & v_{11} \\ & v_{1 L} \end{aligned}$ | -1.0V | -4.2V |  |  | +0.8V |  | 94 |  |
| DATAO | RON | -1.5V | 500 0hms-4.2 V |  | +3.5V | 500 ohms+0.8 V |  | ¢9\% | 3.0 mamax. |
| Into | $\begin{aligned} & \hline V_{\mathrm{iH}} \\ & V_{\mathrm{IL}} \end{aligned}$ |  |  |  | 03 |  |  |  |  |
| INTi | $\begin{aligned} & v_{1 H} \\ & v_{1 L} \end{aligned}$ | -1.5V | -4.2V |  |  | -3.5v | +0.8V |  | \$1 |  |
| A. ${ }^{\text {P }}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{v}_{\mathrm{OL}} \end{aligned}$ | 0.3V | 4.7V |  | +4.7v | +0.3V |  |  | $\begin{aligned} & \text { CL e } 60 \text { of (mont } \\ & \text { mit, Ext or XTL } \\ & \text { Clock } \end{aligned}$ |
| A. BP | $\begin{aligned} & v_{1 H} \\ & v_{1 L} \end{aligned}$ | -0.6V | -4.4V |  | +4.4v | +0.6V |  |  | Slave Clock |
| XTLIN | $\begin{aligned} & \mathrm{V}_{\mathrm{iH}} \\ & \mathrm{~V}_{\mathrm{HL}} \end{aligned}$ | -1.0V | -6.0V |  | +3.5V | -1.0V |  | -4.0V |  |
| CLOCX | $\begin{aligned} & V_{I H} \\ & v_{I L} \end{aligned}$ | -1.0V | $-4.2 v$ |  | +4.0V | +0.8V |  | -3. 04 |  |
|  | RON |  |  | 500 ohms |  |  | 500 ohms | $94^{\circ} \cdot$ | 2.0 ma max . |
| vC | $\begin{aligned} & \overline{v_{\text {IH }}} \\ & v_{\text {IL }} \end{aligned}$ |  |  |  |  |  |  |  | V - 11.0 V max. |
| PO | $\begin{aligned} & \hline v_{\text {IH }} \\ & v_{\text {IL }} \end{aligned}$ | -2.5V | .5.0V |  | +2.5V | ov |  |  | Special circuit |
| -Stete established by o2 (minimum impedance during e4). <br> - -Same as above except $\phi 4$ minimum at $\phi 2$ of next eycle. |  |  |  |  |  |  |  |  |  |

## NOTES:

## MASK PROGRAMMED PULL-DOWN RESISTORS ON OUTPUTS

Resistor pull-downs are available as an option on all RIO, CLOCK, DATAO and DI/O outputs. These pull-downs are connected to $V_{\text {DD }}$. The following values $\pm 50 \%$ are available: $5 \mathrm{~K}, 10 \mathrm{~K}, 25 \mathrm{~K}$, or Open Circuit. The 5K ohm option is not available on the clock or DATAO outputs.

## PULL-DOWNS ON INPUTS

MOS FET pull-downs are also available as an option on the PI. INT, and DATAI inputs. The output current is $50 \mu \mathrm{a} \pm 35 \mu \mathrm{a}$ with the input grounded and $V_{D D}$ at $\mathbf{- 8 . 5}$ volts.

## PART NUMBER A78XX

## PARALLEL PROCESSING SYSTEM (PPS) DATA SHEET

# PPS-4/1 One-Chip Microcomputer Family 

## MM78

## one-chip microcomputer system

## SUMMARY

The Rockwell MM78 microcomputer is a complete, 4-bit parallel processing system. Its large instruction set is augmented by powerful multi-function Instructions. 31 I/O ports further identify the power of this system. Serial I/O capability, which can be clocked simultaneously or externally controlled, extend their power.

On a single LSI chip, the MM78 provides a complete 4-bit parallal processing system - Central Processing Unit (CPU). Program Memory (ROM), Data Memory (RAM), Program Counter (P), Instruction Decode, two Program Save registers, Data Address register ( $B$ ), 10 I/O discrete drivers/receivers, two 4 -bit parallel I/O channels, two 4 -bit paraltel input channels, a serial input/ output port, interrupt and control lagic, and a self-contained four-phase clock generator circuit.

In addition to stand-alone system applications, this microcomputer can be directly interfaced with other multi-chip systems as dedicated slave controllers or for other purposes. Also, two or more MM78 systems can be directly combined to perform parallel processing or cantrol operations.

The MM78 may be ordered with combinations of the following features (not every combination is available).

| Operating Temparature |  |
| :---: | :--- |
| $0^{\circ} \mathrm{C}$ to $+50^{\circ} \mathrm{C}$ | (Consumer) |
| $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | (Commercial) |

Maximum Negative Voltage
-30 Volts (Vacuum Fluorescent Drive)
-15 Volts (Standard)


PPS-4/1 MM78 Pin Configuration

## FEATURES

- 2048 8-bit bytes of program memory and 1284 -bit data words
- Clocked simultaneous serial input/output capability
- Externally controlled serial input/output capability
- Two interrupt request input lines
- TTL and CMOS compatible
- Arithmetic logic دınit and six working registers
- Two-level subroutine nesting
- 31 input/output ports
- Easy circuit level testing by user
- Large instruction set - over 60 instructions
- Multifunction instructions increase throughput
- Single power supply operation ( -15 volts $\pm 5 \%$ )
- Low power ( 75 milliwatts typical, 125 milliwatts max)
- Powerful development aids:
- SYSTEM 65 with built-in mini-floppy disks and PPS-4/1 Personality subsystem
- XPO-1 Evaluation Microcomputer Module
- Development Circuit (P/N A7899) provides address and data lines so that Program Memory can be in external PROM or RAM for emulation purposes
- Scheduled and Special Training Courses
- International Applications Engineering Support


## FUNCTIONAL DESCRIPTION

## PROGRAM COUNTER (P), SA REGISTER, AND SB REGISTER

The Program Counter contains the ROM address of the next program instruction. The address in the $\mathbf{P}$ Register is automatically incremented each cycle time during normal operation to address the next instruction. In addition, instructions are available to alter the address in the $\mathbf{P}$ Register as necessary to fetch an instruction from any address in program memory. After PO reset, the program counter contains address hex 3 CO . This location must contain a NOP instruction.

The SA Register is a "save" register which saves the incremented value of current address in the $P$ Register during subroutine execu 0 tion. This provides a means of returning from a subroutine directly to the next instruction after the subroutine call.

The SB Register provides a second hardware stack register so that two levels of subroutines may be nested in the microcomputer.

## PROGRAM MEMORY - READ ONLY MEMORY (ROM)

The ROM provides 2048 bytes of storage for instructions and constants required to operate the microcomputer. Under control of the Program Counter the ROM wilbread out the addressed instruction which is to be decoded and executed.

## INSTRUCTION DECODE

The Instruction Decode logic circuitry interprets the instructions pulled from ROM to provide control for data transfers, arithmetic operations, other processing functions and input/output operations.

## DATA ADDRESS REGISTER (B)

The Data Address Register is 7 bits in length and is made up of two segments, B Upper (BU) and B Lower (BL). Data locations in RAM are addressed by all 7 bits and the discrete input/output ports are addressed by the 4 bits in BL when the value in $B U$ is between 0 and 3 .

A number of multifunction instructions simultaneously modify B Upper and cause B Lower to be automatically incremented or decremented and tested for overflow or underflow.

## ACCUMULATOR AND ARITHMETIC LOGIC UNIT (A, ALU, AND C)

The Primary working register in the MM78 is the Accumulator (A). It is the Accumulator which ties with the Arithmetic Logic Unit (ALU) and the Carry flip-flop (C) to perform binary arithmetic. By means of software routines, decimal arithmetic can be performed. Constants may be loaded into the Accumulator from the read only memory or variable data may be loaded from, or exchanged with the random access memory (RAM) under control of the Data Address Register ( $B$ ). The Accumulator is also the primary path for 4 -bit parallel or serial input or output data.

## A BUFFER

The contents of the Accumulator may be output for control, display, or data transfer functions through the A Buffer. The A Buffer holds the data for output until new data is received from the Accumulator or until the power is turned off.

## XBUFFER

The $X$ Buffer comprises four latches which will output the last bit pattern loaded until either a new Output $X$ Register command is executed or power is turned off.

## X REGISTER

The $X$ Register is an auxiliary register which may be used as temporary storage for 4 bits of data without reference to data memory. The $X$ Register is also used as a data path to the $X$ Buffer output register and from receiver inputs.

## CHANNEL 1 INPUT PORTS (PII through PI4)

The parallel input port P11 through P14 will be added to the contents of the Accumulator upon command. The receivers are TTL compatible and are synchronized (phase 1 time) so that asynchronous input signals may be used.

## CHANNEL 2 INPUT PORTS (PI5 through PI8)

The inverted state of the inputs at parallel input ports P15 thru PI8 will be loaded into the Accumulator upon command. The receivers are TTL compatible and are synchronized (phase 3 time) so that asynchronous input signals may be used.

## CHANNEL A I/O PORTS (R101 through RI04)

The contents of the Accumulator may be output for control or data transfer purposes through the A Buffer. The A Buffer will hold the data output until new data is output or power is turned off.

## CHANNEL X I/O PORTS (R105 through R108)

The four parallel input/output ports of Channel $X$ function as described in $X$ Buffer and $\times$ Register paragraphs.

## CONDITIONAL INTERRUPTS (INTO and INT1)

The conditional interrupts INTO and INT1 may be used to detect external signals and set internal control flip-flops. The receivers are TTL compatible and synchronized with INTO sampled at phase 3 and INT1 sampled at phase 1.

## DISCRETE INPUT/OUTPUT PORTS (DI/O0 through DI/O9)

There are ten discrete input or output lines each of which can be controlled individually under program control. The receivers are fully synchronized so that asynchronous input signals may be used.

CLOCK CONTROL (VC, CLKIN, EXCLK, AND OSCILLATOR)
The internal Oscillator and Clock circuit generates a four Phase A and $\bar{B}$ clock signal used for all internal logic functions. The $A$ and $\bar{B}$ terms are also brought out so external logic can be synch. ronized. The clock frequency is a nominal $90 \mathrm{kHz} \pm 40 \%$. When precise timing is required, a reference frequency may be input at CLKIN.

## DATA MEMORY (RAM)

The Random Access Memory (RAM) used for data memory contains 1284 -bit characters. Data memory can be used to buffer input or output values, hold intermediate results, or be used as a register for timers, counters, comparators, etc., when the MM78 is used as a universal logic element.

S REGISTER - SERIAL INPUT/OUTPUT - SHIFT COUNTER
The $S$ Register is a 4 -bit serial-in/serial-out, parallel exchange, register which is used as either an auxiliary storage register or buffer for the simultaneous serial input/output functions. The shift rate can be controlled either internally or externally.

## PPS-4/1 MM78 INSTRUCTION SET

| RAM Addressing Instructions |  |
| :--- | :--- |
| XAB | Exchange A with BL |
| LBA | Load BL from A |
| LB | Load BL, BU $\rightarrow$ O |
| EOB | Exclusive OR BU |
| LBL | Load B Long |
| INCB | Increment B |
| DECB | Decrement B |
| SAG | Special Address Generation |
| Bit Manipulation Instructions |  |
| SB | Set Bit |
| RB | Reset Bit |
| SKBF | Skip on Bit Faise |
| Register to Register Instructions |  |
| LXA | Load X from A |
| XAS | Exchange A and S |
| XAX | Exchange A and X |
| Arithmetic Instructions |  |
| A | Add Memory to A |
| AC | Add Memory with Carry to A |
| ACSK | Add Memory with Carry to A and Skip on Carry-out |
| DC | Decimal Correction |
| COM | Complement A |
| RC | Reset Carry |
| SC | Set Carry |
| SKNC | Skip on No Carry |
| LAI | Load A with Immediate Field |
| AISK | Add Immediate and Skip on No Carry-out |
| ROM Addressing Instructions |  |
| RT | Return from Subroutine |
| RTSK | Return and Skip |
| T | Transfer on Page |
| NOP | No Operation |
| TL | Transfer Long |
| TLB | Transfer Long Banked |
| TM | Transfer and Mark |
| TML | Transfer and Mark Long |
| TMLB | Transfer and Mark Long Banked |
|  |  |


| Logical Comparison Instructions |  |
| :---: | :---: |
| SKMEA | Skip If Memory Equals A |
| SKBEI | Skip if BL Equals Immediste Fiald |
| SKAEI | Skip if A Equals Immediate Fiold |
| TAB | Table Look Up |
| Input/Output Instructions |  |
| SOS | Set Output Selected |
| ROS | Reset Output Selected |
| SKISL | Skip on Input Selected Low |
| IX | Input $X$ from RIO 5 -8 |
| OX | Output $X$ to RIO 5.8 |
| IOA | Input A Receivers to A and output A to R1O 1-4 |
| 105 | Serial Input/Output |
| I 1SK | Input Channel 1. Add to A, Skip If No Carry |
| 12C | Input Channel 2 and Complement |
| INT1L | Skip If INT1 Input is Low |
| INTOH | Skip if INTO Input is High |
| Conditional Transfer Instructions |  |
| TC | Transfer on Carry Set |
| TNC | Transfer on No Carry Set |
| TLC | Transfer Long on Carry Set |
| TLNC | Transfer Long on No Carry Set |
| TBF | Transfer on Bit in Memory False |
| TBT | Transfer on Bit in Memory True |
| TLBF | Transfer Long on Bit in Memory False |
| TLBT | Transfer Long on Bit in Memory True |
| TE | Transfer on $A=$ Memory |
| TNE | Transfer on A $\neq$ Memory |
| TLE | Transfer Long on $A=$ Memory |
| TLNE | Transfer Long on A Memory |
| TIH | Transfer if Input High |
| TIL | Transfer if Input Low |
| TLIH | Transfer Long if Input High |
| TLIL | Transfer Long if Input Low |
| Register Memory Instructions |  |
| $L$ | Load A from Memory |
| $\times$ | Exchange $A$ and Memory |
| XDSK | Exchange $A$ with Memory. Decrement BL and Skip if BL Counts to 15 |
| XNSK | Exchange $A$ with Memory. Increment BL and Skip if BL Counts to 0 |



## SPECFFICATIONS

## OPERATING CHARACTERISTICS

Supply Voltag
$V_{D D}=-15$ Volts $\pm 5 \%$
(Logic " 1 " = most negative voltage $V_{\text {IL }}$ and $V_{O L}$.)
$\mathrm{V}_{\mathrm{SS}}=0 \mathrm{Volts}$ (Gnd)
(Logic " 0 " = most positive voltage $\mathrm{V}_{\mathrm{IH}}$ and $\mathrm{V}_{\mathrm{OH}}$.)
System Operating Frequencies:
$90 \mathrm{kHz} \pm 40 \%$ with external resistor
Device Power Consumption:
75 mw , typical
Input Capacitance
<5 pf
Input Leakage:
$<10 \mu$ а

Open Drain Driver Leakage (R OFF): $<10 \mu$ at -30 Volts
Operating Ambient Temperature ( $T_{A}$ ) $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (Commercial) $0^{\circ} \mathrm{C}$ to $50^{\circ} \mathrm{C}$ (Consumer)
Storage Temperature:
$-55^{\circ} \mathrm{C}$ to $120^{\circ} \mathrm{C}$

ABSOLUTE MAXIMUM VOLTAGE RATINGS
(with respect to VSS)
Maximum negative voltage on any.pin $\mathbf{- 3 0}$ Volts Maximum positive voltage on any pin +0.3 Volt


## PARALLEL PROCESSING SYSTEM (PPS) DATA SHEET

## PPS-4/1 One-Chip Microcomputer Family

## MM76EL

low-voltage, low power one-chip microcomputer system

## SUMMARY

The Rockwell MM76EL microcomputer is a complete 4-bit paraltel processing system. The MM76EL is a low voltage $\mathbf{( 6 . 5}$ to 11 volt range), very low power ( 15 milliwatts typical) version of the well known PPS-4/1 one-chip microcomputer. The MM76EL is especially desirable where low-cost battery operation as the primary or backup power source is required, or where power consumption or heat dissipation is a consideration, or where portability is required. The MM76EL is distinguished from competitive microprocessors by superior I/O capability, and by other functional features identified on this page.

On a single LSI chip, the MM76EL provides a complete system consisting of a versatile Central Processing Unit (CPU), Instruction Decode, one Program Save Register, Program Memory (ROM), Data Memory (RAM), Program Counter (P), Data Address Register (B), 10 I/O discrete Drivers/Receivers, two 4-bit parallel I/O channels, two 4 -bit parallel input channels, a Serial $/ / O$ port, Interrupt and Control logic, and a self-contained four-phase Clock Generator circuit.

In addition to stand-alone applications, the MM76EL can be directly included in other multi-chip systems as a dedicated controller or in other functions. Also, two or more MM76EL microcomputers can be directly combined to perform parallel processing. or control operations. In the design of families of end-products, a total range of features can be designed so that increasingly higher levels of performance can be produced by low-cost wiring changes and chip additions, minimizing design costs and production inventories.

The MM76EL may be ordered with combinations of the following features (not every combination is available).

Operating Temperature
$0^{\circ} \mathrm{C}$ to $+50^{\circ} \mathrm{C}$ (Consumer)
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Commercial)
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Industrial)
Maximum Negative Voltage
-30 Volts (Vacuum Fluorescent Drive)
-11 Volts (Standard)
Nominal Internal Clock Frequency $100 \mathrm{kHz}( \pm 30 \%)$ with VC to VDD

## ELECTRICAL FEATURES

- Battery Compatible (-6.5 to -11.0 volt operation)
- Low Power - 15 milliwatts nominal @ -8.5 volts
- 4 Clock Modes including external crystal
- Low Impedance Drivers

DI/O - less than 100 ohm @ 10 ma
RIO - less than $250 \mathrm{ohm} @ 6 \mathrm{ma}$

- Mask Programmed Pull-down Resistors on Outputs
- Mask Programmed Enhancement FET Pull-downs on Inputs


MM76EL Pin Configuration

## FUNCTIONAL FEATURES

- Standard 40 -pin Dual-In-Line (DIP) package
- 1024 8-bit bytes of program memory
- 484 -bit words ( 192 bits) of data memory
- Clocked simultaneous serial input/output capability
- Externally controlled serial input/output capability
- Two interrupt request input lines
- TTL and CMOS compatible
- 31 input/output ports
- Large instruction set - over 60 instructions
- Multifunction instructions increase throughput
- Single power supply operation ( -8.5 volts $-2.5,+2.0$ volts)
- Low power (15 milliwatts typical)
- Powerful development aids:
- SYSTEM 65 with built-in mini-floppy disks and PPS-4/1 Personality subsystem
- XPO-1 Evaluation Microcomputer Module
- Development Circuit (P/N B7699) provides address and data lines so that Program Memory can be in external PROM for emulation purposes
- Scheduled and Special Training Courses
- International Applications Engineering Support


## FUNCTIONAL DESCRIPTION

## PROGRAM COUNTER (P) AND SA REGISTER

The Program Counter contains the ROM address of the next program instruction. The address in the $\mathbf{P}$ Register is automatically incremented each cycle time during normal operation to address the next instruction. In addition, instructions are available to alter the address in the $P$ Register as necessary to fetch an instruction from any address in program memory. After PO reset, the program counter contains address hex 3 CO . This location must contain a NOP instruction.
The SA Register is a "save" register which saves the incremented value of current address in the $\mathbf{P}$ Register during subroutine execution. This provides a means of returning from a subroutine directly to the next instruction after the subroutine call.

## PROGRAM MEMORY - READ ONLY MEMORY (ROM)

The ROM provides 1024 bytes of storage for instructions and constants required to operate the microcomputer. Under control of the Program Counter the ROM will read out the addressed instruction which is to be decoded and executed.

## INSTRUCTION DECODE

The Instruction Decode logic circuitry interprets the instructions pulled from ROM to provide control for data transfers, arithmetic operations, other processing functions and input/output operations.

## DATA ADDRESS REGISTER (B)

The Data Address Register is 6 bits in length and is made up of two segments, B Upper (BU) and B Lower (BL). Data locations in RAM and the discrete input/output ports are addressed by the 4 bits in BL and the 2 bits in BU.
A number of multifunction instructions simultaneously modify B Upper and cause B Lower to be automatically incremented or decremented and tested for overflow or underflow.

## ACCUMULATOR AND ARITHMETIC LOGIC UNIT

(A, ALU, and C)
The primary working register in the MM76EL is the Accumulator (A). It is the Accumulator which ties with the Arithmetic Logic Unit (ALU) and the Carry flip.flop (C) to perform either binary or decimal arithmetic. Constants may be loaded into the Accumulator from the read only memory or variable data may be loaded from, or exchanged with the random access memory (RAM) under control of the Data Address Register (B). The Accumulator is also the primary path for 4-bit parallel or serial input or output data.

## DATA MEMORY (RAM)

The Random Access Memory (RAM) used for data memory contains 484 -bit words. Data memory can be used to buffer input or output values, hold intermediate results, or as a register for timers. counters, comparators, etc.

## CLOCK CONTROL (VC, XTLIN, XTLOUT, A, AND BP)

The internal Oscillator and Clock Circuit generates a four-phase A and BP clock signal used for all internal logic functions. The A and BP clock terms are also brought out so external logic can be synchronized. The clock for the MM76EL can be selected to operate in one of four modes as shown by the table below. These options are selected by control voltages applied to the VC and XTLIN pins.

## A BUFFER

The contents of the Accumulator or 4 of the bits from the $16 \times 8$ Decode Matrix may be output for control, display, or data transfer functions through the A Buffer. The A Buffer holds the data for output until new data is received from the Accumulator or the Decode Matrix, or until the power is turned off.

## B BUFFER

The 4-bit B Buffer functions the same as the A Buffer except it outputs the other 4 bits of the $16 \times 8$ Decode Matrix. The $A$ and $B$ Buffers combined provide the full eight outputs for the Decode Matrix.

## CHANNEL 1 INPUT PORTS (PI1 through PI4)

The parallel input port PI1 through P14 will be loaded into the contents of the Accumulator upon command. The receivers are TTL compatible and are synchronized (phase 1 time) so that asynchronous input signals may be used.

## CHANNEL 2 INPUT PORTS (PI5 through PI8)

The inverted state of the inputs at parallel input ports PI5 thru PI8 will be loaded into the Accumulator upon command. The receivers are TTL compatible and are synchronized (phase 3 time) so that asynchronous input signals may be used.

## CHANNEL A I/O PORTS (RIO1 through RIO4)

The four parallel input/output ports RIO1 thru RIO4 provide a masked input capability and an output from either the $16 \times 8$ Decode Matrix or directly from the accumulator.

CHANNEL B I/O PORTS (RIO5 through RIOB)
The foir parallel input/output ports of Channel B function the same as the four ports of Channel A. Together, they provide an 8 -bit parallel output.

## CONDITIONAL INTERRUPTS (INTO and INT1)

The conditional interrupts INTO and INT1 may be used to detect external signals and set internal control flip-flops. The receivers are TTL compatible and synchronized.

## DISCRETE INPUT/OUTPUT PORTS (DI/O0 through DI/O9)

There are ten discrete input or output lines each of which can be controlled individually under program control. The receivers are fully synchronized so that asynchronous input signals may be used.

## $16 \times 8$ DECODE MATRIX

The Decode Matrix provides a means of decoding and contents of the Accumulator to provide an 8 -bit output suitable for driving various displays or other external devices. The user may define any code desired. The Development Circuit version of the MM76EL has a BCD to seven segment conversion provided. Accumulator contents of $O$ thru $F$ produce 0 thru $9, A,-, P, d, E$ and blank respectively. The carry flip-flop controls one independent output line.

## S REGISTER - SERIAL INPUT/OUTPUT - SHIFT COUNTER

The S register is a 4-bit serial-in/serial-out, parallel exchange, register which is used as either an auxiliary storage register or buffer for the simultaneous serial input/output functions. The shift rate can be controlled either internally or externally.

| Mode | $v_{c}$ | Pins |  |  |  | Frequency |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | XTLIN | XTLOUT | A 1/O | BP 1/O |  |
| INTERNAL | ${ }^{*} \mathrm{~V}_{\mathrm{C}}$ | vss | - | OUT | OUT | $100 \mathrm{kHz} \pm 30 \%$ @ 8.5 V |
| EXTERNAL | GRD | ClOCK |  | OUT | OUT | $400-800 \mathrm{kHz} @ 8.0 \mathrm{~V}$ |
| CRYSTAL** | GRD | XTAL | XTAL | OUT | OUT | $\approx 800 \mathrm{kHz}$ @ 8.0V |
| Slave | $V_{\text {DD }}$ | $V_{\text {DD }}$ | - | IN | IN | $50 \mathrm{kHz}-100 \mathrm{kHz} @ 8.5 \mathrm{~V}$ |
| n be adjusted ggest Murata | freque <br> ber C | ormally se <br> 4 with 2-1 | unt capac |  |  |  |

PPS-4/1 MM76EL INSTRUCTION SET

| RAM Addressing Instructions |  |
| :---: | :---: |
| XAB | Exchange $A$ with BL |
| LBA | Load BL from A |
| LB | Load BU=0, BL=Immediate |
| EOB | Exclusive OR BU |
| LBL | Load 3 Long |
| INCB | Increment B |
| DECB | Decrement $B$ |
| Bit Manipulation Instructions |  |
| SB | Set Bit |
| R8 | Reset Bit |
| SKBF | Skip on Bit False |
| Register to Register Instructions |  |
| $\times$ AS | Exchange $A$ and $S$ |
| LSA | Load S from A |
| Register Memory Instructions |  |
| L | Load A from Memory |
| $\times$ | Exchange $A$ and Memory |
| XDSK | Exchange A with Memory. Decrement BL and Skip if BL Counts to 15 |
| XNSK | Exchange $A$ with Memory. Increment BL and Skip if |
| Arithmetic Instructions |  |
| A | Add Memory to A |
| AC | Add Memorv with Carry to A |
| ACSK | Add Memory with Carry to A and Skip on No Carry-out |
| ASK | Add Memory to A and Skip if No Carry Overflow |
| DC | Decimal Correction |
| COM | Complement A |
| RC | Reset Carry |
| SC | Set Carry |
| SKNC | Skip on No Carry |
| LAI | Load A with Immediate Field |
| AISK | Add Immediate and Skip on No Carry-out |
| Logical Comparison Instructions |  |
| SKMEA | Skip if Mermory Equals A |
| SKBEI | Skip if BL Equals immediate Field |
| SKAEI | Skip if A Equals Immediate Field |


| Input/Output Instructions |  |
| :---: | :---: |
| SOS | Set Output Selected |
| ROS | Reset Output Selected |
| SKISL | Skip on Input Selected L ow |
| IBM | Input Channel 8 ANDed with A |
| O8 | Output from A to Channel B |
| IAM | Input Channel A ANDed with A |
| OA | Output from A to Channel A |
| 105 | Serial Input/Output |
| 11 | Input Channel 1 |
| 12 C | Input Channel 2 and Complement |
| INT1H | Skip if INT 1 Input is Low |
| DIN1 | Skip if INT 1 Flip-flop is Reset |
| INTOL | Skip if INTO Input is High |
| DINO | Skip if INTO Flip-flop is Reset |
| SEG 1 | Decoder Matrix Output to Channel A |
| SEG2 | Decoder Matrix Output to Channel B |
| Conditional Transfer Instructions |  |
| TC | Transfer on Carry Set |
| TNC | Transfer on No Carry Set |
| TLC | Transfer Long on Carry Set |
| TLNC | Transfer Long on No Carry Set |
| TBF | Transfer on Bit in Memory False |
| TBT | Transfer on Bit in Memory True |
| TLBF | Transfer Long on Bit in Memory False |
| TLBT | Transfer Long on Bit in Memory True |
| TE* | Transfer on $A=$ Mernory |
| TNE | Transfer on $A \neq$ Mernory |
| TLE | Transfer Long on $A=$ Memory |
| TLNE | Transfer Long on $A \neq$ Memory |
| TIH | Transfer if Input High |
| TIL | Transfer if input Low |
| TLIH | Transfer Long if Input High |
| TLIL | Transfer Long if Input Low |
| ROM Addressing Instructions |  |
| RT | Return from Subroutine |
| RTSK | Return and Skip |
| T | Transfer on Page |
| NOP | No Operation |
| TL | Transfer Long |
| TM | Transfer and Mark |
| TML | Transfer and Mark Long |



## SPECIFICATIONS

## OPERATING CHARACTERISTICS

Supply Voltage:
$V_{D D}=-8.5$ Volts, $-1.5,+2.0$ Volts (MM76EL-1)
$V_{D D}=-8.5$ Volts, $-2.5,+2.0$ Volts (MM76EL)
(Logic " 1 " = most negative voltage $V_{\text {IL }}$ and $V_{O L}$.)
$\mathrm{V}_{\mathrm{SS}}=0 \mathrm{Volts}$ (Gnd)
(Logic " 0 " = most positive voltage $V_{\text {IH }}$ and $V_{\mathrm{OH}}$.) System Operating Frequencies:
(1) Internal: 100 kHz Nominal at $V_{D D}=-8.5 \cdot \mathrm{~V}$
(2) External 800 kHz Crystal: 100 kHz

Device Power Consumption: 15 mw , typical

Input Capacitance: < 5 pf
Input Leakage: <10 $\mu \mathrm{a}$
Open Drain Driver Leakage (R OFF): $<10 \mu$ a at $\mathbf{- 3 0}$ Volts Operating Ambient Temperature ( $T_{A}$ ):
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Commercial): MM76EL
$0^{\circ} \mathrm{C}$ to $+50^{\circ} \mathrm{C}$ (Consumer): MM76EL-1
$-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ (Industrial): MM76EL-2
Storage Temperature: $-55^{\circ} \mathrm{C}$ to $125^{\circ} \mathrm{C}$
ABSOLUTE MAXIMUM VOLTAGE RATINGS (with respect to VSS)

Maximum negative voltage on any pin -30 Volts Maximum positive voltage on any pin +0.3 Volts

TEST CONDITIONS: $V_{D D}=-8.5 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=0.70^{\circ} \mathrm{C}$


NOTES:

## MASK PROGRAMMED PULL-DOWN RESISTORS ON OUTPUTS

Resistor pull-downs are available as an option on all RIO, CLOCK, DATAO and DI/O outputs. These pull-downs are connected to VDD. The following values $\pm 50 \%$ are available: $5 \mathrm{~K}, 10 \mathrm{~K}, 25 \mathrm{~K}$, or Open Circuit. The 5 K ohm option is not available on the clock or DATAO outputs.

## PULL-DOWNS ON INPUTS

MOS FET pull-downs are also available as an option on the PI, INT, and DATAI inputs. The output current is $50 \mu \mathrm{a} \pm 35 \mu$ a with the input grounded and $V_{D D}$ at -8.5 volts.

## PART NUMBER <br> A78XX

## PARALLEL PROCESSING SYSTEM (PPS) DATA SHEET

PPS-4/1 One-Chip Microcomputer Family

## MM78

## one-chip microcomputer system

## SUMMARY

The Rockwell MM78 microcomputer is a complete, 4-bit parallel processing system. Its large instruction set is augmented by powerful multi-function instructions. $31 \mathrm{I} / \mathrm{O}$ ports further identify the power of this system. Serial I/O capability, which can be clocked simultaneously or externally controlled, extend their power.

On a single LSI chip, the MM78 provides a complete 4-bit paralle! processing system - Central. Processing Unit (CPU), Program Memory (ROM), Data Memory (RAM), Program Counter (P), Instruction Decode, two Program Save registers, Data Address register (B), 10 I/O discrete orivers/receivers, two 4-bit parallel I/O channels, two 4-bit paraltel input channels, a serial input/ output port, interrupt and control logic, and a self-contained four-phase clock generator circuit.

In addition to stand-alona system applications, this microcomputer can be directly interfaced with other multi-chip systems as dedicated slave controllers or for other purposes. Also, two or more MM78 systems can be directly combined to perform parallel processing or control operations.

The MM78 may be ordered with combinations of the following features (not every combination is available).

## Operating Temperature

$0^{\circ} \mathrm{C}$ to $+50^{\circ} \mathrm{C} \quad$ (Consumer)
$0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (Commercial)
Maximum Negative Voltage
-30 Volts (Vacuum Fluorescent Drive)
-15 Volts (Standard)


PPS-4/1 MM78 Pin Configuration

## FEATURES

- 2048 8-bit bytes of program memory and $\mathbf{1 2 8} \mathbf{4}$-bit data words
- Clocked simultaneous serial input/output capability
- Externally controlled serial input/output capability
- Two interrupt request input lines
- TTL and CMOS compatible
- Arithmetic logic unit and six working registers
- Two-level subroutine nesting
- 31 input/output ports
- Easy circuit level testing by user
- Large instruction set - over 60 instructions
- Multifunction instructions increase throughput
- Single power supply operation ( -15 volts $\pm 5 \%$ )
- Low power ( 75 milliwatts typical, 125 milliwatts max)
- Powerful development aids:
- SYSTEM 65 with built-in mini-floppy disks and PPS-4/1 Personality subsystem
- XPO-1 Evaluation Microcomputer Module
- Development Circuit (P/N A7899) provides address and data lines so that Program Memory can be in external PROM or RAM for emulation purposes
- Scheduled and Special Training Courses
- International Applications Engineering Support


## FUNCTIONAL DESCRIPTION

## PROGRAM COUNTER (P), SA REGISTER, AND SB REGISTER

The Program Counter contains the ROM address of the next program instruction. The address in the $\mathbf{P}$ Register is automatically incremented each cycle time during normal operation to address the next instruction. In addition, instructions are available to alter the address in the $\mathbf{P}$ Register as necessary to fetch an instruction from any address in program memory. After PO reset, the program counter contains address hex 3 CO . This location must contain a NOP instruction.

The SA Register is a "save" register which saves the incremented value of current address in the $P$ Register during subroutine execu ${ }^{\circ}$ tion. This provides a means of returning from a subroutine directly to the next instruction after the subroutine call.

The SB Register provides a second hardware stack register so that two levels of subroutines may be nested in the microcomputer.

## PROGRAM MEMORY - READ ONLY MEMORY (ROM)

The ROM provides 2048 bytes of storage for instructions and constants required to operate the microcomputer. Under control of the Program Counter the ROM wilbread out the addressed instruction which is to be decoded and executed.

## INSTRUCTION DECODE

The Instruction Decode logic circuitry interprets the instructions pulled from ROM to provide control for data transfers, arithmetic operations, other processing functions and input/output operations.

## DATA ADDRESS REGISTER (B)

The Data Address Register is 7 bits in length and is made up of two segments, B Upper (BU) and B Lower (BL). Data locations in RAM are addressed by all 7 bits and the discrete input/output ports are addressed by the 4 bits in BL when the value in BU is between 0 and 3 .

A number of multifunction instructions simultaneously modify B Upper and cause B Lower to be automatically incremented or decremented and tested for overflow or underflow.

## ACCUMULATOR AND ARITHMETIC LOGIC UNIT (A, ALU, AND C)

The Primary working register in the MM78 is the Accumulator (A). It is the Accumulator which ties with the Arithmetic Logic Unit (ALU) and the Carry flip-flop (C) to perform binary arithmetic. By means of software routines, decimal arithmetic can be performed. Constants may be loaded into the Accumulator from the read only memory or variable data may be loaded from, or exchanged with the random access memory (RAM) under control of the Data Address Register (B). The Accumulator is also the primary path for 4 -bit parallel or serial input or output data.

## A BUFFER

The contents of the Accumulator may be output for control, dis play, or data transfer functions through the A Buffer. The A Buffer holds the data for output until new data is received from the Accumulator or until the power is turned off.

## X BUFFER

The $X$ Buffer comprises four latches which will output the last bit pattern loaded until either a new Output $X$ Register command is executed or power is turned off.

## X REGISTER

The $X$ Register is an auxiliary register which may be used as temporary storage for 4 bits of data without reference to data memory. The $X$ Register is also used as a data path to the $X$ Buffer output register and from receiver inputs.

## CHANNEL 1 INPUT PORTS (PI1 through P14)

The parallel input port P11 through P14 will be added to the contents of the Accumulator upon command. The receivers are TTL compatible and are synchronized (phase 1 time) so that asynchronous input signals may be used.

## CHANNEL 2 INPUT PORTS (PI5 through PI8)

The inverted state of the inputs at parallel input ports PI5 thru PI8 will be loaded into the Accumulator upon command. The receivers are TTL compatible and are synchronized (phase 3 time) so that asynchronous input signals may be used.

## CHANNEL A I/O PORTS (RIO1 through RIO4)

The contents of the Accumulator may be output for control or data transfer purposes through the A Buffer. The A Buffer will hold the data output until new data is output or power is turned off.

## CHANNEL X I/O PORTS (R105 through R108)

The four parallel input/output ports of Channel $X$ function as described in $X$ Buffer and $X$ Register paragraphs.

## CONDITIONAL INTERRUPTS (INTO and INT1)

The conditional interrupts INTO and INT1 may be used to detect external signals and set internal control flip-flops. The receivers are TTL compatible and synchronized with INTO sampled at phase 3 and INT1 sampled at phase 1.

## DISCRETE INPUT/OUTPUT PORTS (DI/O0 through DI/O9)

There are ten discrete input or output lines each of which can be controlled individually under program control. The receivers are fully synchronized so that asynchronous input signals may be used.

## CLOCK CONTROL (VC, CLKIN, EXCLK, AND OSCILLATOR)

The internal Oscillator and Clock circuit generates a four Phase $A$ and $\bar{B}$ clock signal used for all internal logic functions. The $A$ and $\bar{B}$ terms are also brought out so external logic can be synch-: ronized. The clock frequency is a nominal $90 \mathrm{kHz} \pm 40 \%$. When precise timing is required, a reference frequency may be input at CLKIN.

## DATA MEMORY (RAM)

The Random Access Memory (RAM) used for data memory contains 128 4-bit characters. Data memory can be used to buffer input or output values, hold intermediate results, or be used as a register for timers, counters, comparators, etc., when the MM78 is used as a universal logic element.

S REGISTER - SERIAL INPUT/OUTPUT - SHIFT COUNTER
The S Register is a 4-bit serial-in/serial-out, parallel exchange, register which is used as either an auxiliary storage register or buffer for the simultaneous serial input/output functions. The shift rate can be controlled either internally or externally.

PPS-4/1 MM78 INSTRUCTION SET

| RAM Addressing Instructions |  |
| :--- | :--- |
| XAB | Exchange A with BL |
| LBA | Load BL from A |
| LB | Load BL, BU $\rightarrow$ O |
| EOB | Exclusive OF BU |
| LBL | Load B Long |
| INCB | Increment B |
| DECB | Decrement B |
| SAG | Special Address Generation |
| Bit Manipulation Instructions |  |
| SB | Set Bit |
| RB | Reset Bit |
| SKBF | Skip on Bit False |
| Register to Register Instructions |  |
| LXA | Load X from A |
| XAS | Exchange A and S |
| XAX | Exchange A and X |
| Arithmetic Instructions |  |
| A | AddMemory to A |
| AC | Add Memory with Carry to A |
| ACSK | Add Memory with Carry to A and Skip on Carry-Out |
| DC | Decimal Correction |
| COM | Complement A |
| RC | Reset Carry |
| SC | Set Carry |
| SKNC | Skip on No Carry |
| LAI | Load A with Immediate Field |
| AISK | Add Immediate and Skip on No Carry-out |
| ROM Addressing Instructions |  |
| RT | Return from Subroutine |
| RTSK | Return and Skip |
| T | Transfer on Page |
| NOP | No Operation |
| TL | Transfer Long |
| TLB | Transfer Long Banked |
| TM | Transfer and Mark |
| TML | Transfer and Mark Long |
| TMLB | Transfer and Mark Long Banked |
|  |  |


| Logical Comparison Instructions |  |
| :---: | :---: |
| SKMEA | Skip If Memory Equals A |
| SKBEI | Skjp if BL Equals Immediate Field |
| SKAEI | Skip if A Equals Immediate Fiold |
| TAB | Table Look Up |
| Input/Output Instructions |  |
| SOS | Set Output Selected |
| ROS | Reset Output Selected |
| SKISL. | Skip on Input Selected Low |
| $1 \times$ | Input $X$ from R1O 5-8 |
| OX | Output $X$ to RIO 5.8 |
| IOA | Input A Receivers to A and output A to R10 1.4 |
| IOS | Serial Input/Output |
| I 1SK | Input Channel 1. Add to A, Skip if No Carry |
| 12C | Input Channel 2 and Complement |
| INT1L | Skip if INT 1 Input is Low |
| INTOH | Skip if INTO Input is High |
| Conditional Transfer Instructions |  |
| TC | Transfer on Carry Set |
| TNC | Transfer on No Carry Set |
| TLC | Transfer Long on Carry Set |
| TLNC | Transfer Long on No Carry Set |
| TBF | Transfer on Bit In Memory False |
| TBT | Transfer on Bit in Memory True |
| TLBF | Transfer Long on Bit in Memory False |
| TLBT | Transfer Long on Bit in Memory True |
| TE | Transfer on $\mathrm{A}=$ Memory |
| TNE | Transfer on A $\neq$ Mamory |
| TLE | Transfer Long on $A=$ Mernory |
| TLNE | Trensfer Long on A * Memory |
| TIH | Transfer if Input High |
| TIL | Transfer if input Low |
| TLIH | Transfer Long if Input High |
| TLIL | Transfer Long if Input Low |
| Register Memory Instructions |  |
| $\frac{L}{\square}$ | Load A from Memory |
| $\times$ | Exchange $A$ and Memory |
| XDSK | Exchange $A$ with Memory. Decrement BL and Skip if |
|  | BL Counts to 15 ( |
| XNSK | Exchange A with Memory. Increment BL and Skip if BL Counts to 0 |



## SPECIFICATIONS

## OPERATING CHARACTERISTICS

## Supply Voltage

$V_{D D}=-15$ Volts $\pm 5 \%$
(Logic " 1 " = most negative voltage $V_{\text {IL }}$ and $V_{O L}$.)
$\mathrm{V}_{\mathrm{SS}}=0 \mathrm{Volts}$ (Gnd)
(Logic " $O$ " = most positive voltage $V_{I H}$ and $V_{O H}$.)
System Operating Frequencies:
$90 \mathrm{kHz} \pm 40 \%$ with external resistor
Device Power Consumption:
75 mw , typical
Input Capacitance:
< 5 pf
Input Leakage:
$<10 \mu \mathrm{a}$

Open Drain Driver Leakage (R OFF) $<10 \mu$ at -30 Volts
Operating Ambient Temperature ( $T_{A}$ ): $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (Commercial) $0^{\circ} \mathrm{C}$ to $50^{\circ} \mathrm{C}$ (Consumer)
Storage Temperature:
$-55^{\circ} \mathrm{C}$ to $120^{\circ} \mathrm{C}$

ABSOLUTE MAXIMUM VOLTAGE RATINGS
(with respect to VSS)
Maximum negative voltage on any pin -30 Volts Maximum positive voltage on any pin +0.3 Volt

| FUNCTION | SYMBOL | LIMITS (VSS - 0 ) |  |  | LIMITS (VSS $=+5 \mathrm{~V}$ ) |  |  | TIMING (SAMPLE/ GOOD) | TEST CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | TYP | max | MIN | TYP | max |  |  |
| Supply Current (Avertige) for VDD | 100 |  | 5 mm | 8 ma |  | 5 ms | 8 me |  |  |
| Discrete 1/O's DI/O O-DI/O 9 | $\begin{aligned} & v_{I H} \\ & v_{I L} \end{aligned}$ | . 1.0 V |  | -4.2V | +4.0V |  | +0.8V | * 3 |  |
|  | RON |  |  | 500 onmt |  |  | 300 ohms | $64^{\circ}$ | 3.0 max max. |
| Channel 1 Input PII.PI4 | $\begin{aligned} & \mathrm{v}_{\mathrm{IH}} \\ & \mathrm{v}_{\mathrm{IL}} \end{aligned}$ | . 1.5 V |  | -4.2V | +3.5V |  | +0.8V | 1 |  |
| Channel 2 Input PI5-PIS | $\begin{aligned} & v_{\mathrm{IH}} \\ & v_{\mathrm{IL}} \end{aligned}$ | -1.5V |  | -4.2V | +3.5V |  | +0.8V | * 3 |  |
| 1/O Chennel A R1/O1-R1/O4 | $\begin{aligned} & v_{I H} \\ & v_{I L} \end{aligned}$ | $\cdot 1.5 \mathrm{~V}$ |  | -4.2V | +3.5V |  | +0.8V | 43 - |  |
|  | RON |  |  | 500 ohms |  |  | 500 ohms | $04 \cdot$ | 3.0 mamax. |
| 1/O Chennel X RI/OS-RI/OS | $\begin{aligned} & v_{I H} \\ & v_{I L} \end{aligned}$ | -1.0V |  | -4.2V | +4.0V |  | -0.8V | Not zync. Must be stable at $\$ 1$ and 2. |  |
|  | RON |  |  | 500 orms |  |  | 500 ohme | \$4* | 3.0 mamax. |
| DATA I | $\begin{aligned} & v_{I H} \\ & v_{I L} \end{aligned}$ | -1.0V |  | -4.2V | $+4.0 \mathrm{~V}$ |  | +0.8V | * 4 |  |
| DATAO | RON |  |  |  |  |  |  | +4** |  |
| INTO | $\begin{aligned} & v_{I H} \\ & v_{\text {IL }} \end{aligned}$ | -1.5V |  | .4.2V | +3.5V |  | *0.8V | 43 |  |
| TNT1 | $\begin{aligned} & v_{1 H} \\ & v_{1 L} \end{aligned}$ | -1.5V |  | 4.2V | +3.5v |  | +0.8V | *1 |  |
| clock A. BP, (8) | $\mathrm{V}_{\mathrm{OH}}$ $V_{\mathrm{OL}}$ | . 8.0 V |  | . 10.0 V | +4.0V |  | -5.0V |  | CL - 50 Pf (max. |
| EXCLK | $\begin{aligned} & v_{I H} \\ & v_{I L} \end{aligned}$ | -9.5V |  | . 7.0 V | +3.5v |  | . 2.0 V | STRAP | F max $=80 \mathrm{kHz}$ |
| CLK IN | $\begin{aligned} & v_{1 H} \\ & v_{1 L} \end{aligned}$ | $\cdot 1.0 \mathrm{~V}$ |  | . 10.0 V | +4.0V |  | -5.0V |  |  |
| Shift Clock Clock | $\begin{aligned} & v_{1 H} \\ & v_{\mathrm{IL}} \end{aligned}$ | -1.0V |  | -4.2V | +4.0V |  | +0.8V | ${ }_{6} 34$ | 20. |
|  | RON |  |  | 500 onmi |  |  | 5000 hms | $64^{\circ}$ | 2.0 mamax. |
| vc..* | $\begin{aligned} & v_{1 H} \\ & v_{1 L} \end{aligned}$ |  |  |  |  |  |  |  | 56K $+5 \times$ |
| PO | $\begin{aligned} & v_{\text {IH }} \\ & v_{\text {IL }} \end{aligned}$ | -2.0V |  | -6.0V | +3.0V |  | -1.0V |  | Special cirevit |
| - State established by $\phi 2$ (minimum impedance during $\phi 4$ ). <br> $\cdots$ Same as above except $\phi 4$ minimum ot $\phi 2$ of next cyele. <br> - $\cdot$ Connect VC to VOD through - $56 \mathrm{~K} \Omega$ resistor for 90 kHz . |  |  |  |  |  |  |  |  |  |

## PARALLEL PROCESSING SYSTEM (PPS) APPLICATION NOTE

## SERIAL COMMUNICATIONS PROTOCOL FOR MULTIPLE PPS-4/1 SYSTEMS

A simple communications protocol can be implemented between two PPS-4/1 microprocessors using only five interface lines. In order to prevent both units from attempting to transmit simultaneously, one processor must be designated as the Master and the other as the Slave. The Moster initictes all communication. The Slave responds to commands and inquiries from the Master.

## communications bus

The Communications Bus consists of the Serial Channel lines - Serial Data Out (DATAO), Serial Data In (DATAI) and CLOCK - and two bidirectional handshake lines (DI/O). One of the handshake lines will be used to transmit the Data Ready control signal (DR), the other will be used to transmit the Xmit Acknowledge control signal (XA). The connection of these lines is shown in the Serial Communication Block Diagram.
The normal (inactive) state of the handshake lines is low (driver off), which results in a "wired-OR" arrangement that allows either processor to "raise" the line by turning on its output driver.

## COMMUNICATIONS PHASES

Communications are normally conducted in two phases. During the Command Transmission Phase, the Master transmits a command or inquiry to the Slave. During the Data Transmission Phase, the Slave responds by transmitting one or more data words. The general sequence of events for each phase is described in the text to follow, and illustrated by the accompanying timing diagram.

## Command Transmission Phase

The sequence is:

1. Both handshake lines are low, indicating a "clear to send" condition.
2. Master transmits the command code to Slave via the Serial Channel. Eight cycles are needed to transmir four bits.
3. Master raises DR
4. Slave senses DR high, saves command in RAM buffer and raises XA.
5. Master senses XA high, and drops DR.
6. Slave senses DR low, and drops XA.
7. Slave decodes command and performs required function.

## Data Transmission Phase

The sequence is:

1. Both handshake lines are low, indicating a "clear to send" condition.
2. Slave transmits data to Master via the Serial Channel. Eight cycles are needed to transmit four bits.
3. Slave raises DR.
4. Master senses DR high, saves data in RAM buffer and raises XA.
5. Slave senses $X A$ high, and drops $D R$.
6. Master senses DR low, and drops XA.
7. Slave senses XA low, and steps 2 through 6 are repeated for the required number of data words, including a four-bit checksum value. In the event of a checksum error, Master will transmit a new command and the entire process will be repeated.


PPS-4/I SERIAL COMMUNICATION BLOCK DIAGRAM

## PARALLEL PROCESSING SYSTEM (PPS) APPLICATION NOTE

## Using PPS-4/1 to Operate a Liquid Crystal Display

## PURPOSE

This application note illustrates the use of a PPS-4/1 one-chip microcomputer to operate a liquid crystal display that is driven by a Hughes HLCD 0438 device. Although an MM78L is used as the microcomputer in the example interface, the material in this note can be easily adapted to the MM77, MM77L or MM78.

## DESCRIPTION

Segment data from the display are loaded into the driver from the MM78L serial output port, as shown in Figure 1. Because the PPS $-4 / 1$ is a PMOS circuit and the HLCD is a CMOS circuit, VSS of the MM78L and VDD of the HLCD are connected to ground, and VDD of the MM78L and the ground pin of the HLCD are connected to -8.5 V . For this example, DIO6 of the MM78L drives the HLCD load line and the HLCD


Figure 1. INTERFACE BLOCK DIAGRAM
internal oscillator is used to generate the $A C$ frequency for the LCD wave forms.

Here is how the display is updated: New segment data are stored in the MM78L RAM. The data are then transferred to the HLCD shift register through the MM78L serial output port. Finally, the HLCD load line is pulsed by DIO6 to transfer the data to the HLCD latches and implement the new display pattern.
Figures 2 and 3 show the flowchart and the PPS-4/1 coding for this procedure.


Figure 2. DRIVER FLOWCHART


Figure 3. DISPLAY DRIVER

MODEMS

## MODEM PRODUCTS DATA SHEET

## R24 2400 BPS INTEGRAL MODEM

## INTRODUCTION

The Rockwell R24 is a high performance synchronous serial 2400 bps DPSK modem. Utilizing extensive MOS/LSI technology, the R24 is implemented in three modular building blocks. It is innovatively designed to enable its economic integration by system designers in a broad range of communication, computer, and control equipment.

Having Bell $201 \mathrm{~B} / \mathrm{C}$ and CCITT V. 26 compatibility, the modular R24 offers the user sufficient flexibility to customize a 2400 bps modem to his specific packaging and functional requirements. With a minimum amount of interface circuitry, the modem can be configured for operation on leased lines or on the general switched network.

## MODULE VERSATILITY

The versatility of the R24 design is achieved by dividing the modem's functions into three modules:

Transmitter - Module T
Receiver - Modules R1, R2
Each module can be plugged into standard connectors or can be wave soldered on one or more printed circuit boards. The pin spacing is on 100 mil centers. Modem modules are functionally independent.

## MODEM OPERATION MODES

In general, the modules can be configured to operate in the following modes:

| Simplex - Transmit only: | Only the transmitter module $(T)$ is used. |
| :--- | :--- |
| Simplex - Receive only: | R1 and R2 modules are used to implement <br> a complete receiver function. |
| Half Duplex (2-Wire): | Requires both transmit and receive func- <br> tions (although not simultaneously), <br> therefore, all three modules are used. |
| Full Duplex (4-Wire): | Requires both transmit and receive func- <br> tions simultaneously, again all three <br> modules are used. |

## FEATURES/BENEFITS

- LSI high density; low power
- 2400/1200 bps modes
- Transmitter-Differential phase modulation
- Receiver-Coherent phase detection
- Bell 201 B/C, CCITT V. 26 compatible
- CCITT A/B encoding options
- Operating modes:

Half duplex ( 2 wire)
Full duplex (4 wire)
Simplex (Transmit or Receive only)

- Outstanding performance over unconditioned lines
- LSTTUCMOS compatible digital interface
- Fixed compromise equalizer
- V. 27 compatible scrambler/descrambler
- Answer-back tone generation
- Clear-to-send delay options
- New sync option provides rapid resynchronization
- Typical power consumption 2 watts
- Total module area 25 sq. in.
- R24 Modem Evaluation Board facilitates evaluation and design-in tasks.



R24 Functional Diagram

TECHNICAL DESCRIPTION
Transmitter carrier frequency $\qquad$ $1800 \mathrm{~Hz} \pm 0.01 \%$

Echo suppression and answer tone frequencies - $2100 \mathrm{~Hz} \pm 0.01 \%$ or 2025 $\mathrm{Hz} \pm 0.01 \%$

Received signal frequency tolerance - The recelver can adapt to received frequency errors up to $\pm 10 \mathrm{~Hz}$ with less than a 0.5 dB degradation in bit error rate.

Data signaling and modulation rate:

1) Normal: Signaling Rate -1200 baud $\pm 0.01 \%$. Data Rate $-2400 \mathrm{bps} \pm 0.01 \%$
2) Fallback: Signaling Rate -1200 baud $\pm 0.01 \%$. Data Rate $-1200 \mathrm{bps} \pm 0.01 \%$.

Transmitted Data Spectrum - The transmitted spectrum's bandwidth extends from 800 Hz to 2800 Hz . Phase distortion characteristics are within the limits specified in CCITT Recommendation V. 26 bis. The out of band signal power limitations meet those specified by Part 68 or Tariff 261 of the FCC's regulations, and typically exceed the requirements of international regulatory bodies as well.

Data Encoding (DPSK) - At 2400 bps, differential four-phase modulation is used. The data stream is transmitted in pairs of consecutive bits (dibits). Each dibit is encoded as a phase change relative to the phase of the preceding signal element.

The R24 implements the phase $A$ and $B$ recommendations of CCITT V.26. The modulation coding in Bell 201 modems is the same as V.26B. Definition of these coding arrangements is shown in the following table:

| 2400 BPS |  |  |
| :---: | :---: | :---: |
| DIBIT | PHASE CHANGE |  |
|  | V.26A | V.26B/Bell 201 |
|  |  | $0^{\circ}$ |
| 01 | $+90^{\circ}$ | $+45^{\circ}$ |
| 11 | $+180^{\circ}$ | $+135^{\circ}$ |
| 10 | $+270^{\circ}$ | $+225^{\circ}$ |
|  |  | $+315^{\circ}$ |



At 1200 bps, differential two-phase modulation is used. Each bit is transmitted at a relative phase change to preceding signal element in accordance with CCITT V. 26 bis.

| 1200 BPS |  |
| :---: | :---: |
| BIT | PHASE CHANGE |
| 0 | $+90^{\circ}$ |
| 1 | $+270^{\circ}$ |

Turn On Sequences - A total of twelve selectable turn on sequences can be generated by the transmitter module.

Turn Off Sequence - When the transmitter has been sending data and "Request to Send" is turned off, any remaining data bit information is transmitted within 6 milliseconds.

Ready for Sending (T106) Response Times - These response times are determined by the modem configuration selected and its associated turn on sequence.

| Turn On Sequence Number | Ready for Sending Response TIme | Configuration and Carrler Type |
| :---: | :---: | :---: |
| 1 | 6.67 msec | Switched Carrier - 4-Wire (Bell 201) |
| 2 | 8.33 msec | Switched Carrier - 4-Wire |
| 3 | 30 msec | CCITT - 4-Wire |
| 4 | 30 msec | CCITT - 4-Wire with Scrambler |
| 5 | 90 msec | CCITT - 2-Wire |
| 6 | 90 msec | CCITT - 2-Wire with Scrambler |
| 7 | 148.3 msec | Switched Carrier - 2-Wire |
| 8 | 148.3 msec | Switched Carrier - 2-Wire with Scrambler |
| 9 | 220 msec | CCITT - 2-Wire Echo Protection |
| 10 | 220 msec | Switched 2-Wire Echo Protection with Scrambler |
| 11 | 800 msec | CCITT - 2-Wire Auto Call |
| 12 | 800 msec | CCITT - 2-Wire Auto Call with Scrambler |

Scrambler/Descrambler - As a selectable option, the scrambler/descrambler may be inserted into the transmitter/receiver path. The purpose of this scrambler is to ensure that the line signal will evenly span the allocated bandwidth. This minimizes pattern sensitivity problems arising from simple fixed and periodic data sequences. The scrambler is V. 27 or V. 27 bis/ter compatible.
Carrier Detect (T109) - The modem receiver incorporates a line signal energy detector whose output responds to three selectable threshhold levels.

$$
\begin{array}{rlrl}
\text { Set } 1(\mathrm{~V} .26 \text { bis, switched network) - Greater than }-43 \mathrm{dBm} & =O N \\
\text { Less than }-48 \mathrm{dBm} & =O F F \\
\text { Set } 2(\mathrm{~V} .26 \text { bis, switched network) - Greater than }-33 \mathrm{dBm} & =O N \\
& \text { Less than }-38 \mathrm{dBm} & =O F F \\
\text { Set } 3(\mathrm{~V} .26, \text { leased line }) \quad \text { - Greater than }-26 \mathrm{dBm} & =O N \\
\text { Less than }-31 \mathrm{dBm} & =O F F
\end{array}
$$

NOTE: A minimum hysteresis of 2 db exists between the actual turn-on and turn-off transition levels for each threshhold set.

Selectable T109 Response Times - This time is defined as the interval between the sudden connection or removal of the received line signal to the modems receive filter, and the subsequent transition of Carrier Detect (T109) from one state to the other.
$\left.\begin{array}{|c|r|}\hline \begin{array}{c}\text { Carrier Detect } \\ \text { Transition }\end{array} & \text { Response Time } \\ \hline \text { OFF to ON } & 6 \pm 1 \mathrm{~ms} \\ \text { (connection) } & 14 \pm 1 \mathrm{~ms}\end{array}\right\}$ Selectable

Receive Level - The modem receives line signals from 0 to $\mathbf{4 3} \mathrm{dBm}$.

Transmit Timing - The modem generates a Transmit Clock (T114) having the following characteristics: Frequency $-2400 \mathrm{~Hz} \pm .01 \%(1200 \mathrm{~Hz}$ $\pm .01 \%$ in fallback mode), duty cycle $-50 \pm 1 \%$. The modem is also optionally capable of tracking an External Transmit Clock (T113) supplied by the modem user. T113 has similar characteristics to T114.

Receive Timing ( $\mathbf{T} 115$ ) - The modem provides a data derived "Receive Clock" output in the form of a nominal squarewave ( $50 \pm 1 \%$ duty cycle). The modem timing recovery function is capable of tracking a $\pm 0.01 \%$ frequency error in the associated transmit timing source.

Transmitter Output Levels - This output can be strap controlled in $2 \pm 0.2$ dB steps from $-1 \mathrm{dBm} \pm 1 \mathrm{~dB}$ to $-15 \mathrm{dBm} \pm 1 \mathrm{~dB}$.

Answer Tone Generation - The modem generates a selectable answering tone of $2100 \mathrm{~Hz} \pm 0.01 \%$ or $2025 \mathrm{~Hz} \pm 0.01 \%$. The 2100 Hz tone meets CCITT Recommendations G. 161 and V.25, and the 2025 Hz tone meets Bell System requirements for both answering tone and echo suppressor disabling tone.

Equalizer - As a strap option, the modem contains a fixed compromise delay equalizer which can be used to improve performance over unconditioned schedule 3002 tines. This option is normally positioned in the receiver, but it can be repositioned in the transmitter or bypassed entirely. It is designed to compensate for the mean of the range of group delay distortions generally encountered in the United States. Its amplitude response is nominally flat at 0.0 dB .

Test Pattern Generation - The scrambler/descrambler function can be used to implement a 127 -bit test pattern feature. For example, a constant mark input could be scrambled and transmitted as a pseudo-random signal to be descrambled at the receiver back to the constant mark. A transmission error would be represented as a space for the duration of an incorrect bit.

Multipoll Synchronization - The "new sync" (NSYNC) digital input can be pulsed to cause rapid resynchronization of the receiver for sequences of incoming messages. This feature is necessary in some polling applications. However, if the user's hardware/software does not support the use of "new sync" (NSYNC), then the optional "fast sync" (FSYNC) can be utilized to enable a fast resynchronization procedure.

## Selectable Clamping Options -

1) Received Data (T104) - This output is clamped to a selectable constant (space or mark) when "Carrier Detect" is off, to prevent disturbances on the line from getting through the receiver to the dataoutput.
2) Carrier Detect (T109) Clamp - This output may be clamped OFF (squelched) in 2 -wire applications during the time when "Request to Send" (T105) is on. An additional option extends this clamp for 148 msec beyond T105 transitioning off, providing echo protection.
3) Receive Clock (T115) - This clock output can be clamped OFF when "Carrier Detect" is off, thereby preventing any disturbances from propagating through the receiver to the receive clock output.

## SYSTEM DESIGN

The R24 modem modules provide the user with sufficient flexibility to implement a wide range of modem functional configurations. This flexibility is achieved by digital control at the module interfaces. For a given application, such as a lease network V. 26 Alternative B modem (Bell 201B), the complexity of the user interface can be significantly reduced by strapping those data interface inputs which do not change. The modem interface can also be under software control.

Figures 1 and 2 show the basic interface connections for the transmitter module ( $T$ ) and the receiver modules ( $\mathrm{R} 1, \mathrm{R} 2$ ). These diagrams are applicable for any operation mode of the modem-simplex, half-duplex, or fuil-duplex.


TRANSMITTERINTERFACES
Figure 1


## RECEIVER INTERCONNECTION

Figure 2

## MODEM OPERATION - HALF OR FULL-DUPLEX

Figure 3 indicates the module interconnections necessary for half-duplex operation. For full-duplex operation, the transmitter/receiver interconnections are similar to the half-duplex case with the exception that "REC IN" is not connected to T2 or T1. In full-duplex operations, the transmission and receiver paths are independent.

As shown in the diagram, a transformer is sufficient to connect directly to a leased line in the U.S. For the switched network, registered protective circuitry or a data access arrangement (DAA) is generally required. Rockwell offers an FCC registered protective circuitry product to support this application. Requirements for line interface and protective circuitry vary internationally.


Secondary Channel - The modem modules provide the user with all the interface connections needed to add an external secondary channel if required. This data transmission channel would operate at a lower rate, and in a different portion of the available bandwidth than the primary. Additional external receive filtering would also have to be added to allow simultaneous operation of the primary and secondary channels.

Analog and Digital Loopback - To check out or diagnose the communication link, loopback testing is often performed. A test word is transmitted and "looped" back to the originating DTE. Typical types of loopback tests are:


## INTERFACE DESCRIPTION

| $\qquad$ | EIA RS232C Equivalent | Module Input | ntortace Output | Doscription |
| :---: | :---: | :---: | :---: | :---: |
| T103 | BA | T.9 |  | Transmitted Data |
| T104 | BB |  | R2-5 | Received Data |
| T105 | CA | T-8 |  | Request to Send |
| T106 | CB |  | T-6 | Ready for Sending (Clear to Send) |
| T109 | CF | R1-4 | R2-22 | Data Channel Received Line Signal Detector (Carrier Detect) |
| T111 | CH | $\begin{aligned} & \text { T-12, } \\ & \text { R2-9 } \end{aligned}$ |  | Data Signalling Rate Selector Selects 2400 bps or 1200 bps Mode |
| T113 | DA | T. 7 |  | External Transmit Clock (Transmitted Signal Element Timing) |
| T114 | DB |  | T-10 | Transmit Clock (Transmitteq Signal Element Timing) |
| T115 | DD |  | R2-6 | Receive Clock (Receive Signal Element Timing) |


| TormModule Interface <br> Input Outpui |  |  | Description |
| :---: | :---: | :---: | :---: |
| DAC OUT |  | T-22 | Output of Digital to Analog Converter |
| TFIL | T-23 |  | Input to Low Pass Filter. DAC OUT is Normally Connected to TFIL Unless Additional Filtering or an Equalizer is to be Inserted. |
| TIN <br> $-1 \mathrm{dBm}$ <br> - 3dBm <br> $-5 \mathrm{dBm}$ <br> -7dBm <br> -9dBm <br> - 11 dBm <br> - 13dBm <br> - 15dBm | T-31 | $T-39$ $T-38$ $T-37$ $T-36$ $T-35$ $T-34$ $T-33$ $T-32$ | These Nine Signals Implement the Transmitter Output Level Attenuator. One of the Signals $-1 \mathrm{dBm}, \ldots,-15 \mathrm{dBm}$ is Strapped to TIN to Set the Desired Output Level. |

RECEIVER DIGITAL CONTROLS

| Term | Module Interface |  | Description |
| :---: | :---: | :---: | :---: |
|  | Input | Output |  |
| RBCK | R1-1 | R2-25 | Receiver Baud Clock |
| RLSD THRH R2W/4W TH09 | $\begin{gathered} \text { R2-24 } \\ \text { R1-3 } \\ \text { R2-8 } \\ \text { R2-18 } \end{gathered}$ | $\begin{gathered} \mathrm{R} 1-2 \\ \mathrm{R} 2-23 \end{gathered}$ | Control Signals to Generate Carrier Detect (T109) and implement T109 Threshold Set Select Function |
| TC09 | R2-15 |  | Determines Carrier Detect (T109) Off-to-On Response |
| PBS | R2-16 |  | Determines Carrier Detect (T109) On-to-Off Response |
| CP04 | R2-17 |  | Clamps Received Data (T104) to a mark or space when Carrier Detect(T109) is Off |
| CP15 | R2-19 |  | Optionai Clamping of Received Clock (T115) |
| FSYC | R2-20 |  | Fast Sync Optional Fast Resynchronization Procedure |

RECEIVER DIGITAL DIAGNOSTICS

|  | Module Interface |  |
| :---: | :---: | :---: |
|  |  |  |
| Term | Inpul | Output |
| SYC |  | R2-1 |
| RCVDS | Digital Outputs which Enable User to |  |
| DCP | R2-2 | Generate Eye Pattern and Phase Error |
| A | R2-4 | Information |
| PE | R2-3 |  |

TRANSMITTER DIGITAL CONTROLS

| Tarm | Modulo Intertace |  | Description |
| :---: | :---: | :---: | :---: |
| CAUTO | T-3 |  | Initiates Answer Tone |
| TONA |  | T-5 | Indicates Completion of Transmission of Answer Tone |
| TBC |  | T. 4 | Transmitter Baud Clock |
| Z | T-28 |  | Input Forcing Transmit Clock (T114) to Phase and Frequency Lock to External Transmit Clock (T113) |
| T2W/4W | T-11 |  | Inputs Affecting Ready for Sending |
| X | T-24 |  | Response Times, Answer Tone Frequency |
| K | T-25 |  | and Carrier Detect (T109) Squelch |
| $Y$ | T-26 |  |  |
| TC06 | T-27 |  |  |
| 800MS | T-29 |  |  |
| E | T.30 |  |  |


| Term | Module Interface |  | Description |
| :---: | :---: | :---: | :---: |
|  | Input | Output |  |
| REC OUT | R1.7 |  | Receive Filter Ouput |
| $\begin{aligned} & \text { EQIN } \\ & \text { EQOUT } \end{aligned}$ | $\begin{aligned} & \mathrm{R} 1-8 \\ & \mathrm{R} 1.6 \end{aligned}$ |  | Equalizer Input Equalizer Output |
| $\begin{aligned} & \text { RLSDIN } \\ & \text { AGCIN } \\ & \text { AGC OUT } \end{aligned}$ | $\begin{aligned} & \text { R1.5 } \\ & \text { R2.21 } \end{aligned}$ | R2-26 | Carrier Detect Circuitry Input <br> Automatic Gain Control Circuitry Input <br> Automatic Gain Control Circuitry Output |
| $\begin{gathered} \text { GAIN } \\ \text { G1 } \\ \text { G2 } \end{gathered}$ | $\begin{gathered} \text { R1-11 } \\ \text { R1.9 } \end{gathered}$ | R1-10 $\}$ | Optional Carrier Detect (T109) Threshold Selection Controls |
| IANALOG | R2.27 |  | Sample and Hold Circuitry Input |

## MODEM PERFORMANCE

The R24 is a high performance synchronous 2400 bps DPSK modem, utilizing a coherent demodulation technique to achieve reliable operation over the switched network or unconditioned lines. This section contains a quantitative discussion of the R24's typical performance under varying test conditions.

Timing Jitter - The maximum steady state timing jitter of "receive clock" with respect to "transmit clock" is less than $10 \% \mathrm{p}$-p for an input signal-tonoise ratio of 12 dB .

Bit Error Rate - The following graph represents typical R24 performance:


Phase Error - Phase error can be measured by using the modem's output signals PE, SYC, and A. With an external test circuit, a numerical value can be derived to indicate the quality of received data. This numerical value can be directly correlated to bit error rate performance. The required test circuit can be implemented with discrete circuitry or in software within a micro computer.

Eye Pattern - By using the modems digital output signals RCVDS, SYC, and $A$ along with an added test circuit, the user can generate an oscilloscope quadrature eye pattern. This pattern displays the received signal as a group of dots in the baseband signal plane; hence, it is a graphic representation of modem performance.


Typical Eye Pattern: 4 Phase- 2400 bps -1200 Baud (V26A)
Phase error and eye pattern can be extremely useful for modem acceptance testing, product evaluation, and observation of line signal quality under actual operation.

## ELECTRICAL CHARACTERISTICS

POWER REQUIREMENTS

| Module | Voltage | Ripple | Maximum Current |
| :---: | :---: | :---: | :---: |
| T | $\begin{array}{r} +5 \mathrm{Vdc} \pm 5 \% \\ +12 \mathrm{Vdc} \pm 5 \% \\ -12 \mathrm{Vdc} \pm 5 \% \end{array}$ | $\begin{aligned} & 100 \mathrm{mV} \text { p-p } \\ & 50 \mathrm{mV} \text { p-p } \\ & 50 \mathrm{mV} \text { p-p } \end{aligned}$ | $\begin{aligned} & 38 \mathrm{~mA} \\ & 16 \mathrm{~mA} \\ & 48 \mathrm{~mA} \end{aligned}$ |
| R1 | $\begin{aligned} & +12 \text { Vdc } \pm 5 \% \\ & -12 \text { Vdc } \pm 5 \% \end{aligned}$ | $\begin{aligned} & 50 \mathrm{mV} \text { p-p } \\ & 50 \mathrm{mV} \text { p-p } \end{aligned}$ | 23 mA 16 mA |
| R2 | $\begin{array}{r} +5 \text { Vdc } \pm 5 \% \\ +12 \text { Vdc } \pm 5 \% \\ -12 \text { Vdc } \pm 5 \% \end{array}$ | $\begin{array}{r} 100 \mathrm{mV} \text { p-p } \\ 50 \mathrm{mV} \text { p-p } \\ 50 \mathrm{mV} \text { p-p } \end{array}$ | 64 mA <br> 25 mA <br> 78 mA |

Maximum total power consumption approximately 3 watts.
Typical total power consumption approximately 2 watts.

## DIGITAL INTERFACE

The R24 provides LS TTL or CMOS compatible logic levels that are functionally equivalent to EIA RS232/449 and CCITT V. 24.

| Input <br> Logic | Altowed Input Voltage Levels |
| :---: | :---: |
| Low | -12.0 V to +0.8 V Sinking $<10 \mu \mathrm{~A}$ <br> +4.0 V to +5.0 V Sourcing $<10 \mu \mathrm{~A}$ |

Digital inputs are directly CMOS compatible. Interfacing with standard TTL or low-power Schottky TTL requires an external pull-up resistor.

| Output <br> Logic | Allowed Output Voltage Levels |
| :---: | :---: |
| Low 0.0 V to +0.4 V Sinking 0.36 mA <br> High$+4.0 \mathrm{~V}$ to + 5.0 V Sourcing $100 \mu \mathrm{~A}$ |  |

[^10]
## TRANSMISSION LINE INTERFACE

The R24 provides an analog interface that must generally be transformer coupled to ensure normal telephone line isolation. Through appropriate selection of transformers and other interface circuitry, the R24 can be configured to operate on leased or dial-up telephone lines, or on other special private networks. For the dial-up line interface, Rockwell offers an FCC registered module that allows direct connection to this network. For the leased line interface, only transformers with characteristics similar to those utilized on the R24 modem evaluation board are required for this connection.

The receiver and transmitter line interfaces are single-ended (non-trans former coupled) signals with the following characteristics:

Transmitter Output (Normal)

Output Impedance: 600 ohms $\pm 2 \%$
Maximum output level: $\leqslant 0.0 \mathrm{dBm}$

Transmitter Output (Alternate) Low Impedance:

Output Impedance: 0 ohms (op amp output)
Maximum output level $\leqslant+6.0 \mathrm{~dB}$

Note: This output for transformer loss compensation.
Receiver input:

Input Impedance: 15.8 K ohms $\pm 1 \%$
Maximum Input Level: 0.0 dBm

## MECHANICAL SPECIFICATIONS


\{LEAD PROTECTION)


Receiver - R2 Module Package
NOTES: 1) Dimensions in inches (millimeters). .
2) Component side shown

## PRINTED CIRCUIT BOARD MOUNTING OPTIONS FOR THE R24 MODULES

Three methods of mounting are commonly used. Each configuration has certain distinct advantages.

| Mounting <br> Method | Type of Connection <br> or Connector Used | Basic <br> Advantage |
| :--- | :--- | :--- |
| Standard Flush <br> PCB Component <br> Mount | Wave Soldered Into Standard <br> PCB Eyelets | Lowest Height <br> Profile |
| Above Board | Connectors (SAE Series <br> Low Profile <br> Socket | 3000or Methode Series 1000) <br> These Sockets are Wave <br> Soldered IntoStandard <br> PCB Eyelets |
| PCB Plug-in | Plug-in Capa- <br> bility at Low <br> Cost |  |
| Sockets (Bullets) | Connectors (AMP Miniature <br> Spring Sockets.) <br> Pin Sockets are Individually <br> Soldered Into PCB Eyelets | Lowest Pro- <br> file for Plug-in <br> Capability |

## ENVIRONMENTAL SPECIFICATIONS:

Operating temperature: $0^{\circ} \mathrm{C}$ to $60^{\circ} \mathrm{C}$
Storage temperature: $.40^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$
Relative humidity: to $95 \%$ (non-condensing)
Altitude: $\mathbf{- 2 0 0}$ to 10,000 feet ( $\mathbf{6 1}$ meters to 3,049 meters)
Burn-In: 96 hours at $70^{\circ} \mathrm{C}$

## Order Information

When ordering, specify products as follows:

$$
\begin{aligned}
& \text { R24 - Set of } 3 \text { modules (T, R1, R2) } \\
& \text { R24MEB - Modem Evaluation Board }
\end{aligned}
$$

The R24 transmitter function (R24-T module) and the R24 receiver function (R24-R1, R24-R2 modules) can be purchased separately. Contact your Rockwell Sales office or Anaheim to quote specific customer requirements.

## R24 MODEM EVALUATION BOARD

To facilitate evaluation and design-in of the R24 modem for new and existing equipment designs, an R24 Modem Evaluation Board (R24MEB) is available - see below. The R24MEB can be easily combined with terminal systems for real-time performance evaluation.


R24 Modem Evaluation Board (R24MEB)
The Modem Evaluation Board is equipped with a standard 31 pin edge connector, control switches, output level jumper, and interface transformers. These features allow full control of the interface circuitry. In addition, this unit can be used directly in a U.S. leased line configuration.

The R24MEB is recommended for all first-time users to assist in their evaluation. Complete documentation is supplied with each initial R24MEB.

## MODEM PRODUCTS PRODUCT SUMMARY

## R24 DC 2400 BPS Direct Connect Modem

## INTRODUCTION

The Rockwell R24 DC is a high-performance, serial synchronous DPSK modem suitable for direct connection to domestic switched network or two-wire private lines. Utilizing extensively MOS/LSI Technology and High Quality Components, the Modem plus registered protective circuitry is implemented on a single $5.00^{\prime \prime}$ by $7.850^{\prime \prime}$ card. Performance and versitility are enhanced while cost and size are reduced by the on-board Rockwell PPS-4/1 One Chip Microcomputer.
The Rockwell R24 DC offers the user a complete high performance 2400 BPS Modem that is FCC registered for direct connection to the dial-up network. OEM's can easily incorporate the Single Card into their computer terminals, communication networks, PABX equipment, Data concentrators, Stand-alone box modems or any applications where reliable data communication is required.

## MAXIMUM MODULE DIMENSIONS

| w | L | H |
| :---: | :---: | :---: |
| $5.00^{\prime \prime}$ | $7.850^{\circ}$ | $0.600^{\circ}$ |

INTERFACE CONNECTORS

| 1 DTE |  |
| :---: | :---: |
| 40 pin, $0.100^{\circ}$ spacing <br> $20 /$ side | 10 pin, $0.100^{\circ}$ spacing <br> $5 /$ side |

## FEATURES/BENEFTTS

- High Performance; Low Cost
- LSI High Density; Low Power
- Microcomputer Controlled Line Connect/Disconnect Sequence; Low Component Count
- Bell 201 B/C, CCITT V. 26 Compatible
- Half Duplex (2-Wire) Operating Mode
- 2400 BPS Data Rate
- Auto or Manual Answer
- Auto or Manual Call Originate (Pulse Dialing)
- Automatic Answer Back Tone Generation upon Auto Answer
- Direct Connect to Swtiched Network
- Programmable or Permissive Connection Arrangement
- Local Analog Loopback Test Mode
- Compromise Equalizer (Strap Selectable)
- Scrambler/Descrambler Facility (Selectable)
- Line Current Sensing (Selectable)
- DTE Interface LSTTLCMOS Compatible
- Extemal Transmit Data Clock Tracking
- Power Requirements, $\pm 12 \mathrm{~V},+5 \mathrm{~V}$
- Typical Power Consumption 3 Watts
- Diagnostic Outputs Available for Eye Pattern and Data Quality Monitor
- 15 Second Abort Timer (Selectable)



## POWER SUPPLIES:

```
+5VDC }\pm5%\mathrm{ at }102\mathrm{ ma (max.)
+12VDC }\pm5%\mathrm{ at }64\textrm{ma}\mathrm{ (max.)
-12VDC }\pm5%\mathrm{ at }142\mathrm{ ma (max.)
```

ENVIRONMENTAL SPECIFICATIONS

Operating temperature: $0^{\circ} \mathrm{C}$ to $60^{\circ} \mathrm{C}$
Storage temperature: $-40^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}$
Relative humidity: to $95 \%$ (non-condensing)
Burn In: 96 hours at $70^{\circ} \mathrm{C}$

For more information contact your local Rockwell Representative or Regional Office, or Telecom/Subsystem Marketing, Rockwell Microelectronic Devices, P.O. Box 3669, Anaheim, CA 92803. TWX 910-591-1698. Telephone: (800) 854-8099, in Califocmia (800) 422-4230.

## MODEM PRODUCTS PRODUCT SUMMARY

## V96P/1 Multi-Configuration 9600 BPS Modem

## INTRODUCTION

The Rockwell V96P/1 is a versatile, high-performance modem on a single printed circuit board. Having CCITT V. 29 and V. 27 compatibility, the V96P/1 offers the user sufficient flexibility to customize a 9600 bps modem. With minimum interface circuitry, the V96P/1 can operate on dedicated lines or on the general switched network. In addition, the V96P/1 is compatible with the Rockwell V96P and M96P products.

## MARKET RESTRICTIONS

Minimum purchase must be 1000 units/year. Additional restrictions are application dependent. Please contact Rockwell for further information.

## FEATURES/BENEFITS

- Maximum digital LSI signal processing
- 9600/7200/4800/2400 bps modes
- Ulimate user flexibility (CCITT V.29, V. 27 ter, V. 27 bis compatible, and 300 bps per CCITT T.30)
- Single printed circuit card
- Smallest full-feature modem
- High reliability
- Approaches theoretical performance limits
- Operating Modes:

Half duplex (2 wire)
Full duplex (4 wire)

- TTL-compatible

- Analog loopback test circuitry
- Automatic adaptive equalizer
- Typical power consumption 3.5 watts


## BOARD DIMENSIONS

$9.188 \mathrm{in} .(233.38 \mathrm{~mm}) \times 6.288 \mathrm{in} .(159.7 \mathrm{~mm})$


POWER SUPPLIES:
$+5 \mathrm{~V}( \pm 5 \%)+\mathrm{VM},<200 \mathrm{ma}$ $+12 V( \pm 5 \%)+V A,<110 \mathrm{ma}$ $-12 \mathrm{~V}( \pm 5 \%)-\mathrm{V},<280 \mathrm{ma}$ (maximum currents)

ENVIRONMENTAL SPECIFICATIONS

Operating temperature: $0^{\circ} \mathrm{C}$ to $60^{\circ} \mathrm{C}$
Humidity: Up to $90 \%$, non-condensing, or a wet bulb temperature up to $35^{\circ} \mathrm{C}$, whichever is less

For more information contact your local Rockwell Representative or Regional Office, or Telecom/Subsystem Marketing, Rockwell Microelectronic Devices, P.O. Box 3669, Anaheim, CA 92803. TWX 910-591-1698. Telephone: (800) 854-8099, in California (800) 422-4230.

## TELECOM DEVICES

CRC 8000, 8001 - Binary to Dial Pulse Dialer


16 Digit First-In-First-Out (FIFO) Memory
Asynchronous Operation
10pps ( 2 KHz Clock) Dial Pulse Operation with a Minimum 650 ms Interdigit Time
20pps (4KHz Clock) Dial Pulse Operation with a Minimum 325ms Interdigit Time
CRC 8000, TTL Input compatible
CRC 8001, MOS Input compatible

The dialer accepts binary data, stores the data in a first-in-first-out memory, and generates dial pulses at normal telephone rates. Internal timing is derived from an external 2 KHz or 4 KHz clock. With a 2 KHz clock, a $10 \mathrm{pps}(60 \%$ break $/ 40 \%$ make) dial pulse frequency having a minimum 650 ms interdigit time is generated. If a 4 KHz clock is used, the dial pulse frequency is 20 pps and the interdigit time is reduced to 325 ms minimum. The memory section is necessary as the incoming data rate may be much faster than the normal dial pulse output rate. Binary codes one (1) through fifteen (15) produce the same number of dial pulses. A binary zero input produces sixteen (16) dial pulses.

CRC 8030 — Dual Tone Multi-Frequency Detector


Digital range filter detects all 16 Touch-Tone ${ }^{*}$ signal combinations
Detects a tone pair in 22 ms to 39 ms
Digital logic impervious to frequency or bandwidth drift caused by time, temperature, or voltage
Automatic internal reset when no tones are present
Variable pulsewidth Strobe output provides increased talk-off protection
Binary or 2-of-8 coded outputs option
Inputsloutputs can be left floating when not used
Single or dual power supply option
On-chip oscillator - 3.579545 MHz color-burst crystal
Central-office-quality detection
Excellent talk-offprotection-As little as one hit on Miteltest tape (CM 7290)

Dual-Tone Multi-Frequency (DTMF) or Touch-Tone ${ }^{\text {* }}$ signaling has made telephone communication faster, more efficient and more convenient than dial pulse signaling. Touch-Tone ${ }^{*}$ telephone instruments or automatic dialers generate a tone pair representing the "dialed" number and send them over the lines to a receiver which detects the tones and reliably identifies the number.

Utilizing a digital filter algorithm, the CRC 8030 provides a low-cost and high-performance solution for DTMF detection.

A strobe output indicates when the output data are valid.
When linked with a front-end band-split filter/limiter, the CRC 8030 implements a complete DTMF receiver.

This design approach provides the optimum technological benefits of analog and digital design techniques.

[^11]
## DTMF to Dial Pulse Conversion



A DTMF to dial pulse converter can be easily implemented using the CRC 8030 and the CRC 8001.

For example, where electronic switching systems (ESS) are not available, the CRC 8030, a Dual-Tone Multi-Frequency Detector, and the CRC 8001, a Binary to Dial Pulse Dialer,
can be utilized to convert Touch-Tone ${ }^{\circledR}$ signals to dial pulse signals. The CRC 8030 decodes Touch-Tone signals to their binary equivalent and the CRC 8001 converts the binary information to a train of pulses compatible with the standard telephone dial pulse signals.

# MOS/LSI TELECOMMUNICATIONS DEVICES TECHNICAL BULLETIN 

# Binary to Dial Pulse Dialer 

16 Digit First-In-First-Out (FIFO) Memory

Asynchronous Operation
10pps (2KHz Clock) Dial Pulse Operation with a Minimum 650ms Interdigit Time
20pps ( 4 KHz Clock) Dial Pulse Operation with a Minimum 325 ms Interdigit Time

## TTL Compatible

## General Description

The CRC 8000 and CRC 8001 are P-channel enhancement mode MOS Binary to Dial Pulse Dialer utilizing ion implant, low threshold voltage processing. The Dialer accepts binary data, stores the data in a first-in-first-out memory, and generates dial pulses at normal telephone rates. Internal timing is derived from an external 2 KHz or 4 KHz clock. With a 2 KHz clock, a 10 pps ( $60 \%$ break/40\% make) dial pulse frequency having a minimum 650 ms interdigit time is generated. If a 4 KHz clock is used, the dial pulse frequency is 20 pps and the interdigit time is reduced to 325 ms minimum. CRC 8000 and CRC 8001 are identical except for their input interface. CRC 8000 inputs are TTL compatible and CRC 8001 inputs are MOS compatible. The devices are available in a 16 pin dual-in-line package.
The CRC 8000 can be installed in telephone central office stations to perform binary to dial pulse conversions. In areas where electronic switching systems (ESS) are not available, the CRC 8000 and CRC 8030 , a Dual-Multi-Frequency Detector, can be utilized to convert Touch-Tone ${ }^{\circledR}$ signals to dial pulse signals. The CRC 8030 decodes Touch-Tone signals to their binary equivalent and the CRC 8000 converts the binary information to a train of pulses compatible with the standard telephone dial pulse signals.

## Operation

Digits, in the form of four binary inputs, are loaded asynchronously relative to the clock into a 16 digit first-in-first-out (FIFO) memory. This memory section is necessary as the incoming data rate may be much faster than the normal dial pulse output rate. Binary codes one (1) through fifteen (15) produce the same number of dial pulses. A binary zero input produces sixteen (16) dial pulses.
Dialer operation is controlled by the "Load" and "Memory Read Inhibit" inputs. A load pulse is required in order to input each digit into the FIFO. With a 2 KHz clock, the maximum data entry rate is 500 digits per second.

The Memory Read Inhibit line can be used to delay the Dial Pulse Output. If the Memory Read Inhibit line is low (binary zero), the first digit entering the FIFO memory initiates the dialing sequence. The digit is transferred from the memory to a down counter that generates the appropriate number of dial pulses. Internal timing produces the proper interdigit time between pulse trains. If there is a pause in the binary data input, the circuit generates an extra length interdigit time in a manner identical to that created by a rotary dial.
A high level (binary one) Memory Read Inhibit prevents the reading of the memory thereby causing a pause. During this condition, existing data in the FIFO will be stored until Memory Read Inhibit is released (low level). When the inhibit line is changed from a low level (binary zero) to a high level (binary one), a dial pulse train in process will be completed before pausing. Additional digit data may be input to the FIFO memory as long as the 16 digit capacity is not exceeded.
The Busy output line is high when there is data in memory or dial pulses are being generated.
The Reset input is a "Master Reset". If the Reset input line is low, Busy is set to a low level and Dial Pulse Out is set to a high level. The outputs will remain in that state until a new digit is input to the FIFO.

Technical Characteristics
MAXIMUM RATINGS



## RECOMMENDED OPERATING CONDITIONS/ELECTRICAL <br> CHARACTERISTICS FOR 10pps OPERATION

Unless Otherwise Noted $V_{S S}=+5.0 \mathrm{~V}, V_{G G}=-12.0 \mathrm{~V}, V_{D D}=0.0 \mathrm{~V}$,
$0^{\circ} C \leqslant T_{A} \leqslant 70^{\circ} \mathrm{C}$, and clock frequency $=2.0 \mathrm{KHz} \pm 5 \%$

|  | PARAMETER | MIN | tYp | MAX | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Power Supplles |  | $\begin{array}{r} 4.75 \\ -13.0 \end{array}$ |  |  |  |  |
| $v_{\text {ss }}$ | Supply Voltage |  | $\begin{array}{r} 5.0 \\ -12.0 \end{array}$ | $\begin{array}{r} 5.25 \\ -11.0 \end{array}$ | $\begin{aligned} & v \\ & v \end{aligned}$ | $\begin{aligned} & v_{D D}=0.0 \mathrm{~V} \quad \text { See Note } 1 \\ & v_{D D}=0.0 \mathrm{~V} \end{aligned}$ |
| GG Supply VoitageInputs |  |  |  |  |  |  |
| $V_{1 N^{\prime}}(0)$ | Logical "0' Input voltage | -1.0 | 0.0 | $\left\{\begin{array}{c} 0.8 \\ v_{\mathrm{Ss}}+0.2 \\ 10 \end{array}\right.$ | $v$ | T |
| $V_{\text {IN }}(1)$ | Logical " 1 " Input voltage | $v_{S S}-0.7$ |  |  | $v$ | See Note 2 |
| $C_{\text {IN }}$ | input capacitance |  |  |  | pF | $V_{\text {IN }}=V_{S S}-1.0 \mathrm{~V}$ |
| Input Timing |  |  |  |  |  |  |
| ${ }^{1} \mathrm{c}$ | Clock repetition rate | 1.9 | 2.0 | 2.1 | KHz | See Note 3 |
| $t^{\text {p }}$ c | Clock duty cycle | 45 | 50 | 55 | \% | Applies to |
| $t_{r}$ | Input pulse rise time | 40 |  | 500 | ns | \} all inputs |
| $t_{f}$ | Input pulse fall time | 40 |  | 500 | ns | ¢ Incluating clock |
| ${ }_{\text {t }}^{\text {LH }}$ | Load pulse width "High" | 1.9 |  |  | ms | See |
| ${ }^{\text {t LL }}$ | Load pulse wlath "Low" | 0.1 |  |  | ms | Timing |
| $t_{d 1}$ | Data set-up time |  |  | 0.5 | ms | Diagram |
| ${ }^{\text {t }} \mathrm{d} 2$ | Data hold time | 1.75 |  |  | ms |  |
| ${ }^{\text {mL }}$ ' | Memory Read Intibit stable time relatlve to Load |  |  | 650 | ms | See Note 4 |
| ${ }^{\text {t MOP }}$ | Memory Read Inhlbit stable tlme relatlve to Dlal Puise Out |  |  | 650 | ms | See Note 4 |
| $t_{R}$ | Reset pulse width | 1.0 |  |  | $\mu \mathrm{s}$ |  |

## NOTES

1. Other supply parameters are permissible including $\mathrm{V}_{\mathrm{SS}}=0.0 \mathrm{~V}$, $\mathrm{V}_{\mathrm{DD}}=-6 \mathrm{~V}$, and $\mathrm{V}_{\mathrm{GG}}=-12 \mathrm{~V}$. Input/output parameters will be adjusted accordingly.

|  | Min. | Typical | Max. |
| :--- | ---: | :---: | :---: |
| $\mathrm{V}_{\text {in }}(0)$ | -7.0 | -6.0 | -5.2 |
| $\mathrm{~V}_{\text {in }}(1)$ | -0.7 | 0.0 | +0.2 |
| $\mathrm{~V}_{\text {out }}(0)$ | 0.0 | 0.0 | -5.6 |
| $\mathrm{~V}_{\text {out }}(1)$ | -2.6 | 0.0 | 0.0 |

2. All inputs of CRC 8000 have "on chip" $3200 \pm 30 \%$ ohm pullup resistor to $V_{S S}$ and are suitable for being driven by TTL. All inputs of CRC 8001 have a high impedance input (no pullup resistor) and are suitable for interface with MOS devices.
3. For 20 pps operation, a 4.0 KHz is clock required. If the clock has a $5 \%$ tolerance, the operating specification can be derived from the above table. All parameters will remain the same except for the following timing parameters which will be reduced by one half: ${ }_{t}{ }_{L H},{ }^{t_{L L}},{ }^{t_{d 2}},{ }^{t_{M L}},{ }^{t_{M D P}},{ }^{t} D P D,{ }^{t} D P$, ${ }^{t}$ DPL, ${ }^{t}$ DPH, ${ }^{t}$ ID. Similarly, a 10 KHZ clock could be used, producing a 50 pps output rate.

| PARAMETER | MIN | tYp | MAX | UNITS | CONDITIONS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Outputs |  |  |  |  |  |
| $V_{\text {out }}\left({ }^{(0)}\right.$ Logical "0' output voltage |  |  | 0.4 | $\checkmark$ | $\mathrm{J}_{\text {sink }}=1.6 \mathrm{~mA}$ |
| $t_{\text {f }}$ (out) Output fall time |  |  | 500 | ns | 90\% to $10 \%$ |
| $V_{\text {out }}(1)$ Loglcal ' 1 ' output voltage | 2.4 |  |  | $\checkmark$ | $\mathrm{l}_{\text {source }}=0.1 \mathrm{~mA}$ |
| $t_{r}$ (out) Output rise time |  |  | 400 | ns | 10\% to $90 \%$ |
| Output Timing |  |  |  |  |  |
| ${ }^{1}$ DPD Dlal Pulse Out Delay | 700 |  | 900 | ms |  |
| ${ }^{\text {P }} \mathrm{DP}$ Dlal Pulse Perlod | 95 | 100 | 105 | ms | See Note 3 |
| topl Dial Pulse Width "Low" | 57 | 60 | 63 | ms | and Timing |
| ${ }^{\text {I }} \mathrm{DPH}$ Dlal Puise WIdth "High" | 38 | 40 | 42 | ms | Dlagram |
| $t \mathrm{D}$ Dlal Pulse Interdigit Time | 650 | 740 |  | ms |  |
| $t_{\text {b1 }}$ Busy Low/High Delay |  |  | 2.1 | ms |  |
| $t_{\text {b2 }}$ Busy High/Low Delay |  |  | 10 | $\mu \mathrm{s}$ |  |
| Power |  |  |  |  |  |
| PD Power Olsslpation |  | 125 | 275 | mw |  |



NOTE: CLOCK INPUT IS ASYNCHRONOUS
4. To prevent a dial pulse train from being output, Memory Read Inhibit must be stable prior to initiating that pulse train. This stabilization point is specified for two cases: (1) If no pulse trains are presently in process (e.g., the device has been reset),

## BINARY TO DIAL PULSE DIALER (CRC8000.1.3)

T-0.300 NOM


- PIN 14 is an output clock running at a FREDUENCY OF (PIN $13 \div 200$ ) HZ. THE PE AIOD FREOUENCY OF IPIN 13IS $60 \%$ BREAK/4OK MAKE.
-PIN 15 MUST BE GROUNDED (VOD) DURING
CIRCUIT OPERATION.

Memory Read Inhibit must be stable 650 ms after the load pulse was initiated; (2) If a pulse train is in process, to prevent the next pulse train from being output, Memory Read Inhibit must be stable 650 ms after the interdigit time was initiated.

## Packaging and Ordering Information

The Binary to Dial Pulse Dialer is available in a 16 -pin hermetically sealed ceramic dual-in-line package (see pin assignments and package dimension diagram). Order by type numbers.
CRC 8000-1-3 (ceramic DIP) 765-1892-001
CRC 8001-1-3 (ceramic DIP) 765-5841-001

# O Rockwell DATA SHEET 

## Dual Tone Multi-Frequency Detector

Digital range filter detects all 16 Touch Tone ${ }^{\circledR}$ signal combinations
Detects a tone pair in 22 ms to 39 ms
Digital logic impervious to frequency or bandwidth drift caused by time, temperature, or voltage
Automatic internal reset when no tones are present
Variable pulsewidth Strobe output provides increased talk-off protection
Binary or 2-of-8 coded outputs option
Inputs/outputs can be left floating when not used
Single or dual power supply option
On-chip oscillator - 3.579545 MHz color-burst crystal
Central-office-quality detection
Excellent talk-off protection - As little as one hit on Mitel test tape (CM 7290)

## DTMF Signaling and Receivers

Dual-Tone Multi-Frequency (DTMF) or Touch-Tone ${ }^{(12)}$ signaling has made telephone communication faster, more efficient and more convenient than dial pulse signaling. Touch-Tone ${ }^{\circledR}$ telephone instruments or automatic dialers generate a tone pair representing the "dialed" number and send them over the lines to a receiver which detects the tones and reliably identifies the number. DTMF signals are defined by a $4 \times 4$ audio


tone matrix as illustrated in figure 1. Each digit is represented by one tone from the low-group and one tone from the high-group. These non-harmonically related frequencies protect the message against false-keying by stray signals and voice-generated tones.
A DTMF receiver must recognize the dual tones within a certain bandwidth while tolerating dial tone, noise, input amplitude variation and "twist" or amplitude differential between the two tones. In addition, the receiver has to comply with timing restrictions imposed by the DTMF generation process and meet other specific requirements of the particular application.

## CRC 8030 Genera! Description

The CRC 8030 provides a low-cost and high-performance solution for DTMF detection. Utilizing a unique digital filter algorithm, the patented* CRC 8030 performs the key critical functions of a DTMF receiver. When used in conjunction with a front-end band-split filter/limiter, the CRC 8030 implements a complete DTMF receiver (figure 2). This design approach provides the optimum technological benefits of analog and digital design techniques.


Figure 2. DTMF Receiver ('tilizing CRC 80,30)

[^12]*U.S. Patent No. 1016.371

The exact requirements for the front-end filter/limiter vary with the particular receiver application. For example, high quality central office receivers require a more selective front-end filter. Conversely, low-noise environment keyphone systems can use a less stringent front-end filter design.

DTMF receivers historically have been implemented with all-analog filtering techniques, i.e., phase-locked loops, LC filters and active filters. Compared to a phase-locked-loop receiver, the CRC 8030 provides much superior performance. Compared to LC or active filter receivers, the CRC 8030 can be manufactured for a significantly lower cost while providing improved performance. The CRC 8030 provides the economy, performance, size and reliability benefits of digital MOS/LSI. The CRC 8030 is packaged in a 28 -pin DIP.

## Applications

The CRC 8030 can be applied to all systems requiring DTMF detection. This includes the traditional telephony systems: keyphone, PABX, central office, intercom and mobile radio communications. Other applications include computer signaling and control systems. Where it is necessary to interface with a dial pulse system, the CRC 8030 and the CRC 8000 (a Binary-to-Dial-Pulse Dialer) implement a DTMF-to-dial-pulse conversion system.

The CRC 8030 has been functionally designed to provide optimum performance for a wide variety of DTMF detection applications.

## Operation

The CRC 8030 is a DTMF detector implemented with PMOS ion-implantation processing. This detector accepts group-filtered and square-shaped DTMF frequencies and converts them to binary data or 2 -of- 8 coded data in 22 ms to 39 ms ; out-of-tolerance frequencies are rejected. The device ignores the first few pulses of the input signal in order to prevent errors in detection due to the transients from the Touch-Tone ${ }^{\circledR}$ pad. The signal is then analyzed several times by a digital range filter prior to being accepted as valid. As soon as the range filter has recognized a frequency below 1680 Hz , the Audio Detect (AUD) output is enabled. This output provides the user with a signal for controlling the limiter gain at the receiver front-end. A Strobe (ST) output indicates when the output data are valid.

Once a digit is accepted as valid, the CRC 8030 will ignore any change in tone frequency until either the high-group or low-group tone disappears for more than 10 ms . When this occurs, the device is reset internally and will be ready to accept another Touch-Tone ${ }^{\circledR}$ digit. This feature provides immunity to frequency drift that could be caused by Doppler shift. Should a frequency in either the high- or low-group disappear for less than 10 ms , the gap is bridged resulting in only one digit.

A block diagram of the CRC 8030 is shown in figure 3. The functions include timebase generation, wave shaping circuitry, range counters with correlation circuitry, and the output timing and decoding functions.


Figure 3. CRC 8030 Block Diagram.
21477.10

## Technical Characteristics

Maximum Ratings: Non-operating voltages with no damage to device -

Supply Voltage VDD $_{\text {D }}$. . . . . . . . . . . . . . . . $\mathrm{V}_{\mathrm{SS}}-8.0 \mathrm{~V}$
Supply Voltage $\mathrm{V}_{\mathrm{GG}}$. . . . . . . . . . . . . . . . $\mathrm{V}_{\mathrm{SS}} \cdot 21.0 \mathrm{~V}$
Positive Voltage on any pin. . . . . . . . . . . $\mathrm{V}_{\mathrm{SS}}+0.3 \mathrm{~V}$
Negative Voltage on any pin . . . . . . . . . V VSS -20.0 V
Power Dissipation ( $0^{\circ} \mathrm{C} \leqslant \mathrm{T}_{\mathrm{A}} \leqslant 70^{\circ} \mathrm{C}$ ) . . . . . 200 mW Operating Temperature Range (case). . . $0^{\circ}$ to $+70^{\circ} \mathrm{C}^{*}$ Storage Temperature Range (case) . . $65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$
*An extended temperature range device will be available in the future.

## Inputs and Outputs

The inputs and outputs are illustrated in figure 3 and are described below with a positive logic convention assumed. However, the operation is defined such that when a 2 -of- 8 output format is chosen, the Strobe and the low-group outputs display data with a negative logic convention. The high-group outputs always display data in a negative logic convention. Detailed timing is shown in the timing diagram, figure 4.

## Inputs

Logic levels are MOS compatible. Inputs BIN, INH, HLD, SC, N16, and TE have on-chip active pull-up devices to $\mathrm{V}_{\mathrm{SS}}$ with a minimum of $50 \mathrm{~K} \Omega 2$ resistance; therefore, no connection is required to these pins if a high-level input is desired.

- High- and low-group DTMF signals (FL, FH) - These are the filtered and square-shaped DTMF tones. When no signal is present, both input levels should be low (most negative level).
- Binary Output Select (BIN) - If this input is low (most negative level), the decoded outputs are displayed in a binary format and Strobe (ST) pulses from a normally low state to a high state (figure 4). If this input is high or open, the decoded outputs are displayed in a 2 -of -8 code and Strobe pulses from a normally high state to a low state.
- Chip Inhibit (INH) - If this input is low, the device is inhibited from decoding any DTMF tones. When decoding binary, the outputs stay low. When decoding 2 -of -8 , the outputs stay high. If this input is high or open, the outputs function normally. Chip Inhibit is also a master reset except for the output data registers when Output Hold is low.
- Output Hold (HLD) - If this input is low, the output data, if valid, are stored in the output registers. If the input is high or open, the outputs will function normally.
- Strobe Control (SC) - This input controls the pulsewidth of the Strobe (ST) output.
When Strobe Control is high or open, the signal is analyzed for the full 39 ms data acquisition ( t DA1, Long Strobe) period. If the input tone-pair is detected within 22 ms , then the Strobe (ST) output pulsewidth is at a maximum of 17 ms . If detection takes more than 22 ms , the Strobe pulsewidth is reduced by the extra time needed for detection. If the signal is detected after the 39 ms period, no Strobe pulse will occur.

When Strobe Control is low, the input signal is analyzed for a 33 ms period ( ${ }^{\text {DA2 }}$, Short Strobe). If the tone is detected within 25 ms after its inception, then the Strobe pulsewidth is 8 ms . If detection occurs after 25 ms , then the Strobe pulservidth is reduced by the lag time. If no signal is detected within the 33 ms period, no Strobe pulse will occur. When a Short Strobe is selected, a higher quality input signal must be present in order to be accepted as a valid signal. Thus, voice or noise signals on the telephone line, which require a longer detection time, will be ignored by the chip. As a result, the device has a higher immunity to false-keying when Strobe Control is low.
In either case, the tone pair may be detected, but the Strobe signal may not necessarily be generated, depending on the quality of the input tone-pair.

- 1633 Hz Disable (N16) - If this input is low, the device will not respond to the 1633 Hz tone, thus improving the talk-off rate. If this input is high or open, the device will respond to the 1633 Hz tone.
- Clock Inputs and Control (X1, X2, TE) - The CRC 8030 contains an on-chip oscillator for a 3.57954 MHz parallel resonant crystal. This crystal is connected to X1 and X2 and TE is held high or left open. As an option, an external 447.443 kHz oscillator can be used to clock the CRC 8030 . In this case, X 1 is the 447.443 kHz clock input, X 2 is left open, and TE is held low. For some applications (e.g., using several CRC 8030 devices on a board), it is possible to drive the chip with an external 3.579545MHz clock at pin X2, while leaving the TE pin open, and tying pin X 1 to $\mathrm{V}_{\mathrm{SS}}$.


## Outputs

All outputs feature open-drain devices. With a singlepower supply ( $\mathrm{V}_{\mathrm{GG}}=\mathrm{V}_{\mathrm{DD}}$ ), they will drive LP'TTL, MOS or CMOS inputs. With a dual power supply, they will drive the base of a transistor. The open-drain output devices must be tied through a pull-down resistor to a negative voltage between $\mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{\mathrm{GG}}$ (when used); the value of this resistor depends upon the type of interface. Typically:

| Resistor | Interface |
| ---: | :---: |
| $1.5 \mathrm{~K} \Omega$ | LPTTL |
| $10.0 \mathrm{~K} \Omega$ | MOS or CMOS |
| $7.5 \mathrm{~K} \Omega$ | Base of a Transistor |

These outputs can also drive LEDs. For more design details, consult the Collins Application Note, "CRC 8030 Telephone DTMF Receiver".

- Decoded Outputs (D1/697 Hz, D2/770 Hz, D4/852 $\mathrm{Hz}, \mathrm{D} 8 / 941 \mathrm{~Hz}, 1209 \mathrm{~Hz}, 1336 \mathrm{~Hz}, 1477 \mathrm{~Hz}$, 1633 Hz ) - These outputs display decoded information in either a binary or a 2 -of-8-coded format as described below.
When a 2 -of- 8 format is selected (BIN input is held high or left open), all 8 outputs are utilized. When a particular digit is decoded, the corresponding highand low-group outputs go low (figure 1). For

- For a full description of the output buffer capabilities, refer to the CRC 8030 Application Note.


Figure 4. Timing Diagram

| Touch-Tone ${ }^{\circledR}$ Matrix: Binary Outputs |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1209 |  |  |  | 1336 |  |  |  | 1477 |  |  |  | 1633 |  |  |  |
|  | D1 | 02 | D4 | D8 | D1 | D2 | D4 | D8 | 01 | D2 | D4 | D8 | D1 | D2 | D4 | D8 |
| 697 | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 0 | 1 | 1 |
| 770 | 0 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 1 |
| 852 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 |
| 941 | 1 | 1 | 0 | 1 | 0 | 1 | 0 | 1 | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 |

## Outputs (continued)

example, for digit 1, D1/697 Hz and 1209 Hz outputs will go low when detected. All other outputs remain high.
When the binary format is selected (BIN input is held low), the high-group outputs operate as described above. The low-group outputs (D1/697 Hz, D2/770 $\mathrm{Hz}, \mathrm{D} 4 / 852 \mathrm{~Hz}$ and $\mathrm{D} 8 / 941 \mathrm{~Hz}$ ) provide the binary coded information. These binary outputs are normally low and go high when a tone is detected. The outputs are defined by the above matrix:

- Strobe (ST) - This output indicates when the output data are valid. Validity is defined as detection within 39 ms or 33 ms depending upon the level of Strobe Control. For a description of the operation, refer to the inputs BIN and SC and figure 4.
- Silence Reset (SIL) - This output pulses to a low level when silence is detected. This occurs 9 ms after the interruption of a signal on either high- or low-group inputs. This output can be used to reset any external logic or to exercise the Output Hold option. The chip will reset itself after the Silence Reset output returns to a high level. Silence reset pulses at 10 ms intervals until a signal is present on either $\mathrm{F}_{\mathrm{L}}$ or $\mathrm{F}_{\mathrm{H}}$.
- Audio Detect (AUD) - Audio is defined as energy carried by any frequency lower than 1680 Hz . AUD remains low when both FL and FH are low; AUD will go high if either FL or FH is toggling and will return to a low level as soon as Silence Reset returns from a low to a high level. This output may be used to control the admissible level in the Front-End circuitry (off-chip) or to give advance notice of a tone-pair.
- Test Output (X0) - When using the 3.579545 MHz crystal on-chip oscillator, X0 will display a 447.443 kHz clock. If the 447.443 kHz external oscillator option is utilized, X0 will display a 55.930 kHz clock. The X0 output frequency will be the X 1 input frequency divided by 8.
- Clock Outputs (C2, C16, C32) - These outputs will generate $2 \mathrm{kHz}, 16 \mathrm{kHz}$ and 32 kHz clocks, respectively.


## DTMF Receiver Design

The CRC 8030, in conjunction with a front-end analog filter/limiter, implements a complete DTMF receiver.

Figure 2 illustrates this design. With this approach, a central-office-quality receiver with the following specification can be implemented:

- Input Dynamic Range . . . . . . . . -26 dBm to +6 dBm
- Twist. . . . . . . . . . . . . . . . . . . . . . . . . 8 dB to +4 dB
- Valid Tone Tolerance . . . . . . . . . . . . . . . . . . . $\pm 1.5 \%$
- Invalid Tone Reject Limit . . . . . . . . . . . . . . . . $\pm 3.5 \%$
- Tone Burst (minimum) . . . 40 ms ON, 11 ms OFF at 12 bursts per second
Inasmuch as the front-end filter is an essential part of the total receiver, its characteristics have a major impact on the performance of the system. For example, for high-quality central-office receivers, a more selective front-end filter is required. Conversely, low-noise environment keyphone systems will operate with a less stringent front-end filter design. In view of the differences in specifications for DTMF receivers, the front-end design must be tailored for the particular application. Several manufacturers have off-the-shelf hybrid products which meet these filtering requirements. For more details concerning these design considerations, refer to the Collins "Application Note CRC 8030 Telephone DTMF Receiver".

For specialized applications, the CRC 8030 has several mask programmable features. The parameters that can be programmed include the bandwidth, detection time, strobe time, silence time, and output decode format. Contact Collins Applications Engineering for details.

## Packaging and Ordering Information

The DTMF Detector is available in a 28 -pin, hermetically sealed ceramic dual-in-line package and in a 28 -lead ceramic chip carrier (see pin assignments and package dimension diagrams). Order by type number.
CRC 8030-1-3 (ceramic DIP) . . . . 765-5795-001
CRC 8030-4-3 (ceramic carrier) . . . 765-5795-003
For further information on Rockwell MOS/LSI Standard Products, call your local Rockwell Sales office or:

MOS/LSI Marketing<br>Rockwell International<br>Microelectronic Devices 3310 Miraloma Avenue Anaheim, California 92803<br>Telephone (714) 632-2558<br>TWX 910-591-1698



## MOS/LSI TELECOMMUNICATIONS DEVICES DATA SHEET

## T-1 TRI-PORT MEMORY

## OVERVIEW

The Tri-Port Memory circuit is designed to function as an assembly point and temporary storage area for 8 -bit T-1 data. It provides 648 -bit locations of on-chip random access memory which can be accessed via external addresses or internal sequential addressing.

## TRI-PORT MEMORY OPERATION

The Tri-Port Memory device accepts 8 -bit parallel input data on lines $A$ through $H$. This data is stored in an internal memory location that is selected by either random address lines R01 through R32 or by the device's Sequential Address Counter. Write Select signal WSEL determines the source of the address; in the logic 0 state, WSEL selects the random address, in the logic $\mathbf{1}$ state, WSEL selects the internat sequential address.

The state of Write Enable signal $\overline{W E}$ determines whether or not the data on lines A through $H$ will be written into memory. Data will only be written into memory when $\overline{W E}$ goes low (to a logic 0 state) and the address inputs have stabilized.

The on-chip, six-bit Sequential Address Counter is a binary counter that increments on each positive transition of Sequential Clock (SCLK). When the Counter attains binary 111111, the next positive transition on SCLK will clear it to binary 000000 . The Counter will also be cleared unconditionally if Reset signal $\overline{R S T}$ has been set to logic $\mathbf{O}$ when the positive transition of SCLK occurs.

The Sequential Read Enable signal, $\overline{\operatorname{SRE}}$, enables sequentiallyaddressed read operations. If $\overline{\operatorname{SRE}}$ is logic 0 , the sequential accessed data outputs (SA through SH) will become valid within 430 ns after the next positive transition on SCLK. If $\overline{\text { SRE }}$ is logic 1, and 350 ns have elapsed since the positive transition of SCLK, the sequential accessed data outputs will become valid 80 ns after the negative transition of $\overrightarrow{S R E}$. The Sequential Read Data will cease to be valid within 100 ns after the positive transition of $\overline{S R E}$, or within 340 ns after the negative transition of $\overrightarrow{W E}$ (in the case of a same-location read/write cycle), or within 430 ns after the next positive transition of SCLK.

The Random Read Enable signal, $\overline{R R E}$, enables random-accessed read operations. If $\overline{\mathrm{RRE}}$ is logic 0 , the random accessed data outputs (RA through RH) will become valid within 380 ns after the random address lines have stabilized. If $\overrightarrow{\operatorname{RRE}}$ is logic 1 , and 300 ns have elapsed since the random address lines have stabilized, the random accessed data outputs will become valid 80 ns after the negative transition of $\overline{\operatorname{RRE}}$. The random accessed data outputs cease to be valid after a positive transition of $\overline{\text { RRE }}$, or within 340 ns after the negative transition of $\overline{\mathrm{WE}}$ (in the case of a same-location read/write cycle) or within 380 ns after the random address input lines change.

## FEATURES

- $64 \times 8$ bit static memory
- Single +5 V supply
- Two totally independent read ports
- Multiple Read access time <430 ns (worst case)
- Selectable random-or sequential-address Write operation
- On-chip sequential address counter
- Tri-state drivers, for chip-selectable bus operation
- 40-pin plastic dual in-line package
- LSTTL Schottky-compatible (12K $\Omega$ pullup, to drive CMOS)

| R04 | 1 1葍 | 40 | حصم |
| :---: | :---: | :---: | :---: |
| R08 | 2 | 39 | R01 |
| R16 | 3 | 38 | E AST |
| R32 | 4 | 37 | $\square \mathrm{scLk}$ |
| WSEL | 5 | 36 | $\square \mathrm{N} . \mathrm{C}$. |
| WE | 6 | 35 | $\square \mathrm{VDD}$ |
| RH | 7 | 34 | N.c.* |
| RG | 8 | 33 | SH |
| GND | 9 | 32 | $\square \mathrm{sG}$ |
| RF | 10 | 31 | $\square \mathrm{SF}$ |
| RE | 11 | 30 | SE |
| RD | 12 | 29 | $\square \mathrm{SD}$ |
| RC | 13 | 28 | $\square \mathrm{sc}$ |
| RB | 14 | 27 | $\mathrm{SB}_{5}$ |
| RA | 15 | 26 | $\square S$ |
| BRE | 16 | 25 | $\underline{\text { SRE }}$ |
| A | 17 | 24 |  |
| C | 18 | 23 | Q |
| E | 19 | 22 | F |
| G | 20 | 21 | $\mathrm{P}^{\text {+ }}$ |

*PIN 34 HAS AN OUTPUT SIGNAL APPLICABLE ONLY TO ROCKWELL TESTING. MAKE NO CONNECTION TO THIS PIN


RANDOM READ


RANDOM WRITE


SEQUENTIAL READ


SEQUENTIAL WRITE


READ PORT ENABLES ( $\mathrm{t}_{\mathrm{PE}} / \mathrm{t}_{\mathrm{PD}}$ )


SEQUENTIAL COUNTER RESET


## WRITE ENABLE AND WRITE SELECT TIMING



Timing Characteristics

| Parameter | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Random Read Access Time | ${ }^{\text {tra }}$ |  |  | 380 | ns |
| Sequential Read Access Time | ${ }^{\text {t }}$ SA |  |  | 430 | ns |
| Random Read Address Setup Time | ${ }^{\text {t }}$ AS |  |  | 380 | ns |
| Read Port Disable (to Hi Z) | ${ }^{\text {tPD }}$ |  |  | 100 | ns |
| Read Port Enable | tPE |  |  | 80 | ns |
| $\overline{\text { WE Pulse Width }}$ | twp | 170 | 300 |  | ns |
| WE Pulse Delay | tWE1 | 300 |  |  | ns |
| WE Pulse Setup | twe2 |  |  | 0 | ns |
| SCLK Pulse Width | ${ }^{\text {t }} \mathrm{P}$ | 220 | 325 |  | ns |
| SCLK Frequency | $f$ |  | 1.544 |  | MHz |
| Write Data Setup Time | tws |  |  | 150 | ns |
| Write Data Hold Time | ${ }^{\text {tw }}$ W | 100 |  |  | ns |
| Write Select Setup Time | ${ }^{\text {t }}$ S |  |  | 280 | ns |
| Write Select Hold Time | ${ }_{\text {t }} \mathrm{H}$ | 0 |  |  | ns |
| $\overline{\text { RST }}$ Setup Time | ${ }^{\text {t }}$ RS |  |  | 180 | ns |
| RST Hold Time | ${ }^{\text {tRH }}$ | 0 |  |  | ns |

## SPECIFICATIONS

Maximam Ratings

| Rating | Symbol | Voltage | Unit |
| :--- | :--- | :--- | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{DD}}$ | +4.75 to +5.25 | V |
| Operating Temperature Range | $\mathrm{T}_{\mathrm{OP}}$ | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $\mathrm{T}_{\text {STG }}$ | .55 to +150 | ${ }^{\circ} \mathrm{C}$ |

All inputs contain protection circuitry to prevent damage due to high static charges. Care should be exercised to prevent unnecessary application of voltage outside the specification range.

## Electrical Characteristics

$\left(V_{D D}=+5 \mathrm{~V} \pm 5 \%, V_{S S}=0 V_{A}=25^{\circ} \mathrm{C}\right)$

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Input Logic "1" Voltage | $\mathrm{V}_{1 \mathrm{H}}$ | 2.0 |  | V |
| Input Logic " 0 " Voltage | $V_{\text {IL }}$ |  | 0.8 | V |
| Output Logic "1" Voltage | $\mathrm{v}_{\mathrm{OH}}$ | 2.4 |  | $v$ |
| Output Logic "0" Voltage | $\mathrm{V}_{\mathrm{OL}}$ |  | 0.4 | $v$ |
| Output Source Current | ${ }^{1} \mathrm{OH}$ | -100 |  | $\mu \mathrm{A}$ |
| Output Sink Current | ${ }^{1} \mathrm{OL}$ | 400 |  | $\mu \mathrm{A}$ |
| Input Capacitance | $c_{1}$ |  | 5 | pF |
| Output Capacitance | $\mathrm{C}_{0}$ |  | 25 | pF |
| Power Dissipation (at $25^{\circ} \mathrm{C}$ ) | $\mathrm{P}_{\text {DSS }}$ |  | 300 | mW |



NOTE: Pin No. 1 is in lower teft corner when symbolization is in normal orientation

## Packaging Diagram

## SPECIFICATIONS

Maximam Ratings

| Rating | Symbol | Voltage | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\text {DD }}$ | +4.75 to +5.25 | V |
| Operating Temperature Range | ${ }^{\text {OP }}$ | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $\mathrm{T}_{\text {STG }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

All inputs contain protection circuitry to prevent damage due to high static charges. Care shoald be exercised to prevent unnecessary application of voltage outside the specification range.

## Electrical Characteristics

$\left(V_{D D}=+5 \mathrm{~V} \pm 5 \%, V_{S S}=0 V_{A}=25^{\circ} \mathrm{C}\right)$

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Input Logic "1" Voltage | $V_{\text {IH }}$ | 2.0 |  | $v$ |
| Input Logic ' 0 '" Voltage | $V_{\text {IL }}$ |  | 0.8 | v |
| Output Logic " 1 " Voltage | $\mathrm{v}_{\mathrm{OH}}$ | 2.4 |  | V |
| Output Logic "0' Voltage | $\mathrm{v}_{\mathrm{OL}}$ |  | 0.4 | V |
| Output Source Current | ${ }^{1} \mathrm{OH}$ | -100 |  | $\mu \mathrm{A}$ |
| Output Sink Current | ${ }^{1} \mathrm{OL}$ | 400 |  | $\mu \mathrm{A}$ |
| Input Capacitance | $C_{1}$ |  | 5 | pF |
| Output Capacitance | $\mathrm{C}_{0}$ |  | 25 | pF |
| Power Dissipation (at $25^{\circ} \mathrm{C}$ ) | ${ }^{\text {P DSS }}$ |  | 300 | mW |



NOTE: Pin No. 1 is in lower left corner when symbolization is in normal orientation

## Packaging Diagram

## T-1 SERIAL TRANSMITTER

## GENERAL DESCRIPTION

The Rockwell T-1 Serial Transmitter formats data to be serially transmitted according to T-1 D2 or T-1 D3 specifications, inserting framing and signalling bits along with 24 channels of 8 -bit channel data. The T-1 Serial Transmitter also provides for alarm reporting via the Bit 2 inhibit method or, with minimal external logic, via the multiframe alignment signal ( $F_{S}$ ) modification.

Figure 1 is a functional block diagram of the T-1 Serial Transmitter. The Mod 193 counter is driven by the clock at 1.544 MHz and is either synchronized to the driving system by input signal SYNCIN or provides synchronization via output signal SYNOUT. Input signal FRSYNC applies synchronization to a Mod 12 counter, which identifies the frame of the 12 -frame multiframe being processed.

The input data register latches data during each bit period, when the 8 th bit of a channel sample is being transmitted. The data selector outputs the proper sequence of bits, as controlled by a bit count and frame count.

The zero channel monitor function causes Bit 8 or Bit 7 (as selected by B7OPTN) to be transmitted as a "one" if the channel data sample is all "zeros" for any frame except signalling frame (Frame 6 or 12). Input INH provides a means to inhibit the zero channel monitor function.

Two types of transmit formats are provided, a binary output and a paired unipolar output. The unipolar pair provides a means to externally create a single bipolar output with minimal logic.


Pin Configuration

## FEATURES

- Single 5V supply, low power Schottky TTL compatible
- Accepts 8 bits of parallet data as input
- Generates output as 193 bit serial data stream in T-1, D2 or T-1, D3 data format
- Provides a channel and frame timing signal.
- Provides alternate control for alarm reporting and signalling
- Provides automatic bit insertion for all zero channel samples.


Figure 1. T-1 Serial Transmitter

## T-1 Transmitter Inputs

Any input $\leq 0.8 \mathrm{~V}=$ logic 0 , low. Any input $\geq 2.0 \mathrm{~V}=$ logic 1 , high. The transition from a low level to a high level is called a rising edge, while the converse is defined as a falling edge.

## FRSYNC: Frame Synchronization

Frame sync allows the user to force the frame counter to the frame count of 1. (The first frame of a possible 12.) When high, FRSYNC directly sets the frame count to be frame 1. If FRSYNC does not return to zero before the rising edge of CLOCK, BINOUT, UNPLRA are transmitted high and UNPLRB is transmitted low. Refer to Figure 6 and Figure 7.

## SYNCIN: Synchronization Input

Provides a means to directly reset the Mod 193 bit counter to a bit position corresponding to the first bit of channel 1 . The high level causes the reset. The first bit of channel 1 will be transmitted following the release of SYNCIN.

## TEST: Rockwell Device Test Input

Used only for Rockwell device testing. Keep this input grounded.

## CLOCK: T-1 Clock

Maximum frequency $=1.6 \mathrm{MHz}$
Minimum pulse width $=\mathbf{2 7 5} \mathrm{ns}$
The T-1 bit period is bounded by the rising edges of this input.

## INH: Inhibit Zero Channel Monitor

If INH is high, the zero channel monitor function is disabled, and Bits 7 and 8 are transmitted per corresponding inputs received. See Table 1.

For any frame except a signalling frame (Frame 6 or 12) Bit 8 or. Bit 7 as selected by B7OPTN will be transmitted as a "one" if the channel input data is "zero" and INH is low.

BITS 1-8: Paraliel Channel Data Inputs
Bit 1, the sign bit, will be serially transmitted first, followed by Bits 2 through 8. The falling edge of CHCLKF indicates input channel data has been clocked into the input register and always occurs during the transmission of the final bit (Bit 8) of each channel data sample.

ACH: "A" Channel Highway Signalling
ACH allows the user to transmit a one bit of signalling per channel as Bit 8 of each channel data sample in Frame 6 only. ACH is clocked into the input register by the falling edge of CHCLKF. Refer to Table 1 and $\mathbf{F i g u r e} 4$.

## BCH: "B" Channel Highway Signalling

BCH allows the user to transmit a one bit of signalling per channel as Bit 8 of each channel data sample in Frame 12 only. BCH is clocked into the input register by the falling edge of CHCLKF. Refer to Table 1 and Figure 4.

## S-BIT: Multiframe Signalling Bit

SBIT, in conjunction with CCIS, provides an alternate way to control the multiframe signalling bit ( $F_{S}$ ) transmission. The S-Bit input is transmitted as the multiframe signalling bit ( $\mathrm{FS}_{\mathrm{S}}$ ) if CCIS is held high. Refer to Table 2.

## ALARM: Local Alarm

Used for reporting alarm conditions. If the ALARM signal is high, Bit 2 (the most-significant bit) of every channel data sample of every frame is transmitted as a zero. This is commonly called remote alarm signalling. ALARM is clocked into the input register by the falling edge of CHCLKF. Refer to Table 1 and Figure 4.

## LOOP: Loop Strap

Provided to aid testing of user applications. When enabled to a high level, LOOP forces the unipolar outputs to transmit alternating ones and zeros, regardless of input conditions. Refer to Figure 3.

## CCIS: Common Channel Interoffice Signalling Strap

Provides optional control for transmitting an alternate multiframe (even-numbered frames) signalling pattern via the S-Bit input. Automatically programmed S-Bit ( $\mathrm{F}_{\mathrm{S}}$ ) transmission following Table 2 is achieved by holding CCIS at a low level.

## B70PTN: Bit 7 Option

Provides Bit 7 as an alternate bit position for "one" stuffing, as programmed by the zero channel monitor function. Refer to Table 1.

VSS, VDD: Ground and Power
VDD $=+5 \pm 0.5 \mathrm{Vdc}$
VSS = Ground, 0 Vdc

## T-1 Transmitter Outputs

Low power TTL Schottky compatible. " 1 " $\geq 2.4 \mathrm{Vdc},{ }^{\prime \prime} 0$ " $\leq 0.4 \mathrm{Vdc}$, $C_{L .} 25 \mathrm{pf}$.

## SSTB: $\mathbf{4 k H z}$ Signalling Channel Strobe

SSTB is the least-significant bit of the frame counter. Unless it is directly set by FRSYNC, SSTB will go high as each framing bit ( $F_{T}$ ) is serially transmitted, and will return low as each multiframe alignment signal ( $F_{S}$ ) is transmitted. Refer to Figure 2.

## SYNOUT: Channel Sync Output

SYNOUT provides a means to synchronize to the internal bit counter (Mod 193). SYNOUT is high for one bit time, beginning just prior to the first data bit of a frame being serially transmitted. Refer to Figure 8 .

## CHCLKF: Channel Clock False

The falling edge of CHCLKF, occurring as Bit 8 of any channel is being serially transmitted, indicates input data has been clocked into the input register. With the exception of an extra bit period extending the low level duration at frame bit time, CHCLKF is a divide-by-eight of CLOCK. Refer to Figure 2.

## BINOUT: Serial Data Output, Binary Formatted

BINOUT is the binary formatted serial conversion of the parallel input data. The programmed format of BINOUT follows Table 1 and 2.

BINOUT is synchronously transmitted as a high level if FRSYNC remains during the rising edge of CLOCK. Refer to Figure 6 and 7.

## UNPLRA, UNPLRB: T-1 Serial Data Unipolar Outputs

Two paired unipolar outputs are provided for the purpose of creating a single serial data output transmission in bipolar format. The unipolar output register toggles for each "one" bit to be serially transmitted. UNPLRA and UNPLRB are transmitted as complements for "one" data bits and as low levels for "zero" data bits. See Figure 3.

The input signal loop, if high, forces the unipolar outputs to toggle every bit time, regardless of input data.

FRSYNC perturbs the current bits being transmitted by UNPLRA and UNPLRB. If FRSYNC remains high during the rising edge of CLOCK, UNPLRA will be transmitted as a high level and UNPLRB will be low. Refer to Figures 6 and 7.

Table 1. Serial Output Data Processing for Channel Sample Data (Not $\mathbf{F}_{\mathbf{T}}$ or $\mathbf{F}_{\mathbf{S}}$ )
BINOUT representing the serial data out will be a " 1 " if the below equations are true.

| SERIAL DATA BIT TO BE TRANSMITTED (NEXT BINOUT) | $\begin{aligned} \text { FRAME } & =6 \\ \text { OR FRAME } & =12 \\ \text { AND CCIS } & =0 \end{aligned}$ | $\begin{aligned} & \text { CCIS }=1 \text { AND } \\ & \text { ANY FRAME (2) } \end{aligned}$ |
| :---: | :---: | :---: |
| 1st | Bit $1=1$ (1) | Bit $1=1$ |
| 2nd | $82=1$ (see equation below) | B2 $=1$ |
| 3 rd | Bit $3=1$ | Bit $3=1$ |
| 4th | Bit 4 $=1$ | Bit $4=1$ |
| 5th | Bit $5=1$ | Bit $5=1$ |
| 6th | Bit $6=1$ | Bit $6=1$ |
| 7th | Bit 7 or $B 7 X=1$ | $B 7=1$ |
| 8th | Bit 8 or $88 \mathrm{X}=1$ | $\mathrm{Sig}=1$ |

(1) Terms Bit 1 thru Bit 8, ACH, BCH and ALARM are the clocked data from the paraltel data input register. All other terms are either complex equation terms or unstored device inputs.
(2) If CCIS = 1 the T-1 transmitter can not uniquely identify Frame 6 or Frame 12.
$B 2=B I T 2 \cdot \overline{A L A R M}$
$\mathrm{B7}=\mathrm{BIT7}+\overline{\mathrm{SIG}} \cdot \overline{\mathrm{BIT1}} \cdot \overline{\mathrm{B2}} \cdot \overline{\mathrm{BIT3}} \cdot \overline{\mathrm{BIT4}} \cdot \overline{\text { BIT5 }} \cdot \overline{\mathrm{BITG}} \cdot \overline{\mathrm{INH}}$
$\mathrm{Sig}=\mathrm{ACH} \cdot \mathrm{FRAME}=6+\mathrm{BCH} \cdot \mathrm{FRAME}=12$
$\mathrm{B7X}=\mathrm{B7OPTN} \cdot \overline{\mathrm{BIT1}} \cdot \overline{\mathrm{B2}} \cdot \overline{\mathrm{BIT3}} \cdot \overline{\mathrm{BIT4}} \cdot \overline{\mathrm{BIT5}} \cdot \overline{\mathrm{BIT6}} \cdot \overline{\mathrm{INH}} \cdot \overline{\mathrm{BIT}}$
$\mathrm{B} 8 \mathrm{X}=\overline{\mathrm{B} 7 \mathrm{OPTN}} \cdot \overline{\mathrm{BIT1}} \cdot \overline{\mathrm{B2}} \cdot \overline{\mathrm{BIT3}} \cdot \overline{\mathrm{BIT4}} \cdot \overline{\mathrm{BIT5}} \cdot \overline{\mathrm{BIT6}} \cdot \overline{\mathrm{INH}} \cdot \overline{\mathrm{BIT7}}$

Table 2. Serial Output Data Processing for Framing Bits $\mathrm{F}_{\mathbf{T}}, \mathrm{F}_{\mathbf{S}}$

| CURRENT FRAME NUMBER | REPRESENTED BIT | BINOUT BECOMES A "1" IF: (UNLESS STATED OTHERWISE) |
| :---: | :---: | :---: |
| 1 | $F_{S}$ | SBIT and CCIS = 1 |
| 2 | $\mathrm{F}_{T}$ |  |
| 3 | $F_{S}$ | SBIT and CCIS = 1 |
| 4 | $F_{T}$ | "1" |
| 5 | $\mathrm{F}_{S}$ | SBIT $=1$ or CCIS $=0$ |
| 6 | $\mathrm{F}_{\text {T }}$ | " 0 " |
| 7 | $F_{S}$ | SBIT $=1$ or $\mathrm{CCIS}=0$ |
| 8 | $\mathrm{F}_{\text {T }}$ | "1" |
| 9 | $\mathrm{F}_{S}$ | SBIT $=1$ or CCIS $=0$ |
| 10 | $\mathrm{F}_{T}$ | " 0 " |
| 11 | $\mathrm{F}_{S}$ | SBIT and CCIS $=1$ |
| 12 | $\mathrm{F}_{T}$ | " 1 " |

$F_{T}=$ Framing Bit
$F_{S}=$ Multiframing Alignment Bit
NOTE: $F_{T}$ Bit insertion is automatic and no optional control is provided.

Table 3. Input Timing

|  |  | MIN | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: |
| ${ }^{\text {t }}$ 1s | Buffered Data Setup Time | 450 |  | ns |
| ${ }_{1} \mathrm{H}$ | Buffered Data Hold Time | 0 |  | ns |
| ${ }^{t} 2 \mathrm{~S}$ | Control Input Setup Time | 400 |  | ns |
| ${ }^{t_{2}}$ | Control Input Hold Time | 20 |  | ns |
| ${ }^{1} 3 \mathrm{~S}$ | Asynchronous Control Input Setup Time | 350 |  | ns |
| ${ }^{1} 3 \mathrm{H}$ | Asynchronous Control Input Hold Time | 20 |  | ns |
| ${ }^{t} 4 \mathrm{~S}$ | SYNCIN Setup Time | 200 |  | ns |
| ${ }^{1} 4 \mathrm{H}$ | SYNCIN Hold Time | 20 |  | ns |
|  | SYNCIN Pulse Width | 100 |  | ns |
| ${ }^{\text {t }}$ S | Frame Sync Setup Time (Return to Zero) | 250 |  | ns |
| ${ }^{\text {t }} 5$ | Frame Sync Hold Time (Return to Zero) | 20 |  | ns |
|  | Frame Sync Pulse Width | 200 |  | ns |
| ${ }_{5}{ }_{5}$ | Frame Sync Setup Time (Non-Return to Zero) | 525 |  | ns |
| ${ }^{1} 5 \mathrm{H}$ | Frame Sync Hold Time (Non-Return to Zero) | 20 |  | ns |



Figure 2. T-1 Transmitter Output Signal Relationship


Figure 3. T-1 Transmitter Binary, Unipolar Format

| NEXT BIT |  |  |  |  |
| :--- | :---: | :---: | :---: | :---: |
| TRANSMITTED | 8TH | 1ST OR FT OR F |  | 2ND OR 1ST | 3RD OR 2ND


| BIT BEING <br> TRANSMITTED$\quad$ 7TH |
| :--- |



Figure 4. Input Timing Relationships


Figure 5. SYNCIN Timing Relationship


Figure 6. Return to Zero Frame Sync Application


Figure 7. Non-Return to Zero Frame Sync Application

Table 4. Output Propagation Delay, Worst Case (Measured from Rising Edge of Clock Unless, Stated Otherwise)

| OUTPUT | MAX DELAY | UNIT |
| :---: | :---: | :---: |
| SSTB | 500 | ns |
| SYNOUT | 500 | ns |
| Ref from Falling |  |  |
| Edge of Clock | 500 | ns |
| CHCLKF | 500 | ns |
| BINOUT | 500 | ns |
| UNPLRA | 500 | ns |
| UNPLRB |  |  |



Figure 8. SYNOUT Signal Relationship

## SPECIFICATIONS

Maximum Ratings

| Rating | Symbol | Value | Unit |
| :--- | :--- | :--- | :--- |
| Supply Voltage | $V_{\text {DD }}$ | +4.5 to +5.5 | Vdr |
| Operating Temperature | $T_{\text {OP }}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $T_{\text {STG }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

This device contains input protection against damage due to high static voltages or electric fields; however, precautions should be taken to avoid application of voltages higher than the maximum rating.

## Electrical Characteristics

( $V_{\text {DD }}=5.0 \pm 5 \%$ )

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Logical "1" Input Voltage | $\mathrm{v}_{\mathrm{OH}}$ | 2.0 | $\mathrm{V}_{\text {DD }}+0.3$ | v |
| Logical '0' Input Voltage | $V_{\text {IL }}$ | -0.3 | 0.8 | V |
| Logical "1" Output Voltage | $\mathrm{v}_{\mathrm{OH}}$ | 2.4 | - | V |
| Logical '0" Output Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V |
| Output Source Current | ${ }^{1} \mathrm{OH}$ | . 100 | - | $\mu \mathrm{A}$ |
| Output Sink Current | ${ }^{\prime} \mathrm{OL}$ | 400 | - | $\mu \mathrm{A}$ |
| Capacitance Load | C | - | 25 | pF |
| Input Capacitance (any input) | $C_{\text {IN }}$ | - | 5 | pF |
| Clock Frequency |  | - | 1.6 | MHz |
| Power Dissipation | $P_{\text {D }}$ | - | 250 | mw |



# PART NUMBERS R8060，R8060A 



## T－1 SERIAL RECEIVER

## DESCRIPTION

The Rockwe！ T－ 1 Receiver processes serial unipolar data of a T－1，D2 or T－1，D3 line from which data and a 1.544 MHz clock have been extracted．

Frame synchronization is accomplished by locating the frame bit （ $\mathrm{F}_{\mathrm{T}}$ ）alternating every 386 bits．Loss of frame sync is indicated if a frame bit error occurs within two to four F．Bit frames since the previous frame bit error．

A loss of carrier is indicated if 31 consecutive bit times vield ＂zeros＂at the input．Carrier loss is reset and frame sync search begins when a＂one＂reappears at the TDATA input．

Signaling bits，which occur 193 bit positions after a framing bit， are monitored to detect signaling frames．The signaling frame output．SIGFR，identifies the present frame as a signaling frame， and the S－Bit output at that time identifies which signaling frame is being processed．

Remote alarm reporting is detected by monitoring the second received bit of every channel sample of every frame．An alarm is indicated if 255 consecutive Bit 2 zeros are received．

Channel data bits are output by an eight－bit parallel register．The rising edge of the signal called channel clock（CHCLK）indicates the extraction of new output channel data．

Several signals developed from a MOD 386 counter are provided to aid in the external processing and storage of channel data． Signals are provided to increment counters，synchronize counters， strobe data into memories，etc．

The Rockwell T－1 Receiver chip operates on a single 5 volt supply and directly interfaces to the low power TTL Schottky logic family．The Receiver is packaged in a 28 pin dual in－line（DIP）．

Timing relationships are given in figures 3 through 5.

## FEATURES

－Synchronizes serial T－1，D2 or T－1，D3 signals in less than 5 ms ．
－Extracts 8 bit parallel channel data
－Provides timing signals to capture and synchronize channel and frame information
－Monitors and detects
－Errors in signaling bit pattern
－Loss of frame sync
－Loss of carrier
－－Remote alarm reporting
－Single 5V supply
－LSTTL Schottky compatible


Pin Configuration

## ORDERING INFORMATION

The T－1 Serial Receiver is available in two versions．With the standard commercial version，R8060，data will be stable within 900 ns after the bit clock．With the selected version，R8060A， data will be available within 600 ns after the bit clock．


Figure 1．R8060 Block Diagram

## T-1 RECEIVER INPUTS

Any input $\leq 0.8 \mathrm{~V}=$ LOGIC 0, LOW, ZERO. Any input $\geq 2.0 \mathrm{~V}=$ LOGIC 1. HIGH, ONE. A transition from a low level to a high level is called a rising edge, while the converse is true for the falling edge.

## TDATA: UNIPOLAR T-1-D2, T-1-D3 SERIAL DATA INPUT

Unipolar T-1 Data is clocked in on the falling edge of TCLK. Thereafter, TDATA is processed on the rising edge of TCLK. TDATA must be stable 100 ns before and remain stable 100 ns after the falling edge of TCLK.

## TCLK: T. 1 CLOCK

Typical clock frequency is 1.544 MHz . Maximum clock frequency is 1.85 MHz . The T .1 bit period is bounded by the rising edges of TCLK.

## SYNCEN: FRAME SYNCHRONIZATION ENABLE

Provides a means to disable the automatic resync search initiated by a FRAME ALARM condition. If the SYNCEN signal is low. the synchronization function is inhibited and remains inhibited until SYNCEN transitions high. SYNCEN must be stable 200 ns before the rising edge of FRALRM, in order to inhibit the synchronization function.

## MR: MASTER RESET

Master Reset, when low, performs an initialization clear of the T-1 Receiver; SBALRM and CALRM are reset to low levels while FRALRM, CHCLK, WIHBT and CHSYNC are set to high levels. Frame synchronization search begins on the rising edge of $\overline{M R}$ provided that SYNCEN signal has been high for 200 ns . Minimum pulse width is one T-1 clock period.

## CDINH: CHANNEL DATA INHIBIT

Provides a means to disable channel data bit outputs. When at a high level, CDINH forces channel data Bits 1 through 7 high. Bit 8, the least significant channel data bit, is not controlled by CDINH.

## TESTI: ROCKWELL DEVICE TEST INPUT

Used only for Rockwell device testing, no connection to TESTI is required for normal operation.

## VSS, VDD: GROUND AND POWER

$V D D=+5.0 \pm 0.25 \mathrm{VDC}$
VSS = Ground, 0 VDC

## T-1 RECEIVER OUTPUTS

```
Low Power TTL Schottky - compatible
"1"\geq2.4 Vdc;"0"\leq0.4 Vdc
CMOS - 12 K \Omega pullup to VDD required.
```


## CDB (1.8): CHANNEL DATA BIT 1 THROUGH 8

Bit 1 is the sign bit, Bit 2 is the most significant bit and Bit 8 is the least significant bit. If CDINH is low, new parallel channel data becomes valid within 200 ns after the rising edge of CHCLK and remains valid until the next rising edge of CHCLK. If CDINH is high, channel data Bits 1 through 7 are forced to a nigh level. Bit 8, the least significant bit, is not controlled by CDINH. Channel data Bits 1 through 7 are enabled or disabled within 300 ns (R8060) or 150 ns (R8060A) by CDINH. Refer to Figures 3 through 5.

The rising edge of CHCLK indicates a change of parallel output channel data. CHCLK is four TCLKS high then four TCLKS low except for when an " $F$ "" or " S " bit is received. Then CHCLK stretches to five TCLKS high and four TCLKS low. Refer to Figures 3 and 4.

## CHSYNC: CHANNEL SYNC

Channel Sync occurs one time in a 24 channel period, making it suitable for synchronizing external counters to the T-1 Frame rate. CHSYNC goes low one TCLK period before the falling edge of CHCLK at channel 24 date sample time. CHSYNC returns high 1 TCLK period after the next rising edge of CHCLK. Refer to Figures 3 through 5.

## TESTO: ROCKWELL DEVICE TEST OUTPUT

Designed to aid in Rockwell device testing. No connection required for normal operation.

## WIHBT: WRITE INHIBIT

WIHBT covers the parallel channel data transition period. WIHBT is suitable for clocking or strobing channel data into external memories. WIHBT is high for two TCLK periods, beginning one TCLK period before the rising edge of CHCLK. Refer to Figures 3 and 4.

## MAXCNT: MAXIMUM COUNT OF 386 MODULUS

$\overline{M A X C N T}$ is low for one TCLK period, marking the completion of a two-frame period corresponding to the expected receipt of an $F$-bit at the TDATA input. Refer to Figures 4 and 5.

## SBCLK: S-BIT CLOCK

SBCLK will be high during the S-Bit frame and low during the F-bit frame. The transitions will occur within 300 ns after the rising edge of TCLK as channel 24 data is being transferred to the parallel channel outputs. Refer to Figures 3 through 5.

## S-BIT: SIGNALING BIT OUTPUT

The S-Bit output monitors the previous S-Bit received which occurred two frames before the receipt of the current S-Bit. An S-Bit output transition occurs one TCLK period after the rising edge of SBCLK.

During a signaling frame (SIGFR is low), frame 6 or " $A$ " highway signaling is identified by S -Bit output being low. If S -Bit is high during a signaling frame, frame 12 or " $B$ " highway signaling is identified. Refer to Figures 3 through 5.

## $\overline{\text { SIGFR: SIGNALING FRAME }}$

$\overline{\text { SIGFR }}$ identifies frame 6 or 12 when low. If the sequence of five consecutive received S-Bits is either 0111X or $1 \times 001$ lleft to right, as received), $\overline{\operatorname{SiGFR}}$ shall go low after the rising edge, but at least 375 ns before the falling edge of WIHBT corresponding to channel 1 data sample time. $\overline{\text { SIGFR returns high one frame later }}$ ( 193 bits). Refer to Figures 3 through 5.

## SBALRM: S-BIT ALARM

SBALRM goes high if the sequence of five S-Bits received contains four consecutive ones (01111), and remains high until three consecutive "zero" bits are preceded and followed by a "one" S-Bit (10001). The actual transition of SBALRM output occurs after the rising edge, but at least 375 ns before the falling edge of WIHBT corresponding to channel 1 data sample time.

## B2ALRM: BIT 2 ALARM

B2ALRM goes high, detecting a remote alarm condition, if 255 consecutive channel data samples are received with Bit 2 low. B2ALRM returns low upon the receipt of any channel sample with Bit 2 high.

## CALRM: CARRIER LOSS ALARM

A carrier loss is detected and CALRM is set high if 31 consecutive low leve! TDATA bits are received. CALRM is reset low, FRALRM is set high and frame sync search begins when the first TDATA high level is received

FRALRM: FRAME ERROR ALARM

FRALRM detects an out-of-frame condition. FRALRM goes high if:
A) The framing synchronization function is in progress.
B) Within 250 ns after the falling edge of MR.
C) An F-Bit is received which is not the inverse of the last F-Bit and the same condition also occurred two or three or four F-Bit frames earlier.
D) Within 250 ns after the falling edge of CALRM, (CALRM being reset by high level TDATA bit).

FRALRM goes low upon completion of the synchronization function or within 250 ns after the rising edge of CALRM. (Carrier loss condition during frame synchronization function).

## OUTPUT CLOCK SIGNALS DURING FRAME SYNCHRONIZATION FUNCTION

Following the Declaration of Frame Sync loss (FRALRM goes high). output signals will continue normally for a two-frame period with the exception of CHSYNC, which has the above mentioned second frame sync pulse inhibited. Following the twoframe period CHCLK, CHSYNC, and WIHBT are heid high until frame sync has been located, as indicated by the falling edge of FRALRM. With typical data patterns, frame synchronization takes less than five milliseconds. See Figure 2.


Figure 2. Signal Relationship During Frame Alarm and Search for Resynchronization


тсLк (1.54 мнz)


Figure 3. Signal Relationships at Beginning of $\mathrm{F}_{\mathbf{S}}$ Frame (S-BIT)


Figure 4. Signal Relationships at Beginning of $F_{T}$ Frame (F-BIT)


Figure 5. Multiframe Signal Relationships

Table 1. Output Propagation Delay Worst Case, From Rising Edge to TCLK

| OUTPUT | MAX DELAY (NS) |
| :--- | :--- |
| CHCLK | 300 |
| CHSYNC | 300 |
| WIHBT | 300 |
| MAXCNT | 300 |
| SBCLK | 300 |
| SBIT | 400 |
| SIGFR | 475 |
| SBALRM | 475 |
| B2ALRM | 450 |
| CALRM | 300 |
| FRALRM | 900 (R8060) |
|  | 600 (R8060A) |
| CDB (1-8) | 400 |

## SPECIFICATIONS

Maximum Ratings

| Rating | Symbol | Voltage | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $V_{D D}$ | +4.75 to +5.25 | V |
| Operating Temperature Range | ${ }^{\top}$ OP | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $T_{\text {STG }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

All inputs contain protection circuitry to prevent damage due to high static charges. Care should be exercised to prevent unnecessary application of voltage outside the specification range.

## Electrical Characteristics

$\left.V_{D D}=+5 \mathrm{~V} \pm 5 \%, T_{A}=25^{\circ} \mathrm{C}\right)$

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Input Logic "1" Voltage | $V_{\text {IH }}$ | 2.0 | $\mathrm{V}_{\text {DD }}+0.3$ | $v$ |
| Input Logic " 0 " Voltage | $V_{\text {IL }}$ | -0.3 | 0.8 | V |
| Output Logic "1" Voltage | $\mathrm{v}_{\mathrm{OH}}$ | 2.4 |  | v |
| Output Logic '0' Voltage | $v_{\mathrm{OL}}$ |  | 0.4 | v |
| Output Source Current | ${ }^{1} \mathrm{OH}$ | . 100 |  | $\mu \mathrm{A}$ |
| Output Sink Current | ${ }^{\prime} \mathrm{OL}$ | 400 |  | $\mu \mathrm{A}$ |
| Clock Frequency | ${ }^{\text {CLLK }}$ |  | 1.85 | MHz |
| Input Capacitance | $c_{1}$ |  | 5 | pF |
| Output Capacitance | $\mathrm{C}_{0}$ |  | 25 | pF |
| Power Dissipation | $\mathrm{P}_{\text {DSS }}$ |  | 550 | mW |



FILTER
PRODUCTS

# Rockwell-Collins <br> Disc-Wire Mechanical Filters 



## Table of Contents

Section Page
1.0 Introduction ..... 1
1.1 Filters Using Magnetostrictive Transducers ..... 2
1.2 Filters Using Piezoelectric Transducers ..... 2
2.0 Design Considerations ..... 2
2.1 Disc Resonators ..... 2
2.2 Mechanical Coupling ..... 3
3.0 Practical Design Limits ..... 4
4.0 Enclosure Styles ..... 6
5.0 Application Guidelines ..... 8
5.1 Magnetostrictive Transducers ..... 8
5.2 Piezoelectric Transducers ..... 11
5.3 Application Conclusions ..... 11
6.0 Disc-Wire Filter Characteristics ..... 12
6.1 Effects of Terminating Circuits ..... 12
6.2 Group-Delay Response ..... 14
6.3 Dynamic Range and Power Level ..... 16
6.4 Intermodulation Distortion ..... 16
6.5 Spurious Responses ..... 19
$6.6 \quad$ Filter-to-Filter Variations ..... 19
6.7 Stability ..... 21
6.8 Aging ..... 22
6.9 Reliability ..... 23
7.0 Environmental Effects ..... 24
7.1 Temperature Effects on Center Frequency, Bandwidth, Loss, and Ripple ..... 24
7.2 Shock ..... 25
7.3 Vibration ..... 25

## Rockwell-Collins Disc-Wire Mechanical Filters

### 1.0 Introduction

Disc-wire mechanical filters consist of metal disc resonators that are coupled together by wires. As shown in figure 1A, three basic elements comprise the filter structure: (1) magnetostrictive or piezoelectric transducers, used for converting electrical signals into mechanical vibrations; (2) high Q, mechanically resonant discs; and (3) disc coupling wires.


Figure 1. Disc-Wire Mechanical Filter Analogy

### 1.1 Filters Using Magnetostrictive Transducers

When an electrical signal is applied to the input coil of a magnetostrictive transducer (figure 1A), an alternating magnetic field is produced. This field then passes through the magnetostrictive rod that is attached to the first disc. When properly biased, the rod will vibrate at the frequency of the impressed signal. This is due to dimensional changes of magnetostrictive material that occur when being subjected to a magnetic field. The vibrating rod drives the first disc which, by means of the connecting coupling wires, drives the next disc. Each successive disc is then driven by the preceding disc until the signal reaches the output transducer. Strains developed in the output magnetostrictive rod produce an alternating magnetic field which, in turn, induces a voltage across the output coil.

### 1.2 Filters Using Piezoelectric Transducers

These filters operate in a manner similar to those described above, but a piezoelectric rod is used instead of the coil, biasing magnet and magnetostrictive rod shown in figure 1A. The coil inductance and resonating capacitance shown in figure 1B are replaced by the transducer static capacitance and resonating inductance, respectively. When a voltage is applied across the input piezoelectric transducer, an alternating electric field is produced, causing it to vibrate. The vibrations are transmitted through the disc-wire assembly in the same manner as described in paragraph 1.1, and are converted to a voltage at the filter output. In addition to converting energy from one form to another, the transducers also reflect the source and load resistances into the mechanical circuit. The reflected impedances provide a termination for the filter.

### 2.0 DESIGN CONSIDERATIONS

The disc resonators are made from a specially processed nickel-iron-chromium-titanium alloy. The constant-modulus characteristic of this material minimizes frequency shifts with changes in temperature. Figure 1 B shows that the filter center frequency is determined by the disc resonator frequencies.
Several considerations are important in choosing the physical configurations of disc resonators and the mechanical coupling for a pariicular filter.

### 2.1 Disc Resonators

It must first be determined which mode of vibration is to be used. The two modes of vibration that are generally used in Rockwell-Collins filters are both flexure modes. The discs flex symmetrically about their center, similar to the vibration of a drum head. Both vibration modes use a nodal circle, or circles, which are not coincident with the edge of the disc. A mode with a single-nodal circle is generally used at frequencies of 200 kHz or lower, whereas a mode with 2-nodal circles is used up to 500 kHz . Figure 2 represents a mode with 2-nodal circles. The frequency of a disc resonator is directly proportional to thickness and inversely proportional to the square of the diameter.


Figure 2. Vibration Mode Using 2-Nodal Circles

Other normal modes of vibration occur near the frequency region of interest, most of them having nodal diameters. The primary reason for attaching transducers at the centers of the first and last discs in a filter is to suppress these vibrations. Figure 3 illustrates four basic configurations of transducers used for this purpose.


Figure 3. Transducer Configurations

### 2.2 Mechanical Coupling

The coupling inductors shown in figure $1 B$ represent the wires which couple the disc resonators together and also act as their physical support. Varying the mechanical coupling between the discs, in effect making the coupling wires larger or smaller, varies the filter bandwidth. Since the bandwidth varies as a function of the approximate total cross-sectional area of the coupling wires, it can be increased either by using larger diameter wires or a greater number of coupling wires. It should also be noted that the physical structure becomes weaker as the filter bandwidth is reduced, assuming a fixed coupling wire configuration is used. This is one of the reasons why disc-wire filters are built using three basic coupling wire configurations. See figure 4.


Notably the least obvious of the three configurations shown in figure 4 is "off-resonance coupling", used in narrow bandwidth filters. In this scheme each alternate disc, shown shaded, is tuned so that its resonant frequency is higher than the filter passband region. Since the off-resonance disc is a shunt tank circuit, in the bandpass region in the filter (below the resonant frequency of the disc), it appears as a shunt inductance. This results in a "tee" of coupling inductors between the shaded discs. The net result produces a narrow bandwidth filter with coupling wires significantly larger in diameter than could be used without the "off resonance" discs.

### 3.0 Practical Design Limits

An analysis of all design considerations outlined in Section 2.0, results in definition of a set of design limits. The center frequency vs percent bandwidth is plotted in figure 5. The horizontal axis is filter centerfrequency and the vertical axis is filter bandwidth expressed as a percentage of center frequency. Practical limits within which mechanical filters can be built are represented in figure 5 as the shaded area. Special filters outside of these limits have been built, however, they are very costly.


Figure 5. Center Frequency vs Bandwidth.

Most disc-wire filters approximate a 0.1 dB Chebyshev characteristic and exhibit a monotonic response. However, by bridging one or more discs with a coupling wire of proper dimension, it is possible to achieve a cancellation of signals at the output of the mechanical filter. This results in attenuation poles either in the upper or in the lower filter stopbands, or in both. Filters using these attenuation poles provide steeper skirt selectivity with fewer disc resonators than filters without the poles. This is important in applications where differential or absolute delays in the passband are of concern. See figure 6 for an attenuation comparison for filters having different numbers of disc resonators.


Figure 6. Attenuation Characteristics for Chebyshev Filter with 0.1 dB Ripple.

### 4.0 Enclosure Styles

Enclosure styles and outline dimensions for six different packages are shown in figure 7. Case styles "YA", "V" and " Y " are hermetically-sealed metal cases and are therefore the most expensive. These cases are recommended for stringent military applications, particularly where high humidity environments exist. The other styles shown in figure 7 are plastic cases that are suitable for most commercial applications but have also been used successfully in certain military applications. Case style "HS" is the least expensive and can be used in many applications for filters in the frequency range of $450-500 \mathrm{kHz}$. Whereas in most plastic enclosures the base is bonded to the cover with epoxy, the "HS" enclosure uses heat-staking. With this method no attempt is made to effect a moisture seal. However, this enclosure is suitable for many commercial environments, as the filter itself is not permanently changed by moisture.


Figure 7. Disc-Wire Mechanical Filter Case Styles.

### 5.0 Application Guidelines

Rockwell-Collins disc-wire mechanical filters use two basic types of transducers: magnetostrictive and piezoelectric. Magnetostrictive transducers are further divided into two types: wire and ferrite. The type of transducer incorporated into the filter determines the application technique to be followed.

### 5.1 Magnetostrictive Transducers

Magnetostrictive wire and ferrite transducers require that the input and output transducer coils be capacitively resonated. The care required to resonate the coils depends on the filter type itself, the desired response variation (passband ripple) level, and the loss through the filter. Many mechanical filters, in various applications, can be resonated by a standard fixed-type capacitor (e.g., DM10). The value of this capacitor depends on the particular filter type and on the external/stray capacitance imposed on the filter by the application circuit. As the performance requirements for the filter become more stringent, greater care must be exercised in resonating the transducer coils. For example, if a mechanical filter is used in the receiver section of a CB transceiver, the nominal value of resonating capacitance defined in the filter specification will provide satisfactory results. However, if the filter is used in a single sideband radio that requires a low value of response variation in the passband and more precise frequency response characteristics, it is advisable to use variable capacitors to peak the filter during the equipment design stage. When the capacitance value for that specific filter type and application circuit has been determined, equivalent fixed capacitors may be substituted in production equipment. In applications where ultimate filter performance is required such as the very low ripple value required in voice multiplexing and telecommunications systems, it is advisable to use variable capacitors for tuning the production equipment. In all applications, the transducer coils must be properly resonated to ensure minimum response variation in the passband and to minimize loss through the filter.
To determine the capacitance required for resonance in a particular filter circuit, a simple method is to set the filter signal input at the center frequency of the filter. Then adjust the capacitors to obtain maximum output amplitude from the filter. In most applications no further tuning is required. However, if the absolute minimum value of response variation in the passband is required, further adjustment may be necessary. In this case, sweep the frequency of the input signal across the passband of the filter and, simultaneously, adjust the capacitors to obtain minimum ripple. The capacitance variation from the fixed value should not be large; however, it generally does result in lower ripple values.
In addition to resonating the transducer coils, the circuit must provide the proper source and load resistance values, as in other filter types. Filters which have wire transducers are essentially self-terminated and require a very high value of terminating resistance with the transducer coils parallel-resonated.A very low value of terminating resistance is required when the transducer coils are series-resonated. Thus, for parallel-resonant operation, the terminating resistance can be 100 K ohms or greater and for series-resonant operation it can be 100 ohms or less. In many applications, these limiting resistance values can be changed to 50 K ohms and 200 ohms, respectively; however, for values of resistance in between, a capacity divider is required.
Filters having ferrite transducers also need to be terminated with the specified resistance values defined in the filter specifications. If a filter cannot be terminated with these specific resistance values, a capacitance divider network should be used. For example, let us assume that a mechanical filter with ferrite transducers is designed for parallel-resonant operation. The capacitance value is determined to be 130 pF and the terminating resistance is 20 K ohms; however, it is more convenient for the designer to provide a terminating resis-
 f10K ohms), see figure 9 .


Figure 8. Specified Termination (20K ohms).


Figure 9. Alternate Configuration ( 10 K ohms)

In the example chosen:

$$
\begin{aligned}
& C_{1}=\sqrt{\frac{20,000}{10,000}} \quad(130)=184 \mathrm{pf} \\
& C_{2}=\frac{(184)(130)}{184-130}
\end{aligned}
$$

If operation at a much lower impedance level is required, the designer can convert the terminating circuitry to series-resonate the coil. Assume again, that the filter is designed for parallel-resonant operation with 130 pf capacitance and a terminating resistance of 20 K ohms. The conversions shown in figure 10 are satisfactory at a single frequency to convert either from parallel-to-series or series-to-parallel operation when only one terminating resistance condition is known. Note that the capacitive-reactance must be used in the calculation, not the capacitance value in picofarads.


Figure 10. Parallel-to-Series and Series-to-Parallel Conversions.

In the example, let us assume an operating frequency of 455 kHz . The reactance of 130 pf at 455 kHz is:

$$
\frac{1}{2 \pi(455,000)\left(130 \times 10^{-12}\right)}=2700 \text { ohms }
$$

then:

$$
\begin{aligned}
& R_{S}=\frac{\frac{1}{20,000}}{\left(\frac{1}{20,000}\right)^{2}+\left(\frac{1}{2700}\right)^{2}}=359 \text { ohms } \\
& X_{S}=\frac{\frac{1}{2700}}{\left(\frac{1}{20,000}\right)^{2}+\left(\frac{1}{2700}\right)^{2}}=2650 \text { ohms }
\end{aligned}
$$

and:

$$
C_{S}=\frac{1}{2 \pi(455,000)(2650)} \quad=132 \mathrm{pf}
$$

Therefore, the equivalent series circuit at 455 kHz is a resistance of 359 ohms in series with a capacitance of 132 pf.
The preceding examples used parallel tuning, series tuning, and a capacitance divider and a terminating resistance somewhat less than the 20 K ohms required for parallel tuning. In the following example, let us assume that a terminating resistance significantly closer to 359 ohms (determined above) is required for series tuning. In this range of terminating resistances, it is advantageous to use a capacitance divider, as shown in figure 11.


Figure 11. Capacitance Divider.

Refer to figure 11 and assume a desired value of 1 K ohm for R . Knowing from the previous calculation $R_{S}$ is 359 ohms and $C_{S}$ is 132 pf.

Then:
$C_{4}=\sqrt{\frac{359}{1000}(132)}=79 \mathrm{pf}$
$C_{3}=132-79=53 \mathrm{pf}$

All examples shown use approximations and neglect stray capacitances. This may require some adjustments of values in the final application circuit. However, this is a simple, easy-to-use approach which provides the circuit designer with a good starting point when choosing his design. It is also apparent that some choice of approach exists in the middle range of terminating resistances between the limiting values of 20 K ohms and 359 ohms.

### 5.2 Piezoelectric Transducers

Filters using piezoelectric ceramic transducers are generally tuned internally and need to be terminated with a specific resistance that is normally shunted by a specific capacitance. These filters can be tuned internally so that no external capacitance is required. However, since stray capacitances are always present in external circuits, the filters are designed to "see" some convenient value of capacitance which is defined in the filter specifications.
Application circuits should not be designed with signal levels so high that a slight increase in signal level input changes the bandpass characteristics of the filter. The specification for the filter defines a maximum input level. In general, levels of -20 to -10 dBm are acceptable. Permanent damage to the filter is not likely to occur unless levels are considerably higher. However, some deterioration of the response characteristics may occur when the filter is "overdriven". In terms of small signals, satisfactory operation is obtained with input levels as low as $\mathbf{- 1 0 0 ~ d B m}$.

### 5.3 Application Conclusion

Most mechanical filters are capable of providing stopband rejection greater than 90 dB . To take full advantage of this capability, reasonable care in physical layout must be taken and good design practices must be observed. For example, physical separation and/or shielding between input and output must be provided. Do not allow leakage paths around the filter. If stopband levels are not greater than 90 dB , the problem most likely exists in the external circuit and not in the filter.
All preceding comments are intended as basic guidelines. Design experience and experimentation with mechanical filters will provide the designer with acceptable deviations for specific applications.
Figure 12 shows a generalized application using mechanical filters in transistor amplifiers and figure 13 shows an application for use in a balanced modulator. These circuits are not intended to be limiting; they are supplied only as starting point information for the designer.


Figure 12. Transistor Amplifier Circuit


Figure 13. Balanced Modulator Circuit.

### 6.0 Disc-Wire Filter Characteristics

This section describes the effects of terminating circuits, group-delay response, dynamic range and power level, intermodulation distortion, spurious responses, stability and aging.

### 6.1 Effects of Terminating Circuits

The methods of achieving proper terminations for disc-wire filters were discussed in Section 5 . This paragraph shows the effects when filters are not properly terminated. Improper terminations affect most operating characteristics of any high-performance bandpass filter. In a majority of applications, the most noticeable effects are increases in passband ripple and changes in insertion loss. Generally, the more selective the filter, the more noticeable the effects of improper termination. The performance of a multi-section filter having steep skirt selectivity will be degraded more by improper termination than will a filter having fewer sections and less steep skirt selectivity. To illustrate effects of improper terminations for typical filters, a nine-disc-resonator design with a 3 dB bandwidth of 3 kHz is presented here. Figure 6 shows that a filter ( $\mathrm{N}=9$ ) with these characteristics has a shape factor of approximately 1.6 to 1 , where shape factor is defined as the ratio of filter bandwidth at 60 dB to filter bandwidth at 3 dB .

As indicated in Section 5, all disc-wire filters must be terminated with an equivalent combination of resistance and capacitive reactance. In the following example, assume a typical filter requiring a termination of 10 K ohms shunted by 160 pf. Furthermore, assume a "perfect" filter where every electrical and mechanical parameter meets exactly the nominal values specified, plus or minus zero tolerance. This filter, when properly terminated, has a 0.1 dB passband ripple that is evenly distributed across the passband. The effect of increasing or decreasing the external shunt capacity by 10 percent ( 16 pf ); thereby increasing the passband ripple to approximately 1.0 dB (from 0.1 dB ), is shown in figure 14 .


Figure 14. Effect of Terminating Capacitance on Passband Ripple.
When changing the shunt capacitors back to their correct value of 160 pf , and changing the terminating resistors by plus 100 or minus 50 percent, the passband ripple increases from 0.1 dB to 2.0 dB . This is shown in figure 15.


Figure 15. Effect of Terminating Resistance on Passband Ripple.

In practicality, there are almost no perfect filters. Even when ideally terminated, a filter will have a passband ripple value in the order of 1.5 dB as compared with a value of 0.1 dB . As a result, it is usually necessary to hold termination tolerances to $\pm 5$ percent for resistance and $\pm 2$ percent for capacitance.

### 6.2 Group-Delay Response

The approximate group (envelope) delay for a mechanical filter can be determined from figure 16 and from the following equations. Note that the curves shown in figure 16 are normalized to $3 \mathrm{~dB} ; \mathrm{F}_{\mathrm{N}}=1.0$ at the 3 dB point.

| Group-Delay (Sec.) at <br> Center Frequency$=$ | NGD$\quad \mathrm{NGD}$ | Normalized group-delay <br> from figure 16. |
| :--- | :--- | :--- | :--- |
|  | $\mathrm{BW}_{3 \mathrm{~dB}}$ |  |$\quad \mathrm{BW}_{3 \mathrm{~dB}}=3 \mathrm{~dB}$ Bandwidth (in Hz )

Example 1:
The group-delay for a 9-pole, 0.1 dB Chebyshev filter which has a 3 kHz bandwidth is:

| $\mathrm{N}^{2}$ | $=$ | 9 |
| :--- | :--- | :--- |
| BW $_{3 \mathrm{~dB}}$ | $=$ | $3,000 \mathrm{~Hz}$ |
| NGD from fig. 16 at $\mathrm{f}_{0}$ | $=$ | 7.9 sec |
|  | $=$ | $0.0008382 \mathrm{sec}=$ |
| Group-delay at $\mathrm{f}_{\mathrm{O}}=\frac{7.9}{3000} \pi$ |  | $838.2 \mu \mathrm{sec}$ |

To approximate group-delay at any frequency inside the 3 dB point, use the following equations:

| $F_{x}$ | $=$ | Frequency in Hz from 3 dB point |
| :--- | :--- | :--- |
| $F_{N}$ | $=$ | $\left(0.5 \mathrm{BW}_{3 \mathrm{~dB}}-\mathrm{F}_{\mathrm{x}}\right) / 0.5 \mathrm{BW} 3 \mathrm{~dB}$ |
| Group-delay (sec) at $\mathrm{F}_{\mathrm{N}}$ | $=$ | $\frac{\mathrm{NGD}}{\pi \mathrm{BW}_{3 \mathrm{~dB}}}$ |

Example 2:
In this example, let us determine the delay at 500 Hz inside the 3 dB point:

| N | = | 9 |
| :---: | :---: | :---: |
| $\mathrm{BW}_{3 \mathrm{~dB}}$ | = | 3000 Hz |
| $\mathrm{F}_{\mathrm{X}}$ | = | 500 Hz |
| F. $N$ | = | $(1500-500) / 1500=0.66$ |
| NGD from fig. 16 at $\left(F_{N}=0.66\right)$ | $=$ | 10 sec |
| $\begin{aligned} & \text { Group-delay at } X= \\ & \frac{10}{\pi 3000} \end{aligned}$ | $=$ | $0.001061 \mathrm{sec}=1061 \mu \mathrm{sec}$ |

The differential delay of both examples above (center 2 kHz of the passband) is $1061-838=223 \mu \mathrm{sec}$, assuming that $f_{O}$ was the minimum delay in the passband. The curves shown in figure 16 are idealized. Some variations from these curves exist in all filters.


Figure 16. Group-Delay Characteristics for a Chebyshev Filter with 0.1 dB Ripple.

### 6.3 Dynamic Range and Power Level

There is no practical lower limit on the dynamic range since essentially no internally-generated noise exists. However, where vibration conditions exist, the microphonic electrical output from the filter is dependent on the vibration frequency and on the filter type. A typical output is in the order of -70 dB below a 100 percent, 1 V rms modulated output signal at a vibration level of 5 g 's betwen 0 and 500 Hz vibration frequencies.
The upper limit of the dynamic range is the linearity of the output signal. This, again, depends on the type of filter. A 3 V rms input signal is a typical limit, although signals as high as 10 V rms can be specified in some designs before appreciable non-linearities appear. See figure 17.


Figure 17. Voltage Linearity.

### 6.4 Intermodulation Distortion

Intermodulation distortion in a mechanical filter is the result of non-linearities in the electro-mechanical transducers. Therefore, intermodulation distortion is dependent on the type of transducer used and on the specific transducer design. Figure 18 shows curves of third-order intermodulation products as a function of signal level and transducer design.


Figure 18. Third-Order Intermodulation Products
The intermodulation distortion test circuit is shown in figure 19. Generator $F_{3}$ and the short-circuit that bypasses the mechanical filter are used as a reference level. Generators $F_{1}$ and $F_{2}$ are set at frequencies in the stopband of the filter which result in $\mathrm{F}_{3}$ falling within the passband of the filter, as shown in figure 20. To obtain accurate results, isolation between generators $F_{1}$ and $F_{2}$, and proper signal levels are of the utmost importance.


Figure 19. Filter Intermodulation Distortion Test Circuit.


Figure 20. Third-Order Intermodulation Distortion Froduct.

### 6.5 Spurious Responses

Disc-wire filters do not have the resonant frequency overtones (nearly exact multiples) commonly found in quartz crystals. Mechanical filters do not have adjacent flexure and radial modes which appear in some filters as spurious responses.
With some exceptions, in mechanical filters the adjacent spurious modes are suppressed more than 60 dB below the passband reference level. Filters in the 5 to 10 kHz bandwidth range have spurious responses that exceed 60 dB . Filters in the 40 to 50 kHz bandwidth range may have spurious reversals in the transition bands or in the skirts of the filter response. Figure 21 compares spurious responses between filters with wire transducers, filters with ferrite transducers and center-coupled wideband filters.


Figure 21. Comparison of Spurious Responses

### 6.6 Filter-to-Filter Variations

Paragraph 6.1 made the statement that "there are almost no perfect filters". Figure 22 below shows plots of 18 production filters superimposed on top of each other. This particular filter type was designed as a lower sideband filter for a 455 kHz carrier frequency. It can be seen that there are slight variations from filter to filter. It is also obvious that the specification on the skirt of the filter on the carrier side of the passband is tighter than the specification on the other skirt of the response. As a consequence, there is less filter to filter variation on that skirt.
In general, mechanical filter specifications are written conservatively, and the average filter is well inside the specified limits. Figure 23 clearly illustrates this point. It shows four histograms of selected parameters on a large ( 10,000 unit) sample of filters built for commercial application. The consistency of performance is an outcome of good process controls.


Figure 22. Filter-To-Filter Variations


Figure 23. Typical Production Results.

### 6.7 Stability

The stability of disc-wire mechanical filters depends on the characteristics of the discs themselves. Collins disc-wire mechanical filters use an iron-nickel-chromium-titanium alloy ( Ni -Span C ) as the disc material. The titanium in the material allows the alloy to be heat-treatable. This means that the parabolic resonant frequency vs temperature curve can be shifted along the temperature axis to meet a precise filter specification. Figure 24 shows the frequency shift characteristics of a typical disc resonator at 455 kHz . To approximate the frequency shift at other frequencies, simply scale by the ratio of the new frequency to 455 kHz .
Example:

$$
\Delta f_{f o(k H z)} \quad=\Delta f_{455} \mathrm{kHz} \quad \times \frac{f_{0}(\mathrm{kHz})}{455} \quad \text { (for 2-nodal circles) }
$$



Figure 24. Disc Resonator Frequency Shift Characteristics

The one-sigma limits resulting from a variation in the heat treatment process are shown in figure 24 as dotted lines. Where single-nodal circles are used (normally below 200 kHz ), the frequency shift equation must be multiplied by 1.5 .

### 6.8 Aging

Frequency stability of mechanical filters with age is directly related to the resonator mode and to the characteristics of the material. A good estimate of center frequency shift, with age, is 50 ppm over a 20 -year period or a 25 Hz shift of a 500 kHz center frequency.
The curves in figure 25 show the effect of accelerated aging at the 10 dB points of a typical 500 kHz filter having a bandwidth of 3 kHz .
Accelerated aging was accomplished by subjecting the filter to temperature cycles for 9 hours at $25^{\circ} \mathrm{C}$ and for 15 hours at $90^{\circ} \mathrm{C}$. The cycles were repeated daily for a period of eight months.


Figure 25. Effects of Accelerated Aging.

### 6.9 Reliability

Disc-wire mechanical filters are, by design, very reliable components. A collection of field service data is shown below:

$$
\begin{aligned}
\text { Field Data: } & 277,000 \text { Units } \\
& 2.5 \text { Years } \\
& 374 \text { Failures } \\
\text { MTBF }= & \frac{277,000 \times 2.5 \times 365 \times 24}{374} \\
= & 1.622 \times 10^{7} \text { Hours } \\
= & 61.6 \times 10-^{9}(61.6 \mathrm{FIT})
\end{aligned}
$$

### 7.0 ENVIRONMENTAL EFFECTS

This section describes the environmental effects on disc-wire mechanical filters due to temperature, shock and vibration.

### 7.1 Temperature Effects on Center Frequency, Bandwidth, Loss and Ripple

Disc-wire filter designers use design techniques with compensating factors. These factors minimize center frequency shift and bandwidth of the filter with a change in temperature. Table 1 compares the variations of $f_{o}$ and $\mathrm{BW}_{3 \mathrm{~dB}}$ obtained from 10 single sideband filters at 450 kHz . All values shown are in Hz .

|  | $f_{0}$ <br> at $25^{\circ} \mathrm{C}$ | $\Delta \mathrm{f}_{\mathrm{o}}$ <br> at $-40^{\circ} \mathrm{C}$ | $\Delta f_{\mathrm{o}}$ <br> at $+85^{\circ} \mathrm{C}$ | $\mathrm{BW}_{3 \mathrm{~dB}}$ <br> at $25^{\circ} \mathrm{C}$ | $\Delta \mathrm{BW}_{3 \mathrm{~dB}}$ <br> at $-40^{\circ} \mathrm{C}$ | $\Delta \mathrm{BW}_{3 \mathrm{~dB}}$ <br> at $+85^{\circ} \mathrm{C}$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Average | 451742 | +48 | +46 | 3037 | -1.3 | -9.4 |
| Minimum Value | 451681 | +39 | +37 | 2871 | -23 | -26 |
| Maximum Value | 451803 | +56 | +59 | 3138 | +13 | +2 |

Table 1. Variations of $f_{0}$ and $\mathrm{BW}_{3 \mathrm{~dB}}$ vs Temperature.

Table 2 shows effects of temperature change on a number of parameters for a sample of upper sideband filters designed for a 455 kHz carrier frequency. This filter was designed for a commercial application, so that the operating temperature range was not as great as the filter referenced in Table 1. The Table 1 filter is used in a military application.

| Parameter | $+25^{\circ} \mathrm{C}$ | $-30^{\circ} \mathrm{C}$ to $+50^{\circ} \mathrm{C}$ |  | Maximum $\Delta$ from $25^{\circ} \mathrm{C}$ |
| :---: | :---: | :---: | :---: | :---: |
|  | Average Value | Minimum Value | Maximum Value |  |
| Response Variation in dB | 0.88 | 0.4 | 2.1 | 1.22 |
| Insertion Loss in dB | 2.7 | 2.4 | 4.1 | 1.40 |
| 3 dB Bandwidth in Hz | 2152 | 2070 | 2230 | 82 |
| 60 dB Bandwidth in Hz | 4342 | 4210 | 4480 | 138 |
| Frequency in kHz of Low Side 3 dB Point | 455.392 | 455.350 | 455.450 | 58 |
| Frequency in kHz of High Side 3 dB Point | 457.541 | 457.450 | 457.640 | 99 |
| Frequency in kHz of Low Side 60 dB Point | 454.305 | 454.170 | 454.400 | 135 |
| Frequency in kHz of High Side 60 dB Point | 458.624 | 458.480 | 458.770 | 146 |

Table 2. Temperature Variations.

A typical variation of insertion loss with temperature is $\pm 1.0 \mathrm{~dB}$ over a temperature range of $-10^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$. Changes in passband ripple, due to changes in temperature, depend mainly on the transducer design. Filters using piezoelectric transducers use internal components designed to optimize the response and therefore display better characteristics over temperature changes. A typical change in ripple over a temperature range of $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ is less than 1 dB . Most filters using ferrite or wire transducers have twice the amount of ripple of their actual room temperature values, over this same temperature range.
Temperature variations in center frequency, bandwidth, loss and ripple are temporary. The filter is restored to its original operating condition when the temperature is restored to $+25^{\circ} \mathrm{C}$ without measurable hysteresis.

### 7.2 Shock

To prevent damage from shock, the mechanical filter structure uses an internal resilient rubber shock mount. This shock mount enables the average SSB filter to withstand greater than $50 \mathrm{G}, 11 \mathrm{msec}$ shocks without changing the filter response. Many mechanical filters can withstand 75 G 's of shock before permanent damage occurs. See figure 26 for a comparison of shock level versus filter bandwidth. Note that filters using off-resonant discs have narrow bandwidths, and filters using the mini-single-nodal circle have wide bandwidths.


Figure 26. Shock Level vs Filter Bandwidth.

### 7.3 Vibration

The internal shock mount that so effectively isolates the filter from shock is also excellent for suppressing vibration. All Collins disc-wire mechanical filters exceed MIL-STD-202, Method 201.

## Collins Low Frequency Mechanical Filters <br> 0Rockwell



## Collins Low Frequency Mechanical Filters



Rockwell

## Table of Contents

Page
1.0 Introduction to Low Frequency Mechanical Filters ..... 1
1.1 Practical Design Limits ..... 1
1.2 Enclosure Styles ..... 6
1.3 Application Circuits ..... 6
1.4 Applications for Low Frequency Mechanical Filters ..... 8
2.0 Characteristics for Low Frequency Mechanical Filters ..... 9
2.1 Center Frequency Vs. Termination ..... 9
2.2 Center Frequency Vs. Input Voltage Level ..... 10
2.3 Differential Phase Vs. Input Voltage Level ..... 10
2.4 Input to Output Level Linearity ..... 10
2.5 Group Delay Response ..... 11
2.6 Impulse Response ..... 13
2.7 Spurious Responses ..... 15
2.8 Aging ..... 16
2.9 Reliability ..... 16
3.0 Environmental Effects ..... 16
3.1 Temperature Effect on Center Frequency, Loss and Bandwidth ..... 16
3.2 Shock ..... 17
3.3 Vibration ..... 17
3.4 Moisture Resistance ..... 20

## Collins Low Frequency Mechanical Filters

### 1.0 Introduction to Low Frequency Mechanical Filters

The low frequency mechanical filter consists of two metal alloy bars bonded to piezoelectric ceramic transducers and coupled mechanically with wires which also act as the supporting structure. See figure 1. The bars are made out of a constant modulus nickel-iron alloy whose temperature coefficient is adjusted by heat treatment to help compensate for the high positive temperature coefficient of the ceramic. The composite resonators operate in the flexure mode with wires coupling the bars torsionally. Figure 2 shows the equivalent circuit of the filter.

### 1.1 Practical Design Limits

The mechanical filter may be designed as a Chebyshev, Butterworth, TBT, Linear Phase or Bessel filter in either a 2, 3 or 4 pole (resonator) configuration. The Chebyshev (equal passband ripple) designs are available with ripple values ranging from .01 to 1.5 dB . Typical response curves for these designs are available in standard filter handbooks!


Figure 1. Low Frequency Mechanical Filter

[^13]The practical design limits for low frequency mechanical filters are illustrated in figure 3. The fractional bandwidth ( $\mathrm{BW} \mathbf{3 d B}_{3} / \mathrm{F}_{0}$ ) varies from $.2 \%$ to $1.5 \%$ over a center frequency ( $\mathrm{F}_{0}$ ) range of 3.5 to 70 kHz . The fractional bandwidth is further influenced by the environmental restrictions (shock and vibration) and the type of design, such as Chebyshev or Bessel.

Typically, Chebyshev designs having fractional bandwidths between $.2 \%$ and $1.5 \%$ can be achieved for shock levels to 100 G 's and vibration levels to 10 G 's.

An attenuation comparison for .25 dB ripple Chebyshev filters is presented in figure 4 and a linear phase equiripple ( $.5^{\circ}$ error) design in figure 5 .


Figure 2. Equivalent Circuit of A low Frequency Mechanical Filter


Figure 3. Practical Design Limits of Low Frequency Mechanical Filters

Shape Factor


Figure 4. Attenuation Comparison for $.25 d B$ Ripple Filters


Figure 5. Attenuation Comparison for Linear Phase Equiripple (. $5^{\circ}$ Error) Filters

The Chebyshev designs are primarily for tone selectors while the linear phase designs are used where phase or FSK modulation is transmitted. The linear phase designs have 0 dB ripple and a low ringing impulse response ( $4 \%$ ringing for a 2 -Pole). Typical mechanical filter specifications are tabulated in table 1. The values are interrelated (and therefore not independent) and are a function of the type of design, i.e. a very narrow filter would probably not have a high level shock specification.

Table 1. Mechanical Filter Specifications and Characteristics

| Specifications | Minimum | Typical | Maximum |
| :---: | :---: | :---: | :---: |
| Center Frequency ( $F_{0}$ ) <br> Fractional Bandwidth $\frac{\mathrm{BW}_{3 \mathrm{~dB}}}{\mathrm{~F}_{\mathrm{o}}}$ <br> Number of Poles (Resonators) | $\begin{aligned} & 3.5 \mathrm{kHz} \\ & 0.2 \% \\ & 1 \end{aligned}$ |  | $\begin{aligned} & 70 \mathrm{kHz} \\ & 1.5 \% \\ & 4 \end{aligned}$ |
| Characteristics | Minimum | Typical | Maximum |
| Insertion Loss | 1 dB | 3.5 dB | 10 dB |
| Terminating Resistance | $2 K \Omega$ | $20 \mathrm{~K} \Omega$ | $50 \mathrm{~K} \Omega$ |
| Temperature Coefficient of $\mathrm{F}_{\mathrm{o}}$ | $\pm 3 \mathrm{PPM} /{ }^{\circ} \mathrm{C}$ | $\pm 10 \mathrm{PPM} /{ }^{\circ} \mathrm{C}$ | $\pm 25 \mathrm{PPM} /{ }^{\circ} \mathrm{C}$ |
| Temperature Coefficient of $\mathrm{BW}_{3} \mathrm{~dB}$ |  | $500 \mathrm{PPM} /{ }^{\circ} \mathrm{C}$ |  |
| Passband Ripple | 0 dB | 0.2 dB | 1.5 dB |
| Vibration ( 10 Hz to 2000 Hz ) | 1G | 10 G 's | 15 G's |
| Shock | 15 G 's | 100 G 's | 1500 G's |
| Differential Phase Vs. Input Level $(-70$ to $-10 \mathrm{dBm})$ | $0.5^{\circ}$ | $0.5{ }^{\circ}$ | $2^{\circ}$ |
| Volume | $0.51 \mathrm{~N}^{3}$ | $0.51 \mathrm{~N}^{3}$ | $1.0 \mathrm{IN}^{3}$ |

### 1.2 Enclosure Styles

There are four enclosures currently available with low frequency mechanical filters. Three of the enclosures (PA, FS, and LC) are plastic, the fourth (FP) is a hermetically-sealed metal case. It is recommended that the 'LC' case be used whenever possible as it is significantly lower in cost.

Case style ' $P A$ ' is a plastic version of the ' $F P$ ' enclosure. It is normally not available except under special circumstances.

The 'FS' enclosure is used only on 2-Pole filters which have a 'fail-safe' requirement, i.e. the input can at no time short circuit to the output. This type of filter is normally found in railway systems, people carriers and automated rapid-transit trains. The enclosure is rated for a $-20^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$ environment and is not hermetically-sealed.

The ' $L C$ ' case is made of plastic and is ultrasonically sealed. It is rated for a $-55^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$ environment. Filters in these enclosures have been tested with two consecutive cycles of Mil-Std 202, method 106 for a total time of 20 days at $90 \%$ humidity. During the 20 day period filters are thermally-cycled from $-10^{\circ} \mathrm{C}$ to $+65^{\circ} \mathrm{C}$ and intermittently vibrated at 9 G 's. This test is designed to evaluate the resistance of component parts to tropical environments. Although the cases and the filters withstood this environment, they may not be able to withstand extremely long period environments because of the permeability of the plastic case. However, if the user provides an additional moisture barrier such as 'post-coat', filters in this enclosure will pass a more rigorous environment.

The alternative enclosure for tropical or high altitude service is the ' $F P^{\prime}$ case style. This is a cold-welded metal enclosure with glass to metal terminal seals. The filters in this package are rated for a $-55^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$ environment and guaranteed to meet the moisture resistance test. A disadvantage is that they are several times more expensive than the ' $L C$ ' enclosure.

### 1.3 Application Circuits

The following constraints are suggested limitations on the application circuit. Although these values may be exceeded without damage to the part, the filter will operate in a non-linear portion of its spectrum or will not meet the specifications.

Signal input level (across the terminals): 1 Vrms
DC voltage across the terminals: 50 VDC
Source and load termination:
$\pm 5 \%$
Stray capacitance across the input/output terminals to ground:
50 pf Max

The application circuits of figure 7 demonstrate the use of bridging capacitors ( $\mathrm{C}_{1}, \mathrm{C}_{2}$ ) which are used to convert a monotonic response to an elliptic function response. Bridging the filter with a capacitor between the input and output terminals provides the attenuation poles (transmission zeros) shown in figure 4. This capacitor is typically about 30 pf in value. Although there is a substantial improvement in the filter's shape factor (the ratio of the bandwidth, at a specified attenuation level to the 3 dB bandwidth) the disadvantage with this technique is that the attenuation level in the stopband of the filter decreases as the bridging capacitance is increased. See figure 4 for an illustration of a 2 Pole -2 Zero design.

A method used for realizing greater performance from a mechanical filter and still maintain a high stopband attenuation level is to cascade two or more units. This method results in an addition of the attenuation levels of each filter at any specific frequency.

The cascading is accomplished by using an active network to prevent interaction between the filters. The network could be either a transistor buffer amplifier or an Op-Amp. See figure 7.


Figure 6. Low Frequency Narrowband Mechanical Filter Flatpack Dimensions


Figure 7. Low Frequency Mechanical Filter Circuit Configurations

### 1.4 Applications for Low Frequency Mechanical Filters

Small size and low cost make the filters ideally suited for Omega navigation, selective calling systems, telephone multiplex, telemetry, centralized control systems, Sonar, mobile radio and FSK telegraph applications.

Low frequency mechanical filters can also be used to delay a signal by a specific amount. The delay of the filter is inversely proportional to the bandwidth of the filter and directly proportional to the number of poles, therefore, the delay can be accurately controlled. See section 2.5 for additional information.

### 2.0 Characteristics of Low Frequency Mechanical Filters

### 2.1 Center Frequency Vs. Termination

In normal applications of low frequency mechanical filters, the resistive terminations ( $R_{S}$ and $R_{L}$ ) shown in figure 7 , should not deviate more than $\pm 5 \%$ from the specified values. That is, the terminations affect the actual center frequency to some extent. For example, if a filter with a nominal center frequency of 10 kHz and a 50 Hz bandwidth has both its source and load resistances increased by $5 \%$ above the specified values, the filter center frequency $\left(\frac{F 3 H+F 3 L}{2}\right)$ will increase by .5 Hz . If $R_{S}$ and $R_{L}$ are changed (from the specified value) in opposite directions, small changes ( $2 \%$ to $3 \%$ ) are off-setting, and there is no center frequency shift. For large variations (in opposite directions) in $R_{S}$ and $R_{L}$, the effects are not completely offset, and the insertion loss and passband ripple of the filter will increase.

Stray capacitance between the input/output terminals and ground should not exceed 50 pf. Additional capacitance beyond this value will cause changes in insertion loss and center frequency. An increase to 150 pf will result in a .5 dB change in loss and a 75 ppm change in center frequency in the above example.


Figure 8. Variation of Filter Center Frequency with Resistive Termination

### 2.2 Center Frequency Vs. Input Voltage Level

Low frequency mechanical filters remain very linear with drive level up to 0.5 v , at which point they rapidly become non-linear. See figure 9. The shift in the center frequency at a ten volt level is enough to move some filters out of specification. Alṣo, along with the non-linear effects, excessive drive level causes time dependent changes in the ceramic material. These changes cause the center frequency of the filter to be lower after being driven at a high voltage level. Once the drive level is reduced the filter response begins to return to its original frequency.

### 2.3 Differential Phase Vs. Input Voltage Level

The differential phase at the center frequency of a linear-phase equiripple (. $5^{\circ}$ error) filter is 0.5 degree over an input level variation of 60 dB , namely -10 dBm to -70 dBm . The change in phase is due to a center frequency shift caused by the nonlinearity of the input transducer.

### 2.4 Input to Output Level Linearity

The linearity of the output signal level to the input level at the filter center frequency is 0.1 dB over an input voltage range of $60 \mathrm{~dB}(-10 \mathrm{dBm}$ to $-70 \mathrm{dBm})$.


Figure 9. Variation in Center Frequency with Input Voltage Level

### 2.5 Group Delay Response

The approximate group (envelope) delay for a mechanical filter can be determined from figures $10,11,12$ and 13 as well as the following equation.

Group delay (sec)
at center frequency $=\pi \frac{N G D}{B W} 3 \mathrm{~dB}$$\quad \begin{aligned} & \mathrm{NGD}=\text { Normalized Group Delay from figures 10, 11, 12, or } 13 \\ & B W_{3} \mathrm{~dB}=3 \mathrm{~dB} \text { Bandwidth (in } \mathrm{Hz} \text { ) }\end{aligned}$
Example:
The group delay for a 2 Pole .1 dB Chebyshev filter which has a 40 Hz bandwidth is
$N=2$
$\mathrm{BW}_{3 \mathrm{~dB}}=40 \mathrm{~Hz}$
NGD from figure $12=1.4 \mathrm{sec}$
Group delay $=\frac{1.4}{\pi 40}=.011 \mathrm{sec}=11 \mathrm{msec}$


Figure 10. Group-Delay Characteristics for Linear Phase (Phase Error $=.5^{\circ}$ ) Filter


Figure 11. Group-Delay Characteristics for Chebyshev Filter with 0.01 dB Ripple


Figure 12. Group-Delay Characteristics for Chebyshev Filter with 0.1 dB Ripple


Figure 13. Group-Delay Characteristics for Chebyshev Filter with 0.5 dB Ripple

### 2.6 Impulse Response

Figures 14 thru 17 can be used to approximate the impulse response ringing value of a mechanical filter. A definition of ringing is the ratio of $V_{1} / V_{2}$ in percent.


For example:
A two-pole mechanical filter designed as a linear-phase filter has an impulse response ringing value of $4 \%$.
$N=2$
$V_{1}=.02$ from figure 14
$V_{2}=.48$ from figure 14
Impulse response ringing $=\frac{V_{1}}{V_{2}} \times 100=\frac{.02}{.48} \times 100=4.1 \%$
A three-pole . 5 dB Chebyshev design has an impulse response of $21 \%$.


Figure 14. Impulse Response for Linear Phase (Phase Error $=.5^{\circ}$ ) Filters


Figure 15. Impulse Response for Chebyshev Filters with 0.01 dB Ripple


Figure 16. Impulse Response for Chebyshev Filters with 0.1 dB Ripple


Figure 17. Impulse Response for Chebyshev Filters with 0.5 dB Ripple

### 2.7 Spurious Responses

Mechanical filters have resonant frequency overtones very similar to those found in quartz crystals. These overtones occur at multiples of the fundamental; the multiples are 2.4, 4.8, 7.6, 10.6, etc.

As an example, a mechanical filter designed for Omega navigation system applications at 10.2 kHz will have spurious responses (frequency overtones) at $24.5,49,77.5$ and 108 kHz .

These overtones are inherent to the flexure mode of vibration used in the design of low-frequency mechanical filters. They cannot be suppressed without compromising the filter design. The odd-numbered modes, 2.4 and 7.6, are normally 50 dB below the fundamental. Suppression of these occurs because of the transducer coupling method utilized to drive the fundamental mode. The even-numbered overtones, $4.8,10.6$, have levels approximately 15 dB below the fundamental. These modes cannot be suppressed internally, however, a low-pass filter can be used to reject these higher frequency modes. Another alternative is the use of a bandpass "roofing" filter. See figure 22. The 'roofing' filter will reject both the low frequency microphonic and the high frequency spurious responses. It should be placed after the mechanical filter i.e., the incoming signal should go through the mechanical filter first, then through the 'roofing' filter. In this way, the microphonic responses are rejected as well as the spurious responses. The 'roofing' filter should be compatible with the mechanical filter; it should not affect its passband response.

### 2.8 Aging

Aging is defined herein as the change of center frequency with time. Since insertion loss and bandwidth do not change an appreciable amount, they will not be considered.

The low frequency mechanical filter has four components and processes which are likely to contribute to aging problems: the nickel-iron alloy bar, the ceramic transducer, the solder bond between the bar and transducer and the welds that connect the coupling wires to the bars. When heat treated properly, the nickel-iron alloy bar is very stable. Because its mass is much greater than any of the other components, the stability of the bar helps to compensate for the instability of the ceramic and solder bond.

Since the aging characteristics of low frequency mechanical filters are dependent on the ratio of the ceramic transducer mass to the nickel-iron alloy bar mass, the rate of aging for various types of filters is not only dependent on the center frequency, but perhaps, to a greater extent, on the design bandwidth of the filter. The narrower the bandwidth, the smaller the ceramic transducer need be. This means that the narrower bandwidth filters will age, as a percentage of their center frequency, less than wider bandwidth filters at the same frequency.

The aging rate of a mechanical filter is predictable and always in the positive direction. The aging ( $\Delta \mathrm{f}$ ) of a filter can be computed using the following equation, where $t$ is the time in days, BW is the 3 dB bandwidth in Hertz and $t_{o}$ is 10 days, the time required to manufacture a mechanical filter.

$$
\Delta \mathrm{f}=.02 \mathrm{BW}\left(\log \frac{t}{t o}\right)
$$

For example: A 12 kHz filter which is 50 Hz wide at 3 dB after 5 years will have aged:

$$
\Delta f=.02(50) \log \frac{5(365)}{10}=2.26 \mathrm{~Hz}
$$

### 2.9 Reliability

The MTBF (mean time between failures) is $3 \times 10^{7}$ hours. This is based on field data which was accumulated over a period of several years.

### 3.0 Environmental Effects

### 3.1 Temperature Effect on Center Frequency, Loss and Bandwidth

Design techniques for low frequency mechanical filters utilize compensating factors which minimize the shift of the filter center frequency with a change in temperature.

The center frequency shift vs. temperature is normally compensated to a tolerance of $\pm 10 \mathrm{ppm} /{ }^{\circ} \mathrm{C}$ over a temperature range of $-20^{\circ} \mathrm{C}$ to $+65^{\circ} \mathrm{C}$. The tolerance can be as high as $\pm 25 \mathrm{ppm} /{ }^{\circ} \mathrm{C}$ for the largest fractional bandwidth filters. The filters may be used over larger temperature ranges, such as $-55^{\circ} \mathrm{C}$ to $+95^{\circ} \mathrm{C}$ without any physical damage or permanent effect on the frequency response characteristics.

The variation of insertion loss with temperature is typically $\pm 1 \mathrm{~dB}$ (with a maximum variation of $\pm 1.5 \mathrm{~dB}$ ) over a temperature range of $-20^{\circ} \mathrm{C}$ to $+65^{\circ} \mathrm{C}$. The narrower the filter bandwidth the smaller the insertion loss variation.

Bandwidth normally changes very little with temperature in absolute terms. A typical variation for a filter with a 100 Hz bandwidth would be 1.5 Hz over a temperature range of $+25^{\circ} \mathrm{C}$ to $+65^{\circ} \mathrm{C}$. This is a bandwidth shift of $+375 \mathrm{ppm} /{ }^{\circ} \mathrm{C}$.

The variations in center frequency, loss and bandwidth due to temperature change are temporary in nature; the filter will return to its original condition when the temperature is restored to $+25^{\circ} \mathrm{C}$.

### 3.2 Shock

A resilient rubber shock mount is used to isolate the mechanical filter structure from shock forces which could cause damage. This mount allows the average filter to withstand $100 \mathrm{G}, 6 \mathrm{msec}$, shocks without a change in the filter response. Certain mechanical filters can withstand 1500 G 's of shock before permanent damage occurs.

### 3.3 Vibration

The internal shock mount, that so effectively isolates the filter from shock, also does an excellent job against vibration forces. The average filter will safely withstand a constant 10 G vibration level between 10 to 2000 Hz . At approximately 15 G 's the elastic limit is reached causing the filter to become permanently damaged.

Often it is not only important that a filter survive a specific vibration level, but it is also important that it retains the proper response characteristics during the vibration. While the attenuation response shows little change, there is some variation of phase and some microphonic effects during vibration. These are important characteristics in applications like Omega navigation systems.

The variation of phase of an Omega filter as a function of vibration frequency is shown in figure 18. It will be noticed that there is a peak deviation point around 400 Hz . The reason for the peak is that the entire filter structure has a resonance at this point. This structural resonance also has an effect on the microphonic noise level.


Figure 18. Variation in Phase with External Vibration (10 G Level)

Figure 19 illustrates the levels of microphonic responses of a 100 Hz bandwidth Omega filter. These levels were measured while the filter was vibrated at a constant 5 G level over the frequency range of 50 to 4000 Hz . The maximum output occurred at 525 Hz at a level of -50 dBv .

In applications where these levels are intolerable, special structural designs can be incorporated into the equipment in order to dampen the vibrations around 500 Hz . Methods such as mounting the filter near a brace or an equipment corner, using a low-Q rubber or elastomer as an external filter mount and other vibration suppression techniques will help in limiting the phase shift and amplitude response microphonics.

A successful technique for attenuation of the low frequency microphonic responses is the use of a highpass filter network. These filters are placed in the signal path between the mechanical filter and the detector. Figures 20, 21 and 22 illustrate 3 types of filters which may be used to reduce microphonic responses. They differ in the type and number of components required. The improvement in microphonic amplitude response as a result of using these filters is presented in figures 23 through 26.

The filter circuit of figure 20 will attenuate the microphonic level by approximately 15 dB . It is a single section consisting of 1 reactive component, however, it will not attenuate any spurious frequencies above the filter passband.

The high-pass circuit of figure 21 consists of 3 reactive components and will attenuate only frequencies below 9 kHz . This LC circuit provides 60 dB of rejection at microphonic frequencies.

A "roofing" bandpass filter may be used to attenuate both the spurious modes at high frequencies and the microphonic signals at low frequencies. One circuit which may be used appears in figure 22. The complexity of this circuit is a function of how much attenuation is required by the user, i.e., additional sections provide greater attenuation.


Figure 19. Omega Filter Microphonic Response


Figure 20. RC High.Pass Filter


Figure 21. LC High-Pass Filter


Figure 22. Bandpass Filter

### 3.4 Moisture Resistance

The four available low-frequency mechanical filter enclosures have been tested to MIL-STD-202, method 106. This strenuous test is used to evaluate materials which are subjected to high humidity tropical environments.

The test consists of ten days at 90-95\% humidity with the temperature being cycled from $-10^{\circ} \mathrm{C}$ to $+65^{\circ} \mathrm{C}$. At the end of each 24 hr . cycle, the filter enclosures are vibrated at a 9 G level.

Two enclosures, 'LC' and 'FP', passed the test without a change in the filter response or the enclosure. Although the all-plastic 'LC' enclosure passed the test, it should receive additional moisture protection, such as "post coat", if the filter is to be subjected to this type of environment for a long period of time. The additional moisture barrier is necessary because most plastics are permeable to moisture, therefore, there would be an eventual effect on the filter response. No precautions need to be taken with the all-metal 'FP' enclosure.

The plastic 'PA' and 'FS' enclosures were also subjected to the above moisture test. On these, the epoxy seal around the cases showed signs of degradation and cracking. Moisture apparently enters the filters through the damaged seal, however, the filter response was unchanged and the filters functioned normally. It is not recommended that these enclosures be used in tropical environments because of the possibility of seal failure.


Figure 23. Omega Filter Microphonic Response


Figure 24. Omega Filter Microphonic Response


Figure 25. Omega Filter Microphonic Response


Figure 26. Omega Filter Microphonic Response

## COLLINS USB-LSB-AM MECHANICAL FILTERS



Rockwell-Collins Filter Products offers a complete set of mechanical filters for the communication radio service. Either upper or lower sideband filters plus a super-selective AM filter are available. The unique design features of the original upper sideband filter are incorporated into all three of these filters. You get the inherent stability with time and environmental change of all RockwellCollins Mechanical Filters, along with low volume prices. Here is a very cost-effective package for the ultimate SSB and AM radio.

These filters incorporate quality features that have made Collins Mechanical Filters famous. The disk resonators are made from specially processed Ni -Span " C ", so that filter frequency shift with change in temperature is minimized. For example, over the temperąture range of $30^{\circ} \mathrm{C}$ to $+50^{\circ} \mathrm{C}$ a typical value of total frequency shift for the carrier side 3 dB point of a sideband filter would be 45 Hz . Custom-made ferrite transducers keep the insertion loss low. Normal welded construction is used for the filter assembly. The result is a trio of filters that are very stable with time and/or temperature and have the high performance characteristics needed for minimum interference operations.

The curves shown here illustrate the typical response characteristics of the three filters. Even with the exceptional selectivity and stability of these fine filters, they are competitively priced in volume. Contact your local Rockwell Sales Representative and find out how little it costs to use the best.


FILTER TEST CIRCUIT


The filters were designed with the input balanced and the output unbalanced, so that the radio designer can operate them in a balanced modulator circuit (or any other balanced circuit). Either end may be used as input (or output) but only one end is balanced. Both ends of the sideband filters should be terminated with 2700 ohms resistance, with the filter terminals shunted by 360 pf of capacitance. The AM filter should be terminated with 12,000 ohms resistance and 360 pf of capacitance.

Part Numbers are: $\quad 526-9897-010$, USB
526-9939-010, LSB
526-9920-010. AM

## FURTHER INFORMATION

For technical information on Rockwell filter products or to discuss a filter to your specifications, contact

Rockwell International
Filter Products
4311 Jamboree Road
Newport Beach, CA 92660

Phone 714/833-4632 or contact your local Rockwell Representative.

TYPICAL PERFORMANCE CHARACTERISTICS:

| Parameter | Filter Type | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 3 dB Bandwidth | $\begin{aligned} & \text { USB/LSB } \\ & \text { AM } \end{aligned}$ | $\begin{aligned} & 1,950 \\ & 5,000 \end{aligned}$ | $\begin{aligned} & 2,200 \\ & 5,500 \end{aligned}$ |  | $\begin{aligned} & \mathrm{Hz} \\ & \mathrm{~Hz} \end{aligned}$ |
| 60 dB Bandwidth | $\begin{aligned} & \text { USB/LSB } \\ & \text { AM } \end{aligned}$ |  | $\begin{array}{r} 4,500 \\ 11,000 \end{array}$ | $\begin{array}{r} 5,500 \\ 13,000 \end{array}$ | $\begin{aligned} & \mathrm{Hz} \\ & \mathrm{~Hz} \end{aligned}$ |
| Insertion Loss | $\begin{aligned} & \text { USB/LSB } \\ & \text { AM } \end{aligned}$ |  | $\begin{aligned} & 3.5 \\ & 8 \end{aligned}$ | $\begin{array}{r} 8 \\ 12 \end{array}$ | $\begin{aligned} & \mathrm{dB} \\ & \mathrm{~dB} \end{aligned}$ |
| Passband Response Variation | $\begin{aligned} & \text { USB/LSB } \\ & \text { AM } \end{aligned}$ |  | $\begin{aligned} & 1 \\ & 2.5 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3.5 \end{aligned}$ | $d B$ $d B$ |

FILTER PRODUCTS DATA SHEET

## F455FD SERIES LOW-COST MECHANICAL FILTERS

Rockwell-Collins' low cost F455FD-series of Mechanical Filters takes full advantage of advances in manufacturing techniques to realize superior performance at a modest price for manufacturers of SSB, AM and CW communications equipment. An additional saving in cost is achieved by writing worst-case limit specification requirements which are suitable for the intended applications, and then over-designing the filters to minimize costly inspection and test procedures. As an example, actual insertion loss values are typically 5 or 6 dB , while the specified maximum is 10 dB . Actual 60 dB to 3 dB bandwidth ratios are typically 2 to 1 while the specified maximum ratios range from 2.3-to-1 to 3.3-to-1. Actual response variation values are typically 1 to 1.5 dB , while the specified maximum is 3 dB .

## RECOMMENDED OPERATING PARAMETERS

All seven of the filters in the F455FD-series are designed to operate with 2,000 -ohm source and load resistances, and need to be parallel-tuned with a fixed capacitance, the value of which can vary $\pm 5 \%$ from nominal with negligible effect on the filter performance. This makes for easy and inexpensive assembly in production radios. The signal input voltage should not exceed 2 volts RMS.

A common ground connection and effective shielding between the input and the output must be used to obtain full advantage of the Mechanical Filter's selectivity.

The filters are normally used inter-stage. Used in an IF stage of a receiver, or the modulator stage in an exciter, the filter eliminates the need for additional selectivity components, and permits simplified circuit design and production tuning procedures.

## ELECTRICAL CHARACTERISTICS

| Part and Type Numbers | Minimum 3 dB BW © $25^{\circ} \mathrm{C}$ ( kHz ) | Minimum 4 dB BW OTR ( $\mathbf{k H z}$ ) | Maximum 60 dB BW © $25^{\circ} \mathrm{C}$ (kHz) | Maximum 60 dB BW OTR ( kHz ) | $\begin{gathered} \mathbf{C}_{1}, C_{2} \\ \text { Res Cap } \\ \pm 5 \% \\ \text { (pf) } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 526.9689 .010 \\ & \text { F455FD.04 } \end{aligned}$ | 0.375 | 0.375 | 3.5 | 4.0 | 350 |
| $\begin{aligned} & 526-9690.010 \\ & \text { F455FD } \end{aligned}$ | 1.2 | 1.2 | 8.7 | 9.5 | 350 |
| $\begin{aligned} & 526.9691 \cdot 010 \\ & \text { F455FD. } 19 \end{aligned}$ | 1.9 | 1.9 | 5.4 | 5.9 | 330 |
| $\begin{aligned} & \text { 526.9692.010 } \\ & \text { F455FD.25 } \end{aligned}$ | 2.5 | 2.5 | 6.5 | 7.0 | 510 |
| $\begin{aligned} & \text { 526-9693-010 } \\ & \text { F455FD-29 } \end{aligned}$ | 2.9 | 2.9 | 7.0 | 8.0 | 510 |
| $\begin{aligned} & 526.9694-010 \\ & \text { F455FD. } 38 \end{aligned}$ | 3.8 | 3.8 | 9.0 | 10.0 | 1000 |
| $\begin{aligned} & \text { 526-9695-010 } \\ & \text { F455FD. } 58 \end{aligned}$ | 5.8 | 5.8 | 14.0 | 15.0 | 1100 |



Termination circuits should be designed to eliminate DC currents and voltages from the filter. Satisfactory results may be obtained with current up to 2 ma DC, but in no case to exceed 3 ma DC. DC voltage should not exceed 100 volts DC

## ENVIRONMENTAL SPECIFICATIONS

Shock.
.MIL-STD-202, Method 202
Vibration. .MIL-STD-202, Method 201
Operating Temperature Range (OTR) . . . . . . $10^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}$

## COMMON CHARACTERISTICS:

Maximum Ripple Voltage @ $25^{\circ} \mathrm{C}$. . . . . . . . . . . . . . . . . . . . . . . . . . . 3.0 dB
Operating Temperature Range (OTR) . . . . . . . . . 4.0 dB
Maximum Insertion Loss @ $25^{\circ}$ C. . . . . . . . . . . . . . . . . . . . . . . . . . 10.0 dB Operating Temperature Range (OTR) . . . . . . . 12.0 dB

Minimum 60 dB Stop Band Range . . . . . . 445 kHz to F60L F 60 H to 465 kHz
$R_{S}$ and $R_{L}, \pm 5 \%$
.2,000 $\Omega$



MECHANICAL FILTERS/GENERAL INFORMATION


The Rockwell-Collins Mechanical Filter is a mechanically resonant device which receives an electrical signal, converts this signal into mechanical vibrations, rejects unwanted frequencies within the mechanical structure, and then converts the mechanical vibration back into electrical energy. The filter consists of three basic elements: (1) transducers which convert electrical signals into mechanical vibrations, (2) high Q mechanically resonant metal discs, and (3) disc coupling wires. The multi-element filter shown in the diagram illustrates how the center frequency is determined by the discs. Each disc is represented by a parallel resonant circuit.

Applications for the wide range of standard filters include single sideband, high performance transmitting and receiving equipment, multiplexing equipment, missile guidance systems, precision navigation equipment, spectrum analyzers, FM communications receivers, CB transceivers, and others.

## FURTHER INFORMATION

For technical information on Rockwell filter products or to discuss a filter to your specifications, contact

## Rockwell International

Filter Products
4311 Jamboree Road
Newport Beach, CA 92660

Phone 714/833-4632 or contact your local Rockwell Representative.

## Disc-Wire Mechanical Filters Standard Products and Specifications

| Cntr. Freq ( kHz ) | Part Number | $\begin{array}{\|c\|} \hline \text { Typical } \\ \text { P/B } \\ (\mathrm{kHz} / \mathrm{dB}) \end{array}$ | Typical Stopband ( $\mathrm{kHz} / \mathrm{dB}$ ) | Source \& Load K ohms | Res Cap. (pf) | Function | Caše Style |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 256 | 526-9700-010 | 3.6/1.0 | 8.4/600 | 5.0 | 350 | LSB | Spec |
| 300 | 526-9311-000 | 2.95/2.5 | 5.2/60 | 100.0 | 110 | LS8 | L Spec |
| 300 | 526-9312-000 | 2.95/2.5 | 5.2/60 | 100.0 | 110 | USB | L Spec |
| 450 | 526-9963-010 | 0.320/3.0 | 1.2/60 | 5.0 | 180 | CW | HS |
| 450 | 526-9963-020 | 0.650/3.0 | 2.1/60 | 5.0 | 270 | CW | HS |
| 450 | 526-9963-030 | 1.2/3.0 | $31 / 60$ | 5.0 | 110 | BP | HS |
| 450 | 526-9963-040 | 3.4/3.0 | 6.0/60 | 5.0 | 360 | BP | HS |
| 450 | 526-9963-060 | 6.8/3.0 | 1.5/60 | 50 | 750 | BP | HS |
| 450 | 526-9643-010 | 6.0/6.0 | 23.0/60 | 20.0 | 30 | BP | V |
| 450 | 526-9643-030 | 6.75/6.0 | 23.0/60 | 20.0 | 30 | BP | V |
| 450 | 526-9776-010 | 8.0/6.0 | 31.0/60 | 20.0 | 30 | BP | $V$ |
| 450 | 526-9901-010 | 2.35/6.0 | 4.0.60 | 20.0 | 30 | USB | $V$ |
| 450 | 526-9902-010 | 2.35/6.0 | 4.0/60 | 20.0 | 30 | LSB | $V$ |
| 450 | 526-9955-010 | 2.8/3.0 | 4.6/60 | 5.0 | 30 | USB | FD |
| 450 | 526-9956-010 | 2.8/3.0 | 4.6/60 | 5.0 | 30 | LSB | FD |
| 450 | 526-9923-010 | 28/3.0 | 4.5/60 | 50 | 30 | USB | FD |
| 450 | 526-9924-010 | 2.8/3.0 | 4.5/60 | 5.0 | 30 | LSB | FD |
| 450 | 526-9678-010 | 3.35/2.0 | 4.75/60 | 20.0 | 30 | USB | $V$ |
| 450 | 526-9679-010 | 3.35/2.0 | 4.75/60 | 20.0 | 30 | LSB | $V$ |
| 450 | 526-9936-010 | 6.1/3.0 | $87 / 50.0$ | 2.0 | 30 | LSB | FA |
| 450 | 526-9937-010 | 6.1/3.0 | $8.7 / 50.0$ | 2.0 | 30 | USB | FA |
| 455 | 526-9764-0t0 | 0.2/3.0 | 2.4/60 | 5.0 | 50 | CW | $V$ |
| 455 | 526-9689-010 | 0.525/3.0 | 3.5/60 | 2.0 | 350 | CW | FD |
| 455 | 526-9494-000 | 0.5/6.0 | 3.0/60 | 100.0 | 130 | CW | FA |
| 455 | 526-9521-000 | 0.5/6.0 | 3.0/60 | 100.0 | 130 | CW | Y |
| 455 | 526-9765-010 | 0.5/3.0 | 3.5/60 | 50 | 200 | CW | $V$ |
| 455 | 526-9446-000 | 0.90/6.0 | 4.0/60 | 100.0 | 130 | CW | FA |
| 455 | 526-9770-010 | 1.175/3.0 | 6.0/60 | 5.0 | 100 | BP | $v$ |
| 455 | 526-9690-010 | 1.35/3.0 | 8.0/60 | 2.0 | 350 | BP | FD |
| 455 | 526-9495-000 | 1.50/6.0 | 3 5/60 | 1000 | 130 | BP | FA |
| 455 | 526-9691-010 | 2.05/3.0 | 5.4/60 | 2.0 | 330 | BP | FD |
| 455 | 526-9337-000 | 2.1/6.0 | 5.3/60 | 100.0 | 130 | BP | $Y$ |
| 455 | 526-9427-000 | 2.1/6.0 | $53 / 60$ | 1000 | 130 | BP | FA |
| 455 | 526-9766-010 | 2.25/30 | 6.3/60 | 5.0 | 130 | BP | $V$ |
| 455 | 526-9860-010 | 2.8/3.0 | 11.75/70 | 2.0 | 1500 | BP | V |
| 455 | 526-9692-010 | 2.8/3.0 | 6.5/60 | 2.0 | 510 | BP | FD |
| 455 | 526-9904-010 | 2.65/3.0 | 7.0/60 | 2.0 | 510 | BP | V |
| 455 | 526-9500-000 | 2.3/3.0 | 6.2/60 | 100.0 | 130 | BP | FA |
| 455 | 526-9693-010 | 3.05/3.0 | 7.0/60 | 2.0 | 510 | BP | FD |
| 455 | 526-9772-010 | 2.0/3.0 | 9.0/60 | 5.0 | 50 | BP | $v$ |
| 455 | 526-9496-000 | 3.1/6.0 | 6.5/60 | 100.0 | 130 | BP | FA |
| 455 | 526-9338-000 | 3.1/6.0 | 6.5/60 | 100.0 | 130 | BP | Y |
| 455 | 526-9694-010 | 3.95/3.0 | 9.0/60 | 2.0 | 1000 | BP | FD |
| 455 | 526-9339-000 | 4.0/6.0 | 8.5/60 | 1000 | 130 | BP | Y |
| 455 | 526-9639-010 | 4.0/6.0 | 8.5/60 | 0.750 | 130 | BP | Y |
| 455 | 526-9767-010 | 4.0/3.0 | 12.0/60 | 5.0 | 470 | BP | $V$ |
| 455 | 526-9497-000 | 4.0/6.0 | 8.5/60 | 100.0 | 130 | BP | FA |
| 455 | 526-9920-010 | 5.5/3.0 | 13.0/60 | 12.0 | 360 | BP | HS |
| 455 | 526-9930-010 | 5.8/4.0 | 12.0/63 | 3.0 | 820 | BP | YA |
| 455 | 526-9695-010 | 5.95/3.0 | 14.0/60 | 2.0 | 1100 | BP | FD |
| 455 | 526-9498-000 | 6.0/8.0 | 12.6/60 | 1000 | 130 | BP | FA |
| 455 | 526-9522-001 | 6.0/3.5 | 25.0/60 | 100.0 | 130 | BP | FA |
| 455 | 528-9340-000 | 6.0/6.0 | 12.6/60 | 1000 | 130 | BP | $\boldsymbol{V}$ |
| 455 | 526-9773-010 | 6.0/3.0 | 18.0/60 | 5.0 | 750 | BP | $V$ |
| 455 | 526-9341-000 | 8.0/6.0 | 18.5/60 | 100.0 | 130 | BP | $Y$ |
| 455 | 526-9768-010 | 8.0/3.0 | 24.0/60 | 5.0 | 680 | BP | $v$ |
| 455 | 526-9774-010 | 12.0/3.0 | 36.0/60 | 5.0 |  | BP | $V$ |
| 455 | 526-9667-010 | 15.0/6.0 | 30.0/60 | 0.500 | See Spec: | BP | $T$ |
| 455 | 526-9343-000 | 16.0/6.0 | 27.5/60 | 100.0 | 130 | BP | Y |
| 455 | 526-9769-010 | 16.0/3.0 | 30.0/60 | 5.0 | 1100 | BP | V |


| Cntr. Freq. ( kHz ) | Part Number | $\begin{array}{\|c\|} \hline \text { Typical } \\ \text { P/B } \\ (\mathrm{kHz} / \mathrm{dB}) \end{array}$ | Typical Stopband ( $\mathrm{kHz} / \mathrm{dB}$ ) | Source a Load K ohms | Res. <br> Cap. <br> (pi) | Function | Case Style |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 455 | 526-9605-010 | 1.85/3.0 | 5.0/60 | 100.0 | 130.0 | USB | FA |
| 455 | 526-9606-010 | 1.85/3.0 | 5.0/60 | 100.0 | 130.0 | LSB | FA |
| 455 | 526-9897-010 | 2.1/3.0 | 6.25/60 | 2.7 | 360 | USB | HS |
| 455 | 526-9939-010 | 2.1/3.0 | 6.25/60 | 2.7 | 360 | LSB | HS |
| 455 | 526-9967-010 | 2.3/3.0 | 4.8/60 | 1.0 | 30 | USB | YA |
| 455 | 526-9870-010 | 2.4/3.0 | 5.35/60 | 2.0 | 680 | USB | $V$ |
| 455 | 526-9724-010 | 2.65/6.0 | $43 / 60$ | 2.0 | 700 | USB | FA |
| 455 | 526-9640-010 | 2.8/3.0 | 7.5/60 | 0750 | 130 | LSB | Y |
| 455 | 526-9641-010 | 2.8/3.0 | 7.5/60 | 0.750 | 130 | USB | $Y$ |
| 455 | 526-9958-010 | 3.15/3.0 | 4.9/60 | 5.0 | 270 | LSB | HS |
| 455 | 526-9959-010 | 3.15/3.0 | 4.9/60 | 5.0 | 270 | USB | HS |
| 455 | 526-9364-000 | 3.0/3.0 | 6.0/60 | 100.0 | 130 | USB | $Y$ Long |
| 455 | 526-9365-000 | 3.0/3.0 | 6.0/60 | 100.0 | 130 | LSB | Y Long |
| 455 | 526-9903-010 | 3.2/1.5 | 4.9/40 | 2.0 | 30 | LSB | FD |
| 455 | 526-9698-010 | 3.3/3.0 | 4.8/40 | 2.0 | 30 | USB | FD |
| 455 | 526-9699-010 | 3.0/3.0 | 4.8/40 | 2.0 | 30 | LSB | FD |
| 455 | 526-9899-010 | $3.0 / 30$ | 4.9/60 | 2.0 | 30 | LSB | V |
| 455 | 526-9900-010 | 3.0/3.0 | 4.9/60 | 2.0 | 30 | USB | $V$ |
| 455 | 526-9892-010 | 3 3/3.0 | 4.75/60 | 2.0 | 30 | USB | V |
| 455 | 526-9783-010 | 6.3/3.0 | $8.7 / 50$ | 2.0 | 30 | LSB | $V$ |
| 455 | 526-9784-010 | 6.3/3.0 | $8.7 / 50$ | 2.0 | 30 | US8 | $V$ |
| 500 | 526-9588-010 | 0.8/3.0 | 3.0/60 | $\begin{aligned} & S=1.0 \\ & L=0.330 \end{aligned}$ | See Spec | CS | Y Flange |
| 500 | 526-9719-010 | 1.15/3.0 | 5.6/60 | 2.0 | 30 | BP | V |
| 500 | 526-9717-010 | 3.3/3.0 | 7.0/60 | 2.0 | 30.0 | BP | $v$ |
| 500 | 526-9717-020 | 3.3/3.0 | 7.0/60 | 20 | 30.0 | BP | FD |
| 500 | 526-9378-000 | 6.4/3.0 | 13.2/60 | 1000 | 120.0 | BP | $Y$ |
| 500 | 526-9718-010 | 6.3/30 | 13.0/60 | 2.0 | 30.0 | BP | $V$ |
| 500 | 526-9646-010 | 8.3/3.0 | 20.0/40 | 1.0 | 51 | BP | $V$ |
| 500 | 526-9663-010 | 1.8/2.0 | 5.38/60 ${ }^{\circ}$ | 20.0 | 160 | USB | $Y$ Long |
| 500 | 526-9664-010 | 1.8/2.0 | $538 / 60$ | 20.0 | 160 | LSB | $Y$ Long |
| 500 | 526-9663-020 | 2.3/3.0 | 4.30/60 | 20.0 | 160 | USB | FD |
| 500 | 526-9906-010 | 2.34/6.0 | 4.6/60 | 30 | 180 | LSB | FD |
| 500 | 526-9906-020 | 2.34/6.0 | 4.6/60 | 30 | 180 | LSB | YA |
| 500 | 526-9414-000 | 2.713.0 | 6.1/60 | 100.0 | 120 | USB | $Y$ |
| 500 | 526-9415-000 | 2.7/3.0 | 6.1/60 | 1000 | 120 | LSB | $Y$ |
| 500 | 526-9616-010 | 2.713.5 | 6.1/60 | 1000 | 120 | LSB | $V$ |
| 500 | 526-9376-000 | 3.0/3.0 | 5.8/60 | 100.0 | 105 | LSB | $Y$ |
| 500 | 526-9377-000 | 3.0/3.0 | 5.8/60 | 100.0 | 105 | USB | Y |
| 500 | 526-9873-010 | 2.85/3.0 | 6.5/60 | 20.0 | 100 | US8 | YA |
| 500 | 526-9874-010 | 2.85/3.0 | 6.5/60 | 20.0 | 100 | LSB | YA |
| 500 | 526-9927-010 | 3.3/3.0 | 6.5/60 | 20.0 | 100 | USB | Y |
| 500 | 526-9928-010 | 3.3/3.0 | 6.5/60 | 20.0 | 100 | LBS | $Y$ |
| 500 | 526-9644-010 | 3.35/3.0 | 59/50 | 1.0 | 20 | USB | $V$ |
| 500 | 526-9645-010 | 3.35/3.0 | 5.9/50 | 1.0 | 20 | LSB | $V$ |
| 500 | 526-9968-010 | 4.6/3.0 | 6.75/50 | 1.0 | 20 | USB | $V$ |
| 500 | 526-9711-010 | 6.3/3.0 | 10.5/50 | 1.0 | 30 | LSB | $V$ |
| 500 | 526-9712-010 | 6.3/3.0 | 10.5/50 | 1.0 | 30 | USB | V |

## FURTHER INFORMATION

For technical information on Rockwell filter products or to discuss a filter to your specifications, contact

Rockwell International
Filter Products
4311 Jamboree Road
Newport Beach, CA 92660
or phone 714/833-4324 or 714/833-4544. To order. phone 714/ $833-4632$ or contact your local Rockwell Representative.


## Low Frequency Narrowband Mechanical Filters Standard Products and Specifications



DOCUMENT NO. F-03
REV. 2, NOVEMBER 1980


## FURTHER INFORMATION

For technical information on Rockwell filter products or to discuss a filter to your specifications, contact

Rockwell International
Filter Products
4311 Jamboree Road
Newport Beach, CA 92660
or phone 714/833-4324 or 714/833-4544. To order, phone 714/ 833-4632 or contact your local Rockwell Representative.

Notes

Notes

Notes

Notes

ELECTRONIC DEVICES DIVISION REGIONAL ROCKWELL SALES OFFICES



Electronic Devices Division

## 3310 Miraloma Avenue

P.O. Box 3669

Anaheim, CA 92803
Toll Free (800) 854-8099
in California (800) 422-4230
Rockwell International
QRockwell International Corporation 1981


[^0]:    MULTIPLEXED FUNCTION PINS (Sotlware Selectable)

[^1]:    AlM 65 puts a roomfull of computing

[^2]:    Printed in U.S.A.

[^3]:    ORockwell International Corporation 1981
    All Rights Reserved
    Printed in U.S.A.

[^4]:    I = ISOLATED POWER STRIPS
    Design Prototyping Module - Edge Connector (Wirewrap Side)

[^5]:    Rockwell's optional USER 65(User System EvaluatoR) module allows . . .
    the full power of the SYSTEM 65 to be extended into the user's system. By removing the R6500 CPU from the user system and connecting the USER 65 cable into the CPU socket, the SYSTEM 65 Debug firmware can be used to test and troubleshoot microprocessor systems.

[^6]:    (C) Rockwell International Corporation 1979

    Alt Rights Reserved
    Printed in U.S.A.

[^7]:    (5)

    ENTER 2704, 2708, 2758, 2716, 2516, 2532
    2716 PROM
    TMS
    $=N$

    ```
    ************************
    2716
    ENTER PROM COMMFND: VERIFY(V),PROGRAM(F),READ(R),OR CHECK(C)
    OR MEMORY COMMANO: VERIFY(F),LOAD(L), DUMP(D), MEM FILL(M). INYERT(I)
    =R
    ENTER FIRST RDDRESS
    NTER
    ENTER LRST RDDRESS
    DONE
    ********************
    DEVICE TYPE=
    2716
    ENTER PROM COMMFND: VERIFY(V),PROGRAM(P),REAO(R),OR CHECK(C)
    OR MEMORY COMMAND: VERIFY(F),LOAD(L), CUMP(D),MEM FILL(M), INVERT (I)
    ```

[^8]:    [ ]= bit number

[^9]:    - The size of the index register (ix) does not affect execution time.

[^10]:    Digital outputs are directly CMOS or low-power Schottky TTL compatible.

[^11]:    - Registered trademark of AT\&T

[^12]:    ${ }^{(\oplus)}$ Registered trademark of AT\&T

[^13]:    1 G. Hansell, Filter Design and Evaluation, Van Nostrand Reinhold Company, 1969.
    Howard W. Sams, Reference Data for Radio Engineers, 1968.
    A. Zverev, Handbook of Filter Synthesis, John Wiley and Sons, Inc., 1967.

