

# 1984 <br> DATA <br>  

Second Edition

## Rockwell International



## Semiconductor Products Division

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

## notice

Rockwell International does not assume any liability arising out of the application or use of any products, circuit or software described herein, neither does it convey any license under its patent rights nor the patent rights of others. Rockwell International further reserves the right to make changes in any products described herein without notice. Specifications in the Data Book are subject to change without notice. Preliminary specifications have tentative parameters which may be subject to change after final product characterization is completed.

## TABLE OF CONTENTS

Rockwell Semiconductor Cross-Reference Guide ..... 1
Application Note Index ..... 2
Index By Product Family ..... 3
SECTION
1 R6800 Microprocessor and Peripherals ..... 1-1
Product Family Overview ..... 1-2
R68000 16-Bit Microprocessing Unit (MPU) ..... 1-3
R68465 Double-Density Floppy Disk Controller (DDFDC) ..... 1-58
R68560 and R68561 Multi-Protocol Communications Controller (MPCC) ..... 1-83
R68802 Local Network Controiler (LNET) ..... 1-115
R68C552 Dual Asynchronous Communications Interface Adapter (DACIA) ..... 1-135
2 8-Bit Microprocessors and Peripherals ..... 2-1
Product Family Overview ..... 2-2
R6500 Family Products
R650X and R651X Microprocessors (CPU ..... 2-3
R6501Q and R6511Q One-Chip Microprocessors ..... 2-18
R6520 Peripheral Interface Adapter (PIA) ..... 2-24
R6522 Versatile Interface Adapter (VIA) ..... 2-36
R6530 ROM-RAM-I/O-Timer (RRIOT) ..... 2-58
R6531 ROM-RAM-I/O-Counter (RRIOC) ..... 2-69
R6532 RAM-I/O-Timer (RIOT) ..... 2-82
R6541Q, R6500/41, R6500/42 and R6500/43 One-Chip Intelligent Peripheral Controller ..... 2-92
R6545-1 CRT Controlier (CRTC) ..... 2-100
R6551 Asynchronous Communications Interface Adapter (ACIA) ..... 2-116
R6565 Double-Density Floppy Disk Controller (DDFDC) ..... 2-136
R6592 Single Chip Printer Controller ..... 2-161
R65560 Multi-Protocol Communications Controller (MPCC) ..... 2-172
R65C02, R65C102 and R65C112 CMOS Microprocessors (CPU) ..... 2-202
R65C21 CMOS Peripheral Interface Adapter (PIA) ..... 2-217
R65C24 CMOS Peripheral Interface Adapter Timer (PIAT) ..... 2-229
R65C51 CMOS Asynchronous Communications Interface Adapter (ACIA) ..... 2-249
R65C52 CMOS Dual Asynchronous
Communications Interface Adapter (DACIA) ..... 2-269
Z80/8080 Bus Compatible Products
R6265 Micro Floppy DiskController (MFDC)2-288
R6765 Double-Density Floppy Disk Controller (DDFDC) ..... 2-313
3 R6500/* Microcomputers ..... 3-1
Product Family Overview ..... 3-2
R65C00/21 and R65C29 Dual CMOS Microcomputer and Dual CMOS Microprocessor ..... 3-3
R65F11 and R65F12 FORTH One-Chip Microcomputers ..... 3-35
R65FRX and R65FKX RSC FORTH Development and Kernel ROMs ..... 3-67
R6501Q One-Chip Microprocessor ..... 3-75
R6500/1 One-Chip Microcomputer ..... 3-104
R6500/1E Emulator Device ..... 3-135
R6500/1EB and R6500/1EAB Backpack Emulator ..... 3-142
R6500/11 and R6500/12 One-Chip Microcomputers ..... 3-147
R65/11EB and R65/11EAB Backpack Emulator
R65/11EB and R65/11EAB Backpack Emulator ..... 3-182 ..... 3-182
R6500/13 and R6511Q One-Chip Microcomputer and One-Chip Microprocessor ..... 3-187
R6500/41 and R6500/42 One-Chip Intelligent Peripheral Controllers ..... 3-222
R65/41EB and R65/41EAB Backpack Emulator ..... 3-251
R6500/43 and R6541Q One-Chip Intelligent Peripheral Controllers ..... 3-256
4 Memory Products ..... 4-1
Product Family Overview ..... 4-2
Masked ROMs
R2332A and R2332B 32K NMOS Static ROM ..... 4-3
R2364A 64K NMOS Static ROM ..... 4-7
R2364B 64K NMOS Static ROM ..... 4-11
R23C64 64K CMOS Static ROM ..... 4-15
R23128 128K NMOS Static ROM ..... 4-19
UV Erasable and One-Time PROMs
R27C64P 64K CMOS One-Time PROM ..... 4-23
R87C32 32K CMOS UV EPROM ..... 4-29
R87C64 64K CMOS UV EPROM ..... 4-35
EEROMs
R5213/2816 16K EEROM ..... 4-41
R52B33 64K Latched EEROM ..... 4-49
R2816A and R5516A 16K Latched EEPROM with Timer ..... 4-57
NVRAM
R2000 $64 \times 8$ Non-Volatile RAM ..... 4-65
EPROM Pinouts Guide ..... 4-71
5 Intelligent Display Controllers ..... 5-1
Product Family Overview ..... 5-2
10937 Alphanumeric Display Controller ..... 5-3
10938 and 10939 Dot Matrix Display Controller ..... 5-11
10939, 10942 and 10943 Dot Matrix Display Controller ..... 5-20
10941 and 10939 Alphanumeric and Bargraph Display Controller ..... 5-32
10951 Bargraph and Numeric Display Controller ..... 5-41
6 Microcomputer Development Systems ..... 6-1
Product Family Overview ..... 6-2
Rockwell Design Center (RDC)
RDC-1001 and RDC-1002 RDC System ..... 6-3
RDC-1XX and RDC-3XX RDC R6500/* Personality Set ..... 6-9
RDC-502 and RDC-504 R6502-R65C02 Personality Set ..... 6-13
RDC-2000 R6500 Cross Assembler for Intel Development System ..... 6-17
System 65 Development System(Optional Modules)
M65-1XX and M65-2XX System 65 R6500/*Personality Set6-19
M65-001, M65-002, and M65-003 User 65 Module ..... 6-23
M65-031 and M65-032 16K Static RAM Module ..... 6-28

## TABLE OF CONTENTS (Continued)

M65-040 PROM Programmer Module ..... 6-31
M65-045 PROM/ROM Module ..... 6-39
M65-060 Extender Card ..... 6-43
M65-071 Design Prototyping Module ..... 6-44
M65-660 Macro Assembler and Linking Loader ..... 6-46
Software Preparation System
SPS-200 Software Preparation System Peripheral Connector Module ..... 6-48
7 AIM 65 Microcomputer Family ..... 7-1
Product Family Overview ..... 7-2
A65-100 and A65-400 AIM 65 Microcomputer ..... 7-3
A65-0500 AIM 65 Microcomputer System ..... 7-10
A65-002 and A65-006 AIM 65 Microcomputer Enclosure ..... 7-12
A65-003 Service Test Board ..... 7-14
A65-004-03 Power Supply and Cable ..... 7-16
A65-010 Assembler ROM ..... 7-18
A65-020 BASIC Interpreter ROMs ..... 7-20
A65-024 BASIC Compiler ..... 7-22
A65-030 PL/65 Compiler ROMs ..... 7-24
A65-040 Math Package ROM ..... 7-26
A65-050 FORTH ROMs ..... 7-28
A65-052 FORTH Target Compiler ..... 7-33
A65-060 Instant Pascal ROMs ..... 7-38
A65-090 Disk Operating System (DOS 1.0) ROM ..... 7-41
A65-901 PROM Programmer and CO-ED Module ..... 7-42
A65-905 Memory Cartridge ..... 7-46
8 AIM 65/40 Microcomputer Family ..... 8-1
Product Family Overview ..... 8-2
A65/40-8X15 Series 8000 Microcomputer System ..... 8-3
A65/40-2000, A65/40-3000, A65/40-4000 and A65/40-5000 AIM 65/40 Microcomputer ..... 8-10
A65/40-1000 Single Board Computer ..... 8-22
A65/40-0004 Power Supply and Cable ..... 8-30
A65/40-0200 and A65/40-0210 Standard and Extended Keyboards ..... 8-32
A65/40-0400 40-Character Display ..... 8-36
A65/40-0600 Graphics Printer ..... 8-43
A65/40-0800 Video Display Controller Module ..... 8-49
A65/40-7010 Assembler ROM ..... 8-56
A65/40-7012 Macro Assembler and Linking Loader ..... 8-58
A65/40-7020 BASIC Interpreter ROMs ..... 8-59
A65/40-7024 BASIC Compiler ..... 8-61
A65/40-7040 Math Package ROM ..... 8-63
A65/40-7050 FORTH ROMs ..... 8-65
A65/40-7052 FORTH Target Compiler ..... 8-70
A65/40-7090 Disk Operating System Version 1.0 (DOS 1.0) ROM ..... 8-75
A65/40-7092 Bootstrap Disk Operating System Version 1.0 Upgrade Kit ..... 8-76
9 RM 65 Microcomputer Module Family ..... 9-1
Product Family Overview ..... 9-2
RM65-1000E Single Board Computer (SBC) Module ..... 9-3
RM65-0110 I/O ROM ..... 9-7
RM65-0122 Run-Time BASIC INTERPRETER ROM ..... 9-8
RM65-0152 Run-Time FORTH ROM ..... 9-10
RM65-2901E PROM Programmer Module ..... 9-15
RM65-3108E 8K Static RAM Module ..... 9-21
RM65-3132E 32K Dynamic RAM Module ..... 9-25
RM65-3216E 16K PROM/ROM Module ..... 9-29
RM65-3264NE Univeral Memory Module ..... 9-33
RM65-5101E Floppy Disk Controller (FDC) Module ..... 9-37
RM65-5102E CRT Controller (CRTC) Module ..... 9-43
RM65-5104E Direct Memory Access Controller Module ..... 9-49
RM65-5222E General Purpose Input/Output (GPIO) and Timer Module ..... 9-54
RM65-5223E Multi-Function Peripheral Interface (MPI) Module ..... 9-58
RM65-5302E and RM65-5303E Analog Input Module and Analog Input/Output Module ..... 9-63
RM65-5451E Asynchronous Communications Interface Adapter (ACIA) Module ..... 9-69
RM65-7004E and RM65-7004NE 4-Slot Piggyback Module Stack and Motherboard ..... 9-73
RM65-7008E and RM65-7008NE 8-Slot Card Cage and Motherboard ..... 9-78
RM65-7016E and RM65-7016NE 16-Slot Card Cage and Motherboard ..... 9-83
RM65-7101E Single Card Adapter Module for AIM 65 ..... 9-88
RM65-7102E IEEE-488 Bus Interface Module ..... 9-94
RM65-7104E Adapter/Buffer Module for AIM 65 ..... 9-99
RM65-7116E RM65 Cable Driver Adapter/Buffer Module for AIM 65 ..... 9-105
RM65-7141E Adapter Cable and Buffer Module for AIM 65/40 ..... 9-111
RM65-7201E Design Prototyping Module ..... 9-116
RM65-7211E Extender Module ..... 9-120
10 Integral Modems ..... 10-1
Product Family Overview ..... 10-2
High Speed
R96FAX 9600 BPS Facsimile Modem ..... 10-3
R96DP 9600 BPS Data Pump Modem ..... 10-13
R96FT 9600 BPS Fast Train Modem ..... 10-26
V96P/1 9600 BPS Modem ..... 10-28
R48DP 4800 BPS Data Pump Modem ..... 10-36
V27P/1 4800 BPS Modem ..... 10-49
Low to Medium Speed
R1212 1200 BPS Full Duplex Modem ..... 10-56
R2424 2400 BPS Full Duplex Modem ..... 10-70
R24DC 2400 BPS Direct Connect Modem ..... 10-84
R24LL 2400 BPS Leased Line Modem ..... 10-92
R24 2400 BPS Integral Modem ..... 10-101
Modem Interfacing Products
R24MEB Modem Evaluation Board ..... 10-109
RDAA Rockwell Data Access Arrangement Module ..... 10-111
11 T-1 and T-1/CEPT Pulse Code Modulation Protocol Devices ..... 11-1
Product Family Overview ..... 11-2
R8040 Tri-Port Memory ..... 11-3
R8050 T-1 Serial Transmitter ..... 11-9
R8060 T-1 Serial Receiver ..... 11-17
R8070 T-1/CEPT Pulse Code Modulation Transceiver ..... 11-23
Sales Offices, Representatives and Distributors ..... A-1

| SYNERTEK | ROCKWELL | NCR | ROCKWELL |
| :---: | :---: | :---: | :---: |
| SY6502 | R6502 | NCR6500/1E . | R6500/1EC |
| SY6503 | R6503 | NCR6500/1 | R6500/1 |
| SY6504 | R6504 | NCR6500/11 | R6500/11 |
| SY6505 | R6505 | NCR6500/12 | R6500/12 |
| SY6506 | R6506 | NCR6500/13 | R6500/13 |
| SY6507 | R6507 | NCR6500/11E | R6511Q |
| SY6512 | R6512 | NCR6500/41. | R6500/41 |
| SY6513 | R6513 | NCR6500/42 . | R6500/42 |
| SY6514 | R6514 | NCR6500/43 | R6500/43 |
| SY6515 | R6515 | NCR6500/41E | R6541Q |
| SY6520 | R6520 | NCR65C02 | R65C02 |
| SY6522 | R6522 |  |  |
| SY6530 | R6530 | SEEQ | ROCKWELL |
| SY6532 | R6532 | 5213/2816 | R5213/2816 |
| SY6545-1. | R6545-1 | 5516A | R5516A/2816A |
| SY6551 | R6551 | 5133A | R2764P |
|  |  | $52 \mathrm{B33}$ | R52B33 |
| INTEL | ROCKWELL |  |  |
| 2816. | R5213 | GTE | ROCKWELL |
| 8272. | R6765 | G65SC02. | R65C02 |
| 2816A | R5516A | G65SC21. | R65C21 |
| P2764 | R2764P | G65SC51 | R65C51 |
| P2732A | R27C32P |  | R23C64 |
|  |  | RICOH | ROCKWELL |
| MOTOROLA | ROCKWELL | RD5H32 | R87C32 |
| MC6820 | R6520 | RD5H64. | R87C64 |
| (1) MC6821 | R6520 |  |  |
| (2)MC6845 | R6545-1 | NATIONAL | ROCKWELL |
| (2)MC6845M | R6545-1 | NMC27C32 | R87C32 |
| MC68000 | R68000 | NMC9716E | R5213 |
| (1) except application of (2) TL loads <br> (2) ask customer for evaluation |  | AMI | ROCKWELL |
|  |  | S2333 | R2332 |
| MOS TECHNOLOGY | ROCKWELL | S2364 | R2364 |
| MPS6502. | R6502 | S23128 | R23128 |
| MPS6503 . | R6503 | S6551 | R6551 |
| MPS6504. | R6504 |  |  |
| MPS6505. | R6505 | FUJITSU | ROCKWELL |
| MPS6506 . | R6506 | MBM27C64 | R87C64 |
| MPS6507. | R6507 |  |  |
| MPS6512. | R6512 | AMD | ROCKWELL |
| MPS6513 | R6513 | AM2764 | R87C64 |
| MPS6514. | R6514 |  |  |
| MPS6515. | R6515 | RCA | ROCKWELL |
| MPS6520. | R6520 | CDP65564. | R23C64 |
| MPS6522 . | R6522 |  |  |
| MPS6530 . | R6530 | NEC | ROCKWELL |
| MPS6532. | R6532 | 765. | R6765 |

## APPLICATION NOTE INDEX

| Order No. | Title | Order No. | Title |
| :---: | :---: | :---: | :---: |
| R6500 Microprocessors and Peripherals |  | Development Systems |  |
| 223 <br> 296 <br> 256 <br> 226 <br> 227 <br> 225 | R6502/R6532 Timer Interrupt Precautions <br> R6502 Interfacing Higher Speed R6502's to Lower <br> Speed I/O \& Memory <br> Printer Control with R6522 VIA (Versatile Interface Adapter) <br> R6531 ROM-RAM-I/O Counter (RRIOC) <br> R6531 Address Lines for Contiguous ROM <br> Generating Non-Standard Baud Rates with the R6551 <br> ACIA (Asynchronous Communication Interface Adapter) | $\begin{gathered} 224 \\ 240 \\ 246 \\ 2129 \\ 2158 \\ 2166 \end{gathered}$ | System 65 to AIM 65 Microcomputer Interface <br> User 65 Emulation with less than 512 Bytes of RAM <br> System 65 Bus Interface <br> 0S3.1 Monitor ROM \& Macro Assembler/Linking Loader <br> CMOS User 65 System 65 Development System <br> R6500 Software Preparation System Development Configurations |
| 208 | Low-Cost Crystal Oscillator for Clock Input Frequency Generator | AIM 65 Microcomputer |  |
| $\begin{aligned} & 231 \\ & 276 \\ & 287 \end{aligned}$ | Interfacing R6500 Microprocessors to a FDC (Floppy Disk Controller) <br> Crystal Considerations for R6500 Family Devices Using R65XX Family Peripheral Devices with Z80 CPU | $\begin{aligned} & 230 \\ & 241 \\ & 273 \end{aligned}$ | RS-232C Interface for AIM 65 Microcomputer <br> Preparing an AIM 65 Basic Program for PROM/ROM Operation <br> AIM 65 Program Timer |
| R6500/* Microcomputers |  | 2171 | Adding Analog I/O to AIM 65 Microcomputer |
| 239 | Interfacing R6500/1 to SIDC (Serial Input Display Controller) | Integral Modems |  |
| 237 | R6500/1 Microcomputer-Based Printer Controller | 607 | R24 Modem Options |
| 258 | A Logical Tester for R6500/1 One-Chip Microcomputer | 608 | Quality of Received Data for R24 Modem |
| 2163 | A Dot Matrix Controller System Design Using the 10938/10939 Display Drivers and R6500/1EB Microcomputer | 619 | R24DC Interface to EIA RS-232-C <br> R24DC Interface to U.S. Switched Telephone Network |
| 2162 2178 | A Low Cost Development Module for the R65F11/R65F12 FORTH Microcomputer <br> Design Considerations for Conversion to Rockwell R6500/11 and R6501Q from Intel 8051/8031 | 624 | R24DC Modem Options <br> R24LL and R24DC Modem Control Signal To LED Interface |
| Intelligent Display Controllers |  | 632 | R24LL Modem Options |
| 2163 2175 | A Dot Matrix Controller System Design Using the 10938/10939 Display Drivers and R6500/1EB Microcomputer <br> Display Controller Designer Notes | $\begin{aligned} & 617 \\ & 637 \end{aligned}$ | 4800/9600 BPS Modem Interfacing <br> Picture Plotter Data Transmissi. System |

## PRODUCT INDEX

## R68000 Microprocessor and Peripherals

## 8-BIT Microprocessors and Peripherals

## R6500/* Microcomputers

Memory Products

Intelligent Display Controllers

Microcomputer Development Systems

AIM 65 Microcomputer Family

## AIM 65/40 Microcomputer Family

## RM 65 Microcomputer Module Family

## Integral Modems

## T-1 and T-1/CEPT Pulse Code Modulation Protocol Devices

## SECTION 1 R68000 MICROPROCESSOR AND PERIPHERALS

Page
Product Family Overview ..... 1-2
R68000 16-Bit Microprocessing Unit (MPU) ..... 1-3
R68465 Double-Density Floppy Disk Controller (DDFDC) ..... 1-58
R68560 and R68561 Multi-Protocol Communications Controller (MPCC) ..... 1-83
R68802 Local Network Controller (LNET) ..... 1-115
R68C552 Dual Asynchronous Communications Interface Adapter (DACIA) ..... 1-135

# R68000 MICROPROCESSOR AND PERIPHERAL FAMILY 16-bit Speed and Data Capacity, Peripherals to Build Efficient Systems 

Rockwell peripherals give a designer everything the 68000 family promises. They allow you to design functional systems utilizing all the speed and data handling potential of the 16 -bit 68000 family.

First of these are the Rockwell designed 16-bit peripherals-multi-protocol communications controller, double density floppy disk controller, local area network controller-each a significant "first" that eliminates the "glue parts" between a CPU and peripherals.

Not to be ignored, however, is the very wide and complete family of 8 -bit devices-processors, peripherals, memory, single-chip microcomputers-compatible with the R68000 family. All of the R6500 family of devices described in this Data Book are directly compatible with the R68000 bus. They often provide efficient, economical and very flexible ways of implementing system designs.
The Rockwell R68000 16-bit microprocessor (MPU) operates at clock speeds of $4,6,8,10$ or 12.5 MHz to match essentially any application.
The R68561 multi-protocol communications controller (MPCC) is the highest throughput communications device
ever made commercially available. It operates up to $4 \mathrm{Mbits} / \mathrm{sec}$ and supports all major communication protocols. It's available to work with either 16 -bit or 8 -bit busses and can be adapted to function with essentially any of today's more common busses.
The R68465 double density floppy disk controller (DDFDC) is an intelligent device that can run up to four disk drives without the many support devices previously required.

The R68802* provides a flexible local area network (LNET) controller for the R68000. It supports both the IEEE 802.3 and Ethernet* standards based on the proven CSMA/CD technique together with network statistics.

Rockwell lets you build efficient and economical 16-bit systems through families of 16 -bit and 8 -bit peripherals, all compatible. No other supplier offers you more.
*R68802 is a trademark of the Rockwell International Corp. *Ethernet is a trademark of the Xerox Corp.


R68000/R6500 Peripheral Migration

## PRELIMINARY

## DESCRIPTION

The R68000 microprocessor is designed for high performance where operational computation and versatility is required. The R68000 provides powerful mass-memory handling capability and architectural features designed to fit the broad range of 16-bit needs. The Rockwell family of 16-bit products also includes a wide range of peripherals that will allow complete system design and manufacture.


The R68000 offers seventeen 32-bit registers in addition to the 32 -bit program counter and a 16 -bit status register. The first eight registers (D0-D7) are used as data registers for byte (8-bit), word (16-bit), and long word (32-bit) data operations. The second set of seven registers (A0-A6) and the system stack pointer may be used as software stack pointers and base address registers. In addition, these registers may be used for word and long word address operations. All 17 registers may be used as index registers.

## FEATURES

- 16 M byte ( 8 M word) Linear Addessing Range
- 14 Operand Addressing Modes
- 56 Powerful Instruction Types
- Instruction Set Supports Structured High-Level Languages
- Pipelining Instruction Execution
- 32-Bit Program Counter
- 16-Bit Data Bus
- 23-Line Address Bus
- 32-Bit Data and Address Registers Including:
- Eight General Purpose Data Registers
- Seven Address Registers
- Two Stack Pointers (User, Supervisory)
- All 17 Registers Can Be Index Registers
- Memory Mapped Peripheral Devices
- Vector Generated Exception Processing
- Seven Unique Autovectors for Interrupt Service Routines
- Trace Mode for Software Debugging
- Operations Occur on Five Main Data Types
- Bit
- BCD
- Byte
- Word
- Long Word
- Asynchronous and Synchronous Peripheral Interface Capability
- Many Peripheral Chips Available
- R68560 Multi-Protocol Communications Controller
- R68465 Double Density Floppy Disk Controller
- R68802 Local Network Controller
- Up to 12.5 MHz Input Clock
- +5 VDC Power Supply



## ORDERING INFORMATION

| Order <br> Number | Package <br> Type | Frequency | Temperature <br> Range |
| :--- | :---: | ---: | ---: |
| R68000C4 | Ceramic DIP | 4 MHz | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| R68000C6 | Ceramic DIP | 6 MHz | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| R68000C8 | Ceramic DIP | 8 MHz | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| R68000C10 | Ceramic DIP | 10 MHz | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| R68000C12 | Ceramic DIP | 12.5 MHz | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| R68000Q8 | Plastic QUIP | 8 MHz | $0^{\circ} \mathrm{C}$ to $+55^{\circ} \mathrm{C}$ |
| R68000Q10 | Plastic QUIP | 10 MHz | $0^{\circ} \mathrm{C}$ to $+55^{\circ} \mathrm{C}$ |

## SIGNAL DESCRIPTION

The following paragraphs briefly describe the input and output signals and also reference (if applicable) other paragraphs that contain more detail about the function being performed. Bus operation during the various machine cycles and operations is also discussed. The input and output signals can be functionally organized into the groups shown in Figure 1.

## Note

The terms assertion and negation are used to avoid confusion when dealing with a mixture of "active-low" and "active-high" signals. The terms assert, or assertion, indicates that a signal is active, or true, independent of whether that voltage is low or high. The term negate, or negation, indicates that a signal is inactive or false.

ADDRESS BUS (A1 THROUGH A23). This 23-bit, unidirectional, three-state bus can address eight megawords of data. It provides the address for bus operation during all cycles except interrupt cycles. During interrupt cycles, address lines A1, A2, and A3 encode the interrupt level to be serviced while address lines A4 through A23 are all set high.

DATA BUS (DO THROUGH D15). This 16-bit, bidirectional, three-state bus is the general purpose data path. It transfers and accepts data in either word or byte length. During an interrupt acknowledge cycle, an external device supplies the vector number on data lines DO-D7.

ASYNCHRONOUS BUS CONTROL. Asynchronous data transfers are handled using the following control signals: address strobe, read/write, upper and lower data strobes, and data transfer acknowlege. These signals are explained in the foliowing paragraphs.


Figure 1. Input and Output Signals

Address Strobe ( $\overline{\mathbf{A S}}$ ). The $\overline{\mathrm{AS}}$ output indicates that there is a valid address on the address bus.
Read/Write ( $\mathbf{R} / \bar{W}$ ). The $\mathrm{R} \bar{W}$ output defines the data bus transfer as a read or write cycle. The R $\bar{W}$ signal also works in conjunction with the upper and lower data strobes as explained in the following paragraph.
Upper and Lower Data Strobes ( $\overline{\mathrm{UDS}}, \overline{\mathrm{LDS}}$ ). The $\overline{\text { UDS }}$ and $\overline{\text { LDS }}$ outputs control the data on the data bus, as shown in Table 1. When the $R / \bar{W}$ line is high, the processor reads from the data bus as indicated. When the $\mathrm{R} \overline{\mathrm{W}}$ line is low, the processor writes to the data bus as shown.

Data Transfer Acknowledge ( $\overline{\text { DTACK }}$ ). The $\overline{\text { DTACK }}$ input indicates that the data transfer is completed. When the processor recognizes $\overline{\text { DTACK }}$ during a read cycle, data is latched and the bus cycle terminated. When DTACK is recognized during a write cycle, the bus cycle terminates. Refer to ASYNCHRONOUS VERSUS SYNCHRONOUS OPERATION.

BUS ARBITRATION CONTROL. These three signals form a bus arbitration circuit to determine which device will be the bus master device.
Bus Request ( $\overline{\mathrm{BR}}$ ). The $\overline{\mathrm{BR}}$ input indicates to the processor, that some other device desires to become the bus master. This input can be externally ORed with all other devices that could be bus masters.

Bus Grant ( $\overline{\mathrm{BG}}$ ). The $\overline{\mathrm{BG}}$ output indicates to all other potential bus master devices that the processor will release bus control at the end of the current bus cycle.
Bus Grant Acknowledge ( $\overline{\text { BGACK }}$ ). The $\overline{\text { BGACK }}$ input indicates that some other device has become the bus master. This signal cannot be asserted until the following four conditions are met:

1. a bus grant $(\overline{\mathrm{BG}})$ has been received,
2. address strobe ( $\overline{\mathrm{AS}}$ ) is inactive which indicates that the processor is not using the bus

Table 1. Data Strobe Control of Data Bus

| UDS | LDS | R/W | D8-D15 | D0-D7 |
| :---: | :---: | :---: | :---: | :---: |
| High | High | - | No valid data | No valid data |
| Low | Low | High | Valid data bits 8-15 | Valid data bits 0.7 |
| High | Low | High | No valid data | Valid data bits 0-7 |
| Low | High | High | Valid data bits $8-15$ | No valid data |
| Low | Low | Low | Valid data bits 8-15 | Valid data bits 0-7 |
| High | Low | Low | Valid data bits 0.7 * | Valid data bits 0.7 |
| Low | High | Low | Valid data bits 8-15 | Valid data bits 8-15* |

*These conditions are a result of current implementation and may not appear on future devices.
3. data transfer acknowledge ( $\overline{\mathrm{DTACK}}$ ) is inactive which indicates that neither memory nor peripherals are using the bus, and
4. bus grant acknowledge ( $\overline{B G A C K}$ ) is inactive which indicates that no other device is still claiming bus mastership.

INTERRUPT CONTROL ( $\overline{\mathbf{I P L O}}, \overline{\mathbf{I P L 1}}, \overline{\mathbf{I P L 2}}$ ). These input pins indicate the encoded priority level of the device requesting an interrupt. Level seven is the highest priority while level zero indicates that no interrupts are requested. Level seven cannot be masked. $\overline{\mathrm{IPLO}}$ is the least significant bit while $\overline{\mathrm{IPL2}}$ is the most significant bit. To insure an interrupt is recognized, the interrupt control lines ( $\overline{\mathrm{IPLX}}$ ) must remain stable until the processor signals interrupt acknowledge (FC0, FC1, and FC2 all high).

SYSTEM CONTROL. The system control inputs either reset or halt the processor or indicate to the processor that bus errors have occurred. The three system control inputs are explained in the following paragraphs.

Bus Error ( $\overline{\operatorname{BERR}})$. The $\overline{\mathrm{BERR}}$ input informs the processor that a problem exists with the cycle currently being executed. Problems may be a result of:

1. nonresponding devices,
2. interrupt vector number acquisition failure,
3. illegal access request as determined by a memory management unit, or
4. other application dependent errors.

The Bus Error ( $\overline{\mathrm{BERR}}$ ) signal interacts with the $\overline{\text { 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{\mathrm{RESET}}$ ). This bidirectional signal line acts to reset (initiate a system initialization sequence) the processor and system in response to an external reset signal. An internally generated reset (result of a RESET instruction) resets all external devices while not affecting the internal state of the processor. A total system reset (processor and external devices) is the result of external HALT and RESET signals applied simultaneously. Refer to RESET OPERATION paragraph for additional information.

Halt ( $\overline{\mathrm{HALT}}$ ). The bidirectional $\overline{\text { HALT }}$ line, when driven by an external device, will cause the processor to stop at the completion of the current bus cycle. Halting the processor using HALT causes all control signals to go inactive and all three-state lines to go to their high-impedance state. Refer to BUS ERROR AND HALT OPERATION paragraph for additional information about the interaction between the $\overline{H A L T}$ and $\overline{B E R R}$ 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. Refer to paragaph on Double Bus Faults.

R6500 PERIPHERAL CONTROL. These control signals are used to allow the interfacing of synchronous R6500 peripheral devices with the asynchronous R68000. These signals are explained in the following paragraphs.

Enable ( $E$ ). The $E$ output signal is the standard enable signal ( $\varnothing 2$ clock) common to all R6500 type peripheral devices. The period for this output is ten R68000 clock periods (six clocks low; four clocks high). Enable is generated by an internal ring counter which may come up in any state (i.e., at power on, it is impossible to guarantee phase relationship of $E$ to CLK). E is a free-running clock and runs regardless of the state of the bus on the MPU.

Valid Peripheral Address ( $\overline{\mathrm{VPA}}$ ). The $\overline{\mathrm{VPA}}$ input indicates that the device or region addressed is a R6500 family device and that data transfer should be synchronized with the enable (E) signal. This input also indicates that the processor should use automatic vectoring for an interrupt. Refer to INTERFACE WITH R6500 PERIPHERALS.

Valid Memory Address ( $\overline{\mathrm{VMA}}$ ). The $\overline{\mathrm{VMA}}$ output indicates to R6500 peripheral devices that there is a valid address on the address bus and that the processor is synchronized to enable. This signal only responds to a valid peripheral address (VPA) input which indicates that the peripheral is a R6500 family device.

PROCESSOR STATUS (FC0, FC1, FC2). These function code outputs indicate the state (user or supervisor) and the cycle type currently being executed, as shown in Table 2. The information indicated by the function code outputs is valid whenever address strobe ( $\overline{\mathrm{AS}}$ ) is active.

CLOCK (CLK). The clock input is a TTL-compatible signal that is internally buffered for development of the internal clocks needed by the processor. The clock input should not be gated off at any time and the clock signal must conform to minimum and maximum pulse width times.

SIGNAL SUMMARY. Table 3 summarizes all the signals discussed in the previous paragraphs.

Table 2. Function Code Outputs

| FC2 | FC1 | FC0 | Cycle Type |
| :--- | :--- | :--- | :--- |
| Low | Low | Low | (Undefined, 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 |

Table 3. Signal Summary

| Signal Name | Mnemonic | Input/Output | Active State | Hi-Z |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | On HALT | On BGACK |
| Address Bus | A1-A23 | Output | High | Yes | Yes |
| Data Bus | D0-D15 | Input/Output | High | Yes | Yes |
| Address Strobe | $\overline{\text { AS }}$ | Output | Low | No | Yes |
| Read/Write | $\mathrm{R} / \bar{W}$ | Output | Read-High Write-Low | No | Yes |
| Upper and Lower Data Strobes | $\overline{\text { UDS }}$, LDS | Output | Low | No | Yes |
| Data Transfer Acknowledge | $\overline{\text { DTACK }}$ | Input | Low | No | No |
| Bus Request | $\overline{B R}$ | Input | Low | No | No |
| Bus Grant | $\overline{\mathrm{BG}}$ | Output | Low | No | No |
| Bus Grant Acknowledge | $\overline{\text { BGACK }}$ | Input | Low | No | No |
| Interrupt Priority Level | $\overline{\text { IPLO }}$, $\overline{\mathrm{PPL}}, \overline{\mathrm{IPL2}}$ | Input | Low | No | No |
| Bus Error | $\overline{\text { BERR }}$ | Input | Low | No | No |
| Reset | RESET | Input/Output | Low | No* | No* |
| Halt | $\overline{\text { HALT }}$ | Input/Output | Low | No* | No* |
| Enable | E | Output | High | No | No |
| Valid Memory Address | $\overline{\text { VMA }}$ | Output | Low | No | Yes |
| Valid Peripheral Address | $\overline{\text { VPA }}$ | Input | Low | No | No |
| Function Code Output | FC0, FC1, FC2 | Output | High | No | Yes |
| Clock | CLK | Input | High - | No | No |
| Power Input | $\mathrm{V}_{\text {CC }}$ | Input | - | - | - |
| Ground | GND | Input | - | - | - |
| *Open drain. |  |  |  |  |  |

## REGISTER DESCRIPTION AND DATA ORGANIZATION

STATUS REGISTER. The status register contains the eight level interrupt mask as well as the condition codes; extend ( $X$ ), negative ( N ), zero ( Z ), overflow ( V ), and carry ( C ). Additional status bits indicate that the processor is in a trace $(\mathrm{T})$ mode and/or in a supervisor (S) state.


Status Register

## OPERAND SIZE

Operand sizes are defined as follows: a byte equals 8 bits, a word equals 16 bits, and a long word equals 32 bits. The operand size for each instruction is either explicitly encoded in the instruction or implicitly defined by the instruction operation. Implicit instructions support some subset of all three sizes.

## DATA ORGANIZATION IN REGISTERS

The eight data registers support data operands of $1,8,16$, or 32 bits. The seven address registers together with the active stack pointer support address operands of 32 bits.

DATA REGISTERS. Each data register is 32 bits wide. Byte operands occupy the low order 8 bits, word operands the low order 16 bits, and long word operands the entire 32 bits. The least significant bit is addressed as bit zero; the most significant bit is addressed as bit 31 . When a data register is used as either a source or destination operand, only the appropriate low-order portion is changed; the remaining high order portion is neither used nor changed.


Figure 2. Word Organization In Memory

ADDRESS REGISTERS. Each address register and the stack pointer is 32 bits wide and holds a full 32-bit address. Address registers do not support byte sized operands. Therefore, when an address register is used as a source operand, either the low order word or the entire long word operand is used depending upon the operation size. When an address register is used as the destination operand, the entire register is affected regardless of the operation size. If the operation size is word, any other operands are sign extended to 32 bits before the operation is performed.

## DATA ORGANIZATION IN MEMORY

Bytes are individually addressable with the high order byte having an even address the same as the word, as shown in Figure 2. The low order byte has an odd address that is one higher than the word address. Instructions and multi-byte data are accessed only on word (even byte) boundaries. If a long word datum is located at address $n$ ( $n$ even), then the second word of that datum is located at address $n+2$.

The data types supported by the R68000 are: bit data, integer data of 8,16 , or 32 bits, 32 -bit addresses and binary coded decimal data. Each of these data types is put in memory, as shown in Figure 3. The numbers indicate the order in which data is accessed from the processor.

## BUS OPERATION

The following paragraphs explain control signal and bus operation during data transfer operations, bus arbitration, bus error and halt conditions, and reset operation.

DATA TRANSFER OPERATIONS. Transfer of data between devices involves the following signals:

- Address Bus A1 through A23
- Data Bus D0 through D15
- Control Signals

The address and data buses are separate parallel buses which transfer data using an asynchronous bus structure. In all cycles, the bus master assumes responsibility for deskewing all signals it issues at both the start and end of a cycle. In addition, the bus master is responsible for deskewing the acknowledge and data signals from the slave device.

The following paragraphs explain the read, write, and read-modify-write cycles. The indivisible read-modify-write cycle is the method used by the R68000 for interlocked multiprocessor communications.

Read Cycle. During a read cycle, the processor receives data from memory or a peripheral device. The processor reads bytes of data in all cases, and for a word (or double word) operation, the processor reads both upper and lower bytes simultaneously by asserting both upper and lower data strobes. When the instruction specifies byte operation, the processor uses an internal AO bit to determine which byte to read and then issues the data strobe required for that byte. When the AO bit equals zero, the upper data strobe is issued, and when the $A O$ bit equals one, the lower data strobe is issued. The processor correctly positions the received data internally.

A word read cycle flow chart is given in Figure 4. A byte read cycle flow chart is given in Figure 5. Read cycle timing is given in Figure 6. Figure 7 details word and byte read cycle operations.

Write Cycle. During a write cycle, the processor sends bytes of data to memory or a peripheral device. If the instruction specifies a word operation, the processor writes both bytes. When the instruction specifies a byte operation, the processor uses an internal AO bit to determine which byte to write and then issues the data strobe required for that byte. When the $A O$ bit equals zero, the upper data strobe is issued and when the AO bit equals one, the lower data strobe is issued. A word write cycle flow chart is given in Figure 8. A byte write cycle flow chart is given in Figure 9. Write cycle timing is given in Figure 6. Figure 10 details word and byte write cycle operation.


MSB = MOST SIGNIFICANT BIT
LSB = LEAST SIGNIFICANT BIT
DECIMAL DATA
2 BINARY CODED DECIMAL DIGITS = 1 BYTE

MSD = MOST SIGNIFICANT DIGIT
LSD = LEAST SIGNIFICANT DIGIT

Figure 3. Data Organization In Memory


Figure 4. Word Read Cycle Flow Chart

Read-Modify-Write Cycle. The read-modify-write cycle performs a read, modifies the data in the arithmetic-logic unit, and writes the data back to the same address. In the R68000 this cycle is indivisible in that the address strobe is asserted throughout the entire cycle. The test and set (TAS) instruction uses this cycle to provide meaningful communication between processors in a multiple processor environment. TAS is the only instruction that uses the read-modify-write cycles. Since the test and set instruction only operates on bytes, all read-modify-write cycles are byte operations. A read-modify-write cycle flow chart is given in Figure 11 and a timing diagram is given in Figure 12.

BUS ARBITRATION. Bus arbitration is a technique used by master-type devices to request,-be granted, and knowledge bus mastership. In its simplest form, it consists of:

1. asserting a bus mastership request,
2. receiving a grant that the bus is available at the end of the current cycle, and
3. acknowledging that mastership has been assumed.


Figure 5. Byte Read Cycle Flow Chart

Figure 13 is a flow chart showing the detail involved in a request from a single device. Figure 14 is a timing diagram for the same operation. This technique allows processing of bus requests during data transfer cycles.

The timing diagram shows that the bus request is negated at the time that an acknowledge is asserted. This is true for a system consisting of the processor and one device capable of bus mastership. However, in systems having a number of devices capable of bus mastership, the bus request line from each device is ORed to the processor. In this system, it is easy to see that there could be more than one bus request being made. The timing diagram shows that the bus grant signals negate a few clock cycles after the transition of the acknowledge (BGACK) signal.

However, if the bus requests are still pending, the processor will assert another bus grant within a few clock cycles after negation. This additional assertion of bus grant allows external arbitration circuitry to select the next bus master before the current bus master has completed its requirements. The following paragraphs provide additional information about the three steps in the arbitration process.


Figure 6. Read and Write Cycle Timing Diagram


Figure 7. Word and Byte Read Cycle Timing Diagram

Requesting the Bus. External devices capable of becoming bus masters request the bus by asserting the bus request $(\overline{\mathrm{BR}})$ signal. This ORed signal (although it need not be constructed from open collector devices) indicates to the processor that some external device requires control of the external bus. The processor, at a lower bus priority level than the external device, will relinquish the bus after it has completed the last bus cycle it has started. If no acknowledge is received before the bus request signal goes inactive, the processor will continue processing when it detects that the bus request is inactive. This allows ordinary processing to continue if the arbitration circuitry inadvertently responded to noise.

Receiving the Bus Grant. Normally the processor asserts bus grant $(\overline{\mathrm{BG}})$ as soon as possible after internal synchronization. The only exception occurs when the processor has made an internal decision to execute the next bus cycle but has not progressed far enough into the cycle to have asserted the address strobe $(\overline{\mathrm{AS}})$ signal. In this case, bus grant will not be asserted until one clock after address strobe is asserted to indicate to external devices that a bus cycle is being executed.

The bus grant signal may be routed through a daisy-chained network or through a specific priority-encoded network. The processor is not affected by the external method of arbitration as long as the protocol is obeyed.


Figure 8. Word Write Cycle Flow Chart


Figure 9. Byte Write Cycle Flow Chart


Figure 10. Word and Byte Write Cycle Timing Diagram


Figure 11. Read-Modify-Write Cycle Flow Chart


Figure 12. Read-Modify-Write Cycle Timing Diagram


Figure 13. Bus Arbitration Cycle Flow Chart

Acknowledgment of Mastership. Upon receiving a bus grant $(\overline{\mathrm{BG}})$, the requesting device waits until address strobe ( $\overline{\mathrm{AS}}$ ), data transfer acknowledge ( $\overline{\text { DTACK }}$ ), and bus grant acknowledge (BGACK) are negated before issuing its own BGACK. The negation of the address strobe indicates that the previous master has completed its cycle, while the negation of bus grant acknowledge indicates that the previous master has released the bus. (If address strobe is asserted no device is allowed to "break into" a cycle.) The negation of data transfer acknowledge indicates the previous slave has terminated its connection to the previous master. In some applications data transfer acknowledge may not be required. In this case the devices would use the address strobe. When bus grant acknowledge is issued the device is bus master. Only after the bus cycle(s) is (are) completed should bus grant acknowledge be negated to terminate bus mastership.

The bus request from the granted device should be dropped after bus grant acknowledge is asserted. If a bus request is still pending, another bus grant will be asserted within a few clocks of the negation of bus grant. Refer to Bus Arbitration Control section. The processor does not perform any external bus cycles before it reasserts bus grant.

BUS ARBITRATION CONTROL. The bus arbitration control unit in the R68000 is implemented with a finite state machine. A state diagram of this machine is shown in Figure 15. All asynchronous signals to the R68000 are synchronized before being used internally. This synchronization is accomplished in a maximum of one cycle of the system clock, assuming that the asynchronous input setup time (\#47) has been met (see Figure 16). The input signal is sampled on the falling edge of the clock and is valid internally after the next falling edge. If $\overline{B R}$ and $\overline{B G A C K}$ meet the asynchronous set-up time tASI (\#47), then tBGKBR (\#37A) can be ignored. If $\overline{B R}$ and $\overline{B G A C K}$ are asserted asynchronously with respect to the clock, $\overline{B G A C K}$ has to be asserted before $\overline{B R}$ is negated.

As shown in Figure 15, input signals labeled $R$ and $A$ are internally synchronized on the bus request and bus grant acknowledge pins respectively. The bus grant output is labeled G and the internal three-state control signal T . If T is true, the address, data, and control buses are placed in a high-impedance state when $\overline{\mathrm{AS}}$ is negated. All signals are shown in positive logic (active high) regardless of their true active voltage level.

State changes (valid outputs) occur on the next rising clock edge after the internal signal is valid.

A timing diagram of the bus arbitration sequence during a processor bus cycle is shown in Figure 17. The bus arbitration sequence while the bus is inactive (i.e., executing internal operations such as a multiply instruction) is shown in Figure 18.

If a bus request $(\overline{B R})$ is made at a time when the MPU has already begun a bus cycle but $\overline{A S}$ has not been asserted (bus state SO), $\overline{B G}$ will not be asserted on the next rising edge. Instead $\overline{B G}$ will be delayed until the second rising edge following its internal assertion. This sequence is shown in Figure 19.

BUS ERROR AND HALT OPERATION. In a bus architecture that requires a handshake from an external device, the possibility exists that the handshake might not occur. Since different systems will require a different maximum response time, a bus error input is provided.

External circuitry must be used to determine the duration between address strobe and data transfer acknowledge before issuing a bus error signal. When a bus error signal is received, the processor has two options: initiate a bus error exception sequence or try running the bus cycle again.


Figure 14. Bus Arbitration Cycle Timing Diagram


R = BUS REQUEST INTERNAL
A = BUS GRANT ACKNOWLEDGE INTERNAL
$\mathrm{G}=\mathrm{BUS}$ GRANT
T $=$ THREE-STATE CONTROL TO BUS CONTROL LOGIC ${ }^{2}$
X = DON'T CARE

1. STATE MAChine will not Change state if bus is in SO OR S1. REFER TO BUS ARBITRATION CONTROL FOR ADDITIONAL INFORMATION.
2. THE ADDRESS buS WILL be placed in the high IMPEDANCE STATE IF T IS ASSERTED AND AS NEGATED.

Figure 15. State Diagram of R68000 Bus Arbitration Unit

*THIS DELAY TIME IS EQUAL TO PARAMETER \#33, tchGL

Figure 16. Timing Relationship of External Asynchronous Inputs to Internal Signals

Bus Error Operation. When $\overline{\mathrm{BERR}}$ is asserted, the current bus cycle is terminated. If $\overline{B E R R}$ is asserted before the falling edge of $\mathrm{S} 2, \overline{\mathrm{AS}}$ will be negated in S 7 in either a read or write cycle. As long as BERR remains asserted, the data and address buses will be in the high-impedance state. When BERR is negated, the processor will begin stacking for exception processing. Figure 20 is a timing diagram for the exception sequence. The sequence is composed of the following elements:

1. stacking the program counter and status register,
2. stacking the error information,
3. reading the bus error vector table entry, and
4. executing the bus error handler routine.


Figure 17. Bus Arbitration During Processor Bus Cycle


Figure 18. Bus Arbitration with Bus Inactive


Figure 19. Bus Arbitration During Processor Bus Cycle Special Case


Figure 20. Bus Error Timing Diagram

The stacking of the program counter and the status register is identical to the interrupt sequence. Several additional items are stacked when a bus error occurs. These items are used to determine the nature of the error and correct it, if possible. The bus error vector is vector number two located at address $\$ 000008$. The processor loads the new program counter from this location. A software bus error handler routine is then executed by the processor. Refer to EXCEPTION PROCESSING for additional information.

Re-Running the Bus Cycle. When, during a bus cycle, the processor receives a $\overline{\mathrm{BERR}}$, and $\overline{\text { HALT }}$ is being driven by an external device, the processor enters the re-run sequence. Figure 21 is a timing diagram for re-running the bus cycle.

The processor terminates the bus cycle, then puts the address and data output lines in the high-impedance state. The processor remains 'halted"' and will not run another bus cycle until external logic negates $\overline{\text { HALT}}$. 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. BERR should be negated at least one clock cycle before HALT is negated.

## Note

The processor will not re-run a read-modify-write cycle. This restriction is made to guarantee that the entire cycle runs correctly and that the write operation of a Test-andSet operation is performed without ever releasing $\overline{\text { AS. If }}$ $\overline{B E R R}$ and $\overline{\text { HALT }}$ are asserted during a read-modify-write bus cycle, a bus error operation results.

Halt Operation with No Bus Error. The $\overline{\text { HALT }}$ input signal to the R68000 performs a Halt/Run/Single-Step function in a similar fashion to the R6500 halt functions. When the HALT signal is constantly active the processor "halts" (does nothing) and when the HALT signal is constantly inactive the processor "runs" (does something).

The single-step mode, derived from correctly timed transitions on the HALT signal input, forces the processor to execute a single bus-cycle by entering the "run" mode until the processor starts a bus cycle then changing to the "halt" mode. Thus, the single-step mode allows the user to proceed through (and therefore debug) processor operations one bus cycle at a time.

Figure 22 details the timing required for correct single-step operations. Some care must be exercised to avoid harmful interactions between BERR and HALT when using the single cycle mode as a debugging tool. This is also true of interactions between the HALT and RESET lines since these can reset the machine.

When the processor completes a bus cycle after recognizing that HALT is active, most three-state signals are put in the highimpedance state. These include:

1. address lines, and
2. data lines.

This is required for correct performance of the re-run bus cycle operation.

Honoring the halt request has no effect on bus arbitration. Only the bus arbitration function removes the control signals from the bus.

Total debugging flexibility is derived from the software debugging package, the halt function, and the hardware trace capability. These processor capabilities allow the hardware debugger to trace single bus cycles or single instructions at a time.

Double Bus Faults. When a bus error exception occurs, the processor will attempt to stack several words containing information about the state of the machine. If a bus error exception occurs during the stacking operation, there have been two bus errors in a row, or a double bus fault. A.double bus fault causes the processor to halt. Once a bus error exception has occurred, any bus error exception occurring before the execution of the next instruction constitutes a double bus fault.


Figure 21. Re-Run Bus Cycle Timing Diagram


Figure 22. Halt Signal Timing Waveforms

Note that a bus cycle which is re-run does not constitute a bus error exception, and does not contribute to a double bus fault. This means that as long as the external hardware requests it, the processor will continue to re-run the same bus cycle.

The bus error ( $\overline{B E R R}$ ) pin also has an effect on processor operation after the processor receives an external reset input. The processor reads the vector table after a reset to determine the address to start program execution. If a bus error occurs while reading the vector table (or at any time before the first instruction is executed), the processor reacts as if a double bus fault has occurred and it halts. Only an external reset will start a halted processor.

RESET OPERATION. The reset signal is a bidirectional signal that allows either the processor or an external signal to reset the system. Figure 23 is a timing diagram for reset operations. Both HALT and RESET must be applied to ensure total reset of the processor.

When the $\overline{\text { RESET }}$ and $\overline{\text { HALT }}$ are driven by an external device the entire system, including the processor, is reset. The processor responds by reading the reset vector table entry (vector number zero, address $\$ 000000$ ) and 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, with no other register being affected.

Execution of the RESET instruction drives the reset pin low for 124 clock periods. In this case, the processor is trying to reset the rest of the system. The internal state of the processor, including the processor's internal registers and the status register, is unaffected by the execution of a RESET instruction. All external devices connected to the reset line will be reset at the completion of the RESET instruction.

Asserting $\overline{\text { RESET }}$ and $\overline{\text { HALT }}$ for 10 clock cycles will cause a processor reset, except when Vcc is initially applied to the processor. In this case, an external reset must be applied for 100 milliseconds.

## THE RELATIONSHIP OF $\overline{\text { DTACK }}, \overline{B E R R}$, AND HALT

In order to properly control termination of a bus cycle for a re-run or a bus error condition, $\overline{\mathrm{DTACK}}, \overline{B E R R}$, and HALT should be asserted and negated on the rising edge of R68000 clock. This will assure that when two signals are asserted simultaneously, the required setup time (\#47) for both of them will be met during the same bus state.

This, or some equivalent precaution, should be designed external to the R68000. Parameter \#48 is intended to ensure this operation in a totally asynchronous system, and may be ignored if the above conditions are met.

The preferred bus cycle terminations may be summarized as follows (case numbers refer to Table 4):
Normal Termination: $\overline{\text { DTACK }}$ occurs first (case 1).
Halt Termination: $\overline{\mathrm{HALT}}$ is asserted at same time, or precedes DTACK (no BERR) cases 2 and 3.

Bus Error Termination: $\overline{B E R R}$ is asserted in lieu of, at same time, or preceding $\overline{\text { DTACK }}$ (case 4); $\overline{B E R R}$ negated at same time, or after DTACK.

Re-Run Termination: $\overline{\text { HALT }}$ and $\overline{\text { BERR }}$ asserted in lieu of, at the same time, or before DTACK (cases 6 and 7); HALT must be negated at least one cycle after BERR. (Case 5 indicates $\overline{B E R R}$ may precede HALT which allows fully asynchronous assertion).

Table 4 details the resulting bus cycle termination under various combinations of control signal sequences. The negation of these same control signals under several conditions is shown in Table 5. (DTACK is assumed to be negated normally in all cases; for best results, both $\overline{\text { DTACK }}$ and $\overline{B E R R}$ should be negated when address strobe is negated).

Example A: A system uses a watch-dog timer to terminate accesses to unpopulated address space. The timer asserts $\overline{\text { DTACK }}$ and $\overline{\text { BERR }}$ simultaneously after timeout (case 4).


NOTES:

1) INTERNAL START-UP TIME
2) SSP HIGH READ IN HERE
3) SSP LOW READ IN HERE
4) PC HIGH READ IN HERE
5) PC LOW READ IN HERE
6) FIRST INSTRUCTION FETCHED HERE.

XXXX bus state unknown (all CONTROL SIGNALS INACTIVE)
DATA BUS IN READ MODE

Figure 23. Reset Operation Timing Diagram

Example B: A system uses error detection on RAM contents. Designer may (a) delay DTACK until data verified, and return $\overline{\mathrm{BERR}}$ and HALT simultaneously to re-run error cycle (case 6), or if valid, return DTACK (case 1); (b) delay DTACK until data verified and return BERR at same time as DTACK if data in error (case 4).

## ASYNCHRONOUS VERSUS SYNCHRONOUS OPERATION

## Asynchronous Operation

To achieve clock frequency independence at a system level, the R68000 can be used in an asynchronous manner. This entails using only the bus handshake lines ( $\overline{\mathrm{AS}}, \overline{\mathrm{UDS}}, \overline{\mathrm{LDS}}, \overline{\mathrm{DTACK}}$, $\overline{B E R R}, \overline{H A L T}$, and $\overline{\mathrm{PPA}}$ ) to control the data transfer. Using this method, $\overline{\mathrm{AS}}$ signals the start of a bus cycle and the data strobes are used as a condition for valid data on a write cycle. The slave device (memory or peripheral) then responds by placing the requested data on the data bus for a read cycle or latching data on a write cycle and asserting the data transfer acknowledge signal (DTACK) to terminate the bus cycle. If no slave reponds or the access is invalid, external control logic asserts the BERR, or $\overline{\mathrm{BERR}}$ and $\overline{\mathrm{HALT}}$, signal to abort or rerun the bus cycle.

The $\overline{\text { DTACK }}$ signal is allowed to be asserted before the data from a slave device is valid on a read cycle. The length of time that DTACK may precede data is given as parameter \#31 (See Figure 45) and it must be met in any asynchronous system to insure that valid data is latched into the processor. Notice that there is no maximum time specified from the assertion of $\overline{\mathrm{AS}}$ to the assertion of DTACK. This is because the MPU will insert wait cycles of one clock period each until DTACK is recognized.

The $\overline{B E R R}$ signal is allowed to be asserted after the $\overline{\text { DTACK }}$ signal is asserted. $\overline{B E R R}$ must be asserted within the time given as parameter \#48 after DTACK is asserted in any asynchronous system to insure proper operation. If this maximum delay time is violated, the processor may exhibit erratic behavior.

## Synchronous Operation

To allow for those systems which use the system clock as a signal to generate DTACK and other asynchronous inputs, the asynchronous inputs setup time is given as parameter \#47. If this'setup is met on an input, such as DTACK, the processor is guaranteed to recognize that signal on the next falling edge of the system clock. However, the converse is not true-if the input signal does not meet the setup time it is not guaranteed not to be recognized. In addition, if DTACK is recognized on a falling edge, valid data will be latched into the processor (on a read cycle) on the next falling edge provided that the data meets the setup time given as parameter \#27. Given this, parameter \#31 may be ignored. Note that if DTACK is asserted, with the required setup time, before the falling edge of S4, no wait states will be incurred and the bus cycle will run at its maximum speed of four clock periods.

In order to assure proper operation in a synchronous system when $\overline{B E R R}$ is asserted after $\overline{\text { DTACK, }}$, the following conditions must be met. Within one clock cycle after DTACK was recognized, $\overline{B E R R}$ must meet the setup time parameter \#27A prior to the falling edge of the next clock. The setup time is critical to proper operation, and the R68000 may exhibit erratic behavior if it is violated.

[^0]Table 4. $\overline{\text { DTACK }}, \overline{B E R R}, \overline{\text { HALT }}$ Assertion Results

| Case No. | Control Signal | Asserted on Rising Edge of State |  | Result |
| :---: | :---: | :---: | :---: | :---: |
|  |  | N | $\mathrm{N}+2$ |  |
| 1 | $\begin{aligned} & \overline{\overline{\mathrm{DTACK}}} \\ & \frac{\text { BERR }}{\text { HALT }} \end{aligned}$ | $\begin{aligned} & \text { A } \\ & \text { NA } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & s \\ & x \\ & x \end{aligned}$ | Normal cycle terminate and continue. |
| 2 | $\overline{\text { DTACK }}$ BERR HALT | $\begin{aligned} & \text { A } \\ & \text { NA } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \mathrm{S} \\ & \mathrm{X} \\ & \mathrm{~S} \end{aligned}$ | Normal cycle terminate and halt. Continue when HALT removed. |
| 3 | $\begin{aligned} & \frac{\overline{\text { DTACK }}}{\frac{\text { BERR }}{\text { HALT }}}=\text { Ren } \end{aligned}$ | $\begin{aligned} & \text { NA } \\ & \text { NA } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \text { A } \\ & \text { NA } \\ & S \end{aligned}$ | Normal cycle terminate and halt. Continue when HALT removed. |
| 4 | DTACK BERR HALT | $\begin{aligned} & X \\ & \text { A } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & X \\ & S \\ & \text { NA } \end{aligned}$ | Terminate and take bus error trap. |
| 5 | $\frac{\overline{\text { DTACK }}}{\frac{\text { BERR }}{\text { HALT }}}$ | $\begin{aligned} & \text { NA } \\ & \text { A } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & X \\ & \text { S } \\ & \text { A } \end{aligned}$ | Terminate and re-run. |
| 6 | $\begin{aligned} & \overline{\overline{\text { DTACK }}} \\ & \frac{\text { BERR }}{\text { HALT }} \end{aligned}$ | $\begin{aligned} & \text { X } \\ & \text { A } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{~S} \\ & \mathrm{~S} \\ & \hline \end{aligned}$ | Terminate and re-run when HALT removed. |
| 7 | $\frac{\overline{\text { DTACK }}}{\text { BERR }}$ HALT | $\begin{aligned} & \text { NA } \\ & \text { NA } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & X \\ & \text { A } \\ & \text { S } \end{aligned}$ | Terminate and re-run when HALT removed. |
| gend: <br> N - the <br> A - si <br> NA - sig <br> $X$ - do <br> S - sig | of the serted in t asserte <br> asserted | $\begin{aligned} & \text { n bu } \\ & \text { state } \\ & \text { tate } \end{aligned}$ | g., S4, <br> mains | his state |

Table 5. $\overline{B E R R}$ AND $\overline{\text { HALT }}$ Negation Results

| Conditions of Termination in Table 4-4 | Control Signal | Negated on Rising Edge of State |  |  | Results - Next Cycle |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | N |  | N + 2 |  |
| Bus Error | $\frac{\overline{\text { BERR }}}{\text { HALT }}$ | $\bullet$ | or or | $\bullet$ | Takes bus error trap. |
| Re-run | $\frac{\overline{\text { BERR }}}{\text { HALT }}$ | $\bullet$ |  | - | Iliegal sequence; usually traps to vector number 0 . |
| Re-run | $\frac{\overline{\text { BERR }}}{\overline{\text { HALT }}}$ | - |  | - | Re-runs the bus cycle. |
| Normal | $\overline{\overline{\text { BERR }}}$ | $\bullet$ | or | $\bullet$ | May lengthen next cycle. |
| Normal | $\overline{\overline{\text { BERR }}}$ |  |  | none | If next cycle is started it will be terminated as a bus error. |
| - = Signal is negated in this bus state. |  |  |  |  |  |

## PROCESSING STATES

The following paragraphs describe the actions of the R68000 which are outside the normal processing associated with the execution of instructions. The functions of the bits in the supervisor portion of the status register are covered: the supervisor/user bit, the trace enable bit, and the processor interrupt priority mask. The sequence of memory references and actions taken by the processor on exception conditions are detailed.

The R68000 is always in one of three processing states: normal, exception, or halted. The normal processing state associated with instruction execution; the memory references are to fetch instructions and operands, and to store results. A special case of the normal state is the stopped state which the processor enters when a STOP instruction is executed. In this state, no further references are made.

The exception processing state is associated with interrupts, trap instructions, tracing and other exceptional conditions. The exception may be internally generated by an instruction or by an unusual condition arising during the execution of an instruction. Externally, exception processing can be forced by an interrupt, by a bus error, or by a reset. Exception processing is designed to provide an efficient context switch so that the processor may handle unusual conditions.

The halted processing state is an indication of a catastrophic hardware failure. For example, if during the exception processing of a bus error another bus error occurs, the processor assumes that the system is unusable and halts. Only an external reset can restart a halted processor. Note that a processor in the stopped state is not in the halted state, nor vice versa.

## PRIVILEGE STATES

The processor operates in one of two states of privilege: the "user" state or the "supervisor" state. The privilege state determines legal operations. It is used to choose between the supervisor stack pointer and the user stack pointer in instruction references, and by the external memory management device to control and translate accesses.

The privilege state is a mechanism for providing security in a computer system by allowing most programs to execute in user state. In this state, the accesses are controlled, and the effects on other parts of the system are limited. Programs should access only their own code and data areas, and ought to be restricted from accessing information.

The operating system which executes in the supervisor state, has access to all resources and performs the overhead tasks for the user state programs.
SUPERVISOR STATE. The supervisor state is the higher state of privilege. For instruction execution, the supervisor state is determined by asserting (high) the S-bit of the status register. All instructions can be executed in the supervisor state. The bus cycles generated by instructions executed in the supervisor state are classified as supervisor references. While the processor is in the supervisor privilege state, those instructions which use either the system stack pointer implicitly or address register seven explicitly access the supervisor stack pointer.

All exception processing is done in the supervisor state, regardless of the setting of the S-bit. The bus cycles generated during exception processing are classified as supervisor references. All stacking operations during exception processing use the supervisor stack pointer.

USER STATE. The user state is the lower state of privilege. For instruction execution, the user state is determined by negating (low) the S-bit of the status register.

Most instructions execute the same in user state as in the supervisor state. However, some instructions which have important system effects are made privileged. User programs are not permitted to execute the STOP instruction, or the RESET instruction. To ensure that a user program cannot enter the supervisor state except in a controlled manner, the instructions which modify the whole state register are priviled. To aid in debugging programs which are to be used as operating systems, the move to user stack pointer (MOVE to USP) and move from user stack pointer (MOVE from USP) instructions are also privileged.

The bus cycles generated by an instruction executed in user state are classified as user state references. This allows an external memory management device to translate the address and to control access to protected portions of the address space. While the processor is in user privilege state, those instructions which use either the system stack pointer implicitly or address register seven explicitly, access the user stack pointer.

PRIVILEGE STATE CHANGES. Once the processor is in the user state and executing instructions, only exception processing can change the privilege state. During exception processing, the current setting of the S-bit of the status register is saved and the S-bit is asserted, putting the processing in the supervisor state. Therefore, when instruction execution resumes to process the exception, the processor is in the supervisor privilege state.

REFERENCE CLASSIFICATION. When the processor makes a reference, it classifies the kind of reference being made by using the encoding on the three function code output lines. This allows external translation of addresses, control of access, and differentiation of special processor states, such as interrupt acknowledge. Table 6 lists the classification of references.

Table 6. Reference Classification

| Function Code Output |  |  |  |
| :---: | :---: | :---: | :--- |
| FC2 | FC1 |  | Reference Class |
| 0 | 0 | 0 |  |
| 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 |



Figure 24. Exception Vector Format


Figure 25. Peripheral Vector Number Format


Figure 26. Address Translated From 8-Bit Vector Number

## EXCEPTION PROCESSING

Before discussing the details of interrupts, traps, and tracing, a general description of exception processing is in order. The processing of an exception occurs in four steps, with variations for different exception causes. During the first step, a temporary copy of the status register is made, and the status register is set for exception processing. In the second step the exception vector is determined, and the third step is the saving of the current processor contents. In the fourth step a new context is obtained, and the processor switches to instruction processing.

EXCEPTION VECTORS. Exception vectors are memory locations from which the processor fetches the address of a routine which will handle that exception. All exception vectors are two words in length (Figure 24), except for the reset vector, which is four words. All exception vectors lie in the supervisor data space, except for the reset vector which is in the supervisor program space. A vector number is an eight-bit number which, when multipled by four, gives the address of an exception vector. Vector numbers are generated internally or externally, depending on the cause of the exception. In the case of interrupts, during the interrupt acknowledge bus cycle, a peripheral provides an 8 -bit vector number (Figure 25) to the processor on data bus lines D0 through D7. The processor translates the vector number into a full 24-bit address, as shown in Figure 26. The memory layout for exception vectors is given in Table 7.

As shown in Table 7, the memory layout is 512 words long (1024 bytes). It starts at address 0 and proceeds through
address 1023. This provides 255 unique vectors; some of these are reserved for TRAPS and other system functions. Of the 255, there are 192 reserved for user interrupt vectors. However, there is no protection on the first 64 entries, so user interrupt vectors may overlap at the discretion of the systems designer.

KINDS OF EXCEPTIONS. Exceptions can be generated either internally or externally. Externally generated exceptions include interrupts ( $\overline{\mathrm{RQQ}})$, bus error ( $\overline{\mathrm{BERR}}$ ), and reset ( $\overline{\mathrm{RESET}}$ ) requests. Interrupts are requests from peripheral devices for processor action while BERR and RESET inputs are used for access control and processor restart. Internally generated exceptions come from instructions, from address errors, or from tracing. The trap (TRAP), trap on overflow (TRAPV), check register against bounds (CHK) and divide (DIV) instructions can all generate exceptions as part of their instruction execution. In addition, illegal instructions, word fetches from odd addresses and privilege violations cause exceptions. Tracing behaves like a very high priority, internally generated interrupt after each instruction execution.

EXCEPTION PROCESSING SEQUENCE. Exception processing occurs in four identifiable steps. In the first step, an internal copy is made of the status register. After the copy is made, the S-bit is asserted, putting the processor into the supervisor privilege state. Also, the T-bit is negated which will allow the exception handler to execute unhindered by tracing. For the reset and interrupt exceptions, the interrupt priority mask is also updated.

Table 7. Exception Vector Assignment

| 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 | Uninitialized Interrupt Vector |
| 16-23* | 64 | 04C | 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 | Level 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. |  |  |  |  |



Figure 27. Exception Stack Order (Groups 1 and 2)
In the second step, the vector number of the exception is determined. For interrupts, the vector number is obtained by a processor fetch, classified as an interrupt acknowledge. For all other exceptions, internal logic provides the vector number. This vector number is then used to generate the address of the exception vector.

The third step is to save the current processor status except for the reset exception. The current program counter value and the saved copy of the status register are stacked using the supervisor stack pointer as shown in Figure 27. The program counter value stacked usually points to the next unexecuted instruction; however, for bus error and address error, the value stacked for the program counter is unpredictable, and may be incremented from the address of the instruction which caused the error. Additional information defining the current context is stacked for the bus error and address error exceptions.

The last step is the same for all exceptions. The new program counter value is fetched from the exception vector. The processor then resumes instruction execution. The instruction at the address given in the exception vector is fetched, and normal instruction decoding and execution is started.

MULTIPLE EXCEPTIONS. These paragraphs describe the processing which occurs when multiple exceptions arise simultaneously. Exceptions can be grouped according to their occurrence and priority. The Group 0 exceptions are reset, bus error, and address error. These exceptions cause the instruction currently being executed to be aborted, and the exception processing to commence within two clock cycles. The Group 1 exceptions are trace and interrupt, as well as the privilege violations and illegal instructions. These exceptions allow the current instruction to execute to completion, but preempt the execution of the next instruction by forcing exception processing to occur (privilege violations and illegal instructions are detected when they are the next instruction to be executed). The Group 2 exceptions occur as part of the normal processing of instructions. The TRAP, TRAPV, CHK, and zero divide exceptions are in this group. For these exceptions, the normal execution of an instruction may lead to exception processing.

Group 0 exceptions have highest priority, while Group 2 exceptions have lowest priority. Within Group 0, reset has highest priority, followed by address error and then bus error. Within Group 1, trace has priority over external interrupts, which in turn takes priority over illegal instruction and privilege violation. Since only one instruction can be executed at a time, there is no priority relation within Group 2.

Table 8. Exception Grouping and Priority

| Group | Exception | Processing |
| :---: | :--- | :--- |
| 0 | Reset <br> Address Error <br> Bus Error | Exception processing begins <br> within two clock cycles. |
| 1 | Trace <br> Interrupt <br> Illegal Instruction <br> Privilege Violation | Exception processing begins <br> before the next instruction. |
| 2 | TRAP, TRAPV, CHK, <br> Zero Divide | Exception processing is started <br> by normal instruction execution | is taken first if the conditions for both arise simultaneously. Therefore, if a bus error occurs during a TRAP instruction, the bus error takes precedence, and the TRAP instruction processing is aborted. In another example, if an interrupt request occurs during the execution of an instruction while the $T$-bit is asserted, the trace exception has priority, and is processed first. Before instruction processing resumes, however, the interrupt exception is also processed, and instruction processing commences finally in the interrupt handler routine. Table 8 gives a summary of exception grouping and priority.

## EXCEPTION PROCESSING DETAILED DISCUSSION

Exceptions have a number of sources, and each exception has a unique processing sequence. The following paragraphs detail the sources of exceptions, how each arises, and how each is processed.

RESET. The reset input provides the highest exception level. The processing of the reset signal is designed for system initiation, and recovery from catastrophic failure. Any processing in progress at the time of the reset is aborted and cannot be recovered: The processor is forced into the supervisor state and the trace state is forced off. The processor interrupt priority mask is set at level seven. The vector number is internally generated to reference the reset exception vector at location 0 in the supervisor program space. Because no assumptions can be made about the validity of register contents, in particular the supervisor stack pointer, neither the program counter nor the status register is saved. The address contained in the first two words of the reset exception vector is fetched as the initial supervisor stack pointer, and the address in the last two words of the reset exception vector is fetched as the initial program counter. Finally, instruction execution is started at the address in the program counter. The powerup/restart code should be pointed to by the initial program counter.

The RESET instruction does not cause loading of the reset vector, but does assert the reset line to reset external devices. This allows the software to reset the system to a known state and then continue processing with the next instruction.

INTERRUPTS. Seven levels of interrupt priorities are provided. Devices may be chained externally within interrupt priority levels, allowing an unlimited number of peripheral devices to interrupt the processor. Interrupt priority levels are numbered from one to seven, level seven being the highest priority. The status register contains a three-bit mask which indicates the current processor priority. Interrupts are inhibited for all priority levels less than or equal to the current processor priority.

An interrupt request is made to the processor by encoding the interrupt request level on the interrupt request lines; a zero indicates no interrupt request. Interrupt requests arriving at the processor do not face immediate exception processing, but are made pending. Pending interrupts are detected between instruction executions. If the priority of the pending interrupt is lower than or equal to the current processor priority, execution continues with the next instruction and the interrupt exception processing is postponed. (The recognition of level seven is slightly different, as explained in a following paragraph.)

If the priority of the pending interrupt is greater than the current processor priority, the exception processing sequence is started. First a copy of the status register is saved, and the privilege state is set to supervisor, then tracing is suppressed, and the processor priority level is set to the level of the interrupt being acknowledged. The processor fetches the vector number from the interrupting device, classifying the reference as an interrupt acknowledge and displaying the level number of the interrupt being acknowledged on the address bus. If external logic requests an automatic vectoring, the processor internally generates a vector number which is determined by the interrupt level number. If external logic indicates a bus error, the interrupt is taken to be spurious, and the generated vector number references the spurious interrupt vector. The processor then proceeds with the usual exception processing, saving the program counter and status register on the supervisor stack. The saved value of the program counter is the address of the instruction which would have been executed had the interrupt not been present. The content of the interrupt vector whose vector number was previously obtained is fetched and loaded into the program counter, and normal instruction execution commences in the interrupt handling routine. A flow chart for the interrupt acknowledge sequence is given in Figure 28, a timing diagram is given in Figure 29, and the interrupt exception timing sequence is shown in Figure 30.

Priority level seven is a special case. Level seven interrupts cannot be inhibited by the interrupt priority mask, thus providing a "non-maskable interrupt" capability. An interrupt is generated each time the interrupt request level changes from some lower level to level seven. Note that a level seven interrupt may still be caused by the level comparison if the request level is a seven and the processor priority is set to a lower level by an instruction.

UNINITIALIZED INTERRUPT. An interrupting device asserts VPA or provides an interrupt vector during an interrupt acknowledge cycle to the R68000. If the vector register has not been initialized, the responding R68000 Family peripheral will provide vector 15 , the uninitialized interrupt vector. This provides a uniform way to recover from a programming error.


Figure 28. Interrupt Acknowledge Sequence Flow Chart

SPURIOUS INTERRUPT. If during the interrupt acknowledge cycle no device responds by asserting $\overline{\mathrm{DTACK}}$ or $\overline{\mathrm{VPA}}$, the bus error line should be asserted to terminate the vector acquisition. The processor separates the processing of this error from bus error by fetching the spurious interrupt vector instead of the bus error vector. The processor then proceeds with the usual exception processing.

INSTRUCTION TRAPS. Traps are exceptions caused by instructions. They arise either from processor recognition of abnormal conditions during instruction execution, or from use of instructions whose normal behavior is trapping.

*ALTHOUGH A VECTOR NUMBER IS ONE BYTE, BOTH DATA STROBES ARE ASSERTED DUE TO THE MICROCODE USED FOR EXCEPTION PROCESSING. THE PROCESSOR DOES NOT RECOGNIZE ANYTHING ON DATA LINES D8 THROUGH D15 AT THIS TIME.

Figure 29. Interrupt Acknowledge Sequence Timing Diagram


Figure 30. Interrupt Exception Timing Sequence

Some instructions are used specifically to generate traps. The TRAP instruction always forces an exception, and is useful for implementing system calls for user programs. The TRAPV and CHK instructions force an exception if the user program detects a runtime error, which may be an arithmetic overflow or a subscript out of bounds.

The signed divide (DIVS) and unsigned divide (DIVU) instructions will force an exception if a division operation is attempted with a divisor of zero.

ILLEGAL AND UNIMPLEMENTED INSTRUCTIONS. IIlegal instruction refers to any of the word bit patterns which are not the bit pattern of the first word of a legal instruction. During instruction execution, if such an instruction is fetched, an illegal instruction exception occurs. Rockwell reserves the right to define instructions whose opcodes may be any of the illegal instructions. Three bit patterns will always force an illegal instruction trap on all R68000 Family compatible microprocessors. They are: \$4AFA, \$4AFB, and \$4AFC. Two of the patterns, \$4AFA and \$4AFB, are reserved for Rockwell system products. The third pattern, \$4AFC, is reserved for customer use.

Word patterns with bits 15 through 12 equaling 1010 or 1111 are distinguished as unimplemented instructions and separate exception vectors are given to these patterns to permit efficient emulation. This facility allows the operating system to detect program errors, or to emulate unimplemented instructions in software.

PRIVILEGE VIOLATIONS. In order to provide system security, various instructions are privileged. An attempt to execute one of the privileged instructions while in the user state will cause an exception. The privileged instructions are:

| STOP | AND Immediate to SR |
| :--- | :--- |
| RESET | EOR Immediate to SR |
| RTE | OR Immediate to SR |
| MOVE USP | MOVE to SR |

TRACING. To aid in program development, the R68000 includes a facility to allow instruction by instruction tracing. In the trace state, after each instruction is executed an exeception is forced, allowing a debugging program to monitor the execution of the program under test.

The trace facility uses the T-bit in the supervisor portion of the status register. If the T-bit is negated (off), tracing is disabled, and instruction execution proceeds from instruction to instruction as normal. If the T-bit is asserted (on) at the beginning of the execution of an instruction, a trace exception will be generated after the execution of that instruction is completed. If the instruction is not executed, either because an interrupt is taken, or the instruction is illegal or privileged, the trace exception does not occur. The trace exception also does not occur if the instruction is aborted by a reset, bus error, or address error exception. If the instruction is indeed executed and an interrupt
is pending on completion, the trace exception is processed before the interrupt exception. If, during the execution of the instruction, an exception is forced by that instruction, the forced exception is processed before the trace exception.

As an extreme illustration of the above rules, consider the arrival of an interrupt during the execution of a TRAP instruction while tracing is enabled. First the trap exception is processed, then the trace exception, and finally the interrupt exception. Instruction execution resumes in the interrupt handler routine.

BUS ERROR. Bus error exceptions occur when the external logic requests that a bus error be processed by an exception. The current bus cycle which the processor is making is then aborted. Whether the processor was doing instruction or exception processing, that processing is terminated, and the processor immediately begins exception processing.

Exception processing for bus error follows the usual sequence of steps. The status register is copied, the supervisor state is entered, and the trace state is turned off. The vector number is generated to refer to the bus error vector. Since the processor was not between instructions when the bus error exception request was made, the context of the processor is more detailed. To save more of this context, additional information is saved on the supervisor stack. The program counter and the copy of the status register are of course saved. The value saved for the program counter is advanced by some amount, two to ten bytes beyond the address of the first word of the instruction which made the reference causing the bus error. If the bus error occurred during the fetch of the next instruction, the saved program counter has a value in the vicinity of the current instruction, even if the current instruction is a branch, a jump, or a return instruction. Besides the usual information, the processor saves its internal copy of the first word of the instruction being processed, and the address which was being accessed by the aborted bus cycle. Specific information about the access is also saved: whether it was a read or a write, whether the processor was processing an instruction or not, and the classification displayed on the function code outputs when the bus error occurred. The processor is processing an instruction if in the normal state or processing a Group 2 exception; the processor is not processing an instruction when processing a Group 0 or a Group 1 exception. Figure 31 illustates how the information is organized on the supervisor stack. Although this information is not sufficient to effect full recovery from the bus error, it does allow software diagnosis. Finally, the processor commences instruction processing at the address contained in the vector. It is the responsibility of the error handler routine to clean up the stack and determine where to continue execution.

If a bus error occurs during the exception processing for a bus error, address error; or reset, the processor is halted, and all processing ceases. This simplifies the detection of catastrophic system failure, since the processor removes itself from the system rather than destroy all memory contents. Only the RESET pin can restart a halted processor.


Figure 31. Supervisor Stack Order (Group 0)


Figure 32. Address Error Timing

ADDRESS ERROR. Address error exceptions occur when the processor attempts to access a word or a long word operand or an instruction at an odd address. The effect is much like an internally generated bus error, so that the bus cycle is aborted, and the processor ceases whatever processing it is currently doing and begins exception processing. After exception processing commences, the sequence is the same as that for bus error including the information that is stacked, except that the vector number refers to the address error vector instead. Likewise, if an address error occurs during the exception processing for a bus error, address error, or reset, the processor is halted. As shown in Figure 32, an address error will execute a short bus cycle followed by an exception processing.

## INTERFACE WITH R6500 PERIPHERALS

Rockwell's line of R6500 peripherals are directly compatible with the R68000. Some of these devices that are particularly useful are:

| R6520 | Peripheral Interface Adapter (PIA) |
| :--- | :--- |
| R6522 | Versatile Interface Adapter (VIA) |
| R6545 | CRT Controller (CRTC) |
| R6551 | Asynchronous Communication Interface Adapter |
|  | (ACIA) |

To interface the synchronous R6500 peripherals with the asynchronous R68000, the processor modifies its bus cycle to meet the R6500 cycle requirements whenever an R6500 device address is detected. This is possible since both processors use memory mapped I/O. Figure 33 is a flow chart of the interface operation between the processor and R6500 devices. 6800 peripherals are also compatible with the R68000 processor.

## 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 $\emptyset 2$ signal in existing R6500 systems. The bus frequency is one tenth of the incoming R68000 clock frequency. The timing of $E$ allows 1 MHz peripherals to be used with an 8 MHz R68000. Enable has a 60/40 duty cycle; that is, it is low for six input clocks and high for four input clocks. This duty cycle allows the processor to do successive VPA accesses on successive E pulses.

Figures 34 and 35 give a general R6500 to R68000 interface timing, while Figures 36 and 37 detail the specific timing parameters involved in the interface. At state zero (SO) in the cycle, the address bus is in the high-impedance state. A function code is asserted on the function code output lines. Onehalf clock later, in state 1, the address bus is released from the high-impedance state.

During state 2, the address strobe ( $\overline{\mathrm{AS}}$ ) is asserted to indicate that there is a valid address on the address bus. If the bus cycle is a read cycle, the upper and/or lower data strobes are also asserted in state 2. If the bus cycle is a write cycle, the read/write $(R / \bar{W})$ signal is switched to a low (write) during state 2. One-half clock later, in state 3, the write data is placed on the data bus, and in state 4 the data strobes are issued to indicate valid data on the data bus. The processor now inserts wait states until it recognizes the assertion of 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 $\emptyset 2$ transfer characteristics of the R6500 bus. Valid peripheral address (VPA) is derived by decoding the address bus, conditioned by address strobe ( $\overline{\mathrm{AS}}$ ). Chip select for the R6500 peripherals should be derived by decoding the address bus conditioned by VMA.

After the recognition of $\overline{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. Figures 34 and 35 depict the best and worst case R6500 cycle timing. This cycle length is dependent strictly upon when VPA is asserted in relationship the E clock.

If we assume that external circuitry asserts $\overline{\mathrm{VPA}}$ as soon as possible after the assertion of $\overline{A S}$, then VPA will be recognized as being asserted on the falling edge of S4. In this case, no "extra" wait cycles will be inserted prior to the recognition of $\overline{\text { VPA }}$ assertion and only the wait cycles inserted to synchronize with the E clock will determine the total length of the cycle. In any case, the synchronization delay will be some integral number of clock cycles within the following two extremes:

1. Best Case- $\overline{\mathrm{VPA}}$ is recognized as being asserted on the falling edge three clock cycles before E rises (or three clock cycles after E falls).
2. Worst Case- $\overline{\mathrm{VPA}}$ is recognized as being asserted on the falling edge two clock cycles before $E$ rises (or four clock cycles after E falls).

Near the end of a read cycle, the processor latches the peripheral's data in state 6 . For all cycles, the processor negates the address and data strobes one half clock cycle later in state 7, and the Enable signal goes low at this time. Another half clock later, the address bus is put in the high-impedance state. Upon write cycle completion, the data bus is put in the high-impedance state and the read/write signal is switched high. The peripheral logic must remove VPA within one clock after address strobe is negated.
$\overline{\text { DTACK }}$ should not be asserted while $\overline{\mathrm{VPA}}$ is asserted. Note that the R68000 VMA is active low. This allows the processor to put its buses in the high-impedance state on DMA requests without inadvertently selecting peripherals.

## INTERRUPT OPERATION

During an interrupt acknowledge cycle while the processor is fetching the vector, if VPA is asserted, the R68000 will assert $\overline{\text { VMA }}$ and complete a normal R6500 read cycle as shown in Figure 38. The processor will then use an internally generated vector, called an autovector, that is a function of the interrupt being served. The seven autovectors are vector numbers 25 through 31 (decimal).

Autovectors operate in the same fashion (but are not restricted to) the R6500 interrupt sequence. The basic difference is that there are six normal interrupt vectors and one NMI type vector. As with both the R6500 and the R68000's normal vectored interrupt, the interrupt service routine can be located anywhere in the address space. This is due to the fact that while the vector numbers are fixed, the contents of the vector table entries are assigned by the user.

Since $\overline{\mathrm{VMA}}$ is asserted during autovectoring, the R6500 peripheral address decoding should prevent unintended accesses.


Figure 34. R68000 to R6500 Peripheral Timing-Best Case


Figure 35. R68000 to R6500 Peripheral Timing-Worst Case


NOTES:
THIS FIGURE REPRESENTS THE BEST CASE R6500 TIMING WHERE VPA FALLS BEFORE THE THIRD SYSTEM CLOCK CYCLE after the falling edge of e.

THIS TIMING DIAGRAM IS INCLUDED FOR THOSE WHO WISH TO DESIGN THEIR OWN CIRCUIT TO GENERATE VMA IT SHOWS THE BEST CASE POSSIBLY ATTAINABLE.


Figure 33. R6500 Interfacing Flow Chart

## DATA TYPES AND ADDRESSING MODES

Five basic data types are supported. These data types are:

## Bits

BCD Digits (4-bits)
Bytes (8-bits)
Word (16-bits)
Long Words (32-bits)
In addition, operations on other data types such as memory addresses, status word data, etc., are provided for in the instruction set.

The 14 addressing modes, shown in Table 9, include six basic types:

Register Direct
Register Indirect
Absolute
Program Counter Relative Implied Immediate

Included in the register indirect addressing modes is the capability to do postincrementing, predecrementing, offsetting and indexing. Program counter relative mode can also be modified via indexing and offsetting.

Table 9. Addressing Modes

| 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 <br> Absolute Short <br> Absolute Long | $\begin{aligned} & \mathrm{EA}=(\text { Next Word }) \\ & \mathrm{EA}=(\text { Next Two Words }) \end{aligned}$ |
| Program Counter Relative Addressing <br> Relative with Offset Relative with Index and Offset | $\begin{aligned} & E A=(P C)+d_{16} \\ & E A=(P C)+(X n)+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 \leftarrow A n+N \\ & A n \not A-A n-N 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 Word(s) Inherent Data |
| Implied Addressing Implied Register | $E A=S R, U S P, S P, P C$ |
| NOTES: <br> $\mathrm{EA}=$ Effective Address <br> An = Address Register <br> Dn = Data Register <br> Xn $=$ Address or Data Register used as Index Register <br> $\mathrm{SR}=$ Status Register <br> PC = Program Counter <br> ( ) = Contents of <br> $\mathrm{d}_{8}=$ Eight-bit Offset (displacement) <br> $d_{16}=$ Sixteen-bit Offset (displacement) | $N=1$ for Byte, 2 for Words and 4 for Long Word. If An is the stack pointer and the operand size is byte, $N=2$ to keep the stack pointer on a word boundry. <br> = Replaces |

## INSTRUCTION SET OVERVIEW

The R68000 instruction set is shown in Table 10. Some additional instructions are variations, or subsets, of these and they appear in Table 11. Special emphasis has been given to the instruction set's support of structured high-level languages to facilitate ease of programming. Each instruction, with few exceptions, operates on bytes, words, and long words and most instructions can use any of the 14 addressing modes. Combining instruction types, data types, and addressing modes, over 1000 useful instructions are provided. These instructions include signed and unsigned multiply and divide, "quick" arithmetic operations. BCD arithmetic and expanded operations (through traps).

note: this timing diagram is included for those who wish to design their own circuit to generate vma. IT SHOWS THE WORST CASE POSSIbLY ATTAINABLE.

Figure 37. RC68000 to R6500 Peripheral Timing Diagram - Worst Case

*ALTHOUGH A VECTOR NUMBER IS ONE BYTE, BOTH DATA STROBES ARE ASSERTED DUE TO THE MICROCODE USED FOR EXCEPTION PROCESSING. THE PROCESSOR DOES NOT RECOGNIZE ANYTHING ON DATA LINES D8 THROUGH D15 AT THIS time.

Figure 38. Autovector Operation Timing Diagram

Table 10. Instruction Set Summary

| Mnemonic | Description | Mnemonic | Description | Mnemonic | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ADBC | 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 |
| AND |  |  |  | RESET <br> ROL <br> ROR <br> ROXL <br> ROXR <br> RTE <br> RTR <br> RTS | Reset External Devices <br> Rotate Left without Extend <br> Rotate Right without Extend <br> Rotate Left with Extend <br> Rotate Right with Extend <br> Return from Exception <br> Return and Restore <br> Return from Subroutine |
| ASL |  |  |  |  |  |
| ASR |  | $\begin{aligned} & \text { JMP } \\ & \text { JSR } \end{aligned}$ | Jump <br> Jump to Subroutine |  |  |
| BCC 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 |  |  |  |  |
|  |  | $\begin{aligned} & \text { LEA } \\ & \text { LINK } \\ & \text { LSL } \\ & \text { LSR } \end{aligned}$ | Load Effective Address <br> Link Stack <br> Logical Shift Left <br> Logical Shift Right |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  |  |  |
|  |  |  |  | SBCD SCC STOP SUB SWAP | Subtract Decimal with Extend <br> Set Conditional <br> Stop <br> Subtract <br> Swap Data Register Halves |
|  |  | MOVE | Move |  |  |
| CHK | Check Register Against Bounds Clear Operand Compare | MULU | Unsigned Multiply |  |  |
|  |  |  |  |  |  |
| $\begin{aligned} & \text { CLR } \\ & \text { CMP } \end{aligned}$ |  | NBCD <br> NEG <br> NOP <br> NOT | Negate Decimal with Extend <br> Negate <br> No Operation <br> One's Complement | TAS TRAP TRAPV TST | Test and Set Operand Trap <br> Trap on Overflow <br> Test |
|  |  |  |  |  |  |
| ${ }^{\mathrm{DB}} \mathrm{CC}$ <br> DIVS <br> DIVU | Test Condition, Decrement and Branch Signed Divide Unsigned Divide |  |  |  |  |
|  |  |  |  |  |  |
|  |  | OR | Logical Or |  |  |
|  |  |  |  | UNLK | Unlink |

Table 11. Variations of Instruction Types

| Instruction Type | Variation | Description | Instruction Type | Variation | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| ADD | ADD <br> ADDA <br> ADDQ <br> ADDI <br> ADDX | Add <br> Add Address <br> Add Quick <br> Add Immediate <br> Add with Extend | MOVE | MOVE <br> MOVEA <br> MOVEM <br> MOVEP <br> MOVEQ | Move <br> Move Address <br> Move Multiple Registers <br> Move Peripheral Data <br> Move Quick |
| AND | AND <br> ANDI <br> ANDI to CCR <br> ANDI to SR | Logical And <br> And Immediate And Immediate to Condition Codes And Immediate to Status Register |  | MOVE to SR MOVE to CCR MOVE USP | Move to Status Register Move to Condition Codes Move User Stack Pointer |
|  |  |  | NEG | $\begin{aligned} & \text { NEG } \\ & \text { NEGX } \end{aligned}$ | Negate <br> Negate with Extend |
| CMP | CMP <br> CMPA <br> CMPM <br> CMPI | Compare <br> Compare Address <br> Compare Memory <br> Compare Immediate | OR | OR <br> ORI <br> ORI to CCR <br> ORI to SR | Logical Or <br> Or Immediate <br> Or Immediate to Condition Codes <br> Or Immediate to <br> Status Register |
| EOR | EOR <br> EORI <br> EORI to CCR <br> EORI to SR | Exclusive Or <br> Exclusive Or Immediate <br> Exclusive Or Immediate to Condition Codes <br> Exclusive Or Immediate to Status Register | SUB | SUB <br> SUBA <br> SUBI <br> SUBQ <br> SUBX | Subtract <br> Subtract Address <br> Subtract Immediate <br> Subtract Quick <br> Subtract with Extend |

The following paragraphs contain an overview of the form and structure of the R68000 instruction set. The instructions form a set of tools that include all the machine functions to perform the following operations:

```
Data Movement
Integer Arithmetic
Logical
Shift and Rotate
Bit Manipulation
Binary Coded Decimal
Program Control
System Control
```

The complete range of instruction capabilities combined with the flexible addressing modes described previously provide a very flexible base for program development.

## ADDRESSING

Instructions for the R68000 contain two kinds of information: the type of function to be performed, and the location of the operand(s) on which to perform that function. The methods used to locate (address) the operand(s) are explained in the following paragraphs.

Instructions specify an operand location in one of three ways:
Register Specification - the number of the register is given in the register field of the instruction.
Effective Address - use of the different effective address modes.
Implicit Reference

- the definition of certain instructions implies the use of specific registers.


## DATA MOVEMENT OPERATIONS

The move (MOVE) instruction provides a means for data acquisition (transfer and storage). The move instruction and the effective addressing modes allow both address and data manipulation. Data move instructions allow byte, word, and long word operands to be transferred from memory to memory, memory to register, register to memory, and register to register. Address move instructions allow word and long word operand transfers and ensure that only legal address manipulations are executed. In addition to the general move instruction there are several special data movement instructions: move multiple registers (MOVEM), move peripheral data (MOVEP), exchange registers (EXG), load effective address (LEA), push effective address (PEA), link stack (LINK), unlink stack (UNLK), and move quick (MOVEQ). Table 12 summarizes the data movement operations.

## INTEGER ARITHMETIC OPERATIONS

The arithmetic operators include the four basic operations of add (ADD), subtract (SUB), multiply (MUL), and divide (DIV) as well as arithmetic compare (CMP), clear (CLR), and negate (NEG). The add and subtract instructions are available for both address and data operations, and with data operations accepting all

Table 12. Data Movement Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| EXG | 32 | $R x \rightarrow$ Ry |
| LEA | 32 | $E A \leftarrow A n$ |
| LINK | - | $\begin{aligned} & A n \rightarrow-(S P) \\ & S P \rightarrow \text { An } \\ & S P+\text { displacement } \rightarrow S P \end{aligned}$ |
| MOVE | 8, 16, 32 | $s \rightarrow d$ |
| MOVEM | 16, 32 | $(E A) \rightarrow A n, D n$ $A n, D n \rightarrow E A$ |
| MOVEP | 16, 32 | $\begin{aligned} & (E A) \rightarrow D n \\ & D n \rightarrow(E A) \end{aligned}$ |
| MOVEQ | 8 | $\# \mathrm{xxx} \rightarrow$ Dn |
| PEA | 32 | $E A \rightarrow-(S P)$ |
| SWAP | 32 | $\mathrm{Dn}[31: 16] \rightarrow \mathrm{Dn}[15: 0]$ |
| UNLK | - | $\begin{aligned} & A n \rightarrow S p \\ & (S P)+\rightarrow A n \end{aligned}$ |
| NOTES: |  |  |

operand sizes. Address operations are limited to legal address size operands ( 16 or 32 bits). Data, address, and memory compare operations are also available. The clear and negate instructions may be used on all sizes of data operands.

The multiply and divide operations are available for signed and unsigned operands using word multiply to produce a long word product, and a long word dividend with word divisor to produce a word quotient with a word remainder.

Multiprecision and mixed size arithmetic can be accomplished using a set of extended instructions. These instructions are: add extended (ADDX), subtract extended (SUBX), sign extend (EXT), and negate binary with extend (NEGX).

A text operand (TST) instruction that sets the condition codes as a result of a compare of the operand with zero is available. Test and set (TAS) is a synchronization instruction useful in multiprocessor systems. Table 13 summrizes the integer arithmetic operations.

## INSTRUCTION FORMAT

Instructions, as shown in Figure 39, vary from one to five words in length. The first word of the instruction, called the operation word, specifies the length of the instruction and the operation to be performed. The remaining words further specify the operands. These words are either immediate operands or extensions to the effective address mode specified in the operation word.

Table 13. Integer Arithmetic Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| ADD | $\begin{aligned} & 8,16,32 \\ & 16,32 \end{aligned}$ | $\begin{aligned} & D n+(E A) \rightarrow D n \\ & (E A)+D n \rightarrow(E A) \\ & (E A)+\# x x x \rightarrow(E A) \\ & A n+(E A) \rightarrow A n \end{aligned}$ |
| ADDX | $\begin{aligned} & 8,16,32 \\ & 16,32 \end{aligned}$ | $\begin{aligned} & D x+D y+X \rightarrow D x \\ & -(A x)+-(A y)+X \rightarrow(A x) \end{aligned}$ |
| CLR | 8, 16, 32 | $0 \rightarrow E A$ |
| CMP | $\begin{aligned} & 8,16,32 \\ & 16,32 \end{aligned}$ | $\begin{aligned} & D n-(E A) \\ & (E A)-\# x x x \\ & (A x)+-(A y)- \\ & A n-(E A) \end{aligned}$ |
| DIVS | $32 \div 16$ | $D n \div(E A) \rightarrow D n$ |
| DIVU | $32 \div 16$ | $D n \div(E A) \rightarrow D n$ |
| EXT | $\begin{aligned} & 8 \rightarrow 16 \\ & 16 \rightarrow 32 \end{aligned}$ | $\begin{aligned} & (D n)_{8} \rightarrow \mathrm{Dn}_{16} \\ & (\mathrm{Dn})_{16} \rightarrow \mathrm{Dn}_{32} \end{aligned}$ |
| MULS | $16 \times 16 \rightarrow 32$ | $D \mathrm{D} \times(\mathrm{EA}) \rightarrow \mathrm{Dn}$ |
| MULU | $16 \times 16 \rightarrow 32$ | $D n \times(E A) \rightarrow$ n |
| NEG | 8, 16, 32 | $0-(E A) \rightarrow(E A)$ |
| NEGX | 8, 16, 32 | $0-(E A)-X \rightarrow$ (EA) |
| SUB | $\begin{aligned} & 8,16,32 \\ & 16,32 \end{aligned}$ | $\begin{aligned} & D n-(E A) \rightarrow D n \\ & (E A)-D n \rightarrow(E A) \\ & (E A)-\# x x x \rightarrow(E A) \\ & A n-(E A) \rightarrow A n \end{aligned}$ |
| SUBX | 8, 16, 32 | $\begin{aligned} & D x-D y-X \rightarrow D x \\ & -(A x)--(A y)-X \rightarrow(A x) \end{aligned}$ |
| TAS | 8 | $[E A]-0,1 \rightarrow E A[7]$ |
| TST | 8, 16, 32 | (EA) - 0 |
| ```NOTES: [ ] = bit number -( ) = indirect with predecrement ( )+ = indirect with postdecrement # = immediate data``` |  |  |

## PROGRAM/DATA REFERENCES

The R68000 separates memory references into two classes: program references, and data references. Program references reference that section of memory that contains the program being executed. Data references refer to that section of memory that contains data. Operand reads are from the data space, except in the case of the program counter relative addressing mode. All operand writes are to the data space.

## 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 40 shows the general format of the single effective address instruction operation word. The effective address is composed of two 3 -bit fields: the mode field, and the register field. The value in the mode field selects the different address modes. The register field contains the number of a register.

The effective address field may require additional information to fully specify the operand. This additional information, called the effective address extension, is contained in the following word or words and is considered part of the instruction, as shown in Figure 39. The effective address modes are grouped into three categories: register direct, memory addressing, and special.

REGISTER DIRECT MODES. These effective addressing modes specify that the operand is in one of the 16 multifunction registers.

Data Register Direct. The operand is in the data register specified by the effective address register field.

Address Register Direct. The operand is in the address register specified by the effective address register field.

MEMORY ADDRESS MODES. These effective addressing modes specify that the operand is in memory and provide the specific address of that operand.

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| OPERATION WORD <br> (FIRST WORD SPECIFIES OPERATION AND MODES) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| IMMEDIATE OPERAND <br> (IF ANY, ONE OR TWO WORDS) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| SOURCE EFFECTIVE ADDRESS EXTENSION (IF ANY, ONE OR TWO WORDS) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| DESTINATION EFFECTIVE ADDRESS EXTENSION (IF ANY, ONE OR TWO WORDS) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Figure 39. Instruction Format

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | X | X | X | X | X | X | X | X | X |  | EFFECTIVE ADDRESS MODE , REGIST |  |  |  |  |

Figure 40. Single-Effective-Address Instruction Operation Word General Format

Address Register Indirect. The address of the operand is in the address register specified by the register field. The reference is classified as a data reference with the exception of the jump and jump to subroutine instructions.

Address Register Indirect With Postincrement. The address of the operand is in the address register specified by the register field. After the operand address is used, it is incremented by one, two or four depending upon whether the size of the operand is byte, word, or long word. If the address register is the stack pointer and the operand size is byte, the address is incremented by two rather than one to keep the stack pointer on a word boundary. The reference classifies as a data reference.

Address Register Indirect With Predecrement. The address of the operand is in the address register specified by the register field. Before the operand address is used, it is decremented by one, two, or four depending upon whether the operand size is byte, word, or long word. If the address register is the stack pointer and the operand size is byte, the address is decremented by two rather than one to keep the stack pointer on a word boundary. The reference is classified as a data reference.

Address Register Indirect with Displacement. This address mode requires one word of extension. The address of the operand is the sum of the address in the address register and the sign-extended 16 -bit displacement integer in the extension word. The reference classifies as a data reference with the exception of the jump to subroutine instructions.

Address Register Indirect With Index. This address mode requires one word of extension. The address of the operand sums the addresses in the address register, the sign-extended displacement integer in the low order eight bits of the extension word, and the contents of the index register. The reference is classified as a data reference with the exception of the jump and jump to subroutine instructions.

SPECIAL ADDRESS MODE. The special address modes use the effective address register field to specify the special addressing mode instead of a register number.

Absolute Short Address. This address mode requires one word of extension. The address of the operand is the extension word. The 16 -bit address is sign extended before it is used. The reference classifies as a data reference with the exception of the jump and jump to subroutine instructions.

Absolute Long Address. This address mode requires two words of extension. The address of the operand is developed by the concatenation of the extension words. The high-order part of the address is the first extension word; the low-order part of the
address is the second extension word. The reference classifies as a data reference with the exception of the jump and jump to subroutine instructions.

Program Counter With Displacement. This address mode requires one word of extension. The address of the operand sums the addresses in the program counter and the signextended 16 -bit displacement integer in the extension word. The value in the program counter is the address of the extension word. The reference classifies as a program reference.

Program Counter With Index. This address mode requires one word of extension. This address sums the addresses in the program counter, the sign-extended displacement integer in the lower eight bits of the extension word, and the contents of the index register. The value in the program counter is the address of the extension word. This reference classifies as a program reference:

Immediate Data. This address mode requires either one or two words of extension depending on the size of the operation.

| Byte Operation | - operand is low order byte of exten- <br>  <br>  <br> sion word |
| :--- | :--- |
| Word Operation $\quad$ - 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. |  |

## IMPLICIT REFERENCE

Some instructions make implicit reference to the program counter (PC), the system stack pointer (SP), the supervisor stack pointer (SSP), the user stack pointer (USP), or the status register (SR).

A selected set of instructions may reference the status register by means of the effective address field. These are:

ANDI to CCR
ANDI to SR
EORI to CCR
EORI to SR
MOVE to CCR
MOVE to SR
MOVE from SR
ORI to CCR
ORI to SR

## EFFECTIVE ADDRESS ENCODING SUMMARY

Table 14 summarizes the effective addressing modes discussed in the previous paragraphs.

Table 14. 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 |
| Absolute Short | 111 | 000 |
| Absolute Long | 111 | 001 |
| Program Counter with | 111 | 010 |
| Displacement |  |  |

SYSTEM STACK. The system stack is used implicitly by many instructions; user stacks and queues may be created and maintained through the addressing modes. Address register seven (A7) is the system stack pointer (SP). The system stack pointer is either the supervisor stack pointer (SSP) or the user stack pointer (USP), depending on the state of the S-bit in the status register. If the S-bit indicates supervisor state (High), SSP is the active system stack pointer, and the USP cannot be referenced as an address register. If the S-bit indicates user state (Low), the USP is the active system stack pointer, and the SSP cannot be referenced. Each system stack fills from high memory to low memory.

## LOGICAL OPERATIONS

Logical operation instructions AND, OR, EOR, and NOT are available for all sizes of integer data operands. A similar set of immediate instructions (ANDI, ORI, and EORI) provide these logical operations with all sizes of immediate data. Table 15 summarizes the logical operations.

## SHIFT AND ROTATE OPERATIONS

Shift operations in both directions are provided by arithmetic instructions ASR and ASL and logical shift instructions LSR and LSL. The rotate instructions (with and without extend) available are ROXR, ROXL, ROR, and ROL. All shift and rotate operations can be performed in either registers or memory. Register shifts and rotates support all operand sizes and allow a shift count specified in a data register.

Table 15. Logical Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| AND | 8, 16, 32 | $\operatorname{Dn} \Lambda(E A) \rightarrow$ Dn <br> $(E A) \Lambda D n \rightarrow(E A)$ <br> (EA) $\Lambda \# x x x \rightarrow$ (EA) |
| OR | 8, 16, 32 | $\mathrm{Dn} \nu(\mathrm{EA}) \rightarrow \mathrm{Dn}$ <br> $(E A) \nu \mathrm{Dn} \rightarrow(\mathrm{EA})$ <br> (EA) $\nu \# x x x \rightarrow$ (EA) |
| EOR | 8, 16, 32 | $\begin{aligned} & (E A) \oplus D y \rightarrow(E A) \\ & (E A) \oplus \# x x x \rightarrow(E A) \end{aligned}$ |
| NOT | 8, 16, 32 | $\sim(E A) \rightarrow$ (EA) |
| NOTES: |  |  |

Memory shifts and rotates are for word operands only and allow only single-bit shifts or rotates.

Table 16 summarizes the shift and rotate operations.

## BIT MANIPULATION OPERATIONS

The following instructions provide bit manipulation operations: bit test (BTST), bit test and set (BSET), bit test and clear (BCLR), and bit test and change (BCHG). Table 17 is a summary of the bit manipulation operations. (Bit 2 of the status register is Z .)

Table 16. Shift and Rotate Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| ASL | 8, 16, 32 | $x / C)<-0$ |
| ASR | 8, 16, 32 | $\square \longrightarrow \mathrm{x} / \mathrm{C}$ |
| LSL | 8, 16, 32 | $x / C-4<0$ |
| LSR | 8, 16, 32 | $0 \rightarrow \longrightarrow \mathrm{X} / \mathrm{C}$ |
| ROL | 8, 16, 32 | $\mathrm{c} \sqrt{4}$ |
| ROR | 8, 16, 32 | $\longrightarrow \longrightarrow \mathrm{C}$ |
| ROXL | 8, 16, 32 | $\mathrm{C} \sqrt{x}$ |
| ROXR | 8, 16, 32 | $x \mathrm{x} \rightarrow \square \mathrm{C}$ |

Table 17. Bit Manipulation Operations
$\left.\begin{array}{|c|c|c|}\hline \text { Instruction } & \text { Operand Size } & \text { Operation } \\ \hline \text { BTST } & 8,32 & \sim \text { bit of (EA) } \rightarrow Z \\ \hline \text { BSET } & 8,32 & \begin{array}{l}\sim \text { bit of }(E A) \rightarrow Z \\ 1 \rightarrow \text { bit of EA }\end{array} \\ \hline \text { BCLR } & 8,32 & \begin{array}{l}\sim \text { bit of }(E A) \rightarrow Z \\ 0 \rightarrow \text { bit of EA }\end{array} \\ \hline \text { BCHG } & 8,32 & \sim \text { bit of (EA) } \rightarrow Z \\ \sim \text { bit of (EA) } \rightarrow \text { bit of EA }\end{array}\right]$

## BINARY CODED DECIMAL OPERATIONS

The following instructions accomplish multiprecision arithmetic operations on binary coded decimal numbers: add decimal with extend (ABCD), subtract decimal with extend (SBCD), and negate decimal with extend (NBCD). Table 18 summarizes the binary coded decimal operations.

## PROGRAM CONTROL OPERATIONS

Program control operations implementation requires a series of conditional and unconditional branch instructions and return instructions. These instructions are summarized in Table 19.

The conditional instructions provide setting and branching for the following conditions:
CC - carry clear
CS - carry set
EQ - equal
F - never true
GE - greater or equal
GT - greater than
HI - high
LE - less or equal
LS - low or same
LT - less than
MI - minus
NE - not equal
PL - plus
T. - always true

VC - no overflow
VS - overflow

Table 18. Binary Coded Decimal Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| ABCD | 8 | $D x_{10}+D_{10}+x \rightarrow D x$ <br> $-(A x)_{10}+-(A y)_{10}+x \rightarrow(A x)$ |
| SBCD | 8 | $D x_{10}-D y_{10}-X \rightarrow D x$ <br> $-(A x)_{10}-(A y)_{10}-X \rightarrow(A x)$ |
| NBCD | 8 | $0-(E A)_{10}-X \rightarrow(E A)$ |
| NOTE: $-(\quad)=$ indirect with predecrement |  |  |

Table 19. Program Control Operations

| Instruction | Operation |
| :---: | :--- |
| Conditional <br> BCC | Branch conditionally (14 conditions) <br> 8 - and 16-bit displacement <br> Test condition, decrement, branch <br> 16 -bit displacement <br> Set byte conditionally (16 conditions) |
| SCC | Branch always <br> $8-$ and 16-bit displacement <br> Branch to subroutine <br> $8-$ and 16-bit displacement |
| Unconditional |  |
| BRR | Jump <br> Jump to subroutine |
| JSR |  |

## SYSTEM CONTROL OPERATIONS

System control operations are accomplished by using privileged instructions, trap generating instructions, and instructions that use or modify the status register. These instructions are summarized in Table 20.

## INSTRUCTION SET

The following paragraphs provide information about the addressing categories and instruction set of the R68000.

## ADDRESSING CATEGORIES

Effective address modes may be categorized by the ways in which they may be used. The following classifications will be used in the instructions definitions.
Data If an effective address mode may be used to refer to data operands, it is considered a data addressing effective address mode.
Memory If an effective address mode may be used to refer to memory operands; it is considered a memory addressing effective address mode.
Alterable If an effective address mode may be used to refer to alterable (writeable) operands, it is considered an alterable addressing effective address mode.
Control If an effective address mode may be used to refer to memory operands without an associated size, it is considered control addressing effective address mode.

Table 21 shows the various categories to which each of the effective address modes belong. Table 22 is the instruction set summary.

Table 20. System Control Operations

| Instruction | Operation |
| :--- | :--- |
| Privileged |  |
| ANDI to SR | Logical AND to Status Register |
| EORI to SR | Logical EOR to Status Register |
| MOVE EA to SR | Load New Status Register |
| MOVE USP | Move User Stack Pointer |
| ORI to SR | Logical OR to Status Register |
| RESET | Reset External Devices |
| RTE | Return from Exception |
| STOP | Stop Program Execution |
| Trap Generating |  |
| CHK | Check Data Register Against Upper Bounds |
| TRAP | Trap |
| TRAPV | Trap on Overflow |
| Status Register |  |
| ANDI to CCR | Logical AND to Condition Codes |
| EORI to CCR | Logical EOR to Condition Codes |
| MOVE EA to CCR | Load New Condition Codes |
| MOVE SR to EA | Store Status Register |
| ORI to CCR | Logical OR to Condition Codes |

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.

## INSTRUCTION PREFETCH

The R68000 uses a two-word tightly-coupled instruction prefetch mechanism to enhance performance. This mechanism is described in terms of the microcode operations involved. If the execution of an instruction is defined to begin when the microroutine for that instruction is entered, some features of the prefetch mechanism can be described.

1) When execution of an instruction begins, the operation word and the word following have already been fetched. The operation word is in the instruction decoder.
2) In the case of multi-word instructions, as each additional word of the instruction is used internally, a fetch is made to the instruction stream to replace it.
3) The last fetch from the instruction stream is made when the operation word is discarded and decoding is started on the next instruction.
4) If the instruction is a single-word instruction causing a branch, the second word is not used. But because this word is fetched by the preceding instruction, it is impossible to avoid this superfluous fetch.
5) In the case of an interrupt or trace exception, both words are not used.
6) The program counter usually points to the last word fetched from the instruction stream.

## INSTRUCTION EXECUTION TIMES

The following paragraphs contain listings of the instruction execution times in terms of external clock (CLK) periods. In this timing data, it is assumed that both memory read and write cycle times are four clock periods. Any wait states caused by a longer memory cycle must be added to the total instruction time. The number of bus read and write cycles for each instruction is enclased in parenthesis following the execution periods and is shown as ( $r / w$ ) where $r$ is the number of read cycles and $w$ is the number of write cycles.

Table 21. Effective Addressing Mode Categories

| Effective <br> Address Modes | Mode | Register | Addressing Categories |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Data | Memory | Control | Alterable |
| Dn <br> An <br> (An) | $\begin{aligned} & 000 \\ & 001 \\ & 010 \\ & \hline \end{aligned}$ | Register Number Register Number Register Number | $\frac{x}{x}$ | $\overline{\bar{x}}$ | $\overline{\bar{x}}$ | $\begin{aligned} & X \\ & X \\ & X \end{aligned}$ |
| $\begin{aligned} & (A n)+ \\ & -(A n) \\ & d(A n) \end{aligned}$ | $\begin{aligned} & 011 \\ & 100 \\ & 101 \end{aligned}$ | Register Number Register Number Register Number | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ | $\overline{\bar{x}}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ |
| $\begin{aligned} & d(A n, i x) \\ & \text { xxx.W } \\ & \text { xxx.L } \end{aligned}$ | $\begin{aligned} & 110 \\ & 111 \\ & 111 \end{aligned}$ | Register Number <br> 000 <br> 001 | $\begin{aligned} & X \\ & X \\ & X \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | $\begin{aligned} & x \\ & X \\ & X \end{aligned}$ |
| $\begin{aligned} & d(P C) \\ & d(P C, i x) \\ & \# x x x \end{aligned}$ | $\begin{aligned} & 111 \\ & 111 \\ & 111 \end{aligned}$ | $\begin{aligned} & 010 \\ & 011 \\ & X \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ | $\begin{aligned} & X \\ & X \\ & X \end{aligned}$ | X <br> X | - |

Table 22. Instruction Set

| Mnemonic | Description | Operation | Condition Codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | x | N | z | $v$ | C |
| ABCD | Add Decimal with Extend | $(\text { Destination })_{10}+(\text { Source })_{10}+\mathrm{X} \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 | * | * | * | * | * |
| ADDQ | Add Quick | (Destination) + Immediate Data $\rightarrow$ Destination | * | * | * | * | * |
| ADDX | Add Extended | (Destination) + (Source) $+\mathrm{X} \rightarrow$ Destination | * | * | * | * | * |
| AND | AND Logical | (Destination) $\Lambda$ (Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| ANDI | AND Immediate | (Destination) $\Lambda$ Immediate Data $\rightarrow$ Destination | - | * | * | 0 | 0 |
| ANDI to CCR | AND Immediate to Condition Codes | (Source) $\Lambda$ CCR $\rightarrow$ CCR | * | * | * | * | * |
| ANDI to SR | AND Immediate to Status Register | (Source) $\Lambda$ SR $\rightarrow$ SR | * | * | * | * | * |
| ASL, ASR | Arithmetic Shift | (Destination) Shifted by <count> $\rightarrow$ Destination | * | * | * | * | * |
| $\mathrm{B}_{\mathrm{CC}}$ | Branch Conditionally | If CC then $\mathrm{PC}+\mathrm{d} \rightarrow \mathrm{PC}$ | - | - | - | - | - |
| BCHG | Test a Bit and Change | $\sim$ (<bit number >) OF Destination $\rightarrow$ Z <br> $\sim(<$ bit number $>$ ) OF Destination $\rightarrow$ <br> <bit number> OF Destination | - | - | * | - | - |
| BCLR | Test a Bit and Clear | $\sim$ (<bit number >) OF Destination $\rightarrow Z$ $0 \rightarrow$ <bit number > $\rightarrow$ OF Destination | - | - | * | - | - |
| 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 | $\mathrm{PC} \rightarrow(\mathrm{SP}) ; \mathrm{PC}+\mathrm{d} \rightarrow \mathrm{PC}$ | - | - | - | - | - |
| BTST | Test a Bit | $\sim(<$ bit number $>$ ) OF Destination $\rightarrow Z$ | - | - | * | - | - |
| CHK | Check Register Against Bounds | If $\mathrm{Dn}<0$ or $\mathrm{Dn}>$ (<ea>) then TRAP | - | * | U | U | U |
| CLR | Clear and 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) | - | * | * | * | * |
| $\mathrm{DB}_{\mathrm{CC}}$ | Test Condition, Decrement and Branch | If $\sim$ CC then $\mathrm{Dn}-1 \rightarrow$ 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 |
| EORI to CCR | Exclusive OR Immediate to Condition Codes | (Source) $\oplus$ CCR $\rightarrow$ CCR | * | * | * | * | * |
| NOTES: |  |  |  |  |  |  |  |

Table 22. Instruction Set (Continued)

|  | Description | Operation | Condition Codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Mnemonic |  |  | $\mathbf{x}$ | N | z | v | c |
| EORI to SR | Exclusive OR Immediate to Status Register | (Source) $\oplus$ SR $\rightarrow$ SR | * | * | * | * | * |
| EXG | Exchange Register | R $\mathrm{x} \rightarrow$ - Ry | - | - | - | - | - |
| EXT | Sign Extend | (Destination) Sign-Extended $\rightarrow$ Destination | - | * | * | 0 | 0 |
| JMP | Jump | Destination $\rightarrow$ PC | - | - | - | - | - |
| JSR | Jump to Subroutine | PC $\rightarrow$-(SP); Destination $\rightarrow$ PC | - | - | - | - | - |
| LEA | Load Effective Address | <ea> $\rightarrow$ An | - | - | - | - | - |
| LINK | Link and Allocate | An $\rightarrow$ (SP); SP $\rightarrow$ An; SP + Displacement $\rightarrow$ SP | - | - | - | - | - |
| LSL, LSR | Logical Shift | (Destination) Shifted by <count> - 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 | * | * | * | * | * |
| 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 | $\begin{aligned} & \text { Register } \rightarrow \text { Destination } \\ & \text { (Source) } \rightarrow \text { Registers } \end{aligned}$ | - | - | - | - | - |
| MOVEP | Move Peripheral Data | (Source) - Destination | - | - | - | - | - |
| MOVEQ | Move Quick | Immediate Data $\rightarrow$ Destination | - | * | * | 0 | 0 |
| MULS | Signed Multiply | (Destination)X(Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| MULU | Unsigned Multiply | (Destination) X (Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| NBCD | Negate Decimal with Extend | $0-$ (Destination) $10-X \rightarrow$ Destination | * | U | * | U | * |
| NEG | Negate | $0-$ (Destination) $\rightarrow$ Destination | * | * | * | * | * |
| NEGX | Negate with Extend | $0-$ (Destination) $-\mathrm{X} \rightarrow$ Destination | * | * | * | * | * |
| NOP | No Operation | - | - | - | - | - | - |
| NOT | Logical Complement | $\sim$ (Destination) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| OR | Inclusive OR Logical | (Destination) $\nu$ (Source) $\rightarrow$ Destination | - | * | * | 0 | 0 |
| ORI | Inclusive OR Immediate | (Destination) $\nu$ Immediate Data $\rightarrow$ Destination | - | * | * | 0 | 0 |
| ORI to CCR | Inclusive OR Immediate to Condition Codes | (Source) $\nu$ CCR $\rightarrow$ CCR | * | * | * | * | * |
| ORI to SR | Inclusive OR Immediate to Status Register | (Source) $\nu$ SR $\rightarrow$ SR | * | * | * | * | * |
| PEA | Push Effective Address | <ea> - (SP) | - | - | - | - | - |
| RESET | Reset External Device | - | - | - | - | - | - |
| ROL, ROR | Rotate (Without Extend) | (Destination) Rotated by <count> $\rightarrow$ Destination | - | * | * | 0 | * |

## NOTES:

| $\Lambda=$ logical AND | $*=$ affected |
| :--- | :--- |
| $\nu=$ logical OR | $-=$ unaffected |
| $\oplus=$ logical exclusive OR | $0=$ cleared |
| $\sim=$ logical complement | $1=$ set |
|  | $U=$ undefined |

Table 22. Instruction Set (Continued)

| Mnemonic | Description | Operation | Condition Codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | X | N | z | V | C |
| ROXL, ROXR | Rotate with Extend | (Destination) Rotated by <count> $\rightarrow$ Destination | * | * | * | 0 | * |
| RTE | Return from Exception | $(\mathrm{SP})+\rightarrow \mathrm{SR}$; $(\mathrm{SP})+\rightarrow \mathrm{PC}$ | * | * | * | * | * |
| RTR | Return and Restore Condition Codes | $(\mathrm{SP})+\rightarrow \mathrm{CC} ;(\mathrm{SP})+\rightarrow \mathrm{PC}$ | * | * | * | * | * |
| RTS | Return from Subroutine | $(\mathrm{SP})+\rightarrow \mathrm{PC}$ | - | - | - | - | - |
| SBCD | Subtract Decimal with Extend | (Destination) $1_{10}$ - (Source) $10-\mathrm{X} \rightarrow$ Destination | * | U | * | U | * |
| $\mathrm{S}_{\mathrm{CC}}$ | Set According to Condition | If CC then 1's $\rightarrow$ Destination else 0 's $\rightarrow$ Destination | - | - | - | - | - |
| STOP | Load Status Register and Stop | Immediate Data $\rightarrow$ SR; STOP | * | * | * | * | * |
| 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) - X $\rightarrow$ Destination | * | * | * | * | * |
| SWAP | Swap Register Halves | Register [31:16] $\rightarrow$ Register [15:0] | - | * | * | 0 | 0 |
| TAS | Test and Set an Operand | (Destination) Tested $\rightarrow$ CC; $1 \rightarrow$ [7] OF Destination | - | * | * | 0 | 0 |
| TRAP | Trap | $\mathrm{PC} \rightarrow-$ (SSP); $\mathrm{SR} \rightarrow$ - (SSP); (Vector) $\rightarrow$ PC | - | - | - | - | - |
| TRAPV | Trap on Overflow | If $\nu$ then TRAP | - | - | - | - | - |
| TST | Test and Operand | (Destination) Tested $\rightarrow$ CC | - | * | * | 0 | 0 |
| UNLK | Unlink | $A n \rightarrow$ SP; (SP) $+\rightarrow A n$ | - | - | - | - | - |

## NOTES:

| $\left[\begin{array}{ll}{[ } & =\text { bit number } \\ \Lambda & =\text { logical AND }\end{array}\right.$ |  | $=$ affected |
| :--- | :--- | :--- |
| $\nu$ | $=$ logical OR |  |
| $=$ unaffected |  |  |
| $\oplus$ | $=$ logical exclusive OR |  |
| $\sim$ | $=$ cleared |  |
| $\sim$ | $=$ logical complement | $U$ |

## Note

The number of periods includes instruction fetch and all applicable operand fetches and stores.

## EFFECTIVE ADDRESS OPERAND CALCULATION TIMING

Table 23 lists the number of clock periods required to compute an instruction's effective address. It includes fetching of any extension words, the address computation, and fetching of the memory operand. The number of bus read and write cycles is shown in parenthesis as (r/w). Note there are no write cycles involved in processing the effective address.

## MOVE INSTRUCTION CLOCK PERIODS

Tables 24 and 25 indicate the number of clock periods for the move instruction. This data includes instruction fetch, operand reads, and operand writes. The number of bus read and write cycles is shown in parenthesis as (r/w).

## STANDARD INSTRUCTION CLOCK PERIODS

The number of clock periods shown in Table 26 delineate the time required to perform the operations, store the results, and read the next instruction. The number of bus read and write cycles is shown in parenthesis as (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

In Table 26, the headings have the following meanings: $\mathrm{An}=$ address register operand, $\mathrm{Dn}=$ data register operand, ea $=$ an operand specified by an effective address, and $M=$ memory effective address operand.

## IMMEDIATE INSTRUCTION CLOCK PERIODS

The number of clock periods shown in Table 27 includes the time to fetch immediate operands, perform the operations, store the results, and read the next operation. The number of bus read and write cycles is shown in parenthesis as (r/w). The number

Table 23. Effective Address Calculation Timing

|  | Addressing Mode | Byte, Word | Long |
| :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { Dn } \\ & \text { An } \end{aligned}$ | $\quad$ Register Data Register Direct Address Register Direct | $\begin{aligned} & 0(0 / 0) \\ & 0(0 / 0) \end{aligned}$ | $\begin{aligned} & 0(0 / 0) \\ & 0(0 / 0) \end{aligned}$ |
| (An) $(A n)+$ | Memory <br> Address Register Indirect <br> 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}$ |
| $\begin{aligned} & -(A n) \\ & d(A n) \end{aligned}$ | Address Register Indirect with Predecrement Address Register Indirect with Displacement | $\begin{aligned} & 6(1 / 0) \\ & 8(2 / 0) \end{aligned}$ | $\begin{aligned} & 10(2 / 0) \\ & 12(3 / 0) \end{aligned}$ |
| $\begin{aligned} & \mathrm{d}(\mathrm{An}, \mathrm{ix})^{*} \\ & \mathrm{xxx} . \mathrm{W} \end{aligned}$ | Address Register Indirect with Index Absolute Short | $\begin{gathered} 10(2 / 0) \\ 8(2 / 0) \end{gathered}$ | $\begin{aligned} & 14(3 / 0) \\ & 12(3 / 0) \end{aligned}$ |
| $\begin{aligned} & \mathrm{xxx.L} \\ & \mathrm{~d}(\mathrm{PC}) \end{aligned}$ | Absolute Long <br> Program Counter with Displacement | $\begin{gathered} 12(3 / 0) \\ 8(2 / 0) \end{gathered}$ | $\begin{aligned} & 16(4 / 0) \\ & 12(3 / 0) \end{aligned}$ |
| $\begin{aligned} & \mathrm{d}(\mathrm{PC}, \mathrm{ix})^{*} \\ & \# \mathrm{xxx} \end{aligned}$ | Program Counter with Index Immediate | $\begin{gathered} 10(2 / 0) \\ 4(1 / 0) \end{gathered}$ | $\begin{array}{r} 14(3 / 0) \\ 8(2 / 0) \end{array}$ |
| *The size of the index register (ix) does not affect execution time. |  |  |  |

Table 24. Move Byte and Word Instruction Clock Periods

| Source | Destination |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Dn | An | (An) | (An) + | -(An) | d(An) | d(An, ix)* | xxx.W | xxx.L |
| Dn | 4(1/0) | 4(1/0) | 8(1/1) | 8(1/1) | 8(1/1) | 12(2/1) | 14(2/1) | 12(2/1) | 16(3/1) |
| An | 4(1/0) | 4(1/0) | 8(1/1) | 8(1/1) | 8(1/1) | 12(2/1) | 14(2/1) | 12(2/1) | 16(3/1) |
| (An) | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 16(3/1) | 18(3/1) | 16(3/1) | 20(4/1) |
| (An) + | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 16(3/1) | 18(3/1) | 16(3/1) | 20(4/1) |
| -(An) | 10(2/0) | 10(2/0) | 14(2/1) | 14(2/1) | 14(2/1) | 18(3/1) | 20(3/1) | 18(3/1) | 22(4/1) |
| $\mathrm{d}(\mathrm{An})$ | 12(3/0) | 12(3/0) | 16(3/1) | 16(3/1) | 16(3/1) | 20(4/1) | 22(4/1) | 20(4/1) | 24(5/1) |
| $\mathrm{d}(\mathrm{An}, \mathrm{ix})^{*}$ | 14(3/0) | 14(3/0) | 18(3/1) | 18(3/1) | 18(3/1) | 22(4/1) | 24(4/1) | 22(4/1) | 26(5/1) |
| xxx.W | 12(3/0) | 12(3/0) | 16(3/1) | 16(3/1) | 16(3/1) | 20(4/1) | 22(4/1) | 20(4/1) | 24(5/1) |
| xxx.L | 16(4/0) | 16(4/0) | 20(4/1) | 20(4/1) | 20(4/1) | 24(5/1) | 26(5/1) | 24(5/1) | 28(6/1) |
| d(PC) | 12(3/0) | 12(3/0) | 16(3/1) | 16(3/1) | 16(3/1) | 20(4/1) | 22(4/1) | 20(4/1) | 24(5/1) |
| $\mathrm{d}(\mathrm{PC}, \mathrm{ix})^{*}$ | 14(3/0) | 14(3/0) | 18(3/1) | 18(3/1) | 18(3/1) | 22(4/1) | 24(4/1) | 22(4/1) | 26(5/1) |
| \#xxx | 8(2/0) | 8(2/0) | 12(2/1) | 12(2/1) | 12(2/1) | 16(3/1) | 18(3/1) | 16(3/1) | 20(4/1) |

*The size of the index register (ix) does not affect execution time.
of clock periods and the number of read and write cycles must be added respectively to those of the effective adress calculation where indicated.

In Table 27, the headings have the following meanings: \# = immediate operand, $D n=$ data register operand, $\mathrm{An}=$ address register operand, $\mathrm{M}=$ memory operand, and $\mathrm{SR}=$ status register.

## SINGLE OPERAND INSTRUCTION CLOCK PERIODS

Table 28 indicates the number of clock periods for the single operand instructions. The number of bus read and write cycles is shown in parenthesis as ( $\mathrm{r} / \mathrm{w}$ ). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

Table 25. Move Long Instruction Clock Periods

| Source | Destination |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Dn | An | (An) | (An) + | -(An) | d(An) | $d(A n, i x) *$ | xxx.W | xxx.L |
| Dn | 4(1/0) | 4(1/0) | 12(1/2) | 12(1/2) | 12(1/2) | 16(2/2) | 18(2/2) | 16(2/2) | 20(3/2) |
| An | 4(1/0) | 4(1/0) | 12(1/2) | 12(1/2) | 12(1/2) | 16(2/2) | 18(2/2) | 16(2/2) | 20(3/2) |
| (An) | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2) | 24(4/2) | 28(5/2) |
| (An) + | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2) | 24(4/2) | 28(5/2) |
| - (An) | 14(3/0) | 14(3/0) | 22(3/2) | 22(3/2) | 22(3/2) | 26(4/2) | 28(4/2) | 26(4/2) | 30(5/2) |
| $\mathrm{d}(\mathrm{An})$ | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 28(5/2) | 30(5/2) | 28(5/2) | 32(6/2) |
| $\mathrm{d}(\mathrm{An}, \mathrm{ix})^{*}$ | 18(4/0) | 18(4/0) | 26(4/2) | 26(4/2) | 26(4/2) | 30(5/2) | 32(5/2) | 30(5/2) | 34(6/2) |
| xxx.W | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 28(5/2) | 30(5/2) | 28(5/2) | 32(6/2) |
| xxx.L | 20(5/0) | 20(5/0) | 28(5/2) | 28(5/2) | 28(5/2) | 32(6/2) | 34(6/2) | 32(6/2) | 36(7/2) |
| $\mathrm{d}(\mathrm{PC})$ | 16(4/0) | 16(4/0) | 24(4/2) | 24(4/2) | 24(4/2) | 28(5/2) | 30(5/2) | 28(5/2) | 32(5/2) |
| $\mathrm{d}(\mathrm{PC}, \mathrm{ix})^{*}$ | 18(4/0) | 18(4/0) | 26(4/2) | 26(4/2) | 26(4/2) | 30(5/2) | 32(5/2) | 30(5/2) | 34(6/2) |
| \#xxx | 12(3/0) | 12(3/0) | 20(3/2) | 20(3/2) | 20(3/2) | 24(4/2) | 26(4/2) | 24(4/2) | 28(5/2) |

Table 26. Standard Instruction Clock Periods

| Instruction | Size | op<ea>, Ant | op<ea>, Dn | op Dn, <M > |
| :---: | :---: | :---: | :---: | :---: |
| ADD | Byte, Word | $8(1 / 0)+$ | $4(1 / 0)+$ | $8(1 / 1)+$ |
|  | Long | 6(1/0) + ** | $6(1 / 0)+$ ** | 12(1/2) + |
| AND | Byte, Word | - | 4(1/0) + | 8(1/1) + |
|  | Long | - | $6(1 / 0)+$ * | 12(1/2) + |
| CMP | Byte, Word | $6(1 / 0)+$ | $4(1 / 0)+$ | - |
|  | Long | $6(1 / 0)+$ | $6(1 / 0)+$ | - |
| DIVS | - | - | 158(1/0) + * | - |
| DIVU | - | - | 140(1/0) + * | - |
| EOR | Byte, Word | - | 4(1/0)*** | $8(1 / 1)+$ |
|  | Long | - | 8(1/0) *** | 12(1/2) + |
| MULS | - | - | 70(1/0) + * | - |
| MULU | - | - | 70(1/0) + * | - |
| OR | Byte, Word | : - | 4(1/0) + | $8(1 / 1)+$ |
|  | Long | - | $6(1 / 0)+$ * | 12(1/2) + |
| SUB | Byte, Word | $8(1 / 0)+$ | $4(1 / 0)+$ | $8(1 / 1)+$ |
|  | Long | $6(1 / 0)+$ ** | $6(1 / 0)+$ * | 12(1/2) + |
| NOTES: <br> + add effective address calculation time <br> $\dagger$ word or long only <br> * indicates maximum value <br> ** The base time of six clock periods is increased to eight if the effective address mode is register direct or immediate (effective address time should also be added). <br> *** Only available effective address mode is data register direct <br> DIVS, DIVU The divide algorithm used by the R68000 provides less than $10 \%$ difference between the best and worst case timings. <br> MULS, MULU The multiply algorithm requires $38+2 n$ clocks where $n$ is defined as: <br> MULU: $\mathrm{n}=$ the number of ones in each <ea> <br> MULU: $\mathbf{n}=$ concatanate the <ea> with a zero as the LSB; n is the resultant number of 10 or 01 patterns in the 17-bit source; i.e., worst case happens when the source is $\$ 5555$. |  |  |  |  |
|  |  |  |  |  |

Table 27. Immediate Instruction Clock Periods


Table 28. Single Operand Instruction Clock Periods

| Instruction | Size | Register | Memory |
| :---: | :---: | :---: | :---: |
| CLR | Byte, Word | 4(1/0) | $8(1 / 1)+$ |
| CLR | Long | 6(1/0) | 12(1/2) + |
| NBCD | Byte | 6(1/0) | $8(1 / 1)+$ |
| NEG | Byte, Word | 4(1/0) | $8(1 / 1)+$ |
| NEG | Long | 6(1/0) | 12(1/2) + |
| NEGX | Byte, Word | 4(1/0) | $8(1 / 1)+$ |
| NEGX | Long | 6(1/0) | 12(1/2) + |
| NOT | Byte, Word | 4(1/0) | $8(1 / 1)+$ |
| NOT | Long | 6(1/0) | 12(1/2) + |
|  | Byte, False | 4(1/0) | $8(1 / 1)+$ |
| SCC | Byte, True | 6(1/0) | $8(1 / 1)+$ |
| TAS | Byte | 4(1/0) | 10(1/1) + |
| TST | Byte, Word | 4(1/0) | 4(1/0) + |
| TST | Long | 4(1/0) | 4(1/0) + |
| + add effective address calculation time |  |  |  |

## SHIFT/ROTATE INSTRUCTION CLOCK PERIODS

Table 29 delineates the number of clock periods for the shift and rotate instructions. The number of bus read and write cycles is shown in parenthesis as: $(\mathrm{r} / \mathrm{w})$. The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

## BIT MANIPULATION INSTRUCTION CLOCK PERIODS

Table 30 indicates the number of clock periods required for the bit manipulation instructions. The number of bus read and write cycles is shown in parenthesis as: $(r / w)$. The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

## CONDITIONAL INSTRUCTION CLOCK PERIODS

Table 31 delineates the number of clock periods required for the conditional instructions. The number of bus read and write cycles is indicated in parenthesis as: (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

## JMP, JSR, LEA, PWA, MOVEM INSTRUCTION CLOCK PERIODS

Table 32 indicates the number of clock periods required for the jump, jump to subroutine, load effective address, push effective address, and move multiple registers instructions. The number of bus read and write cycles is shown in parenthesis as: ( $\mathrm{r} / \mathrm{w}$ ).

Table 29. Shift/Rotate Instruction Clock Periods

| Instruction | Size | Register | Memory |
| :---: | :---: | :---: | :---: |
| ASR, ASL | Byte, Word | $6+\mathbf{n}(1 / 0)$ | 8(1/1) + |
|  | Long | $8+2 \mathrm{n}(1 / 0)$ | - |
| LSR, LSL | Byte, Word | $6+\mathbf{2 n}(1 / 0)$ | 8(1/1) + |
|  | Long | $8+2 \mathrm{n}(1 / 0)$ | - |
| ROR, ROL | Byte, Word | $6+2 \mathrm{n}(1 / 0)$ | 8(1/1) + |
|  | Long | $8+2 n(1 / 0)$ | - |
| ROXR, ROXL | Byte, Word | $6+\mathbf{n}(1 / 0)$ | 8(1/1) + |
|  | Long | $8+2 \mathrm{n}(1 / 0)$ | - |
| ective address or rotate count |  |  |  |

Table 30. Bit Manipulation Instruction Clock Periods

| Instruction | Size | Dynamic |  | Static |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Register | Memory | Register | Memory |
| BCHG | Byte | - | 8(1/1) + | - | 12(2/1) + |
|  | Long | 8(1/0)* | - | 12(2/0)* | - |
| BCLR | Byte | - | 8(1/1) + | - | 12(2/1) + |
|  | Long | 10(1/0)* | - | 14(2/0)* | - |
| BSET | Byte | - | 8(1/1) + | - | 12(2/1) + |
|  | Long | 8(1/0)* | - | 12(2/0)* | - |
| BTST | Byte | - | 4(1/0) + | - | $8(2 / 0)+$ |
|  | Long | 6(1/0) | - | 10(2/0) | - |
| + add effective address calculation time <br> * indicates maximum value |  |  |  |  |  |

Table 31. Conditional Instruction Clock Periods

| Instruction | Displacement | Branch Taken | Branch Not Taken |
| :---: | :---: | :---: | :---: |
| BCC | Byte | 10(2/0) | 8(1/0) |
|  | Word | 10(2/0) | 12(2/0) |
| BRA | Byte | 10(2/0) | - |
|  | Word | 10(2/0) | - |
| BSR | Byte | 18(2/2) | - |
|  | Word | 18(2/2) | - |
| DBCC | CC true | - | 12(2/0) |
|  | CC false | 10(2/0) | 14(3/0) |

Table 32. JMP, JSR, LEA, PEA, MOVEM INSTRUCTION CLOCK PERIODS

| Instr | Size | (An) | (An) + | -(An) | d(An) | d(An, ix)* + | xxx.w | xxx.L | d(PC) | d(PC, ix)* |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| JMP | - | 8(2/0) | - | - | 10(2/0) | 14(3/0) | 10(2/0) | 12(3/0) | 10(2/0) | 14(3/0) |
| JSR | - | 16(2/2) | - | - | 18(2/2) | 22(2/2) | 18(2/2) | 20(3/2) | 18(2/2) | 22(2/2) |
| LEA | - | 4(1/0) | - | - | 8(210) | 12(2/0) | 8(2/0) | 12(3/0) | 8(2/0) | 12(2/0) |
| PEA | - | 12(1/2) | - | - | 16(2/2) | 20(2/2) | 16(2/2) | 20(3/2) | 16(2/2) | 20(2/2) |
| $\begin{aligned} & \text { MOVEM } \\ & M \rightarrow R \end{aligned}$ | Word | $\begin{aligned} & 12+4 n \\ & (3+n / 0) \end{aligned}$ | $\begin{aligned} & 12+4 n \\ & (3+n / 0) \end{aligned}$ | - | $\begin{aligned} & 16+4 n \\ & (4+n / 0) \end{aligned}$ | $\begin{aligned} & 18+4 n \\ & (4+n / 0) \end{aligned}$ | $\begin{aligned} & 16+4 n \\ & (4+n / 0) \end{aligned}$ | $\begin{aligned} & 20+4 n \\ & (5+n / 0) \end{aligned}$ | $\begin{aligned} & 16+4 n \\ & (4+n / 0) \end{aligned}$ | $\begin{aligned} & 18+4 n \\ & (4+n / 0) \end{aligned}$ |
|  | Long | $\begin{aligned} & 12+8 n \\ & (3+2 n / 0) \end{aligned}$ | $\begin{aligned} & 12+8 n \\ & (3+2 n / 0) \end{aligned}$ | - | $\begin{aligned} & 16+8 n \\ & (4+2 n / 0) \end{aligned}$ | $\begin{aligned} & 18+8 n \\ & (4+2 n / 0) \end{aligned}$ | $\begin{aligned} & 16+8 n \\ & (4+2 n / 0) \end{aligned}$ | $\begin{aligned} & 20+8 n \\ & (5+2 n / 0) \end{aligned}$ | $\begin{aligned} & 16+8 n \\ & (4+2 n / 0) \end{aligned}$ | $\begin{aligned} & 18+8 n \\ & (4+2 n / 0) \end{aligned}$ |
| $\begin{aligned} & \text { MOVEM } \\ & R \rightarrow M \end{aligned}$ | Word | $\begin{aligned} & 8+4 n \\ & (2 / n) \end{aligned}$ | - | $\begin{aligned} & 8+4 n \\ & (2 / n) \end{aligned}$ | $\begin{aligned} & 12+4 n \\ & (3 / n) \end{aligned}$ | $\begin{aligned} & 14+4 n \\ & (3 / n) \end{aligned}$ | $\begin{aligned} & 12+4 n \\ & (3 / n) \end{aligned}$ | $\begin{aligned} & 16+4 n \\ & (4 / n) \end{aligned}$ | - | - |
|  | Long | $\begin{aligned} & 8+8 \mathbf{n} \\ & (2 / 2 n) \end{aligned}$ | - | $\begin{aligned} & 8+8 n \\ & (2 / 2 n) \end{aligned}$ | $\begin{aligned} & 12+8 n \\ & (3 / 2 n) \end{aligned}$ | $\begin{aligned} & 14+8 n \\ & (3 / 2 n) \end{aligned}$ | $\begin{aligned} & 12+8 n \\ & (3 / 2 n) \end{aligned}$ | $\begin{aligned} & 16+8 n \\ & (4 / 2 n) \end{aligned}$ | - | - |
| n is the number of registers to move <br> * The size of the index register (ix) does not affect the instruction's execution time |  |  |  |  |  |  |  |  |  |  |

## MULTI-PRECISION INSTRUCTION CLOCK PERIODS

Table 33 delineates the number of clock periods for the multiprecision instructions. The number of clock periods includes the time to fetch both operands, perform the operations, store the results, and read the next instructions. The number of read and write cycles is shown in parenthesis as: (r/w).

In Table 33, the headings have the following meanings: $\mathrm{Dn}=$ data register operand and $M=$ memory operand.

Table 33. Multi-Precision Instruction Clock Periods

| Instruction | Size | op Dn, Dn | op M, M |
| :---: | :--- | :---: | :---: |
|  | Byte, Word | $\mathbf{4 ( 1 / 0 )}$ | $18(3 / 1)$ |
|  | Long | $8(1 / 0)$ | $30(5 / 2)$ |
| CMPM | Byte, Word | - | $12(3 / 0)$ |
|  | Long | - | $20(5 / 0)$ |
| SUBX | Byte, Word | $4(1 / 0)$ | $18(3 / 1)$ |
|  | Long | $8(1 / 0)$ | $30(5 / 2)$ |
| ABCD | Byte | $6(1 / 0)$ | $18(3 / 1)$ |
| SBCD | Byte | $6(1 / 0)$ | $18(3 / 1)$ |

## MISCELLANEOUS INSTRUCTION CLOCK PERIODS

Table 34 and 35 indicate the number of clock periods for the following miscellaneous instructions. The number of bus read and write cycles is shown in parenthesis as: (r/w). The number of clock periods plus the number of read and write cycles must be added to those of the effective address calculation where indicated.

## EXCEPTION PROCESSING CLOCK PERIODS

Table 36 delineates the number of clock periods for exception processing. The number of clock periods includes the time for all stacking, the vector fetch, and the fetch of the first instruction of the handler routine. The number of bus read and write cycles is shown in parenthesis as (r/w).

Table 34. Miscellaneous Instruction Clock Periods

| Instruction | Size | Register | Memory | Instruction | Size | Register | Memory |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ANDI to CCR | Byte | 20(3/0) | - | LINK | - | 16(2/2) | - |
| ANDI to SR | Word | 20(3/0) | - | MOVE from USP | - | 4(1/0) | - |
| CHK | - | 10(1/0) + | - | MOVE to USP | - | 4(1/0) | - |
| EORI to CCR | Byte | 20(3/0) | - | NOP | - | 4(1/0) | - |
| EORI to SR | Word | 20(3/0) | -. | RESET | - | 132(1/0) | - |
| ORI to CCR | Byte | 20(3/0) | - | RTE | - | 20(5/0) | - |
| ORI to SR | Word | 20(3/0) | - | RTR | - | 20(5/0) | - |
| MOVE from SR | - | 6(1/0) | $8(1 / 1)+$ | RTS | - | 16(4/0) | - |
| MOVE to CCR | - | 12(2/0) | 12(2/0) + | STOP | - | 4(0/0) | - |
| MOVE to SR | - | 12(2/0) | 12(2/0) + | SWAP | - | 4(1/0) | - |
| EXG | - | 6(1/0) | - | TRAPV | - | 4(1/0) | - |
| EXT | Word | $\frac{4(1 / 0)}{4(1 / 0)}$ | - | UNLK | - | 12(3/0) | - |
| + add effective address calculation time |  |  |  |  |  |  |  |

Table 35. Move Peripheral Instruction Execution Times

| Instruction | Size | Register $\rightarrow$ Memory | Memory $\rightarrow$ Register |
| :---: | :---: | :---: | :---: |
|  | Word | $16(2 / 2)$ | $16(4 / 0)$ |
|  | Long | $24(2 / 4)$ | $24(6 / 0)$ |

Table 36. Exception Processing Clock Periods

|  | Exception | Periods |
| :---: | :---: | :---: |
|  | Address Error | 50(4/7) |
|  | Bus Error | 50(4/7) |
|  | CHK Instruction | 44(5/4) + |
|  | Divide by Zero | 42(5/4) |
|  | Illegal Instruction | 34(4/3) |
|  | Interrupt | 44(5/3)* |
|  | Privilege Violation | 34(4/3) |
|  | RESET** | 40(6/0) |
|  | Trace | 34(4/3) |
|  | TRAP Instruction | 38(4/4) |
|  | TRAPV Instruction | 34(4/3) |
| + add effective address calculation time <br> * The interrupt acknowledge cycle is assumed to take four clock periods. <br> ** Indicates the time from when $\overline{\mathrm{RESET}}$ and $\overline{\mathrm{HALT}}$ are first sampled as negated to when instruction execution starts. |  |  |

## MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to +7.0 | V |
| Operating Temperature Range |  | $\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$ |  |
|  | $\mathrm{T}_{\mathrm{A}}$ | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -56 to 150 | ${ }^{\circ} \mathrm{C}$ |

## THERMAL CHARACTERISTICS

| Characteristic | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Thermal Resistance | $\theta$ JA |  |  |
| 64-Pin Ceramic |  | 30 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| 64-Pin Plastic Dip |  | $55 \pm 5$ | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum-rated voltages to this high-impedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either $V_{S S}$ or $V_{C C}$.

## POWER CONSIDERATIONS

The average chip-junction temperature, $\mathrm{T}_{\mathrm{J}}$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
\begin{equation*}
T_{J}=T_{A}+\left(P_{D} \cdot \theta_{J A}\right) \tag{1}
\end{equation*}
$$

Where:

$$
\begin{aligned}
& \mathrm{T}_{\mathrm{A}} \equiv \equiv \text { Ambient Temperature, }{ }^{\circ} \mathrm{C} \\
& \theta_{\mathrm{JA}} \equiv \text { Package Thermal Resistance, Junction-to- } \\
& \text { Ambient, }{ }^{\circ} \mathrm{C} / \mathrm{W} \\
& \mathrm{PDD} \equiv \mathrm{PINT}^{2}+\mathrm{P}_{1 / \mathrm{O}} \\
& \mathrm{PINT}^{\prime} \equiv \mathrm{ICC} \cdot \mathrm{~V}_{\mathrm{CC}}, \text { Watts-Chip Internal Power } \\
& \mathrm{P}_{1 / \mathrm{O}} \equiv \equiv \text { Power Dissipation on Input and Output Pins- } \\
& \text { User Determined }
\end{aligned}
$$

For most applications $\mathrm{P}_{\mathrm{I} / \mathrm{O}}<\mathrm{PINT}_{\mathrm{IN}}$ and can be neglected.
An approximate relationship between $P_{D}$ and $T_{J}$ (if $P_{I / O}$ is neglected) is:

$$
\begin{equation*}
P_{D}=K \div\left(T J+273^{\circ} C\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
K=P_{D} \cdot\left(T_{A}+273^{\circ} \mathrm{C}\right)+\theta J A \cdot P_{D}{ }^{2} \tag{3}
\end{equation*}
$$

Where K is a constant pertaining to the particular part. K can be determined from equation 3 by measuring $P_{D}$ (at equilibrium) for a known $T_{A}$. Using this value of $K$ the values of $P_{D}$ and $T_{J}$ can be obtained by solving equations (1) and (2) iteratively for any value of $T_{A}$.

DC ELECTRICAL CHARACTERISTICS
$V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{H}{ }^{\circ} \mathrm{C}$. See Figures 41,42 , and 43 .

| Characteristic | Symbol | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{S S}-0.3$ | 0.8 | V |  |
| Input Leakage Current $\overline{B E R R}, \overline{B G A C K}, \overline{B R}, \overline{\mathrm{DTACK}}, \mathrm{CLK}, \overline{\mathrm{PLO}}-\overline{\mathrm{PL} 2}$ $\overline{V P A}, \overline{H A L T}, \overline{R E S E T}$ | IN | - | $\begin{aligned} & 2.5 \\ & 20 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & V_{I N}=5.25 \\ & V_{C C}=0 \end{aligned}$ |
| Three-State (Off State) Input Current AS, A1-A23, D0-D15, FC0-FC2, $\overline{\mathrm{LDS}}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{UDS}}, \overline{\mathrm{VMA}}$ | ITSI | - | 20 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & V_{C C}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage E* <br> E, $\overline{A S}$, A1-A23, $\overline{B G}, D 0-D 15, ~ F C 0-F C 2, \overline{L D S}, R / \bar{W}, \overline{U D S}, \overline{V M A}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{2.4}-0.75$ |  | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{lOH}=-400 \mu \mathrm{~A} \end{aligned}$ |
| Output Low Voltage HALT <br> BG, FC0-FC2, A1-A23 <br> RESET <br> $\overline{A S}, D 0-D 15, \overline{L D S}, R / \bar{W} \overline{U D S}, \overline{V M A}$ | $\mathrm{V}_{\mathrm{OL}}$ | $\begin{aligned} & - \\ & - \\ & - \end{aligned}$ | $\begin{aligned} & 0.6 \\ & 0.5 \\ & 0.5 \\ & 0.5 \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & (\mathrm{IOL}=1.6 \mathrm{~mA}) \\ & (\mathrm{IOL}=3.2 \mathrm{~mA}) \\ & (\mathrm{IOL}=5.0 \mathrm{~mA}) \\ & (\mathrm{IOL}=5.3 \mathrm{~mA}) \end{aligned}$ |
| Power Dissipation | PD*** | - | 1.5 | W |  |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | 20.0 | pF | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \mathrm{~V}_{\mathrm{IN}}=\mathrm{OV} \\ & \mathrm{f}=1 \mathrm{MHz}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |

[^1]**Capacitance is periodically sampled rather than $100 \%$ tested.
***During normal operation instantaneous $V_{\text {CC }}$ current requirements may be as high as 1.5A.


Figure 41. $\overline{\text { RESET Test Load }}$


Figure 42. $\overline{\text { HALT }}$ Test Load


Figure 43. Test Loads

CLOCK TIMING (See Figure 44)

| Characteristic | Symbol | 4 MHz |  | 6 MHz |  | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max |  |
| Frequency of Operation | F | 2.0 | 4.0 | 2.0 | 6.0 | 2.0 | 8.0 | 2.0 | 10.0 | 4.0 | 12.5 | MHz |
| Cycle Time | $\mathrm{t}_{\text {cyc }}$ | 250 | 500 | 167 | 500 | 125 | 500 | 100 | 500 | 80 | 250 | ns |
| Clock Pulse Width | $\begin{aligned} & \mathrm{t}_{\mathrm{t} \mathrm{CL}} \\ & \mathrm{t} \mathrm{CH} \end{aligned}$ | $\begin{aligned} & 115 \\ & 115 \\ & \hline \end{aligned}$ | $\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}$ | $\begin{aligned} & 45 \\ & 45 \end{aligned}$ | $\begin{aligned} & 250 \\ & 250 \end{aligned}$ | $\begin{aligned} & 35 \\ & 35 \end{aligned}$ | $\begin{aligned} & 125 \\ & 125 \end{aligned}$ | ns |
| Rise and Fall Times | $\begin{aligned} & { }^{t_{C}} \\ & t_{\mathrm{t}} \end{aligned}$ | - | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | - | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | - | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | - | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | - | 5 | ns |



Figure 44. Input Clock Waveform

AC ELECTRICAL SPECIFICATIONS - READ AND WRITE CYCLES
( $\mathrm{VCC}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{S S}=0 \mathrm{Vdc} ; \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$, see Figures 45 and 46 )

| Num. | Characteristic | Symbol | 4 MHz |  | 6 MHz |  | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max |  |
| 1 | Clock Period | $\mathrm{t}_{\text {cyc }}$ | 250 | 500 | 167 | 500 | 125 | 500 | 100 | 500 | 80 | 250 | ns |
| 2 | Clock Width Low | ${ }^{\text {t CL }}$ | 115 | 250 | 75 | 250 | 55 | 250 | 45 | 250 | 35 | 125 | ns |
| 3 | Clock Width High | ${ }^{\text {t }} \mathrm{CH}$ | 115 | 250 | 75 | 250 | 55 | 250 | 45 | 250 | 35 | 125 | ns |
| 4 | Clock Fall Time | t C | - | 10 | - | 10 | - | 10 | - | 10 | - | 5 | ns |
| 5 | Clock Rise Time | $\mathrm{t}_{\mathrm{Cr}}$ | - | 10 | - | 10 | - | 10 | - | 10 | - | 5 | ns |
| 6 | Clock Low to Address | t CLAV | - | 90 | - | 80 | - | 70 | - | 60 | - | 55 | ns |
| 6A | Clock High to FC Valid | tchfev | - | 90 | - | 80 | - | 70 | - | 60 | - | 55 | ns |
| 7 | Clock High to Address Data High Impedance (Maximum) | tchazx | - | 120 | - | 100 | - | 80 | - | 70 | - | 60 | ns |
| 8 | Clock High to Address/FC Invalid (Minimum) | ${ }^{\text {t CHAZn }}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 91 | Clock High to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low (Maximum) | ${ }^{\text {t CHSLx }}$ | - | 80 | - | 70 | - | 60 | - | 55 | - | 55 | ns |
| 10 | Clock High to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low (Minimum) | ${ }^{\text {t CHSLn }}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $11^{2}$ | Address to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ (Read) Low/AS Write | ${ }^{\text {taVSL }}$ | 55 | - | 35 | - | 30 | - | 20 | - | 0 | - | ns |
| $11 \mathrm{~A}^{2}$ | FC Valid to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ (Read) Low/Ā Write | tFCVSL | 80 | - | 70 | - | 60 | - | 50 | - | 40 | - | ns |
| ${ }^{12}{ }^{1}$ | Clock Low to $\overline{A S}, \overline{\mathrm{DS}}$ High | ${ }^{\text {t CLSH }}$ | - | 90 | - | 80 | - | 70 | - | 55 | - | 50 | ns |
| $13^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High to Address/FC Invalid | tshaz | 60 | - | 40 | - | 30 | - | 20 | - | 10 | - | ns |
| $14^{2}$ | $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Width Low (Read)// $\overline{A S}$ Write | ${ }^{\text {tSL}}$ | 535 | - | 337 | - | 240 | - | 195 | - | 160 | - | ns |
| 14A ${ }^{2}$ | $\overline{\text { DS Width Low (Write) }}$ | tDWPW | 285 | - | 170 | - | 115 | - | 95 | - | 80 | - | ns |
| $15^{2}$ | $\overline{\text { AS, }} \overline{\text { DS }}$ Width High | tSH | 285 | - | 180 | - | 150 | - | 105 | - | 65 | - | ns |
| 16 | Clock High to $\overline{\text { AS, }} \overline{\text { DS }}$ High | teHSz | - | 120 | - | 100 | - | 80 | - | 70 | - | 60 | ns |
| $17^{2}$ |  | tSHRH | 60 | - | 50 | - | 40 | - | 20 | - | 10 | - | ns |
| $18^{1}$ | Clock High to R/W High (Maximum) | ${ }^{\text {t }} \mathrm{CHRHx}$ | - | 90 | - | 80 | - | 70 | - | 60 | - | 60 | ns |
| 19 | Clock High to $\mathrm{R} / \overline{\mathrm{W}}$ High (Minimum) | ${ }^{\text {t }} \mathrm{CHRHn}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $20^{1}$ | Clock High to R/̄W Low | tCHRL | - | 90 | - | 80 | - | 70 | - | 60 | - | 60 | ns |
| 20A6 | $\overline{\text { AS }}$ Low to R/W Valid | tasRV | - | 20 | - | 20 | - | 20 | - | 20 | - | 20 | ns |
| $21^{2}$ | Address Valid to R/̄W Low | $\mathrm{t}_{\text {AVRL }}$ | 45 | - | 25 | - | 20 | - | 0 | - | 0 | - | ns |
| 21A ${ }^{2}$ | FC Valid to R/W Low | ${ }^{\text {t }}$ FCVRL | 80 | - | 70 | - | 60 | - | 50 | - | 30 | - | ns |
| $22^{2}$ | R/पָ Low to $\overline{\mathrm{DS}}$ Low (Write) | trLSL | 200 | - | 140 | - | 80 | - | 50 | - | 30 | - | ns |
| 23 | Clock Low to Data Out Valid | t CLDO | - | 90 | - | 80 | - | 70 | - | 55 | - | 55 | ns |
| 24 | Clock High to R/ $\bar{W}, \overline{\text { VMA }}$ High Impedance | tCHRZ | - | 120 | - | 100 | - | 80 | - | 70 | - | 60 | ns |
| $25^{2}$ | $\overline{\text { DS }}$ High to Data Out Invalid | tSHDO | 60 | - | 40 | - | 30 | - | 20 | - | 15 | - | ns |
| $26^{2}$ | Data Out Valid to $\overline{\mathrm{DS}}$ Low (Write) | tDOSL | 55 | - | 35 | - | 30 | - | 20 | - | 15 | - | ns |
| 275 | Data In to Clock Low (Setup Time) | t ${ }^{\text {dICL }}$ | 30 | - | 25 | - | 15 | - | 10 | - | 10 | - | ns |
| 27A | Late BERR Low to Clock Low (Setup Time) | tbeLCL | 45 | - | 45 | - | 45 | - | 45 | - | 45 | - | ns |
| $28^{2}$ | $\overline{\text { AS }}$, $\overline{\mathrm{DS}}$ High to DTACK High | tshDAH | 0 | 490 | 0 | 325 | 0 | 245 | 0 | 190 | 0 | 150 | ns |

## AC ELECTRICAL SPECIFICATIONS - READ AND WRITE CYCLES (CONTINUED)

| Num. | Characteristic | Symbol | 4 MHz |  | 6 MHz |  | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max |  |
| 29 | $\overline{\mathrm{DS}}$ High to Data Invalid (Hold Time) | ${ }^{\text {t }}$ SHDI | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 30 | $\overline{\text { AS, }} \overline{\text { DS }}$ High to $\overline{\text { BERR }}$ High | tSHBEH | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $31{ }^{2}$ | DTACK Low to Data In (Setup Time) | tDALDI | - | 180 | - | 120 | - | 90 | - | 65 | - | 50 | ns |
| 32 | HALT and RESET Input Transition Time | ${ }^{\text {thHr,f }}$ | 0 | 200 | 0 | 200 | 0 | 200 | 0 | 200 | 0 | 200 | ns |
| 33 | Clock High to $\overline{\mathbf{B G}}$ Low | tCHGL | - | 90 | - | 80 | - | 70 | - | 60 | - | 50 | ns |
| 34 | Clock High to $\overline{\mathrm{BG}}$ High | ${ }^{\text {t }} \mathrm{CHGH}$ | - | 90 | - | 80 | - | 70 | - | 60 | - | 50 | ns |
| 35 | $\overline{\mathrm{BR}}$ Low to $\overline{\mathrm{BG}}$ Low | tBRLGL | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | Clk. Per. |
| 36 | $\overline{\mathrm{BR}}$ High to $\overline{\mathrm{BG}}$ High | tBRHGH | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | Clk. Per. |
| 37 | BGACK Low to $\overline{\mathbf{B G}}$ High | tGALGH | 1.5 | 3.0 | 1.5 | 3.0 | 1.5 | 3.0 | 1.5 | 3.0 | 1.5 | 3.0 | Clk. Per. |
| 37A | $\overline{B G A C K}$ Low to $\overline{B R}$ High (to Prevent Rearbitration) | tBGKBR | 30 | - | 25 | - | 20 | - | 20 | - | 20 | - | ns |
| 38 | $\overline{B G}$ Low to Bus High Impedance (with $\overline{\text { AS High) }}$ | tGLZ | - | 120 | - | 100 | - | 80 | - | 70 | - | 60 | ns |
| 39 | $\overline{\text { BG Width High }}$ | tGH | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | Clk. Per. |
| 40 | Clock Low to VMA Low | tCLVML | - | 90 | - | 80 | - | 70 | - | 70 | - | $70^{\circ}$ | ns |
| 41 | Clock Low to E Transition | tcle | - | 100 | - | 85 | - | 70 | - | 55 | - | 45 | ns |
| 42 | E Output Rise and Fall Time | tEr,f | - | 25 | - | 25 | - | 25 | - | 25 | - | 25 | ns |
| 43 | VMA Low to E High | tVMLEH | 325 | - | 240 | - | 200 | - | 150 | - | 90 | - | ns |
| 44 | $\overline{\text { AS, }} \overline{\text { DS }}$ High to $\overline{\mathrm{VPA}}$ High | tSHVPH | 0 | 240 | 0 | 160 | 0 | 120 | 0 | 90 | 0 | 70 | ns |
| 45 | E Low to Address/ $\overline{\mathrm{MMA} / F C}$ Invalid | teLAI | 55 | - | 35 | - | 30 | - | 10 | - | 10 | - | ns |
| 46 | BGACK Width | ${ }^{\text {t BGL }}$ | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | Clk. Per. |
| 475 | Asynchronous Input Setup Time | ${ }^{\text {t }}$ ASI | 30 | - | 25 | - | 20 | - | 20 | - | 20 | - | ns |
| $48^{3}$ | $\overline{\text { BERR }}$ Low to DTACK Low | ${ }^{\text {t }}$ BELDAL | 30 | - | 25 | - | 20 | - | 20 | - | 20 | - | ns |
| 49 | E Low to $\overline{A S}, \overline{\mathrm{DS}}$ Invalid | teLSI | -80 | - | -80 | - | -80 | - | -80 | - | -80 | - | ns |
| 50 | E Width High | tEH | 900 | - | 600 | - | 450 | - | 350 | - | 280 | - | ns |
| 51 | E Width Low | $\mathrm{t}_{\mathrm{E}}$ | 1400 | - | 900 | - | 700 | - | 550 | - | 440 | - | ns |
| 52 | E Extended Rise Time | tciehx | - | 80 | - | 80 | - | 80 | - | 80 | - | 80 | ns |
| 53 | Data Hold from Clock High | tCHDO | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 54 | Data Hold from E Low (Write) | teldoz | 60 | - | 40 | - | 30 | - | 20 | - | 15 | - | ns |
| 55 | R/ $\bar{W}$ to Data Bus Impedance Change | trLDO | 55 | - | 35 | - | 30 | - | 20 | - | 10 | - | ns |
| 564 | HALT/RESET Pulse Width | thRPW | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | Clk. Per. |

Notes:

1. For a loading capacitance of less than or equal to 50 picofarads, subtract 5 nanoseconds from the value given in these columns.
2. Actual value depends on clock period.
3. If \#47 is satisfied for both DTACK and BERR, \#48 may be 0 nanoseconds.
4. For power up, the MPU must be held in RESET state for 100 ms to stabilize all on-chip circuitry. After the system is powered up, \#56 refers to the minimum pulse width required to reset the system.
5. If the asynchronous setup time (\#47) requirements are satisfied the $\overline{\text { DTACK }}$ low-to-data setup time (\#31) requirement can be ignored. The data must only satisfy the data-in clock-low setup time (\#27) for the following cycle.
6. When $\overline{A S}$ and $R / \bar{W}$ are equally loaded ( $\pm 20 \%$ ), subtract 10 nanoseconds from the value given in these columns.


NOTES:

1. SETUP TIME FOR THE ASYNCHRONOUS INPUTS $\overline{\text { BGACK }}, \overline{\mathrm{IPLO}}-\overline{\mathrm{IPL}}$, AND $\overline{\mathrm{VPA}}$ GUARANTEES THEIR RECOGNITION AT THE NEXT FALLING EDGE OF THE CLOCK.
2. BR NEEDS FALL AT THIS TIME ONLY IN ORDER TO INSURE BEING RECOGNIZED AT THE END OF THIS BUS CYCLE.
3. TIMING MEASUREMENTS ARE REFERENCED TO AND FROM A LOW VOLTAGE OF 0.8 VOLTS AND A HIGH VOLTAGE OF 2.0 VOLTS, UNLESS OTHERWISE NOTED.

Figure 45. Read Cycle Timing


NOTES:

1. because of loading variations, r/W may be valid after $\overline{\operatorname{AS}}$ even though both are initiated by the rising EDGE OF S2 (SPECIFICATION 20A).
2. timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 VOLTS, UNLESS OTHERWISE NOTED.

Figure 46. Write Cycle Timing

AC ELECTRICAL SPECIFICATIONS - BUS ARBITRATION
( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ}$ to $70^{\circ} \mathrm{C}$. See Figure 47.)

| Num. | Characteristic | Symbol | 4 MHz |  | 6 MHz |  | 8 MHz |  | 10 MHz |  | 12.5 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max | Min | Max | Min | Max |  |
| 33 | Clock High to $\overline{B G}$ Low | tCHGL | - | 90 | - | 80 | - | 70 | - | 60 | - | 50 | ns |
| 34 | Clock High to $\overline{\mathrm{BG}}$ High | ${ }^{\text {t }} \mathrm{CHGH}$ | - | 90 | - | 80 | - | 70 | - | 60 | - | 50 | ns |
| 35 | $\overline{B R}$ Low to $\overline{B G}$ Low | tBRLGL | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | Clk. Per. |
| 36 | $\overline{\mathrm{BR}}$ High to $\overline{\mathrm{BG}}$ High | tBRHGH | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | Clk. Per. |
| 37 | BGACK Low to $\overline{\text { BG High }}$ | tGALGH | 1.5 | 3.0 | 1.5 | 3.0 | 1.5 | 3.0 | 1.5 | 3.0 | 1.5 | 3.0 | Clk. Per. |
| 37A | $\overline{\text { BGACK Low to } \overline{\mathrm{BR}} \text { High }}$ (to Prevent Rearbitration) | tBGKBR | 30 | - | 25 | - | 20 | - | 20 | - | 20 | - | ns |
| 38 | $\overline{B G}$ Low to Bus High Impedance (with $\overline{\text { AS }}$ High) | tGLZ | - | 120 | - | 100 | - | 80 | - | 70 | - | 60 | ns |
| 39 | $\overline{\mathrm{BG}}$ Width High | ${ }_{\text {t }}^{\text {GH }}$ | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | Clk. Per. |
| 46 | BGACK Width | $\mathrm{t}_{\text {BGL }}$ | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | Clk. Per. |

THESE WAVEFORMS SHOULD ONLY BE REFERENCED IN REGARD TO THE EDGE-TO-EDGE MEASUREMENT OF THE TIMING SPECIFICATIONS. THEY ARE NOT INTENDED AS A FUNCTIONAL DESCRIPTION OF THE INPUT AND OUTPUT SIGNALS. REFER TO OTHER FUNCTIONAL DESCRIPTIONS AND THEIR RELATED DIAGRAMS FOR DEVICE OPERATION.


NOTES:

1. SETUP TIME FOR THE ASYNCHRONOUS INPUTS $\overline{B E R R}, \overline{B G A C K}, \overline{B R}, \overline{\text { DTACK }}, \overline{I P L O}-\overline{I P L 2}$, AND $\overline{\text { VPA }}$ GUARANTEES THEIR RECOGNITION AT THE NEXT FALLING EDGE OF THE CLOCK.
2. WAVEFORM MEASUREMENTS FOR ALL INPUTS AND OUTPUTS ARE SPECIFIED AT: LOGIC HIGH=2.0 VOLTS, LOGIC LOW $=0.8$ VOLTS

Figure 47. AC ELECTRICAL Waveforms - Bus Arbitration

## R68465 <br> DOUBLE-DENSITY FLOPPY DISK CONTROLLER (DDFDC)

PRELIMINARY

## DESCRIPTION

The R68465 Double-Density Floppy Disk Controller (DDFDC) interfaces up to four floppy disk drives to a 68000/68008 microprocessor-based system. The DDFDC simplifies the system design by minimizing both the number of external hardware components and software steps needed to implement the floppy disk drive (FDD) interface. Control signals supplied by the DDFDC reduce the number of components required in external phase locked loop and write precompensation circuitry. Memorymapped registers containing commands, status and data simplify the software interface. Built-in functions reduce the software overhead needed to control the FDD interface. The DDFDC supports both the IBM 3740 Single-Density (FM) and IBM System 34 Double-Density (MFM) formats.

The DDFDC interfaces directly to the 68000/68008 asynchronous microprocessor bus and operates with 8-bit byte length data transferred on the bus. The DDFDC will operate in either DMA or non-DMA mode. In DMA mode, the MPU need only load the command into the DDFDC and all data transfers occur under DMA control. The DDFDC is directly compatible with the MC68440 Dual Direct Memory Access Controller (DDMAC). In non-DMA mode, the DDFDC generates an interrupt to the MPU indicating that a byte of data is available.

Controller commands, command or device status, and data are transferred between the DDFDC and the MPU via six internal registers. The Main Status Register (MSR) stores the DDFDC status information while four additional status registers provide result information to the MPU following each controller command. The Data Register (DR) stores actual disk data, parameters, controller commands and FDD status information for use by the MPU.

The R68465 executes 15 separate multi-byte commands:

Read Data
Write Data
Read Deleted Data
Write Deleted Data
Read a Track
Read ID
Seek
Recalibrate (Restore to Track 0)

## Specify

Format a Track
Scan Equal
Scan High or Equal
Scan Low or Equal
Sense Interrupt Status
Sense Drive Status


Figure 1. DDFDC Input and Output Signals

## PIN DESCRIPTION

Throughout this document signals are presented using the terms active and inactive, or asserted and negated, independent of whether the signal is active in the high-voltage state or lowvoltage state. (The active state of each logic pin is described below.) Active low signals are denoted by a superscript bar. For example, $R / \bar{W}$ indicates read is active high and a write is active low.

## BUS INTERFACE

D0-D7-Data Lines. The bidirectional data lines transfer data between the DDFDC and the 8 -bit data bus.

CLK-CLOCK. The clock is a TTL compatible 8 MHz square wave signal.

RESET-RESET. This active high input places the DDFDC in the idle state and resets the output lines to the floppy disk drives to the low state.
$\overline{\mathrm{CS}}$-Chip Select. The DDFDC is selected when the $\overline{\mathrm{CS}}$ input is low.

RS-Data/Status Register Select. This input selects the Data or Status Register for reading from or writing to. When RS = high, the Data Register is selected and the state of R/W determines whether it is a read ( $R \bar{W}=$ high $)$ or a write $(R / \bar{W}=$ low) operation. when RS = low, the Status Register is selected. This register may only be read ( $\mathrm{R} \bar{W} \bar{W}=$ high); the state $\mathrm{R} \overline{\mathrm{W}}=$ low is invalid when the Status Register is selected.
$\overline{\text { IRQ-Interrupt Request. This active low output is the interrupt }}$ request generated by the DDFDC to the MPU. $\overline{\mathrm{IRQ}}$ is asserted upon completion of some DDFDC commands and before a data byte is transferred between the DDFDC and the data bus (in the Non-DMA mode).

R/W-Read/Write. This input defines the data bus transfer as a read or write cycle. When high (read), the data transfer is from the DDFDC to the data bus. When low (write), the data transfer is from the data bus to the DDFDC.

DTACK-Data Transfer Acknowledge. This signal is the asynchronous handshake line for information transfer on the 68000 system bus. It is generated by the DDFDC as an acknowledge to the $\overline{\mathrm{CS}}$ signal in an asynchronous transfer. A low output indicates that valid data is on the bus (read cycle) or that data has been written (write cycle). Except when being asserted, this signal is normally in the high impedance state.

The output characteristics of $\overline{D T A C K}$ are the same as other system interface signals with allowances for an external pullup resistor such that the output is driven to the high level first and then to the high impedance state.

## DIRECT MEMORY ACCESS CONTROLLER (DMAC) INTERFACE

DACK-DMA Acknowledge. The DMA transfer acknowledge signal is a TTL compatible input generated by the DMA controller (DMAC) controlling the DDFDC. The DMA cycle is active when DACK is low and the DDFDC is performing a DMA transfer.
(REQ-Data DMA Request. The transfer request signal is a TTL compatible output generated by the DDFDC to request a data transfer operation under control of the DMAC (in the DMA mode). The request is active when $\overline{\text { REQ }}=$ low. The signal is reset inactive when DMA Acknowledge ( $\overline{\mathrm{DACK}}$ ) is asserted (low).
$\overline{D O N E}-D M A$ Transfer Complete. This input signal is issued to the DDFDC when the DMA transfer for a channel is complete. The signal is active low concurrent with the $\overline{\text { DACK }}$ input when the DMA operation is complete as a result of that transfer.

## FDD SERIAL DATA INTERFACE

RDD-Read Data. Read Data input from the floppy disk drive (FDD) containing clock and data bits.

RDW-Read Data Window. Data Window input generated by the Phase Locked Loop (PLL) and used to sample data from the FDD.

VCO—Variable Frequency Oscillator Sync. This output signal inhibits the VCO in the PLL circuit when low and enables the VCO in the PLL circuit when high. This inhibits RDD and RDW from being generated until valid data is detected from the FDD.

WCK-Write Clock. This input clock determines the Write Data rate to the FDD. The data rate is 500 KHz in the FM mode (MFM = low) and 1 MHz in the MFM mode (MFM = high). The pulse width is 250 ns (typical) in both modes.

WDA-Write Data. Serial write data output to the FDD containing both clock and data bits.

WE-Write Enable. This output signal enables the Write Data into the FDD when high.

PS0-PS1-Preshift. These outputs are encoded to convey write compensation status during the MFM mode to determine early, late or normal times as follows:

| Write Precompensation Status | Preshift Outputs |  |
| :---: | :---: | :---: |
|  | PS0 | PS1 |
| Normal | 0 | 0 |
| Late | 0 | 1 |
| Early | 1 | 0 |
| Invalid | 1 | 1 |
| $0=$ Low, $1=$ High |  |  |

## FDD STATUS INTERFACE

RDY-Ready. An active high input signal indicates the FDD is ready to send data to, or receive data from, the DDFDC.

IDX-Index. An active high input signal from the FDD indicates the index hole is under the index sensor. Index is used to synchronize DDFDC timing.

RW/SEEK—Read Write/Seek. Mode selection signal to the FDD which controls the multiplexer from the multiplexed signals. When $\overline{R W} /$ SEEK is low, the Read/Write mode is commanded; when $\overline{R W} /$ SEEK is high, the Seek mode is commanded.

| $\overline{\text { RW/SEEK }}$ | Mode | Active FDD Interface Signals |
| :---: | :---: | :---: |
| Low | Read/Write | WP, FLT, LCT, FR |
| High | Seek | TS, TRKO, DIR, STP |

WP/TS-Write Protect/Two Side. An active high multiplexed input signal from the FDD. In the Read/Write mode, WP/TS high indicates the media is write-protected. In the Seek mode, WP/TS high indicates the media is two-sided.

FLT/TRKO—Fault/Track Zero. An active high multiplexed input from the FDD. In the Read/Write mode ( $\overline{R W} /$ SEEK $=$ low), FLT/TRKO high indicates an FDD fault. In the Seek mode, FLT/TRKO high indicates that the read/write head is positioned over track zero.


LCT/DIR-Low Current/Direction. A multiplexed output to the FDD. In the Read/Write mode, LCT/DIR is low when the read/write head is to be positioned over the inner tracks and the LCT/DIR is high when the head is to be positioned over the outer tracks. In the Seek mode, LCT/DIR controls the head direction. When LCT/DIR is high, the head steps to the outside of the disk; when LCT/DIR is low, the head steps to the inside of the disk.

FR/STP—Fault Reset/Step. A multiplexed output to the FDD. In the Read/Write mode, FR/STP high resets the fault indicator in the FDD. An FR pulse is issued at the beginning of each read or write command prior to issuing HDL. In the Seek mode, FR/STP provides the step pulses to move the read/write head to another track in the direction indicated by the LCT/DIR signal.

HDL-Head Load. An active high output to notify the FDD that the read/write head should be loaded (placed in contact with the media). A low level indicates the head should be unloaded.

HD-Head Select. An output to the FDD to select the proper read/write head. Head One is selected when HD = high and Head Zero is selected when HD = low.

US0-US1-Unit Select. Output signals for floppy disk drive selection as follows:

| Unit Select |  | Floppy Disk <br> Drive Select |
| :---: | :---: | :---: |
| USO | US1 |  |
| 0 | 0 | 1 |
| 0 | 1 | 2 |
| 1 | 0 | 3 |
| 1 | 1 |  |
| $0=$ Low, $1=$ High |  |  |

MFM-MFM Mode. Output signal to the FDD to indicate MFM or FM mode. Selects the MFM mode when MFM = high and the FM mode when MFM = low.

VCC-Power. +5 V dc.
GND-Ground ( $\mathbf{V}_{\mathbf{s 3}}$ ).


Figure 2. DDFDC Block Diagram

## DDFDC REGISTERS

The DDFDC contains six registers which may be accessed by the processor or DMA controller via the system (i.e., microprocessor) bus: a Main Status Register, a Data Register, and four Result Status Registers. The 8-bit Main Status Register (MSR) contains the status information of the DDFDC, and may be accessed at any time. The 8-bit Data Register, consisting of several registers in a stack with only one register presented to the data bus at a time, stores data, commands, parameters and FDD status information. Bytes of data are read out of, or written into, the Data Register in order to initiate a command or to obtain the results of a command execution.

The read-only Main Status Register facilitates the transfer of data between the system and the DDFDC. The other Status Registers (ST0, ST1, ST2 and ST3) are only available during the result phase, and may be read only after completing a command. The particular command which has been executed determines how many of the Status Registers will be read.

The relationship between the status/data registers and the $\mathrm{R} \bar{W}$ and RS signals is shown below.

| RS | $\mathbf{R} / \bar{W}$ | Function |
| :---: | :---: | :--- |
| 0 | 0 | Read Main Status Register |
| 0 | 0 | lliegal |
| 1 | 1 | Read from Data Register |
| 1 | 0 | Write into Data Register |
| $0=$ Low, $1=$ High |  |  |

Table 1 shows each of the status registers used by the DDFDC and each bit assignment within the individual registers. Table 2 defines the symbols used throughout the command definitions. Each register bit symbol is defined in the register definition that follows Table 2.

## REGISTER DEFINITIONS

## Main Status Register (MSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RQM | DIO | EXM | CB | D3B | D2B | D1B | DOB |

The Main Status Register (MSR) contains the status information of the DDFDC, and must be read by the processor before each byte is written to, or read from, the Data Register during the command or result phase. MSR reads are not required during the execution phase. The Data Input/Output (DIO) and Request for Master (RQM) bits in the MSR indicate when data is ready and in which direction data will be transferred on the data bus. The maximum time between the last $R \bar{W}$ during command or result phases and the DIO and RQM getting set or reset is $12 \mu \mathrm{~s}$. For this reason, every time the MSR is read the processor should wait $12 \mu \mathrm{~s}$. The maximum time from the end of the last read in the result phase to when bit 4 (DDFDC Busy) goes low is also $12 \mu \mathrm{~s}$.

The DIO and RQM timing chart is shown in Figure 3.

## MSR

7 RQM -Request for Master.
Data Register is not ready. Data Register is ready.

## MSR

6 DIO -Data Input/Output.
0 Data transfer is from system to the Data Register.
1 Data transfer is from Data Register to the system.

## MSR

5 EXM -Execution Mode. (Non-DMA mode only).
$\overline{0}$ Execution phase ended, result phase begun.
1 Execution phase started.

## MSR

4 CB -Controller (DDFDC) Busy.
$\overline{0} \quad$ DDFDC is not busy, will accept a command.
1 DDFDC is busy, will not accept a command.

## MSR

3 D3B -Floppy Disk Drive (FDD) 3 Busy.
0 FDD 3 is not busy, DDFDC will accept read or write command.
1 FDD 3 is busy, DDFDC will not accept read or write command.

## MSR

2 D2B -FDD 2 Busy.
$\overline{0} \quad$ FDD 2 is not busy, DDFDC will accept read or write command.
1 FDD 2 is busy, DDFDC will not accept read or write command.

## MSR

1 D1B -FDD 1 Busy.
FDD 1 is not busy, DDFDC will accept read or write command.
1 FDD 1 is busy, DDFDC will not accept read or write command.

## MSR

0 DOB -FDD 0 Busy.
$\overline{0} \quad$ FDD 0 is not busy, DDFDC will accept read or write command.
1 FDD 0 is busy, DDFDC will not accept read or write command.

## Status Register 0 (STO)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IC |  | SE | EC | NR | HD | US |  |
|  |  |  |  | US1 | US0 |  |  |

The Status Register 0 (STO) as well as the other status registers (ST1-ST3), are available only during the result phase, and may be read only after completing a command. The particular command executed determines which status registers are used and may be read.

Table 1. DDFDC Status Register Bit Assignments

Main Status Register (MSR)
Status Register 0 (STO)
Status Register 1 (ST1)
Status Register 2 (ST2)
Status Register 3 (ST3)

| Bit Number |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| RQM | DIO | EXM | CB | D3B | D2B | D1B | DOB |
| IC |  | SE | EC | NR | HD | US |  |
|  |  | US1 |  |  |  | Uso |
| EN | 0 |  | DE | OR | 0 | ND | NW | MA |
| 0 | CM | DD | WT | SH | SN | BT | MD |
| FLT | WP | RDY | TRKO | TS | HD | US1 | USO |

Table 2. Command Symbol Description

| Symbol | Name | Description |
| :---: | :---: | :---: |
| D | Data | The data pattern which is going to be written into a sector. |
| DO-D7 | Data Bus | 8 -bit data bus, where D0 is the least significant data line and D7 is the most significant data line. |
| DTL | Data Length | When N is defined as 00 , DTL is the number of data bytes to read from or write into the sector. |
| EOT | End of Track | The final sector number on a track. During read or write operation, the DDFDC stops data transfer after reading from or writing to the sector equal to EOT. |
| GPL | Gap Length | The length of Gap 3. During read/write commands this value determines the number of bytes that the VCO will stay low after two CRC bytes. During the Format a Track command it determines the size of Gap 3. |
| H | Head Address | Head number 0 or 1, as specified in ID field. |
| HD (H) | Head | A selected head number 0 or 1 which controls the polarity of pin 27. ( $H=H D$ in all command words). |
| HLT | Head Load Time | The head load time in the FDD (2 to 254 ms in 2 ms increments). |
| HUT | Head Unload Time | The head unload time after a read or write operation has occurred ( 16 to 240 ms in 16 ms increments). |
| MF | FM or MFM Mode | When MF $=0$, FM mode is selected; and when MF $=1$, MFM mode is selected. |
| MT | Multi-Track | When MT = 1 , a multi-track operation is to be performed. After finishing a read/write operation on side 0 , the DDFDC will automatically start searching for sector 1 on side 1 . |
| N | Bytes/Sector | The number of data bytes written in a sector. |
| ND | Non-DMA Mode | When ND = 1, operation is in the Non-DMA mode; when ND $=0$, operation is in the DMA mode. |
| NTN | New Track Number | A new track number, which will be reached as a result of the Seek command. Desired head position. |
| PTN | Present Track Number | The track number at the completion of Sense Interrupt Status command. Present head position. |
| R | Record (Sector) | The sector number to be read or written. |
| RS | Register Select | Controls selection of Main Status Register (RS = low) or Data Register (RS = high). |
| R/W | Read/Write | Either read (R) or write (W) signal |
| ST | Sectors/Track | The number of sectors per track. |
| SK | Skip | Skip Deleted Data Address Mark. |
| SRT | Step Rate Time | The stepping rate for the FDD ( 1 to 16 ms in 1 ms increments). Stepping rate applies to all drives ( $F=1 \mathrm{~ms}, E=2 \mathrm{~ms}$, etc.) |
| STO <br> ST1 <br> ST2 <br> ST3 | Status 0 <br> Status 1 <br> Status 2 <br> Status 3 | Four registers which store the status information after a command has been executed. This information is available during the result phase after command execution. These registers should not be confused with the Main Status Register (selected by RS = low). STO-ST3 may be read only after a command has been executed and contain information relevant to that particular command. |
| STP | Sector Test Process | During a Scan command, if STP $=01$, the data in contiguous sectors is compared byte by byte with data sent from the processor (or DMA controller); and if STP $=\mathbf{0 2}$, then alternate sectors are read and compared. |
| T | Track Number | The current/selected track number of the medium (0-255). |
| US0,US1 | Unit Select | A selected drive number ( $0-3$ ). |


| 7 | IC | IC -Interrupt Code. |
| :---: | :---: | :---: |
| 00 |  | Normal Termination (NT). Command was properly executed and completed. |
| 01 |  | Abnormal Termination (AT). Command execution was started, but was not successfully completed. |
| 10 | 0 I | Invalid Command (IC). Received command was invalid. |
| 11 |  | Abnormal Termination (AT). The Ready (RDY) signal from the FDD changed state during command execution. |
| STO |  |  |
| 5 | SE | E -Seek End. |
| $\overline{0}$ |  | Seek command is not completed. |
| 1 |  | Seek command completed by DDFDC. |
| STO |  |  |
| 4 |  | E -Equipment Check. |
| 0 |  | No error. |
| 1 |  | Either a fault signal is received from the FDD or the track 0 signal failed to occur after 256 step pulses (Recalibrate Command). |

## STO

$\frac{3}{0}$ NR -Not Ready.

1. FDD is not ready at issue of read or write command. If a read or write command is issued to side 1 of a singlesided drive, this bit is also set.

STO
$\frac{2}{2}$ HD $\quad$ Head Address. (At Interrupt).
$1 \quad$ Head Select 0.
Head Select 1.

STO
$1 \underline{0}$ US -Unit Select. (At Interrupt).
0 FDD 0 selected.
01 FDD 1 selected.
10 FDD 2 selected.
11 FDD 3 selected.
Status Register 1 (ST1)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EN | 0 | DE | OR | 0 | ND | NW | MA |

## ST1

7 EN -End of Track.
No error.
1 DDFDC attempted to access a sector beyond the last sector of a track.

ST1
$6 \quad$-Not Used. Always Zero.
ST1
5 DE -Data Error.
$\overline{0}$ No error.
1 DDFDC detected a CRC error in ID field or the Data field.

ST1
4 OR -Over Run.
$\overline{0} \quad$ No error.
1 DDFDC was not serviced by the system during data transfers, within a predetermined time interval.

ST1
3 $\quad$-Not Used. Always Zero.
ST1
2 ND -No Data.
0 No error.
13 possible errors.

1. DDFDC cannot find sector specified in ID Register during execution of Read Data, Write Deleted Data or Scan commands.
2. DDFDC cannot read ID field without an error during Read ID command.
3. DDFDC cannot find starting sector during execution of Read a Track command.

## ST1

1 NW -Not Writable.
No error.
1 DDFDC detected a write protect signal from FDD during execution of Write Data, Write Deleted Data or Format a Track commands.

## ST1

0 MA $\quad$ Missing Address Mark.
$\mathbf{0}$ No error.
1

1. DDFDC cannot detect the ID Address Mark after encountering the index hole twice.
2. DDFDC cannot detect the Data Address Mark or Deleted Data Address Mark. The MD (Missing Address Mark in Data field) of Status Register 2 is also set.

Status Register 2 (ST2)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | CM | DD | WT | SH | SN | BT | MD |

## ST2

$7 \quad$-Not Used. Always Zero.

## ST2

6 CM -Control Mark.
$\overline{0}$ No error.
1 DDFDC encountered a sector which contained a Deleted Data Address Mark during execution of a Read Data, Read a Track, or Scan command, or the DDFDC encountered a sector which contained a Data Address Mark during execution of a Read Deleted Data command.

## ST2

5 DD -Data Error in Data Field.
0 No error.
1 DDFDC detected a CRC error in the Data field.

## ST2

4 WT -Wrong Track.
No error.
1 Contents of T on the disk is different from that stored in IDR. Bit is related to ND (Bit 2 ) of Status Register 1.

## ST2

3 SH -Scan Equal Hit.
0 No "equal" condition during a scan command.
1 "Equal" condition satisfied during a scan command.

## ST2

2 SN -Scan Not Satisfied.
0 No error.
1 DDFDC cannot find a sector on the track which meets the scan command condition.

## ST2

1 BT —Bad Track.
No error.
Contents of T on the disk is different from that stored in the IDR and $T=F F$. Bit is related to ND (Bit 2) of Status Register 1.

ST2
0 MD —Missing Address Mark in Data Field.
No error.
1 DDFDC cannot find a Data Address Mark or Deleted
Data Address Mark during a data read from the disk.

## Status Register 3 (ST3)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FLT | WP | RDY | TRKO | TS | HD | US1 | USO |

Status Register 3 (ST3) holds the results of the Sense Drive Status command.

## ST3

| $\mathbf{7}$ | FLT |
| :--- | :--- |
| 0 | Fault (FLT) signal from the FDD is low. |
| 1 | Fault (FLT) signal from the FDD is high. |

ST3

$$
\begin{aligned}
& \text { } \frac{6}{0} \quad \text { WP Write Protect }(W P) \text { signal from the FDD is low. }
\end{aligned}
$$

1 Write Protect (WP) signal from the FDD is high.

## ST3

RDY -Ready.
Ready (RDY) signal from the FDD is low.
Ready (RDY) signal from the FDD is high.

```
ST3
    4 TRKO -Track 0.
    0 Track 0 (TRKO) signal from the FDD is low.
    1. Track 0 (TRKO) signal is from the FDD is high.
ST3
    3 TS -Two Side.
    0 Two Side (TS) signal from the FDD is low.
    1 Two Side (TS) signal from the FDD is high.
ST3
    HD -Head Select.
        Head Select (HD) signal to the FDD is low.
        Head Select (HD) signal to the FDD is high.
ST3
    1 US1 -Unit Select 1.
    0}\mathrm{ Unit Select 1 (US1) signal to the FDD is low.
    1 Unit Select 1 (US1) signal to the FDD is high.
ST3
    0 USO -Unit Select 0.
        Unit Select 0 (USO) signal to the FDD is low.
    1 Unit Select 0 (US1) signal to the FDD is high.
```


## COMMAND SEQUENCE

The DDFDC is capable of performing 15 different commands. Each command is initiated by a multi-byte transfer of data from the system. After command execution, the result of the command may be a multi-byte transfer of data back to the system. Because of this multi-byte transfer of information between the DDFDC and the system, each command consists of three phases:

Command Phase-The DDFDC receives all information required to perform a particular operation from the system.

Execution Phase-The DDFDC performs the instructed operation.

Result Phase-After completion of the operation, status and other housekeeping information are made available to the system.

The bytes of data sent to the DDFDC to form a command, and read out of the DDFDC in the result phase, must occur in the order shown for each command sequence. That is, the command Code byte must be sent first followed by the other bytes in the specified sequence. All command bytes must be written and all result bytes must be read in each phase. After the last byte of data in the command phase is received by the DDFDC, the execution phase starts. Similarly, when the last byte of data is read out in the Result Phase, the command is ended and the DDFDC is ready to accept a new command. A command can be terminated by asserting the $\overline{\text { DONE signal to the DDFDC. This }}$ ensures that the processor can always get the DDFDC's attention even if the command in process hangs up in an abnormal manner.

## COMMAND DESCRIPTION

## READ DATA

A command set of nine bytes places the DDFDC into the Read Data mode. After the Read Data command has been received the DDFDC loads the head (if it is unloaded), waits the specified Head Settling Time (defined in the Specify command), then begins reading ID Address Marks and ID fields from the disk. When the current sector number (R) stored in the ID Register (IDR) matches the sector number read from the disk, the DDFDC transfers data from the disk Data field to the data bus.

After completion of the read operation from the current sector, the DDFDC increments the Sector Number (R) by one, and the data from the next sector is read and output to the data bus. This continuous read function is called a "Multi-Sector Read Operation." The Read Command terminates after reading the last data byte from sector $R$ when $R=E O T$. STO bits 7 and 6 are set to 0 and 1 , respectively, and ST1 bit 7 (EN) is set to a 1 .

The Read Data command can also be terminated by a low DONE signal. DONE should be issued at the same time that the DACK for the last byte of data is sent. Upon receipt of TC, the DDFDC stops outputting data to the data bus, but continues to read data from the current sector, checks CRC (Cyclic Redundancy Count) bytes, and then at the end of that sector terminates the Read Data command and sets bits 7 and 6 in STO to 0 . The amount of data which can be handled with a single command to the DDFDC depends upon MT (Multi-Track), MF (MFM/FM), and N (Number of Bytes/Sector) values. Table 3 shows the transfer capacity.

The multi-track function (MT) allows the DDFDC to read data from both sides of the disk. For a particular track, data is transferred starting at sector 1 , side 0 and completed at sector $L$, side 1 (sector $L=$ last sector on the side). This function pertains to only one track (the same track) on each side of the disk.

When $\mathrm{N}=0$ in command byte 6 (FM mode), the Data Length (DTL) in command byte 9 defines the data length that the DDFDC must treat as a sector. If DTL is smaller than the actual data length in a sector, the data beyond the DTL is not sent to the data bus. The DDFDC reads (internally) the complete sector, performs the CRC check, and depending upon the manner of command termination, may perform a multi-sector Read operation. When N is non-zero (MFM mode), DTL has no meaning and should be set to FF.

At the completion of the Read Data command, the head is not unloaded until the Head Unload Time (HUT) interval defined in the Specify command has elapsed. The head settling time may be avoided between subsequent reads if the processor issues another command before the head unloads. This time savings is considerable when disk contents are copied from one drive to another.

If the DDFDC detects the Index Hole twice in succession without finding the right sector (indicated in R), then the DDFDC sets the No Data (ND) flag in Status Register 1 (ST1) to a 1, sets Status Register 0 (STO) bits 7 and 6 to 0 and 1, respectively, and terminates the Read Data command.

After reading the ID and Data fields in each sector, the DDFDC checks the CRC bytes. If a read error is detected (incorrect CRC in ID field), the DDFDC sets the Data Error (DE) flag in ST1 to a 1, sets the Data Error in Data Field (DD) flag in ST2 to a 1 if a CRC error occurs in the Data field, sets bits 7 and 6 in STO to 0 and 1 , respectively, and terminates the command.

If the DDFDC reads a Deleted Data Address Mark from the disk, and the Skip Deleted Data Address Mark bit in the first command byte is not set $(S K=0)$, then the DDFDC reads all the data in the sector, sets the Control Mark (CM) flag in ST2 to a 1 , and terminates the command. If $\mathrm{SK}=1$, the DDFDC skips the sector with the Deleted Data Address Mark and reads the next sector. The CRC bits in the deleted data field are not checked when $\mathrm{SK}=1$.

Table 3. DDFDC Transfer Capacity

| Multi-Track (MT) | MFM/FM (MF) | Bytes/Sector <br> ( N ) | Maximum Transfer Capacity (Bytes/Sector) (Number of Sectors) | Final Sector Read from Disk |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 00 \\ & 01 \end{aligned}$ | $\begin{aligned} & (128)(26)=3,328 \\ & (256)(26)=6,656 \end{aligned}$ | 26 at Side 0 or 26 at Side 1 |
| $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 00 \\ & 01 \end{aligned}$ | $\begin{aligned} & (128)(52)=6,656 \\ & (256)(52)=13,312 \end{aligned}$ | 26 at Side 1 |
| $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{array}{r} 01 \\ .02 \end{array}$ | $\begin{aligned} & (256)(15)=3,840 \\ & (512)(15)=7,680 \end{aligned}$ | 15 at Side 0 or 15 at Side 1 |
| $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 01 \\ & 02 \end{aligned}$ | $\begin{aligned} & (256)(30)=7,680 \\ & (512)(30)=15,360 \end{aligned}$ | 15 at Side 1 |
| $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 02 \\ & 03 \end{aligned}$ | $\begin{aligned} (512)(8) & =4,096 \\ (1024)(8) & =8,192 \end{aligned}$ | 8 at Side 0 or 8 at Side 1 |
| 1 | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 02 \\ & 03 \end{aligned}$ | $\begin{array}{rr} (512)(16) & =8,192 \\ (1024)(16) & =16,384 \\ \hline \end{array}$ | 8 at Side 1 |

During disk data transfers from the DDFDC to the system, the DDFDC must be serviced by the system within $27 \mu$ s in the FM mode, and within $13 \mu \mathrm{~s}$ in the MFM mode, otherwise the DDFDC sets the Over Run (OR) flag in ST1 to a 1, sets bits 7 and 6 in STO to 0 and 1 , respectively, and terminates the command.

If the processor terminates a read (or write) operation in the DDFDC, then the ID information in the result phase is dependent upon the state of the MT bit in the first command byte and the End of Track (EOT) byte. Table 4 shows the values for Track Number (T), Head Number (H), Sector Number (R), and Number of Data Bytes/Sector ( N ), when the processor terminates the command.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| w | 1 | MT | MF | SK | 0 | 0 | 1 | 1 | 0 |
|  | 2 | X | X | X | x | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
|  | 7 | Number of Data Bytes per Sector (N) |

## WRITE DATA

A command set of nine bytes places the DDFDC in the Write Data mode. After the Write Data command has been received the DDFDC loads the head (if it is unloaded), waits the specified Head Settling Time (defined in the Specify command), then begins reading iD fields from the disk. When the four bytes ( $T$, $H, R, N)$ loaded during the command match the four bytes of the ID field from the disk, the DDFDC transfers data from the data bus to the disk Data field.

After writing data into the current sector, the DDFDC increments the sector number ( $R$ ) by one, and writes into the Data field in the next sector. The DDFDC continues this multi-sector write operation until the last byte is written to sector $R$ when $R=E O T$. STO bits 7 and 6 are set to 0 and 1, respectively, and ST1 bit $7(E N)$ is set to a 1.

The command can also be terminated by a low on $\overline{\text { DONE. If }}$ $\overline{\text { DONE }}$ is sent to the DDFDC while writing into the current sector, then the remainder of the Data field is filled with 00 (zeros). In this case, STO bits 7 and 6 are set to 0 and the command is terminated.

The DDFDC reads the ID field of each sector and checks the CRC bytes. If the DDFDC detects a read error (incorrect CRC) in one of the ID fields, it terminates the Write Data command, sets the DE flag in ST1 to a 1, and sets bits 7 and 6 in STO to 0 and 1 , respectively.

The Write Data command operates in much the same manner as the Read Data command. Refer to the Read Data command for the handling of the following items:

- Transfer Capacity
- End of Track (EN) flag
- No Data (ND) flag
- Head Unload Time (HUT) interval
- ID information when the processor terminates command (see Table 4)
- Definition of Data Length (DTL) when $\mathrm{N}=0$ and when $\mathrm{N} \neq 0$

Table 4. DDFDC Command Termination Values

| Command Phase ID |  | Final Sector Transferred to/from Data Bus | Result Phase ID |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Multi- <br> Track (MT) | Head Number (HD) |  | Track Number (T) | Head Number <br> (H) | Sector Number (R) | No. of Data Bytes (N) |
| 0 | 0 | Less than EOT | NC | NC | R + 1 | NC |
|  | 0 | Equal to EOT | T + 1 | NC | 01 | NC |
|  | 1 | Less than EOT | NC | NC | R + 1 | NC |
|  | 1 | Equal to EOT | T + 1 | NC | 01 | NC |
| 1 | 0 | Less than EOT | NC | NC | $R+1$ | NC |
|  | 0 | Equal to EOT | NC | LSB | 01 | NC |
|  | 1 | Less than EOT | NC | NC | R + 1 | NC |
|  | 1 | Equal to EOT | T + 1 | LSB | 01 | NC |
| Notes: <br> 1. NC (No Change): The same value as the one at the beginning of command execution. <br> 2. LSB (Least Significant Bit): The least significant bit of H is complemented. |  |  |  |  |  |  |

In the Write Data mode, data transfers from the data bus to the DDFDC must occur within $27 \mu \mathrm{~s}$ in the FM mode, and within $13 \mu \mathrm{~s}$ in the MFM mode. If the time interval between data transfers is longer than this, then the DDFDC terminates the Write Data command, sets the Over Run (OR) flag in ST1 to a 1, and sets bits 7 and 6 in STO to 0 and 1, respectively.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | 0 | 0 | 0 | 1 | 0 | 1 |
|  | 2 | X | X | x | X | X | HD | US1 | USO |
|  | 3 | Track Number ( $T$ ) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
| 2 | Status Register 1 (ST1) |  |
| 3 | Status Register 2 (ST2) |  |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## WRITE DELETED DATA

The Write Deleted Data command is the same as the Write Data command except a Deleted Data Address Mark is written at the beginning of the Data field instead of the normal Data Address Mark.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| w | 1 | MT | MF | 0 | 0 | 1 | 0 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
|  | 4 | Track Number (T) |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector(N) |  |

## READ DELETED DATA

The Read Deleted Data command is the same as the Read Data command except that if SK $=0$ when the DDFDC detects a Data Address Mark at the beginning of a Data field, it reads all the data in the sector and sets the CM flag in ST2 to a 1, and then terminates the command. If $S K=1$, then the DDFDC skips the sector with the Data Address Mark and reads the next sector.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| w | 1 | MT | MF | SK | 0 | 1 | 1 | 0 | 0 |
|  | 2 | X | X | X | x | X | HD | US1 | Uso |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (ST0) |
| :--- | :--- | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
|  | 7 | Number of Data Bytes per Sector (N) |

## READ A TRACK

The Read a Track command is similar to the Read Data command except that this is a continuous read operation where all Data fields from each of the sectors on a track are read and transferred to the data bus. Immediately after encountering the Index Hole, the DDFDC starts reading the Data fields as continuous blocks of data. This command terminates when the number of sectors read is equal to EOT. Multi-track operations are not allowed with this command.

If the DDFDC finds an error in the ID or Data CRC check bytes, it continues to read data from the track. The DDFDC compares the ID information read from each sector with the value stored in the IDR, and sets the ND flag in ST1 to a 1 if there is no match.

If the DDFDC does not find an ID Address Mark on the disk after it encounters the Index Hole for the second time it terminates the command, sets the Missing Address Mark (MA) flag in ST1 to a 1, and sets bits 7 and 6 of STO to 0 and 1, respectively.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | MF | SK | 0 | 0 | 0 | 1 | 0 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (ST0) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
|  | 7 | Number of Data Bytes per Sector (N) |

## READ ID

The two-byte Read ID command returns the present position of the read/write head. The DDFDC obtains the value from the first ID field it is able to read, sets bits 7 and 6 in STO to 0 and terminates the command.

If no proper ID Address Mark is found on the disk before the Index Hole is encountered for the second time then the Missing Address Mark (MA) flag in ST1 is set to a 1, and if no data is found then the ND flag to a 1 is also set in ST1. Bits 7 and 6 in STO are set to 0 and 1 , respectively and the command is terminated.

During this command there is no data transfer between DDFDC and the data bus except during the result phase.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $W$ | 1 | 0 | MF | 0 | 0 | 1 | 0 | 1 | 0 |
|  | 2 | $X$ | $X$ | $X$ | $X$ | $X$ | HD | US1 | USO |

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :--- | :--- | :--- |
|  | 2 | Status Register 1 (ST1) |
| 3 | Status Register 2 (ST2) |  |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## FORMAT A TRACK

The six-byte Format a Track command formats an entire track. After the Index Hole is detected, data is written on the disk: Gaps, Address Marks, ID fields and Data fields; all are recorded in either the double-density IBM System 34 format ( $M F=1$ ) or the single-density IBM 3740 format ( $M F=0$ ). The particular format written is also controlled by the values of Number of Bytes/Sector (N), Sectors/Track (ST), Gap Length (GPL) and Data Pattern (D) which are supplied by the processor during the command phase. The Data field is filled with the data pattern stored in D.

The ID field for each sector is supplied by the processor in response to four data requests per sector issued by the DDFDC. The type of data request depends upon the Non-DMA flag (ND) in the Specify command. In the DMA mode ( $N D=0$ ), the DDFDC asserts the DMA Request (DRQ) output four times per sector. In the Non-DMA mode (ND = 1), the DDFDC asserts Interrupt Request (IRQ) output four times per sector.

The processor must write one data byte in response to each request, sending (in the consecutive order) the Track Number (T), Head Number (H), Sector Number (R) and Number of Bytes/ Sector ( N ). This allows the disk to be formatted with nonsequential sector numbers, if desired.
The processor must send new values for T, H, R, and $N$ to the DDFDC for each sector on the track. For sequential formatting $R$ is incremented by one after each sector is formatted, thus, $R$ contains the total numbers of sectors formatted when it is read during the result phase. This incrementing and formatting continues for the whole track until the DDFDC, upon encountering the Index Hole for the second time, terminates the command and sets bits 7 and 6 in STO to 0 .

If the Fault (FLT) signal is high from the FDD at the end of a write operation, the DDFDC sets the Equipment Check (EC) flag in STO to a 1, sets bits 7 and 6 of STO to 0 and 1, respectively, and terminates the command. Also, a low (RDY) signal at the beginning of a command execution phase causes bits 7 and 6 of STO to be set to 0 and 1 , respectively.
Table 5 shows the relationship between N, ST, and GPL for various disk and sector sizes.

Table 5. Standard Floppy Disk Sector Size Relationship

| Disk Size | Mode | Sector Size Bytes/Sector | No. of Data Bytes/Sector <br> (N) | No. of Sectors/Tracks (ST) | Gap Length (GPL)4 |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Read/Write Command 1 | Format Command ${ }^{2}$ |  |
| 8' | FM | 128 | 00 | 1A | 07 | 1B | IBM Disk 1 IBM Disk 2 |
|  |  | 256 | 01 | OF | OE | 2 A |  |
|  |  | 512 | 02 | 08 | 1B | 3A |  |
|  |  | 1024 | 03 | 04 | 47 | 8A |  |
|  |  | 2048 | 04 | 02 | C8 | FF- |  |
|  |  | 4096 | 05 | 01 | C8 | FF |  |
|  | MFM ${ }^{3}$ | 256 | 01 | 1A | OE | 36 | IBM Disk 2D IBM Disk 2D |
|  |  | 512 | 02 | OF | 18 | 54 |  |
|  |  | 1024 | 03 | 08 | 35 | 74 |  |
|  |  | 2048 | 04 | 04 | 99 | FF |  |
|  |  | 4096 | 05 | 02 | C8 | FF |  |
|  |  | 8192 | 06 | 01 | C8 | FF |  |
| 51/4" | FM | 128 | 00 | 12 | 07 | 09 |  |
|  |  | 128 | 00 | 10 | 10 | 19 |  |
|  |  | 256 | 01 | 08 | 18 | 30 |  |
|  |  | 512 | 02 | 04 | 46 | 87 |  |
|  |  | 1024 | 03 | 02 | C8 | FF |  |
|  |  | 2048 | 04 | 01 | C8 | FF |  |
|  | MFM ${ }^{3}$ | 256 | 01 | 12 | OA | OC |  |
|  |  | 256 | 01 | 10 | 20 | 32 |  |
|  |  | 512 | 02 | 08 | 2A | 50 |  |
|  |  | 1024 | 03 | 04 | 80 | F0 |  |
|  |  | 2048 | 04 | 02 | C8 | FF |  |
|  |  | 4096 | 05 | 01 | C8 | FF |  |

Notes:

1. Suggested values of GPL in Read or Write commands to avoid overlapping between Data field and ID field of contiguous sections.
2. Suggested values of GPL in Format a Track command.
3. In MFM mode the DDFDC cannot perform a read/write/format operation with 128 bytes/sector ( $\mathrm{N}=00$ ).
4. Values of ST and GPL are in hexadecimal.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | MF | 0 | 0 | 1 | 1 | 0 | 1 |
|  | 2 | x | X | X | X | X | HD | US1- | USO |
|  | 3 | Number of Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 4 | Sectors per Track (ST) |  |  |  |  |  |  |  |
|  | 5 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 6 | Data Pattern (D) |  |  |  |  |  |  |  |

Result Phase:

| R |  |  |  |  |  | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- | :---: | :---: | :---: | :---: | :---: |
|  | 2 | Status Register 1 (ST1) |  |  |  |  |  |
| 3 | Status Register 2 (ST2) |  |  |  |  |  |  |
| 4 | Track Number (T)* |  |  |  |  |  |  |
| 5 | Head Number (H)* |  |  |  |  |  |  |
| 6 | Sector Number (R)* |  |  |  |  |  |  |
|  | 7 | Number of Data Bytes per Sector (N)* |  |  |  |  |  |
| *The ID information has no meaning in this command. |  |  |  |  |  |  |  |

## SCAN COMMANDS

The scan commands compare data read from the disk to data supplied from the data bus. The DDFDC compares the data, and looks for a sector of data which meets the conditions of $D_{F D D}=D_{B U S}, D_{F D D} \leq D_{B U S}$, or $D_{F D D} \geq D_{B U S}(D=$ the data pattern in hexadecimal). A magnitude comparison is performed (FF = largest number, $00=$ smallest number). The hexadecimal byte of FF either from the bus or from FDD can be used as a mask byte because it always meets the condition of the compare. After a whole sector of data is compared, if the conditions are not met, the sector number is incremented $(R+S T P \rightarrow R)$, and the scan operation is continued. The scan operation continues until one of the following events occur: the conditions for scan are met (equal, low or equal, or high or equal), the last sector on the track is reached (EOT), or DONE is received.
1
ilf conditions for scan are met, the DDFDC sets the Scan Hit (SH) flag in ST2 to a 1, and terminates the command. If the conditions for scan are not met between the starting sector (as specified by R) and the last sector on the track (EOT), then the DDFDC sets the Scan Not Satisfied (SN) flag in ST2 to a 1, and terminates the command. The receipt of DONE from the processor or DMA controller during the scan operation will cause the DDFDC to complete the comparison of the particular byte which is in process, and then to terminate the command. Table 6 shows the status of bits SH and SN under various conditions of scan.

Table 6. Scan Status Codes

| Command | Status Register 2 |  | Comments |
| :---: | :---: | :---: | :---: |
|  | Bit $2=$ SN | Bit $3=\mathbf{S H}$ |  |
| Scan Equal | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & D_{\text {FDD }}=D_{\text {Bus }} \\ & D_{\text {FDD }} \neq D_{\text {Bus }} \end{aligned}$ |
| Scan Low or Equal | $\begin{aligned} & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & D_{\text {FDD }}=D_{\text {BUS }} \\ & D_{\text {FDD }}<D_{B B U S} \\ & D_{\text {FDD }}>D_{\text {BUS }} \end{aligned}$ |
| Scan High or Equal | $\begin{aligned} & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & D_{\text {FDD }}=D_{\text {BUS }} \\ & D_{\text {FDD }}>D_{\text {BuU }} \\ & D_{\text {FDD }}<D_{\text {BUS }} \end{aligned}$ |

If SK = 0 and the DDFDC encounters a Deleted Data Address Mark on one of the sectors, it regards that sector as the last sector of the track, sets the Control Mark (CM) bit in ST2 to a 1 and terminates the command. If SK = 1, the DDFDC skips the sector with the Deleted Data Address Mark, sets the CM flag to a 1 in order to show that a Deleted Sector has been encountered, and reads the next sector.

When either the STP sectors are read (contiguous sectors $=01$, or alternate sectors $=02$ ) or MT (Multi-Track) is set, the last sector on the track must be read. For example, if STP $=02$, MT $=0$, the sectors are numbered sequentially 1 through 26 , and the scan command starts reading at sector 21 . Sectors 21, 23, and 25 are read, then the next sector (26) is skipped and the Index Hole is encountered before the EOT value of 26 can be read. This results in an abnormal termination of the command. If the EOT had been set at 25 or the scanning started at sector 20 , then the scan command would be completed in a normal manner.

During a scan command data is supplied from the data bus for comparison against the data read from the disk. In order to avoid having the Over Run (OR) flag set in ST1, data must be available from the data bus in less than $27 \mu \mathrm{~S}$ (FM mode) or $13 \mu \mathrm{~S}$ (MFM mode). If an OR occurs, the DDFDC terminates the command and sets bits 7 and 6 of STO to 0 and 1, respectively.

The following tables specify the command bytes and describe the result bytes for the three scan commands.

## SCAN EQUAL

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 1 | 0 | 0 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Sector Test Process (STP) |  |  |  |  |  |  |  |

Result Phase:

| R | 1 | Status Register 0 (ST0) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
|  | Track Number (T) |  |
|  | Head Number (H) |  |
| 6 | Sector Number (R) |  |
|  | 7 | Number of Data Bytes per Sector (N) |

## SCAN LOW OR EQUAL

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| w | 1 | MT | MF | SK | 1 | 1 | 0 | 0 | 1 |
|  | 2 | X | X | X | x | X | HD' | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Sector Test Process (STP) |  |  |  |  |  |  |  |

Result Phase:

| $R$ | 1 | Status Register 0 (ST0) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
| 3 | Status Register 2 (ST2) |  |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## SCAN HIGH OR EQUAL

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 1 | 1 | 1 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Sector Test Process (STP) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (ST0) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
|  | 4 | Track Number (T) |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## SEEK

The three-byte Seek command steps the FDD read/write head from track to track. The DDFDC has two independent Present Track Registers for each drive. They are cleared only by the Recalibrate command. The DDFDC compares the Present Track Number (PTN) which is the current head position with the New Track Number (NTN), and if there is a difference, performs the following operation:

> If PTN < NTN: Sets the direction output (LCT/DIR) high and issues step pulses (FR/STP) to the FDD to cause the read/write head to step in.

The rate at which step pulses are issued is controlled by the Step Rate Time (SRT) in the Specify command. After each step pulse is issued, NTN is compared against PTN. When NTN = PTN, then the Seek End (SE) flag in STO is set to a 1, bits 7 and 6 in STO are set to 0 , and the command is terminated. At this point DDFDC asserts $\overline{\mathrm{RQ}}$.

The FDD Busy flag (bit 0-3) in the Main Status Register (MSR) corresponding to the FDD performing the Seek operation is set to a 1.

After command termination, all FDD Busy bits set are cleared by the Sense Interrupt Status command.

During the command phase of the Seek operation the DDFDC sets the Controller Busy (CB) flag in the MSR to 1; but during the execution phase the CB flag is set to 0 to indicate DDFDC non-busy. While the DDFDC is in the non-busy state, another Seek command may be issued, and in this manner parallel seek operations may be performed on all drives at once.

No command other than Seek will be accepted while the DDFDC is sending step pulses to any FDD. If a different command type is attempted, the DDFDC will set bits 7 and 6 in STO to a 1 and 0 , respectively, to indicate an invalid command.

If the FDD is in a not ready state at the beginning of the command execution phase or during the seek operation, then the DDFDC sets the Not Ready (NR) flag in ST0 to a 1, sets STO bits 7 and 6 to 0 and 1, respectively, and terminates the command.

If the time to write the three bytes of the Seek command exceeds $150 \mu \mathrm{~s}$, the time between the first two step pulses may be shorter than the Step Rate Time (SRT) defined by the Specify command by as much as 1 ms .

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | 2 | X | X | X | X | X | 0 | US1 | USO |
|  | 3 | New Track Number (NTN) |  |  |  |  |  |  |  |

Result Phase: None.

## RECALIBRATE

This two-byte command retracts the FDD read/write head to the Track 0 position. The DDFDC clears the contents of the PTN counters, and checks the status of the Track 0 signal from the FDD. As long as the Track 0 signal (TRKO) is low, the direction signal (LCT/DIR) output remains low and step pulses are issued on FR/STP. When TRKO goes high the DDFDC sets the Seek End (SE) flag in STO to a 1 and terminates the command. If the TRKO is still low after 256 step pulses have been issued, the DDFDC sets Seek End (SE) and Equipment Check (EC) flags in STO to 1s, sets bits 7 and 6 of STO to 0 and 1, respectively, and terminates the command.

The ability to do overlap Recalibrate commands to multiple FDDs and the loss of the RDY signal, as described in the Seek command, also applies to the Recalibrate command.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
|  | 2 | $X$ | $X$ | $X$ | $X$ | $X$ | 0 | US1 | USO |

Result Phase: None.

## SENSE INTERRUPT STATUS

Interrupt request ( $\overline{\mathrm{IRQ}}$ ) is asserted by the DDFDC when any of the following conditions occur:

1. Upon entering the result phase of:
a. Read Data command
b. Read a Track command
c. Read ID command
d. Read Deleted Data command
e. Write Data command
f. Format a Track command
g. Write Deleted Data command
h. Scan commands
2. Ready (RDY) line from the FDD changes state
3. Seek or Recalibrate command termination
4. During execution phase in the Non-DMA mode
$\overline{\text { IRQ }}$ caused by reasons 1 and 4 above occur during normal command operations and are easily discernible by the processor. During an execution phase in Non-DMA mode, bit 5 in the MSR is set to 1 . Upon entering result phase this bit is set to 0 . Reasons 1 and 4 do not require the Sense Interrupt Status command. The interrupt is cleared by reading or writing data to DDFDC. Interrupts caused by reasons 2 and 3 are identified with the aid of the Sense Interrupt Status command. This command resets $\overline{\mathrm{RQ}}$ and sets/resets bits 5,6 , and 7 of STO to identify the cause of the interrupt. Table 7 definss the seek and interrupt codes.

Neither the Seek or Recalibrate command has a result phase. Therefore, it is mandatory to use the Sense Interrupt Status command after these commands to effectively terminate them and to verify where the head is positioned by checking the Present Track Number (PTN).

Issuing a Sense Interrupt Status command without an interrupt pending is treated as an invalid command.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |

Result Phase:

| $R$ | 1 | Status Register 0 (STO) |
| :--- | :--- | :--- |
|  | 2 | Present Track Number (PTN) |

## SPECIFY

The three-byte Specify command sets the initial values for each of the three internal timers. The Head Unload Time (HUT) defines the time from the end of the execution phase of one of the read/write commands to the head unload state. This timer is programmable from 16 to 240 ms in increments of 16 ms ( $1=16 \mathrm{~ms}, 2=32 \mathrm{~ms}, \ldots \mathrm{~F}=240 \mathrm{~ms}$ ).

The Step Rate Time (SRT) defines the time interval between adjacent step pulses. This timer is programmable from 1 to 16 ms in increments of $1 \mathrm{~ms}(F=1 \mathrm{~ms}, E=2 \mathrm{~ms}, \mathrm{D}=3 \mathrm{~ms}, \ldots$. $0=16 \mathrm{~ms}$ ).

The Head Load Time (HLT) defines the time between the Head Load (HDL) signal going high and the start of the read/write operation. This timer is programmable from 2 to 254 ms in increments of $2 \mathrm{~ms}(01=2 \mathrm{~ms}, 02=4 \mathrm{~ms}, 03=6 \mathrm{~ms}, \ldots$ $7 \mathrm{~F}=254 \mathrm{~ms})$.

The time intervals are a direct function of the clock (CLK on pin 19). Times indicated above are for an 8 MHz clock. If the clock is reduced to 4 MHz (mini-floppy application) then all time intervals are increased by a factor of two.

The choice of DMA or Non-DMA operation is made by the NonDMA mode (ND) bit. When this bit = 1 the Non-DMA mode is selected, and when ND $=0$ the DMA mode is selected.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
|  | 2 | SRT |  |  |  | HUT |  |  |  |
|  | 3 | HLT |  |  |  |  |  |  | ND |

SRT - Step Rate Time
HUT - Head Unload Time
HLT - Head Load Time
ND - Non-DMA mode
Result Phase: None.

## SENSE DRIVE STATUS

This two-byte command obtains and reports the status of the FDDs. Status Register 3 (ST3) is returned in the result phase and contains the drive status.

Table 7. STO Seek and Interrupt Code Definition for Sense Interrupt Status

| Status Register $\mathbf{0}$ (STO) Bits |  |  |
| :--- | :---: | :---: |
|  |  |  |
|  | Interrupt Code (IC) |  | Seek End (SE) |
|  |  |  |
|  | 6 | 5 |
| Cause |  |  |
| 1 | 1 | 0 |
| RDY line changed state, either polarity |  |  |
| 0 | 0 | 1 |

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $W$ | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
|  | 2 | $X$ | $X$ | $X$ | $X$ | $X$ | $H D$ | US1 | USO |

## Result Phase:

| $\mathbf{R}$ | 1 | Status Register 3 (ST3) |
| :--- | :--- | :--- |

## INVALID COMMAND

If an invalid command (i.e., a command not previously defined) is received by the DDFDC, then the DDFDC terminates the command after setting bits 7 and 6 of STO to 1 and 0 , respectively. The DDFDC does not generate an interrupt during this condition. Bits 6 and 7 (DIO and RQM) in the MSR are both set to a 1 indicating to the processor that the DDFDC is in the result phase and that STO must be read. A hex 80 in STO indicates an invalid command was received.

A Sense Interrupt Status command must be sent after a Seek or Recalibrate interrupt, otherwise the DDFDC considers the next command to be an invalid command.

In some applications the user may wish to use this command as a No-Op command, to place the DDFDC in a standby or no operation state.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | Invalid Codes |  |  |  |  |  |  |  |

## Result Phase:

| $\mathbf{R}$ | 1 | Status Register $0(\mathrm{STO})=80$ |
| :--- | :--- | :--- |

## PROCESSOR INTERFACE

During the command or result phases, the Main Status Register (MSR) must be read by the processor before each byte of information is transferred to, or from, the DDFDC Data Register. After each byte of data is written to, or read from, the Data Register, the processor should wait $12 \mu \mathrm{~s}$ before reading the MSR. Bits 6 and 7 in the MSR must be a 0 and 1 , respectively, before each command byte can be written to the DDFDC. During the result phase, bits 6 and 7 of the MSR must both be 1s prior to reading each byte from the Data Register onto the data bus. Note that this status reading of bits 6 and 7 of the MSR before each byte transfer to and from the DDFDC is required in only the command and result phases and not during the execution phase.

During the result phase all bytes shown in the result phase must be read by the processor. The Read Data command, for example, has seven bytes of data in the result phase. All seven

Bytes must be read to successfully complete the Read Data command. The DDFDC will not accept a new command until all seven bytes have been read. Other commands may require fewer bytes to bo read during the result phase.

## INTERRUPT REQUEST MODE

During the execution phase, the MSR need not be read. The receipt of each data byte from the FDD is indicated by IRQ low on pin 18. When the DDFDC is in Non-DMA mode, $\overline{\mathrm{IRQ}}$ is asserted during the execution phase. When the DDFDC is in the DMA mode, $\overline{\mathrm{IRQ}}$ is asserted at the result phase. The $\overline{\mathrm{IRQ}}$ signal is reset by a read ( $\mathrm{R} \overline{\bar{W}}$ high) or write ( $\mathrm{R} / \bar{W}$ low) of data to the DDFDC. A further explanation of the $\overline{\mathrm{RQ}}$ signal is described in the Sense Interrupt Status command on page 16. If the system cannot handle interrupts fast enough (within $13 \mu \mathrm{~S}$ for MFM mode or $27 \mu$ s for FM mode), it should poll bit 7 (RQM) in the MSR. In this case, RQM in the MSR functions as an Interrupt Request ( $\overline{\mathrm{RQQ}}$ ). If the RQM bit is not set, the Over Run (OR) flag in ST1 will be set to a 1 and bits 7 and 6 of ST0 will be set to a 0 and 1 , respectively.

## DMA MODE

When the DDFDC is in the DMA mode (ND = 0 in the third command byte of the Specify command), DRQ (DMA Request) is asserted during the execution phase (rather than $\overline{\mathrm{RQ}}$ ) to request the transfer of a data byte between the data bus and the DDFDC.

During a read command, the DDFDC asserts $\overline{\mathrm{REQ}}$ as each byte of data is available to be read. The DMA controller responds to this request with both $\overline{\text { DACK }}$ Iow (DMA Acknowledge) and R $\bar{W}$ high (read). When DACK goes low the DMA Request is reset (REQ high). After the execution phase has been completed $\overline{\text { DONE }}$ low or the EOT sector is read), $\overline{\mathrm{IRQ}}$ is asserted to indicate the beginning of the result phase. When the first byte of data is read during the result phase, $\overline{\operatorname{RQ}}$ is reset high.

During a write command, the DDFDC asserts $\overline{\mathrm{REQ}}$ as each byte of data is required. The DMA controller responds to this request with $\overline{\text { DACK }}$ low (DMA Acknowledge) and R $\bar{W}$ low (write). When $\overline{D A C K}$ goes low the DMA Request is reset ( $\overline{R E Q}$ high). After the execution phase has been completed (DONE low or the EOT sector is written), $\overline{\mathrm{IRQ}}$ is asserted. This signals the beginning of the result phase. When the first byte of data is read during the result phase, the $\overline{\mathrm{RQ}}$ is reset high.

## FDD POLLING

After the Specify command has been received by the DDFDC, the Unit Select lines (US0 and US1) begin the polling mode. Between commands (and between step pulses in the Seek Command) the DDFDC polls all the FDD's looking for a change in the RDY line from any of the drives. If the RDY line changes state (usually due to the door opening or closing) then the DDFDC asserts IRQ. When Status Register 0 (STO) is read (after Sense Interrupt Status command is issued), Not Ready (NR = 1) will be indicated. The polling of the RDY line by the DDFDC occurs continuously between commands, thus notifying the processor which drives are on- or off-line. Each drive is polled every 1.024 ms except during read/write commands.


Figure 3. DDFDC and System Data Transfer Timing


CLK


Figure 5. Clock Timing


Figure 6. DDFDC Read Cycle Timing


Figure 7. DDFDC Write Cycle Timing


Figure 8. DMA Operation Timing


Figure 9. FDD Write Operation Timing


NOTE:
EITHER POLARITY DATA WINDOW IS VALID

Figure 10. FDD Read Operation Timing


Figure 11. Seek Operation Timing


Figure 12. Fault Reset Timing


Figure 14. Terminal Count Timing


Figure 13. Index Timing


Figure 15. Reset Timing


INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC " 1 " AND 0.45 V FOR A LOGIC " 0 :" TIMING MEASUREMENTS ARE MADE AT 2.0V FOR A LOGIC " 1 " AND $0.8 V$ FOR A LOGIC " 0 :"


CLOCKS ARE DRIVEN AT 3.0V FOR A LOGIC " 1 " AND 0.3V FOR A LOGIC ' 0 :" TIMING MEASUREMENTS ARE MADE AT 2.4V FOR A LOGIC " 1 " AND $0.65 V$ FOR A LOGIC " 0 ."

Figure 16. AC Timing Measurement Conditions

## AC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Ref. Fig. | No. | Characteristic |  |  | Symbol | Alt. Sym. | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 5 | 1 | Clock Period |  |  | $\mathrm{t}_{\mathrm{CY}}$ | $\phi_{C Y}$ | 120 | 125 | 500 | ns | CLK $=8 \mathrm{MHz}$ |
|  | 2 | Clock High, Low Width |  |  | $\mathrm{t}_{\text {CA }}$ | $\phi_{0}$ | 40 | 62.5 | - | ns |  |
|  | 3 | Clock Rise Time |  |  | $\mathrm{t}_{\mathrm{CLCH}}$ | $\phi_{r}$ | - | - | 20 | ns |  |
|  | 4 | Clock Fall Time |  |  | $\mathrm{t}_{\mathrm{CHCL}}$ | $\phi_{f}$ | - | - | 20 | ns |  |
| $\begin{gathered} 6 \\ \text { and } \\ 7 \end{gathered}$ | 5 | $\overline{\mathrm{CS}}$ High to R/్̄W High |  |  | $\mathrm{t}_{\text {SHRH }}$ | $\mathrm{t}_{\text {SR }}$ | 40 | - | - | ns |  |
|  | 6 | Address Valid to $\overline{\mathrm{CS}}$ Low |  |  | $\mathrm{t}_{\text {AVSL }}$ | $t_{\text {RA }}$ | 0 | - | - | ns |  |
|  | 7 | $\overline{\mathrm{CS}}$ High to Address Invalid |  |  | $\mathrm{t}_{\text {SHAX }}$ | $\mathrm{t}_{\text {AH }}$ | 0 | - | - | ns |  |
|  | 8 | $\overline{\text { CS High }}$ |  |  | $\mathrm{t}_{\text {SHSL }}$ | ${ }_{\text {t }}{ }_{\text {SH }}$ | 150 | - | - | ns |  |
|  | 9 | $\overline{\text { DTACK }}$ Low to Data Valid |  |  | tolov | $\mathrm{t}_{\text {RD }}$ | - | - | 90 | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
|  | 10 | $\overline{\text { CS }}$ High to Output High Z |  |  | $\mathrm{t}_{\text {SHDZ }}$ | $\mathrm{t}_{\mathrm{DF}}$ | 20 | - | - | ns | $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$ |
|  | 11 | $\overline{\text { CS }}$ High to DTACK High |  |  | ${ }^{\text {SHDH }}$ | $\mathrm{t}_{\text {DTK }}$ | - | - | 120 | ns |  |
|  | 12 | Address Valid to R $\bar{W}$ Low |  |  | $\mathrm{t}_{\text {AVRL }}$ | ${ }^{\text {tws }}$ | 20 | - | - | ns |  |
|  | 13 | R/ $\bar{W}$ Low to $\overline{\mathrm{CS}}$ Low |  |  | $\mathrm{t}_{\text {RLSL }}$ | ${ }_{\text {wh }}$ | 80 | - | - | ns |  |
|  | 14 | $\overline{\text { CS }}$ Low Pulse Width |  |  | $\mathrm{t}_{\text {SLSH }}$ | $\mathrm{t}_{\text {SL }}$ | 250 | - | - | ns |  |
|  | 15 | Data Valid to CSS High |  |  | $\mathrm{t}_{\text {DVSH }}$ | tosu | 150 | - | - | ns |  |
|  | 16 | $\overline{\text { CS }}$ High to Data Invalid |  |  | $\mathrm{t}_{\text {SHDZ }}$ | $\mathrm{t}_{\text {DHW }}$ | 5 | - | - | ns |  |
| 8 | 17 | $\overline{\mathrm{IRQ}}$ Delay from $\overline{\mathrm{CS}}$ High |  |  | tILSH | $\mathrm{t}_{\mathrm{IR} \mathrm{Q}}$ | - | - | 500 | $\mu \mathrm{S}$ | CLK $=8 \mathrm{MHz}$ |
|  | 18 | TXRQ Cycle Period |  |  | ${ }_{\text {tacy }}$ | ${ }_{\text {t }}^{\text {TCY }}$ ( | 13 | - | - | ns |  |
|  | 19 | $\overline{\text { ACK }}$ Low to TXRQ Low |  |  | $\mathrm{t}_{\text {AKTH }}$ | $\mathrm{t}_{\text {ACK }}$ | - | - | 200 | ${ }_{\text {t }}$ |  |
|  | 20 | DONE Low Width |  |  | $\mathrm{t}_{\text {NLNH }}$ | toone | 1 | - | - | ns |  |
| 9 | 21 | WCK Cycle Time |  |  | $\mathrm{t}_{\mathrm{KCY}}$ | $\mathrm{t}_{\mathrm{Cr}}$ | - | note 1 | - | $\mu \mathrm{S}$ |  |
|  | 22 | WCK High Width |  |  | $\mathrm{t}_{\text {KHKL }}$ | $\mathrm{t}_{0}$ | 80 | 250 | 350 | ns |  |
|  | 23 | WCK Rise Time |  |  | $\mathrm{t}_{\text {KLKH }}$ | $\mathrm{t}_{\mathrm{r}}$ | - | - | 20 | ns |  |
|  | 24 | WCK Fall Time |  |  | $\mathrm{t}_{\text {KHKL }}$ | $t_{f}$ | - | - | 20 | ns |  |
|  | 25 | WCK High to PSO, PS1 Valid (Delay) |  |  | $\mathrm{t}_{\text {KHPV }}$ | $\mathrm{t}_{\mathrm{CP}}$ | 20 | - | 100 | ns |  |
|  | 26 | PS0, PS1 Valid to WDA High (Delay) |  |  | $\mathrm{t}_{\text {PVDH }}$ | $t_{C D}$ | 20 | - | 100 | ns |  |
|  | 27 | WDA High Width |  |  | $\mathrm{t}_{\text {DHDL }}$ | ${ }_{\text {twod }}$ | $\mathrm{t}_{\text {WCH }}-50$ | - | - | ns |  |
|  | 28 | WE High to WCK High or WE Low to WCK Low |  |  | $\mathrm{t}_{\text {EHKH }}$ | $t_{\text {We }}$ | 20 | - | 100 | ns |  |
| 10 | 30 | RDW Cycle Time |  |  | ${ }_{\text {twCy }}$ | ${ }_{\text {w }}$ | - | note 2 | - | $\mu \mathrm{S}$ |  |
|  | 31 | RDW Valid to RDD High (Setup) |  |  | $\mathrm{t}_{\text {WVRH }}$ | ${ }_{\text {Who }}$ | 15 | - | - | ns |  |
|  | 32 | RDD Low to RDW Invalid (Hold) |  |  | $\mathrm{t}_{\text {RLWI }}$ | $\mathrm{t}_{\text {Row }}$ | 15 | - | - | ns |  |
|  | 33 | RDD High Width |  |  | $\mathrm{t}_{\text {RHRL }}$ | $\mathrm{t}_{\text {RDD }}$ | 40 | - | - | ns |  |
| 11 | 35 | USO, US1 Valid to SEEK High (Setup) |  |  | tuvsh | tus | 12 | - | - | $\mu \mathrm{S}$ | CLK $=8 \mathrm{MHz}$ |
|  | 36 | SEEK Low to USO, US1 Invalid (Hold) |  |  | $\mathrm{t}_{\text {SLUI }}$ | $\mathrm{t}_{\text {Su }}$ | 15 | - | - | $\mu \mathrm{S}$ |  |
|  | 37 | SEEK High to DIR Valid (Setup) |  |  | $\mathrm{t}_{\text {SHDV }}$ | $\mathrm{t}_{\text {SD }}$ | 7 | - | - | $\mu \mathrm{S}$ |  |
|  | 38 | DIR Invalid to SEEK Low (Hold) |  |  | $\mathrm{t}_{\text {DXSL }}$ | $t_{\text {dS }}$ | 30 | - | - | $\mu \mathrm{S}$ |  |
|  | 39 | DIR Valid to STP High (Setup) |  |  | $\mathrm{t}_{\text {DVTH }}$ | $\mathrm{t}_{\text {DST }}$ | 1 | - | - | $\mu \mathrm{S}$ |  |
|  | 40 | STP Low to DIR Invalid (Hold) |  |  | $\mathrm{t}_{\text {TLDX }}$ | $\mathrm{t}_{\text {STD }}$ | 24 | - | - | $\mu \mathrm{S}$ |  |
|  | 41 | STP Low to USO, US1 Invalid (Hold) |  |  | $\mathrm{t}_{\text {tux }}$ | $\mathrm{t}_{\text {STU }}$ | 5 | - | - | $\mu \mathrm{S}$ |  |
|  | 42 | STP High Width |  |  | $\mathrm{t}_{\text {THTL }}$ | $\mathrm{t}_{\text {STP }}$ | 6 | 7 | - | $\mu \mathrm{S}$ |  |
|  | 43 | STP Cycle Time |  |  | $\mathrm{t}_{\text {TCY }}$ | $\mathrm{t}_{\text {SC }}$ | $33^{3}$ | - | note 3 | $\mu \mathrm{S}$ |  |
| 12 | 44 | FR High Width |  |  | $\mathrm{t}_{\text {FHFL }}$ | $\mathrm{t}_{\mathrm{FR}}$ | 8 | - | 10 | $\mu \mathrm{S}$ |  |
| 13 | 45 | IDX High Width |  |  | $\mathrm{t}_{\mathrm{H}}^{\mathrm{HIL}}$ | $\mathrm{t}_{10 \mathrm{D}}$ | 10 | - | - | $\mathrm{t}_{\mathrm{Cr}}$ |  |
| 14 | 46 | DONE Low Width |  |  | $\mathrm{t}_{\text {THTL }}$ | ${ }_{\text {t }}$ | 1 | - | - | $\mathrm{t}_{\mathrm{Cr}}$ |  |
| 15 | 47 | $\overline{\text { RESET }}$ Low Width |  |  | $\mathrm{t}_{\text {RHRL }}$ | $\mathrm{t}_{\text {RST }}$ | 14 | - | - | $t_{\text {cr }}$ |  |
| Notes: |  |  |  |  |  |  |  |  |  |  |  |
| 1. |  | MFM | Mini | Standard | For MFM $=1$ : Typ. $=1 \mu \mathrm{~S}$ <br> 3. $\mathrm{t}_{\mathrm{SC}}=33 \mu \mathrm{~s} \mathrm{~min}$. is for diffe |  |  |  |  |  |  |
|  |  | 0 | $4 \mu \mathrm{~s}$ | $2 \mu \mathrm{~S}$ |  |  |  | nt drive | In the | se of | he same unit, |
|  |  | 1 | $2 \mu \mathrm{~S}$ | $1 \mu \mathrm{~S}$ | ${ }_{\mathrm{s}} \mathrm{CC}$ can be ranged from 1 ms to 16 ms with 8 MHz clock period, and 2 ms to 32 ms with 4 MHz clock, under software control. |  |  |  |  |  |  |

## ABSOLUTE MAXIMUM RATINGS*

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

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

## OPERATING CONDITIONS

| Parameter | Range |
| :---: | :---: |
| $\mathrm{V}_{\text {CC }}$ Power Supply | $5.0 \mathrm{~V} \pm 5 \%$ |
| Operating Temperature | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input Low Voltage Logic CLK and WCK | $\mathrm{V}_{\mathrm{IL}}$ | $\begin{aligned} & -0.5 \\ & -0.5 \end{aligned}$ | $\begin{gathered} 0.8 \\ 0.65 \end{gathered}$ | V |  |
| Input High Voltage Logic CLK and WCK | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{aligned} & 2.0 \\ & 2.4 \end{aligned}$ | $\begin{aligned} & v_{c c}+0.5 \\ & v_{c c}+0.5 \end{aligned}$ | V |  |
| Output Low Voltage | $\mathrm{V}_{\text {OL }}$ |  | 0.45 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | $\mathrm{V}_{\mathrm{cc}}$ | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| Vcc Supply Current | $\mathrm{I}_{\mathrm{Cc}}$ |  | 150 | mA | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Load Current | $1 / 1$ |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ |
| All Inputs |  |  | -10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ |
| High Level Output Leakage Current | $\mathrm{I}_{\mathrm{LOH}}$ |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{OV} \text { to } 5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| Low Level Output Leakage Current | $\mathrm{I}_{\text {LOL }}$ |  | -10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{OV} \text { to } 5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OUT}}=+0.45 \mathrm{~V} \end{aligned}$ |
| Internal Power Dissipation | $\mathrm{P}_{\text {INT }}$ | - | 1.0 | W | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |

## CAPACITANCE

( $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz} ; \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}$ )

| Parameter | Symbol | Max Limit | Unit |
| :--- | :---: | :---: | :---: |
| Clock Input | $\mathrm{C}_{\text {IN(0) }}$ | 20 | pF |
| Input | $\mathrm{C}_{\text {IN }}$ | 10 | pF |
| Output | $\mathrm{C}_{\text {OUT }}$ | 20 | pF |

Note: All pins except pin under test tied to ground.

## PACKAGE DIMENSIONS

40-PIN CERAMIC DIP


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

## 40-PIN PLASTIC DIP



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

# R68560, R68561 MULTI-PROTOCOL COMMUNICATIONS CONTROLLER (MPCC) 

## PRELIMINARY

## DESCRIPTION

The R68560, R68561 Multi-Protocol Communications Controller (MPCC) interfaces a single serial communications channel to a 68008/68000 microcomputer-based system using either asynchronous or synchronous protocol. High speed bit rate, automatic formatting, low overhead programming, eight character buffering, two channel DMA interface and three separate interrupt vector numbers optimize MPCC performance to take full advantage of the $68008 / 68000$ processing capabilities and asynchronous bus structure.

In synchronous operation, the MPCC supports bit-oriented protocols (BOP), such as SDLC/HDLC, and character-oriented protocols (COP), such as IBM Bisync (BSC) in either ASCII or EBCDIC coding. Formatting, synchronizing, validation and error detection is performed automatically in accordance with protocol requirements and selected options. Asynchronous (ASYNC) and isochronous (ISOC) modes are also supported. In addition, modem interface handshake signals are available for general use.

Control, status and data are transferred between the MPCC and the microcomputer bus via 22 directly addressable registers and a DMA interface. Two first-in first-out (FIFO) registers, addressable through separate receiver and transmitter data registers, each buffer up to eight characters at a time to allow more MPU processing time to service data received or to be transmitted and to maximize bus throughput, especially during DMA operation. The two-channel Direct Memory Access (DMA) interface operates with the MC68440/MC68450 DMA Controllers. Three prioritized interrupt vector numbers separately support receiver, transmitter and modem interface operation.

An on-chip oscillator drives the internal baud rate generator (BRG) and an external clock output with an 8 MHz input crystal or clock frequency. The BRG, in conjunction with two selectable prescalers and 16-bit programmable divisor, provides a data bit rate of DC to 4 MHz .

The 48-pin R68561 supports word-length (16-bit) operation when connected to the 68000 16-bit asynchronous bus, as well as bytelength (8-bit) operation when connected to the 680088 -bit bus. The 40-pin R68560 supports byte-length operation on the 68008 bus.

## FEATURES

- Full duplex synchronous/asynchronous receiver and transmitter
- Fully implements IBM Binary Synchronous Communications (BSC) in two coding formats: ASCII and EBCDIC
- Supports other synchronous character-oriented protocols (COP), such as six-bit BSC, X3.28, ISO IS1745, ECMA-16, etc.
- Supports synchronous bit-oriented protocols (BOP), such as SDLC, HDLC, X.25, etc.
- Asynchronous and isochronous modes
- Modem handshake interface
- High speed serial data rate (DC to 4 MHz )
- Internal oscillator and Baud Rate Generator (BRG) with programmable data rate
- Crystal or TTL level clock input and buffered clock output ( 8 MHz )
- Direct interface to 68008/68000 asynchronous bus
- Eight-character receiver and transmitter buffer registers
- 22 directly addressable registers for flexible option selection, complete status reporting, and data transfer
- Three separate programmable interrupt vector numbers for receiver, transmitter and serial interface
- Maskable interrupt conditions for receiver, transmitter and serial interface
- Programmable microprocessor bus data transfer: polled, interrupt and two-channel DMA transfer compatible with MC68440/MC68450
- Clock control register for receiver clock divisor and receiver and transmitter clock routing
- Selectable full/half duplex, autoecho and local loop-back modes
- Selectable parity (enable, odd, even) and CRC (control field enable, CRC-16, CCITT V.41,, VRC/LRC)


## ORDERING INFORMATION




## NOTES:

1. R68560 ONLY.
2. R68561 ONLY.
3. UDS ON R68561 A0 ON R68560
4. $\overline{L D S}$ ON R68561 $\overline{\text { DS }}$ ON R68560

Figure 1. MPCC Block Diagram

## PIN DESCRIPTION

Throughout the document, signals are presented using the terms active and inactive or asserted and negated independent of whether the signal is active in the high-voltage state or lowvoltage state. (The active state of each logic pin is described below.) Active low signals are denoted by a superscript bar. R/W indicates a write is active low and a read active high.

Note: The R68561 interface is described for word mode operation only and the R68560 interface is described for byte mode operation only.

A1-A4-Address Lines. A1-A4 are active high inputs used in conjunction with the $\overline{\mathrm{CS}}$ input to access the internal registers. The address map for these registers is shown in Table 1.

D0 - D15-Data Lines. The bidirectional data lines transfer data between the MPCC and the MPU, memory or other peripheral device. D0 - D15 are used when connected to the 16 -bit 68000 bus and operating in the MPCC word mode. D0 - D7 are used when connected to the 16 -bit 68000 bus or the 8 -bit 68008 bus and operating in the MPCC byte mode. The data bus is threestated when $\overline{\mathrm{CS}}$ is inactive. (See exceptions in DMA mode.)
$\overline{\mathbf{C S}}$-Chip Select. $\overline{\mathrm{CS}}$ low selects the MPCC for programmed transfers with the host. The MPCC is deselected when the CS input is inactive in non-DMA mode. $\overline{\mathrm{CS}}$ must be decoded from the address bus and gated with address strobe ( $\overline{\mathrm{AS}})$.
$\mathbf{R} / \bar{W}$-Read/Write. $R / \bar{W}$ controls the direction of data flow through the bidirectional data bus by indicating that the current bus cycle is a read (high) or write (low) cycle.

DTACK—Data Transfer Acknowledge. $\overline{\text { DTACK }}$ is an active low output that signals the completion of the bus cycle. During read or interrupt acknowledge cycles, DTACK is asserted by the MPCC after data has been provided on the data bus; during
write cycles it is asserted after data has been accepted at the data bus. DTACK is driven high after assertion prior to being tri-stated. A holding resistor is required to maintain DTACK high between bus cycles.
$\overline{\mathrm{DS}}$-Data Strobe (R68560). During a write (R $\bar{W}$ low), the $\overline{\mathrm{DS}}$ positive transition latches data on data bus lines D0-D7 into the MPCC. During a read (R/W high), $\overline{D S}$ low enables data from the MPCC to data bus lines DO-D7.

LDS—Lower Data Strobe (R68561). During a write (R/W low), the positive transition latches data on the data bus lines D0-D7 (and on D8 - D15 if UDS is low) into the MPCC. During a read ( $R / \bar{W}$ high), $\overline{\text { LDS }}$ low enables data from the MPCC to D0-D7 (and to D8-D15 if $\overline{U D S}$ is low).

AO-Address Line A0 (R68560). When interfacing to an 8-bit data bus system such as the 68008, address line AO is used to access an internal register. $A 0=0$ defines an even register and $A O=1$ defines an odd register. See Table 1b.

UDS-Upper Data Strobe (R68561). When interfacing to a 16 -bit data bus system such as the 68000, a low on control bus signal UDS enables access to the upper data byte on D8 - D15. A high on UDS disables access to D8 - D15. Data is latched and enabled in conjunction with LDS.

IRQ-Interrupt Request. The active low $\overline{\mathrm{IRQ}}$ output requests interrupt service by the MPU. $\overline{\mathrm{RQ}}$ is driven high after assertion prior to being tri-stated.
$\overline{\text { IACK }}$-Interrupt Acknowledge. The active low $\overline{\text { IACK }}$ input indicates that the current bus cycle is an interrupt acknowledge cycle. When IACK is asserted the MPCC places an interrupt vector on the lower byte ( $\mathrm{D} 0-\mathrm{D} 7$ ) of the data bus.

TDSR-Transmitter Data Service Request. When Transmitter DMA mode is active, the low TDSR output requests DMA service.


Figure 2. MPCC Input and Output Signals
(RDSR-Receiver Data Service Request. When receiver DMA mode is active, the low RDSR output requests DMA service.
$\overline{\text { DACK——DMA Acknowledge. The } \overline{\text { DACK }} \text { low input indicates }}$ that the data bus has been acquired by the DMAC and that the requested bus cycle is beginning.
$\overline{\text { DTC }}$-Data Transfer Complete. The $\overline{\text { DTC }}$ low input indicates that a DMA data transfer is complete. $\overline{\text { DTC }}$ in response to a RDSR indicates that the data has been successfully stored in memory. $\overline{\text { DTC }}$ in response to a TDSR indicates that the data is present on the data bus for strobing into the MPCC. $\overline{\text { DTC }}$ is used in conjunction with $\mathrm{R} / \overline{\mathrm{W}}$ to increment the TxFIFO or RXFIFO pointer.

DONE-Done. $\overline{\text { DONE }}$ is a bidirectional active low signal. The DONE signal is asserted by the DMAC when the DMA transfer count is exhausted and there is no more data to be transferred, or asserted by the MPCC when the status byte following the last character of a frame (block) is being transferred in response to a $\overline{\text { RDSR }}$. The $\overline{\text { DONE signal asserted by the DMAC in response }}$ to a TDSR will be stored to track with the data byte (lower byte for word transfer) through the TxFIFO.

RESET-Reset. $\overline{\operatorname{RESET}}$ is an active low, high impedance input that initializes all MPCC functions. $\overline{\text { RESET must be }}$ asserted for at least 500 ns to initialize the MPCC.

DTR-Data Terminal Ready. The $\overline{\text { DTR }}$ active low output is general purpose in nature, and is controlled by the DTRLVL bit in the Serial Interface Control Register (SICR).
$\overline{R T S}-R e q u e s t ~ t o ~ S e n d . ~ T h e ~ \overline{R T S}$ active low output is general purpose in nature, and is controlled by the RTSLVL bit in the SICR.
$\overline{\text { CTS }}$-Clear to Send. The $\overline{\text { CTS }}$ active low input positive transition and level are reported in the CTST and CTSLVL bits in the Serial Interface Status Register (SISR), respectively.
$\overline{\mathrm{DSR}}$-Data Set Ready. The $\overline{\mathrm{DSR}}$ active low input negative transition and level are reported in the DSRT and DSRLVL bits in the SISR, respectively. $\overline{\mathrm{DSR}}$ is also an output for RSYN.
$\overline{D C D} — D a t a ~ C a r r i e r ~ D e t e c t . ~ T h e ~ \overline{D C D ~ a c t i v e ~ l o w ~ i n p u t ~ p o s i t i v e ~}$ transition and level are reported in the DCDT and DCDLVL bits in the the SISR, respectively.

TxD-Transmitted Data. The MPCC transmits serial data on the TxD output. The TxD output changes on the negative going edge of TxC.

RxD-Received Data. The MPCC receives serial data on the RxD input. The RxD input is shifted into the receiver with the negative going edge of RxC.

TxC-Transmitter Clock. TxC can be programmed to be an input or an output. When TXC is selected to be an input, the transmitter clock must be provided externally. When TxC is programmed to be an output, a clock is generated by the MPCC's internal baud rate generator. The low-to-high transition of the clock signal nominally indicates the center of a serial data present on the TXD output.

RxC-Receiver Clock. RxC provides the MPCC receiver with received data timing information.


## EXTAL—Crystal/External Clock Input.

XTAL Crystal Return. EXTAL and XTAL connect an 8 MHz external crystal to the MPCC internal oscillator. The pin EXTAL may also be used as a TTL level input to supply a DC to 8 MHz reference timing from an external clock source. XTAL must be tied to ground when applying an external clock to the EXTAL input.

BCLK-Buffered Clock. BCLK is the internal oscillator buffered output available to other MPCC devices eliminating the need for additional crystals.

Vcc-Power. $5 \mathrm{~V} \pm 5 \%$.
GND-Ground. Ground ( $\mathrm{V}_{\mathrm{SS}}$ ).

## MPCC REGISTERS

Twenty-two registers control and monitor the MPCC operation. The registers and their addresses are identified in Table 1a (R68561 operation in word mode) and in Table 1b (R68560 operation in byte mode). When the R68561 is operated in the word mode, two registers are read or written at a time starting at an even boundary. When the R68560 is operated in the byte mode, each register is explicitly addressed based on AO.

Table 2 summarizes the MPCC register bit assignments and their access. A read from an unassigned location results in a read from a "null register." A null register returns all ones for data and results in a normal bus cycle. Unused bits of a defined register are read as zeros unless otherwise noted.

Table 1a. R68561 Accessible Registers (Word Mode)

|  | Register(s) |  | R/W | Addr <br> (Hex.) | Address Lines |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | A4 |  | A3 | A2 | A1 |
| 15 | 8 | 7 0 |  |  |  |  |  |  |
| Receiver Control Register (RCR) |  | Receiver Status Register (RSR) |  | R/W | 00 | 0 | 0 | 0 | 0 |
| Receiver Data Register (RDR)-16 bits ${ }^{1}$ |  |  | R | 02 | 0 | 0 | 0 | 1 |
| Receiver Interrupt Enable Register (RIER) |  | Receiver Interrupt Vector Number Register (RIVNR) | R/W | 04 | 0 | 0 | 1 | 0 |


| Transmitter Control Register (TCR) | Transmitter Status Register (TSR) | R/W | 08 | 0 | 1 | 0 | 0 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Transmitter Data Register (TDR)-16 bits ${ }^{2}$ |  | W | OA | 0 | 1 | 0 | 1 |
| Transmitter Interrupt Enable Register (TIER) | Transmitter Interrupt Vector Number Register (TIVNR) | R/W | OC | 0 | 1 | 1 | 0 |


| Serial Interface Control Register (SICR) | Serial Interface Status Register (SISR) | R/W | 10 | 1 | 0 | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Reserved $^{3}$ | Reserved $^{3}$ | R/W | 12 | 1 | 0 | 0 | 1 |
| Serial Interrupt Enable Register (SIER) | Serial Interrupt Vector Number Register (SIVNR) | R/W | 14 | 1 | 0 | 1 | 0 |


| Protocol Select Register 2 (PSR2) | Protocol Select Register (PSR1) | R/W | 18 | 1 | 1 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Address Register 2 (AR2) | Address Register 1 (AR1) | R/W | 1A | 1 | 1 | 0 | 1 |
| Band Rate Divider Register 2 (BRDR2) | Baud Rate Divider Register 1 (BRDR1) | R/W | 1C | 1 | 1 | 1 | 0 |
| Error Control Register (ECR) | Clock Control Register (CCR) | R/W | 1E | 1 | 1 | 1 | 1 |

[^2]Table 1b. R68560 Accessible Registers (Byte Mode)

| Register(s) | R/W | Addr (Hex.) | Address Lines |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | A4 | A3 | A2 | A1 | A0 |
| 0 |  |  |  |  |  |  |  |
| Receiver Status Register (RSR) | R/W | 00 | 0 | 0 | 0 | 0 | 0 |
| Receiver Control Register (RCR) | R/W | 01 | 0 | 0 | 0 | 0 | 1 |
| Receiver Data Register (RDR)-8 bits ${ }^{1}$ | R | 02 | 0 | 0 | 0 | 1 | 0 |
| Reserved ${ }^{3}$ |  | 03 | 0 | 0 | 0 | 1 | 1 |
| Receiver Interrupt Vector Number Register (RIVNR) | R/W | 04 | 0 | 0 | 1 | 0 | 0 |
| Receiver Interrupt Enable Register (RIER) | R/W | 05 | 0 | 0 | 1 | 0 | 1 |


| Transmitter Status Register (TSR) | R/W | 08 | 0 | 1 | 0 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Transmitter Control Register (TCR) | R/W | 09 | 0 | 1 | 0 | 0 |
| Transmitter Data Register (TDR) ${ }^{2}-8$ bits | W | OA | 0 | 1 | 0 | 1 |
| Reserved ${ }^{3}$ |  | OB | 0 | 1 | 0 | 1 |
| Transmitter Interrupt Vector Number Register (TIVNR) | R/W | OC | 0 | 1 | 1 | 0 |
| Transmitter Interrupt Enable Register (TIER) | R/W | OD | 0 | 1 | 1 | 0 |


| Serial Interface Status Register (SISR) | R/W | 10 | 1 | 0 | 0 | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Serial Interface Control Register (SICR) | R/W | 11 | 1 | 0 | 0 | 0 | 1 |
| Reserved ${ }^{3}$ |  | 12 | 1 | 0 | 0 | 1 | 0 |
| Reserved ${ }^{3}$ |  | 13 | 1 | 0 | 0 | 1 | 1 |
| Serial Interrupt Vector Number Register (SIVNR) | R/W | 14 | 1 | 0 | 1 | 0 | 0 |
| Serial Interrupt Enable Register (SIER) | R/W | 15 | 1 | 0 | 1 | 0 | 1 |


| Protocol Select Register 1 (PSR1) | R/W | 18 | 1 | 1 | 0 | 0 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Protocol Select Register 2 (PSR2) | R/W | 19 | 1 | 1 | 0 | 0 | 1 |
| Address Register 1 (AR1) | R/W | 1A | 1 | $\dagger$ | 0 | 1 | 0 |
| Address Register 2 (AR2) | R/W | 1B | 1 | 1 | 0 | 1 | 1 |
| Band Rate Divider Register 1 (BRDR1) | R/W | 1 C | 1 | 1 | 1 | 0 | 0 |
| Baud Rate Divider Register 2 (BRDR2) | R/W | 1D | 1 | 1 | 1 | 0 | 1 |
| Clock Control Register (CCR) | R/W | 1E | 1 | 1 | 1 | 1 | 0 |
| Error Control Register (ECR) | R/W | 1F | 1 | 1 | 1 | 1 | 1 |

## Notes:

1. Accessible register of the eight byte RxFIFO. The data is not initialized, however, $\overline{\text { RES }}$ resets the RxFIFO pointer to the start of the first byte.
2. Accessible register of the eight byte TXFIFO. The data is not initialized, however, $\overline{\text { RES }}$ resets the TXFIFO pointer to the start of the first byte.
3. Reserved registers may contain random bit values.

Table 2. MPCC Register Bit Assignments

| R/W <br> Access | Bit Number |  |  |  |  |  |  |  | Reset(1) Value |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| R/W | RDA | EOF | 0 | C/PERR | FRERR | ROVRN | RA/B | RIDLE | 00 | Receiver Status Register (RSR) |
| RW | 0 | RDSREN | DONEEN | RSYNEN | STRSYN | 2ADCMP | RABTEN | RRES | 01 | Receiver Control Register (RCR) |
| R | RECEIVED DATA (RxFIFO) ${ }^{2}$ |  |  |  |  |  |  |  | - - | Receiver Data Register (RDR) |
| R/W | RECEIVER INTERRUPT VECTOR NUMBER (RIVN) |  |  |  |  |  |  |  | OF | Receiver Interrupt Vector Number Register (RIVNR) |
| R/W | $\begin{gathered} \text { RDA } \\ \text { IE } \end{gathered}$ | $\begin{gathered} \mathrm{EOF} \\ \mathrm{IE} \end{gathered}$ | 0 | $\begin{array}{\|c\|} \hline \text { C/PERR } \\ \text { IE } \\ \hline \end{array}$ | $\begin{gathered} \hline \text { FRERR } \\ \text { IE } \\ \hline \end{gathered}$ | $\begin{gathered} \hline \text { ROVRN } \\ \text { IE } \\ \hline \end{gathered}$ | $\begin{gathered} \text { RA/B } \\ \text { IE } \\ \hline \end{gathered}$ | 0 | 00 | Receiver Interrupt Enable Register (RIER) |


| R/W | TDRA | TFC | 0 | 0 | 0 | TUNRN | TFERR | 0 | 80 | Transmitter Status Register (TSR) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W | TEN | TDSREN | TICS | THW | TLAST | TSYN | TABT | TRES | 01 | Transmitter Control Register (TCR) |
| W | TRANSMITTED DATA (TxFIFO) ${ }^{2}$ |  |  |  |  |  |  |  | - - | Transmitter Data Register (TDR) |
| R/W | TRANSMITTER INTERRUPT VECTOR NUMBER (TIVN) |  |  |  |  |  |  |  | OF | Transmitter Interrupt Vector Number Register (TIVNR) |
| R/W | $\begin{gathered} \text { TDRA } \\ \text { IE } \end{gathered}$ | $\begin{aligned} & \text { TFC } \\ & \text { IE } \end{aligned}$ | 0 | 0 | 0 | TUNRN IE | TFERR IE | 0 | 00 | Transmitter Interrupt Enabie Register (TIER) |


| R/W | CTST | DSRT | DCDT | CTSLVL | DSRLVL | DCDLVL | 0 | 0 | 00 | Serial Interface Status Register (SISR) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W | RTSLVL | DTRLVL | 0 | 0 | 0 | ECHO | TEST | NRZI | 00 | Serial Interface Control Register (SICR) |
| 12 | RANDOM BIT VALUES |  |  |  |  |  |  |  |  | (reserved) |
| 13 | RANDOM BIT VALUES |  |  |  |  |  |  |  |  | (reserved) |
| - R/W | SERIAL INTERRUPT VECTOR NUMBER (SIVN) |  |  |  |  |  |  |  | OF | Serial Interrupt Vector Number Register (SIVNR) |
| R/W | $\begin{gathered} \hline \text { CTS } \\ \text { IE } \end{gathered}$ | DSR IE | $\begin{gathered} \mathrm{DCD} \\ \text { IE } \end{gathered}$ | - 0 | 0 | 0 | 0 | 0 | 00 | Serial Interrupt Enable Register (SIER) |



## Notes:

1. RESET $=$ Register contents upon power up or RESET.
2. 16-bits for R68561 (word mode); 8-bits for R68560 (byte mode).

## REGISTER DEFINITIONS

## RECEIVER REGISTERS

Receiver Status Register (RSR)

| 7 | 6 | 5 | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RDA | EOF | $\mathbf{0}$ | C/PERR | FRERR | ROVRN | RA/B | RIDLE |

Reset Value $=\$ 00$
The Receiver Status Register (RSR) contains the status of the receiver including error conditions. Status bits are cleared by writing a 1 into respective positions, by writing a 1 into the RCR RRES bit or by RESET. If an EOF, C/PERR, or FRERR is set in the RSR, the data reflecting the error (the first byte or word in the RxFIFO) must be read prior to resetting the corresponding status bit in the RSR. The $\overline{\operatorname{RQ}}$ output is asserted if any of the conditions reported by the status bits occur and the corresponding interrupt enable bit in the RIER is set.

The RSR format is the same as the frame status format (see below) except as noted.

## RSR

| 7 | RDA -Receiver |
| :---: | :---: |
| 0 | The RxFIFO is empty (i.e., no received data available). |
| 1 | Received data is available in the RxFIFO and can read via the RDR. |
| RSR |  |
| 6. | EOF -End of Frame. |
| 0 | No end of frame or block detected. |
| 1 | End of frame or block detected (BOP and BSC) |

## RSR

$\frac{5}{0}$ RHW -Receive Half Word. (Frame Status only)* The last word of the frame contains data on the upper half (D8-D15) and frame status on the lower half (DO-D7) of the data bus.
1 The lower half of the data bus (DO-D7) contains the frame status but the upper half (D8-D15) is blank or invalid.

## RSR

4 C/PERR -CRC/Parity Error.
No CRC or parity error detected.
1 CRC error detected (BOP, BSC), Parity error detected (ASYNC, ISOC and COP).

RSR

## 3 FRERR -Frame Error.

No frame error detected.
1 Short Frame or a closing FLAG detected off boundary (BOP), Frame error (ASYNC, ISOC) or receiver overrun.

## RSR

## 2 ROVRN -Receiver Overrun.

 No receiver overrun detected.1 Receiver overrun detected. Indicates that receiver data was attempted to be transferred into the RxFIFO when it was full, resulting in loss of received data. The data that is already in RxFIFO are not affected and may be read by the processor.

|  |  |  |
| :---: | :---: | :---: |
| 1 | RA/B | -Receiver Abort/Break. |
| 0 |  | Operation. |
| 1 |  | detected after an opening flag (BOP), ENQ d in a block of text data (BSC), or BREAK d (ASYNC). |
| RSR |  |  |
| $\underline{0}$ | RIDLE -Receiver Idie. (RSR only). |  |
| 0 | Receiver not idle. |  |
| 1 | 15 or more consecutive " 1 's" have been received and the receiver is in an inactive idle state. |  |

*Frame Status (RSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | EOF | RHW | C/PERR | FRERR | ROVRN | RA/B | 0 |

For the BSC and BOP protocols which have defined message blocks or frames, a "frame status" byte will be loaded into the RXFIFO following the last data byte of each block. The frame status contains all the status contained within the RSR with the exception of RDA and RIDLE. But, in addition to the RSR contents, the frame status byte has a RHW status in bit 5 which indicates either an even or odd boundary (applicable to word mode only).

If the MPCC is in word mode and the last data byte was on an even byte boundary (i.e., there was an even number of bytes in the message), a blank byte will be loaded into the RxFIFO prior to loading the frame status byte in order to force the "frame status" byte and the next frame to be on an even boundary. When RHW $=0$, the last word of the frame contains data on the upper half and status on the lower half of the data bus. If RHW $=1$, the lower half of the bus contains status but the upper half is a blank or invalid byte.

In the byte mode, the status byte will always immediately follow the last data byte of the block/frame (see Figure 3). The EOF status in the RSR is then set when the byte/word containing the frame status is the next byte/word to be read from the RxFIFO.

In the receiver DMA mode, when the EOF status in the RSR is set, DONE is asserted to the DMAC. Thus the last byte accessed by the DMAC is always a status byte, which the processor may read to check the validity of entire frame.

WORD MODE
WORD

| $\mathbf{N} 15$ | D8 | D7 |
| :---: | :---: | :---: |
| $\mathbf{N}$ | DATA | STATUS |
| $\mathbf{N}+1$ | NEXT | FRAME |

(RHW $=0$ )
WORD

| D15 | D8 $\mathbf{D 7}$ | D0 |
| :---: | :--- | :--- |
| $\mathbf{N}$ | DATA | DATA |
| $\mathbf{N}+1$ | BLANK | STATUS |
| $\mathbf{N}+2$ | NEXT | FRAME |

(RHW = 1)

BYTE MODE

| BYTE | D7 |
| :---: | :--- |
| $M$ | DATA |
| $M+1$ | STATUS |
| $M+2$ | NEXT FRAME |

BYTE

| D7 |  |
| :---: | :--- |
| $M$ | DATA |
| $M+1$ | STATUS |
| $M+2$ | NEXT FRAME |

Figure 3. BSC/BOP Block/Frame Status Location

Receiver Control Register (RCR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | RDSREN | DONEEN | RSYNEN | STRSYN | 2ADCMP | RABEN | RRES |

Reset value $=\$ 01$
The Receiver Control Register (RCR) selects receiver control options.

| $\begin{gathered} \text { RCR } \\ \underline{7} \end{gathered}$ | -Not used. |
| :---: | :---: |
| RCR |  |
| 6 | RDSREN -Receiver Data Service Request Enable. |
| 0 | Disable receiver DMA mode. |
| 1 | Enable receiver DMA mode. |
| RCR |  |
| 5 | DONEEN - DONE Output Enable. |
| 0 | Disable DONE output. |
| 1 | Enable DONE output. (When the receiver is in the DMA mode, i.e., RDSREN = 1). |
| RCR |  |
| 4 | RSYNEN -RSYNEN Output Enable. Selects the DSR signal input or the RSYN SYNC signal output on the $\overline{\mathrm{DSR}}$ pin. |
| 0 | Input DSR on $\overline{\text { DSR }}$. |
| 1 | Output RSYN on DSR. |
| RCR |  |
| 3 | STRSYN - Strip SYN Character (COP only). |
| 0 | Do not strip SYN character. |
| 1 | Strip SYN character. |
| RCR |  |
| 2 | 2ADCMP -One/Two Address Compare (BOP only). |
| 0 | Compare one address byte with the contents of AR1. |
| 1 | Compare two address bytes with the contents of AR1 and AR2. |

RCR
1 RABTEN -Receiver Abort Enable (BOP only).
0 Do not abort frame upon error detection.

1. Abort frame upon RxFIFO overrun (ROVRN bit $=1$ in the RSR) or CFCRC error detection (C/PERR bit $=1$ in the RSR). If either error occurs, the MPCC ignores the remainder of the current frame and searches for the beginning of the next frame.

## RCR

0 RRES -Receiver Reset Command.
$0 \quad$ Enable normal receiver operation.
1 Reset receiver. Resets the receiver section including the RxFIFO and the RSR (but not the RCR). RRES is set by RESET or by writing a 1 into this bit for one write cycle and is cleared by writing a 0 into this bit. RRES requires clearing after RESET.

Receiver Data Register (RDR)
R68561 (Word Mode)

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB |  |  | Byte 1 |  |  | LSB |  | MSB |  |  | Byte 0 |  | LSB |  |  |

R68560 (Byte Mode)

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

The receiver has an 8-byte (or 4-word) First In First Out (FIFO) register file (RxFIFO) where received data are stored before being transferred to the bus. The received data is transferred out of the RxFIFO via the RDR in 8 -bit bytes or 16 -bit words depending on the WD/BYT bit setting in PSR2. When the RxFIFO has a data byte/word ready to be transferred, the RDA status bit in the RSR is set to 1 .

Receiver Interrupt Vector Number Register (RIVNR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Receiver Interrupt Vector Number (RIVN) |  |  |  |  |  |  |  |

Reset value $=\$ 0 F$
If a receiver interrupt condition occurs (as reported by status bits in the RSR that correspond to interrupt enable bits in the RIER) and the corresponding bit is set in the RIER, IRQ output is asserted to request MPU receiver interrupt service. When the $\overline{\text { IACK }}$ input is asserted from the bus, the Receiver Interrupt Vector Number (RIVN) from the Receiver Interrupt Vector Number Register (RIVNR) is placed on the data bus.

Receiver Interrupt Enable Register (RIER)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RDA <br> IE | EOF <br> IE | 0 | C/PERR <br> IE | FRERR <br> IE | ROVRN <br> IE | RA/B <br> IE | 0 |

Reset value $=\$ 00$
The Receiver Interrupt Enable Register (RIER) contains interrupt enable bits for the Receiver Status Register (RSR). When enabled, the IRQ output is asserted when the corresponding condition is detected and reported in the RSR.

## RIER

| 7 | RDA IE -Receiver Data Available Interrupt Enable. |
| :---: | :---: |
| 0 | Disable RDA Interrupt. |
| 1 | Enable RDA Interrupt. |
| RIER |  |
| 6 | EOF IE -End of Frame Interrupt Enable. |
| 0 | Disable EOF Interrupt. |
| 1 | Enable EOF Interrupt. |
| RIER |  |
| 5 | -Not used. |
| RIER |  |
| 4 | C/PERR IE - CRC/Parity Error Interrupt Enable. |
| 0 | Disable C/PERR Interrupt. |
| 1 | Enable C/PERR Interrupt. |
| RIER |  |
| 3 | FRERR IE -Frame Error Interrupt Enable. |
| 0 | Disable FRERR Interrupt. |
| 1 | Enable FRERR Interrupt. |
| RIER |  |
| 2 | ROVRN IE -Receiver Overrun Interrupt Enable. |
| 0 | Disable ROVRN Interrupt. |
| 1 | Enable ROVRN Interrupt. |
| RIER |  |
| 1 | RA/B IE -Receiver Abort/Break Interrupt Enable. |
| 0 | Disable RA/B Interrupt. |
| 1. | Enable RA/B Interrupt. |
| RIER |  |
| 0 | -Not used. |

## TRANSMITTER REGISTERS

Transmitter Status Register (TSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TDRA | TFC | 0 | 0 | 0 | TUNRN | TFERR | 0 |

Reset value $=\$ 80$
The Transmitter Status Register (TSR) contains the transmitter status including error conditions. The transmitter status bits are cleared by writing a 1 into their respective positions, by writing a 1 into the TCR TRES bit, or by RESET. The IRQ output is asserted if any of the conditions reported by the status bits occur and the corresponding interrupt enable bit in the TIER is set.

TSR
$\frac{7}{0}$ TDRA -Transmitter Data Register Available.
$\overline{0} \quad$ The TxFIFO is full.
1 The TxFIFO is not full (i.e., available) and data to transmit can be loaded via the TDR.

TSR
6 TFC -Transmitted Frame Complete. (BOP, BSC and COP only).
0 Frame not complete.
1 Closing FLAG or ABORT character has been transmitted (BOP), Trailing PAD has been transmitted (BSC), or the last character of a frame or block as defined by TLAST (TCR bit 3) has been transmitted (COP).

TSR
5-3
-Not used.
TSR
2 TUNRN -Transmitter Underrun (BOP, BSC and COP only). A transmitter underrun occurs when the transmitter runs out of data during a transmission. For BOP, the underrun condition is treated as an abort. For BSC and COP, SYN characters are transmitted until more data is available in the TxFIFO.
0 No transmitter underrun occurred.
1 Transmitter underrun occurred.
TSR
$\frac{1}{0}$ TFERR -Transmit Frame Error (BOP only).
No frame error has occurred.
1 No control field was present (short frame).
Transmitter Control Register (TCR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TEN | TDSREN | TICS | THW | TLAST | TSYN | TABT | TRES |

Reset value $=\$ 01$
The Transmitter Control Register (TCR) selects transmitter control function.

## TCR

| $\mathbf{7} \quad$ TEN | $\quad$-Transmitter Enable. |
| :--- | :--- |
| 0 | Disable transmitter. TxD output is idled. The TxFIFO |
| may be loaded while the transmitter is disabled. |  |
| 1 | Enable transmitter. |

## TCR

| 6 | TDSREN | -Transmitter Data Service Request |
| :---: | :---: | :---: |
| Enable. |  |  |
| 0 | Disable transmitter DMA mode. |  |
| 1 | Enable transmitter DMA mode. |  |

## TCR

5 TICS
-Transmitter Idle Character Select. Selects the idle character to be transmitted when the transmitter is in an active idle mode (transmitter enabled or disabled).
$0 \quad$ Mark Idle (TxD output is held high).
1 Content of AR2 (BSC and COP), BREAK condition (ASYNC and ISOC), or FLAG character (BOP).

## TCR

4 THW
-Transmit Half Word. (R68561, word mode only). This bit is used when the frame or block ends on an odd boundary in conjunction with the TLAST bit and indicates that the last word in the TxFIFO contains valid data in the upper byte only. This bit must always be 0 in byte mode (R68560).
Transmit full word ( 16 bits) from the TxFIFO. Transmit upper byte ( 8 bits) from the TxFIFO.

## TCR

3 TLAST -Transmit Last Character (BOP, BSC and COP only).
0 The next character is not the last character in a frame or block.
1 The next character to be written into the TDR is the last character of the message. The TLAST bit automatically returns to a 0 when the associated word/byte is written to the TxFIFO. If the transmitter DMA mode is enabled, TLAST is set to a 1 by DONE from the DMAC. In this case the character written into the TDR in the current cycle is the last character.

TSYN -Transmit SYN (BSC and COP only).
Do not transmit SYN characters.
Transmit SYN characters. Causes a pair of SYN characters to be transmitted immediately following the current character. If BSC transparent mode is active, a DLE SYN sequence is transmitted. The TSYN bit automatically returns to a 0 when the SYN character is loaded into the Transmitter Shift Register.

TCR
$\frac{1}{0} \quad$ TABT $\quad$-Transmit ABORT (BOP only). Causes an abort by sending eight consecutive 1's. A data word/byte must be loaded into the TxFIFO after setting this bit in order to complete the command. The TABT bit clears automatically when the subsequent data word/byte is loaded into the TxFIFO.

## TCR

0 TRES -Transmitter Reset Command.
$\overline{0} \quad$ Enable normal transmitter operation.
1 Reset transmitter. Clears the transmitter section including the TxFIFO and the TSR (but not the TCR). The TxD output is held in "Mark" condition. TRES is set by RESET or by writing a 1 into this bit for one write cycle and is cleared by writing a 0 into this bit. TRES requires clearing after RESET.

Transmit Data Register (TDR)
R68561 (Word Mode)

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB |  | Byte 1 |  |  |  | LSB |  | MSB |  |  | Byte 0 |  | LSB |  |  |

R68560 (Byte Mode)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB |  |  | Byte 0 |  |  | LSB |  |

The transmitter has an 8-byte (or 4-word) FIFO register file (TxFIFO). Data to be transmitted is transferred from the bus into the TxFIFO via the TDR in 8 -bit bytes or 16 -bit words depending on the WD/BYT bit setting in PSR2. The TDRA status bit in the TSR is set to 1 when the TXFIFO is ready to accept another data word/byte.

Transmitter Interrupt Vector Number Register (TIVNR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Transmitter Interrupt Vector Number (TIVN) |  |  |  |  |  |  |  |

Reset value $=\$ 0 \mathrm{~F}$
If a transmitter interrupt condition occurs (as reported by status bits in the TSR that correspond to interrupt enable bits in the TIER) and the corresponding bit in the TIER is set, the IRQ output is asserted to request MPU transmitter interrupt service. When the $\overline{\text { ACK }}$ input is asserted from the bus, the Transmitter Interrupt Vector Number (TIVN) from the Transmitter Interrupt Vector Number Register (TIVNR) is placed on the data bus.

Transmitter Interrupt Enable Register (TIER)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TDRA <br> IE | TFC <br> IE | 0 | 0 | 0 | TUNRN <br> IE | TFERR <br> IE | - |

## Reset value $=\$ 00$

The Transmitter Interrupt Enable Register (TIER) contains interrupt enable bits for the Transmitter Status Register. When enabled, the $\overline{\mathrm{RQ}}$ output is asserted when the corresponding condition is detected and reported in the TSR.

## TIER

$$
\begin{array}{cc}
\mathbf{7} & \text { TDRA IE } \\
\text { - Transmitter Data Register (TDR) Avail- } \\
\text { able Interrupt Enable. } \\
0 & \text { Disable TDRA Interrupt. } \\
1 & \text { Enable TDRA Interrupt. }
\end{array}
$$

| TIER |  |
| :---: | :---: |
| 6 | TFC IE $\quad \begin{gathered}\text {-Transmit Frame Complete (TFC) Interrupt } \\ \text { Enable. }\end{gathered}$ |
| 0 | Disable TFC Interrupt. |
| 1 | Enable TFC Interrupt. |
| $\begin{gathered} \text { TIER } \\ 5-3 \\ \hline \end{gathered}$ | -Not used. |
| TIER |  |
| 2 | TUNRN IE -Transmitter Underrun (TUNRN) Interrupt Enable. |
| 0 | Disable TUNRN Interrupt. |
| 1 | Enable TUNRN Interrupt. |
| TIER |  |
| 1 | TFERR IE —Transmit Frame Error (TFERR) Interrupt Enable. |
| 0 | Disable TFERR Interrupt. |
| 1 | Enable TFERR Interrupt. |
| TIER |  |
| 0 | -Not used. |

## SERIAL INTERFACE REGISTERS

Serial Interface Status Register (SISR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CTST | DSRT | DCDT | CTSLVL | DSRLVL | DCDLVL | 0 | 0 |

Reset value $=\$ 00$
The Serial Interface Status Register (SISR) contains the serial interface status information. The transition status bits (CTST, DSRT and DCDT) are cleared by writing a 1 into their respective positions, or by RESET. The level status bits (CTSLVL, DSRLVL and DCDLVL) reflect the state of their respective inputs and cannot be cleared internally. The $\overline{\mathrm{RQ}}$ output is asserted if any of the conditions reported by the transition status bits occur and the corresponding interrupt enable bit in the SIER is set.

| SISR |  |
| :---: | :---: |
| 7 | CTST -Clear to Send Transition Status. |
| 1 | $\overline{\mathrm{CTS}}$ has transitioned positive (from active to inactive). (TRES must be zero). |
| 0 | CTS has not transitioned positive. |
| SISR |  |
| 6 | DSRT -Data Set Ready Transition Status. |
| 1 | $\overline{\overline{D S R}}$ has transitioned negative (from inactive to active). |
| 0 | $\overline{\mathrm{DSR}}$ has not transitioned negative. |
| SISR |  |
| 5 | DCDT -Data Carrier Detect Transition Status. |
| 1 | $\overline{\overline{D C D}}$ has transitioned positive (from active to inactive). |
| 0 | $\overline{\mathrm{DCD}}$ has not transitioned positive. |
| SISR |  |
| 4 | CTSLVL -Clear to Send Level. |
| 0 | CTS input level is negated (high). |
| 1 | CTS input level is asserted (low). |

## SISR

3 DSRLVL -Data Set Ready Level.
$\overline{0} \quad \overline{\text { DSR }}$ input level is negated (high).
$1 \overline{\mathrm{DSR}}$ input level is asserted (low).
SISR
2 DCDLVL -Data Carrier Detect Level.
$\overline{0} \quad \overline{D C D}$ input level is negated (high).
$1 \quad \overline{D C D}$ input level is asserted (low).
SISR
1-0 -Not used.
Serial Interface Control Register (SICR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RTSLVL | DTRLVL | 0 | 0 | 0 | ECHO | TEST | NRZI |

Reset value $=\$ 00$
The Serial Interface Control Register (SICR) controls various serial interface signals and test functions.

SICR
$\frac{7}{0}$ RTSLVL -Request to Send Level.
1 .... Negate $\overline{\text { RTS }}$ output (high).
1 Assert $\overline{\text { RTS output (low). }}$

## NOTE

In BOP, BSC, or COP, when the RTSLVL bit is cleared in the middle of data transmission, the RTS outputremains asserted until the end of the current frame or block has been transmitted. In ASYNC or ISOC, the $\overline{\text { RTS }}$ output is negated when the TxFIFO is empty. If the transmitter is idling when the RTSLVL bit is reset, the $\overline{\mathrm{RTS}}$ output is negated within two bit times.

SICR

| 6 | DTRLVL |
| :--- | :--- |
| 0 | Negate |
| DTR output (high). |  |

1 Assert DTR output (low).
SICR
5-3
-Not used. These bits are initialized to 0 by RESET and must not be set to 1 .

SICR
2 ECHO —Echo Mode Enable.
$\overline{0}$ Disable Echo mode (enable normal operation).
1 Enable Echo mode. Received data (RxD) is routed back through the transmitter to TxD. The contents of the TxFIFO is undisturbed. This mode may be used for remote test purposes.

## SICR

1 TEST -Self-test Enable.
Disable self-test (enable normal operation).
1 Enable self-test. The transmitted data (TxD) and clock (TxC) are routed back through to the receiver through RxD and RxC, respectively ( $\overline{\mathrm{DCD}}$ and $\overline{\mathrm{CTS}}$ are ignored). This "loopback" self-test may be used for all protocols. RxC is external regardless of the state of CCR bit 2. CCR bit 3 may be a 0 or a 1.

SICR

0 NRZI | -NRZI Data Format Select. Selects the |
| :---: |
| transmit and receive data format to be NRZ |
| or NRZI. |

0 Select NRZ data format. NRZ coding-high $=1$ and low $=0$.
1 Select NRZI data format. The serial data remains in the same state to send a binary 1 and switches to the opposite state to send a binary 0 . A 1 bit delay is added to the TxD output to allow for encoding.

Serial Interrupt Vector Number Register (SIVNR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Serial Interrupt Vector Number (SIVN) |  |  |  |  |  |  |  |

Reset value $=\$ 0 \mathrm{~F}$
If a serial interface interrupt condition occurs (as reported by status bits in the SISR that correspond to interrupt enable bits in the SIER) and the corresponding bit in the SIER is set, the $\overline{\mathrm{IRQ}}$ output is asserted to request MPU serial interface interrupt service. When the $\overline{\mathrm{IACK}}$ input is asserted from the bus, the Serial Interrupt Vector Number (SIVN) from the Serial Interrupt Vector Number Register (SIVNR) is placed on the data bus.

Serial Interrupt Enable Register (SIER)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CTS <br> IE | DSR <br> IE | DCD <br> IE | 0 | 0 | 0 | 0 | 0 |

Reset value $=\$ 00$
The Serial Interrupt Enable Register (SIER) contains interrupt enable bits for the Serial Interface Status Register. When an interrupt enable bit is set, the $\overline{\mathbb{R Q}}$ output is asserted when the corresponding condition occurs as reported in the SISR.

```
SIER
    lum _Clear to Send (CTS) Interrupt Enable.
SIER
    6}\mathrm{ DSR IE -Data Set Ready (DSR) Interrupt Enable.
        Disable DSR Interrupt.
        Enable DSR Interrupt.
SIER
    5 DCD IE -Data Carrier Detect (DCD) Interrupt
                Enable.
    0 Disable DCD Interrupt.
    1 Enable DCD Interrupt.
SIER
4-0 -Not used.
```


## GLOBAL REGISTERS

The global registers contain command information applying to different modes of operation and protocols. After changing global register data, TRES in the TCR and RRES in the RCR should be set then cleared prior to performing normal mode processing.

Protocol Select Register 1 (PSR1)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | CTLEX | ADDEX |

Reset value $=\$ 00$
Protocol Select Register 1 (PSR1) selects BOP protocol related options.

| $\begin{gathered} \text { PSR1 } \\ 7-2 \\ \hline \end{gathered}$ | -Not used. |
| :---: | :---: |
| PSR1 |  |
| 1 | CTLEX -Control Field Extend (BOP only). |
| 0 | Select 8-bit control field. |
| 1 | Select 16-bit control field. |
| PSR1 |  |
| 0 | ADDEX -Address Extend (BOP only). |
| 0 | Disable address extension. All eight bits of the address byte are utilized for addressing. |
| 1 | Enable address extension. When bit 0 in the address byte is a 0 the address field is extended by one byte. An exception to the address field extension occurs when the first address byte is all 0 's (null address). |

Protocol Select Register 2 (PSR2)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| WD/BYT | STOP BIT SEL |  | CHAR LEN SEL |  | PROTOCOL SEL |  |  |
|  | SB2 | SB1 | CL2 | CL1 | PS3 | PS2 | PS1 |

Reset value $=\$ 00$
Protocol Select Register 2 (PSR2) selects protocols, character size, the number of stop bits, and word/byte mode.

## PSR2

7 WD/BYT -Data Bus Word/Byte Mode.
$0 \quad$ Select byte mode. Selects the number of data bits to be transferred from the RxFIFO and the registers to the data bus and to be transferred from the data bus to the TXFIFO and the registers. The MPCC is initialized by $\overline{\text { RESET }}$ to the byte mode.
1 Select word mode. For operation with the 16-bit bus, select the word mode by sending $\$ 80$ on D7-D0 to address $\$ 19$ prior to transferring subsequent data between the MPCC and the data bus.

## PSR2

6-5 STOP BIT SEL -Number of Stop Bits Select. Selects the number of stop bits transmitted at the end of the data bins in ASYNC and ISOC modes.

| 6 | 5 | No. of Stop Bits |  |
| :---: | :---: | :---: | :---: |
|  |  |  |  |
| SB2 | SB1 | ASYNC | ISOC |
| 0 | 0 | 1 | 1 |
| 0 | 1 | 1-1/2 | 2 |
| 1 | 0 | 2 | 2 |

## PSR2

4-3 CHAR LEN SEL -Character Length Select. Selects the character length except in BOP and BSC where the character length is always eight bits. Parity is not included in the character length.


CL1 Character Length
5 bits
6 bits
7 bits
8 bits
PSR2
2-0 PROTOCOL SEL—Protocol Select. Selects protocol and defines the protocol dependent control bits.

| 2 | 1 |
| :---: | :---: |
| PS3 | PS2 |
| 0 | 0 |
| 0 | 0 |
| 0 | 1 |
| 0 | 1 |
| 1 | 0 |
| 1 | 0 |
| 1 | 1 |
| 1 | 1 |


| 0 <br> PS1 | Protocol |
| :--- | :--- |
| 0 | BOP (Primary) |
| 1 | BOP (Secondary) |
| 0 | Reserved |
| 1 | COP |
| 0 | BSC EBCDIC |
| 1 | BSC ASCII |
| 0 | ASYNC |
| 1 | ISOC |

Address Register 1 (AR1)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| BOP ADDRESS/BSC \& COP PAD |  |  |  |  |  |  |  |

Reset value $=\$ 00$
Address Register 2 (AR2)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| BOP ADDRESS/BSC \& COP SYN |  |  |  |  |  |  |  |

Reset value $=\$ 00$
The protocol selected in PSR2 (BOP, BSC and COP only) determines the function of the two 8-bit Address Registers (AR1 and AR2). As a secondary station in BOP, the contents of the address registers are used for address matching depending on the 2 ADCMP selection in the RCR. In BSC and COP, AR1 and AR2 contain programmable leading PAD and programmable SYN characters, respectively.
Address Register (AR) Contents

| Protocol Selected | 2ADCMP | AR1 | AR2 |
| :--- | :---: | :---: | :---: |
| BOP (Primary) | X | X | X |
| BOP (Secondary) | 0 | Address | X |
|  | 1 | Address | Address |
| BSC EBCDIC | X | Leading PAD | SYN |
| BSC ASCII | X | Leading PAD | SYN |
| COP | X | Leading PAD | SYN |
| ${ }^{*} \mathrm{X}=$ Not used |  |  |  |

Baud Rate Divider Register 1 (BRDR1)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BAUD RATE DIVIDER (LSH) |  |  |  |  |  |  |  |

Reset value $=\$ 01$
Baud Rate Divider Register 2 (BRDR2)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BAUD RATE DIVIDER (MSH) |  |  |  |  |  |  |  |

Reset value $=\$ 00$
The two 8-bit Baud Rate Divider Registers (BRDR1 and BRDR2) hold the divisor of the Baud Rate Divider circuit. BRDR1 contains the least significant half (LSH) and BRDR2 contains the most significant half (MSH), With an 8.064 MHz EXTAL input, standard bit rates can be selected using the combination of Prescaler Divider (in the CCR) and Baud Rate Divider values shown in Table 3. For isochronous or synchronous protocols, the Baud Rate Divider value must be multiplied by two for the same Prescaler Divider value.

The Baud Rate Divider (BRD) value can be computed for other crystal frequency, prescaler divider and desired baud rate values as follows:

$$
\text { BRD }=\frac{\text { Crystal Frequency }}{\text { (Prescaler Divider) (Baud Rate) (K) }}
$$

where: $\quad K=\begin{aligned} & 1 \text { for isochronous or synchronous } \\ & 2 \text { for asynchronous }\end{aligned}$

Clock Control Register (CCR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | PSCDIV | TCLKO | RCLKIN | CLK SEL |  |
|  |  |  |  |  |  | CK2 | CK1 |

Reset value $=\mathbf{\$ 0 0}$
The CCR selects various clock options.

| $\begin{aligned} & \text { CCR } \\ & \hline 7-5 \\ & \hline \end{aligned}$ | -Not used. |
| :---: | :---: |
| CCR |  |
| 4 | PSCDIV —Prescaler Divider. The Prescaler Divider network reduces the external/oscillator frequency to a value for use by the internal Baud Rate Generator. |
| 0 | Divide by 2. |
| 1 | Divide by 3. |
| CCR |  |
| 3 | TCLKO -Transmitter Clock Output Select. |
| 0 | Select TxC to be an input. |
| 1 | Select TxC to be an output. |

Table 3. Standard Baud Selection (8.064 MHz Crystal)

| Desired Baud Rate (Bit Rate) | Prescaler Divider |  | Baud Rate Divider |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Asynchronous |  |  | Isochronous and Synchronous |  |  |
|  | Decimal Value | $\begin{aligned} & \text { PSCDIV } \\ & \text { (0 to 1) } \\ & \hline \end{aligned}$ | Decimal Value | Hexadecimal Value |  | Decimal Value | Hexadecimal Value |  |
|  |  |  |  | $\begin{aligned} & \text { BRDR2 } \\ & \text { (MSH) } \end{aligned}$ | $\begin{gathered} \text { BRDR1 } \\ \text { (LSH) } \end{gathered}$ |  | BRDR2 (MSH) | $\begin{gathered} \text { BRDR1 } \\ \text { (LSH) } \end{gathered}$ |
| 50 | 3 | 1 | 26,880 | 69 | 00 | 53,760 | D2 | 00 |
| 75 | 2 | 0 | 26,880 | 69 | 00 | 53,760 | D2 | 00 |
| 110 | 3 | 1 | 12,218 | 2 F | BA | 24,436 | 5F | 74 |
| 135 | 2 | 0 | 14,933 | 3A | 55 | 29,866 | 74 | AA |
| 150 | 3 | 1 | 8,960 | 23 | 00 | 17,920 | 46 | 00 |
| 300 | 2 | 0 | 6,720 | 1A | 40 | 13,440 | 34 | 80 |
| 1200 | 3 | 1 | 1,120 | 04 | 60 | 2,240 | 08 | CO |
| 1800 | 2 | 0 | 1,120 | 04 | 60 | 2,240 | 08 | CO |
| 2400 | 2 | 0 | 840 | 03 | 48 | 1,680 | 06 | 90 |
| 3600 | 2 | 0 | 560 | 02 | 30 | 1,120 | 04 | 60 |
| 4800 | 3 | 1 | 280 | 01 | 18 | 560 | 02 | 30 |
| 7200 | 2 | 0 | 280 | 01 | 18 | 560 | 02 | 30 |
| 9600 | 3 | 1 | 140 | 00 | 8 C | 280 | 01 | 18 |
| 19200 | 3 | 1 | 70 | 00 | 46 | 140 | 00 | 8 C |
| 38400 | 3 | 1 | 35 | 00 | 23 | 70 | 00 | 46 |

## CCR

2 RCLKIN -Receiver Clock Internal Select (ASYNC only).
0 Select External RxC.
1 Select Internal RxC.

CCR
1-0 CLK DIV -External Receiver Clock Divider. Selects the divider of the external RxC to determine the receiver data rate.

| CK2 | CK1 | Divider |
| :---: | :---: | :---: |
| 0 | 0 | 1 (ISOC) |
| 0 | 1 | 16 |
| 1 | 0 | 32 |
| 1 | 1 | 64 |

Error Control Register (ECR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PAREN | ODDPAR | - | - | CRCCTL | CRCPRE | CRCSEL |  |
|  |  |  |  |  |  | CR2 | CR1 |

Reset value $=\$ 04$
The Error Control Register (ECR) selects the error detection method used by the MPCC.

ECR
7 PAREN -Parity Enable. (ASYNC, ISOC and COP only).
$0 \quad$ Disable parity generation/checking.
1 Enable parity generation/checking.

ECR
6 ODDPAR -Odd/Even Parity Select (Effective only when PAREN = 1).
0 Generate/check even parity.
1 Generate/check odd parity.
ECR
5-4 -Not used.
ECR
3 CFCRC -Control Field CRC Enable.
0 Disable control field CRC. Enables an intermediate CRC remainder to be appended after the address/control field in transmitted BOP frames and checked in received frames. The CRC generator is reset after control field CRC calculation.

ECR
2 CRCPRE -CRC Generator Preset Select.
$0 \quad$ Preset CRC Generator to 0.
1 Preset CRC Generator to 1 and transmit the 1's complement of the resulting remainder.

ECR
1-0 CRCSEL -CRC Polynomial Select. Selects one of the RC polynominals.

10

| CR2 | CR1 | Polynominal |
| :---: | :---: | :---: |
| 0 | 0 | $\mathrm{x}^{16+x^{12}+\mathrm{x}^{5}+1 \text { (CCITT V.41) }}$ |
| 0 | 1 | $x^{16}+x^{15}+x^{2}+1$ (CRC-16) |
| 1 | 0 | $\mathrm{x}^{8}+1 \quad$ (VRC/LRC)* |
| 1 | 1 | Not used. |

*VRC: Odd-parity check is performed on each character including the LRC character.

## INPUT/OUTPUT FUNCTIONS

## MPU INTERFACE

Transfer of data between the MPCC and the system bus involves the following signals:

|  | R68561 | R68560 |
| :---: | :---: | :---: |
| Address Lines | A1-A4 | A0-A4 |
| Data Lines | D0-D15 | D0-D7 |
| Read/Write | R/W | R/W |
| Data Transfer Acknowledge | DTACK | $\overline{\text { DTACK }}$ |
| Chip Select | $\overline{C S}$ | $\overline{\text { CS }}$ |
| Data Strobes | $\overline{U D S}$ and $\overline{L D S}$ | $\overline{\mathrm{DS}}$ |

Figures 10 and 11 show typical interface connections.

## Read/Write Operation

The $\mathrm{R} \overline{\mathrm{W}}$ input controls the direction of data flow on the data bus. $\overline{\mathrm{CS}}$ (Chip Select) enables the MPCC for access to the internal registers and other operations. When $\overline{\mathrm{CS}}$ is asserted, the data I/O buffer acts as an output driver during a read operation and as an input buffer during a write operation. $\overline{\mathrm{CS}}$ must be decoded from the address bus and gated with address strobe ( $\overline{\mathrm{AS}}$ ).

When the R68561 is connected to the 16 -bit bus for operation in the word mode (WD/BYT = 1 in the PSR2), address lines A1-A4 select the internal register(s) (the 8 -bit control/status registers are accesed two at a time and the 16 -bit data registers are accessed on even address boundaries). When the MPCC is selected ( $\overline{C S}$ low) during a read ( $\mathrm{R} / \overline{\mathrm{W}}$ high), 16 bits of register data are placed on the data bus when the data strobes ( $\overline{\mathrm{LDS}}$ and $\overline{\mathrm{UDS}}$ ) are asserted. $\overline{\mathrm{LDS}}$ strobes the eight data bits from the even numbered registers to the lower data bus lines (D0-D7) and UDS strobes the eight data bits from the odd numbered registers to the upper data bus lines (D8-D15). The MPCC asserts Data Transfer Acknowledge (DTACK prior to placing data on the data bus. Conversely, when the MPCC is selected ( $\overline{\mathrm{CS}}$ low) during a write (R $\bar{W}$ low) $\overline{L D S}$ and $\overline{U D S}$ strobe data from the $D 0-D 7$ and D8-D15 data bus lines into the addressed even and odd numbered registers, respectively, and the MPCC asserts $\overline{\text { DTACK. }}$ $\overline{\text { DTACK }}$ is negated when $\overline{\mathrm{CS}}$ is negated. Figures 12 and 13 show the read and write timing relationships.

When the R68560 is connected to the 8 -bit bus for operation in the byte mode (WD/BYT $=0$ in the PSR2), address lines A0-A4 select one internal 8 -bit register. When the MPCC is selected ( $\overline{C S}$ low) during a read ( $R / \bar{W}$ high), eight bits of register data are placed on data bus lines D0-D7 when the data strobe ( $\overline{\mathrm{DS}}$ ) is asserted. When the MPCC is selected ( $\overline{C S}$ low) for a write (R/W low), $\overline{D S}$ strobes data from the D0-D7 data lines into the selected register.

## DMA INTERFACE

The MPCC is capable of providing DMA data transfers up to 2 Mbytes per second when used with the MC68440 or MC68450 DMAC in the single address mode. Based on $4 \mathrm{Mb} / \mathrm{s}$ serial data rate and 5 bits/character, the maximum DMA required transfer rate is 800 Kbytes per second.

The MPCC has separate DMA enable bits for the transmitter and receiver, each of which requires a DMA channel. Both the transmitter and receiver data are implicitly addressed (TDR or RDR) therefore addressing of the data register is not required before data may be transferred. Communication between the

MPCC and the DMAC is accomplished by a two-signal request/acknowledge handshake. Since the MPCC has only one acknowledge input (DACK) for its two DMA request lines, an external OR function must be provided to combine the two DMA acknowledge signals. The MPCC uses the R/W input to distinguish between the Transmitter Data Service Request (TDSR acknowledge and the Receiver Data Service Request (RDSR) acknowledge.

## Receiver DMA Mode

The receiver DMA mode is enabled when the RDSREN bit in the RCR is set to 1 . When data is available in the RxFIFO, Receiver Data Service Request ( $\overline{\mathrm{RDSR}}$ ) is asserted for one receiver clock period to initiate the MPCC to memory DMA transfer. The next RDSR cycle may be initiated as soon as the current $\overline{\text { RDSR }}$ cycle is completed (i.e., a full sequence of DACK, $\overline{\mathrm{DS}}$, and $\overline{\mathrm{DTC}}$ ).

In response to $\overline{\operatorname{RDSR}}$ assertion, the DMAC sets the $\mathrm{R} / \bar{W}$ line to write, asserts the memory address, address strobe, and DMA acknowledge. The MPCC outputs data from the RxFIFO to the data bus and the DMAC asserts the data strobes. The memory latches the data and asserts DTACK to complete the data transfer. The DMAC asserts $\overline{\text { DTC }}$ to indicate to the MPCC that data transfer is complete. Figure 13 shows the timing relationships for the receiver DMA mode.
$\overline{\text { RDSR }}$ is inhibited when either RDSREN is reset to 0 or RRES is set to 1 (both in the RCR), or when RESET is asserted.

## Transmitter DMA Mode

The transmitter DMA mode is enabled when the TDSREN bit in the TCR is set to 1 . When the TxFIFO is available, Transmitter Data Service Request (TDSR) is asserted for one transmitter clock period to initiate the memory to MPCC DMA transfer. The next TDSR cycle may be initiated as soon as the current TDSR cycle is completed.

In the transmitter DMA mode, the TxFIFO Is implicitly addressed. That is, when the transfer is from memory to the TxFIFO, only the memory is addressed. In response to TDSR assertion, the DMAC sets the R $\bar{W}$ line to read, asserts the memory address, the address strobe, the data strobes and DMA acknowledge. The memory places data on the data bus and asserts DTACK. Data is valid at this time and will remain valid until the data strobes are negated. The DMAC asserts $\overline{\text { DTC }}$ to indicate to the MPCC that data is available. The MPCC loads the data into the TxFIFO on the negation (rising edge) of $\overline{\mathrm{DS}}$ and the transfer is complete. A timing diagram for the transmitter DMA Mode is shown in Figure 15.
$\overline{\text { TDSR }}$ is inhibited when either TDSREN is reset to 0 or TRES is set to 1 (both in the TCR), or when RESET is asserted.

## DONE Signal

When the DMA transfer count is exhausted in transmitter DMA mode, the DMAC asserts DONE which sets the TLAST bit in the TCR to indicate that the last word/byte has been transferred. In the receiver DMA mode, DONE is asserted by the MPCC when the last character of the frame/block is being transferred from the RxFIFO to the data bus if the DONEEN bit is set to a 1 in the RCR.

## INTERRUPTS

If an interrupt generating status occurs and the interrupt is enabled, the MPCC asserts the IRQ output. Upon receiving IACK for the pending interrupt request, the MPCC places an interrupt vector on DO-D7 data bus and asserts DTACK.

The MPCC has three vector registers: Receiver Interrupt Vector Number Register (RIVNR), Transmitter Interrupt Vector Number Register (TIVNR), and Serial Interrupt Vector Number Register (SIVNR). The receiver interrupt has higher priority over the transmitter interrupt, and the transmitter interrupt has priority over the serial interface interrupt. For example, if a pending interrupt request has been generated simultaneously by the receiver and the transmitter, the Receiver Interrupt Vector Number (RIVN) is placed on DO-D7 when acknowledged by the MPU. Upon completion of the first interrupt request cycle (which clears the receiver interrupt), $\overline{\mathrm{I} Q Q}$ will remain low to start the transmitter interrupt cycle. $\overline{\mathrm{RQ}}$ is negated by clearing all bits set in a status register that could have caused the interrupt.

A timing diagram for the interrupt acknowledge sequence is shown in Figure 15.

## SERIAL INTERFACE

The MPCC is a high speed, high performance device supporting the more popular bit and character oriented data protocols. The lower speed asynchronous (ASYNC) and isochronous (ISOCH) modes are also supported. An on-chip clock oscillator and baud rate generator provide an output data clock at a frequency of DC to 4 MHz . The clock can also be used in the ASYNC mode to provide a receive clock for the incoming data. The serial interface consists of the following signals:

## $\overline{\text { RTS }}$ (Request to Send) Output

The $\overline{\text { RTS }}$ output to the DCE is controlled by the RTSLVL bit in the SICR in conjunction with the state of the transmitter section. When the RTSLVL bit is set to 1 , the RTS output is asserted. When the RTSLVL bit is reset to 0 , the RTS output remains asserted until the TxFIFO becomes empty or the end of the message (or frame), complete with CRC code if any, has been transmitted. $\overline{\text { RTS }}$ also is negated when the RTSLVL bit is reset during transmitter idle, or when the RESET input is asserted.

## CTS (Clear to Send) Input

The $\overline{\text { CTS }}$ input signal is normally generated by the DCE to indicate whether or not the data set is ready to transmit data. The CTST bit in the SISR reflects the transition status of the CTS input while the CTSLVL bit in the SISR reflects the current level. A positive transition on the CTS pin asserts $\overline{\mathrm{RQ}}$ if the CTS IE bit in the SIER is set. The $\overline{\text { CTS }}$ input in an inactive state disables the start of transmission.

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

The $\overline{\mathrm{DCD}}$ input signal is normally generated by the DCE and indicates that the DCE is receiving a data carrier signal suitable for demodulation. The DCDT bit in the SISR reports the transition status of the $\overline{D C D}$ input while the DCDLVL bit in the SISR contains the current level. A positive transition on the $\overline{\mathrm{DCD}}$ pin asserts the $\overline{\operatorname{RRQ}}$ output if the DCD IE bit in the SIER is set. A negated $\overline{\mathrm{DCD}}$ input disables the start of the receiver.

## $\overline{\text { DSR (Data Set Ready) Input/RSYN Output }}$

The DSRT input from the DCE indicates the status of the local set. The DSRT bit in the SISR contains the transition status of the $\overline{\mathrm{DSR}}$ input while the DSRLVL bit in the SISR reports the current level. A negative transition on the $\overline{D S R}$ pin asserts the $\overline{\text { IRQ }}$ output if the DSR IE bit in the SIER is set.

When the RSYN bit in the RCR is set to 1 , the frame synchronization signal (RSYN) in the receiver is output on the DSR pin. In this mode, DSR output low indicates detection of SYN in BSC or COP, or an address match in BOP.

## DTR (Data Terminal Ready) Output

The $\overline{\mathrm{DTR}}$ output is general purpose in nature and can be used to control switching of the DCE. The DTR output is controlled by the DTRLVL bit in the SICR.

## TxC (Transmitter Clock) Input/Output

The transmitter clock (TxC) may be programmed to be input or an output. When the TCLKO control bit in the CCR is set to a 1, the TxC pin becomes an output and provides the DCE with a clock whose frequency is determined by the internal baud rate generator. When the TCLKO control bit is reset, TxC is an input and the transmitter shift timing must be provided externally. The TxD output changes state on the negative-going edge of the transmitter clock. In the asynchronous mode when TCLKO $=0$ in the CCR, the TxC input frequency must be two times the desired baud rate.

## TxD (Transmitted Data) Output

The serial data transmitted from the MPCC is coded in NRZ or NRZI (zero complement) data format as selected by the NRZI control bit in the SICR.

## RxC (Receiver Clock) Input

The receiver latches data on the negative transition of the RxC.

## RxD (Received Data) Input

The serial data received by the MPCC can be coded in NRZ or NRZI data format. The MPCC will decode the received data in accordance with the NRZI control bit setting in the SICR.

## Serial Interface Timing

The timing for the serial interface clock and data lines is shown in Figure 18. The MPCC supports high speed synchronous operation. As shown, the TxD output changes with the negative-going edge of TxC and the received data on RxD is latched on the negative edge of RxC. This assures high speed two-way operation between two MPCCs connected as shown in Figure 17.

For low speed operation between the MPCC and a modem or RS-232C Data Communications Equipment (DCE), an inverter can be used in the TxC output lines as shown in Figure 17. RS-232 and RS-423 (covering serial data interface up to 100 K baud) require that data be centered $\pm 25 \%$ about the negative-going edge of the RxC. This criteria is met for frequencies up to 1.25 MHz using the inverter. Use of the inverter also allows MPCC to MPCC operation up to 2.17 MHz .

## SERIAL COMMUNICATION MODES AND PROTOCOLS

## ASYNCHRONOUS AND ISOCHRONOUS MODES

Asynchronous and isochronous data are transferred in frames. Each frame consists of a start bit, 5 to 8 data bits plus optional even or odd parity, and $1,11 / 2$, or 2 stop bits. The data character is transmitted with the least significant bit (LSB) first. The data line is normally held high (MARK) between frames, however, a BREAK (minimum of one frame length for which the line is held low) is used for control purposes. Figure 4 illustrates the frame format supported by the MPCC.

## Asynchronous Receive

In the asynchronous (ASYNC) mode, data received on RxD occurs in three phases: (1) detection of the start bit and bit synchronization, (2) character assembly and optional parity check, and (3) stop bit detection. The receiver bit stream may be synchronized by the internal baud rate generator clock or by an external clock on RxC. When RCLKIN in the CCR is set to 0 , an external clock with a frequency of 16,32 , or 64 times the data rate establishes the data bit midpoint and maintains bit synchroniza-
tion. The character assembly process does not start if the start bit is less than one-half bit time. Framing and parity errors are detected and buffered along with the character on which errors occurred. They are passed on to the RxFIFO and set appropriate status bits in the RSR when the character with an error reaches the last RxFIFO register where it is ready to be transferred onto the data bus via the RDR.

## Isochronous Receive

In the isochronous (ISOC) mode, a 1 times clock on RxC is required with the data on RxD and the serial data bit is latched on the falling edge of each clock puise. The requirement for the detection of a valid start bit, or the beginning of a break, is satisfied by the detection of a high-to-low transition on the serial data input line. Error detection and status indication are the same as the asynchronous mode.

## Asynchronous and Isochronous Transmit

In asynchronous and isochronous transmit modes, output data tansmission on TxD begins with the start bit. This is followed by the data character which is transmitted LSB first. If parity generation is enabled, the parity bit is transmitted after the MSB of the character.


Figure 4. Asynchronous and Isochronous Frame Format

## SYNCHRONOUS MODES

In synchronous modes, a one-times clock is provided along with the data. Serial output data is shifted out and input data is latched on the falling edge of the clock.

## BIT ORIENTED PROTOCOLS (BOP)

In bit oriented protocols (BOP), messages (data) are transmitted and received in frames. Each frame contains an opening flag, address field, control field, frame check sequence, and a closing flag. A frame may also contain an information field. (See Figure 5).
The opening flag is a special character whose bit pattern is 01111110 . It marks the frame boundaries and is the interframe fill character. The address field of a frame contains the address of the secondary station which is receiving or responding to a command. The address field may be one or more bytes long. The address field can be extended by setting the ADDEX bit to a 1 in PSR1. In this case, the address field will be extended until the occurrence of an address byte with a 1 in bit 0 . Up to two bytes of the address field may be automatically checked when the MPCC is programmed to be a secondary station in BOP. An automatic check for global (11111111) or null ( 00000000 ) address is also made. The control field of one or two bytes is transparent to the MPCC and sent directly to the host without interpretation.
The optional information field consists of 8-bit characters. Cyclic redundancy checking is used for error detection and the CRC remainder resulting from the calculation is transmitted as the frame check sequence field. For BOP, the polynomial $X^{16}+X^{12}$ $+X^{5}+1$ (CRC-CCITT) should be used, i.e., selected in the CRC SEL bits in the ECR. The registers representing the CRC-CCITT polynomial are generally preset to all 1s, and the 1 s complement of the resulting remainder is transmitted. (See X. 25 Recommendation.)

Zero insertion/deletion is employed to prevent valid frame data from being confused with the special characters. A 0 is inserted by the transmitter after every fifth consecutive 1 in the data stream. These inserted zeros are removed by the receiver to restore the data to its original form. The inserted zeros are not included in the CRC calculation.

The end of the frame is determined by the detection of the closing Flag special character which is the same is the opening Flag.

With the control options offered by the MPCC, commonly used bit oriented protocols such as SDLC, HDLC and X. 25 standards can be supported. Figure 6 compares the requirements of these options.

## BOP Receiver Operation

In BOP, the receiver starts assembling characters and accumulating CRC immediately after the detection of a Flag. The receiver also continues to search for additional Flag, or Abort, characters on a bit-by-bit basis. Zero deletion is implemented in the Receiver Shift Register after the Flag detection logic and before the CRC circuitry. The receiver recognizes the shared flag (the closing flag for one frame serves as the opening flag for the next frame) and the shared zero (the ending 0 of a closing flag serves as the beginning 0 of an opening flag forming the pattern "0111111011111110."

Character assembly and CRC accumulation are stopped when a closing Flag or Abort is detected. The CRC accumulation includes all the characters between the opening Flag and the closing Flag. The contents of the CRC register are checked at the close of a frame and the C/PERR bit in the RSR is updated. The FCS and the Flag are not passed on to the RxFIFO.

If the Flag is a closing flag, checks for short frame (no control field) and CRC error conditions are made and the appropriate status is updated. When an Abort (seven 1s) is detected, the remaining frame is discarded and the RA/B bit is set in the RSR. When a link idle ( 15 or more consecutive 1s) is detected, the RIDLE status bit is set in the RSR. The zeros that have been inserted to distinguish data from special characters are detected and deleted from the data stream before characters are assembled. The MPCC programmed as a secondary station provides automatic address matching of up to two bytes. If there is no address match, the receiver (secondary station) ignores the remainder of the frame by searching for the Flag. If there is a match, the address bytes are transferred to the RxFIFO as they are assembled.

| flag 0111110 | ADDRESS bytes | $\begin{aligned} & \text { CONTROL } \\ & \text { 10 } \\ & 2 \text { B BTTES } \end{aligned}$ | INFORMATION N BYTES (OPTIONAL) | FCS 2 BYTES | flag 01111110 |
| :---: | :---: | :---: | :---: | :---: | :---: |

Figure 5. Bit Oriented Protocol (BOP) Frame Format
IBM SDLS FRAME FORMAT

| FLAG <br> 01111110 | ADDRESS <br> 1 BYTE | CONTROL <br> 1 BYTE | INFORMATION N BYTES | FCS <br> 2 BYTES | $\begin{aligned} & \text { FLAG } \\ & 01111110 \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |

## ADCCP/HDLC FRAME FORMAT

| FLAG <br> 01111110 | ADDRESS <br> N BYTES | CONTROL <br> 1 OR <br> 2 BYTES | INFORMATION <br> N BYTES | FCS <br> 2 | BYTES |
| :--- | :--- | :--- | :--- | :--- | :--- |

Figure 6. Implemented Bit Oriented Protocols

For the control field, one or two bytes are assembled and passed on to the RxFIFO depending on the state of the extended control field bit.

If the CFCRC bit in the ECR is set to 1 , an intermediate CRC check will be made after the address and control field. The Frame Check Sequence is still calculated over the remainder of the frame.

## BOP Transmitter Operation

In BOP, the TxFIFO can be preloaded through the TDR while the transmitter is disabled (TEN $=0$ in the TCR). When the transmitter is enabled (TEN = 1 in the TCR), the leading Flag is automatically sent prior to transmitting data from the TxFIFO. The TDRA bit is set to 1 in the TSR as long as TxFIFO is not full. If an underrun occurs, the TUNRN bit in the TSR is set to a 1 and an Abort (11111111) is transmitted followed by continuous Flags or marks until a new sequence is initiated.

The TLAST bit in the TCR must be set prior to loading the last character of the message to signal the transmitter to append the two-byte Frame Check Sequence (FCS) following the last character. If the transmitter DMA mode is selected (the TDSREN bit set to 1 in the TCR) the TLAST bit is set by the DONE signal from the DMAC.

A message may be terminated at any time by setting the TABT bit in the TCR to 1. This causes the transmitter to send an Abort character followed by the remainder of the current frame data in the TxFIFO.

The serial data from the Transmitter Shift Register is continuously monitored for five consecutive 1s, and a 0 is inserted in the data stream each time this condition occurs (excluding Flag and Abort characters).

CRC accumulation begins with the first non-Flag character and includes all subsequent characters. The CRC remainder is transmitted as the FCS following the last data character. If the CTLCRC bit in the ECR is set to 1 , an intermediate CRC remainder is appended after the Address and Control field. The final Frame Check Sequence is calculated over the balance of the frame.

## BISYNC (BSC)

The structure of messages utilizing the IBM Binary Synchronous Communications (BSC) protocol, commonly called Bisync, is shown in Figure 7. The MPCC can process both transparent and nontransparent messages using either the EBCDIC or the ASCII codes. The CRC-16 polynomial should be selected by setting the appropriate CRCSEL bits in the ECR for both transparent and
non-transparent EBCDIC and for transparent ASCII coded messages. VRC/LRC should be selected for non-transparent ASCII coded messages. BSC messages are formatted using defined data-link control characters. Data-link control characters generated and recognized by the MPCC are listed in Table 4.

Table 4. BSC Control Sequences-Inclusion in CRC Accumulation

| ASCII |  |  | EBCDIC |  |  |
| :--- | :---: | :---: | :--- | :---: | :---: |
| Command | Byte 1 | Byte 2 | Command | Byte 1 | Byte 2 |
| SYN | $16^{*}$ | - | SYN | $32^{*}$ | - |
| SOH | 01 | - | SOH | 01 | - |
| STX | 02 | - | STX | 02 | - |
| ETB | 17 | - | EOB (ETB) | 26 | - |
| ETX | 03 | - | ETX | 03 | - |
| ENQ | 05 | - | ENQ | $2 D$ | - |
| DLE | 10 | - | DLE | 10 | - |
| ITB | $1 F$ | - | ITB | $1 F$ | - |
| EOT | 04 | - | EOT | 37 | - |
| ACK N* | 10 | $30-37$ | ACK 0 | 10 | 70 |
| NAK | 15 | - | ACK 1 | 10 | 61 |
| WACK | 10 | $3 B$ | NAK | $3 D$ | - |
| RVI | 10 | $3 C$ | WACK | 10 | $6 B$ |
|  |  | RVI | 10 | $7 C$ |  |
|  |  |  |  |  |  |
| Note: *Programmable |  |  |  |  |  |

A heading is a block of data starting with an SOH and containing one or more characters that are used for message control (e.g., message identification, routing, and priority). The SOH initiates the block-check-character (BCC) accumulation, but is not included in the accumulation. The heading is terminated by STX when it is part of a block containing both heading and text. A block containing only a heading is terminated with an ITB or an ETB followed by the BCC. Only the first SOH or STX in a transmission block following a line turnaround causes the BCC to reset. All succeeding STX or SOH characters are included in the BCC. This permits the entire transmission (excluding the first SOH or STX) to be block-checked.

The text data is transmitted in complete units called messages, which are initiated by STX and concluded with ETX. A message can be subdivided into smaller blocks for ease in processing and more efficient error control. Each block starts with STX and ends with ETB (except for the last block of a message, which ends with ETX). A single transmission can contain any number of blocks (ending with ETB) or messages (ending with ETX). An EOT following the last ETX block indicates a normal end of transmission. Message blocking without line turnaround can be accomplished by using ITB (see the Additional Data Link Capabilities section, IBM GA 27-3004-2).

| LEADING PAD | SYN | SYN | BODY | BCC |
| :--- | :--- | :--- | :--- | :--- |
| 1 BYTE <br> (AR1) | BYTE <br> (AR2) |  |  |  |

Figure 7. BSC Block Format


Figure 8. BSC Message Format Examples

Two modes of data transfers are used in BSC. In non-transparent mode, data link control characters may not appear as text data. In transparent mode, each control character is preceded by a data link escape (DLE) character to differentiate it from the text data. Table 5 indicates which control characters are excluded in the CRC generation. All characters not shown in the table are included in the CRC generation. Figure 8 shows various formats for Control/Response Blocks and Heading and Text Blocks.

Table 5. BSC Control Sequences - Inclusion
in CRC Accumulation

| Character of Sequence | Included in CRC Accumulation |  |
| :---: | :---: | :---: |
|  | Yes | No |
| TSOH | - | DLESYN |
| TSTX* | - | DLESOH |
| TETB | ETB | DLESTX |
| TETX | ETX | DLE |
| TDLE | (DLE)DLE | DLE(DLE) |

*If not preceded within the same block by transparent heading information.

## BSC Receiver Operation

Character length defaults to eight bits in BSC mode. When ASCII is selected, the eighth bit is used for parity provided that VRC/LRC polynomial is selected. Character assembly starts after the receipt of two consecutive SYN characters. Serial data bits are shifted through the Receiver Shift Register into the Serial-to-Parallel Register and transferred to the RxFIFO. The RDA status bit in the RSR is set to 1 each time data is transferred to the RxFIFO. The SYN character in non-transparent mode and DLE-SYN pairs in transparent mode are discarded.

The receiver starts each block in the non-transparent mode. It switches to transparent mode if a block begins with a DLE-SOH or DLE-STX pair. The receiver remains in transparent mode until a DLE-ITB, DLE-ETB, DLE-ETX or DLE-ENQ pair is received. BCC accumulation begins after an opening SOH, STX, or DLESTX. SYN characters in non-transparent mode or DLE-SYN pairs in transparent mode are excluded from the BCC accumulation. The first DLE of a DLE-DLE sequence is not included in the BCC accumulation and is discarded. The BCC is checked after receipt of an ITB, ETB, or ETX in non-transparent mode or DLE-ITB, DLEETB, DLE-ETX in transparent mode. If a CRC error is detected, the C/PERR and EOF bits in the RSR are set to 1. If no error
is detected only the EOF bit is set. If the closing character was an ITB, BCC accumulation and character assembly starts again on the first character following the BCC.

## BSC Transmitter Operation

BSC transmission begins with the sending of an opening pad (PAD) and two sync (SYN) characters. These characters are programmable and stored in AR1(PAD) and AR2(SYN). SOH or STX initiates the block-check-character (BCC) accumulation. An initial SOH or STX is not included in the BCC accumulation. Should an underrun condition occur, the content of AR2 (normally SYN character) is transmitted until new characters become available. The message is terminated by the transmission of the BCC followed by a closing pad when an ETB, ITB, or ETX is fetched from the TXFIFO. The closing PAD is generated by the MPCC.

In transparent mode, the BCC accumulation is initiated by DLESTX and is terminated by the sequences DLE-ETX, DLE-ETB, or DLE-ITB. See Table 5 for character sequence and inclusion in CRC accumulation. If an underrun occurs, DLE-SYN characters will be transmitted until new characters are available in the TXFIFO, ETC, ETX, ITB, or ENQ with a TLAST tag is treated as a control character and the MPCC automatically inserts a DLE immediately preceding these characters, DLE-ETB, DLE-ETX, DLE-ITB, or DLE-ENQ terminates a block of transparent text, and returns the data link to normal mode. BCC generation is not used for messages beginning with characters other than SOH, STX, DLE-SOH, or DLE-STX. On all message types, if the TSYN bit is set to 1 in the TCR, a SYN-SYN (DLE-SYN sequence on transparent messages) sequence is transmitted before the next character is fetched from the TxFIFO.

## CHARACTER ORIENTED PROTOCOLS

The character oriented protocol (COP) option uses the format shown in Figure 9. It may be used for various character oriented protocols with 5-8 bit character sizes and optional parity checking. The input data is checked on a bit-by-bit basis for a pair of consecutive SYN characters to establish character synchronization. These SYN characters are discarded after detection. The PAD and SYN characters may be 5-8 bits long and are user programmable as stored in AR1 and AR2, respectively.

If parity checking is enabled the characters assembled after character sync are checked for parity errors. If STRSYN is set in the RCR, all SYN characters detected within the message will be discarded and will not be passed on to the RxFIFO. If STRSYN is reset, SYNs detected within the message will be treated as data.


Figure 9. Character Oriented Protocol Format


Figure 10. Typical Interface to $\mathbf{6 8 0 0 0}$-Based System


Figure 11. Typical Interface to 68008-Based System


1

Figure 12. MPCC Read Cycle Timing


NOTES:

1. BYTE MODE WHEN CONNECTED TO AO ON 68008 BUS.
2. WORD MODE WHEN CONNECTED TO UDS ON 68000 BUS.
3. TIMING MEASUREMENTS ARE REFERENCED TO AND FROM A LOW VOLTAGE OF 0.8 VOLTS AND A HIGH VOLTAGE OF 2.0 VOLTS, UNLESS OTHERWISE NOTED.

Figure 13. MPCC Write Cycle Timing


Figure 14. MPCC to Memory DMA Transfer Cycle Timing (Receiver DMA Mode)


NOTES:

1. TIMING MEASUREMENTS ARE REFERENCED TO AND FROM A LOW VOLTAGE OF 0.8 VOLTS AND A HIGH VOLTAGE OF 2.0 VOLTS UNLESS OTHERWISE NOTED.
2. WORD MODE ONLY.

Figure 15. Memory to MPCC DMA Transfer Cycle Timing (Transmitter DMA Mode)


NOTES:

1. timing measurements are referenced to and from a low voltage of 0.8 Volts and a high VOLTAGE OF 2.0 VOLTS, UNLESS OTHERWISE NOTED.
2. IRQ IS NEGATED WHEN ALL BITS IN STATUS REGISTERS THAT COULD HAVE CAUSED THE INTERRUPT ARE CLEARED.

Figure 16. Interrupt Request Cycle Timing


Figure 17. Serial Interface


LOW SPEED APPLICATION (RS-232 COMPATIBLE)


Figure 18. Serial Interface Timing


NOTE:
TIMING MEASUREMENTSS ARE REFERENCED TO AND FROM A LOW VOLTAGE OF 0.8 VOLTS AND A HIGH VOLTAGE OF 2.0 VOLTS, UNLESS OTHERWISE NOTED.

Figure 19. Serial Interface Echo Mode Timing

## AC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Number | Parameter | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | R/ $\bar{W}$ High to $\overline{C S}, \overline{\text { DS }}$ Low | $\mathrm{t}_{\text {RHSL }}$ | 0 | - | ns |
| 2 | Address Valid to CS, $\overline{\mathrm{DS}}$ Low | $t_{\text {AVSL }}$ | 30 | - | ns |
| $3^{(1)}$ | $\overline{C S}$ Low to DTACK Low | $\mathrm{t}_{\text {CLDAL }}$ | 0 | 60 | ns |
| 4(1) | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ Low to Data Valid | $\mathrm{t}_{\text {SLOV }}$ | 0 | 140 | ns |
| 5 | $\overline{C S}, \overline{\overline{D S}}$ High to Data Invalid | $\mathrm{t}_{\text {SHDXR }}$ | 10 | 150 | ns |
| 6 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High to $\overline{\text { DTACK }}$ High | $\mathrm{t}_{\text {SHDAT }}$ | 0 | 40 | ns |
| 7. | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High to Address Invalid | $t_{\text {SHAI }}$ | 20 | - | ns |
| 8 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High to R/ $\overline{\mathrm{W}}$ Low | $t_{\text {SHAL }}$ | 20 | - | ns |
| 9 | R/ $\bar{W}$ Low to $\overline{C S}, \overline{\mathrm{DS}}$ Low | $\mathrm{t}_{\text {RLSL }}$ | 0 | - | ns |
| 10 | $\overline{\mathrm{CS}}$ High, $\overline{\mathrm{DS}}$ High to R/W High | $\mathrm{t}_{\text {SHRH }}$ | 20 | - | ns |
| 11 | Data Valid to $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High | $\mathrm{t}_{\text {DVSH }}$ | 60 | - | ns |
| 12 | $\overline{\overline{C S}}, \overline{\mathrm{DS}}$ High to Data Invalid | $\mathrm{t}_{\text {SHDXW }}$ | 0 | - | ns |
| 17 |  | $\mathrm{t}_{\text {clsh }}$ | 60 | - | ns |
| 18 |  | $\mathrm{t}_{\text {ALDV }}$ | 0 | 140 | ns |
| 19 | $\overline{\overline{D S}}$ High to Data Invalid | $\mathrm{t}_{\text {SHDXDR }}$ | 10 | 150 | ns |
| 21 | Data Valid to $\overline{\mathrm{DS}}$ High | $\mathrm{t}_{\text {bVSH }}$ | 60 | - | ns |
| 22 | $\overline{\mathrm{DS}}$ High to Data Invalid | $\mathrm{t}_{\text {SHDXDW }}$ | 0 | - | ns |
| 25 | $\overline{\text { IACK }}$ Low to $\overline{\text { DTACK }}$ Low | $t_{\text {laLaL }}$ | 0 | 40 | ns |
| 26 | $\overline{\text { IACK, }} \overline{\mathrm{DS}}$ Low to Data Valid | $\mathrm{t}_{\text {IALDV }}$ | 0 | 140 | ns |
| 27 | $\overline{\mathrm{DS}}$ High to Data Invalid | $\mathrm{t}_{\text {ISHDI }}$ | 10 | 150 | ns |
| 28 | $\overline{\text { IACK High to DTACK High }}$ | $\mathrm{t}_{\text {IAHDAT }}$ | 0 | 40 | ns |
| 30 | RxC and TxC Period | $\mathrm{t}_{\mathrm{CP}}$ | 248 | - | ns |
| 31 | TxC Low to TxD Delay | ${ }_{\text {tclid }}$ | 0 | 200 | ns |
| 32 | RxC Low to RxD Transition (Hold) | $\mathrm{t}_{\text {RCLRD }}$ | 0 | - | ns |
| 33 | RxD Transition to RxC Low (Setup) | $\mathrm{t}_{\text {RORCL }}$ | 30 | - | ns |
| 34 | RxD to TxD Delay (Echo Mode) | $\mathrm{t}_{\text {RDTD }}$ | - | 200 | ns |
| 35 | R/ $\bar{W}$ Low to $\overline{\text { DTACK }}$ Low (Setup) | $\mathrm{t}_{\text {RLAL }}$ | 0 | - | ns |
| 36 | $\overline{\text { DACK High to } \overline{\text { DONE }} \text { High }}$ | $\mathrm{t}_{\text {AHDH }}$ | 0 | - | ns |

Note:

1. For read cycle timing, the MPCC asserts $\overline{\text { DTACK }}$ within the MPU S4 clock low setup time requirement and establishes valid data (Data In) within the MPU S6 clock low setup time requirement.

## ABSOLUTE MAXIMUM RATINGS*

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

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

## THERMAL CHARACTERISTICS

| Parameter | Symbol | Value | Rating |
| :---: | :---: | :---: | :---: |
| Thermal Resistance | $\theta_{\mathrm{JA}}$ |  | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic |  | 50 |  |
| Plastic |  | 68 |  |

## OPERATING CONDITIONS

| Parameter | Range |
| :---: | :---: |
| $V_{\mathrm{CC}}$ Power Supply | $5.0 \mathrm{~V} \pm 5 \%$ |
| Operating Temperature | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage All Inputs | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| Input Low Voltage All Inputs | $\mathrm{V}_{\text {IL }}$ | -0.3 | +0.8 | V |  |
| $\begin{aligned} & \text { Input Leakage Current }\left(V_{I N}=0 \text { to } 5.25 \mathrm{~V}\right) \\ & \mathrm{R} \overline{\mathrm{~W}}, \overline{\text { RESET, }} \overline{\mathrm{CS}} \end{aligned}$ | IN | - | 10.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\mathbb{I N}}=0 \text { to } 5.25 \mathrm{~V} \\ & V_{C C}=0 \end{aligned}$ |
| Three-State (Off State) Input Current ( $\mathrm{V}_{\mathrm{IN}}=0.4$ to 2.4) $\overline{\text { RQQ }}, \overline{\text { DTACK }}, ~ D 0-D 15$ | $\mathrm{T}_{\text {TSI }}$ | - | 10.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=0.4 \text { to } 2.4 \mathrm{~V} \\ & V_{C C}=5.0 \mathrm{~V} \end{aligned}$ |
| Output High Voltage <br> $\overline{R D S R}, \overline{T D S R}, \overline{I R Q}, \overline{D T A C K}, D 0-D 15, \overline{D S R}, \overline{D T R}, \overline{R T S}$, TxD, TxC | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\text {ss }}+2.4$ | - | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-400 \mu \mathrm{~A} \\ & \mathrm{C}_{\text {LOAD }}=130 \mathrm{pF} \end{aligned}$ |
| BCLK | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{v}_{\text {Ss }}+2.4$ | - | V | $\begin{aligned} & V_{C C}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=0 \\ & \mathrm{C}_{\text {LOAD }}=30 \mathrm{pF} \end{aligned}$ |
| Output Low Voltage <br> $\overline{\text { RDSR }}, \overline{T D S R}, \overline{I R Q}, \overline{D T A C K}$ DO-D15, $\overline{D S R}, \overline{D T R}, \overline{R T S}$, TxD, TXC, BCLK, | $\mathrm{V}_{\text {OL }}$ | - | 0.5 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=3.2 \mathrm{~mA} \end{aligned}$ |
| $\overline{\text { DONE }}$ |  |  |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{l}_{\mathrm{LOAD}}=8.8 \mathrm{~mA} \end{aligned}$ |
| Internal Power Dissipation | Pint | - | 1 | W | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | 13 | pF | $\begin{aligned} & V_{\mathbb{I N}}=O V \\ & T_{A}=25^{\circ} \mathrm{C} \\ & f=1 \mathrm{MHZ} \end{aligned}$ |

## PACKAGE DIMENSIONS

## 48-PIN CERAMIC DIP



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

## PRELIMINARY

## DESCRIPTION

The R68802* Local Network Controller (LNET) implements the IEEE 802.3 CSMA/CD Access Method local network standard. More generally, it is designed to support a variety of local network designs with varying performance requirements.

The basic function of the LNET is to execute the CSMACD algorithm, perform parallel-to-serial and serial-to-parallel conversions of the 10 M bps packet data stream, and assemble and disassemble the packet format. In addition, the LNET provides the necessary asynchronous handshake signals to the 68000 family processors, the required DMA interfaces, and the proper interface to the Manchester Interface (MI) component(s) used to connect the LNET to an IEEE 802.3 defined Media Attachment Unit (MAU).

The controller can interface data terminal equipment to local networks with differing performance requirements. At the high end, the R68802 meets the IEEE 802.3 10M bps specification and supports the implementation of ISO layers one and two. For low cost networks, the controller can be run at greatly reduced data rates and inexpensive system components (drivers, cables, etc.) may be selected.

The LNET controller implements a protocol known as Carrier Sense Multiple Access with Collision Detection (CSMA/CD), which allows multiple Data Terminal Equipment to share the same communication medium without the need for a central arbiter of medium utilization.

Ethernet nodes needing to transmit wait exactly $9.6 \mu \mathrm{~s}$ before transmitting data to provide recovery time for other controllers and the cable itself. If a collision with another station is detected, the transmission is aborted and a jam signal transmitted to alert other nodes. Following a jam, the station waits a random amount of time based on a Binary Exponential Back-off algorithm before retransmitting. Repeated collisions result in repeated retries and an increase in the randomly selected time interval to improve trafficking.

## ORDERING INFORMATION

Part Number
R68802_ Temperature Range: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

Package:
$\mathrm{C}=$ Ceramic
$\mathrm{P}=$ Plastic

## FEATURES

- Serial data rates as high as 10 M bps
- Compatible with a variety of 8- or 16-bit processors and DMA controllers
- Meets the IEEE 802.3 (as well as Ethernet*) specifications for local networks
- Interfaces to SEEQ 8002 Manchester Code Converter (MCC)
- Programmable interframe wait times for smaller topologies and lower data rates
- CSMACD algorithm:
-Wait before transmit
- Jam on collision
-Binary exponential backoff
- Programmable 2- or 6-byte address recognition
- Supports three modes of node self-test
- Programmable disable on reception
- 32-bit CRC generation and reception
- Broadband applications
- TTL compatible I/O
- 40-pin DIP
- Single 5V power supply
-R68802 is a trademark of the Rockwell Intemational Corporation.
*Ethernet is a trademark of the Xerox Corporation.

| vcc $\square^{1}$ | 40 | MAUREQ |
| :---: | :---: | :---: |
| R/W-2 | 39 | $\square$ MAUAVAIL |
| RESET- 3 | 38 | $\square$ ISOLATE |
| D0-4 | 37 | $\square$ TXCLK |
| D1-5 | 36 | $\square$ TXDATA |
| D2-6 | 35 | $\square$ TXEN |
| D3-7 | 34 | $\square$ SIGQUAL |
| D4-8 | 33 | ص SENSE |
| D5-9 | 32 | $\square$ RXCLK |
| D6-10 | 31 | $\square$ RXDATA |
| D7-11 | 30 | $\square$ MILOOP |
| D8- 12 | 29 | $\square$ TXPEQ |
| D9 - 13 | 28 | $\square$ PXREQ |
| D10-14 | 27 | D $\overline{\text { DACK }}$ |
| D11-15 | 26 | $\square$ DONE |
| D12-16 | 25 | $\square \mathrm{IRa}$ |
| D13-17 | 24 | ص DTACK |
| D14-18 | 23 | صDS |
| D15 -19 | 22 | $\overline{\text { İCK }}$ |
| CS $\square^{20}$ | 21 | صGND |

R68802 Pin Assignments



## PIN DESCRIPTION

Throughout the document, signals are presented using the terms active and inactive or asserted and negated independent of whether the signal is active in the high-voltage state or lowvoltage state. (The active state of each logic pin is described below.) Active low signals are denoted by a superscript bar. $R / \bar{W}$ indicates a write is active low and a read active high.


Figure 2. LNET Input and Output Signals

D0-D15-Data Lines. The bidirectional data lines transfer data between the LNET and the MPU, memory or other peripheral device. D0-D15 are used when connected to the 16-bit 68000 bus and operating in the word mode. DO-D7 are used when connected to the 16 -bit 68000 bus or the 8 -bit 68008 bus and operating in the byte mode. The data bus is tri-stated when $\overline{\mathrm{CS}}$ is inactive. (See exceptions in DMA mode.)
$\overline{\mathbf{C S}}$-Chip Select. $\overline{\mathrm{CS}}$ low selects the LNET for programmed transfers with the host. The LNET is deselected when the $\overline{\mathrm{CS}}$ input is inactive in non-DMA mode. $\overline{C S}$ must be decoded from the address bus and gated with address strobe ( $\overline{\mathrm{AS}}$ ).
$\mathbf{R} / \bar{W}$-Read/Write. $\mathrm{R} / \overline{\mathrm{W}}$ controls the direction of data flow through the bidirectional data bus by indicating that the current bus cycle is a read (high) or write (low) cycle.
$\overline{\text { DTACK-Data Transfer Acknowledge. } \overline{\text { DTACK }} \text { is an active }}$ low output that signals the completion of the bus cycle. During read or interrupt acknowledge cycles, DTACK is asserted by the LNET after data has been provided on the data bus; during write cycles it is asserted after data has been accepted at the data bus. A pull up resistor is required to maintain DTACK high between bus cycles.
$\overline{\mathrm{DS}}$-Data Strobe. During a write ( $\mathrm{R} / \overline{\mathrm{W}}$ low), the $\overline{\mathrm{DS}}$ positive transition latches data from the external data bus lines into the LNET. During a read (R/W high), $\overline{\mathrm{DS}}$ low enables data from the LNET onto data bus lines.
$\overline{\mathbf{I R Q}}$-Interrupt Request. The active low $\overline{\mathrm{IRQ}}$ output requests interrupt service by the MPU.
$\overline{\text { IACK_Interrupt Acknowledge. The active low } \overline{\text { IACK }} \text { input }}$ indicates that the current bus cycle is an interrupt acknowledge cycle. When $\overline{\mathrm{IACK}}$ is asserted the LNET places an interrupt vector on the lower byte (D0-D7) of the data bus.
$\overline{\text { DACK-DMA Acknowledge. The } \overline{\text { DACK }} \text { low input indicates }}$ that the data bus has been acquired by the DMAC and that the requested bus cycle is beginning.
$\overline{\text { DONE }}-$ Done. $\overline{\text { DONE }}$ is a bidirectional active low signal. The DONE signal is asserted by the DMAC when the DMA transfer count is exhausted and there is no more data to be transferred, or is asserted by the LNET when either the last byte of receive data is transferred or a collision is detected during a transmission.
$\overline{\text { RESET}}$-Reset. The active low, high impedance $\overline{\text { RESET }}$ input initializes all LNET functions. $\overline{\text { RESET must be asserted for at }}$ least 500 TXCLKs to initialize the LNET.

RXREQ-Receive DMA Request. When receive data becomes available in the RXFIFO, RXREQ output is asserted and held low for 16 (single address burst mode) DMAC cycles (16 sequential DACK pulses) or until the end of the receive block. When the last data byte of the receive block is transferred, $\overline{\text { DONE }}$ is asserted by the LNET with the last DACK strobe and the negation of RXREQ.

TXREQ-Transmit DMA Request. When the Transmitter Enable bit is set in Command Register 1, TXREQ output is asserted and held low for 16 (single address burst mode) DMAC cycles ( 16 sequential DACK pulses) or until the end of the transmit data block as signaled by the DMAC's assertion of $\overline{\mathrm{DONE}}$.

MILOOP-MI Loopback. With an active MILOOP output, the MI shunts its LNET data-in path to its LNET data-out path, effectively routing the LNET TXDATA output into the LNET RXDATA input.

RXDATA-Receive Data. The LNET receives serial data via the RXDATA input. The RXDATA input is shifted into the receiver on the positive going edge of RXCLK.

RXCLK-Receive Clock. The free-running Receive Clock provides the LNET with received data timing information. The positive (low-to-high) clock transition enables an RXDATA bit into the LNET.

SENSE-Carrier Sense. The active high SENSE input indicates the presence of data on the RXDATA serial input line.

SIGQUAL-Signal Quality. The assertion of the active high SIGQUAL input by the MI indicates an error condition on the medium. During the transmission mode the LNET interprets this as a collision.

TXEN-Transmit Enable. The active high TXEN output indicates to the MI that data is present on the TXDATA output.

TXDATA-Transmit Data. The LNET transmits serial data on the TXDATA line. The TXDATA output changes on the positive going edge of TXCLK.

TXCLK-Transmit Clock. The Transmit Clock input is a freerunning clock supplied by the MI that provides both a system clock and a means of shifting out serial data bit on the TXDATA output line.

ISOLATE-Isolate MAU. The active low ISOLATE output is asserted when the Isolate bit in Command Register 1 is set to 1 to isolate the MAU from the medium. As long as ISOLATE is low, the MAU is unable to transmit or receive on the medium.

MAUAVAIL-MAU Available. When the active low MAUAVAIL input is asserted, the transmission algorithm can proceed.

MAUREQ-MAU Request. The active low MAUREQ output is asserted prior to transmission if MAUAVAIL is not asserted.

VCC-Power. 5 V $\pm \mathbf{5 \%}$.
GND-Ground. Ground.

## LNET REGISTERS

The LNET contains three groups of registers accessible from the MPU bus which initialize the LNET, control and monitor LNET operation, and transfer data between the LNET and the MPU bus. These register groups, specific registers within each group, and the size, access and mode of each register are listed in Table 1.

All registers, except the Mode Register, may be accessed either in the word or byte mode, depending on the MPU data bus length (8-bit or 16-bit) and the Word/Byte mode selected in bit 4 of the Mode Register during initialization. In the word mode, two registers are read or written during one cycle with the least significant byte (D0-D7) accessed first.

## INITIALIZATION REGISTERS

The initialization registers contain command information to configure the LNET for normal operation. The registers are the onebyte Mode Register (MR); the one-byte Interrupt Vector Number Register (IVNR) and the two- or six-byte Station Address Register (SAR). These registers must be loaded upon RESET (either caused by power up or initiated during normal operation) or upon setting of the RESET bit in Command Register 1. Any of these conditions reset the LNET by clearing the Mode Register, Station Address Register, Command Registers and Status Registers. The Interrupt Vector Number Register is auto-initialized to its default value of $\$ 0 \mathrm{~F}$.

All initialization registers must be written to by the MPU instruction sequence immediately after a reset in the manner decribed below even if no data is changed in a register. The number of bytes written depends upon the number of bytes in the Station Address as selected in bit 4 of the Mode Register.

After the proper number of write cycles have been completed, the LNET Initialized bit in Status Register 1 is set and further MPU writes to the LNET will address only Command Register 1 or Command Register 2. All MPU reads of the LNET after initialization is complete will access only Status Register 1 or Status Register 2.

## Initialization Procedure for 16-Bit MPU Bus

Write cycle 1-write the Mode byte on the lower byte of the data bus D0-D7. The upper byte is not used and can contain any data.

Write cycle 2-write the Interrupt Vector Number on the lower byte of the data bus D0-D7. The upper byte is not used and can contain any data.

Write cycle 3 or write cycles 3 through 5-write the one- or three-word Station Address (depending on the Station Address Size loaded into the Mode Register), least significant words first.

Table 1. LNET MPU Bus Accessible Registers

| Register Group | Register Name | $\begin{gathered} \text { Size } \\ \text { (No. Bytes) } \end{gathered}$ | Access | Reset Value | Mode |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Initialization Registers | Mode Register (MR) | 1 | $\overline{C S}=L, R / \bar{W}=L\left(\right.$ write one byte $\left.{ }^{1}\right)$ | \$00 | MPU Write |
|  | Interrupt Vector Number Register (IVNR) | 1 | $\overline{C S}=L, R / \bar{W}=L\left(\right.$ write one byte $\left.{ }^{2}\right)$ | \$0F |  |
|  | Station Address Register (SAR) | - 2 or 6 | $\overline{\mathrm{CS}}=\mathrm{L}, \mathrm{R} / \overline{\mathrm{W}}=\mathrm{L}$ (write 1 or 3 sequential words or 2 or 6 sequential bytes) | \$00 |  |
| Operating Registers | Command Register 1 (CR1) <br> Command Register 2 (CR2) | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\overline{\mathrm{CS}}=\mathrm{L}, \mathrm{R} / \overline{\mathrm{W}}=\mathrm{L}$ | \$00 | MPU Write |
|  | Status Register 1 (SR1) <br> Status Register 2 (SR2) | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\overline{\mathrm{CS}}=\mathrm{L}, \mathrm{R} / \overline{\mathrm{W}}=\mathrm{H}$ | \$00 | MPU Read |
| Data Buffers | Transmit FIFO Register File (TXFIFO) | 32 | $\overline{\text { TXREQ }}=\mathrm{L}$ | \$xX | DMA Write |
|  | Receive FIFO Register File (RXFIFO) | 32 | $\overline{\text { RXREQ }}=\mathrm{L}$ | \$XX | DMA Read |

## Notes:

1. Second byte of word ignored.
2. Second byte in word mode ignored.

## Initialization Procedure for 8-Bit MPU Bus

Write cycle 1-write the Mode byte on the data bus.
Write cycle 2-write the Interrupt Vector Number on the data bus.

Write cycles 3 through 4 or 3 through 8-write the two- or sixbyte Station Address (depending on the Station Address Size loaded into the Mode Register), least significant bytes first.

## Mode Register (MR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IFWT |  | BYTE | INTCOL | DISRX | NOLC | SAS |

The Mode Register sets conditions during initialization for use during normal operations. It must be the first byte written during initialization. All mode bits are active high, i.e., $=1$. All bits are cleared upon RESET or setting the RESET bit to 1 in Command Register 1.

|  | IFWT -Interframe Wait Time |
| :---: | :---: |
| 7-5 | No. of TXCLKs |
| 000 | 16 |
| 001 | 32 |
| 010 | 48 |
| 011 | 64 |
| 100 | 80 |
| 101 | 96 |
| 110 | 112 |
| 111 | 128 |
| MR |  |
| 4 | BYTE -Data Bus Byte Mode |
| 0 | Select word mode (for use with 16-bit MPU bus). |
| 1 | Select byte mode (for use with 8 -bit MPU bus). |
| MR |  |
| 3 | INTCOL -Interrupt on Collision |
| 0 | Assert only DONE on collision. |
| 1 | Assert $\overline{\mathrm{RQ}}$ and DONE on collision. |
| MR |  |
| $\underline{2}$ | DISRX -Disable Receiver |
| 0 | Enable receiver after each packet reception. |
| 1 | Disable receiver after each packet reception. |
| MR |  |
| 1 | NOLC - No Length Count |
| 0 | Use length count in packet format. |
| 1 | Do not use length count in packet format. |
| MR |  |
| $\underline{0}$ | SAS -Station Address Size |
| 0 | 6 -byte station address. |
| 1 | 2-byte station address. |

Interrupt Vector Number Register (IVNR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Interrupt Vector Number (IVN) |  |  |  |  |  |  |  |

If an interrupt condition occurs (as reported by bits in Status Register 1 and Status Register 2), $\overline{\mathrm{RQ}}$ is asserted to request MPU interrupt service. Upon IACK input assertion, the Interrupt Vector Number (IVN) from the Interrupt Vector Number Register (IVNR) is placed on the data bus (DO-D7). The IVN must be the second byte initialized during LNET initialization. The IVN is set to \$OF upon RESET or setting the RESET bit to 1 in Command Register 1.

## Station Address Register (SAR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Station Address |  |  |  |  |  |  |  |

The Station Address Register holds the Station Address for the Receiver Address Recognition circuitry. The Station Address bytes must be written to the LNET following the Interrupt Vector Number during the initialization sequence. Either two or six bytes must be written, least significant bytes first, depending on the Station Address Size loaded into the Mode Register.

## OPERATING REGISTERS

The command or status registers are addressed during an MPU write or read, respectively, after initialization is complete as indicated by the LNET Initialized bit in Status Register 1. In word mode, both command registers are written during one write cycle. Command Register 1 occupies the lower byte of the word. Likewise, while reading the status registers in word mode, Status Register 1 occupies the lower byte of the word.

## COMMAND REGISTERS

## Command Register 1 (CR1)

Command Register 1 controls the operation of the LNET. All command bits are active high (i.e., $=1$ ).

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RESET | ENRX | RECALL | NOISOL | MILOOP | INLOOP | ODDND | ENMAU |

## CR1

```
7 RESET -Reset
\overline{0}}\mathrm{ Enable LNET operation.
1 Reset LNET.
```

Note: The RESET bit is automatically cleared to 0 upon the completion of the reset sequence. This bit is unaffected by the RESET pin level.

```
CR1
    6 ENRX -Enable Receiver after Packet Reception
    0 Disable receiver after packet reception.
    1 Enable receiver after packet reception. This bit must be
        set after each packet is received to enable reception of
        the next packet only if bit 2 in the Mode Register is set
        at initialization. Reception of the packet clears this bit.
```

Note: This bit is not used if bit 2 in the Mode Register is not set at intitialization.

CR1

## 5 RECALL-Receive All Packets

0 Receive only addressed packets. The address must correspond to the Station Address loaded into the Station Address Register upon initialization.
1 Receive all packets (regardless of address).
CR1
$\frac{4}{0}$ NOISOL $=$ No Issolate Assert ISOLATE to the MI to request that the MAU isolate itself from the medium.
1 Negate ISOLATE to the MI to request that the MAU connect itself to the medium.

CR1
3 MILOOP-Manchester Interface Loopback Test
$\overline{0}$ Negate $\overline{\text { MILOOP }}$ to command MI normal operation.
1 Assert MILOOP to command MI loopback operation.

```
CR1
    2 INLOQP-Internal LNET Loopback Test
        Enable LNET normal operation.
    1 Enable LNET internal loopback operation.
CR1
    1 ODDNO - Odd Number of Bytes
        Transmit even number of bytes in a block.
    1 Transmit odd number of bytes in a block.
CR1
ENMAU -Enable MAUREQ
    Negate MAUREQ.
    Assert MAUREQ.
```

Command Register 2 (CR2)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| Reserved for future use |  |  |  |  |  |  |  |

This register not presently in use. When programming, $\$ 00$ should be written to CR2 to assure future software compatibility. In byte mode, $\$ 00$ must be written to this register following the Command Register 1 write cycle.

## STATUS REGISTERS

The two interrupt driven status registers report the status of the LNET receiver and transmitter operations. Status registers cannot be polled, they can only be read upon interrupt service by the MPU. Status is reported in either discrete or encoded bits. All discrete (or non-encoded) status bits are active high (i.e., $=1$ ).

A change in any of these status bits causes IRQ to be asserted (except as noted). Reading of the status registers resets the individual bit or encoded field that caused the IRQ assertion and negates IRQ (except as noted). In the byte mode, both status registers must be read in consecutive read cycles.

## Status Register 1 (SR1)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| HRTBT | TXSTAT |  | ODD | RXSTAT |  |  |  |

## SR1

7 HRTBT -Heartbeat Absent
Heartbeat present.
1 Heartbeat absent (part of the transmission algorithm is to listen for the heartbeat before posting transmit status. Set concurrent with the transmitter status field.). The Heartbeat test checks the collision detection circuitry by listening for a "ping" within seven TXCLKs after the end of a transmission).

## SR1

6-4 TXSTAT -Transmitter Status
000 Transmitter idle.
001 Transmit successful.
010 Collision (Assertion of SIGQUAL within the first 512 bit times causes $\overline{\mathrm{DONE}}$, or $\overline{\mathrm{DONE}}$ and $\overline{\mathrm{IRQ}}$, to be asserted depending on the state of MR bit 3).
011 Signal Quality error (SIGQUAL asserted after the first 512 bit times).
100 Transmit retry count exceeded.
101 Transmit buffer underflow during transmission (indicates the TXFIFO emptied between the 16th data byte delivered for transmission and the assertion of DONE).
110 Transmit in progress (indicates the real time activity of the TXDATA pin. This state does not set the IRQ bit in SR2 nor cause $\overline{\mathrm{RQ}}$ to be asserted. This bit pattern is not reset to the transmitter idle pattern upon reading SR1.
$111 \overline{\text { MAUAVAIL }}$ changed staté during transmission.
SR1
3 ODD -Odd Number of Receive Bytes
Even number of bytes in the receive packet.
1 Odd number of bytes in the receive packet.

## SR1

2-0 RXSTAT -Receiver Status
000 Receiver idle.
001 Receive successful.
010 Minimum packet size error.
011 Receive buffer overflow.
100 Frame terminated on a non-byte boundary error.
101 Frame Check Sequence (FCS) error.
110 Receive in progress (indicates a valid address has been recognized and $\overline{\text { DONE }}$ has not been asserted. This state does not set the IRQ bit in SR2 nor cause $\overline{\mathrm{RQ}}$ to be asserted. This bit pattern is not reset to the receiver idle pattern upon reading SR1.
111 Reserved

## Status Register 2 (SR2)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IRQ | 0 | INIT | MAUAVAIL |  | COLCNT |  |  |

## SR2

$\frac{7}{\mathbf{7}} \quad$ IRQ An interrupt condition has not occurred and IRQ has not been asserted.
1 An interrupt condition has occurred and $\overline{\mathrm{RQ}}$ has been asserted.

Note: This bit is cleared when SR2 is read and there is no pending interrupt condition.

SR2
$\frac{6}{0} \quad$ Always reads zero.

## SR2

5 INIT -LNET Initialized
LNET initialization not complete.
1 LNET initialization complete (set after the last station address byte has been written).

Note: This bit is cleared upon $\overline{\operatorname{RESET}}$ or RESET bit set in Command Register 1.

SR2

## 4 MAUAVAIL-MAU Available <br> MAU is not available. <br> 1 MAU is available.

Note: This bit is not cleared when SR2 is read.

## SR2

3-0 COLCNT-Collision Count
0000 Zero

1111 Fifteen
Note: Reset to zero when the enable $\overline{\text { MAUREQ }}$ bit is set in CR1. If Mode Register bit 3 is negated the changing count does not generate IRQ interrupts.

## TRANSMIT DATA BUFFER (TXFIFO)

The Transmit data buffer is a 32 -byte FIFO register file (TXFIFO) which can be loaded only by DMA service. One half of the TXFIFO loads data for transmission via the DMAC; the other half holds data currently being transmitted out serially on TXDATA. When the transmitting half is empty it becomes the loading half and the current loading buffer becomes the transmitting half. If the transmitting buffer empties before the loading buffer is fully loaded, $\overline{\mathrm{IRQ}}$ is asserted and the transmitter buffer underflow bit pattern (101) is set in Status Register 1.

The time required to load half the transmitter buffer under DMAC control must be less than the time it takes to serialize out the
transmitting half on TXDATA. From the assertion of TXREQ to the end of the 16th DMAC bus cycle, no more than 128 TXCLKs can elapse.

## RECEIVE DATA BUFFER (RXFIFO)

The Receive data buffer is a 32 -byte FIFO register file (RXFIFO) which can be read only during DMA service. One half of the RXFIFO is a receiving buffer for the data from the Serial-to-Parallel Register; the other half is a reading buffer for the data ready to be transferred to the MPU bus. As soon as the receiving buffer is full, these two halves switched roles. If the receiving buffer is fully loaded before the reading buffer is empty, $\overline{\mathrm{IRQ}}$ is asserted and the receive buffer overflow bit pattern (011) is set in Status Register 1.

The time it takes to unload the reading buffer under DMAC control must be less than the time it takes to load the receiving buffer from RXDATA. The loading time is 128 RXCLKs.

## INPUT/OUTPUT FUNCTIONS

In addition to being directly compatible with the 68000 and the 68008 MPU's, the LNET supports DMA transfers when used with the 68440, 68450, AMZ9516, or AMZ8016 DMA controller. The LNET also provides the necessary synchronous signals for interfacing to the Manchester Interface device.

## MPU INTERFACE

Transfer of data between the LNET and the system bus involves the following signals: Data Bus D0 through D15 and control singals consisting of $\mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{DTACK}}, \overline{\mathrm{CS}}, \overline{\mathrm{IACK}}$, and $\overline{\mathrm{DS}}$.

## 16-Bit MPU Interface

When connecting the LNET to the 16 -bit 68000 MPU data bus, the LNET $\overline{\mathrm{DS}}$ input is connected to the bus $\overline{\mathrm{LDS}}$ line and the LNET D0-D15 data lines are connected to the bus D0-D15 data lines (see Figure 4).

Bit 4 in the Mode Register, left in its default value of 0 during initialization, selects the word mode. In the word mode, a read of both status registers performed with one word read cycle transfers Status Register 1 on D0-D7 and Status Register 2 on D8-D15. A write to the command registers is also accomplished in one cycle which transfers Command Register 1 on D0-D7 and Command Register 2 on D8-D15.

## 8-Bit MPU Interface

When connecting the LNET to the 8 -bit 68008 MPU data bus, the $\overline{\mathrm{DS}}$ input is connected to the bus $\overline{\mathrm{DS}}$ line and the LNET DOD7 data lines are connected to the bus D0-D7 data lines (see Figure 5).

Bit 4 of the Mode Register set to 1 during initialization selects byte mode. In the byte mode, reading of the status registers is performed with two consecutive byte read cycles to enable first Status Register 1 and then Status Register 2 onto DO-D7. Writing to the command registers also requires two consecutive byte write cycles with Command Register 1 transferred first followed by Command Register 2.

## Read/Write Operation

The $R / \bar{W}$ input controls the direction of data flow on the data bus. $\overline{\mathrm{CS}}$ (Chip Select) enables the LNET for access to the internal registers and other operations. When $\overline{\mathrm{CS}}$ is asserted the data I/O buffer acts as an output driver during a read operation, and as an input buffer during a write operation. $\overline{\mathrm{CS}}$ must be decoded from the address bus and gated with address strobe ( $\overline{\mathrm{AS}}$ ).

If the LNET is selected ( $\overline{C S}=$ low $)$ for a read $(R / \bar{W}=$ high $)$, data is placed on the data bus from the status register when the $\overline{\mathrm{DS}}$ is asserted. The LNET asserts Data Transfer Acknowledge (DTACK) concurrent with the output data.

If the LNET is selected ( $\overline{C S}=$ low) for a write $(R / \bar{W}=$ low $), \overline{D S}$ strobes data into the selected register and the LNET asserts $\overline{\text { DTACK }}$ immediately after $\overline{\mathrm{DS}}$ is asserted.

## DMA INTERFACE

During receiving or transmitting data from the MPU bus, the LNET asserts a receive or transmit request ( $\overline{\mathrm{RXREQ}}$ or TXREQ $)$ to the DMAC. A DMA acknowledge (DACK) signal is asserted in response to $\overline{\text { RXREQ }}$ or TXREQ when the DMAC is ready to service the request. Both receive request and transmit request share the same $\overline{\text { DACK }}$ pin; therefore, in the case of DMAC devices with a $\overline{\text { DACK }}$ for each channel, they must be ORed together externally.

## Transmit DMA Request

In servicing the TXREQ, the DMAC writes to the TXFIFO a byte or a word at a time. The TXFIFO input pointer (TIP) is advanced and data latches on the rising edge of $\overline{\mathrm{DS}}$.

## Receive DMA Request

In servicing the RXREQ, the DMAC reads from the RXFIFO a byte or word at a time. Data is enabled out on the falling edge of DACK and the RXFIFO output pointer (ROP) is advanced on the rising edge of DACK. The data lines are tri-stated following the rising edge of $\overline{\mathrm{DACK}}$.

## DONE

$\overline{\text { DONE }}$ is a bidirectional signal line to or from the DMAC. With the AMZ8016 and the AMZ9516, DONE auto-initializes the DMAC back to the start of the packet when a collision occurs during transmission. With the 68440, the DONE output is routed to the 68440's PCL input after gating with TXREQ line. For the 68450 it is necessary for the MPU to reinitialize the DMAC on collision.

## INTERRUPTS

The $\overline{\mathrm{RQ}}$ output asserts when there is status information available after the completion of a transmit or receive transaction. The MPU grants the interrupt by asserting an interrupt acknowledge ( $\overline{\mathrm{IACK}}$ ) signal and reads the interrupt vector when the LNET asserts data transfer acknowledge (DTACK). The subsequent negation of $\overline{\mathrm{ACK}}$ and $\overline{\mathrm{RQ}}$ preceed MPU interrupt processing.

## MANCHESTER INTERFACE (MI) SIGNALS

The abbreviation MI refers to the Manchester Interface component(s) necessary to interface the LNET to an IEEE 802.3 specified Media Access Unit (MAU).

## SENSE (Sense Carrier) Input

The MI asserts SENSE when it has detected a change in Carrier Sense from no carrier present to carrier present. SENSE stays active as long as carrier is present and is negated when the carrier disappears.

## ISOLATE (Isolate Message Request) Output

The LNET asserts ISOLATE to direct the MI to send an Isolate message to the MAU. When ISOLATE is negated, the MI sends a Normal message to the MAU unless the LNET requires that the MAU request message be sent to permit data output.

## MAUREQ (MAU Request) Output

The LNET asserts $\overline{\text { MAUREQ }}$ when CR 1 bit 0 is active. $\overline{\text { MAUREQ }}$ stays active and a MAU request message is sent until the end of a packet transmission.

## $\overline{\text { MAUAVAIL (MAU Available) Input }}$

The MI asserts MAUAVAIL when an MAU available message from the MAU is received. $\overline{M A U A V A I L}$ is negated when an MAU not available message is received from the MAU.

## SIGQUAL (Signal Quality) Input

SIGQUAL is asserted by MI when a Signal Quality Error Message is received from the MAU.

## TXEN (Transmission Enable) Output

The LNET starts a transmission by asserting TXEN and outputs serial data on TXDATA which is Manchester encoded by the MI. TXEN is active until the end of the transmission.

## RXCLK (Receive Clock) Input

RXCLK shifts receive data into the LNET and is free running at 10 MHz , or slower.

## TXCLK (Transmitter Clock) Input

The TXCLK is a free running 10 MHz , or slower, clock used to clock data into the MI and perform operations in the transmitter.

## $\overline{\text { MILOOP (MI Loopback) Output }}$

The $\overline{\text { MILOOP }}$ output signals the MI component(s) that the current data is a test frame and it is to be "looped back" to the LNET instead of being sent to the MAU.

## LNET FUNCTIONAL DESCRIPTION

The LNET transmits and receives serial data on an IEEE 802.3 CSMA/CD Access Method defined communications medium and transfers parallel data to and from a host system under program or DMA control according to the IEEE 802.3 data link specification.

## Frame Format

Serial data transfers synchronously between the LNET and the MI within the frame structure for data communications using local area network media access control (MAC) procedures. Each MAC frame, or packet, consists of eight fields: Preamble, Start Field Delimiter (SFD), Destination Address, Source Address, Length Count, Data, Pad and Frame Check Sequence (FSC). Figure 3 illustrates the frame format.

The Preamble consists of seven bytes of alternating 1's and 0's, i.e., 1010 . . 1010.

The Start Field Delimiter (SFD) consists of one byte of bit pattern 10101011 immediately following the Preamble pattern which indicates the start of a valid frame.

The Destination and Source Addresses are either two or six bytes in length. Addresses may be any one of the following three types: Station Address, Logical Group, or Broadcast. Logical Group and Broadcast Addresses are identified by a 1 in the first bit position received. The first bit of a Station Address is 0 .

The Length Count field is two bytes in length and specifies the Data field length (in an Ethernet application this field is the Type field and the Length Count field in the Mode Register must be initialized appropriately).

The Data field can have a variable number of bytes. If the Data field is less than 46 bytes (in a six-byte address mode), or less than 54 (in a two-byte address mode), pad bytes are added to the frame on transmission to bring the overall packet size up to the minimum size of 72 bytes. The maximum Data field length must be programmed into the DMAC operating with the LNET.

The Frame Check Sequence (FCS) field is four bytes in length.

## Frame Reception

The Receiver consists of the following sections: Delimiter Recognition, Receive CRC, Serial-to-Parallel Register, Receive Length Counter, Address Recognition, and a 32-byte FIFO register file (RXFIFO). These registers are all driven or loaded by RXCLK or a derivative.

In the absence of serial input data from the network bus, the SENSE input from the MI is inactive. The Receive Clock (RXCLK) is free running and the Receiver front end is idling.

The assertion of SENSE defines the beginning of a frame. The rising edge of RXCLK enables SENSE and concurrently the first Preamble bit on RXDATA to the LNET. The falling edge of RXCLK shifts the first bit of the Preamble into the Delimiter Recognition logic and SENSE into the SENSE Detection logic. Delimiter Recognition is deferred for eight RXCLKS after the assertion of SENSE, to give the MI unit time to synchronize on the Preamble.

If sequential zeros are detected during the time the LNET is searching for the double ones delimiter, the packet's reception is aborted.

The Preamble bits are shifted through the Delimiter Recognition logic without result. As the last bit of the Delimiter is shifted in, an internal signal is asserted.

The data is then routed to the Receive CRC and the Serial-toParallel Register. The Byte Alignment and Odd/Even byte monitor is initialized, and a Byte Counter is started.

At the appropriate byte count, the first byte of Destination Address is converted to parallel data, and compared with the first byte of Station Address and loaded into the RXFIFO.

The RXFIFO Input Pointer (RIP) is then advanced by one. The next byte(s) of destination and source addresses are loaded in the same manner. As the two length count bytes are sent to the RXFIFO they are also loaded into the Length Counter. If this field is non-zero it is decremented on each succeeding byte of the packet.

The remainder of the first 16 bytes of the packet are loaded into the RXFIFO (unless the Length Counter reaches its terminal count or the packet terminates).

With 16 bytes buffered, the RXFIFO is half full. $\overline{\text { RXREQ }}$ is now asserted, the receiving half of the buffer becomes the reading half, and the first 16 bytes of receive data are unloaded by advancing the RXFIFO Output Pointer (ROP) as a function of the DMAC's $\overline{\text { DACK }}$ and $\overline{\mathrm{DS}}$ signals. Meanwhile the empty, receiving half, of the RXFIFO continues to fill.

As the 32nd byte of received data is loaded, $\overline{\operatorname{RXREQ}}$ is asserted again and RIP proceeds to the just emptied reading buffer while DMA bus cycles unload the new reading buffer.

The RXFIFO continues to load and unload in this manner throughout the duration of the packet's Data field.

The position of RIP indicates when to load the Length Counter from the data stream, when to check for a valid address, when to assert or negate $\overline{\operatorname{RXREQ}}$ and to flag an overrun of the receive DMA service.

| PREAMBLE | START <br> FIELD <br> DELIMITER <br> (SFD) | DESTINATION ADDRESS | SOURCE ADDRESS | LENGTH COUNT | DATA PAD | FRAME CHECK sequence |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $7$ <br> BYTES | $\begin{aligned} & \mathbf{1} \\ & \text { BYTE } \end{aligned}$ | $2 \text { OR } 6$ BYTES | $\begin{aligned} & 2 \text { OR } 6 \\ & \text { BYTES } \end{aligned}$ | 2 <br> BYTES | VARIABLE NO. OF BYTES | 4 BYTES |

Figure 3. MAC Frame Format

The two-byte Length Counter is located either four or twelve bytes (depending on the address mode) after Valid Delimiter. The Length Counter is decremented every eight RXCLKs. When the Length Counter equals zero, indicating the end of the Data field, RIP is disabled and RXREQ asserts long enough to unload the last bytes.

In the case of a normal termination of the packet, after the last bytes are unloaded, the LNET asserts $\overline{\mathrm{DONE}}$ concurrent with the last DACK strobe and negates RXREQ. The CRC Register continues to calculate over the Pad and Frame Check Sequence fields and the Byte Alignment Checker continues to run until packet end. The state of the Odd/Even byte checker is latched at the time of the Length Counter's terminal count.

The end of the packet is recognized as follows. The last FCS bit shifts in as RXCLK goes low in the normal manner. Two RXCLKs later the negated value of SENSE shifts in. At the next rising edge of RXCLK the CRC syndrom is compared and the result is posted to Status Register 1 and $\overline{\mathrm{RQ}}$ is asserted.

If, during the course of a reception, the Data byte count held by the system exceeds the maximum number ( 1500 bytes for Ethernet), a maximum frame size error is flagged by DONE from the DMAC. The LNET responds by negating $\overline{R X R E Q}$ and clearing the status registers without generating an $\overline{\mathrm{RQ}}$.

## Frame Transmission

The Transmitter consists of the following: Parallel-to-Serial Register, Transmit Length Counter, 32-byte Transmitter FIFO register file (TXFIFO), Transmit CRC Generator, Preamble and Delimiter Generator, Jam Generator, Interframe Delay Counter, and the Binary Exponential Back-Off Counter. These sections are all driven by TXCLK or a derivation.

Frame transmission commences with a MPU write to Command Register 1 setting the Enable MAUREQ bit. The LNET responds by asserting Transmit DMA Request (TXREQ). Under DMA control, 16 bytes are loaded from the MPU bus into the TXFIFO by advancing the TXFIFO Input Pointer (TIP) as a function of $\overline{\text { DACK }}$ and DS. The LNET then negates TXREQ until the first byte of this data has been serialized out.

While the first 16 bytes are being loaded into the TXFIFO, the LNET is monitoring the SENSE input. Upon SENSE negation the Transmitter waits 96 TXCLKS (strict IEEE 802.3 or Ethernet application, otherwise the delay follows whatever is programmed into Mode Register bits 5-7) and then serializes out the first byte of data on TXDATA if the TXFIFO is half full (if it is not half full yet, the LNET returns to monitoring SENSE). If SENSE is active the LNET waits until it is negated and then starts the Interframe Delay Counter.

At the terminal count of the Interframe Delay Counter the first preamble bits are shifted out under TXCLK control and the transmitter begins to monitor the SIGQUAL input. At the same time TXREQ is asserted again and another 16-byte data burst is transferred into the empty half of the TXFIFC.

As the TXFIFO Output Pointer (TOP) advances to the first byte of the most recently filled half of the buffer, $\overline{\text { TXREQ }}$ is again asserted to reload the half just emptied.

Upon the assertion of the $\overline{\mathrm{DONE}}$ input by the DMAC (at the time of the last byte or word transfer), the transmitter finishes serializing the last bytes out, zeros the TXFIFO Input Pointer (TIP) and serializes the contents of the CRC Register out on TXDATA.

If SIGQUAL is asserted by the MIduring the first 512 TXCLKS, the LNET assumes there has been a collision between its own transmission and that of another node in the network. The response of the LNET at its MI interface is to abort the frame transmission after appending a Jam signal consisting of 48 alternating zeros and ones to it. The Jam signal is sent whenever the LNET has successfully contended for the medium and then has been interrupted in its transmission during the collision window.

## DMA TRANSFER MODES

The response of the LNET at its MPU/DMAC interface to a collision is programmable to one of two modes in the Mode Register at initialization.
This allows for the LNET to be used with DMACs of differing capabilities. Specifically, some DMACs need to be reinitialized by the MPU if they are to restart a block transfer that has been aborted by a peripheral's assertion of a $\overline{D O N E}$ and an $\overline{\mathrm{IRQ}}$. Others are capable of automatically re-starting a block by themselves if a DONE is detected during a transfer.

## Mode One: Assert $\overline{\mathrm{IRQ}}$ plus $\overline{\mathrm{DONE}}$ On Collision.

Assertion of SIGQUAL during the first 512 TXCLKS after transmission begins sets the collision code (010) in the encoded Transmitter Status field in Status Register 1 and increments the Collision Count field in Status Register 2 by one. Next, $\overline{\mathrm{IRQ}}$ is asserted, and the Interrupt Vector Number from the Interrupt Vector Number Register is output on the data bus when IACK is asserted.

The MPU processes the interrupt by reading the status registers to determine the cause of the interrupt and to clear the interrupt. The MPU then reinitializes the DMAC and reloads the first 16 bytes of the aborted data packet into the TXFIFO. Meanwhile the LNET is sending the Jam signal followed by a delay interval determined by the Binary Exponential Back-off Counter. At the end of this time interval the LNET begins to transmit the preamble and delimiter again if the TXFIFO has been reloaded with the first 16 bytes of the packet. If the TXFIFO has not been reloaded by the time the Jam signal and the back-off delay interval are over, the LNET will wait for data.

## Mode Two: Assert only $\overline{\text { DONE On Collision. }}$

Upon the assertion of SIGQUAL during the first 512 TXCLKs, the LNET zeros the TIP, asserts DONE to the DMAC concurrent with the next $\overline{\mathrm{DACK}}$ signal, increments the retry count and remains in the transmit mode (TXREQ asserted, etc.), the Jam is sent, and the Back-off delay is observed. In the meantime, 16 bytes of data are loaded into the TXFIFO by the DMAC. The packet is then transmitted as before.

If the MI asserts SIGQUAL after the first 512 TXCLKs, $\overline{\mathrm{IRQ}}$ is asserted and the Transmitter Status field in Status Register 2 is set to 011 .

Figure 4. Typical Interface to $\mathbf{6 8 0 0 0}$-Based System

Figure 5. Typical Interface to 68008-Based System


Figure 7. Manchester Interface Serial Transmitter Timing


NOTE:
Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.

Figure 8. LNET Read Cycle Timing



NOTES: 1. Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.
2. Word mode only.

Figure 10. LNET to Memory DMA Transfer Cycle Timing


NOTES: 1. Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of 2.0 volts, unless otherwise noted.
2. Word mode only.

Figure 11. Memory to LNET DMA Transfer Cycle Timing


NOTE: Timing measurements are referenced to and from a low voltage of 0.8 volts and a high voltage of $\mathbf{2 . 0}$ volts, unless otherwise noted.

Figure 12. Interrupt Request Cycle Timing

## SPECIFICATIONS

AC ELECTRICAL CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{S}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0\right.$ to $70^{\circ} \mathrm{C}$ )

| Number | Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Clock Period | $\mathrm{t}_{\mathrm{CP}}$ | 90 |  | 1000 | ns |
| 2 | Receive Clock Pulse Width | $\mathrm{t}_{\text {cr }}$ | 45 |  | - | ns |
| 3 | Receive Data/Sense Setup | $\mathrm{t}_{\mathrm{RXS}}$ | 30 |  | - | ns |
| 4 | RXDATA, Sense Hold Time | $\mathrm{t}_{\mathrm{RXH}}$ | 20 |  | - | ns |
| 5 | $\overline{\mathrm{IRQ}}$ Delay from RXCLK | $\mathrm{t}_{\text {RID }}$ | 0 |  | 80 | ns |
| 6 | $\overline{\mathrm{DS}}$ to $\overline{\mathrm{RQ}}$ Clear (Status Read) | $t_{\text {DID }}$ | 50 |  | - | ns |
| 7 | TXDATA/TXEN Delay ( $\mathrm{C}_{\mathrm{L}}=35 \mathrm{pF}$ ) | $\mathrm{t}_{\text {TXD }}$ | 20 |  | 60 | ns |
| 8 | SIGQUAL Hold Time | $\mathrm{t}_{\text {CPH }}$ | 0 |  | - | ns |
| 9 | $\overline{\mathrm{IRQ}}$ Delay from SIGQUAL Edge (Optional)* | $\mathrm{t}_{\text {ISD }}$ | 0 |  |  | ns |
| 10 | MAU/MI Control Output Delay | $\mathrm{t}_{\text {MOD }}$ | 0 |  | 80 | ns |
| 11 | R/W High to $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ Low | $\mathrm{t}_{\text {RHSL }}$ | 0 |  | - | ns |
| 12 | $\overline{\text { CS }}$ Low to $\overline{\text { TTACK }}$ Low | $t_{\text {cloal }}$ | 20 | 40 | 80 | ns |
| 13 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High to R/प్W Low | $t_{\text {SHRL }}$ | 20 |  | - | ns |
| 14 | $\overline{\overline{C S}}$ High to $\overline{\text { TTACK }}$ Tristate | $t_{\text {SHDAT }}$ | 20 | 40 | 80 | ns |
| 15 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ Low to Data Valid | $\mathrm{t}_{\text {stov }}$ | 0 |  | 140 | ns |
| 16 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High to Data Invalid | $\mathrm{t}_{\text {SHDI }}$ | 10 |  | 150 | ns |
| 17 | R/W Low to $\overline{\mathrm{CS}}$, $\overline{\mathrm{DS}}$ Low | $\mathrm{t}_{\text {RLSL }}$ | 0 |  | - | ns |
| 18 | $\overline{\text { CS, }} \overline{\mathrm{DS}}$ High to R/W High | $\mathrm{t}_{\text {SHRH }}$ | 20 |  | - | ns |
| 19 | Data Valid to $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High | $t_{\text {DVSH }}$ | 100 |  | - | ns |
| 20 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High to Data Invalid | $\mathrm{t}_{\text {SHDI }}$ | 10 |  | - | ns |
| 21 | $\overline{\text { IACK Low to } \overline{\text { DTACK }} \text { Low }}$ | $\mathrm{t}_{\text {IALAL }}$ | 20 | 40 | 80 | ns |
| 22 | $\overline{\text { IACK }}$ High to $\overline{\text { DTACK }}$ Tristate | $\mathrm{t}_{\text {IAHDAT }}$ | 20 | 40 | 80 | ns |
| 23 | $\overline{\text { IACK }}$ Low to Data Valid | $\mathrm{t}_{\text {Ialdv }}$ | 0 |  | 140 | ns |
| 24 | $\overline{\overline{D S}}$ High to Data Invalid | $\mathrm{t}_{\text {ISHDI }}$ | 10 |  | 50 | ns |
| 25 | $\overline{\text { DACK }}$ Low to $\overline{\text { DONE/ }}$ Data Valid | toldv | 0 |  | 50 | ns |
| 26 | $\overline{\text { DTACK }}$ High to $\overline{\text { DONE }}$ Invalid/Data | $\mathrm{t}_{\text {DHDV }}$ | 0 |  | 40 | ns |
| 27 | $\overline{\text { DS Low to } \overline{\text { DACK }} \text { High }}$ | $t_{\text {dLD }}$ | 0 |  | 50 | ns |
| 28 | $\overline{\text { DS }}$ High to Data Invalid | $\mathrm{t}_{\text {SHDI }}$ | 0 |  | 40 | ns |
| 29 | Data Invalid to $\overline{\mathrm{DS}}$ High | $\mathrm{t}_{\text {DVSH }}$ | 65 |  | - | ns |
| 30 | Clock Low to $\overline{\text { DONE }}$ (to LNET) Low | $\mathrm{t}_{\text {cLDL }}$ | 0 |  | 100 | ns |
| 31 | External $\overline{\text { DONE }}$ Pulse Width | $\mathrm{t}_{\text {EDPW }}$ | 70 |  | 250 | ns |
| 32 | $\overline{\text { DACK }}$ Low to Internal $\overline{\text { DONE }}$ Low Delay | $t_{\text {DLID }}$ |  |  | 80 | ns |
| 33 | $\overline{\text { DACK }}$ High to Internal $\overline{\text { DONE }}$ High Delay | $t_{\text {DHID }}$ |  |  | 80 | ns |
| 34 | $\overline{\text { DONE }}$ Low to $\overline{\text { RXREQ }}$ High | $\mathrm{t}_{\text {DLRXH }}$ |  | 2 |  | RXCLK |
| 35 | $\overline{\overline{D S}}$ High to $\overline{\mathrm{IRQ}}$ High | $\mathrm{t}_{\text {DSHIH }}$ |  | 2 |  | RXCLK |

Note:
$\star \overline{\mathrm{RQ}}$ assertion on collision dependent on bit 3 of mode register (MR).

## MAXIMUM RATINGS

| Characteristics | Symbol | Value |
| :--- | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 V |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to +7.0 V |
| Operating Temperatures | $\mathrm{T}_{\mathrm{A}}$ | 0 to $70^{\circ} \mathrm{C}$ |
| Storage Temperatures | $\mathrm{T}_{\mathrm{STG}}$ | -55 to $+150^{\circ} \mathrm{C}$ |
| Note: |  |  |
| This device contains circuitry to protect the inputs against |  |  |
| damage due to high static voltages or electric fields; however, |  |  |
| normal precautions should be taken to avoid application of any |  |  |
| voltage higher than maximum-rated voltages to this high-imped- |  |  |
| ance circuit. Reliability of operation is enhanced if unused inputs |  |  |
| are tied to an appropriate logic voltage level (e.g., either $\mathrm{V}_{\mathrm{SS}}$ or |  |  |
| $\mathrm{V}_{\mathrm{CC}}$. |  |  |

THERMAL CHARACTERISTICS

| Characteristics | Symbol | Value | Rating |
| :--- | :---: | :---: | :--- |
| Thermal Resistance | $\theta_{\text {JA }}$ |  |  |
| Ceramic |  | 50 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Plastic |  | 68 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |

DC ELECTRICAL CHARACTERISTICS $\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0\right.$ to $70^{\circ} \mathrm{C}$ unless otherwise noted)

| Characteristics | Symbol | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | +2.0 | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | -0.3 | +0.8 | V |  |
| Input Leakage Current R/W, $\overline{R E S E T}, \overline{C S}$ | IN | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\text {IN }}=0 \text { to } 5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{Cc}}=0 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State (Off) DTACK, D0-D15 | $I_{\text {TSI }}$ | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=0.4 \text { to } 2.4 \mathrm{~V} \\ & V_{C C}=0 \mathrm{~V} \end{aligned}$ |
| Output High Voltage <br> $\overline{\text { RXREQ, }}, \overline{T X R E Q}, \overline{\mathrm{DTACK}}$, <br> D0-D15, MILOOP, MAUREQ, ISOLATE TXEN, TXDATA | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & +2.4 \\ & +2.4 \\ & +2.4 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & \mathrm{v} \\ & \mathrm{v} \\ & \mathrm{v} \\ & \hline \end{aligned}$ | $\begin{aligned} & V_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & I_{\text {LOAD }}=-400 \mu \mathrm{~A}, \mathrm{C}_{\text {LOAD }}=130 \mathrm{pF} \\ & I_{\text {LOAD }}=-400 \mu \mathrm{C}, \mathrm{C}_{\text {LOAD }}=32 \mathrm{pF} \\ & I_{\text {LOAD }}=0, C_{\text {LOAD }}=30 \mathrm{pF} \end{aligned}$ |
| $\begin{aligned} & \text { Output Low Voltage } \\ & \frac{\text { RXREQ, }}{\text { TXREQ, TXEN, TXDATA, } \overline{\text { DTACK, }} \text {, DO-D15 }} \\ & \overline{\text { MILOOP, } \overline{\text { MAUREQ, }} \overline{\text { IROLALE }} \overline{\text { DONE }}} \end{aligned}$ | VoL | - | 0.5 0.5 | V v | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=3.2 \mathrm{~mA} \\ & \mathrm{I}_{\text {LOAD }}=8.8 \mathrm{~mA} \end{aligned}$ |
| Power Dissipation | Pint | - | 1.0 | W | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | 13 | pF | $\begin{gathered} \mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V} \\ \mathrm{~V}_{\text {IN }}=0 \mathrm{~V} \\ \mathrm{f}=1 \mathrm{MHz} \\ \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{gathered}$ |

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



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

## 40-PIN PLASTIC DIP



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

## R68C552 DUAL ASYNCHRONOUS COMMUNICATIONS INTERFACE ADAPTER (DACIA)

## PRELIMINARY

## DESCRIPTION

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

The DACIA 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 38,400 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 DACIA is programmable for word lengths of 5,6 , 7 or 8 bits; even, odd, or no parity; and 1 or 2 stop bits.

The DACIA is designed for maximum programmed control from the microprocessor (MPU) to simplify hardware implementation. Dual sets of registers allow independent control and monitoring of each channel. The DACIA also provides a unique, programmable Automatic Address Recognition mode for use in a multidrop environment.

The Control Register and Status Register permit the MPU to easily select the R68C552's operating modes and determine operational status.
The Interrupt Enable Registers (IER) and Interrupt Status Registers (ISR) allow the MPU to control and monitor the interrupt capabilities of the DACIA.
The Control and Format Register (CFR) permits selection of baud rates, word lengths, parity and stop bits as well as control of DTR and RTS output signals.
The Status Register (SR) gives the MPU access to the state of the modem control lines, framing error, transmitter underrun and break conditions.
The Compare Data Registers (CDR) hold the data value to be used in the compare mode.
The IRQ Vector Register (IVR) holds the interrupt vector for use in the interrupt acknowledge state, or commands a Transmit Break and provides for parity/address recognition during Automatic Address Recognition mode.

## ORDERING INFORMATION



## FEATURES

- Low power CMOS N-well silicon gate technology
- Two independent full duplex channels with buffered receivers and transmitters.
- Data set/modem control functions
- Internal baud rate generator with 15 programmable baud rates ( 50 to 38,400 )
- Program-selectable internally or externally controlled receiver rate
- Programmable word lengths, number of stop bits, and parity bit generation and detection
- Programmable interrupt control
- Programmable control of edge detect for DCD, DSR, DTR, RTS, and CTS
- Program-selectable serial echo mode for each channel
- Automatic Address Recognition mode for multi-drop operations
- $5.0 \mathrm{Vdc} \pm 5 \%$ supply requirements
- 40-pin plastic or ceramic DIP
- Full TTL or CMOS input/output compatibility
- Compatible with R68000 microprocessor family


Figure 1. R68C552 Pin Configuration

## INTERFACE SIGNALS

Figure 2 shows the DACIA interface signals associated with the microprocessor and the modem.

## DATA BUS (D0-D7)

The D0-D7 pins are eight data lines that transfer data between the microprocessor (MPU) and the DACIA. These lines are bidirectional and are normally high-impedance except during READ cycle when the DACIA is selected.

## REGISTER SELECTS (RS0, RS1, RS2)

The three register select lines are normally connected to the processor address lines to allow the MPU to select the various internal registers. Table 1 shows the internal register select coding and identifies the abbreviations (ABBR) used throughout the text for each register. Table 2 summarizes the control and status registers and shows each bit allocation.

## READ/WRITE (R/W)

The R/ $\bar{W}$ input, generated by the microprocessor, controls the direction of data transfer. A high on the $R / \bar{W}$ line indicates a read cycle, while a low indicates a write cycle.

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

The chip select input is normally connected to the processor address lines either directly or through decoders. The DACIA latches address and $R / \bar{W}$ inputs on the falling edge of $\overline{C S}$ and latches the data bus inputs on the rising edge of $\overline{C S}$.

## RESET (RES)

During system initialization a low level on the $\overline{\operatorname{RES}}$ input causes a RESET to occur. At this time the IER's are set to $\$ 80$, the DTR and $\overline{\text { RTS }}$ lines go to the high state, the RDR register is cleared, the IVR is set to $\$ 0 F$, the compare mode is disabled, and the $\overline{\mathrm{CTS}}$, $\overline{\mathrm{DCD}}, \overline{\mathrm{DSR}}$ flags are cleared. No other bits are affected.

## TRANSMIT DATA (TXD1, TXD2)

The TxD outputs transfer serial non-return to zero (NRZ) data to the data communications equipment (DCE). The data is transferred, LSB first, at a rate determined by the baud rate generator.

RECEIVE DATA (RXD1, RXD2)
The RxD inputs transfer serial NRZ data into the DACIA from the DCE, LSB first. The receiver baud rate is determined by the baud rate generator.

## CLEAR TO SEND ( $\overline{\mathbf{C T S 1}}, \overline{\mathrm{CTS2}})$

The $\overline{\mathrm{CTS}}$ control line inputs allow handshaking by the transmitter. When $\overline{\mathrm{CTS}}$ is low, the data is transmitted continuously. When $\overline{\mathrm{CTS}}$ is high, the Transmit Data Register empty bit in the ISR is not set. The word presently in the Transmit Shift Register is sent normally. Any active transition on the $\overline{\mathrm{CTS}}$ lines sets the $\overline{\mathrm{CTS}}$ bit in the appropriate ISR. The CTS status bit in the SR reflects the current high or low state of CTS.

## DATA CARRIER DETECT (DCD1, $\overline{\text { DCD2 }})$

These two lines may be used as general purpose inputs. An active transition sets the $\overline{D C D}$ bit in the ISR. The $\overline{D C D}$ bit in the SR reflects the current state of the $\overline{D C D}$ line.


Figure 2. DACIA Interface Signals

## DATA SET READY (DSR1, DSR2)

These two lines may be used as general purpose inputs. An active transition sets the $\overline{\mathrm{DSR}}$ bit in the ISR. The $\overline{\mathrm{DSR}}$ bit in the SR reflects the current state of the $\overline{\mathrm{DSR}}$ line.

## REQUEST TO SEND ( $\overline{\text { RTS1 }}, \overline{\text { RTS2 }}$ )

These two lines may be used as general purpose outputs. They are set high upon reset. Their state may be programmed by setting the appropriate bits in the CFR high or low. The state of the $\overline{\mathrm{RTS}}$ line is reflected by the $\overline{\mathrm{RTS}}$ bit in the SR.

## DATA TERMINAL READY ( $\overline{\text { DTR1, }} \overline{\text { DTR2 }}$ )

These two lines may be used as general purpose outputs. They are set high upon reset. Their state may be programmed by setting the appropriate bits in the CFR high or low. The state of the $\overline{\text { DTR }}$ line is reflected by the $\overline{\text { DTR }}$ bit in the SR.

## INTERRUPT REQUEST (IRQ1, $\overline{\text { IRQ2 }})$

The $\overline{\mathrm{RQ}}$ lines are open-drain outputs from the interrupt control logic. $\overline{\mathrm{IRQ1}}$ is associated with ACIA1 and $\overline{\mathrm{RQ} 2}$ is associated with ACIA2. These lines are normally high but go low when one of the flags in the ISR is set, provided that its corresponding enable bit is set in the IER.

## CLOCK CIRCUIT

The internal clock oscillator supplies the time base for the baud rate generator. The oscillator can be driven by a crystal or an external clock, or it can be disabled, in which case the time base for the baud rate is generated by the Receiver External Clock (RxC) and Transmitter External Clock (TxC) input pins. Figure 3 shows the three possible clock configurations.

## CRYSTAL (XTALI, XTALO)

These pins are normally connected to an external 3.6864 MHz crystal used as the time base for the baud rate generator. As an alternative, the XTALI pin may be driven with an externally

## RECEIVER CLOCK (RxC)

This pin is the Receiver 16x clock input when the baud rate generator is programmed for External Clock. Figure 15 shows timing considerations for RxC.

## TRANSMITTER CLOCK (TxC)

This pin is the transmitter 16 x clock input when the baud rate generator is programmed for External Clock. Figure 16 shwos timing considerations for TxC.

## Note

When RxC and TxC are used for external clock input, XTALI must be tied to ground (Vss) and XTALO must be left open (floating).

## CLOCK OUT (CLK OUT)

This output is a buffered output from the 3.6864 MHz crystal oscillator. It may be used to drive the XTALI input of another DACIA. This allows multiple DACIA chips to be used in a system with only one crystal needed. CLK OUT is in phase with XTALI.



Figure 3. DACIA Clock Generation


Figure 4. DACIA Block Diagram

## FUNCTIONAL DESCRIPTION

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

## DATA BUS BUFFER

The Data Bus Buffer is a bidirectional interface between the system data lines and the internal data bus. When $R \bar{W}$ is high and $\overline{C S}$ is low, the Data Bus Buffer passes data from the internal data bus to the system data lines. When $R \bar{W}$ is high, $\overline{\mathrm{CS}}$ is high, and either IACK line is low, the IRQ vector is passed to the system data bus. When $R \bar{W}$ is low and $\overline{C S}$ is low, data is brought into the DACIA from the system data bus. The following table summarizes the Data Bus Buffer states.

Data Bus Buffer Summary

| R/ $/ \bar{W}$ | Control Signals |  |  | Data Bus Buffer State |
| :---: | :---: | :---: | :---: | :---: |
|  | CS | IACK1 | IACK2 |  |
| L | L | L | L | ILLEGAL MODE - TRI STATE |
| L | L | L | H | ILLEGAL MODE - TRI STATE |
| L | L | H | L | ILLEGAL MODE - TRI STATE |
| L | L | H | H | WRITE MODE - TRI STATE |
| L | H | L |  | ILLEGAL MODE - TRI STATE |
| L | H | L | H | ILLEGAL MODE - TRI STATE |
| L | H | H | L | ILLEGAL MODE - TRI STATE |
| L | H | H | H | TRI STATE |
| H | L | L | L | ILLEGAL MODE - OUTPUT \$OF |
| H | L | L | H | ILLEGAL MODE - OUTPUT \$OF |
| H | L | H | L | ILLEGAL MODE - OUTPUT \$0F |
| H | L | H | H | READ MODE - OUTPUT DATA |
| H | H |  | L | ILLEGAL MODE - OUTPUT \$OF |
| H | H | L | H | OUTPUT IRQ VECTOR 1 |
| H | H | H | L | OUTPUT IRQ VECTOR 2 |
| H | H | H | H | TRI STATE |

## TRANSMIT AND RECEIVE DATA REGISTERS

These registers are used as temporary data storage for the DACIA Transmit and Receive circuits. The Transmit Data Register is characterized as follows:

- Bit 0 is the leading bit to be transmitted.
- Unused data bits are the high-order bits and are "don't care" for transmission.
- Write-Only Register.

The Receive Data Register is characterized in a similar fashion as follows:

- Bit 0 is the leading bit received.
- Unused data bits are the high order bits and are " 0 '" for the receiver.
- Parity bits are not contained in the Receive Data Register, but are stripped off after being used for external parity checking.
Parity and all unused high-order bits are " 0 ".
- Read-Only Register

Figure 5 shows an example of a single transmitted or received data word. In this example, the data word is formatted with 8 data bits, parity, and two stop bits. Figure 5 also shows a single character transmitted or received in Address Recognition mode. In this example, the address or data word is 8 bits, there is no parity bit, and there are two stop bits. The 10th bit, (normal parity bit) is an address/data indicator bit. A 1 means the 8 bits are an address that will be compared with the address stored in the Compare Data Register. A 0 means the 8 bits are data.


Figure 5. Typical Data Word

## INTERRUPT LOGIC

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

## INTERRUPT ENABLE REGISTER (IER)

The Interrupt Enable Register (IER) is a write-only register that allows each of the possible IRQ sources to be enabled, or disabled, individually without affecting any of the other interrupt enable bits in the register. IRQ sources are enabled by writing to the IER with bit 7 set to a 1 and every bit set to a 1 that corresponds to the IRQ source to be enabled. IRQ sources are disabled by writing to the IER with bit 7 set to a 0 and every bit set to a 1 that corresponds to the IRQ source to be disabled. Any bit (except bit 7 ) to which a 0 is written is unaffected and remains in its original state. As an example, writing \$7F to the IER will disable all IRQ source bits, but writing \$FF to the IER will enable all IRQ source bits. A hardware reset ( $\overline{\mathrm{RES}}$ ) clears all IRQ source bits to the 0 state. Bit assignments for the IER are as follows:

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { CLEAR/ } \\ & \text { SET } \\ & \text { BITS } \end{aligned}$ | $\begin{gathered} \text { TDR } \\ \text { EMPTY } \\ \text { IE } \end{gathered}$ | $\begin{gathered} \text { CTS } \\ \text { IE } \end{gathered}$ | $\overline{\mathrm{DCD}}$ | $\begin{gathered} \overline{\text { DSR }} \\ \text { IE } \end{gathered}$ | PARITY ERROR IE | FRM OVR BRK IE | $\begin{aligned} & \text { RDR } \\ & \text { FULL } \\ & \text { IE } \end{aligned}$ |

Table 1. DACIA Register Selection

| HEX | REGISTER SELECT LINES |  |  | CONTROL \& FORMAT REGISTER BITS |  | REG | REGISTER ACCESS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | L | L | L | - | - | IER1 ISR1 | INTERRUPT ENABLE REGISTER 1 | INTERRUPT STATUS REGISTER 1 |
| 01 | L | L | H | 0 | - | CFR1 SR1 | CONTROL REGISTER 1 | STATUS REGISTER 1 |
|  |  |  |  | 1 | - | CFR1 | FORMAT REGISTER 1 | INVALID |
| 02 | L | H | L | - | 0 | CDR1 | COMPARE DATA REGISTER 1 | INVALID |
|  |  |  |  | - | 1 | IVR1 | IRQ VECTOR 1 | INVALID |
| 03 | L | H | H | - | - | TDR1 RDR1 | TRANSMIT DATA REGISTER 1 | RECEIVE DATA REGISTER 1 |
| 04 | H | L | L | - | - | $\begin{aligned} & \text { IER2 } \\ & \text { ISR2 } \end{aligned}$ | INTERRUPT ENABLE REGISTER 2 | INTERRUPT STATUS REGISTER 2 |
| 05 | H | L | H | 0 | - | $\begin{aligned} & \text { CFR2 } \\ & \text { SR2 } \end{aligned}$ | CONTROL REGISTER 2 | STATUS REGISTER 2 |
|  |  |  |  | 1 | - | CFR2 | FORMAT REGISTER 2 | INVALID |
| 06 | H | H | L | - | 0 | CDR2 | COMPARE DATA REGISTER 2 | INVALID |
|  |  |  |  | - | 1 | IVR2 | IRQ VECTOR 2 | INVALID |
| 07 | H | H | H | - | - | TDR2 RDR2 | TRANSMIT DATA REGISTER 2 | RECEIVE DATA REGISTER 2 |

Table 2. Control and Status Registers Format Summary

| REGISTER BIT NUMBERS |  |  |  |  |  |  |  | REGISTER | $\overline{\text { RES }}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | INTERRUPT ENABLE REGISTERS | \$80 |
| CLEAR/SET BITS | TDR EMPTY IE | $\begin{gathered} \overline{\text { CTS }} \\ \text { IE } \end{gathered}$ | $\overline{\mathrm{DCD}}$ | $\begin{gathered} \overline{\mathrm{DSR}} \\ \mathrm{IE} \end{gathered}$ | PARITY ERROR IE | $\begin{aligned} & \hline \text { FRM } \\ & \text { OVR } \\ & \text { BRK } \\ & \text { IE } \end{aligned}$ | $\begin{aligned} & \text { RDR } \\ & \text { FULL } \\ & \text { IE } \end{aligned}$ |  |  |
| $\begin{aligned} & \hline \text { ANY } \\ & \text { BIT } \\ & \text { SET } \end{aligned}$ | TDR EMPTY | $\begin{aligned} & \text { CTS } \\ & \text { TRANS } \end{aligned}$ | $\begin{aligned} & \overline{\text { DCD }} \\ & \text { TRANS } \end{aligned}$ | $\begin{aligned} & \overline{\text { DSR }} \\ & \text { TRANS } \end{aligned}$ | PARITY ERROR | $\begin{aligned} & \text { FRM } \\ & \text { OVR } \end{aligned}$ | RDR | INTERRUPT STATUS REGISTERS | - |
| FRAMING ERROR | TRANS UNDR | $\overline{C T S}$ STATUS | $\begin{aligned} & \overline{\mathrm{DCD}} \\ & \text { STATUS } \end{aligned}$ | $\begin{aligned} & \overline{\mathrm{DSR}} \\ & \text { STATUS } \end{aligned}$ | REC BREAK | $\begin{aligned} & \overline{\overline{D T R}} \\ & \text { sTATUS } \end{aligned}$ | $\begin{aligned} & \overline{\text { RTS }} \\ & \text { STATUS } \end{aligned}$ | STATUS REGISTERS | - |
| 0 | $\begin{aligned} & \text { IVR/CDR } \\ & \text { REG } \end{aligned}$ | $\begin{aligned} & \text { NO. } \\ & \text { STOP } \\ & \text { BITS } \end{aligned}$ | ECHO | BAUD RATE SELECTION |  |  |  | CONTROL REGISTERS <br> AND <br> FORMAT REGISTERS | - |
| 1 | NUMBER OF DATA BITS |  | PARITY SELECTION |  | PARITY ENABLE | $\begin{gathered} \overline{\text { DTR }} \\ \text { CONTROL } \end{gathered}$ | $\begin{gathered} \overline{\text { RTS }} \\ \text { CONTROL } \end{gathered}$ |  |  |
| COMPARE BITS (ADDRESS RECOGNITION) |  |  |  |  |  |  |  | $\begin{aligned} & \text { COMPARE } \\ & \text { DATA } \\ & \text { REGISTER } \end{aligned}$ | - |
| IRQ VECTOR ADDRESS |  |  |  |  |  | IRQ SOURCE |  | IA MODE INTERRUPT |  |
| NOT USED |  |  |  |  |  | TRANS BRK | PAR/ ADDR | REGISTER <br> T/R MODE |  |

## R68C552

## INTERRUPT STATUS REGISTER (ISR)

The Interrupt Status Register (ISR) is a read-only register that identifies the current status condition for each DACIA internal IRQ source. Bits 6 through 0 of the ISR are set to a 1 whenever the corresponding IRQ source condition has occurred in the DACIA. Bit 7 identifies if any of the IRQ source status bits have been set in the ISR.

| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ANY <br> BIT <br> SET | TDR <br> EMPTY | CTS <br> TRANS | $\overline{\text { DCD }}$ <br> TRANS | DSR <br> TRANS | PARITY <br> ERROR | FRM <br> OVR <br> BRK | RDR <br> FULL |


| Bit 7 | Any Bit Set |
| :---: | :---: |
| 1 | Any bit (6 through 0) has been set to a 1 |
| 0 | No bits have been set to a 1 |
| Bit 6 | Transmit Data Register Empty (TDR EMPTY) |
| 1 | Transmit Data Register has been transferred to the shift register |
| 0 | New data has been written to the Transmit Data Register |
| Bit 5 | Transition On CTS Line ( $\overline{\mathbf{C T S}}$ TRANS) |
| 1 | A positive or negative transition has occurred on CTS |
| 0 | No transition has occurred on CTS, or ISR has been read |
| Blt 4 | Transition On $\overline{\mathrm{DCD}}$ Line ( $\overline{\text { DCD }}$ TRANS) |
| 1 | A positive or negative transition has occurred on $\overline{D C D}$ |
| 0 | No transition has occurred on $\overline{\text { DCD }}$, or ISR has been read |
| Bit 3 | Transition On $\overline{\text { DSR }}$ Line ( $\overline{\text { DSR }}$ TRANS) |
| 1 | A positive or negative transition has occurred on DSR |
| 0 | No transition has occurred on $\overline{\text { DSR }}$, or ISR has been read |
| Bit 2 | Parity Error |
| 1 | A parity error has occurred in received data |
| 0 | No parity error has occurred, or the Receive Data Register (RDR) has been read |
| Bit 1 | Frame Error, Overrun or Break (FRM, OVR, BRK) |
| 1 | A framing error, receive overrun, or receive break has occurred |
| 0 | No error, overrun, break has occurred or RDR has been read |
| Bit 0 | Receive Data Register Full (RDR FULL) |
| 1 | Shift register data has been transferred to Receive Data Register |
| 0 | Receive Data Register has been read |

## INTERRUPT VECTOR REGISTER (IVR)

The DACIA has two Interrupt Vector Registers which are write-only registers. By storing the appropriate vector address number in bits 7 through 2 of the IVR, the DACIA will place the vector on the data bus when requested by the $\overline{\mathrm{IACK}}$ signal. In this mode, bits 1 and 0 identify the source of the IRQ.

Note: In order for the IVR Vector Address to be recognized, bit 6 of the CFR must be a 1.

During the Transmit Receive mode, bits 7 through 2 are not used and are treated as "don't care" bits. In this mode, bits 1 and 0 are used for Transmit Break and Parity/Address recognition.

Writing a 1 to bit 1 of the IVR causes a continuous Break to be transmitted by the ACIA associated with the register. Writing a 0 to this bit allows normal transmission to resume. Writing a 1 to bit 0 of the IVR commands the value of the Parity bit to be sent to the Parity Error bit (bit 2 of the ISR). Writing a 0 to this bit allows normal Parity Error recognition to be in force. When an $\overline{\mathrm{RES}}$ is received by the DACIA, both of these bits are reset to 0 . The bits format for the IVR are as follows:

| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IRQ VECTOR ADDRESS |  |  | $\mathbf{0}$ |  |  |  |
|  | IRQ SOURCE |  |  |  |  |  |
| NOT USED |  | TRANS <br> BRK | PARI <br> ADDR |  |  |  |

Interrupt Acknowledge Mode (IA Mode)
Bits 7-2 IRQ Vector Address
Bit 1 IRQ Source Channel
1 ACIA1 selected
0 ACIA2 selected
Bit $0 \quad$ IRQ Source
1 Other IRQ (CTS, DCD, DSR, Parity, Break, OV)
0 Transmit or Receive IRQ

| Transmit/Receive Mode (T/R Mode) |  |
| :---: | :--- |
| Bits 7-2 | Not used (don't care) |
| Bit 1 | Transmit Break (TRANS BRK) |
| 1 | Transmit continuous Break until disabled |
| 0 | Resume normal transmission |
| Bit 0 | Parity/Address Recognition (PAR/ADDR) <br> 1 |
| Send value of parity to ISR bit 2 (Address |  |
| 0 | Recognition mode) |
| Return to normal Parity Error recognition mode |  |

## COMPARE DATA REGISTER

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

## STATUS REGISTER (SR)

The Status Register (SR) is a read-only register that provides I/O status and error condition information. The SR is normally read after an IRQ has occurred to determine the exact cause of the interrupt condition.

| 7 | 6 | 5 | 4 | 3 | 2 | 1. | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FRAMING ERROR | TRANS UNDR | $\begin{array}{\|c\|} \hline \overline{\text { CTS }} \\ \text { STATUS } \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline \overline{\mathrm{DCD}} \\ \text { STATUS } \\ \hline \end{array}$ | $\begin{array}{c\|} \hline \overline{D S R} \\ \text { STATUS } \end{array}$ | $\begin{array}{\|c\|} \hline \text { REC } \\ \text { BREAK } \\ \hline \end{array}$ | $\begin{array}{\|c\|} \hline \overline{\text { DTR }} \\ \text { STATUS } \end{array}$ | $\begin{array}{\|c} \overline{R T S} \\ \text { STATUS } \end{array}$ |
| Bit 7 |  | Framing Error |  |  |  |  |  |
| 1 |  | A framing error occurred in receive data |  |  |  |  |  |
| 0 |  | No framing error occurred, or the RDR was read |  |  |  |  |  |
| Bit 6 |  | Transmitter Underrun (TRANS UNDR) |  |  |  |  |  |
| 1 |  | Transmit shift register is empty and TDRE bits |  |  |  |  |  |
|  |  | in IER | R and ISR | R are se |  |  |  |
| 0 |  | A write to the TDR has occurred |  |  |  |  |  |
| Bit 5 |  | $\overline{\text { CTS }}$ Status |  |  |  |  |  |
| 1 |  | CTS line high |  |  |  |  |  |
| 0 |  | CTS line low |  |  |  |  |  |
| Bit 4 |  | $\overline{\text { DCD }}$ Status |  |  |  |  |  |
| 1 |  | $\overline{D C D}$ line high |  |  |  |  |  |
| 0 |  | $\overline{D C D}$ line low |  |  |  |  |  |
| Bit 3 |  | $\overline{\text { DSR }}$ Status |  |  |  |  |  |
| 1 |  | $\overline{\text { DSR }}$ line high |  |  |  |  |  |
| 0 |  | $\overline{\text { DSR }}$ line low |  |  |  |  |  |
| Bit 2 |  | REC Break |  |  |  |  |  |
| 1 |  | A Receive Break has occurred |  |  |  |  |  |
| 0 |  | No Receive Break occurred, or RDR, was read |  |  |  |  |  |
| Bit 1 |  | $\overline{\text { DTR Status }}$ |  |  |  |  |  |
| 1 |  | DTR line high |  |  |  |  |  |
| 0 |  | $\overline{\text { DTR }}$ line low |  |  |  |  |  |
| Bit 0 |  | $\overline{\text { RTS }}$ Status |  |  |  |  |  |
| 0 |  | RTS line high |  |  |  |  |  |
|  |  | RTS line low |  |  |  |  |  |

## CONTROL AND FORMAT REGISTER (CFR)

The Control and Format Register (CFR) is a dual-function, writeonly register which allows control of word length, baud rate, control line outputs, parity, echo mode, and compare/IVR access. When the CFR is written to with bit $7=0$, the CFR functions as a Control Register. When the CFR is written to with bit $7=1$, the CFR operates as a Formal Register.

Control Register (CFR Addressed with Bit $7=0$ )

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | IVR/CDR | NO. STOP BITS | ECHO | BAUD RATE SELECTION |  |  |  |

Bit 6
1 Access the IRQ Vector Register (IVR)
0

| $\begin{gathered} \text { Bit } 5 \\ 1 \\ 0 \end{gathered}$ |  |  | Number of Stop Bits Two stop bits One stop bit |
| :---: | :---: | :---: | :---: |
|  |  |  |  |
|  |  |  |  |
|  | Bit 4 |  | Echo Selection (ECHO) |
|  | 1 |  | Echo activated |
|  | 0 |  | Echo deactivated |
|  | Bits 3-0 |  | Baud Rate Selection |
| 3 | 21 | $\underline{0}$ | Baud Rate |
| 0 | 00 | 0 | 50 |
| 0 | 00 | 1 | 109.2 |
| 0 | 01 | 0 | 134.58 |
| 0 | 01 | 1 | 150 |
| 0 | 10 | 0 | 300 |
| 0 | 10 | 1 | 600 |
| 0 | 11 | 0 | 1200 |
| 0 | 11 | 1 | 1800 |
| 1 | 00 | 0 | 2400 |
| 1 | 00 | 1 | 3600 |
| 1 | 01 | 0 | 4800 |
| 1 | $0 \quad 1$ | 1 | 7200 |
| 1 | 10 | 0 | 9600 |
| 1 | 10 | 1 | 19200 |
| 1 | 11 | 0 | 38400 |
| 1 | 11 | 1 | External TxC and RxC |

Format Register (CFR Addressed with Bit $7=1$ )

| $\mathbf{7}$ | $\mathbf{6} \quad \mathbf{5}$ | $\mathbf{4} \quad \mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{1}$ | NUMBER <br> OF DATA <br> BITS | PARITY <br> SELECTION | PARITY <br> ENABLE | $\overline{\text { DTR }}$ <br> CONTROL | $\overline{\text { RTS }}$ <br> CONTROL |


| Bits 6-5 | Number of Data Bits Per Channel |
| :---: | :---: |
| 65 | No. Bits |
| 00 | 5 |
| 01 | 6 |
| 10 | 7 |
| 11 | 8 |
| Bits 4-3 | Parity Mode Selection |
| 43 | Selects |
| 00 | Odd Parity |
| 01 | Even Parity |
| 10 | Mark Parity |
| 11 | Space Parity |
| Bit 2 | Parity Enable |
| 1 | Parity as specified by bits 4-3 |
| 0 | No Parity |
| Bit 1 | DTR Control |
| 1 | DTR high |
| 0 | DTR low |
| Bit 0 | RTS Control |
| 1 | $\overline{\text { RTS }}$ high |
| 0 | RTS low |

## OPERATION

The ten modes (or conditions) of operation of the DACIA are:

- Continuous Data Transmit
- Continuous Data Receive
- Transmit Underrun Condition
- Effects of CTS on Transmitter
- Effects of Overrun on Receive
- Echo Mode Timing
- Framing Error
- Transmit Break Character
- Receive Break Character
- Automatic Address Mode


## CONTINUOUS DATA TRANSMIT

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


Figure 6. Continuous Data Transmit

## CONTINUOUS DATA RECEIVE

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


Figure 7. Continuous Data Receive

## TRANSMIT UNDERRUN CONDITION

If the MPU is unable to load the TDR before the last stop bit is sent, the TxD line goes to the MARK condition and the underrun
flag is set. This condition persists until the TDR is loaded with a new word. Figure 8 shows the relation between IRQ and TxD for the Transmit Underrun Condition.


Figure 8. Transmit Underrun Condition Relationship

## EFFECTS OF CTS ON TRANSMITTER

The $\overline{\mathrm{CTS}}$ control line controls the transmission of data or the handshaking of data to a "busy" device (such as a printer). When the CTS line is low, the transmitter operates normally. Any transition on this line sets the $\overline{C T S}$ bit in the ISR. A high condition inhibits
the TDRE bit in the ISR from becoming set. The word currently in the shift register continues to be sent but any word in the TDR is held until CTS goes low. At the high-to-low transition the $\overline{C T S}$ bit in the ISR is again set. Figure 9 shows the relationship of IRQ, TxD, and $\overline{C T S}$ for the effects of $\overline{\text { CTS }}$ on the transmitter.


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

## EFFECTS OF OVERRUN ON RECEIVER

If the processor does not read the RDR before the stop bit of the next word, an overrun error occurs, the overrun bit is set in the ISR, and the new data word is not transferred to the RDR. The

RDR contains the last word not read by the MPU and all following data is lost. The receiver will return to normal operation when the RDR is read. Figure 10 shows the relation of $\overline{R Q}$ and $R \times D$ for the effects of overrun on the receiver.


Figure 10. Effects of Overrun on Receiver

## ECHO MODE TIMING

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


Figure 11. Echo Mode Timing

## FRAMING ERROR

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


Figure 12. Framing Error

## TRANSMIT BREAK CHARACTER

A Break may be transmitted by storing a value of $\$ 00$ in the IER. After storing zero in the IER the Break is transmitted immediately. Care should be exercised so that a character in transmission is not disturbed inadvertently. The Break level lasts until other than
$\$ 00$ is stored in the IER at which time a stop bit is sent and transmission may resume. At least one full word time of Break will be sent regardless of the length of time between starting and stopping the Break character. Figure 13 shows the relationship of $\overline{\mathrm{RQQ}}$ and TXD for a Transmit Break character.


Figure 13. Transmit Break Character

## RECEIVE BREAK CHARACTER

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


Figure 14. Receive Break Character

## AUTOMATIC ADDRESS RECOGNITION

The DACIA offers a unique solution to the standard problem associated with multi-drop environment UARTs and communication interface controllers. In the standard configuration used by other devices, the slave CPU must be constantly interrupted to analyze incoming characters on the communications net to determine if an address word is present and if so, does that address match the address assigned to the slave UART. This CPU interrupt scheme can become intolerable in very large multi-drop networks because every slave on the communications net must "wake-up"' it's CPU for every character sent down the network by the master. The end results is that the CPUs on the communications net are constantly being interrupted for the mundane task of address recognition.

To avoid this constant CPU interrupt problem, the DACIA has been designed to do address comparison and recognition internally without the need for CPU intervention. Therefore, the slave CPU is not interrupted until the DACIA has determined that the character sent over the communications net by the master was an address and the address matched the address stored in the DACIA Compare Register. At this point the DACIA interrupts the CPU, goes out of Compare Mode, and receives the string of characters being transmitted by the master, (i.e., the data
characters). When all data has been received by the slave, it's CPU must again write the slave address into the DACIA Compare Register which automatically puts it back into the Compare Mode, waiting for another address character.

## GENERATION OF NON-STANDARD BAUD RATES

## Divisors

The internal counter/divider circuit selects the appropriate divisor for the crystal frequency by means of bits 0-3 of the CFR Control Register, as shown in Table 4.

## 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 DACIA with an off-chip oscillator to achieve other baud rates. In this case, XTALI (pin 3) must be the clock input and XTALO (pin 4) must be a nonconnect.

Table 4. Divisor Selection

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



Figure 15. DACIA External Clock Timing - Receive Data


Figure 16. DACIA External Clock Timing - Transmit Data


DACIA Read Cycle Timing


DACIA Write Cycle Timing


DACIA Transmit/Receiver Timing


DACIA Interrupt Acknowledge Timing

## SPECIFICATIONS

## AC CHARACTERISTICS

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

| Number | Characteristic | Symbol | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| READ/WRITE TIMING |  |  |  |  |  |
| 1 | $\mathrm{R} / \bar{W}, \mathrm{RSO}$-RS2 Valid to $\overline{\mathrm{CS}}$ Low (Setup) | $\mathrm{t}_{\mathrm{RVCL}}$ | 0 | - | ns |
| 2 | $\overline{\text { CS }}$ Low to R $\bar{W}$, RS0-RS2 Read (Hold Time) | $t_{\text {cLRV }}$ | 65 | - | ns |
| 3 | $\overline{\mathrm{CS}}$ Low to Data Valid | $\mathrm{t}_{\text {CLDV }}$ | - | 100 | ns |
| 4 | $\overline{\text { CS }}$ High to DTACK High | $\mathrm{t}_{\mathrm{CHTH}}$ | - | 10 | ns |
| 5 | Data Valid to $\overline{\mathrm{CS}}$ High | $\mathrm{t}_{\text {DVCH }}$ | 20 | - | ns |
| 6 | $\overline{\mathrm{CS}}$ High to Data Invalid (Read) | $\mathrm{t}_{\text {CHDZ }}$ | 10 | 30 | ns |
| 7 | $\overline{\mathrm{CS}}$ High to Data Invalid (Write) | $\mathrm{t}_{\mathrm{CHDZ}}$ | - | 40 | ns |
| 8 | $\overline{\mathrm{CS}}$ Low to $\overline{\text { DTACK }}$ Low (Write) | $\mathrm{t}_{\text {clit }}$ | 0 | - | ns |
| 9 | Data Valid to DTACK Low (Read) | $t_{\text {DVTL }}$ | 0 | - | ns |


| TRANSMIT/RECEIVE TIMING |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 10 | Transmit/Receive Clock Rate | $\mathrm{t}_{\mathrm{CY}}$ | 250 | - | ns |
| 11 | Transmit/Receive Clock High | $\mathrm{t}_{\mathrm{CH}}$ | 100 | - | ns |
| 12 | Transmit/Receive Clock Low | $\mathrm{t}_{\mathrm{LL}}$ | 100 | - | ns |
| 13 | XTALI to TxD Propagation Delay | $\mathrm{t}_{\text {CLTD }}$ | - | 250 | ns |
| 14 | XTALI to $\overline{\mathrm{RQQ}}$ Propagation Delay | $\mathrm{t}_{\text {cLID }}$ | - | 250 | ns |
| 15 | $\overline{\mathrm{CTS}}, \overline{\mathrm{DCD}}, \overline{\mathrm{DSR}}$ Valid to $\overline{\mathrm{RQ}}$ Low | $\mathrm{t}_{\text {SVIL }}$ | - | 150 | ns |
| 16 | $\overline{\text { IRQ Propagation Delay (Clear) }}$ | $\mathrm{t}_{\text {IROC }}$ | - | 150 | ns |
| 17 | $\overline{\text { RTS, }} \overline{\text { DTR Propagation Delay }}$ | $\mathrm{t}_{\text {RDPD }}$ | - | 150 | ns |


| INTERRUPT ACKNOWLEDGE TIMING |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 18 | $\overline{\text { IACK }}$ Low to Data Valid | $\mathrm{tILDV}^{\text {chen }}$ | - | 100 | ns |
| 19 | IACK Low to DTACK Low | tilti | 0 | - | ns |
| 20 | $\overline{\text { IACK }}$ High to DTACK High | $\mathrm{t}_{\text {HTH }}$ | 0 | - | ns |
| 21 | $\overline{\text { IACK }}$ High to Data Invalid | $\mathrm{t}_{\text {IHDZ }}$ | 10 | 30 | ns |

## ABSOLUTE MAXIMUM RATINGS*

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

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

## OPERATING CONDITIONS

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

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min | Typ | Max | Unit | Test Condltions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage Except XTALI and XTALO XTALI and XTALO | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{aligned} & +2.0 \\ & +2.4 \end{aligned}$ | 二 | $\begin{aligned} & v_{c c}+0.3 \\ & v_{c c}+0.3 \end{aligned}$ | V |  |
| Input Low Voltage <br> Except XTALI and XTALO XTALI and XTALO | $\mathrm{V}_{\mathrm{IL}}$ | $\begin{aligned} & -0.3 \\ & -0.3 \end{aligned}$ | - | $\begin{aligned} & +0.8 \\ & +0.4 \end{aligned}$ | V |  |
| ```Input Leakage Current \(\mathrm{R} \overline{\mathrm{W}}, \overline{\mathrm{RES}}, \mathrm{RS} 0, \mathrm{RS} 1, \mathrm{RS} 2, \mathrm{RxD}, \overline{\mathrm{CTS}}, \overline{\mathrm{DCD}}, \overline{\mathrm{DSR}}, \overline{\mathrm{RxC}}\), TXC, CS, IACK``` | $\mathrm{I}_{\mathrm{N}}$ | - | 10 | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=0 \mathrm{~V} \text { to } 5.0 \mathrm{~V} \\ & V_{C C}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State Off D0-D7 | $\mathrm{I}_{\text {TSI }}$ | - | $\pm 2$ | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage D0-D7, TxD, CLK OUT, RTS, DTR | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{gathered} +2.4 \\ 1.5 \end{gathered}$ | - | - | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{C}_{\text {LOAD }}=-100 \mu \mathrm{~A} \end{aligned}$ |
| Output Low Voltage D0-D7, TxD, CLK OUT, RTS', DTR | $\mathrm{V}_{\mathrm{OL}}$ | - | - | +0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output Leakage Current (Off State) IRQ, DTACK | Ioff | - | $\pm 2$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OUT}}=0 \text { to } 2.4 \mathrm{~V} \end{aligned}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | - | - | 10 | mW/MHz |  |
| Input Capacitance Except XTALI and XTALO XTALI and XTALO | $\mathrm{C}_{\text {IN }}$ | - | - | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V} \\ & V_{\mathrm{IN}}=0 \mathrm{~V} \\ & \mathrm{f}=2 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | Cout | - |  | 10 | pF | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |

## Notes:

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

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



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

40-PIN PLASTIC DIP


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

## SECTION 2 8-BIT MICROPROCESSORS AND PERIPHERALS

Page
Product Family Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-2
R6500 Family Products
R650X and R651X Microprocessors (CPU) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-3
R6501Q and R6511Q One-Chip Microprocessors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-18
R6520 Peripheral Interface Adapter (PIA) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-24
R6522 Versatile Interface Adapter (VIA) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-36
R6530 ROM-RAM-I/O-Timer (RRIOT) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
R6531 ROM-RAM-I/O-Counter (RRIOC) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-69
R6532 RAM-I/O-Timer (RIOT) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-82
R6541Q, R6500/41, R6500/42 and R6500/43 One-Chip Intelligent
Peripheral Controller . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-92
R6545-1 CRT Controller (CRTC) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-100
R6551 Asynchronous Communications Interface Adapter (ACIA) . . . . . . . . . . . . . . . . . 2-116
R6565 Double-Density Floppy Disk Controller (DDFDC) . . . . . . . . . . . . . . . . . . . . . . . . 2-136
R6592 Single Chip Printer Controller . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-161
R65560 Multi-Protocol Communications Controller (MPCC) . . . . . . . . . . . . . . . . . . . . . . 2-172
R65C02, R65C102 and R65C112 CMOS Microprocessors (CPU) . . . . . . . . . . . . . . . . . 2-202
R65C21 CMOS Peripheral Interface Adapter (PIA) . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-217
R65C24 CMOS Peripheral Interface Adapter Timer (PIAT) . . . . . . . . . . . . . . . . . . . . . . 2-229
R65C51 CMOS Asynchronous Communications Interface Adapter (ACIA) . . . . . . . . . . 2-249
R65C52 CMOS Dual Asynchronous Communications Interface Adapter (DACIA) . . . . 2-269
Z80;3080 Bus Compatible Products
R6265 Micro Floppy Disk Controller (MFDC) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-288
R6765 Double-Density Floppy Disk Controller (DDFDC) . . . . . . . . . . . . . . . . . . . . . . . . . 2-313

# R6500 MICROPROCESSOR AND PERIPHERAL FAMILY Fastest Executing, Largest Selling 8-Bit Family Now Also In CMOS 

There is no microprocessor family easier to implement than the R6500. It's the fastest instruction executing 8-bit family. It's software compatible with a family of single-chip microcomputers. It's available in NMOS and CMOS versions. It has a wide variety of CPUs and peripheral controllers and versatile memory-//O-timer combinations.

In the 8-bit range, nothing gives higher performance than this third generation microprocessor family. Pipeline architecture provides much faster instruction execution ( $1 \mu \mathrm{sec}$ ). Thirteen address modes provide the most efficient ways of addressing memory. R6500 peripherals are system oriented, designed to implement systems with minimum chips.

And now, it's available in CMOS, for even higher speed, low power applications-the R65C00 family. It's now possible to move complete product and system designs directly into CMOS, being downward software compatible with the NMOS R6500 family.

Because of its inherent characteristics, the advanced Rockwell CMOS provides low power consumption, high noise immunity and high speed operation. Its 2 MHz CPU dissipates only 40 mW (compared to $700-800 \mathrm{~mW}$ in NMOS) and requires only $10 \mu \mathrm{~A}$ standby current. Instructions can be executed in only 500 nanoseconds. Instruction memory requirements are $20 \%$ less due to added bit manipulation features. And, there are even more advantages.
The entire 8-bit R6500 family is upward compatible with the 16-bit R68000 bus, software compatible to the R6500/* single-chip microcomputers and are the building blocks for the RM 65 module family and AIM 65 board microcomputer families, for a wide range of system applications. There's no wonder it's one of the world's largest selling families of microprocessors, as documented by Dataquest. (See below)


Source: Dataquest-April 1983

## R650X and R651X MICROPROCESSORS (CPU)

## DESCRIPTION

The 8 -bit R6500 microprocessor devices are 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 is cost-effectivity. System cost-effectivity is further enhanced by providing a family of 10 software-compatible microprocessor (CPU) devices, described in this document. Rockwell also provides single chip microcomputers, memory and peripheral devices-as well as low-cost design aids and documentation.

Ten CPU devices are available. All are software-compatible. They provide options of addressable memory, interrupt input, on-chip clock oscillators and drivers. All are bus-compatible with earlier generation microprocessors like the M6800 devices.

The R650X and R651X family includes six microprocessors with on-board clock oscillators and drivers and four microprocessors driven by external clocks. The on-chip clock versions are aimed at high performance, low cost applications where single phase inputs, crystal or RC inputs provide the time base. The external clock versions are geared for multiprocessor system applications where maximum timing control is mandatory. All R6500 microprocessors are also available in a variety of packaging (ceramic and plastic), operating frequency ( $1 \mathrm{MHz}, 2 \mathrm{MHz}$ and 3 MHz ) and temperature (commercial and industrial) versions.

## ORDERING INFORMATION

| [Temperature Range $\left(T_{L}\right.$ to $\left.T_{H}\right)$ : <br> No letter $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ <br> $\mathrm{E}=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ <br> Package: <br> C = Ceramic <br> $\mathrm{P}=$ Plastic <br> Frequency Range: <br> No letter $=1 \mathrm{MHz}$ <br> $A=2 \mathrm{MHz}$ <br> $B=3 \mathrm{MHz}$ <br> Model Designator: <br> $X X=02,03,04, \ldots 15$ |
| :---: |
|  |  |

## FEATURES

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


## R6500 CPU FAMILY MEMBERS

| Microprocessors with Internal Two Phase Clock Generator |  |  |
| :--- | :---: | :---: |
|  |  |  |
| Model | No. Pins | Addressable Memory |
| R6502 | 40 | 64K Bytes |
| R6503 | 28 | 4K Bytes |
| R6504 | 28 | $8 K$ Bytes |
| R6505 | 28 | 4K Bytes |
| R6506 | 28 | 4K Bytes |
| R6507 | 28 | $8 K$ Bytes |

Microprocessors with External Two Phase Clock Input

| Model | No. Pins | Addressable Memory |
| :---: | :---: | :---: |
| R6512 | 40 | $64 K$ Bytes |
| R6513 | 28 | $4 K$ Bytes |
| R6514 | 28 | $8 K$ Bytes |
| R6515 | 28 | $4 K$ Bytes |

## INTERFACE SIGNAL DESCRIPTIONS

## CLOCKS ( $\left(1, \not 1, \varnothing_{2}\right)$

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

## ADDRESS BUS (A0-A15, R6502)

The address line outputs access data in memory device locations or cells, access data in I/O device registers and/or effect logical operations in I/O or controller devices depending on system design. The addressing range is determined by the number of address lines available on the particular CPU device. The R6502 and R6512 can address 64K bytes with a 16-bit address bus (A0-A15); the R6504, R6507, and the R6514 can address 8 K bytes with a 13-bit address bus (A0-A12); and the R6503, R6505, R6506, R6513, and R6515 can address 4 K bytes with a 12 -bit address bus (AO-A11). These outputs are TTL-compatible and are capable of driving one standard TTL load and 130 pF .

## DATA BUS (D0-D7)

The data lines (DO-D7) form an 8 -bit bidirectional data bus which transfers data between the CPU and memory or peripheral devices. The outputs are tri-state buffers capable of driving one standard TTL load and 130 pF .

## DATA BUS ENABLE (DBE, R6512 ONLY)

The TTL-compatible DBE input allows external control of the tristate data output buffers and will enable the microprocessor bus driver when in the high state. In normal operation DBE is driven by the phase two (ø2) clock, thus allowing data output from microprocessor only during $\varnothing 2$. During the read cycle, the data bus drivers are internally disabled, becoming essentially an open circuit. To disable data bus drivers externally, DBE should be held low.

## READY (RDY)

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

## INTERRUPT REQUEST ( $\overline{\mathbf{R} \mathbf{Q}})$

The TTL level active-low $\overline{\mathrm{RQ}}$ input requests that an interrupt sequence begin within the microprocessor. The microprocessor will complete the current instruction being executed before recognizing the request. At that time, the interrupt mask bit in the Processor Status Register will be examined. If the interrupt mask flag is not set, the microprocessor will begin an interrupt sequence. The Program Counter and Processor Status Register
are stored in the stack. The microprocessor will then set the interrupt mask flag high so that no further interrupts can occur. At the end of this cycle, the program counter low will be loaded from address FFFE, and program counter high from location FFFF, therefore transferring program control to the memory vector located at these addresses. The RDY signal must be in the high state for any interrupt to be recognized. A $3 \mathrm{~K} \Omega$ external resistor should be used for proper wire-OR operation.

## NON-MASKABLE INTERRUPT (NMI)

A negative going edge on the $\overline{N M I}$ input requests that a nonmaskable interrupt sequence be generated within the microprocessor.
$\overline{N M I}$ is an unconditional interrupt. Following completion of the current instruction, the sequence of operations defined for $\widehat{\mathrm{RQ}}$ will be performed, regardless of the state interrupt mask flag. The vector address loaded into the program counter, low and high, are locations FFFA and FFFB respectively, thereby transferring program control to the memory vector located at these addresses. The instructions loaded at these locations cause the microprocessor to branch to a non-maskable interrupt routine in memory.
$\overline{\mathrm{NMI}}$ also requires an external $3 \mathrm{~K} \Omega$ register to $\mathrm{V}_{\mathrm{CC}}$ for proper wire-OR operations.

Inputs $\overline{\mathrm{RQ}}$ and $\overline{\mathrm{NMI}}$ are hardware interrupts lines that are sampled during $\varnothing 2$ (phase 2 ) and will begin the appropriate interrupt routine on the $\varnothing 1$ (phase 1) following the completion of the current instruction.

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

A negative going edge on the $\overline{\mathrm{SO}}$ input sets the overflow bit in the Processor Status Register. This signal is sampled on the trailing edge of $\emptyset 1$ and must be externally synchronized.

## SYNC

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

## RESET (RES)

The active low $\overline{R E S}$ resets, or starts, the microprocessor from a power down or restart condition. During the time that this line is held low, writing to or from the microprocessor is inhibited. When a positive edge is detected on the input, the microprocessor will immediately begin the reset sequence.

After a system initialization time of six clock cycles, the mask interrupt flag is set and the microprocessor loads the program counter from the memory vector locations FFFC and FFFD. This is the start location for program control.

After $V_{\text {CC }}$ 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 $\bar{W}$ and SYNC signals become valid.

## R6502 FEATURES

- 64 K addressable bytes of memory (A0-A15)
- $\overline{\mathrm{RQ}}$ interrupt

- On-chip clock

TTL-level single phase input
RC time base input
crystal time base input

- SYNC signal
(can be used for single instruction execution)
- RDY signal
(can be used to halt or single cycle execution)
- Two phase output clock for timing of support chips
- $\overline{\mathrm{NMI}}$ interrupt
- 40-pin DIP



## R6504 FEATURES

- 8 K addressable bytes of memory (A0-A12)
- On-chip clock
- $\overline{R Q}$ interrupt
- 8-bit bidirectional data bus
- 28-pin DIP



## R6505 FEATURES

- 4 K addressable bytes of memory (A0-A11)
- On-chip clock
- $\overline{\mathrm{RQ}}$ interrupt
- RDY signal
- 8-bit bidirectional data bus
- 28-pin DIP



## R6513 FEATURES

- 4K addressable bytes of memory (A0-A11)
- Two phase clock input
- $\overline{\mathrm{RQ}}$ interrupt
- NMI interrupt
- 8 -bit bidirectional data bus
- 28-pin DIP



## R6514 FEATURES

- 8K addressable bytes of memory (A0-A12)
- Two phase clock input
- $\overline{\mathrm{RQ}}$ interrupt
- 8-bit bidirectional data bus



## R6515 FEATURES

- 4 K addressable bytes of memory (A0-A11)
- Two phase clock input
- $\overline{\mathrm{RQ}}$ interrupt
- RDY signal
- 8-bit bidirectional data bus



## R6506 FEATURES

- 4K addressable bytes of memory (A0-A11)
- On-chip clock
- $\overline{\mathbf{R Q}}$ interrupt
- Two phase output clock for timing of support chips
- 8-bit bidirectional data bus
- 28-pin DIP



## R6507 FEATURES

- 8 K addressable bytes of memory (A0-A12)
- On-chip clock
- RDY signal
- 8-bit bidirectional data bus
- 28-pin DIP



## R6512 FEATURES

- 64 K addressable bytes of memory (A0-A15)
- $\overline{\mathrm{RQ}}$ interrupt
- $\overline{\mathrm{NMI}}$ interrupt
- RDY signal
- 8-bit bidirectional data bus
- SYNC signal
- Two phase clock input
- Data Bus Enable
-40-pin DIP

*Pins 37 and 39 are connected internally


## FUNCTIONAL DESCRIPTION

The internal organization of all R6500 CPUs is identical except for some variations in clock interface, the number of address output lines, and some unique input/output lines between versions.

## CLOCK GENERATOR

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

## TIMING CONTROL

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

## PROGRAM COUNTER

The 16-bit program counter provides the addresses which step the microprocessor through sequential instructions in a program.

Each time the microprocessor fetches an instruction from program memory, the lower byte of the program counter (PCL) is placed on the low-order bits of the address bus and the higher byte of the program counter (PCH) is placed on the high-order 8 bits. The counter is incremented each time an instruction or data is fetched from program memory.

## INSTRUCTION REGISTER AND DECODE

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

## ARITHMETIC AND LOGIC UNIT (ALU)

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

## ACCUMULATOR

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

## INDEX REGISTERS

There are two 8 -bit index registers ( $X$ and $Y$ ), which may be used to count program steps or to provide an index value to be used in generating an effective address.

When executing an instruction which specifies indexed addressing, the CPU fetches the op code and the base address, and modifies the address by adding the index register to it prior to performing the desired operation. Pre- or post-indexing of indirect addresses is possible (see addressing modes).

## STACK POINTER

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

## PROCESSOR STATUS REGISTER

The 8-bit processor status register contains seven status flags. Some of the flags are controlled by the program, others may be controlled both by the program and the CPU.


## INSTRUCTION SET

The R6500 CPU has 56 instruction types which are enhanced by up to 13 addressing modes for each instruction. The accu-
mulator, index registers, Program Counter, Stack Pointer and Processor Status Register are illustrated below.

## Alphabetic Listing of Instruction Set

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



## ADDRESSING MODES

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

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

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

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

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

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

INDEXED ABSOLUTE ADDRESSING [ABS, X or Y$]$ - $(\mathrm{X}, \mathrm{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 [Implied]-In the implied addressing mode, the address containing the operand is implicitly stated in the operation code of the instruction.

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

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

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

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

ABSOLUTE INDIRECT [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 are contained in the third byte of the instruction. The contents of the fully specified memory location are the low order byte of the effective address. The next memory location contains the high order byte of the effective address which is loaded into the sixteen bits of the program counter. (JMP (IND) only)

## INSTRUCTION SET OP CODE MATRIX

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



## INSTRUCTION SET SUMMARY

| instructions |  | Immediate |  |  | absolute |  | zero page |  |  |  |  | Implifo |  |  |  | (1NO). r |  | 2 Page. ${ }^{\text {a }}$ |  |  | ABS . ${ }^{\text {a }}$ |  |  |  |  | relative |  | Indinect | 2 Page. r |  | PROCESSOR STATUSCOOES |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| mNemonic | operation | OP $n$ | $n$ | OP | OP $n$ | T. | OP | n | $\cdots$ - ${ }^{\circ}$ | OP $n$ | " OP | n | " ${ }^{\circ}$ | OP $n$ | $\cdots$ | OP | $n$ | OP | P | " | OP | $n$ | " OP | Of $n$ | " | n | OP |  | OP $n$ | n |  | UnEMONIC |
| $\begin{aligned} & \hline A D C \\ & A N D \\ & \text { ASL } \\ & \text { BCC } \\ & \text { BCS } \\ & \hline \end{aligned}$ | $A+M+C-A$ (4) (1) <br> $A A M-A$  <br> $C-1$  <br> (1)  <br> BRANCHON -0  <br> BRANCHON $=0$ (2) <br> (2)  | 69 2 <br> 29 2 | 2 2 <br> 2 2 | $\begin{array}{l\|l} \hline 2 & 60 \\ 2 & 20 \\ & 20 \end{array}$ |  | 3 | 65 | 3 3 5 | 2 | OA 2 | , |  |  | 61 6 <br> 21 6 | 2 | 71, | 5 2 <br> 5 2 | 2 75 <br> 2.  <br> 35  <br>   <br> 16  |  4 <br> 16  | 2 | 70 <br> 30 <br> $1 E$ | 4 | 3 79 <br> 3 39 | 9 4 <br> 39 4 | 0 | 疗 |  |  |  |  |  | $\begin{aligned} & \text { ADC } \\ & \text { AND } \\ & A S L \\ & B C C \\ & B C S \\ & \hline \end{aligned}$ |
| $\begin{aligned} & \hline \text { BEO } \\ & \text { BIT } \\ & \text { BM } \\ & \text { BNE } \\ & \text { BPL } \\ & \hline \end{aligned}$ | BRANCHONZ = 1 (2) <br> AAM <br> BRANCHONN = 1 (2) <br> BRANCHONZ =O (2) <br> BRANCHONN $=0$ (2) |  |  |  | 2 C 4 | 3 | 24 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0 | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ |  |  |  | $\begin{array}{cccc}\cdot & . & . & .\end{array} \cdot$. | $\begin{aligned} & \hline \text { BEO } \\ & \text { BIT } \\ & \text { BM } \\ & \text { BNE } \\ & \text { BPL } \end{aligned}$ |
| $\begin{aligned} & \hline B R K \\ & B V C \\ & B V S \\ & C L C \\ & C L D \\ & \hline \end{aligned}$ | break <br> BRANCHONV =O (2) <br> BRANCHONV = 1 (2) $\begin{aligned} & 0 \rightarrow c \\ & 0 \rightarrow 0 \end{aligned}$ |  |  |  |  |  |  |  |  |  | [00 |  | 1 1 1 1 |  |  |  |  |  |  |  |  |  |  |  | 50 | 2 |  |  |  |  |  | $\begin{aligned} & B . R K \\ & B \vee C \\ & B \vee S \\ & C L C \\ & C L D \end{aligned}$ |
| $\begin{aligned} & \hline C L I \\ & C L V \\ & C M P \\ & C P X \\ & C P Y \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 0 \rightarrow 1 \\ & 0 \rightarrow V \\ & A-M \\ & X-M \\ & Y-M \end{aligned}$ |  | 2 | $\begin{array}{l\|l\|} 2 & \mathrm{CD} \\ 2 & \mathrm{EC} \\ 2 & \mathrm{CC} \\ \hline \end{array}$ | $\begin{array}{l\|l} C D & 4 \\ \text { EC } & 4 \\ C C & 4 \\ \hline \end{array}$ |  |  | 3 <br> 3 <br> 3 | 2 <br> 2 <br> 2 |  | 888 |  | 1 | C1 6 | 2 | D1 | 52 | 2 D5 | 5 | 2 | DD | 4 | 3 D9 | 894 | 3 |  |  |  |  |  |  | $\begin{aligned} & \hline C L I \\ & C L V \\ & C M P \\ & C P X \\ & C P Y \\ & \hline \end{aligned}$ |
| $\begin{aligned} & \hline \text { DEC } \\ & \text { DEX } \\ & \text { DEY } \\ & \text { EOR } \\ & \text { INC } \\ & \hline \end{aligned}$ | $\begin{aligned} & M-1 \rightarrow M \\ & X-1 \rightarrow X \\ & Y-1 \rightarrow Y \\ & A \forall M \rightarrow A \\ & M+1 \rightarrow M \end{aligned}$ | 492 | 2 |  |  | 3 |  | 5 <br>  <br> 3 <br> 5 | 2 <br> 2 <br> 2 |  | CA |  |  | 41.6 | 2 | 51. | 52 | D6 <br> 55 <br> 56 <br> 8 | 6 | 2 | $\begin{array}{\|c\|} \hline \mathrm{OE} \\ \hline \mathrm{SO} \\ \hline \end{array}$ | 7 | $\begin{array}{\|l\|l} \hline & \\ & \\ 3 & 59 \\ 3 & \\ \hline \end{array}$ | 594 | 3 |  |  |  |  |  |  | $\begin{aligned} & \hline D E C \\ & D E X \\ & D E Y \\ & E O R \\ & \text { INC } \\ & \hline \end{aligned}$ |
| INX INY INP JMP JSR LDA | $\begin{aligned} & \hline x+1-x \\ & y+1-y \\ & \text { JUMP TONEW LOC } \\ & \text { JUMP SUB } \\ & M \rightarrow A \\ & \hline \end{aligned}$ | ${ }^{\text {A9 }} 2$ |  | $\begin{aligned} & 4 C \\ & 20 \\ & A D \\ & \hline \end{aligned}$ | $\begin{array}{c\|c} 4 C & 3 \\ 20 & 6 \\ A D & 4 \\ \hline \end{array}$ |  | A5 | ${ }^{1}$ | 2 |  | E8 | 2 |  | $\text { A1 } 6$ | 2 | B1 | 52 | 85 | ${ }_{5}$ | 2 | 80 | ${ }_{4}$ | 3 B9 | 89 4 | 3 |  | 6 C | 3 |  |  |  | $\begin{aligned} & \text { INX } \\ & \text { INY } \\ & \text { JMP } \\ & \text { JSR } \\ & \text { LDA } \end{aligned}$ |
| $\begin{aligned} & \text { LDX } \\ & \text { LDY } \\ & \text { LSR } \\ & \text { NOP } \\ & \text { ORA } \end{aligned}$ |  | $\begin{array}{\|c\|c} \hline \mathrm{A} 2 & 2 \\ \mathrm{AO} & 2 \\ & 2 \\ & 209 \\ & 2 \end{array}$ | $\begin{array}{\|l\|} \hline 2 \\ 2 \\ 2 \\ 2 \end{array}$ | $\begin{array}{l\|l} \hline 2 & \mathrm{AE} \\ 2 & \mathrm{AC} \\ & A E \\ 2 & \mathrm{OD} \\ \hline \end{array}$ |  | $\begin{aligned} & 3 \\ & 3 \\ & 3 \\ & 3 \end{aligned}$ |  | $\begin{aligned} & 3 \\ & 3 \\ & 5 \\ & 3 \\ & 3 \end{aligned}$ | $\begin{array}{\|l\|l} \hline 2 \\ 2 \\ 2 & \\ 2 & 4 \mathrm{~A} \\ 2 & \\ \hline \end{array}$ | $\|4 \mathrm{~A}\|^{2}$ | $1{ }^{\text {EA }}$ | 2 |  | 016 | 2 |  |  | 84 <br> 56 <br> 2 |  | $2$ | $\begin{aligned} & B C \\ & 5 E \\ & 10 \end{aligned}$ |  | $\begin{array}{\|l\|l\|} \hline & B E \\ 3 & \\ 3 & \\ 3 & 19 \\ \hline \end{array}$ |  | $3$ |  |  |  | 86 | 4 |  | $\begin{aligned} & \text { LDAX } \\ & \text { LOA } \\ & \text { LSR } \\ & \text { NOP } \\ & \text { ORA } \end{aligned}$ |
| PHA <br> PHP <br> PLA <br> PLP <br> ROL <br> POR | $A \rightarrow M \mathrm{~S}$ $\mathrm{~S}-1 \rightarrow \mathrm{~S}$ <br> $\mathrm{P} \rightarrow \mathrm{MS}$ $\mathrm{S}-1 \rightarrow \mathrm{~S}$ <br> $\mathrm{~S}+1 \rightarrow \mathrm{~S}$ $\mathrm{Ms} \rightarrow \mathrm{A}$ <br> $\mathrm{S}+1 \rightarrow \mathrm{~S}$ $\mathrm{Ms} \rightarrow \mathrm{P}$ <br> A CD |  |  |  | 2 E 6 |  | 26 | 5 | 2 A | 2 A 2 | ( 48 | 3 3 4 4 | 1 1 1 1 |  |  |  |  |  | ${ }_{6} 6$ | 2 | 3 E | , | ${ }_{3}$ |  |  |  |  |  |  |  |  | $\begin{aligned} & \hline P H A \\ & P H P \\ & P L A \\ & P L P \\ & R O L \end{aligned}$ |
| Bor <br> R TI <br> RTS <br> SBC <br> SEC <br> SED | C단 <br> rtrnint <br> rtansub $\begin{align*} & A-M-\bar{C} \rightarrow A  \tag{1}\\ & 1 \rightarrow C \\ & 1 \rightarrow D \end{align*}$ | E9 2 | 2 |  |  |  | E5 | ${ }^{5}$ |  | $\begin{array}{\|c\|} 6 A \\ \hline \end{array}$ | 40 <br> 60 <br> 38 <br> 88 <br> 8 | 6 6 2 2 | $\begin{gathered} 1 \\ 1 \\ 1 \\ 1 \\ 1 \end{gathered}{ }_{E=1}$ | E1 6 | 2 | F1 | 52 |  | 6 |  | $\mathrm{F}_{\text {f }}^{\text {fo }}$ | ${ }^{7}$ | $3_{3}{ }_{59}$ | 9.4 | 3 |  |  |  |  |  |  | AOR <br> R TI <br> RTS <br> SBC <br> SEC <br> SED |
| STEI <br> STA <br> STA <br> STY <br> TAX <br> SAY | $\begin{aligned} & 1-1 \\ & A \rightarrow M \\ & X \rightarrow M \\ & Y \rightarrow M \\ & A \rightarrow X \end{aligned}$ |  |  |  | 30 4 <br> $B E$ 4 <br> $3 C$ 4 | ( $\begin{aligned} & 3 \\ & 3 \\ & 3\end{aligned}$ | $\begin{aligned} & 85 \\ & 86 \\ & 84 \end{aligned}$ | 3 3 3 | 2 |  | $F_{78}$ <br> AA |  | ${ }^{1} 8$ | 31.6 | 2 | 91 | $6 \cdot 2$ |  | 5 | , | 90 | 5 | 399 | 995 | 3 |  |  |  | 96 | 42 | $\cdots \cdots$ | SEE <br> STA <br> STA <br> STA <br> STY <br> TAX <br> TAY |
| TAX <br> TAY <br> TSX <br> TXA <br> TXS <br> TYA | $\begin{aligned} & A-Y \\ & S-X \\ & X \rightarrow A \\ & X \rightarrow S \\ & Y \rightarrow A \\ & \hline \end{aligned}$ |  |  |  |  |  |  |  |  |  | AB | 2 <br> 2 <br> 2 <br> 2 <br> 2 <br> 2 | 1 1 1 1 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | TAXY <br> TS X <br> TXA <br> TXS <br> TYA <br> He |
| (1) ADD 1 10 N IF PAGE BOUNDARY IS CROSSED <br> (21 ADD ITO N IF BRANCH OCCURS TO SAME PAGE <br> ADD 2 TO N IF BRANCH OCCURS TO DIFFERENT PAGE <br> (3) CARRY NOT $=$ BORROW <br> (4) IF IN DECIMAL MODE Z FLAG IS INVALID ACCUMULATOR MUST BE CHECKED FORZERO RESULT |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | M ${ }_{\text {M }}$ | $M_{S}$ |  |  | $\begin{aligned} & \text { UYATO } \\ & \text { ZY PER } \end{aligned}$ | or <br> EfF <br> RTA | $\begin{aligned} & \text { FECTIV } \\ & \text { CKK } \end{aligned}$ | $\begin{aligned} & \text { TIVE AD } \\ & \text { POINTE } \end{aligned}$ | $\begin{aligned} & \text { DERE } \\ & \text { TER } \end{aligned}$ |  |  |  | btrac <br> D <br> Clusive | VE OR | M. MEMORY <br> Mr MEMORY <br> $n$ No. CYCL <br> " no. bytes |  |

## R650X CLOCK TIMING



## R651X CLOCK TIMING



R65XX READ WRITE TIMING


## AC CHARACTERISTICS

| Characteristic | Symbol | $\begin{aligned} & \hline \text { R65XX } \\ & (1 \mathrm{MHz}) \end{aligned}$ |  | $\begin{aligned} & \hline \text { R65XXA } \\ & (2 \mathrm{MHz}) \end{aligned}$ |  | $\begin{aligned} & \text { R65XXB } \\ & \text { ( } 3 \mathrm{MHz} \text { ) } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| R650X CLOCK TIMING |  |  |  |  |  |  |  |  |
| Clock Cycle Time | $\mathrm{T}_{\text {cre }}$ | 1.0 | 10 | 0.5 | 10 | 0.33 | 10 | $\mu s$ |
| 00 (IN) Low Pulse Width | $\mathrm{T}_{\text {Løо }}$ | 480 | - | 240 | - | 160 | - | ns |
| $\emptyset 0$ (IN) High Pulse Width | $\mathrm{T}_{\text {нøо }}$ | 460 | - | 240 | - | 160 | - | ns |
| 90 (IN) Rise and Fall Time ${ }^{1,2}$ | $\mathrm{T}_{\text {Ro, }}, \mathrm{T}_{\text {Fo }}$ | - | 10 | - | 10 | - | 10 | ns |
| \$1 (OUT) High Pulse Width | $\mathrm{T}_{\text {PWH01 }}$ | 460 | - | 235 | - | 155 | - | ns |
| \$2 (OUT) High Pulse Width | T ${ }_{\text {PWH02 }}$ | 460 | - | 240 | - | 160 | - | ns |
| Delay Between $\$ 1$ (OUT) and $\downarrow 2$ (OUT) | $\mathrm{T}_{\mathrm{D}}$ | 0 | - | 0 | - | 0 | - | ns |
| $\$ 1$ (OUT), $\$ 2$ (OUT) Rise and Fall Time ${ }^{1,2}$ | $\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}$ | - | 25 | - | 25 | - | 15 | ns |

## R651X CLOCK TIMING

| Clock Cycle Time | Tcre | 1.0 | 10 | 0.5 | 10 | 0.33 | 10 | $\mu \mathrm{s}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$1 (IN) High Pulse Width | TPWH01 | 430 | - | 215 | - | 150 | - | ns |
| \$2 (IN) High Pulse Width | $\mathrm{T}_{\text {PWH02 }}$ | 470 | - | 235 | - | 160 | - | ns |
| Delay Between $\emptyset 1$ and $\emptyset 2$ | $\mathrm{T}_{\mathrm{D}}$ | 0 | - | 0 | - | 0 | - | ns |
| ¢1 (IN), $\varnothing 2$ (IN) Rise and Fall Time ${ }^{1,3}$ | $\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}$ | - | 25 | - | 20 | - | 15 | ns |

R65XX READ/WRITE TIMING

| $\mathbf{R} \bar{W}$ Setup Time | $\mathrm{T}_{\text {RWs }}$ | - | 225 | - | 140 | - | 110 | ns |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| $\mathbf{R} \bar{W}$ Hold Time | $\mathrm{T}_{\text {HRW }}$ | 30 | - | 30 | - | 15 | - | ns |
| Address Setup Time | $\mathrm{T}_{\text {ADS }}$ | - | 225 | - | 140 | - | 110 | ns |
| Address Hold Time | $\mathrm{T}_{\text {HA }}$ | 30 | - | 30 | - | 15 | - | ns |
| Read Access Time | $\mathrm{T}_{\text {ACC }}$ | - | 650 | - | 310 | - | 170 | ns |
| Read Data Setup Time | $\mathrm{T}_{\text {DSU }}$ | 100 | - | 50 | - | 50 | - | ns |
| Read Data Hold Time | $\mathrm{T}_{\text {HR }}$ | 10 | - | 10 | - | 10 | - | ns |
| Write Data Setup Time | $\mathrm{T}_{\text {MDS }}$ | - | 175 | - | 100 | - | 85 | ns |
| Write Data Hold Time | $\mathrm{T}_{\text {HW }}$ | 30 | - | 30 | - | 15 | - | ns |
| SYNC Hold Time | $\mathrm{T}_{\text {SYH }}$ | 30 | - | 30 | - | 15 | - | ns |
| RDY Setup Time | $\mathrm{T}_{\text {ROY }}$ | 100 | - | 50 | - | 35 | - | ns |
| $\overline{\text { SO Setup Time }}$ | $\mathrm{T}_{\text {SO }}$ | 100 | - | 50 | - | 35 | - | ns |
| SYNC Setup Time | $\mathrm{T}_{\text {SYN }}$ | - | 225 | - | 140 | - | 110 | ns |

## Notes:

1. Loads: All output except clocks $=1 \mathrm{TTL}+130 \mathrm{pF}$. Clock outputs $=1 \mathrm{TTL}+30 \mathrm{pF}$.
2. Measured between 0.8 and 2.0 points on waveform load.
3. Measured between $10 \%$ and $90 \%$ points on waveforms.
4. *RDY must never switch states within R $_{\text {foy }}$ to end of $\emptyset 2$.

RECOMMENDED TIME BASE GENERATION FOR R6502

*CRYSTAL: CTS KNIGHTS MP SERIES, OR EQUIVALENT

## ABSOLUTE MAXIMUM RATINGS*

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

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

## OPERATING CONDITIONS

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

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min. | Typ. ${ }^{5}$ | Max. | Unit ${ }^{1}$ | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage Logic, $\emptyset 0$ (IN) $\$ 1$ (IN), $\varnothing_{2}^{(I N)}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{gathered} 2.0 \\ \mathrm{v}_{\mathrm{cc}}-0.3 \\ \hline \end{gathered}$ | - | $\begin{gathered} v_{c c} \\ v_{C C}+0.25 \end{gathered}$ | V |  |
| Input Low Voltage <br> Logic, $\varnothing 0$ (IN) <br> $\$ 1$ (IN), $\varnothing_{2}$ (IN) | $\mathrm{V}_{\mathrm{IL}}$ | $\begin{array}{r} -0.3 \\ -0.3 \end{array}$ | - | $\begin{aligned} & 0.8 \\ & 0.4 \end{aligned}$ | V |  |
| ```Input Leakage Current Logic (Excl. RDY, S.O.) $1 (IN), $2 (IN) 00 (IN)``` | $\mathrm{I}_{\mathrm{N}}$ | - | - | $\begin{gathered} 2.5 \\ 100 \\ 10 \end{gathered}$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V} \text { to } 5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three State Off DO-D7 | ${ }^{\text {TSI }}$ | - | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage <br> SYNC, DO-D7, AO-A15, R $\bar{W}, ~ \emptyset 1$ (OUT), $\emptyset 2$ (OUT) | $\mathrm{V}_{\mathrm{OH}}$ | +2.4 | - | - | v | $\begin{aligned} & V_{\text {LOAD }}=-100 \mu \mathrm{~A} \\ & V_{C C}=4.75 \mathrm{~V} \end{aligned}$ |
| Output Low Voltage <br> SYNC, DO-D7, AO-A15, R $\bar{W}, ~ \emptyset 1$ (OUT), $\$ 2$ (OUT) | $\mathrm{V}_{\mathrm{OL}}$ |  |  | +0.4 | V | $\begin{aligned} & \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \end{aligned}$ |
| Power Dissipation 1 and 2 MHz 3 MHz | $\mathrm{P}_{\mathrm{D}}$ | - | $\begin{aligned} & 450 \\ & 500 \end{aligned}$ | $\begin{aligned} & 700 \\ & 800 \end{aligned}$ | mW |  |
| Capacitance Logic DO-D7 AO-A15, R $\bar{W}$, SYNC 00 (IN) 01 (IN) 02 (IN) | C <br> $\mathrm{C}_{\text {IN }}$ <br> $\mathrm{C}_{\text {OUT }}$ Co(IN) C01 <br> C02 | ー | $\begin{aligned} & \overline{30} \\ & 50 \end{aligned}$ | $\begin{aligned} & 10 \\ & 15 \\ & 12 \\ & 15 \\ & 50 \\ & 80 \end{aligned}$ | pF | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V} \\ & V_{I N}=0 \mathrm{~V} \\ & f=1 \mathrm{MHz} \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |

## Notes:

1. All units are direct current (dc) except for capacitance.
2. Negative sign indicates outward current flow, positive indicates inward flow.
3. $\overline{\mathrm{RQ}}$ and NMI require 3 K pull-up resistor.
4. $\emptyset_{1}(\mathrm{IN})$ and $\$ 2(\mathrm{IN})$ apply to R6512, 13, 14, and 15 ; $\emptyset 0(\mathrm{IN})$ applies to R6502, 03, 04, 05,06 and 07.
5. Typical values shown for $\mathrm{V}_{C C}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## R6501Q AND R6511 Q ONE-CHIP MICROPROCESSOR

## INTRODUCTION

The Rockwell R6501Q and R6511Q are extended, high performance 8-bit NMOS-3, single chip microprocessors, and are compatible with all members of the R6500 family.

The devices contain an enhanced R6502 CPU, an internal clock oscillator, 192 bytes of Random Access Memory, 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. A full 16 -bit address bus and 8 -bit data bus provide accessing to 65 K bytes of external memory.
The devices come in a 64-pin Quad Inline package (QUIP).
The devices may be used as a CPU-RAM-I/O counter device in multichip systems or as an emulator for the R6500/11 family of microcomputers. They provide all R6500/11 interface lines, plus the address bus, data bus and control lines to interface with external memory.

## SYSTEMS DEVELOPMENT

Rockwell supports development of the devices with the Rockwell Design Center System and the R6500/* Personality Set: Complete in-circuit emulation with the Personality Set allows total systems test and evaluation.

This data sheet is for the reader familiar with the R6502 CPU hardware and programming capabilities. For additional information see the R6501Q Product Description, (Document Order Number 2145) or the R6511Q Product Description, (Document Order Number 2133).

ORDERING INFORMATION

| Part <br> Number | Package <br> Type | Frequency <br> Option | Temp. <br> Range |
| :--- | :---: | :---: | :---: |
| R6501Q | Plastic (QUIP) | 1 MHz | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| R6501AQ | Plastic (QUIP) | 2 MHz | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| R6511Q | Plastic (QUIP) | 1 MHz | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| R6511AQ | Plastic (QUIP) | 2 MHz | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |

## FEATURES

[^3]- 192-byte static RAM
- 32 bidirectional, TTL-compatible I/O lines (four ports)
- One 8-bit port may be tri-stated under software control
- One 8-bit port may have latched inputs under software control
- Two 16-bit programmable counter/timers, with 3 latches
-Pulse width measurement
-Pulse generation (1 symmetrical, 1 asymmetrical)
-Interval timer
-Event counter
-Retriggerable interval timer
- Serial Port - Full Duplex, Buffered UART
-Receiver Wake Up and Transmitter End of Transmission Features
-Programmable Standard Asynchronous Baud Rates from 50 to 125 K bits/sec at 2 MHz
Satisfies SMPTE 422 Broadcast Standard (8 Data, Parity, 1 Stop) at 38.4 K bits/sec
-Programmable 5-8 bit Character Lengths, with or without parity
-Receiver Error Detection for Framing, Parity, and Overrun
-Synchronous Shift Register alternate mode (250KC at 2 MHz )
- Ten interrupts
-Four edge-sensitive lines; two positive, two negative
-Two counter underflows
-Serial data receiver buffer full
-Serial data transmitter buffer empty
-Non-maskable
-Reset
- Full data and address pins for 65K bytes of external memory
- Flexible clock circuitry
-2 MHz or 1 MHz internal operation
-Internal clock with external XTAL at four times internal frequency (R6501Q) or two times internal frequency (R6511Q)
—External clock input divided by one or four (R6501Q) or one or two (R6511Q)
- 68\% of the instructions have execution times less than $2 \mu \mathrm{~S}$ at 2 MHz
- NMOS-3 silicon gate, depletion load technology
- Single +5 V power supply
- 12 mW stand-by power for 32 bytes of the 192-byte RAM
- 65-pin QUIP
- R6501Q has pullup resistors on PA, PB, and PC R6511Q has no pullup resistors


## FUNCTIONAL DESCRIPTION

## CENTRAL PROCESSING UNIT (CPU)

The internal CPU of the device is a standard R6502 configuration with the standard R6502 instructions plus 4 new bit manipulation instructions. These new bit manipulator instructions form an enhanced R6502 instruction set and improve memory utilization efficiency and performance.

## Set Memory Bit (SMB \#,ADDR.)

This instruction sets to " 1 " one bit of the 8 -bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and which one of 8 bits to be set. The second byte of the instruction designates the address $(0-225)$ of the byte or I/O port to be operated upon.

## Reset Memory Bit (RMB \#,ADDR.)

This instruction is the same operation and format as the SMB instruction except a reset to " 0 " of the bit results.

## Branch on Bit Set Relative (BBS \#,ADDR.,DEST)

This instruction tests one of 8 bits designated by a 3-bit immediate field within the first byte of the instruction. The second byte is used to designate the location of the byte or I/O port to be tested within the zero page address range. The third byte of the instruction is used to specify the 8-bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

## Branch on Bit Reset Relative (BBR \#,ADDR.,DEST)

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

## Random Access Memory (RAM)

The RAM consists of 192 by 8 bits of read/write memory with an assigned page zero address of 0040 through 00FF. The devices provide a separate power pin ( $\mathrm{V}_{\mathrm{RR}}$ ) which may be used for standby power. In the event of the loss of $\mathrm{V}_{\mathrm{Cc}}$ power, the lowest 32 bytes of RAM data will be retained if standby power is supplied to the $V_{R R}$ pin.

## Clock Oscillator

The clock oscillator provides the basic timing signals. A reference frequency can be generated with the on board oscillator (with external crystal) or an external reference source can be driven into the XTLI pin. If the XTLO pin is left floating, the reference frequency is internally divided by four (R6501Q) or two (R6511Q) to obtain the internal clock. The internal clock is then available as an output at the $\varnothing 2 \mathrm{pin}$. The XTLI pin may be used as an undivided clock input by connecting XTLO to $\mathrm{V}_{\mathrm{SS}}$, in which case the internal division circuitry is bypassed and the device operates at the reference frequency.

## Paraliel Input/Output Ports

The devices have 32 I/O lines grouped into four 8-bit ports (PA, PB, PC, PD). Ports A through C may be used either for input or output individually, or in groups of any combination. The

R6501Q has pullup resistors on PA, PB and PC. The R6511Q has no pullup resistors. Port D may be used as all inputs or all outputs. It has active pull-ups.

Port A (PA) can be programmed as a standard parallel 8-bit I/O port or under software control as serial I/O lines, counter I/O lines, positive (2) and negative (2) edge detects, or an input data strobe for the Port $B(P B)$ input latch.

Port B(PB) can be programmed as an I/O port with latched input enabled or disabled.

Port C (PC) can be programmed as an I/O port, as an abbreviated bus, as a multiplexed bus, or as part of the full address mode. In the full address mode pins PC6 and PC7 serve as addresses A13 and A14, respectively; PC0-PC5 are I/O pins.

Port D (PD) functions as an I/O port, an 8-bit tri-state data bus, or as a multiplexed address/data bus.

## Serial Input/Output Channel - UART

The devices provide a full duplex serial I/O channel with programmable bit rates covering all standard baud rates from 50 to 125 K bits/sec including the SMPTE 422 standard at 38.4 K bits/ sec. Character lengths of 5 to 8 bits, with or without parity are programmable. A full complement of flags provides for Receiver Wake Up; Receiver Buffer Full; Receiver Error Conditions detecting Framing, Parity, and Overrun errors; Transmitter End of Transmission and Transmitter Buffer Empty. In addition, a synchronous shift register mode to 250 KC at 2 MHz is available.

## Wake-Up Feature

In a multi-distributed microcomputer application, a destination address is usually included at the beginning of the message. The Wake-Up Feature allows non-selected CPUs to ignore the remainder of the message until the beginning of the next message by setting the Wake-Up bit.

## Counter/Latch Logic

The devices contain two 16-bit counters (Counter A and Counter B) and three 16-bit latches associated with the counters. Counter A has one 16-bit latch and Counter B has two 16-bit latches. Each counter can be independently programmed to operate in one of four modes:

> Counter A
> - Pulse width measurement
> - Pulse Generation
> - Interval Timer
> - Event Counter

## Counter B

- Retriggerable Interval Counter
- Assymmetrical Pulse Generation
- Interval Timer
- Event Counter


## Mode Control Register (MCR)

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for Counter A and Counter B.

## Ports C and D Operation Modes

There are four operating modes available in ports $C$ and $D$, software programmable via the Mode Control Register. The full address mode allows access to a full 65 K bytes of external storage. In this mode PC6 and PC7 are automaticallyu used for A13 and A14. In the Input/Output mode the four ports are all used for I/O. In the abbreviated and multiplexed modes some port pins set up for addressing 64 or 16,384 bytes of external memory.

Interrupt Flag Register (IFR) and Interrupt Enable Register (IER)

The devices include an Interrupt Flat Register and an Interrupt Enable Register which flags and controls I/O and counter status.


-MULTIPLEXED FÚNCTIONS PINS (Sotware Selectable)
BLOCK DIAGRAM
INTERNAL REGISTERS
WRITE
ADDRESS
001F
001E
0010
001 C
001B
001A
0019
0018
0017
0016
0015
0014
0013
0012
0011
0010
000F

0007
0006

0004
0003

0000

## KEY REGISTER SUMMARY



CPU Registers


Mode Control Register

Serial Communications Control Register


Interrupt Enable and Flag Registers


Serial Communications Status Register

## ABSOLUTE MAXIMUM RATINGS*

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

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

## DC CHARACTERISTICS

$\left(V_{C C}=5 \mathrm{~V} \pm 5 \% V_{S S}=0\right)$

| Parameter | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipation (Outputs High) Commercial at $25^{\circ} \mathrm{C}$ | $P_{\text {D }}$ | - | - | 1200 | mW |
| RAM Standby Voltage (Retention Mode) | $\mathrm{V}_{\mathrm{RR}}$ | 3.0 | - | $\mathrm{V}_{\mathrm{CC}}$ | Vdc |
| RAM Standby Current (Retention Mode) Commercial at $25^{\circ} \mathrm{C}$ | $I_{R R}$ | - | 4 | - | mAdc |
| Input High Voltage Except XTLI | $\mathrm{V}_{\mathrm{H}}$ | $+2.0$ | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Input High Voltage (XTLI) | $\mathrm{V}_{\mathrm{IH}}$ | +4.0 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | -0.3 | - | $+0.8$ | Vdc |
| Input Leakage Current ( $\overline{\mathrm{RES}}, \overline{\mathrm{NMI}})$ $\mathrm{V}_{\mathrm{IN}}=0 \text { to } 5.0 \mathrm{Vdc}$ | IN | - | - | $\pm 10$ | $\mu$ Adc |
| Input Low Current $\left(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{Vdc}\right)$ | IL | - | -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 | - | $\mathrm{V}_{\mathrm{CC}}$ | Vdc |
| Output Low Voltage ( LOAD $=1.5 \mathrm{mAdc}$ ) | $\mathrm{V}_{\mathrm{OL}}$ | - | - | $+0.4$ | Vdc |
| Input Capacitance $\begin{aligned} & \left(V_{I N}-0, T_{A}=25^{\circ} \mathrm{C}, f=1.0 \mathrm{MHz}\right) \\ & \text { XTL1, XTLO } \\ & \text { All Others } \end{aligned}$ | $\mathrm{C}_{\mathrm{IN}}$ | - | - | $\begin{aligned} & 50 \\ & 10 \\ & \hline \end{aligned}$ | pF |
| I/O Port Pull-Up Resistance PA0-PA7, PB0-PB7, PC0-PC7 R6501Q only | $R_{L}$ | 3.0 | 6.0 | 11.5 | K $\Omega$ |

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

AC CHARACTERISTICS
$\left(V_{C C}=5 \mathrm{~V} \pm 6 \% V_{S S}=0\right.$

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

## PACKAGE DIMENSIONS



## R6520 <br> PERIPHERAL INTERFACE ADAPTER (PIA)

## DESCRIPTION

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

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

## ORDERING INFORMATION



## FEATURES

- Direct replacement for MC6820 PIA
- Two 8-bit bidirectional I/O ports with individual data direction control
- Automatic "Handshake" control of data transfers
- Two interrupts (one for each port) with program control
- Commercial and industrial temperature range versions
- 40-pin plastic and ceramic versions
- 5 volt $\pm 5 \%$ supply requirements
- Compatible with the R6500, R6500/* and R65C00 family of microprocessors
- 1 and 2 MHz versions


Figure 1. R6520 Pin Configuration

## FUNCTIONAL DESCRIPTION

The R6520 PIA is organized into two independent sections referred to as the A Side and the B Side. Each section consists of a Control Register (CRA, CRB), Data Direction Register (DDRA, DDRB), Output Register (ORA, OBR), Interrupt Status Control (ISCA, ISCB), and the buffers necessary to drive the

Peripheral Interface buses. Data Bus Buffers (DBB) interface data from the two sections to the data bus, while the Data Input Register (DIR) interfaces data from the DBB to the PIA registers. Chip Select and R/W control circuitry interface to the processor bus control lines. Figure 2 is a block diagram of the R6520 PIA.


Figure 2. R6520 PIA Block Diagram

## DATA INPUT REGISTER (DIR)

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

## CONTROL REGISTERS (CRA and CRB)

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

## DATA DIRECTION REGISTERS (DDRA, DDRB)

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

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

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

## PERIPHERAL OUTPUT REGISTERS (ORA, ORB)

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

## INTERRUPT STATUS CONTROL (ISCA, ISCB)

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

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

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

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

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

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

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

Table 1. Control Registers Bit Designations

| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| IRQA1 | IRQA2 | CA2 Control | DDRA <br> Access | $\mathbf{1}$ |  |
| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ |
| CA1 Control |  |  |  |  |  |
| IRQB1 | IRQB2 |  | CB2 Control | DDRB <br> Access | $\mathbf{1}$ |

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

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

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

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

## DATA BUS BUFFERS (DBB)

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

## INTERFACE SIGNALS

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

The PIA interfaces to the peripheral devices with four interrupt/ control lines and two 8 -bit bidirectional data buses.

Figure 1 (on the front page) shows the pin assignments for these interface signals and Figure 3 shows the interface relationship of these signal as they pertain to the CPU and the peripheral devices.

## CHIP SELECT (CSO, CS1, CS2)

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

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

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

## CLOCK SIGNAL (02)

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

## READ/WRITE SIGNAL (R/W)

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

## REGISTER SELECT (RSO, RS1)

The two Register Select lines (RS0, RS1), in conjunction with the Control Registers (CRA, CRB) Data Direction Register access bits (see Table 1, bit 2) select the various R65C21 registers to be accessed by the CPU. RS0 and RS1 are normally connected to the microprocessor (CPU) address output lines. Through control of these lines, the CPU can write directly into the Control


Figure 3. Interface Signals Relationship

Registers (CRA, CRB) the Data Direction Registers (DDRA, DDRB) and the Peripheral Output Registers (ORA, ORB). In addition, the processor may directly read the contents of the Control Registers and the Data Direction Registers. Accessing the Peripheral Output Register for the purpose of reading data back into the processor operates differently on the ORA and the ORB registers and therefore are shown separately in Table 2.

Table 2. ORA and ORB Register Addressing

| Register Address (Hex) | Register Select Lines |  | Data Direction Control |  | Register Operation |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS1 | RSO | $\begin{array}{\|c} \hline \text { CRA } \\ \text { (Bit 2) } \end{array}$ | $\begin{array}{c\|} \hline \text { CRB } \\ \text { (Bit 2) } \end{array}$ | $\mathrm{R} / \overline{\mathbf{W}}=\mathbf{H}$ | $\mathrm{R} \bar{W}=\mathrm{L}$ |
| 0 | L | L | 1 | - | Read PIBA | Write ORA |
| 0 | L | L | 0 | - | Read DDRA | Write DDRA |
| 1 | L | H | - | - | Read CRA | Write CRA |
| 2 | H | L | - | 1 | Read PIBB | Write ORB |
| 2 | H | L | - | 0 | Read DDRB | Write DDRB |
| 3 | H | H | - | - | Read CRB | Write CRB |

## INTERRUPT REQUEST LINES ( $\overline{(R Q A}, \overline{\text { IRQB }})$

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

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

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

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

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

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

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

The flags act as the link between the peripheral interrupt signals and the processor interrupt inputs. The interrupt disable bits allow the processor to control the interrupt function.

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

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

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

## Note:

A negative transition is defined as a transition from a high to a low, and a positive transition is defined as a transition from a low to a high voltage.

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

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

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

## CONTROL REGISTER A (CRA)

CA2 INPUT MODE (BIT 5 = 0)

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

CA2 OUTPUT MODE (BIT 5 = 1)

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

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

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


## CA2 INPUT MODE (BIT 5 = 0)

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


## CA2 OUTPUT MODE (BIT 5 = 1)

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

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

## CONTROL REGISTER B (CRB)

CB2 INPUT MODE (BIT $5=0$ )

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { IRQB1 } \\ \text { FLAG } \end{gathered}$ | $\begin{aligned} & \text { IRQB2 } \\ & \text { FLAG } \end{aligned}$ | CB2 INPUTMODE SELECT$(=0)$ | $\begin{array}{\|c\|} \hline \text { IRQB2 } \\ \text { POSITIVE } \\ \text { TRANSITION } \end{array}$ | $\begin{gathered} \overline{\mathrm{RQB}} \\ \text { ENABLE } \\ \text { FOR IRQB2 } \end{gathered}$ | $\begin{aligned} & \text { ORB } \\ & \text { SELECT } \end{aligned}$ | $\begin{gathered} \text { IRQB1 } \\ \text { POSITIVE } \\ \text { TRANSITION } \end{gathered}$ | $\begin{gathered} \overline{\mathrm{TRQB}} \\ \text { ENABLE } \\ \text { FOR IRQB1 } \end{gathered}$ |
|  |  |  | $\overline{\mathrm{IRQB}} /$ IRQB2 CONTROL |  |  | $\overline{\text { IRQB//RQB1 }}$ CONTROL |  |

CB2 OUTPUT MODE (BIT $5=1$ )

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

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

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

## CB2 INPUT MODE (BIT $5=0$ )

## Bit 6 IRQB2 FLAG

1 A transition has occurred on CB2 that satisfies the bit 4 IRQB2 transition polarity criteria. This flag is cleared by a read of Output Register B or by RES.
0 No transition has occurred on CB2 that satisfies the bit 4 IRQB2 transition polarity criteria.

Bit 5 CB2 MODE SELECT
0 Select CB2 Input Mọde.
Bit 4 IRQB2 POSITIVE TRANSITION
1 Set IRQB2 Flag (bit 6) on a positive (low-to-high) transition of CB2.
0 Set IRQB2 Flag (bit 6) on a negative (high-to-low) transition of CB2.

Bit 3 IRQB ENABLE FOR IRQB2
1 Enable assertion of $\overline{\operatorname{RQQ}}$ when IRQB2 Flag (bit 6) is set.
0 . Disable assertion of $\overline{\mathrm{RQB}}$ when IRQB2 Flag (bit 6) is set.

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

Bit 3 CB2 WRITE STROBE RESTORE CONTROL (BIT $4=0$ )
1 CB2 returns high on the next $\emptyset 2$ clock negative transition following a write to Output Register B.
$0 \quad$ CB2 returns high on the next active CB1 transition following a write to Output Register B as specified by bit 1 .

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

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

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

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

## READING THE PERIPHERAL A I/O PORT

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

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

## READING THE PERIPHERAL B I/O PORT

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


Figure 5. Read Timing Waveforms


Figure 6. Write Timing Waveforms

## BUS TIMING CHARACTERISTICS

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| 02 Cycle <br> 02 Pulse Width <br> 02 Rise and Fall Time | $\mathrm{t}_{\mathrm{CYC}}$ $t_{c}$ $t_{\mathrm{r}}, \mathrm{t}_{\mathrm{fc}}$ | $\begin{aligned} & 1.0 \\ & 470 \end{aligned}$ | $\overline{25}$ 25 | $\begin{aligned} & 0.5 \\ & 235 \end{aligned}$ | 25 15 | $\begin{aligned} & \mu \mathrm{s} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \end{aligned}$ |

## READ TIMING

| Address Set-Up Time <br> Address Hold Time <br> Peripheral Data Set-Up Time <br> Data Bus Delay Time <br> Data Bus Hold Time | $t_{\text {ACR }}$ <br> tcar <br> $t_{\text {PCR }}$ <br> $t_{\text {CDR }}$ <br> $t_{H R}$ | $\begin{array}{r} 150 \\ 0 \\ 300 \\ - \\ 10 \end{array}$ | $\frac{-}{395}$ | $\begin{array}{r} 90 \\ 0 \\ 150 \\ - \\ 10 \end{array}$ | $\begin{aligned} & - \\ & \overline{190} \end{aligned}$ | ns ns ns ns ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |

## WRITE TIMING



## PERIPHERAL INTERFACE TIMING



## ABSOLUTE MAXIMUM RATINGS*

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

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

## OPERATING CONDITIONS

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

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min. | Typ. ${ }^{3}$ | Max. | Unit ${ }^{1}$ | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | +2.0 | - | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | - | +0.8 | V |  |
| Input Leakage Current R $\bar{W}$, $\overline{\text { RES }}, \mathrm{RSO}, \mathrm{RS} 1, \mathrm{CSO}, \mathrm{CS} 1, \overline{\mathrm{CS} 2}$, CA1, CB1, $\emptyset_{2}$ | ${ }_{1}$ | - | $\pm 1$ | $\pm 2.5$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=O V \text { to } 5.25 \mathrm{~V} \\ & V_{C C}=O V \end{aligned}$ |
| Output Leakage Current for Three-State Off D0-D7, PB0-PB7, CB2 | ${ }_{\text {ITSI }}$ | - | $\pm 2$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input High Current PA0-PA7, CA2 | ${ }_{1 / H}$ | -100 | -250 | - | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ |
| Input Low Current PA0-PA7, CA2 | ILL | - | -1 | -1.6 | mA | $\mathrm{V}_{\mathrm{lL}}=0.4 \mathrm{~V}$ |
| Output High Voltage All outputs PB0-PB7, CB2 (Darlington Drive) | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{array}{r} 2.4 \\ 1.5 \\ \hline \end{array}$ | - | - | $\begin{aligned} & \mathrm{v} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{C C C}=4.75 \mathrm{~V} \\ & I_{\text {LOAD }}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\text {LOAD }}=-1.0 \mathrm{~mA} \end{aligned}$ |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | - | +0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing) Logic PB0-PB7, CB2 (Darlington Drive) | $\mathrm{IOH}^{\text {}}$ | $\begin{aligned} & -100 \\ & -1.0 \\ & \hline \end{aligned}$ | $\begin{gathered} -1000 \\ -2.5 \\ \hline \end{gathered}$ | $-$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \\ & \hline \end{aligned}$ | $\begin{aligned} \mathrm{V}_{\mathrm{OH}} & =2.4 \mathrm{~V} \\ \mathrm{~V}_{\mathrm{OH}} & =1.5 \mathrm{~V} \end{aligned}$ |
| Output Low Current (Sinking) | $\mathrm{l}_{\mathrm{OL}}$ | 1.6 | - | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Output Leakage Current (Off State) IRQA, $\overline{\text { IRQB }}$ | loff | - | 1 | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ |  | 200 | 500 | mW |  |
| Input Capacitance D0-D7, PA0-PA7, PB0-PB7, CA2, CB2 R/W, $\overline{\mathrm{RES}}, \mathrm{RS} 0, \mathrm{RS} 1, \mathrm{CS} 0, \mathrm{CS} 1, \overline{\mathrm{CS} 2}$ CA1, CB1, 92 | $\mathrm{C}_{\text {IN }}$ | - | - | $\begin{aligned} & 10 \\ & 7.0 \\ & 20 \end{aligned}$ | pF | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V} \\ & V_{\mathrm{VN}}=0 \mathrm{~V} \\ & f=2 \mathrm{MHz} \\ & T_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUt }}$ | - | - | 10 | pF |  |

## Notes:

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

## PACKAGE DIMENSIONS

40-PIN CERAMIC DIP


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

## 40-PIN PLASTIC DIP



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

## R6522 <br> VERSATILE INTERFACE ADAPTER (VIA)

## DESCRIPTION

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

Control of peripheral devices is handled primarily through two 8 -bit bidirectional 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 frequency square waves or for counting externally generated pulses. To facilitate control of the many powerful features of this chip, an interrupt flag register, an interrupt enable register and a pair of function control registers are provided.

## ORDERING INFORMATION



## FEATURES

- Two 8-bit bidirectional I/O ports
- Two 16-bit programmable timer/counters
- Serial data port
- TTL compatible
- CMOS compatible peripheral control lines
- Expanded "handshake" capability allows positive control of data transfers between processor and peripheral devices.
- Latched output and input registers
- 1 MHz and 2 MHz operation
- Single +5 V power supply



## INTERFACE SIGNALS

## RESET (RES)

A low reset ( $\overline{\mathrm{RES}}$ ) input clears all R6522 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.

## INPUT CLOCK (PHASE 2)

The input clock is the system $\phi 2$ clock and triggers all data transfers between processor bus and the R6522.

## READ/WRITE (R/W)

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

## DATA BUS (DO-D7)

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

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

The two chip select inputs are normally connected to processor address lines either directly or through decoding. The selected R6522 register is accessed when CS1 is high and CS2 is low.

## REGISTER SELECTS (RSO-RS3)

The coding of the four Register Select inputs select one of the 16 internal registers of the R6522, as shown in Table 1.

## INTERRUPT REQUEST (IRQ)

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 open-drain to allow the interrupt request signal to be wire-OR'ed with other equivalent signals in the system.

## PERIPHERAL PORT A (PAO-PA7)

Port A consists of eight lines which can be individually programmed to act as inputs or outputs under control of Data Direction Register A. 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 2 illustrates the output circuit.


Figure 1. R6522 VIA Interface Signals

## PORT A CONTROL LINES (CA1, CA2)

The two Port 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 Port A 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.

## PORT B (PB0-PB7)

Peripheral Port B consists of eight bidirectional lines which are controlled by an output register and a data direction register in much the same manner as the Port A. In addition, the polarity of the PB7 output signal can be controlled by one of the interval timers while the second timer can be programmed to count pulses on the PB6 pin. Port B lines represent one standard TTL load in
the input mode and will drive one standard TTL load in the output mode. In addition, 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 3 is the circuit schematic.

## PORT B CONTROL LINES (CB1, CB2)

The Port 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. CB2 can also drive a Darlington transistor circuit; however, CB1 cannot.

Table 1. R6522 Register Addressing

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



Figure 2. Port A Output Circuit


Figure 3. Port B Output Circuit

## FUNCTIONAL DESCRIPTION

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

## PORT A AND PORT B OPERATION

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

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

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

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

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

Figures 5 through 8 illustrate the formats of the port registers. In addition, the input latching modes are selected by the Auxiliary Control Register (Figure 14).


Figure 4. R6522 VIA Block Diagram

## HANDSHAKE CONTROL OF DATA TRANSFERS

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

## Read Handshake

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


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


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

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


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


Figure 8. Data Direction Register A (DDRA0)


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

## Write Handshake

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

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


Figure 11. Peripheral Control Register (PCR)


Figure 10. Write Handshake Timing

## COUNTER/TIMERS

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

## TImer 1 Operation

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

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

REG 6-TIMER 1 LOW-ORDER LATCH


WRITE - 8 BITS LOADED INTO T1 LOW-ORDER LATCHES. THIS OPERATION IS NO DIIFERENT THAN A WRITE INTO PEAD BITS
READ - 8 BITS FROM T1 LOW-ORDER LATCHES TRANSERRED TO MPU. UNLIKE REG 4 operation, this does not cause RESET OF T1 INTERRUPT FLAG

REG 7-TIMER 1 HIGH-ORDER LATCH


WRITE - 8 BITS LOADED INTO T1 HIGH-ORDER LATCHES. UNLIKE REG 4 OPERATION NO LATCH-TO-COUNTER TRANSFERS take place.
READ - 8 BITS FROM T1 HIGH-ORDER LATCHES TRANSFERRED TO MPU.

Figure 12. Timer 1 (T1) Latch Registers

REG 4-TIMER 1 LOW-ORDER COUNTER


COUNT
value

REG 5-TIMER 1 HIGH-ORDER COUNTER


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

Figure 13. Timer 1 (T1) Counter Registers


Figure 14. Auxillary Control Register (ACR)

## TImer 1 One-Shot Mode

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

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

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


Figure 15. Timer 1 One-Shot Mode Timing

## Timer 1 Free-Run Mode

The most important advantage associated with the latches in T1 is the ability to produce a continuous series of evenly spaced interrupts and the ability to produce a square wave on PB7 whose frequency is not affected by variations in the processor interrupt response time. This is accomplished in the "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 time-out 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.

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 16. Timer 1 Free-Run Mode Timing

## Timer 2 Operation

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

## Timer 2 One-Shot Mode

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

## Timer 2 Pulse Counting Mode

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


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


Figure 18. Timer 2 One-Shot Mode Timing


Figure 19. Timer 2 Pulse Counting Mode

## SHIFT REGISTER OPERATION

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

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

## SR Mode 0 - Disabled

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

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

In mode 1, the shifting rate is controlled by the low order 8 bits of T2 (Figure 22). Shift pulses are generated on the CB1 pin to control shifting in external devices. The time between transitions of this output clock is a function of the system clock period and the contents of the low order T2 latch ( N ).

notes:

1. WHEN SHIFTING OUT. BIT 7 !S THE FIRST BIT

OUT AND SIMULTANEOUSLY IS ROTATED BACK
INTO BIT O.
2. WHEN SHIFTING IN, BITS INITIALLY ENTER

BIT 0 AND ARE SHIFTED TOWARDS BIT 7.

The shifting operation is triggered by the read or write of the SR if the SR flag is set in the IFR. Otherwise the first shift will occur at the next time-out of T2 after a read or write of the SR. 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 $\emptyset 2$ clock cycle following the positive-going edge of the CB1 clock pulse. After 8 CB1 clock pulses, the shift register interrupt flag will set and IRQ will go low.

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

In mode 2, the shift rate is a direct function of the system clock frequency (Figure 23). CB1 becomes an output which generates shift pulses for controlling external devices. Timer 2 operates as an independent interval timer and has no effect on SR. The shifting operation is triggered by reading or writing the Shift Register. Data is shifted, first into bit 0 and is then shifted into the next higher order bit of the shift register on the trailing edge of each $\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.


Figure 21. Shift Register Modes

Figure 20. Shift Registers

## SR Mode 3 - Shift in Under CB1 Control

In mode 3, external pin CB1 becomes an input (Figure 24). This allows an external device to load the shift register at its own pace. The shift register counter will interrupt the processor each time 8 bits have been shifted in. 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.

SR Mode 4 - Shift Out Under T2 Control (Free-Run) Mode 4 is very similar to mode 5 in which the shifting rate is set by

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

## SR Mode 5 - Shift Out Under T2 Control

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

Figure 23. SR Mode 2 - Shift In Center $\boldsymbol{\phi} 2$ Control


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


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

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

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

## SR Mode 7 - Shift Out Under CB1 Control

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

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


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


Figure 27. SR Mode 6 - Shift Out Under $\phi 2$ Control


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

## Interrupt Operation

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

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

## Interrupt Flag Register (IFR)

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

The Interrupt Flag Register (IRF) 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 appplied to the chip, the contents of this register are placed on the data bus. Bit 7 indicates the

Figure 29. Interrupt Flag Register (IFR)
status of the $\overline{\mathrm{RQ}}$ output. This bit corresponds to the logic function: $\overline{\mathrm{IRQ}}=$ IFR6 $\times$ IER6 + IFR5 $\times$ IER5 + IFR4 $\times$ IER4 + IFR3 $\times$ IER3 + IFR2 $\times$ IER2 + IFR1 $\times$ IER1 + IFR0 $\times$ IERO.

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

## Interrupt Enable Register (IER)

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

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

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

REG 14-INTERRUPT ENABLE REGISTER

ALL OTHER BITS WILL REFLECT THEIR ENABLE/DISABLE STATE.

Figure 30. Interrupt Enable Register (IER)


NOTES:

1. IF BIT 7 IS A " 0 ", THEN EACH " 1 " IN BITS 0-6 DISABLES THE CORRESPONDING INTERRUPT.
2. IF BIT 7 IS A " 1 ", THEN EACH " 1 " IN BITS $0-6$ ENABLES THE CORRESPONDING INTERRUPT.
3. IF A READ OF THIS REGISTER IS DONE, BIT 7 WILL BE " 1 " AND

## PERIPHERAL INTERFACE CHARACTERISTICS

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

## PERIPHERAL INTERFACE WAVEFORMS



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


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


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


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


Figure 31e. Peripheral Data Input Latching Timing


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


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

CB1
SHIFT CLOCK INPUT


Figure 31h. External Shift Clock Timing


Figure 31i. Pulse Count Input Timing

## BUS TIMING CHARACTERISTICS

| Parameter | Symbol | R6522 (1 MHz) |  | R6522A (2 MHz) |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |

## READ TIMING

| Cycle Time | $T_{C Y}$ | 1 | 10 | 0.5 | 10 | $\mu \mathrm{~s}$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Address Set-Up Time | $\mathrm{T}_{\text {ACR }}$ | 180 | - | 90 | - | ns |
| Address Hold Time | $T_{C A R}$ | 0 | - | 0 | - | ns |
| Peripheral Data Set-Up Time | $T_{P C R}$ | 300 | - | 150 | - | ns |
| Data Bus Delay Time | $T_{C D R}$ | - | 365 | - | 190 | ns |
| Data Bus Hold Time | $T_{H R}$ | 10 | - | 10 | - | ns |

## WRITE TIMING

| Cycle Time | $\mathrm{T}_{\text {cr }}$ | 1 | 10 | 0.50 | 10 | $\mu \mathrm{S}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\phi 2$ Pulse width | $\mathrm{T}_{\mathrm{c}}$ | 470 | - | 235 | - | ns |
| Address Set-Up Time | $\mathrm{T}_{\text {ACW }}$ | 180 | - | 90 | - | ns |
| Address Hold Time | TCAW | 0 | - | 0 | - | ns |
| R/ $\bar{W}$ Set-Up Time | $T_{\text {wCw }}$ | 180 | - | 90 | - | ns |
| R $\bar{W}$ Hold Time | $\mathrm{T}_{\text {cww }}$ | 0 | - | 0 | - | ns |
| Data Bus Set-Up Time | $\mathrm{T}_{\text {DCW }}$ | 200 | - | 90 | - | ns |
| Data Bus Hold Time | $\mathrm{T}_{\text {HW }}$ | 10 | - | 10 | - | ns |
| Peripheral Data Delay Time | $\mathrm{T}_{\text {crw }}$ | - | 1.0 | - | 0.5 | ${ }_{\mu} \mathrm{s}$ |
| Peripheral Data Delay Time to CMOS Levels | Tсмоя | - | 2.0 | - | 1.0 | ${ }^{\mu} \mathrm{S}$ |
| Note: $\mathrm{t}_{\mathrm{R}}$ and $\mathrm{t}_{\mathrm{F}}=10$ to 30 ns . |  |  |  |  |  |  |

## BUS TIMING WAVEFORMS

Read Timing Waveforms


Write Timing Waveforms


## ABSOLUTE MAXIMUM RATINGS*

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

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

## OPERATING CONDITIONS

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

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min. | Typ. ${ }^{3}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.4 | - | $\mathrm{V}_{\text {cc }}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | - | 0.4 | V |  |
| Input Leakage Current R $\bar{W}, \overline{\text { RES }}$, RSO, RS1, RS2, RS3, CS1, $\overline{\text { CS2 }}$, CA1, $\emptyset 2$ | $\mathrm{I}_{\mathrm{IN}}$ | - | $\pm 1$ | $\pm 2.5$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=O V \text { to } 5.25 \mathrm{~V} \\ & V_{C C}=O V \end{aligned}$ |
| Input Leakage Current for Three-State Off D0-D07 | $\mathrm{I}_{\text {TS }}$ | - | $\pm 2$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{1 \mathrm{~N}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & V_{C C}=5.25 \mathrm{~V} \end{aligned}$ |
| Input High Current PAO-PA7, CA2, PB0-PB7, CB1, CBS | $\mathrm{I}_{\mathrm{IH}}$ | -100 | -200 | - | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\mathrm{IN}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Low Current PAO-PA7, CA2, PB0-PB7, CB1, CB2 | IIL | - | -0.9 | -1.8 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage All outputs PB0-PB7, CB2 (Darlington Drive) | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 2.4 \\ & 1.5 \end{aligned}$ | - | 二 | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ | $\begin{aligned} & V_{C C}=4.75 \mathrm{~V} \\ & l_{\text {LOAD }}=-100 \mu \mathrm{~A} \\ & l_{\text {LOAD }}=-1.0 \mathrm{~mA} \end{aligned}$ |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing) Logic PB0-PB7, CB2 (Darlington Drive) | IOH | $\begin{array}{r} -100 \\ -1.0 \\ \hline \end{array}$ | $\begin{gathered} -1000 \\ -2.5 \\ \hline \end{gathered}$ | $-10$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \end{aligned}$ |
| Output Low Current (Sinking) | $\mathrm{IOL}^{\text {l }}$ | 1.6 | - | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Output Leakage Current (Off State) | Ioff | - | 4 | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | - | 450 | 700 | mW |  |
| Input Capacitance <br> R $\bar{W}, \overline{\text { RES }}$, RSO, RS1, RS2, RS3, CS1, $\overline{\mathrm{CS} 2}$, DO-D7, PAO-PA7, CA1, CA2, PB0-PB7 <br> CB1, CB2 <br> 92 Input | $\mathrm{C}_{\text {IN }}$ | - - - | - | $\begin{aligned} & 7 \\ & 10 \\ & 20 \end{aligned}$ | pF <br> pF <br> pF | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V} \\ & V_{I N}=0 \mathrm{~V} \\ & f=1 \mathrm{MHz} \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Output Capacitance | Cout | - | - | 10 | pF |  |

## Notes:

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

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



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

## 40-PIN PLASTIC DIP



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

## R6530 <br> ROM-RAM-I/O-TIMER (RRIOT)

## DESCRIPTION

The R6530 ROM-RAM-I/O-Timer (RRIOT) combines read only memory, random access memory, parallel I/O data ports, and timer functions into a single peripheral device which operates in conjunction with any CPU in the R6500 microprocessor family. The R6530 allows two chip solutions in a variety of production applications. 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 262,144 clock periods.

## ORDERING INFORMATION



## FEATURES

- $1024 \times 8$ mask programmable 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
- 8-bit directional data bus for direct communication with the microprocessor
- High impedance three-state data bus
- Allows up to 7K contiguous bytes of ROM with no external decoding


R6530 Pin Configuration

## INTERFACE SIGNALS

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

During system initialization, a $\overline{\operatorname{RES}}$ input causes zeroing of all four V/O registers. This in turn causes all V/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{R E S}$ signal. The RES signal must be held low for at least one clock period when reset is required.

## READ/WRITE (R/W)

The $R / \bar{W}$ input is supplied by the microprocessor and controls the transfer of data between the R6530 and the microprocessor via the data bus. A high on the $R / \bar{W}$ pin reads (with proper addressing) data from the R6530 onto the data bus. A low on the $R / \bar{W}$ pin writes (with proper addressing) data from the data bus into R6530.

## PHASE 2 CLOCK (ø2)

The Phase 2 clock ( $\varnothing 2$ ) input is the system clock generated by the CPU that triggers all data transfers between the data bus and the R6530.

## INTERRUPT REQUEST (IRQ)

The $\overline{\mathrm{RQ}}$ 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 collectorOR'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.

## ADDRESS LINES (A0-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.

## ROM SELECT (RSO)

RSO serves as an additional address input line. When RSO is high, internal ROM is selected; when RSO is low, internal ROM is not selected.

## PERIPHERAL DATA PORTS

The R6530 has 16 pins available for peripheral I/O operations. Each pin is individually software programmable to act as either an input or an output. The 16 pins are divided into two 8 -bit ports, 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 causes 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 information 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.

## CHIP SELECT (CS0, CS1)

Pins 18 and 19 are individually selectable at mask time as either chip selects CS1 and CS2, respectively, or port B functions PB6 and PB5, respectively.


## 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 I/O secticn consists of two 8 -bit halves. Each half contains a Data Direction Register (DDR) and an Output Register.

## ROM-1K BYTE (8K BITS)

The 1 K byte ROM is in a $1024 \times 8$ configuration. Address lines A0-A9, as well as RS0 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$ side) 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 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 1T, 8T, 64T or 1024T 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 -225 T . Thus, after the interrupt flag is set, a Read of the timer will tell how long since the flag was set up to a maximum of 255T.

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 1024T) is decoded from address lines AO and A1. During a Read or Write operation address line A3 controls the interrupt capability of PB7, i.e., $A 3=$ 1 enables $\overline{\mathrm{RQ}}$ on PB7, $\mathrm{A} 3=0$ disables $\overline{\mathrm{RQ}}$ on PB7. When PB7 is to be used as an interrupt flag with the interval timer it should be programmed 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}{ll}1 & 1 \\ 1 & 1 \\ 1\end{array} 1$ 1. 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.

$$
\begin{aligned}
& \text { Value read }=1 \begin{array}{llllllll}
1 & 1 & 1 & 0 & 0 & 1 & 0 & 0 \\
\text { Complement }=0 & 0 & 0 & 1 & 1 & 0 & 1 & 1=27
\end{array}
\end{aligned}
$$

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 $\begin{array}{lllllllll}0 & 1 & 1 & 0 & 1 & 0 & 0(=52) \text {. With }\end{array}$ 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 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 flag is read on D7 all other D outputs (D0 through D6) go to " 0 ".

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


Basic Elements of Interval Timer


## 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 chipselect 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 chip-select. The third additional address line is RS0. The R6502 and R6530 in a 2-chip system would use RS0 to distinguish between ROM and non-ROM sections of the R6530. With the addressing pins available, a total of 7K contiguous ROM may be addressed with no external decode. Following is an example of a 1 -chip and a 7-chip R6530 Addressing Scheme.

## ONE-CHIP ADDRESSING

A 1-chip system decode is illustrated in the R6530 One-Chip Address Encoding Diagram.

## SEVEN-CHIP ADDRESSING

In the seven-chip system, the objective would be to have 7K bytes 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 I/O. This would place the 7 K ROM between addresses 65,535 and 58,367 . The two pins designated as chip-select, or I/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 table 1.

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 I/O registers are desired, as well as the coding of the interval timer.

## I/O REGISTER-TIMER ADDRESSING

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

When the timer is selected A1 and A0 decode the divide by matrix. In addition, Address A3 is used to enable the interrupt flag to PB7.

Table 1. R6530 Seven-Chip Addressing Scheme

| Device | Function | Address, Chip Select and Register Select Lines |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { CS2 } \\ & \text { A12 } \end{aligned}$ | $\begin{aligned} & \text { CS1 } \\ & \text { All } \end{aligned}$ | $\begin{aligned} & \text { RS0 } \\ & \text { A10 } \end{aligned}$ | A9 | A8 | A7 | A6 |
| R6530 \#1 | ROM Select RAM Select VO Timer | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & x \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & 0 \\ & 0 \end{aligned}$ | X 0 0 |
| R6530 \#2 | ROM Select RAM Select I/O Timer | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & x \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & x \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & 0 \\ & 0 \end{aligned}$ | X 1 1 |
| R6530 \#3 | ROM Select RAM Select VO Timer | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & x \\ & 0 \\ & 1 \end{aligned}$ | X 0 0 | X 1 1 | X 0 0 |
| R6530 \#4 | ROM Select RAM Select /O Timer | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & x \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & x \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & 1 \\ & 1 \end{aligned}$ | X <br> 1 <br> 1 |
| R6530 \#5* | ROM Select RAM Select I/O Timer | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & x \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & x \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | X 0 0 | X 0 0 |
| R6530 \#6 | ROM Select RAM Select /O Timer | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & x \\ & 0 \\ & 1 \end{aligned}$ | X <br> 1 <br> 1 | X 0 0 | X 1 1 |
| R6530 \#7 | ROM Select RAM Select I/O Timer | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & x \\ & 0 \\ & 1 \end{aligned}$ | X 1 1 | $X$ 1 1 | $\begin{aligned} & X \\ & 0 \\ & 0 \end{aligned}$ |

A. X indicates mask programming, i.e.:

ROM select $=$ CS1 $\bullet$ RSO
RAM select $=\overline{\mathrm{CS} 1} \bullet \overline{\mathrm{RSO}} \bullet \overline{\mathrm{A} 9} \bullet A 7 \bullet A 6$
I/O TIMER SELECT $=\overline{\mathrm{CS} 1} \bullet \overline{\mathrm{RSO}} \bullet A 9 \bullet A 8 \bullet A 7 \bullet A 6$
B. Notice that A8 is a don't care for RAM select
C. CS2 can be used as PB5 in this example


R6530 One-Chip Address Encoding Diagram
Table 2. Addressing Decode for I/O Register and Timer

| Function | Addressing Decode |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | ROM Select | RAM Select | 1/0 Timer Select | R/W | A3 | A2 | A1 | AO |
| 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 | X |
| 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 |  | 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 |
| Notes: *A3 $=1$ Enables $\overline{\mathrm{RQ}}$ to PB 7 <br> $\mathrm{A} 3=0$ Disables $\overline{\mathrm{RQ}}$ to PB 7 |  |  |  |  |  |  |  |  |

## TIMING CHARACTERISTICS

Read Timing

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{R} / \overline{\mathrm{W}}$ valid before positive transition of clock | $T_{\text {WCR }}$ | 180 | - | ns |
| Address valid before positive transition of clock | $T_{\text {ACR }}$ | 180 | - | ns |
| Peripheral data valid before positive transition of clock | TPCR | 300 | - | ns |
| Data Bus valid after positive transition of clock | $\mathrm{T}_{\text {CDR }}$ | - | 395 | ns |
| Data Bus Hold Time | THR | 10 | - | ns |
| IRQ (Interval Timer Interrupt) valid before positive transition of clock | $\mathrm{T}_{1 \mathrm{C}}$ | 200 | - | ns |
| $\begin{aligned} \text { Note: Loading } & =30 \mathrm{pF}+1 \mathrm{TTL} \text { load for PAO-PA7, PB0-PB7 } \\ & =130 \mathrm{pF}+1 \mathrm{TTL} \text { load for D0-D7 } \end{aligned}$ |  |  |  |  |

Write Timing

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Clock Period | TCYC | 1 | 10 | $\mu \mathrm{S}$ |
| Rise \& Fall Times | $\mathrm{T}_{\mathrm{R},} \mathrm{T}_{\mathrm{F}}$ | - | 25 | ns |
| Clock Pulse Width | $\mathrm{T}_{\mathrm{C}}$ | 470 | - | ns |
| R/W valid before positive transition of clock | TwCw | 180 | - | ns |
| Address valid before positive transition of clock | TACW | 180 | - | ns |
| Data Bus valid before negative transition of clock | TDCW | 300 | - | ns |
| Data Bus Hold Time | THW | 10 | - | ns |
| Peripheral data valid after negative transition of clock | $\mathrm{T}_{\mathrm{CPW}}$ | - | 1 | $\mu \mathrm{S}$ |
| Peripheral data valid after negative transition of clock driving CMOS (Level $=$ VCC $-30 \%$ ) | TCMOS | - | 2 | $\mu \mathrm{S}$ |



## MAXIMUM RATINGS*

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

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

## DC CHARACTERISTICS

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

| Characteristic | Symbol | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $V_{1 H}$ | +2.4 |  | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | -0.3 |  | +0.4 | V | - |
| Input Leakage Current <br> AO-A9, RSO, R $\bar{W}, \overline{\text { RES }}, 02$, PB6 $^{(3)}$, PB5 $^{(3)}$ | $\mathrm{I}_{\mathrm{N}}$ |  | 1.0 | 2.5 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=0 \text { to }+5.0 \mathrm{~V} \\ & V_{C C}=0 \end{aligned}$ |
| Input Leakage Current for Three State Off D0-D7 | ${ }_{\text {ITS }}$ I |  | $\pm 1.0$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input High Current PAO-PA7, PB0-PB7 | $\mathrm{I}_{\mathrm{H}}$ | -100 | -300 |  | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=2.4 \mathrm{~V}$ |
| Input Low Current; PAO-PA7 PB0-PB7 | $\mathrm{I}_{\text {IL }}$ |  | -1.0 | -1.6 | mA | $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |
| Output High Voltage PA0-PA7, PB0-PB7 (TTL drive), D0-D7 PB0-PB7, (other drive, e.g., Darlington) | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & +2.4 \\ & +1.5 \end{aligned}$ |  |  | V | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}=4.25 \mathrm{~V} \\ I_{\text {LOAD }}=-100 \mu \mathrm{~A} \\ I_{\text {LOAD }}=3.0 \mathrm{~mA} \end{gathered}$ |
| Output Low Voltage | $\mathrm{V}_{\text {OL }}$ |  |  | +0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.25 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing) PAO-PA7, PB0-PB7 (TTL drive), DO-D7 PB0-PB7 (other drive) | $\mathrm{IOH}^{\text {}}$ | $\begin{array}{r} -100 \\ -3.0 \end{array}$ | $\begin{gathered} -1000 \\ -5.0 \end{gathered}$ |  | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & V_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \end{aligned}$ |
| Output Low Current (Sinking) PAO-PA7, PBO-PB7 | IOL | 1.6 |  |  | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Power Dissipation | $P_{D}$ |  | 500 | 1000 | mW |  |
| Imput Capacitance ø2 Logic | $\mathrm{C}_{\mathrm{cLK}}$ <br> $\mathrm{C}_{\text {IN }}$ |  |  | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & V_{\text {IN }}=0, f=1 \mathrm{MHz} \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUt }}$ |  |  |  |  |  |
| Note: 1. All units are direct current (DC). <br> 2. Negative sign indicates outward current flow, positive indicates inward flow. <br> 3. When programmed as address pins. |  |  |  |  |  |  |

## PACKAGE DIMENSIONS



## DESCRIPTION

The R6531 ROM-RAM-I/O-Counter (RRIOC) integrates readonly memory, random access memory, various I/O data port configurations and timer functions into a single peripheral device which operates in conjunction with any CPU in the R6500 microprocessor family. The R6531 provides innovative system designers with a two-chip solution to a wide range of applications. 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. Both versions contain a $2048 \times 8$ mask-programmable ROM, a $128 \times 8$ static RAM, a software programmable multimode 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 to provide a RAM standby power pin and chip selects for multi-chip systems.

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.

## ORDERING INFORMATION

| Part Number R6531 | Temperature Range: ( $T_{L}-T_{h}$ ) Blank $=0^{\circ}$ to $+70^{\circ} \mathrm{C}$ $E=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ <br> Package: $\begin{aligned} & C=40 \text {-Pin DIP, Ceramic } \\ & P=40 \text {-Pin DIP, Plastic } \\ & Q=52-\text {-Pin QUIP, Plastic } \end{aligned}$ <br> Frequency Range: <br> No letters $=1 \mathrm{MHz}$ $\mathrm{A}=2 \mathrm{MHz}$ |
| :---: | :---: |
| NOTE: Conta availa | local Rockwell representative for |

## FEATURES

- $2048 \times 8$ mask programmable ROM
- $128 \times 8$ static RAM
- 16-bit multi-mode counter/latch
- internal 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
- 15 bidirectional I/O lines (2 ports - 40-pin package)
- Expansion 8-bit output port and 4-bit input port (52-pin package)
- I/O handshake control
- Four edge sensitive interrupt inputs
- 1 MHz or 2 MHz operation
- ROM-less versions available for prototyping
- Single +5V power supply


Interface Signals

## INTERFACE SIGNALS

## RESET (RES)

This active low signal initializes 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{\text { 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 off-state except when the R6531 is selected for a read operation.

## READ/WRITE (R/ $\overline{\mathbf{W}}$ )

The $\mathrm{R} \overline{\mathrm{W}}$ input controls 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.

## PHASE 2 CLOCK ( $\phi$ 2)

The Phase 2 Clock ( $\varnothing 2$ ) input is the system clock that triggers all data transfers between the data bus and 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, PB0-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 part, PC0-PC7, and a 4-bit input only port PD0-PD3. PD2 and PD3 may be assigned other functions as described later.

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{R Q}$ request output, the line is driven low and requires an external pull-up, thus allowing the wire OR-ing of IRQ from other devices.

## RAM RETENTION VOLTAGE (VRR)

A separate pin for a power supply for the read/write memory is available 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 below the specified level or is turned off.



PB6 OPTION


VRR OPTION

R6531 40-Pin DIP Configurations


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

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

The 16K ROM is a $2048 \times 8$ bit configuration. An address on lines A0-A10 uniquely 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 14K 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 A0-A6. Additionally, 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.

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

## Control Registers

Two control registers allow software selection of various I/O functions. The Peripheral Control Register (PCR) is primarily associated with Port B functions and the Auxiliary Control Register (ACR) is associated with the counter and serial data functions which also affect Port B.

## ADDRESSING

Addressing of the R6531 offers many variations to the user for system configuration flexibility. Combination with other R6531 ROMs, RAMs or I/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 shown in Table 1.

Table 1. R6531 Addressing


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.

## 40-PIN PROTOTYPING CIRCUIT

Prototyping circuits R6531-098 (1 MHz) and R6531-098A (2 MHz ) 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 Table 2.

Table 2. R6531-098 Addressing

| R6531-098 Function | Chip 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 |  |  | RA | M | Dec | od |  |
| 1/0 | N | N | L | H | H | H | L | L | L | L |  | D | eco |  |

N means No Effect, H means High and L means Low.

## 52-PIN PROTOTYPING CIRCUIT

Prototyping circuits R6531-099 (1 MHz) and R6531-099A (2 MHz) are packaged in the 52 -point 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 Table 3.

Table 3. R6531-099 Addressing

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

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

## REGISTERS

## REGISTER SELECTION

The register selection and/or general operation performed by the 15 R6531 addresses in conjunction with the R/W state is shown in Table 4.

Table 4. Register Selection

| Hex Addr | Address Line |  |  |  | Operation |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | A3 | A2 | A1 | A0 | R/W = High | R/W = Low |
| 0 | L | L | L | L | Read Port A Data | Write Port A Data |
| 1 | L | L' | L | H | Read Port B Data | Write Port B Data |
| 2 | L | L | H | L | - | Write Port C Data |
| 3 | L | L | H | H | - | Write Port D Data |
| 4 | L | H | L | L | Read Lower Counter | Write Lower Latch |
| 5 | L | H | L | H | Read Upper Counter | Write Upper Latch and Download |
| 6 | L | H | H | L | - | Write Lower Latch |
| 7 | L | H | H | H | - | Write Upper Latch |
| 8 | H | L | L | L | Read Serial Data Register | Write Serial Data Register |
| 9 | H | L | L | H | Read Interrupt Flag Register | Write Interrupt Flag Register |
| A | H | L | H | L | Read Interrupt Enable Register | Write Interrupt Enable Register |
| B | H | L | H | H | Read Auxiliary Control Register | Write Auxiliary Control Register |
| C | H | H | L | L | Read Peripheral Control Register | Write Peripheral Control Register |
| D | H | H | L | H | - | Write Port A Data Direction Register |
| E | H | H | H | L | - | Write Port B Data Direction Register |

## Peripheral Control Register (PCR)

Some Port B operating options are software selectable by writing control bits to the Peripheral Control Register (PCR).


## Auxiliary Control Register (ACR)

Operating Modes for the Timer/Counter, PB2/PB3 Serial input/output and PB4 pulse output are selected by writing bits to the Auxiliary Control Register (ACR).


## Interrupt Enable and Flag Registers

Two registers are provided for interrupt control. Corresponding bits in the enable and flag registers are logically ANDed to set the Interrupt Request Pending flag. If the pending flag is set and PB6 is selected as an $\overline{\mathrm{RQ}}$ Request Output, then PB6 will be set low to request the R6502 CPU to service $\overline{\mathrm{RQ}}$.

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

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

These registers and their bit assignments are illustrated.


## 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 (DDRA). 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 DDR 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 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 parallel 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 PB0 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.

## 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 Timing for Handshake Mode


## 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 $\phi 2$ clock rate. If the external clock is used, data may be shifted at any rate up to one half the system $\emptyset 2$ clock rate. In the external clock mode, the counter may be operated in the free run pulse generation 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.


R6531 Serial I/O Timing

## COUNTER/TIMER

The R6531 contains a multi-mode 16 -bit counter/timer with an associated 16 -bit latch whose modes are software selectable by setting appropriate bits in the Auxiliary Control Register. The latch holds the counter preset value and all 16 bits download to the counter simultaneously upon command (I/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 \quad$-Counter Off
Mode 1 -Event Counter - counts external event inputs (negative transitions) at PB5

Mode 2 -Interval Timer - counts 02 system clock pulses.

| Mode 3 | - External Trigger -counts $\phi 2$ system clock <br> 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.


## BUS TIMING CHARACTERISTICS

| Characteristlc | Symbol | $\begin{gathered} \text { R6531 } \\ (1 \mathrm{MHz}) \end{gathered}$ |  | R6531A <br> ( 2 MHz ) |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | MIn | Max |  |
| Clock Period | $\mathrm{T}_{\mathrm{crc}}$ | 1.0 | 10 | 0.5 | 10 | $\mu \mathrm{s}$ |
| Clock Pulse Width | $\mathrm{T}_{\mathrm{c}}$ | 470 | - | 235 | - | ns |
| Rise \& Fall Times | $\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}$ | - | 25 | - | 15 | ns |

READ TIMING

| $\mathrm{R} \bar{W}$ valid before positive transition of clock | $T_{\text {WCR }}$ | 180 | - | 120 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address valid before positive transition of clock | $\mathrm{T}_{\text {ACP }}$ | 180 | - | 120 | - | ns |
| Peripheral data valid before positive transition of clock | $\mathrm{T}_{\text {PCR }}$ | 270 | - | 135 | - | ns |
| Data Bus valid after positive transition of clock | $\mathrm{T}_{\text {cDR }}$ | - | 350 | - | 180 | ns |
| Data Bus Hold Time | $\mathrm{T}_{\text {HR }}$ | 10 | - | 10 | - | ns |
| $\overline{\mathbf{R Q}}$ valid after negative transition of clock | Tic | - | 900 | - | 450 | ns |

## WRITE TIMING

| $\mathrm{R} \bar{W}$ valid before positive transition of clock | $\mathrm{T}_{\text {wow }}$ | 180 | - | 120 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address valid before positive transition of clock | $\mathrm{T}_{\text {ACW }}$ | 180 | - | 120 | - | ns |
| Data Bus valid before negative transition of clock | $\mathrm{T}_{\text {DCW }}$ | 270 | - | 135 | - | ns |
| Data Bus Hold Time | $\mathrm{T}_{\mathrm{Hw}}$ | 10 | - | 10 | - | ns |
| Peripheral data valid after negative transition of clock | $\mathrm{T}_{\text {cPW }}$ | - | 900 | - | 450 | ns |
| NOTES: $\begin{aligned} \text { Load } & =100 \mathrm{pF}+1 \mathrm{TTL} \text { for PA0-PA7, PBO-PB6, and PC0-PC7. } \\ & =100 \mathrm{pF}+1 \mathrm{TTL} \text { for DO-D7 (R6531A). } \\ & =130 \mathrm{pF}+1 \mathrm{TTL} \text { for D0-D7 (R6531). } \end{aligned}$ |  |  |  |  |  |  |



WRITE T!MING WAVEFORMS


## 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 <br> Commercial | $\mathrm{T}_{\mathrm{A}}$ | 0 to +70 <br> Industrial |  |
| Storage Temperature Range | $\mathrm{T}_{\text {stg }} \mathrm{C}$ |  |  |
|  | -50 to +85 | ${ }^{\circ} \mathrm{C}$ |  |

*Note: This device contains circuitry to protect the inputs against damage due to high static voltages, however, normal precautions should be taken to avoid application of any voltage higher than maximum rated voltages to this circuit.

## DC CHARACTERISTICS

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

| Characteristic | Symbol | Min | Max | Unit(1) | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{H}}$ | 2.0 | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | -0.3 | +0.8 | V |  |
| Input Leakage Current A0-A11, CS1-CS3, R $\bar{W}$, $\overline{\text { RES }}, \phi 2$, PD0-PD3 | In | - | 2.5 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\mathrm{IN}}=0 \mathrm{~V} \text { to } 5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V} \end{aligned}$ |
| Leakage Current for Three-State Off (Three State) D0-D7, PA0-PA7, PB0-PB6 | $\mathrm{I}_{\text {TS }}$ | - | $\pm 10$ | ${ }_{\mu} \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \end{aligned}$ |
| Input High Current PA0-PA7, PB0-PB6, PD0-PD3 | $\mathrm{I}_{\mathrm{H}}$ | -100 | - | ${ }_{\mu} \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=2.4 \mathrm{~V}$ |
| Input Low Current PA0-PA7, PB0-PB6, PD0-PD3 | ILI | 1.6 | - | mA | $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ |
| Output High Voltage D0-D7, PA0-PA7, PB0-PB6, PC0-PC7 | $\mathrm{V}_{\mathrm{OH}}$ | +2.4 | - | V | $\begin{aligned} & \mathrm{V}_{C C}=4: 75 \mathrm{~V} \\ & I_{\text {LOAD }}=-200 \mu \mathrm{~A} \end{aligned}$ |
| Output Low Voltage D0-D7, PAO-PA7, PB0-PB6, PC0-PC7 | $\mathrm{V}_{\mathrm{OL}}$ |  | +0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=2.5 \mathrm{~mA} \\ & \hline \end{aligned}$ |
| Output High Current (Sourcing); PAO-PA7, PB0-PB6, PC0-PC7 | $\mathrm{IOH}^{\text {r }}$ | -200 | - | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ |
| Output Low Current (Sinking) PA0-PA7, PB0-PB7, PC0-PC7 | ${ }^{\text {OL }}$ | 2.1 | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| $\begin{aligned} & \text { Input Capacitance } \\ & \phi 2 \\ & \text { Logic } \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{C}_{\mathrm{Clk}} \\ & \mathrm{C}_{\mathrm{IN}} \\ & \hline \end{aligned}$ |  | $\begin{array}{r} 20 \\ 10 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \\ & \hline \end{aligned}$ | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, \\ & V_{I N}=0 \mathrm{~V}, \\ & f=1 \mathrm{MHz}, \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ |  | 10 | pF | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ |  | 1.0 | W |  |
| NOTES: <br> 1. All units are direct current (DC). <br> 2. Negative sign indicates current flow, positive indicates inward flow. |  |  |  |  |  |

## PACKAGE DIMENSIONS



## DESCRIPTION

The R6532 RAM-I/O-Timer (RIOT) integrates random access memory (RAM), parallel I/O data ports and timer functions into a single peripheral device which operates in conjunction with any CPU in the R6500 microprocessor family. It is comprised of a $128 \times 8$ static RAM, two software-controlled, 8 -bit bidirectional data ports allowing direct interfacing between the microcomputer and peripheral devices, a software programmable interval timer with interrupt, capable of timing in various intervals from 1 to 262,144 clock periods, and a programmable edgedetect circuit.

## FEATURES

- $128 \times 8$ static RAM
- Two 8 bit bidirectional data ports
- Programmable interval timer with interrupt capability
- TTL \& CMOS compatible peripheral lines
- One port has direct transistor drive capability
- Programmable edge-sensitive interrupt input
- 8 bit bidirectional data bus
- $6500 / 6800$ bus compatible
- 1 MHz and 2 MHz parts available
- Single +5 V power supply


R6532 Pin Configuration

## INTERFACE SIGNALS

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

During system initialization, a low $\overline{\text { RES }}$ input causes a zeroing of all four I/O registers. This in turn causes all I/O buses to act as inputs thus protecting external components from possible damage and erroneous data while the system is being configured under software control. The Data Bus Buffers are put into an OFF-STATE during Reset. Interrupt capability is disabled with the $\overline{R E S}$ signal. The $\overline{R E S}$ signal must be held low for at least two clock periods when reset is required.

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

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

## INTERRUPT REQUEST (IRQ)

The $\overline{\mathrm{RQ}}$ pin is an interrupt pin from the interrupt control logic. The pin will be normally high with a low indicating an interrupt from the R6532. An external 3K pull-up resistor is required. The $\overline{\text { IRQ }}$ pin may be activated by a transition on PA7 or timeout of the interval timer.

## DATA BUS (D0-D7)

The R6532 has eight bidirectional data pins (D0-D7). These pins connect to the system's data lines and transfer data between the R6532 and the microprocessor data bus. The output buffers remain off, or tri-stated, except when the R6532 is selected for a Read operation.

## ADDRESS LINES (A0-A6)

There are seven address pins (A0-A6). In addition, there is the $\overline{R A M}$ SELECT $(\overline{\mathrm{RS}})$ pin. The pins A0-A6 and $\overline{\mathrm{RS}}$ are always used as addressing pins. There are two additional pins which are used as CHIP SELECTS. They are pins CS1 and CS2. Tables 1 and 2 identify the functions selected and registers addressed depending upon the address line and $\overline{\mathrm{RS}}$ inputs in conjunction with the R$\overline{\mathrm{N}}$

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

The R6532 has 16 pins available for peripheral I/O operations. Each pin is individually software programmable to act as either an input or an output. The 16 pins are divided into two 8 -bit ports, PAO-PA7 and PBO-PB7. (PA7 also has another use which is discussed later.) Each is set up as an input by writing a " 0 " into the corresponding bit of the data direction register. A "1" written into the data direction register causes its corresponding bit to be an output. When in the input mode, the peripheral output buffers are in the " 1 " state and the internal pull-up device acts as less than one TTL load to the peripheral data lines. On a Read operation, the microprocessor reads the peripheral pin. When the peripheral device gets information from the R6532 it receives data stored in the data register. The microproces $\%$ reads valid pin information if the peripheral lines are greater than 2.0 volts for a " 1 " and less than 0.8 volt for a " 0 " as the peripheral pins are all TTL compatible. Pins PB0PB7 are also capable of sourcing 3 ma at 1.5 V , thus making them capable of Darlington drive.


RIOT Interface Signals

Table 1. Address Decoding


Notes:

- Don't Care, "1" = High level $(\geqslant 2.4 \mathrm{~V}$ ), " 0 " = Low level $(\leqslant 0.4 \mathrm{~V})$
(a) $\mathrm{A} 3=0$ to disable interrupt from timer to $\overline{\mathbb{R Q}}$ $A 3=1$ to enable interrupt from timer to $\overline{\operatorname{RQ}}$
(b) $\mathrm{A} 1=0$ to disable interrupt from PA7 to $\overline{\mathrm{RQ}}$
$A 1=1$ to enable interrupt from PA7 to $\overline{I R Q}$
(c) $A O=0$ for negative edge-detect $A O=1$ for positive edge-detect

Table 2. Register Addressing

| Start Address + | Register/Function | Start <br> Address + | Register/Function |
| :---: | :---: | :---: | :---: |
| \$0 | DRA (' A ' side data register) | \$7 | Write edge-detect control (positive edge-detece, |
| \$1 | DDRA (' A ' side data direction register) |  | enable interrupt) |
| \$2 | DRB ('B' side data register) | \$C | Read timer (enable interrupt) |
| \$3 | DDRB ('B' side data direction register) | \$14 | Write timer (divide by 1 , disable interrupt) |
| \$4 | Read timer (disable interrupt) | \$15 | Write timer (divide by 8 , disable interrupt) |
| \$4 | Write edge-detect control (negative edge-detect, | \$16 | Write timer (divide by 64, disable interrupt) |
|  | disable interrupt) | \$17 | Write timer (divide by 1024, disable interrupt) |
| $\$ 5$ | Read interrupt flag register (bit $7=$ timer, bit $6=$ | $\$ 1 \mathrm{C}$ | Write timer (divide by 1 , enable interrupt) |
|  | PA7 edge-detect) Clear PA7 flag | \$1D | Write timer (divide by 8 , enable interrupt) |
| $\$ 5$ | Write edge-detect control (positive edge-detect, disable interrupt) | $\begin{aligned} & \$ 1 E \\ & \$ 1 F \end{aligned}$ | Write timer (divide by 64, enable interrupt) Write timer (divide by 1024, enable interrupt) |
| \$6 | Write edge-detect control (negative edge-detect, enable interrupt) |  |  |

## INTERNAL ORGANIZATION

The R6532 is divided into four basic sections, RAM, I/O, Timer, and Interrupt Control. The RAM interfaces directly with the microprocessor through the system data bus and address lines. The I/O section consists of two 8-bit halves. Each half contains a Data Direction Register (DDR) and a Data Register (DR).

## RAM-128 BYTES ( 1024 BITS)

The $128 \times 8$ Read/Write Memory acts as a conventional static RAM and can be accessed from the microprocessor by selecting the chip (CS1 $=$ high, $\overline{\mathrm{CS} 2}=$ low) and by setting $\overline{\mathrm{RS}}$ low. Address lines A0 through A6 then select the desired byte of storage.

## I/O PORTS AND REGISTERS

The I/O Ports consist of eight lines which can be individually programmed to act as either an input or an output. A logic zero in a bit of the Port A Data Direction Register (DDRA) causes the corresponding line of Port $A$ to act as an input. A logic one causes the corresponding Port A line to act as an output. The voltage on any line programmed to be an output is determined by the corresponding bit in the Port A Data Register (DRA).

Data is read directly from the data pins during any read operation. For any output pin, the data transferred into the processor will be the same as that contained in the Data Register if the voltage on the pin is allowed to go to 2.4 V for a logic one. Note that for input lines, the processor can write into the corresponding bit of the Data Register. This will not affect the polarity on the pin until the corresponding bit of DDRA is set to a logic one to allow the I/O line to act as an output.

The operation of the Port B is exactly the same as the normal I/O operation of the Port A. Each of the eight lines can each be programmed to act as either an input or as an output by placing a 0 or a 1 into the Port B Data Direction register (DDRB). In the output mode, the voltage on a peripheral pin is controlled by the Port B Data Register (DRB).

The primary difference between Port A and the Port B is in the operation of the output buffers which drive these pins. The Port B output buffers aie push-pull devices which are capable of sourcing 3 ma at 1.5 V . This allows these pins to directly drive transistor switches. To assure that the microprocessor will read proper data on a "Read Port B" operation, logic in the R6532 allows the microprocessor to read the Output Register instead of reading the peripheral pin as on Port $A$.


R6532 Block Diagram

## EDGE DETECTING WITH PA7

In addition to acting as a peripheral I/O line, the PA7 line can be used as an edge-detecting input. In this mode, an active transition sets the internal interrupt flag (bit 6 of the Interrupt Flag register). Setting the interrupt flag causes IRQ 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, A0 controls the polarity of the active transition and A1 acts to enable or disable interrupting of the processor. The data which is placed on the Data Bus during this operation is discarded and has no effect on the control of PA7.

The PA7 interrupt flag is set on an active transition, even if the pin is being used as a normal input or as a peripheral control output. The flag is also set by an active transition if the PA7 interrupt is disabled. The reset signal ( $\overline{\mathrm{RES}}$ ) disables the PA7 interrupt and enables negative (high-to-low) edge detection on PA7. The PA7 edge detect logic can be set to detect either a positive or negative transition and to either enable or disable interrupt ( (IRQ) generation upon detection.

During system initialization, the interrupt flag may inadvertently be set by an unexpected transition on the PA7. It is therefore recommended that the interrupt flag be cleared before enabling interrupting from PA7. To clear PA7 interrupt flag, simply read the interrupt Flag Register.

## INTERVAL TIMER

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

The Timer can be programmed to count up to 255 time intervals. Each time interval can be either 1T, 8T, 64T or 1024T increments, where $T$ is the system clock period. When a full count is reached, an interrupt flag is set to logic " 1 ". After the interrupt flag is set the internal clock begins counting down at the system clock rate to a maximum of -255 T . Thus, after the interrupt flag is set, a Read of the timer will tell how long since the flag was set up to a maximum of 255 T .


Basic Elements of Interval Timer

## INTERVAL TIMER EXAMPLE

The 8-bit microprocessor data bus transfers data to and from the Timer. If a count of 52 time intervals were to be counted, the pattern 000111001000 would be put on the data bus and written into the divide by 1 Timer register.

At the same time that data is being written to the Timer, the counting intervals of $1,8,64,1024 \mathrm{~T}$ are decoded from address lines A0 and A1. During a Read or Write operation address line $A 3$ controls the interrupt capability of PB7, i.e., $A 3=1$ enables $\overline{\mathrm{IRQ}}, \mathrm{A} 3=0$ disables $\overline{\mathrm{RQQ}}$. 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 through 00000000 on the next count time an interrupt will occur and the counter will read $\begin{array}{llllllll}1 & 1 & 1 & 1 & 1 & 1 & 1 & 1\end{array}$. After the interrupt flag is set, the timer register decrements at a divide by " 1 " rate of the system clock. If the timer is read after the interrupt flag is set and a value of 11100100 is read, the time since interrupt is 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 $=11100100$ |  |  |
| :---: | :---: | :---: |
| Complement | $=00011011$ |  |
| 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 $001110100(=52)$. With a divide by 8 , total time to interrupt is $(52 \times 8)+1=417 \mathrm{~T}$. Total elapsed time would be $416 \mathrm{~T}+27 \mathrm{~T}=443 \mathrm{~T}$, assuming the value read after interrupt was 11100100 .

The interrupt flag will be reset whenever the Timer is accessed by a read or a write. However, the reading of the timer at the same time the interrupt occurs will not reset the interrupt flag. When the interrupt flags are read (D7 for the timer, D6 for the edge detect) data bus lines D0-D5 go to 0 .

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


## Notes:

Assume 52 Loaded into Timer with a divide by 8.
The Counter Contents and the Clock Pulse Numbers will coincide.
Prescale, $\mathrm{P}=8$.
Cycle Time, $\mathrm{T}_{\mathrm{c}}=1 \mu \mathrm{sec}$ (for 1 MHz )
Count, $\mathrm{N}=52$

## bus and peripheral timing waveforms



WRITE TIMING


## AC CHARACTERISTICS

| Characteristic | Symbol | $\begin{gathered} \mathrm{R} 6532 \\ (1 \mathrm{MHz}) \end{gathered}$ |  | $\begin{aligned} & \text { R6532A } \\ & \text { (2 MHz) } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Clock Cycle Time | $\mathrm{T}_{\mathrm{GrC}}$ | 1 | 10 | 0.5 | 10 | $\mu \mathrm{s}$ |
| Clock Pulse Width | $\mathrm{T}_{\mathrm{C}}$ | 470 | - | 240 | - | ns |
| Rise \& Fall Times | $\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}$ | - | 25 | - | 15 | ns |

## READ TIMING

| Address Set Up Time | $\mathrm{T}_{\text {ACR }}$ | 180 | - | 90 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address Hold Time | $\mathrm{T}_{\text {CAR }}$ | 0 | - | 0 | - | ns |
| R/̄W Set Up Time | TWCR | 180 | - | 90 | - | ns |
| Data Bus Delay Time | $\mathrm{T}_{\text {CDR }}$ | - | 395 | - | 190 | ns |
| Data Bus Hold Time | $\mathrm{T}_{\mathrm{HR}}$ | 10 | - | 10 | - | ns |
| Peripheral Data Set Up Time | TPCR | 300 | - | 150 | - | ns |

## WRITE TIMING

| 02 Cycle Time | $\mathrm{T}_{\mathrm{CrC}}$ | 1 | 10 | 0.5 | 10 | $\mu \mathrm{s}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\emptyset 2$ Pulse Width | $\mathrm{T}_{\mathrm{C}}$ | 470 | - | 240 | - | ns |
| Address Set Up Time | $\mathrm{T}_{\text {ACW }}$ | 180 | - | 90 | - | ns |
| Address Hold Time | $\mathrm{T}_{\text {CAH }}$ | 0 | - | 0 | - | ns |
| R/W Set Up Time | Twcw | 180 | - | 90 | - | ns |
| R/W Hold Time | TCWH | 0 | - | 0 | - | ns |
| Data Bus Set-Up Time | $\mathrm{T}_{\text {DCW }}$ | 200 | - | 90 | - | ns |
| Data Bus Hold Time | $\mathrm{T}_{\text {HW }}$ | 10. | - | 10 | - | ns |
| Peripheral Data Delay Time | $\mathrm{T}_{\text {CPW }}$ | - | 1 | - | 0.5 | $\mu s$ |
| Peripheral Data Delay Time CMOS | TCMOS | - | 2 | - | 1 | $\mu \mathrm{S}$ |

MAXIMUM RATINGS*

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

*Note: 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.

## DC CHARACTERISTICS

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

| Characteristic | Symbol | Min | Max | Unit ${ }^{(1)}$ | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.4 | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | 0 | -0.4 | $\checkmark$ |  |
| Input Leakage Current: AO-A6, RS, R $\overline{W_{2}}, \overline{R E S}, ~ \emptyset 2, ~ C S 1, \overline{C S 2}$ | IN |  | 2.5 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=O V \text { to } 5.0 \mathrm{~V} \\ & V_{c \mathrm{CC}}=O V \end{aligned}$ |
| Input Leakage Current for Three-State Off D0-D7 | $\mathrm{I}_{\text {TSI }}$ | - | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ to 2.4 V |
| Input High Current PAO-PA7, PBO-PB7 | $I_{H}$ | -100 | - | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ |
| Input Low Current PAO-PA7, PB0-PB7 | ILL | - | $-1.6$ | mA | $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |
| Output High Voltage <br> PAO-PA7, PB0-PB7 (TTL drive), DO-D7 <br> PB0-PB7 (other than TTL drive, e.g., Darlington) | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 2.4 \\ & 1.5 \end{aligned}$ | - | V | $\begin{aligned} & V_{C C}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \\ & I_{\text {LOAD }}=3 \mathrm{~mA} \end{aligned}$ |
| Output Low Voltage DO-D7 | $\mathrm{V}_{0}$ | - | 0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing) PAO-PA7, PB0-PB7 (TTL drive), D0-D7 PB0-PB7 (other drive, e.g., Darlington) | IOH | $\begin{aligned} & -100 \\ & -3.0 \end{aligned}$ | - | $\mu A$ mA | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \end{aligned}$ |
| Output Low Current (Sinking) <br> PAO-PA7, PBO-PB7 | lob | 1.6 | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Input Capacitance $\emptyset 2$ Other | $\begin{aligned} & \mathrm{C}_{\mathrm{CLK}} \\ & \mathrm{C}_{\mathrm{IN}} \end{aligned}$ | - | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \end{aligned}$ |
| Other Capacitance | $\mathrm{C}_{\text {Out }}$ | - | 10 | pF | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| Power Dissipation | PD | - | 1000 | mW | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |

## Notes:

1. All units are direct current (DC).
2. Negative sign indicates outward current flow, positive indicates inward flow.

## PACKAGE DIMENSIONS

40-PIN CERAMIC DIP


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

## 40-PIN PLASTIC DIP



| D1M | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
| A | 51.28 | 52.32 | 2.040 | 2.060 |
| B | 13.72 | 14.22 | 0.540 | 0.580 |
| C | 3.55 | 5.08 | 0.140 | 0.200 |
| D | 0.36 | 0.51 | 0.014 | 0.020 |
| F | 1.02 | 1.52 | 0.040 | 0.080 |
| 0 | 2.54 BSC |  | 0.100 BSC |  |
| H | 1.65 | 2.16 | 0.085 | 0.085 |
| J | 0.20 | 0.30 | 0.008 | 0.012 |
| K | 3.05 | 3.56 | 0.120 | 0.140 |
| L | 15.24 BSC |  | 0.600 BSC |  |
| M | $7{ }^{\circ}$ | $10^{\circ}$ | 7 | $10^{\circ}$ |
| N | 0.51 | 1.02 | 0.020 | 0.040 |

## R6541Q, R6500/41, R6500/42 \& R6500/43 ONE-CHIP INTELLIGENT PERIPHERAL CONTROLLER

## INTRODUCTION

The Rockwell R6541Q, R6500/41, R6500/42 and R6500/43 One-Chip Intelligent Peripheral Controllers (IPC) are general purpose, programmable interface V/O devices designed for use with a variety of 8 -bit and 16 -bit microprocessor systems.

## NOTE

This document describes four Intelligent Peripheral Controller devices. In the text, the terms IPC or device will be used when describing all parts. The few differences will be described in the text using the terms R6541Q, R6500/41, R6500/42, or R6500/43.

The one-chip R6500/41 IPC has an enhanced R6502 CPU, 1.5 K by 8 -bit ROM, 64 by 8 -bit RAM, three $1 / \mathrm{O}$ ports with multiplexed special functions, and a multi-function timer all contained within a 40 pin package.

For systems requiring additional I/O ports, the device is also available in a 64 -pin QUIP version, R6500/42, that provides three additional 8-bit ports.

Another 64 pin QUIP version, R6500/43, is functionally equivalent to the R6500/41 except 4 K addresses and a data bus are provided on pins, and the ROM size is optionally 256 or 0 bytes.

The R6541Q, also a 64 pin QUIP version, is functionally identical to the R6500/43 except it has no options. The part has no ROM and no port pull-up resistors. It can be used as an IPC microprocessor or as an emulator for the family.

In all versions, special interface registers allow these IPC devices to function as peripheral controllers for the 6500, 6800, Z80, 8080 , and other 8 -bit or 16 -bit host microcomputer systems. The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as the instruction simplicity results in system cost-effectiveness and a wide range of computational power. These features make the device a leading candidate for IPC computer applications.

## FEATURES

- Directly compatible with $6500,6800,8080$, and $\mathbf{Z 8 0}$ bus families
- Asynchronous Host interface that allows independent clock operation
- Input, Output and Status Registers for CPU/Host data transfers
- Interrupt or polled data interchange with Host
- Enhanced 6502 CPU
-Four new bit manipulation instructions: Set Memory Bit (SMB) Reset Memory Bit (RMB) Branch on Bit Set (BBS) Branch on Bit Reset (BBR)
-Decimal and binary arithmetic modes
- 13 addressing modes
-True indexing
- 1.5K, 256 or zero bytes mask-programmable ROM
- 64-byte static RAM
- 47 TTL-compatible I/O lines (R6500/42)
- 23 TTL-compatible I/O lines (all others)
- A 16-bit programmable counter/timer, with latch
-Pulse width measurement
-Pulse generation
-Interval timer
-Event counter
- Seven interrupts
-Two edge-sensitive lines: one positive, one negative
- Reset
- Counter
-Host data received
-Output Data Register full
-Input Data Register empty
- Multiplexed bus expandable to 4 K bytes of external memory
- Unmultiplexed bus for Peripheral I/O expansion
- $68 \%$ of the instructions are executed in less than $2 \mu \mathrm{~s}$ at 2 MHz
- NMOS-3 silicon gate, depletion load technology
- Single +5 V power supply
- 40-pin DIP (R6500/41)
- 64-pin QUIP (all others)

Rockwell supports development of the R6500/41, R6500/42, and R6500/43 with the System 65 Microcomputer development System and the R6500/* Family of Personality Modules. Complete in-circuit emulation with the R6500/* Family of Personality Modules allows total system test and evaluation.

This document is for the reader familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual (Order Number 201). A description of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Order Number 202).

Additional information on the devices can be obtained from the R6500/41 and R6500/42 Product Description (Order Number 2135) and the R6500/43 and R6541Q Product Description (Order Number 2136).

## MASK OPTIONS

The R6500/41 provides for internal pull-up resistors on PA and PC ports as a mask option. This option is available for port groups only, not for individual port lines.

The R6500/42 has provision for pull-up resistors on PA, PC, PF, and PG ports as a mask option. This option is available for port groups only, not for individual port lines.

The R6500/43 allows for 256 Bytes of ROM or no ROM, the Reset vector at FFFC or OFFC, and pull-up resistors on PA and PC ports as independent mask options. The port resistor options are available for port groups only, not for individual port lines.

The R6541Q has no options. It is configured with no ROM, Reset vector at FFFC, and no pull-up resistors.

## FUNCTIONAL DESCRIPTION

The internal CPU or the device is a standard R6502 configuration with the standard R6502 instructions, plus four new bit manipulation instructions. These new bit manipulator instructions form an enhanced R6502 instruction set and improve memory utilization efficiency and performance.

## Set Memory Bit (SMB \#,ADDR.)

This instruction sets to " 1 " one bit of the 8 -bit data field specified by the zero page address (memory or $1 / 0$ port). The first byte of the instruction specifies the SMB operation and which one of the eight bits to set. The second byte of the instruction designates the address $(0-255)$ of the byte or the I/O port to be operated on.

## Reset Memory Bit (RMB \#,ADDR.)

This instruction has the same operation and format as the SMB instruction except that a reset to " 0 " results.

## Branch on Bit Set Relative (BBS \#,ADDR.,DEST)

This instruction tests one of the eight bits designated by a 3-bit immediate field within the first byte of the instruction. The second byte designates the location of the byte or I/O port to be tested within the zero page address range. The third byte of the instruction specifies the 8 -bit relative address that the instruction will branch to if the tested bit is a "1". If the bit tested is not set, the next sequential instruction is executed.

## Branch on Bit Reset Relative <br> (BBR \#,ADDR.,DEST)

This instruction has the same operation and format as the BBS instruction except that a branch occurs if the bit tested is a " 0 ".

## Read Only Memory (ROM)

The ROM consists of 1536 bytes of mask programmable memory with an address space from FA00 to FFFF for the

R6500/41 and R6500/42. The R6500/43 has an optional 256 bytes of ROM at address space 0F00 to OFFF. The R6541Q has no ROM.

## Random Access Memory (RAM)

The RAM consists of 64 bytes of read/write memory with an assigned page zero address of 0040 through 007F.

## System Clock

The device functions with an external clock. It is fully asynchronous in reference to the Host computer timing. The device clock frequency equals the external clock frequency. It is also made available for any external device synchronization at pin $\varnothing 2$.

## Parallel Input/Output Ports

All of the devices except the R6500/42 have 23 I/O lines grouped into three ports (PA, PB, PC). Ports A and C may be used either for input or output individually or in groups of any combination. Port B may be used as all inputs or all outputs.

## Port A (PA)

Port A can be programmed as a standard parallel 8-bit I/O port or, under software control, as a counter I/O line or positive and negative edge detects.

## Port B (PB)

Port B can be programmed as an I/O port.

## Port C (PC)

Port C has seven pins and can be programmed as an I/O port.

## Ports E, F, and G (PE, PF, \& PG) R6500/42 only

The R6500/42 has all of the above ports $A, B$, and $C$, plus three extra ports (PE, PF, PG). Port E is outputs only. Ports $F$ and $G$ are bidirectional in any combination.

## Host Computer Interface

The device will work with a variety of Host Computers. The HOST interface consists of a chip select, one address line, two control lines, and an 8-bit 3-state data bus. Internal logic (controlled by MCR4) configures the address and two control lines to either a 6500 or 8080 operational methodology. The interface is completely asynchronous and will work with a Host Computer up to a 5 MHz bus transfer rate. The device clock input frequency need not be the same as the Host's. A mode control register is set to match the interface to that of the Host device as follows:

The device has an 8-bit Input Data Register (IDR) and an 8bit Output Data Register (ODR). The IDR serves as a temporary storage for commands and data from the Host to the device.

The ODR serves as a temporary storage for data from the device to the Host.

A Host Status Flag Register facilitates a software protocol that permits independent and uninterrupted flow of data asynchronously between the Host Computer and the device.

The Host Status Flag Register contains eight flag bits that can be read at any time by either the Host or the device.


## Counter/Latch Logic

The device contains a 16 -bit counter and a 16 -bit latch associated with it. The counter can be independently programmed to operate in one of four modes:

Counter

- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Ccunter


## Mode Control Register (MCR)

The Mode Control Register contains control bits for the multifunction I/O ports, mode select bits for the Counter, and a selection bit for the type of Host interface.

## Interrupt Flag Register (IFR) and Interrupt Enable Register (IER)

The device includes an Interrupt Flag Register and an Interrupt Enable Register which flags and controls I/O and counter status.


## MEMORY MAP



## KEY REGISTER SUMMARY

CPU Registers


Mode Control Register


Processor Status Register


Interrupt Enable and Flag Registers


| RS $\left(A_{0}\right)$ | READ | WRITE |
| :---: | :---: | :---: |
| 1 | HOST <br> STATUS FLAG | COMMAND <br> INPUT |
| 0 | DATA REG <br> INPUT | DATA REG <br> OUTPUT |


| Interface Diagram |  |
| :---: | :---: |
| $\begin{array}{r} \overline{\mathbf{C S}} 1 \\ \mathbf{E}(\overline{\mathrm{RD}}) \\ \hline \end{array}$ | ${ }^{49} \mathrm{v}_{\text {cc }}$ |
| R/W ( $\overline{\mathbf{W R})} 3$ | 38 RES |
| RS (A0) 4 | $37 \mathrm{PB7}$ |
| HDO 5 | $36 \mathrm{PB6}$ |
| HD1 6 | 35, PB5 |
| HD2 7 | 34 PB4 |
| HD3 8 | 33 PB3 |
| HD4 9 | $32 \mathrm{PB2}$ |
| HD5 10 | (31 PB1 |
| HD6 11 | 30 PBO |
| HD7 12 | 29 PA 7 |
| PCO 13 | 28 PA6 |
| PC1 14 | 27 PA5 |
| PC2 15 | 26 PA4 |
| PC3 16 | 25 PA3 |
| PC4 17 | 24) PA2 |
| PC5 18 | 23 PA1 |
| PC6 19 | 22 PAO |
| 82 | (21) $\mathrm{V}_{\mathbf{s}}$ |

FIGURE 2-2. R6500/41 Pin Out Designation (40 PIN DIP)


FIGURE 2-3. R6500/41 Dimensional Outline


FIGURE 2-4. R6541Q, R6500/42 \& R6500/43 Pin Out Designations (64 PIN QUIP)


FIGURE 2-5. 64 PIN QUIP Dimensional Outline

## ELECTRICAL SPECIFICATIONS

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 <br> Commercial | T | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $\mathrm{T}_{\text {sts }}$ | -65 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 ( $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 5 \% ; \mathrm{V}_{\mathrm{ss}}=0$ )

| CHARACTERISTIC | SYMBOL | MIN | TYP | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipation (Outputs High) Commercial $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $P_{\text {D }}$ | - | 500 | - | mW |
| Input High Voltage (Normal Operating Levels) | $\mathrm{V}_{\text {IH }}$ | +2.0 | - | $\mathrm{V}_{C c}$ | Vde |
| Input Low Voltage (Normal Operating Levels) | $\mathrm{V}_{12}$ | -0.3 | - | -0.8 | Vdc |
| Input Leakage Current $V_{\text {in }}=0 \text { to } 5.25 \mathrm{Vdc}$ | $\mathrm{I}_{\mathrm{IN}}$ | - 10.0 |  | +10.0 | $\mu$ Adc |
| Input Low Current $\left(\mathrm{V}_{\mathrm{lL}}=0.4 \mathrm{Vac}\right)$ | 111 |  | -1.0 | -1.6 | mAdc |
| Output High Voltage $\left(V_{c c}=\min , L_{\text {Loaso }}=-100 \mu \mathrm{Adc}\right)$ | V OH | +2.4 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Output High Voltage $\left(V_{c c}=\min \right)$ | $\mathrm{V}_{\text {cmos }}$ | $\mathrm{V}_{\mathrm{cc}}-30 \%$ | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Output Low Voltage $\left(V_{c c}=\min , I_{\text {Load }}=1.6 \mathrm{mAdc}\right)$ | $\mathrm{V}_{0}$ | - | - | -0.4 | Vdc |
| Output High Current (Sourcing) $\left(\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{Vdc}\right)$ | $\mathrm{IOH}_{\mathrm{OH}}$ | -100 | - | - | $\mu \mathrm{Adc}$ |
| Output Low Current (Sinking) $\left(\mathrm{V}_{\mathrm{OL}}-0.4 \mathrm{Vdc}\right)$ | loL | 1.6 | - | $\therefore$ - | mAdc |
| Darlington Current Drive, PE* $\left(\mathrm{V}_{\mathrm{OH}}=1.5 \mathrm{Vdc}\right)$ | $\mathrm{IOH}^{\text {H}}$ | -1.0 | - | - | mAdc |
| Output Low Current, PE* $\left(V_{\mathrm{OL}}=0.4 \mathrm{Vdc}\right)$ | $\mathrm{I}_{02}$ | 1.6 | - | - | mAdc |
| Input Capacitance $\begin{aligned} & \left(\mathrm{V}_{\text {in }}-0, \mathrm{~T}_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right) \\ & \mathrm{PA}, \mathrm{~PB}, \mathrm{PC}, \mathrm{PF}^{*}, \mathrm{PG}^{*} \end{aligned}$ | $\mathrm{C}_{\text {in }}$ | - | - | 10 | pF |
| $\begin{aligned} & \text { Output Capacitance } \\ & \qquad\left(V_{\text {in }}-0 . T_{A}=25^{\circ} \mathrm{C}, f=1.0 \mathrm{MHz}\right) \end{aligned}$ | $\mathrm{C}_{\text {OUT }}$ | - | - | 10 | pF |
| t/O Port Resistance PAO-PA7, PC0-PC6 PF0-PF7, PGO-PG7 | $\mathrm{R}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | $K!!$ |

NOTE: Negative sign indicates outward current flow, positive indicates inward flow. $V_{c c}=5 \mathrm{~V} \pm 5 \%$. *R6500/42 only.

## R6545-1 CRT CONTROLLER (CRTC)

## DESCRIPTION

The R6545-1 CRT Controller (CRTC) interfaces an 8-bit microprocessor to CRT raster scan video displays, and adds an advanced CRT controller to the established and expanding line of R6500, R6500/* and R65C00 microprocessor, microcomputer and peripheral device products.

The R6545-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 internal cursor register which generates a cursor output when its contents are equal to the current refresh address. Programmable cursor start and end registers allow a cursor of up to the full character scan in height to be placed on any scan lines of the character. Variable cursor display blink rates are provided. A light pen strobe input allows capture of the current refresh address in an internal light pen register. The refresh address lines are configured to provide direct dynamic memory refresh.

All timing for the video refresh memory signals is derived from the character clock input. Shift register, latch, and multiplex control signals (when needed) are provided by external high-speed timing. The mode control register allows noninterlaced video display modes at 50 or 60 Hz refresh rate. The internal status register may be used to monitor the R6545-1 operation. The $\overline{\mathrm{RES}}$ input allows the CRTC-generated field rate to be dynam-ically-synchronized with line frequency jitter.

## ORDERING INFORMATION

| Part Number: R6545-1 |
| :---: | :---: |
| Operating Temperature $\left(T_{L}\right.$ to $\left.T_{H}\right)$ <br> No letter $=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ <br> $E=-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ <br> Package <br> $\mathrm{P}=$ Plastic <br> $\mathrm{C}=$ Ceramic <br> Operating Frequency <br> No Letter $=1 \mathrm{MHz}$ <br> $\mathrm{A}=2 \mathrm{MHz}$ |

## 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)
- Video Display RAM may be configured as part of microprocessor memory field or independently slaved to R6545-1 (Transparent Addressing)
- Non-interlaced scan
- $50 / 60 \mathrm{~Hz}$ operation
- Fully programmable cursor
- Light pen register
- Addresses refresh RAM to 16 K characters
- No external DMA required
- Internal status register
- 40-Pin ceramic or plastic DIP
- Pin-compatible with MC6845
- Single $+5 \pm 5 \%$ Volt Power Supply


R6545-1 Pin Configuration

## INTERFACE SIGNAL DESCRIPTION

Figure 1 illustrates the interface between the CPU, the R6545-1, and the video circuitry. Figure 2 shows typical timing waveforms at the video interface.


Figure 1. R6545-1 Interface Diagram

## CPU INTERFACE

## Ø2 (Phase 2 Clock)

The Phase 2 ( $\varnothing 2$ ) input clock triggers all data transfers between the system processor (CPU) and the R6545-1. Since there is no maximum limit to the allowable $\varnothing 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 / \bar{W}$ input signal generated by the processor controls the direction of data transfers. A high on the $R / \bar{W}$ pin allows the processor to read the data supplied by the R6545-1, a low on the $R / \bar{W}$ pin allows data on data lines D0-D7 to be written into the R6545-1.

## $\overline{C S}$ (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 $\overline{\mathrm{CS}}$ is low.

## RS (Register Select)

The Register Select input accesses internal registers. A low on this pin permits writes $(R / \bar{W}=$ low $)$ into the Address Register and reads ( $R / \bar{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)

The eight data lines (D0-D7) transfer data between the processor and the R6545-1. These lines are bidirectional and are normally high-impedence except during read cycles when the chip is selected $(\overline{C S}=$ low $)$.

## VIDEO INTERFACE

## HSYNC (Horizontal Sync)

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

## DISPLAY ENABLE (Display Enable)

The DISPLAY ENABLE active-high output signal indicates when the R6545-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 generate the DISPLAY ENABLE signal. DISPLAY ENABLE delays one character time by setting bit 4 of R8 to a 1.

## CURSOR (Cursor Coincidence)

The CURSOR active-high output signal indicates when the scan coincides with the programmed cursor position. The cursor position is programmable to any character in the address field. Furthermore, within the character, the cursor may be programmed to be any block of scan lines, since the 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 edge-sensitive input signal loads the internal Light Pen Register with the contents of the Refresh Scan Counter at the time the active edge occurs. The low-to-high transition activates LPEN.

## CCLK (Clock)

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

## RES

The $\overline{\text { RES }}$ active-low input signal initializes all internal scan counter circuits. When $\overline{\text { ESS }}$ is low, all internal counters stop and clear all scan and video outputs go low with no affect on control registers. $\overline{\text { RES }}$ must stay low for at least one CCLK period. All scan timing initiates when $\overline{\text { RES }}$ goes high. In this way, $\overline{\text { RES }}$ can synchronize display frame timing with line frequency. $\overline{R E S}$ may also synchronize multiple CRTC's in horizontal and/or vertical split screen operation.

## REFRESH RAM AND CHARACTER ROM INTERFACE

## MAO-MA13 (Refresh RAM Address Lines)

These 14 active-high output signals address the Refresh RAM for character storage and display operations. The fully programmable starting scan address and ending scan address determines the total number of characters displayed, 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 design must translate row and column character coordinates into sequentially-numbered addresses. In the row/ column mode (R8, Mode Control, bit $2=1$ ), MA0-MA7 become column addresses CC0-CC7 and MA8-MA13 become row addresses CR0-CR5. In this case, the software manipulates characters in terms of row and column locations, but additional address compression circuits are needed to convert the CCOCC7 and CRO-CR5 addresses into a memory-efficient binary address scheme.

## RAO-RA4 (Raster Address Lines)

These five active-high output signals select each raster scan within an individual character row. The number of raster scan lines is programmable and determines the character height, including spaces between character rows.

The high-order line, RA4, is unique in that it can also function as a strobe output pin when the R6545-1 is programmed to operate in the "Transparent Address Mode." In this case the strobe is an active-high output and is true at the time the Refresh RAM update address gates on to the address lines, MAO-MA13. In this way, updates and readouts of the Video Display RAM can be made under control of the R6545-1 with only a small amount of external circuitry.


Figure 2. Vertical and Horizontal Timing

## INTERNAL REGISTER DESCRIPTION

Table 1 summarizes the internal registers and indicates their address selection and read/write capabilities.

## ADDRESS REGISTER

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\mathrm{A}_{4}$ | $\mathrm{~A}_{3}$ | $\mathrm{~A}_{2}$ | $\mathrm{~A}_{1}$ | $\mathrm{~A}_{0}$ |

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

## STATUS REGISTER (SR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| UR | LRF | VRT | - | - | - | - | - |

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


SR 4-0 $\quad$-Not used.

Table 1. Internal Register Summary

| $\overline{\text { CS }}$ | RS | Address Reg. |  |  |  |  | Reg.No. | Register Name | Stored Info. | RD | WR | Register Bit |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1. | 0 |
| 1 | - | - | - | - | - | - | - |  |  |  |  |  |  |  |  |  |  | 的 |  |
| 0 | 0 | - | - | - | - | - | - | Address Reg. | Reg. No. |  | $\checkmark$. |  |  |  | $\mathrm{A}_{4}$ | $\mathrm{A}_{3}$ | $\mathrm{A}_{2}$ | $\mathrm{A}_{1}$ | $\mathrm{A}_{0}$ |
| 0 | 0 | - | - | - | - | - | - | Status Reg. |  | $\checkmark$ |  | U | L | v |  |  |  |  |  |
| 0 | 1 | 0 | 0 | 0 | 0 | 0 | RO | Horiz. Total -1 | \# Charac. |  | $\checkmark$ | - | - | $\bullet$ | - | - | $\bullet$ | - | $\bullet$ |
| 0 | 1 | 0 | 0 | 0 | 0 | 1 | R1 | Hor iz. Displayed | \# Charac. |  | $\checkmark$ | - | $\bullet$ | - | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ |
| 0 | 1 | 0 | 0 | 0 | 1 | 0 | R2 | Horiz. Sync Position | \# Charac. |  | $\checkmark$ | - | - | $\bullet$ | $\bullet$ | - | - | - | - |
| 0 | 1 | 0 | 0 | 0 | 1 | 1 | R3 | VSYNC, HSYNC Widths | \# Scan Lines and <br> \# Char. Times |  | $\checkmark$ | $\mathrm{V}_{3}$ | $V_{2}$ | $V_{1}$ | $V_{0}$ | $\mathrm{H}_{3}$ | $\mathrm{H}_{2}$ | $\mathrm{H}_{1}$ | $\mathrm{H}_{0}$ |
| 0 | 1 | 0 | 0 | 1 | 0 | 0 | R4 | Vert. Total -1 | \# Charac. Row |  | $\checkmark$ | , | - | $\bullet$ | $\bullet$ | $\bullet$ | - | - | - |
| 0 | 1. | 0 | 0 | 1 | 0 | 1 | R5 | Vert. Total Adjust | \# Scan Lines |  | $\checkmark$ |  |  | , | $\bullet$ | $\bullet$ | $\bullet$ | - | - |
| 0 | 1 | 0 | 0 | 1 | 1 | 0 | R6 | Vert. Displayed | \# Charac. Rows |  | $\checkmark$ |  | - | - | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| 0 | 1 | 0 | 0 | 1 | 1 | 1 | R7 | Vert. Sync Position | \# Charac. Rows |  | $\checkmark$ |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - |
| 0 | 1 | 0 | 1 | 0 | 0 | 0 | R8 | Mode Control |  |  | $\checkmark$ | $\mathrm{U}_{1}$ | $U_{0}$ | c | D | T | RC |  | 0 |
| 0 | 1 | 0 | 1 | 0 | 0 | 1 | R9 | Scan Lines -1 | \# Scan Lines |  | $\checkmark$ |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | - | - |
| 0 | 1 | 0 | 1 | 0 | 1 | 0 | R10 | Cursor Start | Scan Line No. |  | 4 |  | $\mathrm{B}_{1}$ | $\mathrm{B}_{0}$ | - | $\bullet$ | $\bullet$ | - | - |
| 0 | 1 | 0 | 1 | 0 | 1 | 1 | R11 | Cursor End | Scan Line No. |  | $\checkmark$ |  |  |  | - | $\bullet$ | $\bullet$ | - | - |
| 0 | 1 | 0 | 1 | 1 | 0 | 0 | R12 | Display Start Addr (H) |  |  | $\checkmark$ |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| 0 | 1 | 0 | 1 | 1 | 0 | 1 | R13 | Display Start Addr (L) |  |  | $\checkmark$ | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - |
| 0 | 1 | 0 | 1 | 1 | 1 | 0 | R14 | Cursor Position (H) |  | $\checkmark$ | $\checkmark$ |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| 0 | 1 | 0 | 1 | 1. | 1 | 1 | R15 | Cursor Position (L) |  | $\checkmark$ | $\checkmark$ | - | $\bullet$ | - | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| 0 | 1 | 1 | 0 | 0 | 0 | 0 | R16 | Light Pen Reg ( H ) |  | $\checkmark$ |  |  |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ |
| 0 | 1 | 1 | 0 | 0 | 0 | 1 | R17 | Light Pen Reg (L) |  | $\checkmark$ |  | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ |
| 0 | 1 | 1 | 0 | 0 | 1 | 0 | R18 | Update Address Reg (H) |  |  | $\checkmark$ |  |  | $\bullet$ | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ |
| 0 | 1 | 1 | 0 | 0 | 1 | 1 | R19 | Update Address Reg (L) |  |  | $\checkmark$ | $\bullet$ | - | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | $\bullet$ | - |
| 0 | 1 | 1 | 1 | 1 | 1 | 1 | R31 | Dummy Location |  |  |  |  |  | 多 |  |  |  |  |  |
| Notes: $\square$ Designates used bit in registerDesignates unused bit in register. Reading this bit is always 0 , except not drive the data bus at all, and for CS $=1$ which operates likewise. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

## RO-HORIZONTAL TOTAL CHARACTERS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| NUMBER OF CHARACTERS -1 |  |  |  |  |  |  |  |

This 8-bit write-only register contains the total of displayed and non-displayed characters, minus one, per horizontal line. This register determines the frequency of HSYNC.

## R1—HORIZONTAL DISPLAYED CHARACTERS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NUMBER OF CHARACTERS |  |  |  |  |  |  |  |

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

## R2-HORIZONTAL SYNC POSITION

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| HORIZONTAL SYNC POSITION |  |  |  |  |  |  |  |

This 8-bit write-only register contains the position of HSYNC on the horizontal line, in terms of the character location number on the line. The position of the HSYNC determines the left to right location of the displayed text on the video screen. In this way, the side margins are adjusted.

## R3-HORIZONTAL AND VERTICAL SYNC WIDTHS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{~V}_{3}$ | $\mathrm{~V}_{2}$ | $\mathrm{~V}_{1}$ | $\mathrm{~V}_{0}$ | $\mathrm{H}_{3}$ | $\mathrm{H}_{2}$ | $\mathrm{H}_{1}$ | $\mathrm{H}_{0}$ |

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

## Hvsw

## 7-4 VSYNC Pulse Width

The width of the vertical sync pulse (VSYNC) in the number of scan lines. When bits 4-7 are all 0, VSYNC is 16 scan lines wide.

## HVSW

## 3-0 HSYNC Pulse Width

The width of the horizontal sync pulse (HSYNC) in the number of character clock times (CCLK).

Control of these parameters allows the R6545-1 to interface with a variety of CRT monitors, since the HSYNC and VSYNC timing signals may be accommodated without the use of external one shot timing.

## R4-VERTICAL TOTAL ROWS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | NO. OF CHAR. ROWS -1 |  |  |  |  |  |  |

The 7-bit Vertical Total Register contains the total number of character rows in a frame, minus one. This register, along with R5, determines the overall frame rate, which should be close
to the line frequency to ensure flicker-free appearance. If the frame time is adjusted to be longer than the period of the line frequency, then RES may provide absolute synchronism.

## R5-VERTICAL TOTAL LINE ADJUST

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | SCAN LINES |  |  |  |  |

The 5 -bit write-only Vertical Total Line Adjust Register (R5) contains the number of additional scan lines needed to complete an entire frame scan and is intended as a fine adjustment for the video frame time.

## R6—VERTICAL DISPLAYED ROWS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | DISPLAYED CHAR. ROWS |  |  |  |  |  |  |

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

## R7—VERTICAL SYNC POSITION

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | VERTICAL POSITION |  |  |  |  |  |  |

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

## R8-MODE CONTROL (MC)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| UM $(T)$ | US(T) | CSK | DES | RRA | RAD | - | 0 |

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

| MC | UM(T) - Update/Read Mode (Transparent Mode) |
| :---: | :---: |
| 0 | Update occurs during horizontal and vertical blanking times with update strobe. |
| 1 | Update interleaves during $\varnothing 2$ portion of cycle. |
| MC |  |
| 6 | US(T) -Update Strobe (Transparent Mode) |
| 0 | Pin 34 functions as memory address. |
| 1 | Pin 34 functions as update strobe. |
| MC |  |
| 5 | CSK -Cursor Skew |
| 0 | No delay |
| 1 | Delays Cursor one character time. |
| MC |  |
| 4 | DES -Display Enable Skew |
| 0 | No delay |
| 1 | Display Enable delays one character time. |

MC
3

## 3 RRA -Refresh RAM Access

Shared memory access
1 Transparent memory access
MC
2 RAD -Refresh RAM Addressing Mode
Straight binary addressing
Row/column addressing
MC
$1 \quad$-Not Used-don't care
MC O $\quad$-Not Used—must be a 0.
R9-ROW SCAN LINES

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | SCAN LINES -1 |  |  |  |  |

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

## R10-CURSOR START LINE

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | $\mathrm{B}_{1}$ | $\mathrm{~B}_{0}$ | START SCAN LINE |  |  |  |  |

## R11-CURSOR END LINE

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | END SCAN LINE |  |  |  |  |

These 5 -bit write-only registers select the starting and ending scan lines for the cursor. In addition, bits 5 and 6 of R10 are used to select the cursor blink mode, as follows:

| $\mathbf{B}_{\mathbf{1}}$ | $\mathbf{B}_{\mathbf{0}}$ | Cursor Operating Mode |
| :---: | :---: | :--- |
| 0 | 0 | Display Cursor Continuously |
| 0 | 1 | Blank Cursor |
| 1 | 0 | Blink Cursor at $1 / 16$ Field Rate |
| 1 | 1 | Blink Cursor at $1 / 32$ Field Rate |

A one character wide cursor can be controlled by storing values into the Cursor Start Line (R10) and Cursor End Line (R11) registers and into the Cursor Position Address High (R14) and Cursor Position Low (R15) registers.

## R12-DISPLAY START ADDRESS HIGH

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | DISPLAY START ADDRESS HIGH |  |  |  |  |  |

## R13-DISPLAY START ADDRESS LOW

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DISPLAY START ADDRESS LOW |  |  |  |  |  |  |  |

These registers 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.

## R14-CURSOR POSITION HIGH

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | CURSOR POSITION HIGH |  |  |  |  |  |

## R15-CURSOR POSITION LOW

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| CURSOR POSITION LOW |  |  |  |  |  |  |  |

These registers 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.

A 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

## R16-LIGHT PEN HIGH

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | LPEN HIGH |  |  |  |  |  |

## R17-LIGHT PEN LOW

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LPEN LOW |  |  |  |  |  |  |  |

These registers 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.

## R18—UPDATE ADDRESS HIGH

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | UPDATE ADDRESS HIGH |  |  |  |  |  |

## R19-UPDATE ADDRESS LOW

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: |
| UPDATE ADDRESS LOW |  |  |  |  |  |  |  |

These registers together comprise a 14 -bit register whose contents is the memory address at which the next read or update will occur (for transparent address mode, only). Whenever a read/update occurs, the update location automatically increments to allow for fast updates or readouts of consecutive character locations. This is described elsewhere in this document. The section on REFRESH RAM ADDRESSING describes this more fully.

## R31-DUMMY LOCATION

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

This register does not store any data, but is required to detect when transparent addressing updates occur. This is necessary to increment the Update Address Register and to set the Update Ready bit in the status register.

## REGISTER FORMATS

Register pairs R12/R13, R14/R15, R16/R17, and R18/R19 are formatted in one of two ways:
(1) Straight binary, if register R8, bit $2=0$
(2) Row/Column, if register R8, bit $2=1$. In this case the low byte is the Character Column and the high byte is the Character Row.


Figure 4. Video Display Format

## DESCRIPTION OF OPERATION

## VIDEO DISPLAY

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

Non-displayed areas of the Video Display are for horizontal and vertical retrace functions of the CRT monitor. The horizontal and vertical sync signals, HSYNC and VSYNC, are programmed to occur during these intervals and trigger the retrace in the CRT monitor. The pulse widths are constrained by the monitor requirements. The time position of the pulses may be adjusted to vary the display margins (left, right, top, and bottom).

## REFRESH RAM ADDRESSING

There are two modes of addressing for the video display memory:

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

In this mode, the Refresh RAM address lines (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 (CCO-CC7) and MA8-MA13 become character row addresses (CRO-CR5). Figure 5 illustrates the system configuration.

## Transparent Memory Addressing

For this mode, the display RAM is not directly accessible by the CPU, but is controlled entirely by the R6545-1. All CPU accesses are made via the R6545-1 and a small amount of external circuits. Figure 6 shows the system configuration for this approach.


Figure 5. Shared Memory System Configuration


Figure 6. Transparent Memory Addressing System Configuration (Data Hold Latch Needed for Horizontal/Vertical Blanking Updates, Only).

## ADDRESSING MODES

Figure 7 illustrates the address sequence for both modes of the Refresh RAM address.

## Row/Column

In this mode, the CRTC address lines (MAO-MA13) generate 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 (register R8, bit 2 is a 1 ).

## Binary

In this mode, the CRTC address lines are straight binary and no compression circuits are needed. However, software complexity increases since the CRT characters cannot be stored in terms of their row and column locations, but must be sequential (register R8, bit 2 is a 0 ).

## USE OF DYNAMIC RAM FOR REFRESH MEMORY

The R6545-1 permits use of dynamic RAMS as storage devices for the Refresh RAM by continuing to increment memory addresses in the non-display intervals of the scan. This is a
viable technique, since the Display Enable signal controls the actual video display blanking. Figure 7 illustrates Refresh RAM addressing for both row/column and binary addressing for 80 columns and 24 rows with 10 non-displayed columns and 10 non-displayed rows.

Note that the straight-binary mode has the advantage that all display memory addresses are stored in a continuous memory block, starting with address 0 and ending at 1919. The disadvantage with this method is that, if it is desired to change a displayed character location, the row and column identity of the location must be converted to its binary address before the memory may be written. The row/column mode, on the other hand, does not need to undergo this conversion. However, memory is not used as efficiently, since the memory addresses are not continuous, gaps exist. This requires that the system be equipped with more memory than actually used and this extra memory is wasted. Alternatively, address compression logic may be employed to translate the row/column format into a continuous address block.

The user selects whichever mode is best for the given application. The trade-offs between the modes are software versus hardware. Straight-binary mode minimizes hardware requirements and row/column minimizes software requirements.


STRAIGHT BINARY ADDRESSING SEQUENCE


ROW/COLUMN ADDRESSING SEQUENCE

Figure 7. Display Address Sequences (with Start Address $=0$ ) for $\mathbf{8 0} \times \mathbf{2 4}$ Example

## MEMORY CONTENTION SCHEMES FOR SHARED MEMORY ADDRESSING

From the diagram of Figure 5, it is clear that both the R6545-1 and the system CPU must address the video display memory. The R6545-1 repetitively fetches character information to generate the video signals in order to keep the screen display active. The CPU occasionally accesses the memory to change the displayed information or to read out current data characters. Three ways of resolving this dual-contention requirement are apparent:

- CPU Priority

In this technique, the address lines to the video display memory are normally driven by the R6545-1 unless the CPU needs access, in which case the CPU addresses immediately override those from the R6545-1 giving the CPU immediate access.

- $\phi 1 / \phi 2$ Memory Interleaving

This method permits both the R6545-1 and the CPU access to the video display memory by time-sharing via the system $\phi 1$ and $\phi 2$ clocks. During the $\phi 1$ portion of each cycle (the time when $\phi 2$ is low), the R6545-1 address outputs are gated to the video display memory. In the $\phi 2$ time, the CPU address lines are switched in. In this way, both the R6545-1 and the CPU have unimpeded access to the memory. Figure 8 illustrates the timings.


Figure 8. $\boldsymbol{\phi 1 / \phi 2}$ Interleaving

## - Vertical Blanking

With this approach, the address circuitry is identical to the case for CPU Priority updates. The only difference is that the Vertical Retrace status bit (bit 5 of the Status Register) is used by the CPU so that access to the video display memory is only made during vertical blanking time (when bit 5 is a 1). In this way, no visible screen perturbations result. See Figure 10 for details.

## TRANSPARENT MEMORY ADDRESSING

In this mode of operation, the video display memory address lines are not switched by contention circuits, but are generated by the R6545-1. In effect, the contention is handled by the R6545-1. As a result, the schemes for accomplishing CPU memory access are different:

- $\phi 1 / \phi 2$ Interleaving

This mode is similar to the Interleave mode used with shared memory. In this case, however, the $\phi 2$ address is generated from the Update Address Register (R18 and R19) in the R6545-1. Thus, the CPU must first load the address to be accessed into R18/R19 and then this address is always gated onto the MA lines during $\phi 2$. Figure 9 shows the timing.


Figure 9. $\phi 1 / \phi 2$ Transparent Interleaving

- Horizontal/Vertical Blanking

In this mode, the CPU loads the Update Address, but is only gated onto the MA lines during horizontal or vertical blank times, so memory accesses do not interfere with the display appearance. To signal when the update address is on the MA lines, an update strobe (STB) is provided as an alternate function of pin 34. Data hold latches are necessary to temporarily retain the character to be stored until the retrace time occurs. In this way, the system CPU is not halted waiting for the blanking time to arrive. Figure 11 illustrates the address and strobe timing for this mode.

## CURSOR AND DISPLAY ENABLE SKEW CONTROL

Bits 4 and 5 of the Mode Control register (R8) are used to delay the Display Enable and Cursor outputs, respectively. Figure 12 illustrates the effect of the delays.


Figure 10. Operation of Vertical Blanking Status Big


Figure 11. Retrace Update Timing


Figure 12. Cursor and Display Enable Skew

WRITE TIMING CHARACTERISTICS $\quad\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

|  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol | Characteristic | Min. | Max. | Min. | Max. | Unit |
| $\mathrm{t}_{\mathrm{CYC}}$ | Cycle Time | 1.0 | - | 0.5 | - | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{C}}$ | $\phi 2$ Pulse Width | 440 | - | 200 | - | ns |
| $t_{\text {ACW }}$ | Address Set-Up Time | 180 | - | 90 | - | ns |
| $\mathrm{t}_{\text {CAH }}$ | Address Hold Time | 0 | - | 0 | - | ns |
| $t_{\text {WCW }}$ | R/W Set-Up Time | 180 | - | 90. | - | ns |
| $\mathrm{t}_{\mathrm{CWH}}$ | R/ $\bar{W}$ Hold Time | 0 | - | 0 | - | ns |
| $\mathrm{t}_{\text {DCW }}$ | Data Bus Set-Up Time | 265 | - | 100 | - | ns |
| $t_{\text {HW }}$ | Data Bus Hold Time | 10 | - | 10 | - | ns |
| ( $\mathrm{t}_{\mathrm{R}}$ and $\mathrm{t}_{\mathrm{F}}=10$ to 30 ns ) |  |  |  |  |  |  |

READ TIMING CHARACTERISTICS $\quad\left(\mathrm{V}_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Characteristic | R6545-1 |  | R6545A-1 |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | Min. | Max. | Min. | Max. | Unit |
| $t_{\text {CYC }} \quad$ Cycle Time | 1.0 | - | 0.5 | - | $\mu \mathrm{S}$ |
| ${ }^{\text {c }}$ c $\quad \phi 2$ Pulse Width | 440 | - | 200 | - | ns |
| $t_{\text {ACR }} \quad$ Address Set-Úp Time | 180 | - | 90 | - | ns |
| $t_{\text {CAR }} \quad$ Address Hold Time | 0 | - | 0 | - | ns |
| $t_{\text {WCR }} \quad \mathrm{R} / \overline{\mathrm{W}}$ Set-Up Time | 180 | - | 90 | - | ns |
| $\mathrm{t}_{\mathrm{CDR}} \quad$ Read Access Time (Valid Data) | - | 340 | - | 150 | ns |
| $t_{\text {HR }} \quad$ Read Hold Time | 10 | - | 10 | - | ns |
| $t_{\text {CDA }} \quad$ Data Bus Active Time (Invalid Data) | 40 | - | 40 | - | ns |
| ( $\mathrm{t}_{\mathrm{R}}$ and $\mathrm{t}_{\mathrm{F}}=10$ to 30 ns ) |  |  |  |  |  |



## MEMORY AND VIDEO INTERFACE CHARACTERISTICS

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

| Symbol | Characteristic | R6545-1 |  | R6545A-1 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {chCr }}$ | Character Clock Cycle Time | 0.40 | - | 0.40 | - | $\mu \mathrm{s}$ |
| ${ }^{\text {c }}$ CCH | Character Clock Puise Width | 200 | - | 200 | - | ns |
| (X) $\mathrm{t}_{\text {MAD }}$ | MAO-MA13 Propagation Delay | - | 300 | - | 300 | ns |
| (X) $\mathrm{t}_{\text {Rad }}$ | RA0-RA4 Propagation Delay | - | 300 | - | 300 | ns |
| (X)t ${ }_{\text {dTD }}$ | DISPLAY ENABLE Propagation Delay | - | 450 | - | 450 | ns |
| (X) ${ }_{\text {HSD }}$ | HSYNC Propagation Delay | - | 450 | - | 450 | ns |
| (X)tvSD | VSYNC Propagation Delay | - | 450 | - | 450 | ns |
| (X) $\mathrm{t}_{\text {cDD }}$ | CURSOR Propagation Delay | - | 450 | - | 450 | ns |
| ${ }^{\text {t }}$ TAD | MA0-MA13 Switching Delay | - | 200 | - | 200 | ns |
| Note: <br> $\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}=20 \mathrm{~ns}$ (max). |  |  |  |  |  |  |



## TRANSPARENT ADDRESSING WAVEFORMS ( $\phi 1 / \phi 2$ INTERLEAVING)



## LIGHT PEN STROBE TIMING CHARACTERISTICS



LIGHT PEN STROBE TIMING WAVEFORMS


NOTE: "Safe" time position for LPEN positive edge to cause address $\mathrm{n}+2$ to load into Light Pen Register.
$t_{\text {LP2 }}$ and $t_{\text {LP1 }}$ are time positions causing uncertain results.

## ABSOLUTE 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 Commercial Industrial | $\mathrm{T}_{\mathrm{A}}$ | $\begin{array}{r} 0 \text { to }+70 \\ -40 \text { to }+85 \end{array}$ | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

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

DC CHARACTERISTICS $\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.4 | $\mathrm{V}_{\mathrm{Cc}}$ | Vdc |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | -0.3 | 0.4 | Vdc |
| Input Leakage ( $\varnothing 2, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{RES}}, \overline{\mathrm{CS}}, \mathrm{RS}, \mathrm{LPEN}, \mathrm{CCLK}$ ) | 1 IN | - | 2.5 | $\mu \mathrm{Adc}$ |
| Three-State Input Leakage (D0-D7) $\left(V_{\text {IN }}=0.4 \text { to } 2.4 \mathrm{~V}\right)$ | $\mathrm{I}_{\text {TSI }}$ | - | $\pm 10.0$ | $\mu$ Adc |
| Output High Voltage $\begin{aligned} & \mathrm{I}_{\text {LOAD }}=205 \mu \mathrm{Adc}(\mathrm{DO}-\mathrm{D} 7) \\ & \mathrm{I}_{\text {LOAD }}=100 \mu \mathrm{Adc} \text { (all others) } \end{aligned}$ | VOH | 2.4 | - | Vdc |
| Output Low Voltage $I_{\text {LOAD }}=1.6 \mathrm{mAdc}$ | $V_{\text {OL }}$ | - | 0.4 | Vdc |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | - | 900 | mW |
| Input Capacitance <br> $\not 2_{2}, \mathrm{R} \overline{\mathrm{W}}, \overline{\mathrm{RES}}, \overline{\mathrm{CS}}, \mathrm{RS}, \operatorname{LPEN}, \mathrm{CCLK}$ DO-D7 | $\mathrm{C}_{\text {IN }}$ | 二 | $\begin{aligned} & 10.0 \\ & 12.5 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ |
| Output Capacitance | $\mathrm{Cout}^{\text {O }}$ | - | 10.0 | pF |

TEST LOAD


$$
\begin{aligned}
\text { R } & =11 \mathrm{~K} \Omega \text { FOR DO-D7 } \\
& =24 \mathrm{~K} \Omega \text { FOR ALL OTHER OUTPUTS } \\
C & =130 \mathrm{pF} \text { TOTAL FOR DO-D7 } \\
& =30 \mathrm{pF} \text { ALL OTHER OUTPUTS }
\end{aligned}
$$

## PACKAGE DIMENSIONS

40-PIN CERAMIC DIP


| DIM | MLLLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
| A | 50.29 | 51.56 | 1.980 | 2.030 |
| B | 14.73 | 15.49 | 0.580 | 0.610 |
| C | 1.78 | 3.05 | 0.070 | 0.120 |
| D | 0.38 | 0.58 | 0.015 | 0.023 |
| F | 1.02 | 1.65 | 0.040 | 0.065 |
| G | 2.29 | 2.80 | 0.090 | 0.110 |
| J | 0.20 | 0.38 | 0.008 | 0.015 |
| K | 3.18 | 3.81 | 0.125 | 0.150 |
| L | 14.99 | 16.51 | 0.590 | 0.650 |
| M | $0^{\circ}$ | $10^{\circ}$ | $0^{\circ}$ | $10^{\circ}$ |
| N | 0.58 | 1.78 | 0.020 | 0.070 |

## 40-PIN PLASTIC DIP



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

## R6551

ASYNCHRONOUS COMMUNICATIONS INTERFACE ADAPTER (ACIA)

## DESCRIPTION

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

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

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

The Command Register controls parity, receiver echo mode, transmitter interrupt control, the state of the RTS line, receiver interrupt control, and the state of the DTR line.

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

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

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

## ORDERING INFORMATION

| Part No.: R6551 |
| :---: |
| $\left[\begin{array}{c}\text { Temperature Range }\left(T_{L} \text { to } T_{H}\right): \\ \text { Blank }=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ \mathrm{E}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}\end{array}\right.$ |
| Frequency Range: |
| $1=1 \mathrm{MHz}$ |
| $2=2 \mathrm{MHz}$ |
| Package: |
| $\mathrm{C}=$ Ceramic |
| $\mathrm{P}=$ Plastic |

## FEATURES

- Compatible with 8-bit microprocessors
- Full duplex operation with buffered receiver and transmitter
- Data set/modem control functions
- Internal baud rate generator with 15 programmable baud rates (50 to 19,200)
- Program-selectable internally or externally controlled receiver rate
- Programmable word lengths, number of stop bits, and parity bit generation and detection
- Programmable interrupt control
- Program reset
- Program-selectable serial echo mode
- Two chip selects
- 2 or 1 MHz operation
- $5.0 \mathrm{Vdc} \pm 5 \%$ supply requirements
- 28-pin plastic or ceramic DIP
- Full TTL compatibility
- Compatible with R6500, R6500/* and R65C00 microprocessors



Figure 2. ACIA Internal Organization

## FUNCTIONAL DESCRIPTION

A block diagram of the ACIA is presented in Figure 2 followed by a description of each functional element of the device.

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

## INTERRUPT LOGIC

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

## I/O CONTROL

The I/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 Receiver Select (RS1, RSO) and Read/Write $(R / W)$ lines as described later in Table 1.

## 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 $\varnothing 2$ clock input. The chip will perform data transfers to or from the microcomputer data bus during the $\not \varnothing 2$ high period when selected.

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

## TRANSMITTER AND RECEIVER DATA REGISTERS

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

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

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.

## STATUS REGISTER

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

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IRQ | $\overline{D S R}$ | $\overline{D C D}$ | TDRE | RDRE | OVRN | FE | PE |


| Bit 7 | Interrupt (IRQ) |
| :---: | :---: |
| 0 | No interrupt |
| 1 | Interrupt has occurred |
| Bit 6 | Data Set Ready ( $\overline{\mathrm{DSR}}$ ) |
| 0 | $\overline{\text { DSR }}$ low (ready) |
| 1 | $\overline{\text { DSR }}$ high (not ready) |
| Bit 5 | Data Carrier Detect ( $\overline{\text { DCD }}$ ) |
| 0 | $\overline{\mathrm{DCD}}$ low (detected) |
| 1 | $\overline{\mathrm{DCD}}$ high (not detected) |


| Bit 4 | Transmitter Data Register Empty |
| :---: | :--- |
| 0 | Not empty |


| Bit 3 | Receiver Data Register Full |
| :---: | :--- |
| 0 | Not full |
| 1 | Full |

Bit 2 Overrun*
0 No overrun
1 Overrun has occurred
Bit 1 Framing Error*
0 No framing error
1 Framing error detected
Bit 0 Parity Error*
0 No parity error
1 Parity error detected
*No interrupt occurs for these conditions
Reset Initialization


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

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

## Receiver Data Register Full (Bit 3)

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

## Transmitter Data Register Empty (Bit 4)

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

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

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

## Interrupt (Bit 7)

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

## CONTROL REGISTER

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

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SBN | WL |  | RCS | SBR |  |  |  |
|  | WL1 | WLO |  | SBR3 | SBR2 | SBR1 | SBRO |
| Bit 7 |  | Stop Bit Number (SBN) |  |  |  |  |  |
| 0 |  | 1 Stop bit |  |  |  |  |  |
| 1 |  | 2 Stop bits |  |  |  |  |  |
| 1 |  | 11/2 Stop bits |  |  |  |  |  |
|  |  | For W | L $=5$ | and no p | parity |  |  |
| 1 |  | 1 Stop bit |  |  |  |  |  |
|  |  | For WL = 8 and parity |  |  |  |  |  |
| Bits 6-5 Word Length (WL) |  |  |  |  |  |  |  |
| 6 |  | No. Bits |  |  |  |  |  |
|  | 0 | 8 |  |  |  |  |  |
| 0 |  | 7 |  |  |  |  |  |
| 1 | 0 | 6 |  |  |  |  |  |
| 1 | 1 | 5 |  |  |  |  |  |
| Bit 4 Receiver Clock Source (RCS) |  |  |  |  |  |  |  |
| 0 |  | External receiver clock |  |  |  |  |  |
| 1 |  | Baud rate |  |  |  |  |  |
| Bits 3-0 |  | Selected Baud Rate (SBR) |  |  |  |  |  |
| 3 | 2 |  | 0 Ba | Baud |  |  |  |
| 0 | 0 |  | 0 16x | 16x Exter | rnal Clo |  |  |
| 0 | 0 | 0 | 150 | 50 |  |  |  |
| 0 | 0 | 1 | 075 | 75 |  |  |  |
| 0 | 0 | 1 | 11 | 109.92 |  |  |  |
| 0 | 1 | 0 | 013 | 134.58 |  |  |  |
| 0 | 1 | 0 | 115 | 150 |  |  |  |
| 0 | 1 | 1 | 0300 | 300 |  |  |  |
| 0 | 1 | 1 | 1600 | 600 |  |  |  |
| 1 | 0 | 0 | $0 \quad 12$ | 1200 |  |  |  |
| 1 | 0 | 0 | 118 | 1800 |  |  |  |
| 1 | 0 | 1 | 02 | 2400 |  |  |  |
| 1 | 0 | 1 | 13 | 3600 |  |  |  |
| 1 | 1 | 0 | 048 | 4800 |  |  |  |
| 1 | 1 | 0 | 17 | 7200 |  |  |  |
| 1 | 1 | 1 | 09 | 9600 |  |  |  |
| 1 | 1 | 1 | 1 19 | 19,200 |  |  |  |

## Reset Initialization

$\begin{array}{llllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

Hardware reset ( $\overline{\text { RES }}$ )
Program reset

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

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

If the Receiver clock uses the same baud rate as the transmitter, then RxC becomes an output and can be used to slave other circuits to the ACIA. Figure 3 shows the Transmitter and Receiver layout.


Figure 3. Transmitter/Receiver Clock Circuits

## Receiver Clock Source (Bit 4)

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

## Word Length (Bits 5, 6)

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

## Stop Bit Number (Bit 7)

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

## COMMAND REGISTER

The Command Register controls specific modes and functions.


| Bits 7-6 | Parity Mode Control (PMC) |
| :---: | :---: |
| $7 \quad 6$ |  |
| 00 | Odd parity transmitted/received |
| 0 | Even parity transmitted/received |
| 10 | Mark parity bit transmitted |
|  | Parity check disabled |
| 11 | Space parity bit transmitted |
|  | Parity check disabled |
| Bit 5 | Parity Mode Enabled (PME) |
| 0 | Parity mode disabled |
|  | No parity bit generated |
|  | Parity check disabled |
| 1 | Parity mode enabled |
| Bit 4 | Receiver Echo Mode (REM) |
| 0 | Receiver normal mode |
| 1 | Receiver echo mode bits 2 and 3 |
|  | Must be zero for receiver echo mode, RTS will be low. |
| Bits 3-2 | Transmitter Interrupt Control (TIC) |
| $3 \quad 2$ |  |
| $0 \quad 0$ | $\overline{\text { RTS }}=$ High, transmit interrupt disabled |
| 01 | $\overline{\text { RTS }}=$ Low, transmit interrupt enabled |
| 10 | $\overline{\text { RTS }}=$ Low, transmit interrupt disabled |
| 11 | $\begin{aligned} \overline{\mathrm{RTS}}= & \text { Low, transmit interrupt disabled } \\ & \text { transmit break on } \mathrm{TxD} \end{aligned}$ |
| Bit 1 | Interrupt Request Disabled (IRD) |
| 0 | $\overline{\text { IRQ }}$ enabled |
| 1 | $\overline{\text { IRQ disabled }}$ |
| Bit 0 | Data Terminal Ready (DTR) |
| 0 | Data terminal not ready ( $\overline{\text { DTR }}$ high) |
| 1 | Data terminal ready (DTR low) |

## Data Terminal Ready (Bit 0)

This bit enables all selected interrupts and controls the state of the Data Terminal Ready ( $\overline{\mathrm{DTR}}$ ) 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{\text { DTR }}$ line low.

## Receiver Interrupt Control (Bit 1)

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

## Transmitter Interrupt Control (Bits 2, 3)

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

## Receiver Echo Mode (Bit 4)

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

## Parity Mode Enable (Bit 5)

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

## Parity Mode Control (Bits 6, 7)

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

## Reset Initialization

|  |  |  |  |  |  |  |  |  | Hardware reset (RES Program reset |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 |  | 0 | 0 | 0 |  |  |  |  |  |
|  |  |  | 0 |  |  | 0 | 0 |  |  |  |  |  |  |

## INTERFACE SIGNALS

Figure 4 shows the ACIA interface signals associated with the microprocessor and the modem.


Figure 4. ACIA Interface Diagram ?

## MICROPROCESSOR INTERFACE

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

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

## Input Clock ( ${ }^{(\sigma 2)}$

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

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

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

## Interrupt Request (IRQ)

The $\overline{\mathrm{RQ}}$ 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{RQ}}$ microprocessor input. Normally a high level, $\overline{\bar{R} Q}$ goes low when an interrupt occurs.

## Data Bus (D0-D7)

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

## Chip Selects (CS0, $\overline{\mathbf{C S} 1)}$

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

## Register Selects (RS0, RS1)

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

Table 1. ACIA Register Selection

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

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

## ACIA/MODEM INTERFACE

## Crystal Pins (XTLI, XTLO)

These pins are normally directly connected to the external crystal ( 1.8432 MHz ) to derive the various baud rates. Alternatively, an externally generated clock can drive the XTLI pin, in which case the XTLO pin must float. XTLI is the input pin for the transmit clock.

## Transmit Data (TxD)

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

## Receive Data (RxD)

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

## Receive Clock (RxC)

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

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

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

## Clear to Send (CTS)

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

## Data Terminal Ready (DTR)

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

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

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

## Data Carrier Detect ( $\overline{\mathbf{D C D}}$ )

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

## TRANSMITTER AND RECEIVER OPERATION

## Continuous Data Transmit

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

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


Figure 5. Continuous Data Transmit

## Continuous Data Receive

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


## Transmit Data Register Not Loaded by Processor

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

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


Figure 7. Transmit Data Register Not Loaded by Processor

## Effect of CTS on Transmitter

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


Figure 8. Effect of CTS on Transmitter

## Effect of Overrun on Receiver

If the processor does not read the Receiver data Register in the allocated time, 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 9 shows the timing relationship for this mode.


Figure 9. Effect of Overrun on Receiver

## Echo Mode Timing

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


Figure 10. Echo Mode Timing

## Effect of CTS on Echo Mode Operation

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


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

## Overrun in Echo Mode

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


Figure 12. Overrun in Echo Mode

## Framing Error

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


Figure 13. Framing Error

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

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

Once such a change of state occurs, subsequent transitions will not cause interrupts or changes in the Status Register until the first interrupt is serviced. When the Status Register is read by the processor, the ACIA automatically checks the level of the $\overline{\mathrm{DCD}}$ line, and if it has changed, another $\overline{\mathrm{RQ}}$ occurs (see Figure 14).


Figure 14. Effect of DCD on Receiver

## Timing with $11 / 2$ Stop Bits

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


Figure 15. Timing with $1 \frac{1}{2}$ Stop Bits

## Transmit Continuous "BREAK"

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

## Note

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


Figure 16. Transmit Continuous "BREAK""

## Receive Continuous "BREAK"

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


Figure 17. Receive Continuous "BREAK"

## Asynchronous Communications Interface Adapter (ACIA)

## STATUS REGISTER OPERATION

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

## 1. Read Status Register

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

If not set, the interrupt source is not the ACIA.
3. Check $\overline{\mathrm{DCD}}$ and $\overline{\mathrm{DSR}}$

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

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

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

## PROGRAM RESET OPERATION

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

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

## MISCELLANEOUS

1. If Echo Mode is selected, $\overline{\text { RTS }}$ goes low.
2. If Bit 0 of Command Register is 0 (disabled), then:
a) All interrupts are disabled, including those caused by DCD and DSR transitions.
b) Transmitter is disabled immediately.
c) Receiver is disabled, but a character currently being received will be completed first.
3. Odd parity occurs when the sum of all the 1 bits in the data word (including*the parity bit) is odd.
4. In the receive mode, the received parity bit does not go into the Receiver Data Register, but generates parity error or no parity error for the Status Register.
5. Transmitter and Receiver may be in full operation simultaneously. This is "full-duplex" mode.
6. If the RXD line inadvertently goes low and then high right after a Stop Bit, the ACIA does not interpret this as a Start Bit, but samples the line again halfway into the bit to determine if it is a true Start Bit or a false one. For false Start Bit detection, the ACIA does not begin to receive data, instead, only a true Start Bit initiates receiver operation.
7. Precautions to consider with the crystal oscillator circuit:
a) The external crystal should be a "series" mode crystal.
b) The XTALI input may be used as an external clock input. The unused pin (EXTALO) 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 $\mathrm{V}_{\mathrm{Cc}}$.

## GENERATION OF NON-STANDARD baUd Rates

## Divisors

The internal counter/divider circuit selects the appropriate divisor for the crystal frequency by means of bits 0-3 of the ACIA Control Register, as shown in Table 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 ACIA with an off-chip oscillator to achieve other baud rates. In this case, XTALI (pin 6) must be the clock input and XTALO (pin 7) must be a noconnect.

Table 2. Divisor Selection

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

## DIAGNOSTIC LOOP-BACK OPERATING MODES

A simplified block diagram for a system incorporating an ACIA is shown in Figure 18.

It may be desirable to include in the system a facility for "loopback" 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 ACIA does not contain automatic loop-back operating modes, but they may be implemented with the addition of a small amount of external circuitry. Figure 19 indicates the necessary logic to be used with the ACIA. The LLB line is the pos-itive-true signal to enable local loop-back operation. Essentially, LLB $=$ high does the following:

1. Disables outputs TxD, $\overline{\mathrm{DTR}}$, and $\overline{\mathrm{RTS}}$ (to Modem).
2. Disables inputs RxD, $\overline{\mathrm{DCD}}, \overline{\mathrm{CTS}}, \overline{\mathrm{DSR}}$ (from Modem).
3. Connects transmitter outputs to respective receiver inputs (i.e., TXD to $\mathrm{RXD}, \overline{\mathrm{DTR}}$ to $\overline{\mathrm{DCD}}, \overline{\mathrm{RTS}}$ to $\overline{\mathrm{CTS}}$ ).

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.

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 1 , so that the transmitter clock equals the receiver clock.
2. Command Register bit 4 must be 1 to select Ecto Mode.
3. Command Register bits 3 and 2 must be 1 and 0 , respectively to disable IRQ interrupt to transmitter.
4. Command Register bit 1 must be 0 to disable $\overline{\mathrm{RQ}}$ interrupt for receiver.

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


Figure 18. Simplified System Diagram


Figure 19. Loop-Back Circuit Schematic

## READ TIMING DIAGRAM

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

Table 3. Transmit/Receive Characteristics

|  |  | $1 \mathbf{M H z}$ |  | $2 \mathbf{M H z}$ |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Characteristic | Symbol | Min | Max | Min | Max | Unit |
| Transmit/Receive <br> Clock Rate | $\mathrm{t}_{\mathrm{CCY}}$ | $400^{*}$ | - | $400^{*}$ | - | ns |
| Transmit/Receive <br> Clock High Time | $\mathrm{t}_{\mathrm{CH}}$ | 175 | - | 175 | - | ns |
| Transmit/Receive <br> Clock Low Time | $\mathrm{t}_{\mathrm{CL}}$ | 175 | - | 175 | - | ns |
| XTLI to TXD <br> Propagation Delay | $\mathrm{t}_{\mathrm{DD}}$ | - | 500 | - | 500 | ns |
| RTS Propagation <br> Delay | $\mathrm{t}_{\mathrm{DLY}}$ | - | 500 | - | 500 | ns |
| IRQ Propagation <br> Delay (Clear) | $\mathrm{t}_{\mathrm{IRQ}}$ | - | 500 | - | 500 | ns |
| Load Capacitance | $\mathrm{C}_{\mathrm{L}}$ | - | 130 | - | 130 | pF |
| DTR, RTS <br> TxD |  | - | 30 | - | 30 | pF |

Notes:
$\left(\mathrm{t}_{\mathrm{B}}, \mathrm{t}_{\mathrm{F}}=10\right.$ to 30 ns )
*The baud rate with external clocking is: Baud Rate $=\frac{1}{16 \times \mathrm{t}_{\mathrm{cCY}}}$


Figure 20. Transmit Timing with External Clock


Figure 21. Receive External Clock Timing


Figure 22. Interrupt and Output Timing

## AC CHARACTERISTICS

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

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Cycle Time | $\mathrm{t}_{\mathrm{crc}}$ | 1.0 | 40 | 0.5 | 40 | $\mu \mathrm{s}$ |
| Ø2 Pulse Width | $\mathrm{t}_{\mathrm{c}}$ | 400 | - | 200 | - | ns |
| Address Set-Up Time | $t_{\text {AC }}$ | 120 | - | 70 | - | ns |
| Address Hold Time | $t_{\text {caH }}$ | 0 | - | 0 | - | ns |
| R/W Set-Up Time | $\mathrm{t}_{\text {wc }}$ | 120 | - | 70 | - | ns |
| R/W Hold Time | $\mathrm{t}_{\text {cWH }}$ | 0 | - | 0 | - | ns |
| Data Bus Set-Up Time | $\mathrm{t}_{\text {dCW }}$ | 150 | - | 60 | - | ns |
| Data Bus Hold Time | $\mathrm{t}_{\mathrm{HW}}$ | 20 | - | 20 | - | ns |
| Read Access Time (Valid Data) | $t_{\text {cDR }}$ | - | 200 | - | 150 | ns |
| Read Hold Time | $\mathrm{t}_{\mathrm{HR}}$ | 20 | - | 20 | - | ns |
| Bus Active Time (Invalid Data) | $\mathrm{t}_{\text {cDA }}$ | 40 | - | 40 | - | ns |

Notes: 1. $V_{C C}=5.0 \mathrm{~V} \pm 5 \%$.
2. $T_{A}=T_{L}$ to $T_{H}$.
3. $t_{R}$ and $t_{F}=10$ to 30 ns .
4. DO-D7 load capacitance $=130 \mathrm{pF}$.


WRITE TIMING DIAGRAM


READ TIMING CHARACTERISTICS

## ABSOLUTE MAXIMUM RATINGS

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

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

## OPERATING CONDITIONS

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

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min | Typ | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage Except XTLI and XTLO XTLI and XTLO | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{aligned} & 2.0 \\ & 2.4 \end{aligned}$ | - | $\begin{aligned} & \mathrm{v}_{\mathrm{cc}} \\ & \mathrm{~V}_{\mathrm{cc}} \end{aligned}$ | V |  |
| Input Low Voltage Except XTLI and XTLO XTLI and XTLO | $\mathrm{V}_{\text {IL }}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{ss}} \\ & \mathrm{~V}_{\mathrm{ss}} \\ & \hline \end{aligned}$ | - | 0.8 0.4 | v |  |
| Input Leakage Current $\emptyset 2$, RIW, $\overline{\text { RES }}, \mathrm{CSO}, \mathrm{CS} 1, R S O, R S 1, \overline{C T S}, R \times D, \overline{D C D}, \overline{D S R}$ | $\mathrm{I}_{\text {IN }}$ | - | - | 2.5 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V} \text { to } 5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for High Impedance (Three State Off) D0-D7 | $I_{\text {TSI }}$ | - | $\pm 2$ | $\pm 10.0$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage D0-D7, TxD, RxC, $\overline{R T S}$, $\overline{D T R}$ | $\mathrm{V}_{\text {OH }}$ | 2.4 | - | - | V | $\begin{aligned} & I_{\text {LOAD }}=-100 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \end{aligned}$ |
| Output Low Voltage D0-D7, TxD, RxC, $\overline{R T S}, \overline{D T R}, \overline{\mathrm{RQ}}$ | $\mathrm{V}_{\text {OL }}$ | - | - | 0.4 | V | $\begin{aligned} & V_{C C}=4.75 \mathrm{~V} \\ & I_{\text {LOAD }}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Cürrent (Sourcing) D0-D7, TxD, RxC, $\overline{R T S}, \overline{D T R}$ | $\mathrm{IOH}^{\text {O}}$ | -100 | - | - | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ |
| Output Low Current (Sinking) D0-D7, TxD, RxC, RTS, $\overline{D T R}, \overline{I R Q}$ | 1 OL | 1.6 | - | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Output Leakage Current (off state) $\overline{\text { IRQ }}$ | loff | - | - | 10.0 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5 \mathrm{~V}$ |
| Clock Capacitance (ø2) | $\mathrm{C}_{\text {cLK }}$ | - | - | 20 | pF |  |
| Input Capacitance except $\emptyset 2$ | $\mathrm{C}_{\text {IN }}$ | - | - | 10 | pF | $\begin{aligned} & V_{I N}=0 V \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | Cout | - | - | 10 | pF | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| Power Dissipation | $P_{\text {D }}$ | - | 170 | 300 | mW | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |

## PACKAGE DIMENSIONS



PRELIMINARY

## DESCRIPTION

The R6565 Double-Density Floppy Disk Controller (DDFDC) interfaces up to four floppy disk drives to a $6500 / 6800$ micro-processor-based system. The DDFDC simplifies the system design by minimizing both the number of external hardware components and software steps needed to implement the floppy disk drive (FDD) interface. Control signals supplied by the DDFDC reduce the number of components required in external phase locked loop and write precompensation circuitry. Memory-mapped registers containing commands, status and data simplify the software interface. Built-in functions reduce the software overhead needed to control the FDD interface. The DDFDC supports both the IBM 3740 Single-Density (FM) and IBM System 34 DoubleDensity (MFM) formats.

The DDFDC interfaces directly to the 6500/6800 synchronous microprocessor bus and operates with 8 -bit byte length data transferred on the bus. The DDFDC will operate in either DMA or nonDMA mode. In DMA mode, the CPU need only load the command into the DDFDC and all data transfers occur under DMA control. The R6565 is directly compatible with the MC6844 Direct Memory Access Controller (DMAC). In non-DMA mode, the DDFDC generates an interrupt to the CPU indicating that a byte of data is available.

Controller commands, command or device status, and data are transferred between the DDFDC and the CPU via six internal registers. The Main Status Register (MSR) stores the DDFDC status information while four additional status registers provide result information to the CPU following each controller command. The Data Register (DR) stores actual disk data, parameters, controller commands and FDD status information for use by the CPU.

The R6565 executes 15 separate multi-byte commands:

Read Data<br>Write Data<br>Read Deleted Data<br>Write Deleted Data<br>Read a Track<br>Read ID<br>Seek<br>Specify<br>Format a Track<br>Scan Equal<br>Scan High or Equal<br>Scan Low or Equal<br>Sense Interrupt Status<br>Sense Drive Status<br>Recalibrate (Restore to Track 0)

## FEATURES

- Address mark detection circuitry
- Software control of
-Track stepping rate
-Head load time
-Head unload time
- IBM compatible in both single- and double-density recording formats
- Programmable data record lengths: 128, 256, 512, 1024, 2048, 4096 or 8192 bytes/sector
- Multi-sector and multi-track transfer capability
- Controls up to four floppy disk drives
- Data scan capability-will scan a single sector or an entire track of data fields, comparing on a byte-by-byte basis data in the processor's memory with data read from the disk
- Data transfers in DMA or non-DMA mode
- Parallel seek operations on up to four drives
- Directly compatible with 6500 and 6800 synchronous microprocessor bus
- Single phase 8 MHz Clock
- Single +5 Volt Power Supply


## ORDERING INFORMATION

| Part Number R6565 | CLK Frequency <br> 8 MHz | Temperature Range $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| :---: | :---: | :---: |
| R6565 | age: <br> = Ceramic <br> $=$ Plastic |  |



## PIN DESCRIPTION

Throughout this document signals are presented using the terms active and inactive, or asserted and negated, independent of whether the signal is active in the high-voltage state or low-voltage state. (The active state of each logic pin is described below.) Active low signals are denoted by a superscript bar.

## BUS INTERFACE

D0-D7-Data Lines. The bidirectional data lines transfer data between the DDFDC and the 8 -bit data bus.

CLK-CLOCK. The clock is a TTL compatible 8 MHz square wave signal.

RES-RESET. This active low input places the DDFDC in the idle state and resets the output lines to the floppy disk drive (FDD) to the low state.
$\overline{\mathrm{CS}}$-Chip Select. The DDFDC is selected when the $\overline{\mathrm{CS}}$ input is low.

RS-Data/Status Register Select. This input selects the Data or Status Register for reading from or writing to. When RS = high, the Data Register is selected and the state of $R \bar{W}$ determines determines whether it is a read ( $R \bar{W}=$ high $)$ or a write $(R \bar{W}=$ low $)$ operation. When RS = low, the Status Register is selected. This register may only be read $(\mathrm{R} / \overline{\mathrm{W}}=$ high $)$; the state $\mathrm{R} / \overline{\mathrm{W}}=$ low is invalid when the Status Register is selected.
$\overline{\text { IRQ }}$-Interrupt Request. This active low output is the interrupt request generated by the DDFDC to the CPU.

R/W-Read/Write. This input defines the data bus transfer as a read or write cycle. When high (read), the data transfer is from the DDFDC to the data bus. When low (write), the data transfer is from the data bus to the DDFDC.

02-Enable. This input is the synchronous handshake line for the information transfer on the R6500 processor bus. This input signal is the standard enable signal commonly called 02 in R6500 peripheral devices or Enable in 6800 peripheral devices.

## DIRECT MEMORY ACCESS CONTROLLER (DMAC) INTERFACE

DACK-DMA Acknowledge. The DMA transfer acknowledge signal is a TTL compatible input generated by the DMA controller (DMAC) controlling the DDFDC. The DMA cycle is active when DACK is low and the DDFDC is performing a DMA transfer.

TXRQ-DMA Request. The transfer request signal is a TTL compatible output generated by the DDFDC to request a data transfer operation under control of the DMAC (in the DMA mode). The request is active when TXRQ $=$ high. The signal is reset inactive when DMA Acknowledge (DACK) is asserted (low).

DONE-DMA Transfer Complete. This input signal is issued to the DDFDC when the DMA transfer for a channel is complete. The signal is active low concurrent with the DACK input when the DMA operation is complete as a result of that transfer.

## FDD SERIAL DATA INTERFACE

RDD-Read Data. Read Data input from the floppy disk drive (FDD) containing clock and data bits.

RDW-Read Data Window. Data Window input generated by the Phase Locked Loop (PLL) and used to sample data from the FDD.

VCO-Variable Frequency Oscillator Sync. This output signal inhibits the VCO in the PLL circuit when low and enables the VCO in the PLL circuit when high. This inhibits RDD and RDW from being generated until valid data is detected from the FDD.

WCK-Write Clock. This input clock determines the Write Data rate to the FDD. The data rate is 500 KHz in the FM mode (MFM $=$ low) and 1 MHz in the MFM mode (MFM = high). The pulse width is 250 ns (typical) in both modes.

WDA-Write Data. Serial write data output to the FDD containing both clock and data bits.

WE-Write Enable. This output signal enables the Write Data into the FDD when high.

PSO-PS1—Preshift. These outputs are encoded to convey write compensation status during the MFM mode to determine early, late or normal times as follows:

| Write Precompensation Status | Preshift Outputs |  |
| :---: | :---: | :---: |
|  | PS0 | PS1 |
| Normal | 0 | 0 |
| Late | 0 | 1 |
| Early | 1 | 0 |
| Invalid | 1 | 1 |
| $0=$ Low, $1=$ High |  |  |

## FDD STATUS INTERFACE

RDY-Ready. An active high input signal indicates the FDD is ready to send data to, or receive data from, the DDFDC.

IDX-Index. An active high input signal from the FDD indicates the index hole is under the index sensor. Index is used to synchronize DDFDC timing.
$\overline{R W} / S E E K$-Read Write/Seek. Mode selection signal to the FDD which controls the multiplexer from the multiplexed signals. When RW/SEEK is low, the Read/Write mode is commanded; when $\overline{R W} /$ SEEK is high, the Seek mode is commanded.

| RW/SEEK | Mode | Active FDD Interface Signals |
| :---: | :---: | :---: |
| Low | Read/Write | WP, FLT, LCT, FR |
| High | Seek | TS, TRKO, DIR, STP |

WP/TS-Write Protect/Two Side. An active high multiplexed input signal from the FDD. In the Read/Write mode, WP/TS high indicates the media is write-protected. In the Seek mode, WP/TS high indicates the media is two-sided.

FLT/TRKO—Fault/Track Zero. An active high multiplexed input from the FDD. In the Read/Write mode (RW/SEEK = low), FLT/TRKO high indicates an FDD fault. In the Seek mode, FLT/TRKO high indicates that the read/write head is positioned over track zero.

LCT/DIR-Low Current/Direction. A multiplexed output to the FDD. In the Read/Write mode, LCT/DIR is low when the read/write head is to be positioned over the inner tracks and the LCT/DIR is high when the head is to be positioned over the outer tracks. In the Seek mode, LCT/DIR controls the head direction. When LCT/DIR is high, the head steps to the outside of the disk; when LCT/DIR is low, the head steps to the inside of the disk.

FR/STP—Fault Reset/Step. A multiplexed output to the FDD. In the Read/Write mode, FR/STP high resets the fault indicator in the FDD. An FR pulse is issued at the beginning of each read or write command prior to issuing HDL. In the Seek mode, FR/STP provides the step pulses to move the read/write head to another track in the direction indicated by the LCT/DIR signal.

HDL-Head Load. An active high output to notify the FDD that the read/write head should be loaded (placed in contact with the media). A low level indicates the head should be unloaded.

HD-Head Select. An output to the FDD to select the proper read/write head. Head One is selected when HD = high and Head Zero is selected when HD = low.


R6565 DDFDC Pin Diagram

US0-US1—Unit Select. Output signals for floppy disk drive selection as follows:

| Unit Select |  | Floppy Disk <br> Drive Select |
| :---: | :---: | :---: |
| USO | US1 |  |
| 0 | 0 | 1 |
| 0 | 1 | 2 |
| 1 | 0 | 3 |
| 1 | 1 |  |
| $0=$ Low, $1=$ High |  |  |

MFM-MFM Mode. Output signal to the FDD to indicate MFM or FM mode. Selects the MFM mode when MFM = high and the FM mode when MFM = low.

VCC-Power. +5 V dc.
GND-Ground ( $\mathbf{V}_{\mathbf{S S}}$ ).

## DDFDC REGISTERS

The DDFDC contains six registers which may be accessed by the processor or DMA controller via the system (i.e., microprocessor) bus: a Main Status Register, a Data Register, and four Result Status Registers. The 8-bit Main Status Register (MSR) contains the status information of the DDFDC, and may be accessed at any time. The 8-bit Data Register, consisting of several registers in a stack with only one register presented to the data bus at a time, stores data, commands, parameters and FDD status information. Bytes of data are read out of, or written into, the Data Register in order to initiate a command or to obtain the results of a command execution.

The read-only Main Status Register facilitates the transfer of data between the system and the DDFDC. The other Status Registers (ST0, ST1, ST2 and ST3) are only available during the result phase, and may be read only after completing a command. The particular command which has been executed determines how many of the Status Registers will be read.


Figure 2. DDFDC Block Diagram

The relationship between the status/data registers and the $\mathrm{R} / \overline{\mathrm{W}}$ and RS signals is shown below.

| RS | $\mathbf{R} / \overline{\mathbf{W}}$ | Function |
| :---: | :---: | :--- |
| 0 | 1 | Read Main Status Register |
| 0 | 0 | Illegal |
| 1 | 1 | Read from Data Register |
| 1 | 0 | Write into Data Register |
| $0=$ Low, $1=$ High |  |  |

Table 1 shows each of the status registers used by the DDFDC and each bit assignment within the individual registers. Table 2 defines the symbols used throughout the command definitions. Each register bit symbol is defined in the register descriptions that follow Table 2.

## REGISTER DEFINITIONS

## Main Status Register, (MSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RQM | DIO | EXM | CB | D3B | D2B | D1B | DOB |

The Main Status Register (MSR) contains the status information of the DDFDC, and must be read by the processor before each byte is written to, or read from, the Data Register during the command or result phase. MSR reads are not required during the execution phase. The Data Input/Output (DIO) and Request for Master (RQM) bits in the MSR indicate when data is ready and in which direction data will be transferred on the data bus. The maximum time between the last $R \bar{W}$ during command or result phases and the DIO and RQM getting set or reset is $12 \mu \mathrm{~s}$. For this reason, every time the MSR is read the processor should wait $12 \mu \mathrm{~s}$. The maximum time from the end of the last read in the result phase to when bit 4 (DDFDC Busy) goes low is also $12 \mu \mathrm{~s}$.

The DIO and RQM timing chart is shown in Figure 3.

## MSR

$$
\begin{array}{ll}
\frac{7}{0} & \text { RQM } \\
\text { Data Register is not ready. } \\
1 & \text { Data Register is ready. }
\end{array}
$$

## MSR

$\frac{6}{0}$ DIO Data Input/Output.
1 Data transfer is from system to the Data Register.
Data transfer is from Data Register to the system.

## MSR

5 EXM -Execution Mode. (Non-DMA mode only).
$\overline{0}$ Execution phase ended, result phase begun.
1 Execution phase started.

## MSR

4 CB -Controller (DDFDC) Busy.
$\overline{0} \quad$ DDFDC is not busy, will accept a command.
1 DDFDC is busy, will not accept a command.

## MSR

3 D3B -Floppy Disk Drive (FDD) 3 Busy. FDD 3 is not busy, DDFDC will accept read or write command.
1 FDD 3 is busy, DDFDC will not accept read or write command.

## MSR

2 D2B -FDD 2 Busy.
0 FDD 2 is not busy, DDFDC will accept read or write command.
1 FDD 2 is busy, DDFDC will not accept read or write command.

## MSR

1 D1B -FDD 1 Busy.
$\overline{0} \quad$ FDD 1 is not busy, DDFDC will accept read or write command.
1 FDD 1 is busy, DDFDC will not accept read or write command.

## MSR

0 DOB -FDD 0 Busy.
FDD 0 is not busy, DDFDC will accept read or write command.
1 FDD 0 is busy, DDFDC will not accept read or write command.

## Status Register 0 (STO)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IC |  | SE | $E C$ | $N R$ | $H D$ | US |  |
|  |  |  |  |  |  |  |  |

The Status Register 0 (STO) as well as the other status registers (ST1-ST3), are available only during the result phase, and may be read only after completing a command. The particular command executed determines which status registers are used and may be read.

## STO

$\frac{7}{6}-1 C \quad$ Interrupt Code.
$\overline{0} \quad \overline{0} \quad$ Normal Termination (NT). Command was properly executed and completed.
01 Abnormal Termination (AT). Command execution was started, but was not successfully completed.
10 Invalid Command (IC). Received command was invalid.
11 Abnormal Termination (AT). The Ready (RDY) signal from the FDD changed state during command execution.

## STO

5 SE -Seek End.
${ }_{0}$ Seek command is not completed.
1 Seek command completed by DDFDC.

## STO

4 EC -Equipment Check.
$\overline{0} \quad$ No error.
1 Either a fault signal is received from the FDD or the track 0 signal failed to occur after 256 step pulses (Recalibrate Command).

Table 1. DDFDC Status Register Bit Assignments

Main Status Register (MSR)
Status Register 0 (STO)
Status Register 1 (ST1)
Status Register 2 (ST2)
Status Register 3 (ST3)

| Bit Number |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| RQM | DIO | EXM | CB | D3B | D2B | D1B | DOB |
| IC |  | SE | EC | NR | HD | US |  |
|  |  |  |  | US1 | USO |  |  |
| EN | 0 | DE | OR | 0 | ND | NW | MA |
| 0 | CM | DD | WT | SH | SN | BT | MD |
| FLT | WP | RDY | TRKO | TS | HD | US1 | USO |

Table 2. Command Symbol Description

| Symbol | Name | Description |
| :---: | :---: | :---: |
| D | Data | The data pattern which is going to be written into a sector. |
| D0-D7 | Data Bus | 8 -bit data bus, where D0 is the least significant data line and D7 is the most significant data line. |
| DTL | Data Length | When N is defined as 00, DTL is the number of data bytes to read from or write into the sector. |
| EOT | End of Track | The final sector number on a track. During read or write operation, the DDFDC stops data transfer after reading from or writing to the sector equal to EOT. |
| GPL | Gap Length | The length of Gap 3. During read/write commands this value determines the number of bytes that the VCO will stay low after two CRC bytes. During the Format a Track command it determines the size of Gap 3. |
| H | Head Address | Head number 0 or 1, as specified in ID field. |
| HD (H) | Head | A selected head number 0 or 1 which controls the polarity of pin 27. ( $H=H D$ in all command words). |
| HLT | Head Load Time | The head load time in the FDD (2 to 254 ms in 2 ms increments). |
| HUT | Head Unload Time | The head unload time after a read or write operation has occurred ( 16 to 240 ms in 16 ms increments). |
| MF | FM or MFM Mode | When MF $=0$, FM mode is selected; and when MF $=1, \mathrm{MFM}$ mode is selected. |
| MT | Multi-Track | When $M T=1$, a multi-track operation is to be performed. After finishing a read/write operation on side 0 , the DDFDC will automatically start searching for sector 1 on side 1 . |
| N | Bytes/Sector | The number of data bytes written in a sector. |
| ND | Non-DMA Mode | When $\mathrm{ND}=1$, operation is in the Non-DMA mode; when ND $=0$, operation is in the DMA mode. |
| NTN | New Track Number | A new track number, which will be reached as a result of the Seek command. Desired head position. |
| PTN | Present Track Number | The track number at the completion of Sense Interrupt Status command. Present head position. |
| R | Record (Sector) | The sector number to be read or written. |
| RS | Register Select | Controls selection of Main Status Register (RS = low) or Data Register (RS = high). |
| R/W | Read/Write | Either read (R) or write ( $W$ ) signal. |
| ST | Sectors/Track | The number of sectors per track. |
| SK | Skip | Skip Deleted Data Address Mark. |
| SRT | Step Rate Time | The stepping rate for the FDD ( 1 to 16 ms in 1 ms increments). Stepping rate applies to all drives ( $F=1 \mathrm{~ms}, E=2 \mathrm{~ms}$, etc.) |
| $\begin{aligned} & \hline \text { STO } \\ & \text { ST1 } \\ & \text { ST2 } \\ & \text { ST3 } \end{aligned}$ | Status 0 <br> Status 1 <br> Status 2 <br> Status 3 | Four registers which store the status information after a command has been executed. This information is available during the result phase after command execution. These registers should not be confused with the Main Status Register (selected by RS = low). STO-ST3 may be read only after a command has been executed and contain information relevant to that particular command. |
| STP | Sector Test Process | During a Scan command, if STP $=01$, the data in contiguous sectors is compared byte by byte with data sent from the processor (or DMA controller); and if STP $=02$, then alternate sectors are read and compared. |
| T | Track Number | The current/selected track number of the medium (0-255). |
| USO,US1 | Unit Select | A selected drive number (0-3). |

```
STO
    NR -Not Ready.
    FDD is ready.
    1 FDD is not ready at issue of read or write command. If
    a read or write command is issued to side 1 of a single-
    sided drive, this bit is also set.
```

```
STO
    HD -Head Address. (At Interrupt).
    Head Select 0.
    Head Select 1.
```

STO
10 US -Unit Select. (At Interrupt).
0 FDD 0 selected.
01 FDD 1 selected.
10 FDD 2 selected.
11 FDD 3 selected.

Status Register 1 (ST1)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $E N$ | 0 | $D E$ | OR | 0 | $N D$ | $N W$ | $M A$ |

## ST1

$\mathbf{7}$ EN -End of Track.
$\mathbf{0} \quad$ No error.
1
DDFDC attempted to access a sector beyond the last
sector of a track.

## ST1

$6 \quad$-Not Used. Always Zero.
ST1
5 DE -Data Error
$\overline{0}$ No error.

1 DDFDC detected a CRC error in ID field or the Data field.

## ST1

4 OR -Over Run.
$\overline{0}$ No error.
1 DDFDC was not serviced by the system during data transfers, within a predetermined time interval.

## ST1

$3 \quad$-Not Used. Always Zero.

## ST1

ND -No Data.
No error.
13 possible errors.

1. DDFDC cannot find sector specified in ID Register during execution of Read Data, Write Deleted Data or Scan commands.
2. DDFDC cannot read ID field without an error during Read ID command.
3. DDFDC cannot find starting sector during execution of Read a Track command.
```
ST1
    NW -Not Writable.
        No error.
        DDFDC detected a write protect signal from FDD during execution of Write Data, Write Deleted Data or Format a Track commands.
```

ST1
MA -Missing Address Mark.
No error.
2 possible errors.

1. DDFDC cannot detect the ID Address Mark after encountering the index hole twice.
2. DDFDC cannot detect the Data Address Mark or Deleted Data Address Mark. The MD (Missing Address Mark in Data field) of Status Register 2 is also set.

Status Register 2 (ST2)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | CM | DD | WT | SH | SN | BT | MD |

```
ST2
    7 -Not Used. Always Zero.
ST2
    6 CM -Control Mark.
        No error.
- 1 DDFDC encountered a sector which contained a Deleted
        Data Address Mark during execution of a Read Data,
        Read a Track, or Scan command, or which contained a
        Data Address Mark during execution of a Read Deleted
        Data command.
ST2
    5 DD -Data Error in Data Field.
        No error.
    1 DDFDC detected a CRC error in the Data field.
ST2
    WT -Wrong Track.
        No error.
    Contents of T on the disk is different from that stored in
        IDR. Bit is related to ND (Bit 2) of Status Register 1.
ST2
    SH -Scan Equal Hit.
        No "equal" condition during a scan command.
    1. "Equal" condition satisfied during a scan command.
ST2
    SN -Scan Not Satisfied.
        No error.
1 DDFDC cannot find a sector on the track which meets
        the scan command condition.
```

5 DD Data Error in Data Field.
1 DDFDC detected a CRC error in the Data field.
ST2
4 WT -Wrong Track.
1 Contents of $T$ on the disk is different from that stored in IDR. Bit is related to ND (Bit 2) of Status Register 1.

ST2
3 SH -Scan Equal Hit.
No "equal" condition during a scan command.
1 "Equal" condition satisfied during a scan command.
ST2
2 SN -Scan Not Satisfied.
0 No error.
1 DDFDC cannot find a sector on the track which meets the scan command condition.

## ST2

1 BT -Bad Track.
No error.
Contents of $T$ on the disk is different from that stored in
the IDR and $T=F F$. Bit is related to ND (Bit 2) of Status
Register 1.

ST2
0 MD —Missing Address Mark in Data Field.
0 No error.
1 DDFDC cannot find a Data Address Mark or Deleted Data Address Mark during a data read from the disk.

## Status Register 3 (ST3)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FLT | WP | RDY | TRKO | TS | HD | US1 | USO |

Status Register 3 (ST3) holds the results of the Sense Drive Status command.

## ST3

$$
\begin{array}{ll}
\mathbf{7} & \text { FLT } \\
\frac{\text { Fault (FLT) signal from the FDD is low. }}{0} & \text { Fault (FLT) signal from the FDD is high. } \\
1 & \text { Faut }
\end{array}
$$

## ST3

WP -Write Protect.
Write Protect (WP) signal from the FDD is low.
Write Protect (WP) signal from the FDD is high.
ST3

| $\mathbf{5}$ | RDY $\quad$-Ready. |
| :--- | :---: |
| $\frac{\text { Ready (RDY) signal from the RDD is low. }}{0}$ |  |
| 1 | Ready (RDY) signal from the FDD is high. |

ST3
TRKO -Track 0.
Track 0 (TRKO) signal from the FDD is low.
Track 0 (TRKO) signal is from the FDD is high.
ST3
TS -Two Side.
Two Side (TS) signal from the FDD is low. Two Side (TS) signal from the FDD is high.

ST3
HD -Head Select.
Head Select (HD) signal to the FDD is low. Head Select (HD) signal to the FDD is high.

ST3
1 US1 -Unit Select 1.
Unit Select 1 (US1) signal to the FDD is low. Unit Select 1 (US1) signal to the FDD is high.

ST3
USO -Unit Select 0.
Unit Select 0 (USO) signal to the FDD is low.
Unit Select 0 (US1) signal to the FDD is high.

## COMMAND SEQUENCE

The DDFDC is capable of performing 15 different commands. Each command is initiated by a multi-byte transfer of data from the system. After command execution, the result of the command may be a multi-byte transfer of data back to the system. Because of this multi-byte transfer of information between the DDFDC and the system, each command consists of three phases:

Command Phase-The DDFDC receives all information required to perform a particular operation from the system.

Execution Phase-The DDFDC performs the instructed operation.

Result Phase-After completion of the operation, status and other housekeeping information are made available to the system.

The bytes of data sent to the DDFDC to form a command, and read out of the DDFDC in the result phase, must occur in the order shown for each command sequence. That is, the command code byte must be sent first followed by the other bytes in the specified sequence. All command bytes must be written and all result bytes must be read in each phase. After the last byte of data in the command phase is received by the DDFDC, the execution phase starts. Similarly, when the last byte of data is read out in the result phase, the command is ended and the DDFDC is ready to accept a new command. A command can be terminated by asserting the $\overline{\text { DONE }}$ signal to the DDFDC. This ensures that the processor can always get the DDFDC's attention even if the command in process hangs up in an abnormal manner.

## COMMAND DESCRIPTION

## READ DATA

A command set of nine bytes places the DDFDC into the Read Data mode. After the Read Data command has been received the DDFDC loads the head (if it is unloaded), waits the specified Head Settling Time (defined in the Specify command), then begins reading ID Address Marks and ID fields from the disk. When the current sector number ( R ) stored in the ID Register (IDR) matches the sector number read from the disk, the DDFDC transfers data from the disk Data field to the data bus.

After completion of the read operation from the current sector, the DDFDC increments the Sector Number (R) by one, and the data from the next sector is read and output to the data bus. This continuous read function is called a "Multi-Sector Read Operation." The Read command terminates after reading the last data byte from sector $R$ when $R=$ EOT. STO bits 7 and 6 are set to 0 and 1 , respectively, and ST1 bit 7 (EN) is set to a 1.

The Read Data command can also be terminated by a low $\overline{\mathrm{DONE}}$ signal. DONE should be issued at the same time that the DACK for the last byte of data is sent. Upon receipt of DONE, the DDFDC stops outputting data to the data bus, but continues to read data from the current sector, checks CRC (Cyclic Redundancy Count) bytes, and then at the end of that sector terminates the Read Data command and sets bits 7 and 6 in STO to 0 . The amount of data
which can be handled with a single command to the DDFDC depends upon MT (Multi-Track), MF (MFM/FM), and N (Number of Bytes/Sector) values. Table 3 shows the transfer capacity.

The multi-track function (MT) allows the DDFDC to read data from both sides of the disk. For a particular track, data is transferred starting at sector 1 , side 0 and completed at sector L, side 1 (sector $\mathrm{L}=$ last sector on the side). This function pertains to only one track (the same track) on each side of the disk.

When $N=0$ in command byte 6 (FM mode), the Data Length (DTL) in command byte 9 defines the data length that the DDFDC must treat as a sector. If DTL is smaller than the actual data length in a sector, the data beyond the DTL is not sent to the data bus. The DDFDC reads (internally) the complete sector, performs the CRC check, and depending upon the manner of command termination, may perform a multi-sector Read operation. When $N$ is non-zero (MFM mode), DTL has no meaning and should be set to FF.

At the completion of the Read Data command, the head is not unloaded until the Head Unload Time (HUT) interval defined in the Specify command has elapsed. The head settling time may be avoided between subsequent reads if the processor issues another command before the head unloads. This time savings is considerable when disk contents are copied from one drive to another.

If the DDFDC detects the Index Hole twice in succession without finding the right sector (indicated in R), then the DDFDC sets the No Data (ND) flag in Status Register 1 (ST1) to a 1, sets Status Register 0 (STO) bits 7 and 6 to 0 and 1, respectively, and terminates the Read Data command.

After reading the ID and Data fields in each sector, the DDFDC checks the CRC bytes. If a read error is detected (incorrect CRC in ID field), the DDFDC sets the Data Error (DE) flag in ST1 to a 1, sets the Data Error in Data Field (DD) flag in ST2 to a 1 if a CRC error occurs in the Data field, sets bits 7 and 6 in STO to 0 and 1 , respectively, and terminates the command.

If the DDFDC reads a Deleted Data Address Mark from the disk, and the Skip Deleted Data Address Mark bit in the first command byte is not set $(S K=0)$, then the DDFDC reads all the data in the sector, sets the Control Mark (CM) flag in ST2 to a 1, and terminates the command. If $S K=1$, the DDFDC skips the sector with the Deleted Data Address Mark and reads the next sector. The CRC bits in the deleted data field are not checked when $S K=1$.

During disk data transfers from the DDFDC to the system, the DDFDC must be serviced by the system within $27 \mu$ s in the FM mode, and within $13 \mu \mathrm{~s}$ in the MFM mode, otherwise the DDFDC sets the Over Run (OR) flag in ST1 to a 1, sets bits 7 and 6 in STO to 0 and 1 , respectively, and terminates the command.

If the processor terminates a read (or write) operation in the DDFDC, then the ID information in the result phase is dependent upon the state of the MT bit in the first command byte and the End of Track (EOT) byte. Table 4 shows the values for Track Number (T), Head Number (H), Sector Number (R), and Number of Data Bytes/Sector ( N ), when the processor terminates the command.

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 0 | 0 | 1 | 1 | 0 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

Table 3. DDFDC Transfer Capacity

| Multi-Track (MT) | MFM/FM (MF) | Bytes/Sector <br> ( N ) | Maximum Transfer Capacity (Bytes/Sector) (Number of Sectors) | Final Sector Read from Disk |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 00 \\ & 01 \end{aligned}$ | $\begin{aligned} & (128)(26)=3,328 \\ & (256)(26)=6,656 \end{aligned}$ | 26 at Side 0 or 26 at Side 1 |
| $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 00 \\ & 01 \end{aligned}$ | $\begin{aligned} & (128)(52)=6,656 \\ & (256)(52)=13,312 \end{aligned}$ | 26 at Side 1 |
| $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 01 \\ & 02 \end{aligned}$ | $\begin{aligned} & (256)(15)=3,840 \\ & (512)(15)=7,680 \end{aligned}$ | 15 at Side 0 or 15 at Side 1 |
| $\begin{array}{r} 1 \\ 1 \end{array}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 01 \\ & 02 \end{aligned}$ | $\begin{aligned} & (256)(30)=7,680 \\ & (512)(30)=15,360 \end{aligned}$ | 15 at Side 1 |
| $0$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 02 \\ & 03 \end{aligned}$ | $\begin{aligned} (512)(8) & =4,096 \\ (1024)(8) & =8,192 \end{aligned}$ | 8 at Side 0 or 8 at Side 1 |
| $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 02 \\ & 03 \end{aligned}$ | $\begin{aligned} (512)(16) & =8,192 \\ (1024)(16) & =16,384 \end{aligned}$ | 8 at Side 1 |

Table 4. DDFDC Command Termination Values

| Command Phase ID |  | Final Sector Transferred to/from Data Bus | Result Phase ID |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Multi- <br> Track (MT) | Head Number (HD) |  | Track Number <br> (T) | Head Number <br> (H) | Sector Number <br> (R) | No. of Data Bytes (N) |
| - 0 | 0 | Less than EOT | NC | NC | R + 1 | NC |
|  | 0 | Equal to EOT | T+1 | NC | 01 | NC |
|  | 1 | Less than EOT | NC | NC | R + 1 | NC |
|  | 1 | Equal to EOT | $T+1$ | NC | 01 | NC |
| 1 | 0 | Less than EOT | NC | NC | $\mathrm{R}+1$ | NC |
|  | 0 | Equal to EOT | NC | LSB | 01 | NC |
|  | 1 | Less than EOT | NC | NC | R + 1 | NC |
|  | 1 | Equal to EOT | T + 1 | LSB | 01 | NC |

## Notes:

1. NC (No Change): The same value as the one at the beginning of command execution.
2. LSB (Least Significant Bit): The least significant bit of H is complemented.

## Result Phase:

| R | 1 | Status Register 0 (ST0) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
|  | 7 | Number of Data Bytes per Sector (N) |

## WRITE DATA

A command set of nine bytes places the DDFDC in the Write Data mode. After the Write Data command has been received the DDFDC loads the head (if it is unloaded), waits the specified Head Settling Time (defined in the Specify command), then begins reading ID fields from the disk. When the four bytes (T, H, R, N) loaded during the command match the four bytes of the ID field from the disk, the DDFDC transfers data from the data bus to the disk Data field.

After writing data into the current sector, the DDFDC increments the sector number ( $R$ ) by one, and writes into the Data field in the next sector. The DDFDC continues this multi-sector write operation until the last byte is written to sector $R$ when $R=E O T$. STO bits 7 and 6 are set to 0 and 1, respectively, and ST1 bit $7(\mathrm{EN})$ is set to a 1 .

The command can also be terminated by a low on $\overline{\mathrm{DONE}}$. If $\overline{\mathrm{DONE}}$ is sent to the DDFDC while writing into the current sector, then the remainder of the Data field is filled with 00 (zeros). In this case, STO bits 7 and 6 are set to 0 and the command is terminated.

The DDFDC reads the ID field of each sector and checks the CRC bytes. If the DDFDC detects a read error (incorrect CRC) in one
of the ID fields, it terminates the Write Cata command, sets the DE flag in ST1 to a 1, and sets bits 7 and 6 in STO to 0 and 1, respectively.

The Write Data command operates in much the same manner as the Read Data command. Refer to the Read Data command for the handling of the following items:

- Transfer Capacity
- End of Track (EN) flag
- No Data (ND) flag
- Head Unload Time (HUT) interval
- ID information when the processor terminates command (see Table 4)
- Definition of Data Length (DTL) when $N=0$ and when $N \neq 0$

In the Write Data mode, data transfers from the data bus to the DDFDC must occur within $27 \mu$ s in the FM mode, and within $13 \mu \mathrm{~s}$ in the MFM mode. If the time interval between data transfers is longer than this, then the DDFDC terminates the Write Data command, sets the Over Run (OR) flag in ST1 to a 1, and sets bits 7 and 6 in STO to 0 and 1, respectively.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | 0 | 0 | 0 | 1 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number ( $T$ ) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT). |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (ST0) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
| 3 | Status Register 2 (ST2) |  |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## WRITE DELETED DATA

The Write Deleted Data command is the same as the Write Data command except a Deleted Data Address Mark is written at the beginning of the Data field instead of the normal Data Address Mark.

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | 0 | 0 | 1 | 0 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
|  | 4 | Track Number (T) |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector(N) |  |

## READ DELETED DATA

The Read Deleted Data command is the same as the Read Data command except that if SK = 0 when the DDFDC detects a Data Address Mark at the beginning of a Data field, it reads all the data in the sector and sets the CM flag in ST2 to a 1, and then terminates the command. If $S K=1$, then the DDFDC skips the sector with the Data Address Mark and reads the next sector.

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 0 | 1 | 1 | 0 | 0 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
|  | 7 | Number of Data Bytes per Sector (N) |

## READ A TRACK

The Read a Track command is similar to the Read Data command except that this is a continuous read operation where all Data fields from each of the sectors on a track are read and transferred to the data bus. Immediately after encountering the Index Hole, the DDFDC starts reading the Data fields as continuous blocks of data. This command terminates when the number of sectors read is equal to EOT. Multi-track operations are not allowed with this command.

If the DDFDC finds an error in the ID or Data CRC check bytes, it continues to read data from the track. The DDFDC compares the ID information read from each sector with the value stored in the IDR, and sets the ND flag in ST1 to a 1 if there is no match.

If the DDFDC does not find an ID Address Mark on the disk after it encounters the Index Hole for the second time it terminates the command, sets the Missing Address Mark (MA) flag in ST1 to a 1, and sets bits 7 and 6 of STO to 0 and 1, respectively.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| w | 1 | 0 | MF | SK | 0 | 0 | 0 | 1 | 0 |
|  | 2 | X | x | X | x | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :---: |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
|  | 4 | Track Number (T) |
|  | 5 | Head Number (H) |
|  | 6 | Sector Number (R) |
|  | 7 | Number of Data Bytes per Sector (N) |

## READ ID

The two-byte Read ID command returns the present position of the read/write head. The DDFDC obtains the value from the first ID field it is able to read, sets bits 7 and 6 in STO to 0 and terminates the command.

If no proper ID Address Mark is found on the disk before the Index Hole is encountered for the second time then the Missing Address Mark (MA) flag in ST1 is set to a 1, and if no data is found then the ND flag in ST1 is also set to a 1 . Bits 7 and 6 in STO are set to 0 and 1 , respectively and the command is terminated.

During this command there is no data transfer between DDFDC and the data bus except during the result phase.

## Command Phase:

| R/W | BYTE | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{W}$ | 1 | 0 | MF | 0 | 0 | 1 | 0 | 1 | 0 |
|  | 2 | X | X | X | X | X | HD | US1 | US0 |

## Result Phase:

| $R$ | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
| 2 | Status Register 1 (ST1) |  |
| 3 | Status Register 2 (ST2) |  |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## FORMAT A TRACK

The six-byte Format a Track command formats an entire track. After the Index Hole is detected, data is written on the disk: Gaps, Address Marks, ID fields and Data fields; all are recorded in either the double-density IBM System 34 format (MF = 1) or the singledensity IBM 3740 format ( $\mathrm{MF}=0$ ). The particular format written is also controlled by the values of Number of Bytes/Sector ( N ), Sectors/Track (ST), Gap Length (GPL) and Data Pattern (D) which are supplied by the processor during the command phase. The Data field is filled with the data pattern stored in D.

The ID field for each sector is supplied by the processor in response to four data requests per sector issued by the DDFDC. The type of data request depends upon the Non-DMA flag (ND) in the Specify command. In the DMA mode ( $\mathrm{ND}=0$ ), the DDFDC asserts the DMA Request (TXRQ) output four times per sector. In the Non-DMA mode (ND = 1), the DDFDC asserts Interrupt Request (IRQ) output four times per sector.

The processor must write one data byte in response to each request, sending (in the consecutive order) the Track Number (T), Head Number (H), Sector Number (R) and Number of Bytes/ Sector (N). This allows the disk to be formatted with nonsequential sector numbers, if desired.

The processor must send new values for $T, H, R$, and $N$ to the DDFDC for each sector on the track. For sequential formatting R is incremented by one after each sector is formatted, thus, $\mathbf{R}$ contains the total numbers of sectors formatted when it is read during the result phase. This incrementing and formatting continues for the whole track until the DDFDC, upon encountering the Index Hole for the second time, terminates the command and sets bits 7 and 6 in STO to 0.

If the Fault (FLT) signal is high from the FDD at the end of a write operation, the DDFDC sets the Equipment Check (EC) flag in STO to a 1, sets bits 7 and 6 of STO to 0 and 1, respectively, and terminates the command. Also, a low (RDY) signal at the beginning of a command execution phase causes bits 7 and 6 of STO to be set to 0 and 1 , respectively.

Table 5 shows the relationship between N, ST, and GPL for various disk and sector sizes.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | MF | 0 | 0 | 1 | 1 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Number of Bytes per Sector ( N ) |  |  |  |  |  |  |  |
|  | 4 | Sectors per Track (ST) |  |  |  |  |  |  |  |
|  | 5 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 6 | Data Pattern (D) |  |  |  |  |  |  |  |

Table 5. Standard Floppy Disk Sector Size Relationship

| Disk Size | Mode | Sector Size Bytes/Sector | No. of Data Bytes/Sector <br> (N) | No. of Sectors/Tracks (ST) | Gap Length (GPL) ${ }^{4}$ |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Read/Write Command ${ }^{1}$ | Format Command ${ }^{2}$ |  |
| 8" | FM | $\begin{array}{r} 128 \\ 256 \\ 512 \\ 1024 \\ 2048 \\ 4096 \end{array}$ | $\begin{aligned} & 00 \\ & 01 \\ & 02 \\ & 03 \\ & 04 \\ & 05 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \mathrm{~A} \\ & 0 \mathrm{~F} \\ & 08 \\ & 04 \\ & 02 \\ & 01 \end{aligned}$ | $\begin{aligned} & \hline 07 \\ & 0 E \\ & 1 B \\ & 47 \\ & C 8 \\ & C 8 \\ & \hline \end{aligned}$ | 1B <br> 2A <br> 3A <br> 8A <br> FF- <br> FF | IBM Disk 1 IBM Disk 2 |
|  | MFM ${ }^{3}$ | $\begin{array}{r} 256 \\ 512 \\ 1024 \\ 2048 \\ 4096 \\ 8192 \end{array}$ | $\begin{aligned} & 01 \\ & 02 \\ & 03 \\ & 04 \\ & 05 \\ & 06 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { 1A } \\ & 0 \mathrm{~F} \\ & 08 \\ & 04 \\ & 02 \\ & 01 \end{aligned}$ | $\begin{aligned} & \hline 0 \mathrm{E} \\ & 1 \mathrm{~B} \\ & 35 \\ & 99 \\ & \mathrm{C} 8 \\ & \mathrm{C} 8 \\ & \hline \end{aligned}$ | $\begin{aligned} & 36 \\ & 54 \\ & 74 \\ & \text { FF } \\ & \text { FF } \\ & \text { FF } \end{aligned}$ | IBM Disk 2D <br> IBM Disk 2D |
| " | FM | $\begin{array}{r} 128 \\ 128 \\ 256 \\ 512 \\ 1024 \\ 2048 \end{array}$ | $\begin{aligned} & 00 \\ & 00 \\ & 01 \\ & 02 \\ & 03 \\ & 04 \end{aligned}$ | $\begin{aligned} & 12 \\ & 10 \\ & 08 \\ & 04 \\ & 02 \\ & 01 \end{aligned}$ | 07 10 18 46 $C 8$ $C 8$ | $\begin{aligned} & \hline 09 \\ & 19 \\ & 30 \\ & 87 \\ & \text { FF } \\ & \text { FF } \end{aligned}$ |  |
| 51/4" | MFM ${ }^{3}$ | $\begin{array}{r} 256 \\ 256 \\ 512 \\ 1024 \\ 2048 \\ 4096 \\ \hline \end{array}$ | $\begin{aligned} & \hline 01 \\ & 01 \\ & 02 \\ & 03 \\ & 04 \\ & 05 \\ & \hline \end{aligned}$ | $\begin{aligned} & 12 \\ & 10 \\ & 08 \\ & 04 \\ & 02 \\ & 01 \end{aligned}$ | $\begin{aligned} & \mathrm{OA} \\ & 20 \\ & 2 \mathrm{~A} \\ & 80 \\ & \mathrm{CB} \\ & \mathrm{CB} \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline 0 C \\ & 32 \\ & 50 \\ & \text { FO } \\ & \text { FF } \\ & \text { FF } \end{aligned}$ |  |

## Notes:

1. Suggested values of GPL in Read or Write Commands to avoid overlapping between Data field and ID field of contiguous sections.
2. Suggested values of GPL in Format a Track command.
3. In MFM mode the DDFDC cannot perform a read/write/format operation with 128 bytes/sector ( $\mathrm{N}=00$ ).
4. Values of ST and GPL are in hexadecimal.

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T)* |  |
| 5 | Head Number (H)* |  |
|  | 6 | Sector Number (R)* |
|  | 7 | Number of Data Bytes per Sector (N)* |
| * The ID information has no meaning in this command. |  |  |

## SCAN COMMANDS

The scan commands compare data read from the disk to data supplied from the data bus. The DDFDC compares the data, and looks for a sector of data which meets the conditions of $D_{\mathrm{FDD}}=$ $D_{\text {BUS }}, D_{\text {FDD }} \leq D_{\text {BUS }}$, or $D_{F D D} \geq D_{\text {BUS }}$ ( $D=$ the data pattern in hexadecimal). A magnitude comparison is performed ( $\mathrm{FF}=$ largest number, $00=$ smallest number). The hexadecimal byte of FF either from the bus or from FDD can be used as a mask byte because it always meets the condition of the compare. After a whole sector of data is compared, if the conditions are not met,
the sector number is incremented $(R+S T P \rightarrow R)$, and the scan operation is continued. The scan operation continues until one of the following events occur: the conditions for scan are met (equal, low or equal, or high or equal), the last sector on the track is reached (EOT), or DONE is received.

If conditions for scan are met, the DDFDC sets the Scan Hit (SH) flag in ST2 to a 1, and terminates the command. If the conditions for scan are not met between the starting sector (as specified by R) and the last sector on the track (EOT), then the DDFDC sets the Scan Not Satisfied (SN) flag in ST2 to a 1, and terminates the command. The receipt of DONE from the processor or DMA controller during the scan operation will cause the DDFDC to complete the comparison of the particular byte which is in process, and then to terminate the command. Table 6 shows the status of bits SH and SN under various conditions of scan.

If SK $=0$ and the DDFDC encounters a Deleted Data Address Mark on one of the sectors, it regards that sector as the last sector of the track, sets the Control Mark (CM) bit in ST2 to a 1 and terminates the command. If $\mathrm{SK}=1$, the DDFDC skips the sector with the Deleted Data Address Mark, sets the CM flag to a 1 in order to show that a Deleted Sector has been encountered, and reads the next sector.

Table 6. Scan Status Codes

| Command | Status Register 2 |  | Comments |
| :---: | :---: | :---: | :---: |
|  | Bit $2=\mathbf{S N}$ | Bit $3=\mathbf{S H}$ |  |
| Scan Equal | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} & D_{\text {FDD }}=D_{\text {Bus }} \\ & D_{\text {FDD }} \neq D_{\text {Bus }} \end{aligned}$ |
| Scan Low or Equal | $\begin{aligned} & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \mathrm{D}_{\mathrm{FDD}}=\mathrm{D}_{\mathrm{BUS}} \\ & \mathrm{D}_{\mathrm{FDD}}<\mathrm{D}_{\mathrm{BuS}} \\ & \mathrm{D}_{\mathrm{FDD}}>\mathrm{D}_{\text {Bus }} \end{aligned}$ |
| Scan High or Equal | $\begin{aligned} & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & D_{\text {FDD }}=D_{\text {Bus }} \\ & D_{\text {FDD }}>D_{\text {Bus }} \\ & D_{\text {FDD }}<D_{\text {Bus }} \end{aligned}$ |

When either the STP sectors are read (contiguous sectors $=01$, or alternate sectors $=02$ ) or MT (Multi-Track) is set, the last sector on the track must be read. For example, if STP $=02, \mathrm{MT}$ $=0$, the sectors are numbered sequentially 1 through 26 , and the scan command starts reading at sector 21 . Sectors 21,23 , and 25 are read, then the next sector (26) is skipped and the Index Hole is encountered before the EOT value of 26 can be read. This results in an abnormal termination of the command. If the EOT had been set at 25 or the scanning started at sector 20, then the scan command would be completed in a normal manner.

During a scan command data is supplied from the data bus for comparison against the data read from the disk. In order to avoid having the Over Run (OR) flag set in ST1, data must be available from the data bus in less than $27 \mu \mathrm{~S}$ (FM mode) or $13 \mu \mathrm{~S}$ (MFM mode). If an OR occurs, the DDFDC terminates the command and sets bits 7 and 6 of STO to 0 and 1, respectively.

The following tables specify the command bytes and describe the result bytes for the three scan commands.

## SCAN EQUAL

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 1 | 0 | 0 | 0 | 1 |
|  | 2 | X | x | X | x | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Sector Test Process (STP) |  |  |  |  |  |  |  |

Result Phase:

| R | 1 | Status Register 0 (STO) |
| :--- | :--- | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
|  | 7 | Number of Data Bytes per Sector (N) |

## SCAN LOW OR EQUAL

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 1 | 1 | 0 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | uso |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Sector Test Process (STP) |  |  |  |  |  |  |  |

Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
|  | 4 | Track Number (T) |
|  | 5 | Head Number (H) |
|  | 6 | Sector Number (R) |
|  | 7 | Number of Data Bytes per Sector (N) |

## SCAN HIGH OR EQUAL

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 1 | 1 | 1 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Sector Test Process (STP) |  |  |  |  |  |  |  |

Result Phase:

| R | 1 | Status Register 0 (ST0) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
|  | 5 | Head Number (H) |
|  | 6 | Sector Number (R) |
|  | 7 | Number of Data Bytes per Sector (N) |

## SEEK

The three-byte Seek command steps the FDD read/write head from track to track. The DDFDC has two independent Present Track Registers for each drive. They are cleared only by the Recalibrate command. The DDFDC compares the Present Track Number (PTN) which is the current head position with the New Track Number (NTN), and if there is a difference, performs the following operation:

> If PTN $<$ NTN: Sets the direction output (LCT/DIR) high and issues step pulses (FR/STP) to the FDD to cause the read/write head to step in.
> If PTN $>$ NTN: Sets the direction output (LCT/DIR) low and issues step pulses to the FDD to cause the read/write head to step out.

The rate at which step pulses are issued is controlled by the Step Rate Time (SRT) in the Specify command. After each step pulse is issued, NTN is compared against PTN. When NTN $=$ PTN, then the Seek End (SE) flag in STO is set to a 1, bits 7 and 6 in STO are set to 0 , and the command is terminated. At this point DDFDC asserts IRQ.

The FDD Busy flag (bit 0-3) in the Main Status Register (MSR) corresponding to the FDD performing the Seek operation is set to a 1 .

After command termination, all FDD Busy bits set are cleared by the Sense Interrupt Status command.

During the command phase of the Seek operation the DDFDC sets the Controller Busy (CB) flag in the MSR to 1; but during the execution phase the CB flag is set to 0 to indicate DDFDC non-busy. While the DDFDC is in the non-busy state, another Seek command may be issued, and in this manner parallel seek operations may be performed on all drives at once.

No command other than Seek will be accepted while the DDFDC is sending step pulses to any FDD. If a different command type is attempted, the DDFDC will set bits 7 and 6 in STO to a 1 and 0 , respectively, to indicate an invalid command.

If the FDD is in a not ready state at the beginning of the command execution phase or during the seek operation, then the DDFDC sets the Not Ready (NR) flag in STO to a 1, sets STO bits 7 and 6 to 0 and 1, respectively, and terminates the command.

If the time to write the three bytes of the Seek command exceeds $150 \mu \mathrm{~s}$, the time between the first two step pulses may be shorter than the Step Rate Time (SRT) defined by the Specify command by as much as 1 ms .

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | 2 | X | X | $\times$ | X | X | 0 | US1 | USO |
|  | 3 | New Track Number (NTN) |  |  |  |  |  |  |  |

Result Phase: None.

## RECALIBRATE

This two-byte command retracts the FDD read/write head to the Track 0 position. The DDFDC clears the contents of the PTN counters, and checks the status of the Track 0 signal from the FDD. As long as the Track 0 signal (TRKO) is low, the direction signal (LCT/DIR) output remains low and step pulses are issued on FR/STP. When TRKO goes high the DDFDC sets the Seek End (SE) flag in STO to a 1 and terminates the command. If the TRKO is still low after 256 step pulses have been issued, the DDFDC sets Seek End (SE) and Equipment Check (EC) flags in STO to 1s, sets bits 7 and 6 of STO to 0 and 1, respectively, and terminates the command.

The ability to do overlap Recalibrate commands to multiple FDDs and the loss of the RDY signal, as described in the Seek command, also applies to the Recalibrate command.

## Command Phase:

| R/W | BYTE | $\mathbf{7}$ | 6 | 5 | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
|  | 2 | X | X | X | X | X | 0 | US 1 | USO |

Result Phase: None.

## SENSE INTERRUPT STATUS

Interrupt Request ( $\overline{\mathrm{IRQ}}$ ) is asserted by the DDFDC when any of the following conditions occur:

1. Upon entering the result phase of:
a. Read Data command
b. Read a Track command
c. Read ID command
d. Read Deleted Data command
e. Write Data command
f. Format a Track command
g. Write Deleted Data command
h. Scan commands
2. Ready (RDY) line from the FDD changes state
3. Seek or Recalibrate command termination
4. During execution phase in the Non-DMA mode
$\overline{\text { IRQ }}$ caused by reasons 1 and 4 above occur during normal command operations and are easily discernible by the processor. During an execution phase in Non-DMA mode, bit 5 in the MSR is set to 1 . Upon entering result phase this bit is set to 0 . Reasons 1 and 4 do not require the Sense Interrupt Status command. The interrupt is cleared by reading or writing data to DDFDC. Interrupts caused by reasons 2 and 3 are identified with the aid of the Sense Interrupt Status command. This command resets $\overline{\mathrm{RQ}}$ and sets/resets bits 5,6 , and 7 of STO to identify the cause of the interrupt. Table 7 defines the seek and interrupt codes.

Neither the Seek or Recalibrate command has a result phase. Therefore, it is mandatory to use the Sense Interrupt Status command after these commands to effectively terminate them and to verify where the head is positioned by checking the Present Track Number (PTN).

Issuing a Sense Interrupt Status command without an interrupt pending is treated as an invalid command.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |

## SPECIFY

The three-byte Specify command sets the initial values for each of the three internal timers. The Head Unload Time (HUT) defines the time from the end of the execution phase of one of the read/write commands to the head unload state. This timer is programmable from 16 to 240 ms in increments of $16 \mathrm{~ms}(1=16 \mathrm{~ms}$, $2=32 \mathrm{~ms}, \ldots \mathrm{~F}=240 \mathrm{~ms}$ ).

The Step Rate Time (SRT) defines the time interval between adjacent step pulses. This timer is programmable from 1 to 16 ms in increments of $1 \mathrm{~ms}(F=1 \mathrm{~ms}, E=2 \mathrm{~ms}, \mathrm{D}=3 \mathrm{~ms}, \ldots .0=16 \mathrm{~ms}$.

The Head Load Time (HLT) defines the time between the Head Load (HDL) signal going high and the start of the read/write operation. This timer is programmable from 2 to 254 ms in increments of $2 \mathrm{~ms}(01=2 \mathrm{~ms}, 02=4 \mathrm{~ms}, 03=6 \mathrm{~ms}, \ldots 7 \mathrm{~F}=254 \mathrm{~ms})$.

The time intervals are a direct function of the clock (CLK on pin 19). Times indicated above are for an 8 MHz clock. If the clock is reduced to 4 MHz (mini-floppy application) then all time intervals are increased by a factor of two.

The choice of DMA or Non-DMA operation is made by the NonDMA mode (ND) bit. When this bit $=1$ the Non-DMA mode is selected, and when ND $=0$ the DMA mode is selected.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| w | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
|  | 2 | SRT |  |  |  | HUT |  |  |  |
|  | 3 | HLT |  |  |  |  |  |  | ND |

SRT - Step Rate Time
HUT-Head Unload Time
HLT - Head Load Time
ND - Non DMA mode
Result Phase: None.

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :--- | :--- | :--- |
|  | 2 | Present Track Number (PTN) |

Table 7. STO Seek and Interrupt Code Definition for Sense Interrupt Status

| Status Register 0 (ST0) Bits |  |  |  |
| :---: | :---: | :---: | :---: |
| Interrupt Code (IC) |  | Seek End (SE) | Cause |
| 7 | 6 | 5 |  |
| 1 | 1 | 0 | RDY line changed state, either polarity |
| 0 | 0 | 1 | Normal termination of Seek or Recalibrate command |
| 0 | 1 | 1 | Abnormal termination of Seek or Recalibrate command |

## SENSE DRIVE STATUS

This two-byte command obtains and reports the status of the FDDs. Status Register 3 (ST3) is returned in the result phase and contains the drive status.

## Command Phase:

| R/W | BYTE | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{W} \mathrm{W}$ | $\mathbf{1}$ | $\mathbf{0}$ | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
|  | $\mathbf{2}$ | X | X | X | X | X | HD | US1 | US0 |

## Result Phase:

| $R$ | 1 | Status Register 3 (ST3) |
| :---: | :---: | :--- |

## INVALID COMMAND

If an invalid command (i.e., a command not previously defined) is received by the DDFDC, then the DDFDC terminates the command after setting bits 7 and 6 of STO to 1 and 0 , respectively. The DDFDC does not generate an interrupt during this condition. Bits 6 and 7 (DIO and RQM) in the MSR are both set to a 1 indicating to the processor that the DDFDC is in the result phase and that STO must be read. A hex 80 in STO indicates that an invalid command was received.

A Sense Interrupt Status command must be sent after a Seek or Recalibrate interrupt, otherwise the DDFDC considers the next command to be an invalid command.

In some applications the user may wish to use this command as a No-Op command, to place the DDFDC in a standby or no operation state.

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $W$ | 1 | Invalid Codes |  |  |  |  |  |  |  |

## Result Phase:

| $R$ | 1 | Status Register $0(S T O)=80$ |
| :---: | :--- | :--- |

## PROCESSOR INTERFACE

During the command or result phases, the Main Status Register (MSR) must be read by the processor before each byte of information is transferred to, or from, the DDFDC Data Register. After each byte of data is written to, or read from, the Data Register, the processor should wait $12 \mu$ s before reading the MSR. Bits 6 and 7 in the MSR must be a 0 and 1, respectively, before each command byte can be written to the DDFDC. During the result phase, bits 6 and 7 of the MSR must both be 1s prior to reading each byte from the Data Register onto the data bus. Note that this status reading of bits 6 and 7 of the MSR before each byte transfer to and from the DDFDC is required in only the command and result phases and not during the execution ohase.

During the result phase all bytes shown in the result phase must be read by the processor. The Read Data command, for example, has seven bytes of data in the result phase. All seven bytes must be read to successfully complete the Read Data command. The DDFDC will not accept a new command until all seven bytes have been read. Other commands may require fewer bytes to be read during the result phase.

## INTERRUPT REQUEST MODE

During the execution phase, the MSR need not be read. The receipt of each data byte from the FDD is indicated by $\overline{\mathrm{RQ}}$ low on pin 18. When the DDFDC is in Non-DMA mode, $\overline{\mathbb{R Q}}$ is asserted during the execution phase. When the DDFDC is in the DMA mode, the $\overline{\mathrm{IRQ}}$ is asserted at the result phase. The $\overline{\mathrm{IRQ}}$ signal is reset by a read ( $R / \bar{W}$ high) or write ( $R / \bar{W}$ low) of data to the DDFDC. A further explanation of the $\overline{\mathrm{RQ}}$ signal is described in the Sense Interrupt Status command on page 16. If the system cannot handle interrupts fast enough (within $13 \mu \mathrm{~s}$ for MFM mode or $27 \mu \mathrm{~s}$ for FM mode), it should poll bit 7 (RQM) in the MSR. In this case, RQM in the MSR functions as an Interrupt Request (IRQ). If the RQM bit is not set, the Over Run (OR) flag in ST1 will be set to a 1 and bits 7 and 6 of STO will be set to a 0 and 1, respectively.

## DMA MODE

When the DDFDC is in the DMA mode (ND = 0 in the third command byte of the Specify command), TXRQ (DMA Request) is asserted during the execution phase (rather than $\overline{\mathrm{RQ}}$ ) to request the transfer of a data byte between the data bus and the DDFDC.

During a read command, the DDFDC asserts TXRQ as each byte of data is available to be read. The DMA controller responds to this request with $\overline{\text { DACK }}$ low (DMA Acknowledge) and R/ $\bar{W}$ high (read). When DACK goes low the DMA Request is reset (TXRQ low). After the execution phase has been completed ( $\overline{\mathrm{DONE}}$ low or the EOT sector is read), $\overline{\mathrm{RQ}}$ is asserted to indicate the start of the result phase. When the first byte of data is read during the result phase, $\overline{I R Q}$ is reset high.

During a write command, the DDFDC asserts TXRQ as each byte of data is required. The DMA controller responds to this request with $\overline{\text { DACK }}$ low (DMA Acknowledge) and R $\bar{W}$ low (write). When DACK goes low the DMA Request is reset (TXRQ low). After the execution phase has been completed ( $\overline{\mathrm{DONE}}$ low or the EOT sector is written), $\overline{\mathrm{RQ}}$ is asserted. This signals the beginning of the result phase. When the first byte of data is read during the result phase, the $\overline{\mathrm{RQ}}$ is reset high.

## FDD POLLING

After the Specify command has been received by the DDFDC, the Unit Select lines (US0 and US1) begin the polling mode. Between commands (and between step pulses in the Seek Command) the DDFDC polls all the FDD's looking for a change in the RDY line from any of the drives. If the RDY line changes state (usually due to the door opening or closing) then the DDFDC asserts $\overline{\mathrm{IRQ}}$. When Status Register 0 (STO) is read (after Sense Interrupt Status command is issued), Not Ready (NR =1) will be indicated. The polling of the RDY line by the DDFDC occurs continuously between commands, thus notifying the processor which drives are on- or off-line. Each drive is polled every 1.024 ms except during read/write commands.


Figure 3. DDFDC and System Data Transfer Timing



Figure 5. Clock Timing


Figure 6. Read Cycle Timing


Figure 7. Write Cycle Timing


Figure 8. DMA Operation Timing


Figure 9. FDD Write Operation Timing


NOTE:
EITHER POLARITY DATA WINDOW IS VALID

Figure 10. FDD Read Operation Timing


Figure 11. Seek Operation Timing


Figure 12. Fault Reset Timing


Figure 14. $\overline{\text { DONE Timing }}$


Figure 13. Index Timing


Figure 15. $\overline{R E S E T}$ Timing


INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC "1" AND 0.45 V FOR A LOGIC " 0 :" TIMING MEASUREMENTS ARE MADE AT 2.0V FOR A LOGIC " 1 " AND $0.8 V$ FOR A LOGIC " 0 :"


CLOCKS ARE DRIVEN AT 3.OV FOR A LOGIC "1" AND 0.3V FOR A LOGIC " 0 :" TIMING MEASUREMENTS ARE MADE AT 2.4V FOR A LOGIC " 1 " AND 0.65 V FOR A LOGIC " 0 :'

Figure 16. AC Timing Measurement Conditions

## AC CHARACTERISTICS

$\left(V_{\text {cC }}=5.0 \mathrm{Vdc} \pm 5 \%, V_{s s}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}$ )


## ABSOLUTE MAXIMUM RATINGS*

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

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

## OPERATING CONDITIONS

| Parameter | Range |
| :---: | :---: |
| $V_{\text {cC }}$ Power Supply | $5.0 \mathrm{~V} \pm 5 \%$ |
| Operating Temperature | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min | Max | Unit | Test Conditions |
| :--- | :---: | :---: | :---: | :---: | :---: |
| Input Low Voltage <br> Logic <br> CLK and WCK | $\mathrm{V}_{\mathrm{IL}}$ | -0.5 | 0.8 | V |  |
| Input High Voltage <br> Logic <br> CLK and WCK | $\mathrm{V}_{\mathrm{IH}}$ | -0.5 | 0.65 |  |  |
| Output Low Voltage | 2.0 | $\mathrm{V}_{\mathrm{CC}}+0.5$ <br> $\mathrm{~V}_{\mathrm{CC}}+0.5$ | V |  |  |
| Output High Voltage | $\mathrm{V}_{\mathrm{OL}}$ |  | 0.45 | V | $\mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{CC}}$ Supply Current | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | $\mathrm{~V}_{\mathrm{CC}}$ | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| Input Load Current <br> All Inputs | $\mathrm{I}_{\mathrm{CC}}$ |  | 150 | mA | $\mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| High Level Output Leakage Current | $\mathrm{I}_{\mathrm{LOH}}$ |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ |
| Low Level Output Leakage Current | $\mathrm{I}_{\mathrm{LOL}}$ |  | -10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V}$ |
| Internal Power Dissipation |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}$ to $5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V}$ <br> $\mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}}$ |  |

## CAPACITANCE

$\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz} ; \mathrm{V}_{\mathrm{CC}}=\mathrm{OV}\right.$ )

| Parameter | Symbol | Max Limit | Unit |
| :--- | :---: | :---: | :---: |
| Clock Input | $\mathrm{C}_{\mathrm{IN}_{\mathrm{N}}(0)}$ | 20 | pF |
| Input | $\mathrm{C}_{\mathrm{IN}}$ | 10 | pF |
| Output | $\mathrm{C}_{\text {OUT }}$ | 20 | pF |

Note: All pins except pin under test tied to ground.

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



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

## 40-PIN PLASTIC DIP



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

## INTRODUCTION

The Rockwell R6592 is a single-chip printer controller for eight different EPSON* dot-matrix impact printers, models 210, 220, 240, 511L, 512, 522, 541L, and 542. The R6592 offers the flexibility to support any of these models with a minimum of circuitry. Generation of 96 standard ASCII upper and lower case characters and 6 special characters is provided. In addition, up to 10 ASCII control commands are accepted, depending upon the printer. Logic is included in the R6592 to print up to 26 columns on the 210,220 , and 240 models, and up to 40 columns on the 511L, 512 $522,541 \mathrm{~L}$ and 542 models.

Input data may be selected to be in the RS-232 serial format with selectable baud rate from 50 to 7200 bits/second or the parallel format. External circuitry is required to convert RS-232 logic levels to R6592 interface logic levels. An external latch may be required for the R6592 to sample parallel data. If both selectable serial and parallel data interface capability is desired, two external multiplexers are required; one to combine four serial baud select lines and four parallel data interface lines into four R6592 input lines and the other to combine two serial data/control lines and two parallel control lines into two other R6592 input lines.
*EPSON is a trade name of Shinshu Seiki Co., Ltd., a member of the Seiko Group. EPSON printers are distributed in the United States by C. Itoh Electronics, Inc. The R6592 meets the printer specifications listed in this data sheet.

## FEATURES

- Controls EPSON Dot-Matrix Impact Printers:

| Model 210 | Model 512 |
| :--- | :--- |
| Model 220 | Model 522 |
| Model 240 | Model 541L |
| Model 511L | 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)


R6592 Pin Configuration


## R6592 Interface Diagram

## INTERFACE SIGNALS

## PRINTER SOLENOID 1 (ㅍS1) <br> PRINTER SOLENOID 2 (PS2) <br> PRINTER SOLENOID 3 (PS3) <br> PRINTER SOLENOID 4 (PS4) <br> PRINTER SOLENOID 5 (PS5) <br> PRINTER SOLENOID 6 (PS6)

Active low output signals used to command seven constant current print head solenoid drivers. When low, the respective solenoid will be energized to print a dot; and when high, the solenoid will be de-energized to not print a dot. Each solenoid line corresponds to a dot position on the seven row print head. Line $\overline{\mathrm{PS}}$ corresponds to the top 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 { PCLI }}$ )
PRINTER CONTROL LINE 2 (PCL2) PRINTER CONTROL LINE 3 (PCL3)

Active low output control lines used to issue various nonprint 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 | PCL1 |  |  |
| :--- | :--- | :--- | :--- |
|  | PCL2 |  | 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 and Cut Paper |
| 541 Laper | NA | Paper Feed | Paper Release |
| 542 | NA | Paper Feed | Paper Release |

TIMING (TIM)
RESET LEFT ( $\overline{\mathrm{RL}} / \mathrm{RL}$ )
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{\mathrm{RL}}$ ) and are active high for the 200 series (RL). The printer timing and reset lines are assigned as follows:

| Printer Model | R6592 Signal |  |  |
| :---: | :---: | :---: | :---: |
|  | TIM | $\overline{\text { RL/RL }}$ | $\overline{\mathbf{R R}}$ |
| 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}}$ ) | $\begin{aligned} & \text { Reset Signal R-R } \\ & (\overline{\mathrm{RR}}) \end{aligned}$ |
| 522 | Timing Signal | Reset Signal R-L (RL) | Reset Signal R-R ( $\overline{\mathrm{RR}})$ |
| 541L | Timing Signal | 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 (MDS)

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 200 series must additionally provide motor braking.

PRINTER MODEL 1 ( $\overline{\text { PM1 } 1) ~}$
PRINTER MODEL 2 (PM2)
PRINTER MODEL 3 (포3)
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 |
| 210 | 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 (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 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 low (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 (DL1/BR1) <br> DATA LINE 2/BAUD RATE 2 (DL2/BR2) <br> DATA LINE 3/BAUD RATE 3 (DL3/BR3) <br> DATA LINE 4/BAUD RATE 4 (DLi/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 parallel 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 ASCII 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 (DL5)
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 (IP)/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 INPUT PRIME ( $\overline{\mathrm{IP}}$ ). When $\overline{\mathrm{P}} / \mathrm{DSR}$ is high, the R6592 issues prints commands to the printer in a normal fashion. When IP/DSR is low, the R6592 will disable printing. Thiṣ 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}})$ /RECEIVED SERIAL DATA ( $\overline{\text { RSD }})$

Input line multiplexed between a parallel communications control line (DATA STROBE) and the serial communications data line (RECEIVED SERIAL DATA).

If the parallel data transfer mode is selected (SER SEL = low), this line is assigned to the DATA STROBE (DS). 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 RECEIVED SERIAL DATA (RSD). The data is processed in accordance with the selected baud rate. The data must by 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 (DATA 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 DATA TERMINAL READY (ㅁTR). 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{\text { DTR }}$ is switched high during character print and while non-print commands are being processed.

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

Active low output signal used to inform the parallel data transmitter that an input character has been received. $\overline{A C K}$ 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.

## PRIMARAY POWER (VCC)

R6592 primary power supply: $+5 \mathrm{~V} \pm 10 \%$. Supplies power to $\mathrm{CPU}, \mathrm{I} / \mathrm{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 (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

| 20 㗊品 㗊㗊 别品 㗊品 | 21 㗊㗊 品 趷品 品㗊 |  |  |  |  |  | $\begin{aligned} & 27 \\ & \text { 㗊品 } \\ & \text { 噳 } \\ & \text { 㗊品 } \\ & \text { 㗊品 } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 28 㗊品㗊 㗊㗊 品品品 |  |  |  | 2C 㗊㗊 品㗊 品㗊品 品 | 2D品品品 00000 0000潞品 |  |  |
|  | $\begin{aligned} & 31 \\ & \text { 枵㗊 } \\ & \text { 㗊品 } \\ & \text { 品品 } \\ & \text { 品 } \end{aligned}$ |  |  |  |  |  |  |
|  |  | $3 A$品品品㯭䎁品品㨐 $\qquad$ | 3B 㗊㗊 品㗊 品㗊 㗊品 |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |
|  |  |  |  | 5C 聐品品 品品 品品 品品 |  |  | $5 F$吅品 ם品别品 ㅁorg gogng |
|  |  |  |  |  |  |  |  |
|  |  |  |  |  |  | 6 E品品品 － 0008 880 |  |
|  |  |  |  |  |  |  |  |
|  | 79 09090吅品品品品 － |  |  |  |  | 7E吅口ロロ 080碞哭品 |  |

Special 6 Character 5x7 Matrix Dot Patterns


## R6592 Internal Data Format for 7-Bit ASCII Table Character Look-Up



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 | Q | a | q |
| 2 | 0010 |  | DC2 | , | 2 | B | R | b |  |
| 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 | $g$ | w |
| 8 | 1000 |  | CAN | $($ | 8 | H | X | h | $x$ |
| 9 | 1001 |  |  | ) | 9 | 1 | Y | i | y |
| A | 1010 | LF | $¥$ | * | : | J | z | j | $z$ |
| B | 1011 | VT | t | + | ; | K | [ | k | \{ |
| C | 1100 | FF | $1{ }_{2}$ |  | $<$ | L | 1 | 1 | \| |
| D | 1101 | CR | ${ }_{\square}$ | - | $=$ | M | 1 | m | \} |
| E | 1110 |  | $\mathrm{N}_{\mathrm{T}}$ |  | > | N | 1 | n | $\sim$ |
| F | 1111 |  | $\begin{aligned} & T \\ & X \end{aligned}$ | / | ? | 0 | - | 0 | DEL |
| LF - Line Feed <br> CAN - Cancel <br> VT - Vertical Tabulation <br> ¥ - Yen <br> FF - Form Feed <br> t - Pound <br> CR - Carriage Return <br> © - Cent <br> DC1 - Device Control 1 <br> $1_{2}$-One-Half <br> DC2 - Device Control 2 <br> DC3 - Device Control 3 <br> $\mathrm{N}_{\mathrm{T}}$ - No Tax <br> DC4 - Device Control 4 <br> X 4 Tax |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |

Note: Valid control commands are dependent upon printer model.


## PARALLEL DATA TIMING




## SERIAL DATA TIMING

## DATA SET READY (DSR)



SERIAL DETECT ENABLE (DET ENA)


SERIAL CLOCK (SER CLK)


RECEIVED SERIAL DATA (RSD)


## PRINTER INTERFACE SPECIFICATIONS

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

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

## ABSOLUTE MAXIMUM RATINGS*

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

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

## STATIC DC CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{~V} \pm 10 \%\right)$

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

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

## PACKAGE DIMENSIONS



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

# R65560 <br> MULTI-PROTOCOL COMMUNICATIONS CONTROLLER (MPCC) 

PRELIMINARY

## DESCRIPTION

The R65560 Multi-Protocol Communications Controller (MPCC) interfaces a single serial communications channel to a $6500 /$ 6800 microcomputer-based system using either asynchronous or synchronous protocol. High speed bit rate, automatic formatting, low overhead programming, eight character buffering, and two channel DMA interface optimize MPCC performance to take full advantage of the $6500 / 6800$ processing capabilities.

In synchronous operation, the MPCC supports bit-oriented protocols (BOP), such as SDLC/HDLC, and character-oriented protocols (COP), such as IBM Bisync (BSC) in either ASCII or EBCDIC coding. Formatting, synchronizing, validation and error detection is performed automatically in accordance with protocol requirements and selected options. Asynchronous (ASYNC) and isochronous (ISOC) modes are also supported. In addition, modem interface handshake signals are available for general use.

Control, status and data are transferred between the MPCC and the microcomputer bus via 19 directly addressable registers and a DMA interface. Two first-in first-out (FIFO) registers, addressable through separate receiver and transmitter data registers, each buffer up to eight characters at a time to allow more CPU/ MPU processing time to service data received or to be transmitted and to maximize bus throughput, especially during DMA operation. The two-channel Direct Memory Access (DMA) interface operates with the MC6844 DMA Controller.

An on-chip oscillator drives the internal baud rate generator (BRG) and an external clock output with an 8 MHz input crystal or clock frequency. The BRG, in conjunction with two selectable prescalers and 16-bit programmable divisor, provides a data bit rate of DC to 4 MHz .

## ORDERING INFORMATION

| Part Number | Frequency | Temperature Range |
| :---: | :---: | :---: |
| $\mathrm{R}^{65560}$ | 4 MHz | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
|  | $\begin{aligned} & C=\text { Ceramic } \\ & P=\text { Plastic } \end{aligned}$ |  |

## FEATURES

- Full duplex synchronous/asynchronous receiver and transmitter
- Fully implements IBM Binary Synchronous Communications (BSC) in two coding formats: ASCII and EBCDIC
- Supports other synchronous character-oriented protocols (COP), such as six-bit BSC, X3.28, ISO IS1745, ECMA-16, etc.
- Supports synchronous bit-oriented protocols (BOP), such as SDLC, HDLC, X.25, etc.
- Asynchronous and isochronous modes
- Modem handshake interface
- High speed serial data rate (DC to 4 MHz )
- Internal oscillator and Baud Rate Generator (BRG) with programmable data rate
- Crystal or TTL level clock input and buffered clock output ( 8 MHz )
- Direct interface to $6500 / 6800$ microprocessor bus
- Eight-character receiver and transmitter buffer registers
- 19 directly addressable registers for flexible option selection, complete status reporting, and data transfer
- Maskable interrupt conditions for receiver, transmitter and serial interface
- Programmable microprocessor bus data transfer: polled, interrupt and two-channel DMA transfer compatible with MC6844
- Clock control register for receiver clock divisor and receiver and transmitter clock routing
- Selectable full/half duplex, autoecho and local loop-back modes
- Selectable parity (enable, odd, even) and CRC (control field enable, CRC-16, CCITT V.41,, VRC/LRC)


Figure 1. MPCC Block Diagram

## PIN DESCRIPTION

Throughout the document, signals are presented using the terms active and inactive or asserted and negated independent of whether the signal is active in the high-voltage state or lowvoltage state. (The active state of each logic pin is described below.) Active low signals are denoted by a superscript bar. R/W indicates a write is active low and a read active high.

A0 - A4-Address Lines. A0 - A4 are active high inputs used in conjunction with the $\overline{\mathrm{CS}}$ input to access the internal registers. The address map for these registers is shown in Table 1.

D0 - D7-Data Lines. The bidirectional data lines transfer data between the MPCC and the CPU, memory or other peripheral device. The data bus is tri-stated when $\overline{C S}$ is inactive. (See exceptions in DMA mode.)
$\overline{\mathbf{C S}}$-Chip Select. $\overline{\mathrm{CS}}$ low selects the MPCC for programmed transfers with the host. The MPCC is deselected when the $\overline{C S}$ input is inactive in non-DMA mode.
$\mathbf{R} / \bar{W}$-Read/Write. $\mathbf{R} / \bar{W}$ controls the direction of data flow through the bidirectional data bus by indicating that the current bus cycle is a read (high) or write (low) cycle.

02-Phase 2. During a write ( $R \bar{W}$ low), the $\emptyset 2$ negative transition latches data on data bus lines DO-D7 into the MPCC. During a read ( $\mathrm{R} / \overline{\mathrm{W}}), \emptyset 2$ high enables data from the MPCC to data bus

IRQ-Interrupt Request. The active low $\overline{\mathrm{RQ}}$ output requests interrupt service by the CPU. $\overline{\mathrm{RQ}}$ is driven high after assertion prior to being tri-stated.

TDSR-Transmitter Data Service Request. When Transmitter DMA mode is active, the low TDSR output requests DMA service.

RDSR-Receiver Data Service Request. When receiver DMA mode is active, the low RDSR output requests DMA service.
$\overline{\text { DACK }}$-DMA Acknowledge. The $\overline{\text { DACK }}$ low input indicates that that the data bus has been acquired by the DMAC and that the requested bus cycle is beginning.

DTS—DMA Transfer Strobe. The $\overline{\text { DTS }}$ low input causes a DMA transfer to occur on the next $\emptyset 2$ cycle. When $R \bar{W}$ is high, data is transferred into the TxFIFO; when R $\bar{W}$ is low, data is transferred from the RxFIFO.
$\overline{\text { DONE -Done. }} \overline{\text { DONE }}$ is a bidirectional active low signal. The DONE signal is asserted by the DMAC when the DMA transfer count is exhausted and there is no more data to be transferred. $\overline{\text { DONE }}$ will also be asserted by the MPCC, if enabled by bit 5 in the RCR, when the status byte folloiwng the last character of a frame (block) is being transferred in response to a RDSR. The $\overline{\text { DONE }}$ signal asserted by the DMAC in response to a TDSR will be stored to track with the data byte through the TxFIFO.
$\overline{R E S}-R e s e t . \overline{R E S}$ is an active low; high impedance input that initializes all MPCC functions. $\overline{\text { RES }}$ must be asserted for at least 500 ns to initialize the MPCC.

DTR-Data Terminal Ready. The $\overline{\text { DTR }}$ active low output is general purpose in nature, and is controlled by the DTRLVL bit in the Serial Interface Control Register (SICR)
$\overline{\text { RTS}}-$ Request to Send. The $\overline{\operatorname{RTS}}$ active low output is general
$\overline{\text { CTS }}-C l e a r ~ t o ~ S e n d . ~ T h e ~ \overline{C T S}$ active low input positive transiition and level are reported in the CTST and CTSLVL bits in the Serial Interface Status Register (SISR), respectively.


Figure 2. MPCC Input and Output Signals

DSR-Data Set Ready. The $\overline{\mathrm{DSR}}$ active low input negative transition and level are reported in the DSRT and DSRLVL bits in the SISR, respectively. $\overline{\text { DSR }}$ is also an output for RSYN.
$\overline{\mathbf{D C D}}$ —Data Carrier Detect. The $\overline{\mathrm{DCD}}$ active low input positive transition and level are reported in the DCDT and DCDLVL bits in the the SISR, respectively.

TxD-Transmitted Data. The MPCC transmits serial data on the TxD output. The TxD output changes on the negative going edge of TxC.

RxD-Received Data. The MPCC receives serial data on the RxD input. The RxD input is shifted into the receiver with the negative going edge of RxC.

TxC-Transmitter Clock. TxC can be programmed to be an input or an output. When TxC is selected to be an input, the transmitter clock must be provided externally. When TxC is programmed to be an output, a clock is generated by the MPCC's internal baud rate generator: The low-to-high transition of the clock signal nominally indicates the center of a serial data present on the TxD output.

RxC-Receiver Clock. RxC provides the MPCC receiver with received data timing information. The clock transition from low-to-high nominally indicates the center of each serial data bit on the RxD input.

## EXTAL-Crystal/External Clock Input.

XTAL Crystal Return. EXTAL and XTAL connect an 8 MHz external crystal to the MPCC internal oscillator. The pin EXTAL may also be used as a TTL level input to supply a DC to 8 MHz reference timing from an external clock source. XTAL must be tied to ground when applying an external clock to the EXTAL input.

BCLK—Buffered Clock. BCLK is the internal oscillator buffered output available to other MPCC devices eliminating the need for additional crystals.

Vcc-Power. 5V $\pm 5 \%$.
GND-Ground. Ground ( $\mathrm{V}_{\mathrm{SS}}$ ).

## MPCC REGISTERS

Nineteen 8-bit registers define, control and monitor the data communications process. These registers and their access are listed in Table 1.

Table 2 summarizes the MPCC register bit assignments and their access. A read from an unassigned location results in a read from a "null register." A null register returns all ones for data and results in a normal bus cycle. Unused bits of a defined register are read as zeros unless otherwise noted.


R65560

Table 1. R65560 Accessible Registers

| Register(s) | R/W | Addr <br> (Hex.) | Address Lines |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | A4 | A3 | A2 | A1 | A0 |
| 0 |  |  |  |  |  |  |  |
| Receiver Status Register (RSR) | R/W | 00 | 0 | 0 | 0 | 0 | 0 |
| Receiver Control Register (RCR) | R/W | 01 | 0 | 0 | 0 | 0 | 1 |
| Receiver Data Register (RDR) ${ }^{1}$ | R | 02 | 0 | 0 | 0 | 1 | 0 |
| Receiver Interrupt Enable Register (RIER) | R/W | 05 | 0 | 0 | 1 | 0 | 1 |


| Transmitter Statue Register (TSR) | R/W | 08 | 0 | 1 | 0 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Transmitter Control Register (TCR) | R/W | 09 | 0 | 1 | 0 | 0 |
| Transmitter Data Register (TDR) | 1 |  |  |  |  |  |
| Transmitter Interrupt Enable Register (TIER) | W | 0 A | 0 | 1 | 0 | 1 |


| Serial Interface Status Register (SISR) | R/W | 10 | 1 | 0 | 0 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Serial Interface Control Register (SICR) | R/W | 11 | 1 | 0 | 0 | 0 |
| Serial Interrupt Enable Register (SIER) | R/W | 15 | 1 | 0 | 1 | 0 |


| Protocol Select Register 1 (PSR1) | R/W | 18 | 1 | 1 | 0 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Protocol Select Register 2 (PSR2) | R/W | 19 | 1 | 1 | 0 | 0 |
| Address Register 1 (AR1) | R/W | 1 A | 1 | 1 | 0 | 1 |
| Address Register 2 (AR2) | R/W | 1 B | 1 | 1 | 0 | 1 |
| Baud Rate Divider Register 1 (BRDR1) | R/W | 1 1C | 1 | 1 | 1 | 0 |
| Baud Rate Divider Register 2 (BRDR2) | R/W | 1 1D | 1 | 1 | 1 | 0 |
| Clock Control Register (CCR) | R/W | 1E | 1 | 1 | 1 | 1 |
| Error Control Register (ECR) | R/W | 1F | 1 | 1 | 1 | 1 |

## Notes:

1. Accessible register of the eight byte RxFIFO. The data is not initialized, however, $\overline{\text { RES }}$ resets the RxFIFO pointer to the start of the first byte.
2. Accessible register of the eight byte TxFIFO. The data is not initialized, however, $\overline{\text { RES }}$ resets the TxFIFO pointer to the start of the first byte.
3. Reserved registers may contain random bit values.

Table 2. MPCC Register Bit Assignments

| R/W Access | Bit Number |  |  |  |  |  |  |  | Reset** Value |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| R/W | RDA | EOF | 0 | C/PERR | FRERR | ROVRN | RA/B | RIDLE | 00 |
| R/W | 0 | RDSREN | DONEEN | RSYNEN | STRSYN | 2ADCMP | Rabten | RRES | 01 |
| R | RECEIVED DATA (RxFIFO) |  |  |  |  |  |  |  | - - |
| R/W | $\begin{gathered} \text { RDA } \\ \text { IE } \end{gathered}$ | $\begin{gathered} \mathrm{EOF} \\ \mathrm{IE} \end{gathered}$ | 0 | C/PERR IE | FRERR IE | ROVRN IE | $\begin{gathered} \text { RA/B } \\ \text { IE } \end{gathered}$ | 0 | 00 |

Receiver Status Register (RSR)
Receiver Control Register (RCR)
Receiver Data
Register (RDR)
Receiver Interrupt Enable
Register (RIER)

| R/W | TDRA | TFC | 0 | 0 | 0 | TUNRN | TFERR | 0 | 80 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W | TEN | TDSREN | TICS | THW | TLAST | TSYN | TABT | TRES | 01 |
| W | TRANSMITTED DATA (TxFIFO) |  |  |  |  |  |  |  |  |
| R/W | TDRA <br> IE | TFC <br> IE | 0 | 0 | 0 | TUNRN <br> IE | TFERR <br> IE | 0 | 00 |

Transmitter Status
Register (TSR)
Transmitter Control Register (TCR)
Transmitter Data Register (TDR)
Transmitter Interrupt Enable Register (TIER)

| R/W | CTST | DSRT | DCDT | CTSLVL | DSRLVL | DCDLVL | 0 | 0 | 00 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W | RTSLVL | DTRLVL | 0 | 0 | 0 | ECHO | TEST | NRZI | 00 |
| RNW | CTS <br> Serial Interface Status <br> Register (SISR) |  |  |  |  |  |  |  |  |
| Serial Interface <br> Register (SICR) |  |  |  |  |  |  |  |  |  |
| Control |  |  |  |  |  |  |  |  |  |
| Serial Interrupt Enable <br> Register (SIER) |  |  |  |  |  |  |  |  |  |


| R/W | 0 | 0 | 0 | 0 | 0 | 0 | CTLEX | ADDEX | 00 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W | 0 | STOP BIT SEL |  | CHAR LEN SEL |  | PROTOCOL SEL |  |  | 00 |
|  |  | SB2 | SB1 | CL2 | CL1 | PS3 | PS2 | PS1 |  |
| R/W | BOP ADDRESS/BSC \& COP PAD |  |  |  |  |  |  |  | 00 |
| RM | BOP ADDRESS/BSC \& COP SYN |  |  |  |  |  |  |  | 00 |
| R/W | BAUD RATE DIVIDER (LSH) |  |  |  |  |  |  |  | 01 |
| R/W | BAUD RATE DIVIDER (MSH) |  |  |  |  |  |  |  | 00 |
| R/W | 0 | 0 | 0 | PSCDIV | TCLKO | RCLKIN | CLK SEL |  | 00 |
|  |  |  |  |  |  |  | CK2 | CK1 |  |
| R/W | PAREN | ODDPAR | 0 | 0 | CTLCRC | CRCPRE | CRC SEL |  | 04 |
|  |  |  |  |  |  |  | CR2 | CR1 |  |

Protocol Select Register 1 (PSR1)
Protocol Select
Register 2 (PSR2)
Address Register 1 (AR1)
Address Register 2 (AR2)
Baud Rate Divider
Register 1 (BRDR1)
Baud Rate Divider Register 2 (BRDR2)
Clock Control
Register (CCR)
Error Control
Register (ECR)

[^4]
## REGISTER DEFINITIONS

## RECEIVER REGISTERS

Receiver Status Register (RSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RDA | EOF | 0 | C/PERR | FRERR | ROVRN | RA/B | RIDLE |

Reset value $=\$ 00$
The Receiver Status Register (RSR) contains the status of the receiver including error conditions. Status bits are cleared by writing a 1 into respective positions, by writing a 1 into the RCR RRES bit or by RES. If an EOF, C/PERR, or FRERR is set in the RSR, the data reflecting the error (the first byte or word in the RxFIFO) must be read prior to resetting the corresponding status bit in the RSR. The IRQ output is asserted if any of the conditions reported by the status bits occur and the corresponding interrupt enable bit in the RIER is set.

The RSR format is the same as the frame status format (see below) except as noted.

| RSR |  |
| :---: | :---: |
| 7 | RDA -Receiver Data Available. (RSR only). |
| 0 | The RxFIFO is empty (i.e., no received data is available). |
| 1 | Received data is available in the RxFIFO and can be read via the RDR. |
| RSR |  |
| 6 | EOF -End of Frame. |
| 0 | No end of frame or block detected. |
| 1 | End of frame or block detected (BOP and BSC). |
| RSR |  |
| 5 | -Not Used. |
| RSR |  |
| 4 | C/PERR -CRC/Parity Error. |
| 0 | No CRC or parity error detected. |
| 1 | CRC error detected (BOP, BSC), Parity error detected (ASYNC, ISOC and COP). |
| RSR |  |
| 3 | FRERR -Frame Error. |
| 0 | No frame error detected. |
| 1 | Short Frame or a closing FLAG detected off boundary (BOP), Frame error (ASYNC, ISOC) or receiver overrun. |

## RSR

## 2 ROVRN -Receiver Overrun.

## $0 \quad$ No receiver overrun detected.

1 Receiver overrun detected. Indicates that receiver data was attempted to be transferred into the RxFIFO when it was full, resulting in loss of received data. The data that is already in RxFIFO are not affected and may be read by the processor.

## RSR

1 RA/B -Receiver Abort/Break.
0 Normal Operation.
1 ABORT detected after an opening flag (BOP), ENQ detected in a block of text data (BSC), or BREAK detected (ASYNC).

RSR
0 RIDLE -Receiver Idle. (RSR only).
Receiver not idle.
15 or more consecutive " 1 ' $s$ " have been received and the receiver is in an inactive idle state.

Frame Status (RSR)

| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | EOF | RHW | C/PERR | FRERR | ROVRN | RA/B | 0 |

For the BSC and BOP protocols which have defined message blocks or frames, a "frame status" byte will be loaded into the RxFIFO following the last data byte of each block (see Figure 3). The EOF status in the RSR is then set when the byte/word containing the frame status is the next byte/word to be read from the RxFIFO.

In the receiver DMA mode, when the EOF status in the RSR is set, DONE is asserted to the DMAC. Thus the last byte accessed by the DMAC is always a status byte, which the processor may read to check the validity of entire frame.

The frame status contains all the status contained within the RSR with the exception of RDA and RIDLE.

| BYTE | D7 |
| :---: | :--- |
| $M$ | DATA |
| $M+1$ | STATUS |
| $M+2$ | NEXT FRAME |

## Figure 3. BSC/BOP Block/Frame Status Location

Receiver Control Register (RCR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | RDSREN | DONEEN | RSYNEN | STRSYN | 2ADCMP | RABEN | RRES |

Reset value $=\$ 01$
The Receiver Control Register (RCR) selects receiver control options.

| $\begin{gathered} \text { RCR } \\ 7 \end{gathered}$ | -Not used. |
| :---: | :---: |
| RCR |  |
| $\underline{6}$ | RDSREN -Receiver Data Service Request Enable. |
| 0 | Disable receiver DMA mode. |
| 1 | Enable receiver DMA mode. |
| RCR |  |
| 5 | DONEEN - $\overline{\text { DONE }}$ Output Enable. |
| 0 | Disable DONE output. |
| 1 | Enable DONE output. (When the receiver is in the DMA mode, i.e., RDSREN $=1$ ). |
| RCR |  |
| 4 | RSYNEN -RSYNEN Output Enable. Selects the DSR signal input or the RSYN SYNC signal output on the $\overline{\mathrm{DSR}}$ pin. |
| 0 | Input DSR on DSR. |
| 1 | Output RSYN on DSR. |
| RCR |  |
| 3 | STRSYN - Strip SYN Character (COP only). |
| 0 | Do not strip SYN character. |
| 1 | Strip SYN character. |
| RCR |  |
| 2 | 2ADCMP -One/Two Address Compare (BOP only). |
| 0 | Compare one address byte with the contents of AR1. |
| 1 | Compare two address bytes with the contents of AR1 and AR2. |

RCR
1 RABTEN -Receiver Abort Enable (BOP only). $\overline{0}$ Do not abort frame upon error detection.
1 Abort frame upon RxFIFO overrun (ROVRN bit $=1$ in the RSR) or CFCRC error detection (C/PERR bit $=1$ in the RSR). If either error occurs, the MPCC ignores the remainder of the current frame and searches for the beginning of the next frame.

RCR 0 RRES -Receiver Reset Command. 0 Enable normal receiver operation.
1 Reset receiver. Resets the receiver section including the RxFIFO and the RSR (but not the RCR). RRES is set by $\overline{\text { RES }}$ or by writing a 1 into this bit for one write cycle and is cleared by writing a 0 into this bit. RRES requires clearing after $\overline{\text { RES }}$.

Receiver Data Register (RDR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB | Received Data (RxFIFO) |  |  |  |  | LSB |  |  |

The receiver has an 8-byte First In First Out (FIFO) register file (RxFIFO) where received data are stored before being transferred to the bus. The received data is transferred out of the RxFIFO via the RDR. When the RxFIFO has a data byte ready to be transferred, the RDA status bit in the RSR is set to 1 .

## Receiver Interrupt Enable Register (RIER)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RDA <br> IE | EOF <br> IE | 0 | C/PERR <br> IE | FRERR <br> IE | ROVRN <br> IE | RA/B <br> IE | - |

Reset value $=\mathbf{\$ 0 0}$
The Receiver Interrupt Enable Register (RIER) contains interrupt enable bits for the Receiver Status Register (RSR). When enabled, the IRQ output is asserted when the corresponding condition is detected and reported in the RSR.

## RIER

| 7 | RDA IE -Receiver Data Available Interrupt Enable. |
| :---: | :---: |
| 0 | Disable RDA Interrupt. |
| 1 | Enable RDA Interrupt. |
| RIER |  |
| 6 | EOF IE -End of Frame Interrupt Enable. |
| 0 | Disable EOF Interrupt. |
| 1 | Enable EOF Interrupt. |
| RIER |  |
| 5 | -Not used. |
| RIER |  |
| 4 | C/PERR IE-CRC/Parity Error Interrupt Enable. |
| 0 | Disable C/PERR Interrupt. |
| 1 | Enable C/PERR Interrupt. |
| RIER |  |
| 3 | FRERR IE -Frame Error Interrupt Enable. |
| 0 | Disable FRERR Interrupt. |
| 1 | Enable FRERR Interrupt. |
| RIER |  |
| 2 | ROVRN IE -Receiver Overrun Interrupt Enable. |
| 0 | Disable ROVRN Interrupt. |
| 1 | Enable ROVRN Interrupt. |

## RIER

$\begin{array}{ll}\mathbf{1} & \text { RA/B IE } \\ \mathbf{0} & \text { Disable RA/B Interrupt. } \\ 1 & \text { Enable RA/B Interrupt. }\end{array}$
RIER
0 -Not used.

## TRANSMITTER REGISTERS

Transmitter Status Register (TSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TDRA | TFC | 0 | 0 | 0 | TUNRN | TFERR | 0 |

Reset value $=\$ 80$

The Transmitter Status Register (TSR) contains the transmitter status including error conditions. The transmitter status bits are cleared by writing a 1 into their respective positions, by writing a 1 into the TCR TRES bit, or by RES. The IRQ output is asserted if any of the conditions reported by the status bits occur and the corresponding interrupt enable bit in the TIER is set.

TSR
$\frac{7}{0}$ TDRA -Transmitter Data Register Available.
1 The TxFIFO is not full (i.e., available) and data to transmit can be loaded via the TDR.

TSR
6 TFC
-Transmitted Frame Complete. (BOP, BSC and COP only).
0 Frame not complete.
1 Closing FLAG or ABORT character has been transmitted (BOP), Trailing PAD has been transmitted (BSC), or the last character of a frame or block as defined by TLAST (TCR bit 3) has been transmitted (COP).

TSR
5-3 -Not used.
TSR
2 TUNRN -Transmitter Underrun (BOP, BSC and COP only). A transmitter underrun occurs when the transmitter runs out of data during a transmission. For BOP, the underrun condition is treated as an abort. For BSC and COP, SYN characters are transmitted until more data is available in the TxFIFO.
0 No transmitter underrun occurred.
1 Transmitter underrun occurred.

## TSR

10 | TFERR |
| :--- |
| No frame error has occurred. | -Transmit Frame Error (BOP only).

Reset value = \$01
The Transmitter Control Register (TCR) selects transmitter control function.

## TCR

$\frac{7}{0}$ TEN -Transmitter Enable.
Disable transmitter. TxD output is idled. The TxFIFO may be loaded while the transmitter is disabled.
1 Enable transmitter.

| 6 | TDSREN | -Transmitter Data Service Request |
| :--- | :---: | :---: |
| Enable. |  |  |

5 TICS -Transmitter Idle Character Select. Selects the idle character to be transmitted when the transmitter is in an active idle mode (transmitter enabled or disabled).
Mark Idle (TxD output is held high).
Content of AR2 (BSC and COP), BREAK condition (ASYNC and ISOC), or FLAG character (BOP).

TCR

4

## TCR

3 TLAST -Transmit Last Character (BOP, BSC and COP only).
0 The next character is not the last character in a frame or block.
1 The next character to be written into the TDR is the last character of the message. The TLAST bit automatically returns to a 0 when the associated word/byte is written to the TxFIFO. If the transmitter DMA mode is enabled, TLAST is set to a 1 by $\overline{\text { DONE }}$ from the DMAC. In this case the character written into the TDR in the current cycle is the last character.

2 TSYN -Transmit SYN (BSC and COP only).
Do not transmit SYN characters.
1 Transmit SYN characters. Causes a pair of SYN characters to be transmitted immediately following the current character. If BSC transparent mode is active, a DLE SYN sequence is transmitted. The TSYN bit automatically returns to a 0 when the SYN character is loaded into the Transmitter Shift Register.

TCR
1 TABT -Transmit ABORT (BOP only).
Enable normal transmitter operation. Causes an abort by sending eight consecutive 1's. A data word/byte must be loaded into the TxFIFO after setting this bit in order to complete the command. The TABT bit clears automatically when the subsequent data word/byte is loaded into the TxFIFO.

TCR
0 TRES -Transmitter Reset Command. Enable normal transmitter operation.
Reset transmitter. Clears the transmitter section including the TxFIFO and the TSR (but not the TCR). The TxD output is held in "Mark" condition. TRES is set by $\overline{R E S}$ or by writing a 1 into this bit for one write cycle and is cleared by writing a 0 into this bit. TRES requires clearing after $\overline{\text { RES }}$.

Transmit Data Register (TDR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB | Transmitted Data (TxFIFO) |  |  |  |  | LSB |  |  |  |

The transmitter has an 8-byte FIFO register file (TxFIFO). Data to be transmitted is transferred from the bus into the TxFIFO via the TDR. The TDRA status bit in the TSR is set to 1 when the TxFIFO is ready to accept another data byte.

Transmitter Interrupt Enable Register (TIER)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TDRA <br> IE | TFC <br> IE | 0 | 0 | 0 | TUNRN <br> IE | TFERR <br> IE | - |

Reset value $=\$ 00$
The Transmitter Interrupt Enable Register (TIER) contains interrupt enable bits for the Transmitter Status Register. When enabled, the $\overline{\mathrm{RQ}}$ output is asserted when the corresponding condition is detected and reported in the TSR.

```
TIER
    7 TDRA IE -Transmitter Data Register (TDR) Avail-
                able Interrupt Enable.
    0 Disable TDRA Interrupt.
    1 Enable TDRA Interrupt.
TIER
    6 TFC IE -Transmit Frame Complete (TFC) Interrupt
        Enable.
    0 Disable TFC Interrupt.
    1 Enable TFC Interrupt.
TIER
    5-3 -Not used.
TIER
    2 TUNRN IE -Transmitter Underrun (TUNRN) Interrupt
                Enable.
    0 Disable TUNRN Interrupt.
    1 Enable TUNRN Interrupt.
TIER
    1 TFERR IE -Transmit Frame Error (TFERR) Interrupt
            Enable.
    0 Disable TFERR Interrupt.
    1 Enable TFERR Interrupt.
TIER
    O -Not used.
-Not used.
```


## SERIAL INTERFACE REGISTERS

Serial Interface Status Register (SISR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CTST | DSRT | DCDT | CTSLVL | DSRLVL | DCDLVL | 0 | 0 |

Reset value $=\$ 00$
The Serial Interface Status Register (SISR) contains the serial interface status information. The transition status bits (CTST, DSRT and DCDT) are cleared by writing a 1 into their respective positions, or by RESET. The level status bits (CTSLVL, DSRLVL and DCDLVL) reflect the state of their respective inputs and cannot be cleared internally. The $\overline{\mathrm{RQ}}$ output is asserted if any of the conditions reported by the transition status bits occur and the corresponding interrupt enable bit in the SIER is set.

## SISR

7 CTST -Clear to Send Transition Status.
1 CTS has transitioned positive (from active to inactive). (TRES must be a zero).
$0 \quad$ CTS has not transitioned positive.

| $\begin{gathered} \text { SISR } \\ 6 \end{gathered}$ | DSRT -Data Set |
| :---: | :---: |
| 1 | $\overline{\text { DSR }}$ has transitioned negativ |
| 0 | DSR has transitioned negative from |
| 0 | DSR has not transitioned negative. |
| SISR |  |
| 5 | DCDT -Data Carrier Detect Tra |
| 1 | $\overline{\overline{D C D}}$ has transitioned positive (from |
| 0 | $\overline{\mathrm{DCD}}$ has not transitioned positive. |
| SISR |  |
| 4 | CTSLVL -Clear to Send Level. |
| 0 | CTS input level is negated (high). |
| 1 | CTS input level is asserted (low). |

## SISR

3 DSRLVL -Data Set Ready Level.
$\overline{0} \quad \overline{\mathrm{DSR}}$ input level is negated (high).
$1 \quad \overline{\mathrm{DSR}}$ input level is asserted (low).
SISR
2 DCDLVL -Data Carrier Detect Level.
$\overline{0} \quad \overline{D C D}$ input level is negated (high).
$1 \quad \overline{D C D}$ input level is asserted (low).

SISR
1-0 $\quad$-Not used.

Serial Interface Control Register (SICR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RTSLVL | DTRLVL | - | - | - | ECHO | TEST | NRZI |

Reset value $=\$ 00$

The Serial Interface Control Register (SICR) controls various serial interface signals and test functions.

SICR
$\frac{7}{0}$ RTSLVL -Request to Send Level.
1
Assert RTS output (low).

## NOTE

In BOP, BSC, or COP, when the RTSLVL bit is cleared in the middle of data transmission, the RTS outputremains asserted until the end of the current frame or block has been transmitted. In ASYNC or ISOC, the RTS output is negated when the TxFIFO is empty. If the transmitter is idling when the RTSLVL bit is reset, the $\overline{\mathrm{RTS}}$ output is negated within two bit times.

SICR
6 DTRLVL -Data Terminal Ready Level.
$0 \quad$ Negate $\overline{\text { DTR }} 0$ output (high).
1 Assert DTR output (low).
SICR
5-3
-Not used. These bits are initialized to 0 by RESET and must not be set to 1.

## SICR

2 ECHO -Echo Mode Enable.

## SICR

1 TEST -Self-test Enable.
$\frac{1}{0}$ Disable self-test (enable normal operation).
1 Enable self-test. The transmitted data (TxD) and clock (TXC) are routed back through to the receiver through RxD and RxC, respectively ( $\overline{\mathrm{DCD}}$ and $\overline{\mathrm{CTS}}$ are ignored). This "loopback"' self-test may be used for all protocols. RxC is external regardless of the state of CCR bit 2 . CCR bit 3 may be a 0 or a 1.

## SICR

0 NRZI -NRZI Data Format Select. Selects the transmit and receive data format to be NRZ or NRZI.
Select NRZ data format. NRZ coding-high = 1 and low $=0$.
Select NRZI data format. The serial data remains in the same state to send a binary 1 and switches to the opposite state to send a binary 0 . A 1 bit delay is added to the TxD output to allow for encoding.

Serial Interrupt Enable Register (SIER)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CTS <br> IE | DSR <br> $I E$ | DCD <br> IE | - | - | - | - | - |

Reset value $=\$ 00$
The Serial Interrupt Enable Register (SIER) contains interrupt enable bits for the Serial Interface Status Register. When an interrupt enable bit is set, the IRQ output is asserted when the corresponding condition occurs as reported in the SISR.

| SIER |  |
| :---: | :---: |
| 7 | CTS IE -Clear to Send (CTS) Interrupt Enable. |
| 0 | Disable CTS Interrupt. |
| 1 | Enable CTS Interrupt. |
| SIER |  |
| 6 | DSR IE -Data Set Ready (DSR) Interrupt Enable. |
| 0 | Disable DSR Interrupt. |
| 1 | Enable DSR Interrupt. |
| SIER |  |
| 5 | DCD IE - Data Carrier Detect (DCD) Interrupt |
| 0 | Disable DCD Interrupt. |
| 1 | Enable DCD Interrupt. |
| SIER |  |
| 4-0 | -Not used. |

## GLOBAL REGISTERS

The global registers contain command information applying to different modes of operation and protocols. After changing global register data, TRES in the TCR and RRES in the RCR should be set then cleared prior to performing normal mode processing.

Protocol Select Register 1 (PSR1)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | CTLEX | ADDEX |

Reset value $=\$ 00$
Protocol Select Register 1 (PSR1) selects BOP protocol related options.

## PSR1

7-2 -Not used.
PSR1
CTLEX -Control Field Extend (BOP only).
Select 8-bit control field.
Select 16-bit control field.
PSR1
0 ADDEX -Address Extend (BOP only).
Disable address extension. All eight bits of the address byte are utilized for addressing.
1 Enable address extension. When bit 0 in the address byte is a 0 the address field is extended by one byte. An exception to the address field extension occurs when the first address byte is all 0 's (null address).

Protocol Select Register 2 (PSR2)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| WD/BYT | STOP BIT SEL |  | CHAR LEN SEL |  | PROTOCOL SEL |  |  |
|  | SB2 | SB1 | CL2 | CL1 | PS3 | PS2 | PS1 |

Reset value $=\$ 00$

Protocol Select Register 2 (PSR2) selects protocols, character size, the number of stop bits, and word/byte mode.

PSR2
$7 \quad$-Not Used. This bit is initialized to 0 by $\overline{\text { RES }}$ and must not be changed to 1 .

PSR2
6-5 STOP BIT SEL -Number of Stop Bits Select. Selects the number of stop bits transmitted at the end of the data bins in ASYNC and ISOC modes.
6
SB2
0
0
1
5
SB1
1
0

| No. of Stop Bits |  |
| :---: | :---: |
| $\frac{\text { ASYNC }}{}$ | $\frac{\text { ISOC }}{1}$ |
| 1 | $1 / 2$ |
| 2 | 2 |
|  | 2 |

## PSR2

4-3 CHAR LEN SEL -Character Length Select. Selects the character length except in BOP and BSC where the character length is always eight bits. Parity is not included in the character length.

| 4 | 3 |  |
| :---: | :---: | :---: |
| $\frac{3}{\text { CL2 }}$ | $\frac{\text { CL1 }}{}$ | $\frac{\text { Character Length }}{}$ |
| 0 | 0 | 5 bits |
| 0 | 1 | 6 bits |
| 1 | 0 | 7 bits |
| 1 | 1 | 8 bits |

PSR2
2-0 PROTOCOL SEL—Protocol Select. Selects protocol and defines the protocol dependent control bits.

| 2 | 1 | 0 |  |
| :--- | :---: | :--- | :--- |
| PS3 | PS2 | PS1 | Protocol |
| 0 | 0 | 0 | BOP (Primary) |
| 0 | 0 | 1 | BOP (Secondary) |
| 0 | 1 | 0 | Reserved |
| 0 | 1 | 1 | COP |
| 1 | 0 | 0 | BSC EBCDIC |
| 1 | 0 | 1 | BSC ASCII |
| 1 | 1 | 0 | ASYNC |
| 1 | 1 | 1 | ISOC |

Address Register 1 (AR1)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BOP ADDRESS/BSC \& COP PAD |  |  |  |  |  |  |  |

Reset value $=\$ 00$

## Address Register 2 (AR2)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| BOP ADDRESS/BSC \& COP SYN |  |  |  |  |  |  |  |

Reset value $=\$ 00$
The protocol selected in PSR2 (BOP, BSC and COP only) determines the function of the two 8-bit Address Registers (AR1 and AR2). As a secondary station in BOP, the contents of the address registers are used for address matching depending on the 2 ADCMP selection in the RCR. In BSC and COP, AR1 and AR2 contain programmable leading PAD and programmable SYN characters, respectively.

| Protocol Selected | 2ADCMP | AR1 | AR2 |
| :---: | :---: | :---: | :---: |
| BOP (Primary) | X | X | X |
| BOP (Secondary) | 0 | Address | X |
|  | 1 | Address | Address |
| BSC EBCDIC | X | Leading PAD | SYN |
| BSC ASCII | X | Leading PAD | SYN |
| COP | X | Leading PAD | SYN |
| * $\mathrm{X}=$ Not used |  |  |  |

Baud Rate Divider Register 1 (BRDR1)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BAUD RATE DIVIDER (LSH) |  |  |  |  |  |  |  |

Reset value $=\$ 01$

Baud Rate Divider Register 2 (BRDR2)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BAUD RATE DIVIDER (MSH) |  |  |  |  |  |  |  |

Reset value $=\$ 00$
The two 8-bit Baud Rate Divider Registers (BRDR1 and BRDR2) hold the divisor of the Baud Rate Divider circuit. BRDR1 contains the least significant half (LSH) and BRDR2 contains the most significant half (MSH), With an 8.064 MHz EXTAL input, standard bit rates can be selected using the combination of Prescaler Divider (in the CCR) and Baud Rate Divider values shown in Table 3. For isochronous or synchronous protocols, the Baud Rate Divider value must be multiplied by two for the same Prescaler Divider value.

The Baud Rate Divider (BRD) value can be computed for other crystal frequency, prescaler divider and desired baud rate values as follows:

$$
\mathrm{BRD}=\frac{\text { Crystal Frequency }}{(\text { Prescaler Divider) (Baud Rate) }(\mathrm{K})}
$$

where: $\quad K=1$ for isochronous or synchronous 2 for asynchronous

## Clock Control Register (CCR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | PSCDIV | TCLKO | RCLKIN | CLK SEL |  |
|  |  |  |  |  |  | CK2 | CK1 |

Reset value $=\$ 00$
The CCR selects various clock options.
CCR
7-5
-Not used.

CCR
4 PSCDIV -Prescaler Divider. The Prescaler Divider network reduces the external/oscillator frequency to a value for use by the internal Baud Rate Generator.
$0 \quad$ Divide by 2.
1 Divide by 3.
CCR
3 TCLKO -Transmitter Clock Output Select.
$\overline{0} \quad$ Select TxC to be an input.
1 Select TxC to be an output.
CCR

## 2 RCLKIN -Receiver Clock Internal Select (ASYNC only). <br> 0 Select External RxC. <br> 1 Select Internal RxC. <br> CCR <br> 1-0 CLK DIV -External Receiver Clock Divider. Selects the divider of the external RxC to determine the receiver data rate.

| CK2 | CK1 | Divider |
| :---: | :---: | :---: |
| 0 | 0 | 1 (ISOC) |
| 0 | 1 | 16 |
| 1 | 0 | 32 |
| 1 | 1 | 64 |

Table 3. Standard Baud Selection (8.064 MHz Crystal)

| Desired Baud Rate (Bit Rate) | Prescaler Divider |  | Baud Rate Divider |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Asynchronous |  |  | Isochronous and Synchronous |  |  |
|  | Decimal Value | PSCDIV$\text { (0 to } 1)$ | Decimal Value | Hexadecimal Value |  | Decimal Value | Hexadecimal Value |  |
|  |  |  |  | $\begin{aligned} & \text { BRDR2 } \\ & \text { (MSH) } \end{aligned}$ | $\begin{aligned} & \text { BRDR1 } \\ & \text { (LSH) } \end{aligned}$ |  | $\begin{aligned} & \text { BRDR2 } \\ & \text { (MSH) } \end{aligned}$ | $\begin{aligned} & \text { BRDR1 } \\ & \text { (LSH) } \end{aligned}$ |
| 50 | 3 | 1 | 26,880 | 69 | 00 | 53,760 | D2 | 00 |
| 75 | 2 | 0 | 26,880 | 69 | 00 | 53,760 | D2 | 00 |
| 110 | 3 | 1 | 12,218 | 2 F | BA | 24,436 | 5 F | 74 |
| 135 | 2 | 0 | 14,933 | 3A | 55 | 29,866 | 74 | AA |
| 150 | 3 | 1 | 8,960 | 23 | 00 | 17,920 | 46 | 00 |
| $300$ | 2 | 0 | 6,720 | 1A | 40 | 13,440 | 34 | 80 |
| - 1200 | 3 | 1 | 1,120 | 04 | 60 | 2,240 | 08 | CO |
| * 1800 | 2 | 0 | 1,120 | 04 | 60 | 2,240 | 08 | Co |
| 2400 | 2 | 0 | 840 | 03 | 48 | 1,680 | 06 | 90 |
| 3600 | 2 | 0 | 560 | 02 | 30 | 1,120 | 04 | 60 |
| 4800 | 3 | 1 | $280$ | 01 | 18 | 560 | 02 | 30 |
| 7200 | 2 | 0 | 280 | 01 | 18 | 560 | 02 | 30 |
| 9600 | 3 | 1 | - 140 | 00 | 8 C | 280 | 01 | 18 |
| 19200 | 3 | 1 | 70 | 00 | 46 | 140 | 00 | 8C |
| 38400 | 3 | 1 | 35 | 00 | 23 | 70 | 00 | + 46 |

Error Control Register (ECR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PAREN | ODDPAR | - | - | CRCCTL | CRCPRE | CRCSEL |  |
|  |  |  |  |  | CR2 | CR1 |  |

Reset value $=\mathbf{\$ 0 4}$
The Error Control Register (ECR) selects the error detection method used by the MPCC.

ECR
1 PAREN -Parity Enable. (ASYNC, ISOC and COP only).
0 Disable parity generation/checking.
1 Enable parity generation/checking.

ECR
6 ODDPAR -Odd/Even Parity Select (Effective only when PAREN =1).
0 Generate/check even parity.
1 Generate/check odd parity.
ECR
5-4 -Not used.

ECR
$\frac{3}{0}$ CFCRC -Control Field CRC Enable.
Disable control field CRC. Enables an intermediate CRC remainder to be appended after the address/control field in transmitted BOP frames and checked in received frames. The CRC generator is reset after control field CRC calculation.

ECR
2 CRCPRE - CRC Generator Preset Select.
$0 \quad$ Preset CRC Generator to 0.
1 Preset CRC Generator to 1 and transmit the 1's complement of the resulting remainder.

ECR
1-0 CRCSEL -CRC Polynomial Select. Selects one of the RC polynominals.

| $\begin{gathered} 1 \\ \text { CR2 } \end{gathered}$ | 0 CR1 | Po |
| :---: | :---: | :---: |
| 0 | 0 | $\mathrm{x}^{16}+\mathrm{x}^{12}+\mathrm{x}^{5}+1$ (CCITT V.41) |
| 0 | 1 | $x^{16}+x^{15}+x^{2}+1$ (CRC-16) |
| 1 | 0 | $x^{8}+1 \quad$ (VRC/LRC)* |
| 1 | 1 | Not used. |

*VRC: Odd-parity check is performed on each character including the LRC character.

## INPUT/OUTPUT FUNCTIONS

## MPU INTERFACE

Transfer of data between the MPCC and the system bus involves the following signals: Address lines AO through A4, Data Bus Lines D0 through D7, and control signals consisting of $R / \bar{W}, \overline{C S}$, and $\emptyset 2$. Figures 10 and 11 show typical interface connections.

## Read/Write Operation

The $\mathrm{R} / \overline{\mathrm{W}}$ input controls the direction of data flow on the data bus. $\overline{\mathrm{CS}}$ (Chip Select) enables the MPCC for access to the internal registers and other operations. When $\overline{\mathrm{CS}}$ is asserted, the data I/O buffer acts as an output driver during a read operation and as an input buffer during a write operation.

When the MPCC is selected (CS low) during a read ( $\mathrm{R} / \overline{\mathrm{W}}$ high), eight bits of register data are placed on data bus lines D0 - D7 when $\emptyset 2$ is asserted. When the MPCC is selected (CS low) for a write ( $R \bar{W}$ low), $\emptyset 2$ strobes data from the DO-D7 data lines into the selected register. Figures 12 and 13 show the read and write timing relationships.

## DMA INTERFACE

The MPCC is capable of providing DMA data transfers up to 2 Mbytes per second when used with the MC68440 DMAC in the single address mode. Based on $4 \mathrm{Mb} / \mathrm{s}$ serial data rate and 5 bits/character, the maximum DMA required transfer rate is 800 Kbytes per second.

The MPCC has separate DMA enable bits for the transmitter and receiver, each of which requires a DMA channel. Both the transmitter and receiver data are implicitly addressed (TDR or RDR) therefore addressing of the data register is not required before data may be transferred. Communication between the MPCC and the DMAC is accomplished by a two-signal request/acknowledge handshake. Since the MPCC has only one acknowledge input ( $\overline{\mathrm{DACK}}$ ) for its two DMA request lines, an external OR function must be provided to combine the two DMA acknowledge signals. The MPCC uses the $R \bar{W}$ input to distinguish between the Transmitter Data Service Request (TDSR acknowledge and the Receiver Data Service Request (RDSR) acknowledge.

## Receiver DMA Mode

The receiver DMA mode is enabled when the RDSREN bit in the RCR is set to 1. When data is available in the RxFIFO, Receiver Data Service Request ( $\overline{\mathrm{RDSR}}$ ) is asserted for one receiver clock period to initiate the MPCC to memory DMA transfer. The next RDSR cycle may be initiated as soon as the current RDSR cycle is completed (i.e., a full sequence of $\overline{\mathrm{DACK}}, 02$, and $\overline{\mathrm{DTS}}$ ).

In response to $\overline{R D S R}$ assertion, the DMAC sets the $\mathrm{R} \overline{\mathrm{W}}$ line to write and asserts the memory address, DMA transfer strobe (DTS), and DMA acknowledge (DACK). The MPCC outputs data from the RxFIFO to the data bus during $\emptyset 2$. The memory latches the data to complete the data transfer. Figure 13 shows the timing relationships for the receiver DMA mode.
$\overline{\text { RDSR }}$ is inhibited when either RDSREN is reset to 0 or RRES is set to 1 (both in the RCR), or when $\overline{\text { RES }}$ is asserted.

## Transmitter DMA Mode

The transmitter DMA mode is enabled when the TDSREN bit in the TCR is set to 1 . When the TxFIFO is available, Transmitter Data Service Request (TDSR) is asserted for one transmitter clock period to initiate the memory to MPCC DMA transfer. The next TDSR cycle may be initiated as soon as the current TDSR cycle is completed.

In the transmitter DMA mode, the TxFIFO is implicitly addressed. That is, when the transfer is from memory to the TxFIFO, only the memory is addressed. In response to TDSR assertion, the DMAC sets the $R \bar{W}$ line to read and asserts the memory address, DMA transfer strobe ( $\overline{\mathrm{DTS}}$ ) and DMA acknowledge ( $\overline{\mathrm{DACK}}$ ). The The memory places data on the data bus and the MPCC loads the data into the TXFIFO to complete the data transfer. A timing diagram for the transmitter DMA mode is shown in Figure 15.
$\overline{\text { TDSR }}$ is inhibited when either TDSREN is reset to 0 or TRES is set to 1 (both in the TCR), or when RES is asserted.

## DONE Signal

When the DMA transfer count is exhausted in transmitter DMA mode, the DMAC asserts DONE which sets the TLAST bit in the TCR to indicate that the last word/byte has been transferred. In the receiver DMA mode, DONE is asserted by the MPCC when the last character of the frame/block is being transferred from the RxFIFO to the data bus if the DONEEN bit is set to a 1 in the RCR.

## INTERRUPTS

There are three possible sources of an interrupt request ( $\overline{\mathrm{IRQ}}$ ): the receiver section (as reported in the RSR), the transmitter section (as reported in the TSR), and the serial interface (as reported in the SISR). When an interrupt generating status occurs and the interrupt is enabled by a corresponding bit in the associated interrupt enable register, $\overline{\mathbb{R Q}}$ is asserted. The inter-! rupt processing software must examine all status registers that have interrupt status bits enabled to determine the cause of the interrupt and perform the required processing to clear the interrupt. $\overline{I R Q}$ will remain asserted until all interrupt causing conditions reported in status registers have been cleared.

## SERIAL INTERFACE

The MPCC is a high speed, high performance device supporting the more popular bit and character oriented data protocols. The lower speed asynchronous (ASYNC) and isochronous (ISOCH) modes are also supported. An on-chip clock oscillator and baud rate generator provide an output data clock at a frequency of DC to 4 MHz . The clock can also be used in the ASYNC mode to provide a receive clock for the incoming data. The serial interface consists of the following signals:

## RTS (Request to Send) Output

The $\overline{\text { RTS }}$ output to the DCE is controlled by the RTSLVL bit in the SICR in conjunction with the state of the transmitter section. When the RTSLVL bit is set to 1 , the RTS output is asserted. When the RTSLVL bit is reset to 0 , the RTS output remains asserted until the TxFIFO becomes empty or the end of the message (or frame), complete with CRC code if any, has been transmitted. $\overline{R T S}$ also is negated when the RTSLVL bit is reset during transmitter idle, or when the RES input is asserted.

## CTS (Clear to Send) Input

The $\overline{\mathrm{CTS}}$ input signal is normally generated by the DCE to indicate whether or not the data set is ready to transmit data. The CTST bit in the SISR reflects the transition status of the CTS input while the CTSLVL bit in the SISR reflects the current level. A positive transition on the $\overline{\mathrm{CTS}}$ pin asserts $\overline{\mathrm{IRQ}}$ if the CTS IE bit in the SIER is set. The $\overline{\mathrm{CTS}}$ input in an inactive state disables the start of transmission.

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

The $\overline{D C D}$ input signal is normally generated by the DCE and indicates that the DCE is receiving a data carrier signal suitable for demodulation. The $\overline{\text { DCDT }}$ bit in the SISR reports the transition status of the $\overline{D C D}$ input while the DCDLVL bit in the SISR contains the current level. A positive transition on the $\overline{D C D}$ pin asserts the $\overline{\mathrm{IRQ}}$ output if the DCD IE bit in the SIER is set. A negated DCD input disables the start of the receiver.

## $\overline{\text { DSR (Data Set Ready) Input/RSYN Output }}$

The $\overline{\mathrm{DSR}}$ input from the DCE indicates the status of the local data set. The DSRT bit in the SISR contains the transition status of the $\overline{\mathrm{DSR}}$ input while the DSRLVL bit in the SISR reports the current level. A negative transition on the $\overline{\mathrm{DSR}}$ pin asserts the $\overline{\mathrm{IRQ}}$ output if the DSR IE bit in the SIER is set.

When the RSYN bit in the RCR is set to 1 , the frame synchronization signal (RSYN) in the receiver is output on the DSR pin. In this mode, $\overline{\text { DSR }}$ output low indicates detection of SYN in BSC or COP, or an address match in BOP.

## DTR (Data Terminal Ready) Output

The $\overline{\text { DTR }}$ output is general purpose in nature and can be used to control switching of the DCE. The DTR output is controlled by the DTRLVL bit in the SICR.

## TXC (Transmitter Clock) Input/Output

The transmitter clock (TxC) may be programmed to be input or an output. When the TCLKO control bit in the CCR is set to a 1 , the TXC pin becomes an output and provides the DCE with a clock whose frequency is determined by the internal baud rate generator. When the TCLKO control bit is reset, TxC is an input and the transmitter shift timing must be provided externally. The TxD output changes state on the negative-going edge of the transmitter clock. In the asynchronous mode when TCLKO $=0$ in the CCR, the TXC input frequency must be two times the desired baud rate.

## TxD (Transmitted Data) Output

The serial data transmitted from the MPCC is coded in NRZ or NRZI (zero complement) data format as selected by the NRZI control bit in the SICR.

## RxC (Receiver Clock) Input

The receiver latches data on the negative transition of the RxC.

## RxD (Received Data) Input

The serial data received by the MPCC can be coded in NRZ or NRZI data format. The MPCC will decode the received data in accordance with the NRZI control bit setting in the SICR.

## Serial Interface Timing

The timing for the serial interface clock and data lines is shown in Figure 16. The MPCC supports high speed synchronous operation. As shown, the TxD output changes with the negativegoing edge of TxC and the received data on RxD is latched on the negative edge of RxC. This assures high speed two-way operation between two MPCCs connected as shown in Figure 18.

For low speed operation between the MPCC and a modem or RS-232C Data Communications Equipment (DCE), an inverter can be used in the TxC output lines as shown in Figure 18. RS-232 and RS-423 (covering serial data interface up to 100 K baud) require that data be centered $\pm 25 \%$ about the negativegoing edge of the RxC. This criteria is met for frequencies up to 1.25 MHz using the inverter. Use of the inverter also allows MPCC to MPCC operation up to 2.17 MHz .

## SERIAL COMMUNICATION MODES AND PROTOCOLS

## ASYNCHRONOUS AND ISOCHRONOUS MODES

Asynchronous and isochronous data are transferred in frames. Each frame consists of a start bit, 5 to 8 data bits plus optional even or odd parity, and $1,11 / 2$, or 2 stop bits. The data character is transmitted with the least significant bit (LSB) first. The data line is normally held high (MARK) between frames, however, a BREAK (minimum of one frame length for which the line is held low) is used for control purposes. Figure 4 illustrates the frame format supported by the MPCC.

## Asynchronous Receive

In the asynchronous (ASYNC) mode, data received on RxD occurs in three phases: (1) detection of the start bit and bit synchronization, (2) character assembly and optional parity check, and (3) stop bit detection. The receiver bit stream may be synchronized by the internal baud rate generator clock or by an external clock on RxC. When RCLKIN in the CCR is set to 0 , an external clock with a frequency of 16,32 , or 64 times the data rate establishes the data bit midpoint and maintains bit synchronization. The character assembly process does not start if the start bit is less than one-half bit time. Framing and parity errors are detected and buffered along with the character on which errors occurred. They are passed on to the RxFIFO and set appropriate status bits in the RSR when the character with an error reaches the last RXFIFO register where it is ready to be transferred onto the data bus via the RDR.


Figure 4. Asynchronous and Isochronous Frame Format

## Isochronous Receive

In the isochronous (ISOC) mode, a 1 times clock on RxC is required with the data on RxD and the serial data bit is latched on the falling edge of each clock pulse. The requirement for the detection of a valid start bit, or the beginning of a break, is satisfied by the detection of a high-to-low transition on the serial data input line. Error detection and status indication are the same as the asynchronous mode.

## Asynchronous and Isochronous Transmit

In asynchronous and isochronous transmit modes, output data tansmission on TXD begins with the start bit. This is followed by the data character which is transmitted LSB first. If parity generation is enabled, the parity bit is transmitted after the MSB of the character.

## SYNCHRONOUS MODES

In synchronous modes, a one-times clock is provided along with the data. Serial output data is shifted out and input data is latched on the falling edge of the clock.

## BIT ORIENTED PROTOCOLS (BOP)

In bit oriented protocols (BOP), messages (data) are transmitted and received in frames. Each frame contains an opening flag, address field, control field, frame check sequence, and a closing flag. A frame may also contain an information field. (See Figure 5).

The opening flag is a special character whose bit pattern is 01111110 . It marks the frame boundaries and is the interframe fill character. The address field of a frame contains the address of the secondary station which is receiving or responding to a command. The address field may be one or more bytes long. The address field can be extended by setting the ADDEX bit to a 1 in PSR1. In this case, the address field will be extended until the occurrence of an address byte with a 1 in bit 0 . Up to two bytes of the address field may be automatically checked when the MPCC is programmed to be a secondary station in BOP. An automatic check for global (11111111) or null ( 00000000 ) address is also made. The control field of one or two bytes is transparent to the MPCC and sent directly to the host without interpretation.

The optional information field consists of 8-bit characters. Cyclic redundancy checking is used for error detection and the CRC remainder resulting from the calculation is transmitted as the frame check sequence field. For BOP, the polynomial $\mathbf{X}^{16}+$ $X^{12}+X^{5}+1$ (CRC-CCITT) should be used, i.e., selected in the CRC SEL bits in the ECR. The registers representing the CRC-CCITT polynomial are generally preset to all 1s, and the is complement of the resulting remainder is transmitted. (See X. 25 Recommendation.)

Zero insertion/deletion is employed to prevent valid frame data from being confused with the special characters. A 0 is inserted by the transmitter after every fifth consecutive 1 in the data stream. These inserted zeros are removed by the receiver to restore the data to its original form. The inserted zeros are not included in the CRC calculation.

The end of the frame is determined by the detection of the closing Flag special character which is the same is the opening Flag.

With the control options offered by the MPCC, commony used bit oriented protocols such as SDLC, HDLC and X. 25 standards can be supported. Figure 6 compares the requirements of these options.

## BOP Receiver Operation

In BOP, the receiver starts assembling characters and accumulating CRC immediately after the detection of a Flag. The receiver also continues to search for additional Flag, or Abort, characters on a bit-by-bit basis. Zero deletion is implemented in the Receiver Shift Register after the Flag detection logic and before the CRC circuitry. The receiver recognizes the shared flag (the closing flag for one frame serves as the opening flag for the next frame) and the shared zero (the ending 0 of a closing flag serves as the beginning 0 of an opening flag forming the pattern "011111101111110."

Character assembly and CRC accumulation are stopped when a closing Flag or Abort is detected. The CRC accumulation includes all the characters between the opening Flag and the closing Flag. The contents of the CRC register are checked
at the close of a frame and the C/PERR bit in the RSR is updated. The FCS and the Flag are not passed on to the RxFIFO.

If the Flag is a closing flag, checks for short frame (no control field) and CRC error conditions are made and the appropriate status is updated. When an Abort (seven 1s) is detected, the remaining frame is discarded and the FA/B bit is set in the RSR. When a link idle ( 15 or more consecutive 1s) is detected, the RIDLE status bit is set in the RSR. The zeros that have been inserted to distinguish data from special characters are detected and deleted from the data stream before characters are assembled. The MPCC programmed as a secondary station provides automatic address matching of up to two bytes. If there is no address match, the receiver (secondary station) ignores the remainder of the frame by searching for the Flag. If there is a match, the address bytes are transferred to the RxFIFO as they are assembled.

For the control field, one or two bytes are assembled and passed on to the RxFIFO depending on the state of the extended control field bit.

If the CFCRC bit in the ECR is set to 1 , an intermediate CRC check will be made after the address and control field. The Frame Check Sequence is still calculated over the remainder of the frame.

## BOP Transmitter Operation

In BOP, the TxFIFO can be preloaded through the TDR while the transmitter is disabled (TEN = 0 in the TCR). When the transmitter is enabled (TEN = 1 in the TCR), the leading FLAG is automatically sent prior to transmitting data from the TxFIFO. The TDRA bit is set to 1 in the TSR as long as TxFIFO is not full. If an underrun occurs, the TUNRN bit in the TSR is set to a 1 and an ABORT (11111111) is transmitted followed by continuous FLAGSs or marks until a new sequence is initiated.

The TLAST bit in the TCR must be set prior to loading the last character of the message to signal the transmitter to append the two-byte Frame Check Sequence (FCS) following the last character. If the transmitter DMA mode is selected (the TDSREN bit set to 1 in the TCR) the TLAST bit is set by the DONE signal from the DMAC.

| FLAG $01111110$ | ADDRESS 1 OR N BYTES | CONTROL <br> 1 OR <br> 2 BYTES | INFORMATION N BYTES (OPTIONAL) | $\begin{aligned} & \text { FCS } \\ & 2 \text { BYTES } \end{aligned}$ | FLAG 01111110 |
| :---: | :---: | :---: | :---: | :---: | :---: |

Figure 5. Bit Oriented Protocol (BOP) Frame Format

IBM SDLS FRAME FORMAT

| FLAG <br> 01111110 | ADDRESS <br> 1 BYTE | CONTROL <br> 1 BYTE | INFORMATION <br> N BYTES | FCS <br> 2 BYTES | FLAG <br> 01111110 |
| :--- | :--- | :--- | :--- | :--- | :--- |

ADCCP/HDLC FRAME FORMAT

| FLAG <br> 01111110 | ADDRESS <br> N BYTES | CONTROL <br> 1 OR <br> 2 BYTES | INFORMATION <br> N BYTES | FCS <br> 2 BYTES | FLAG <br> 01111110 |
| :--- | :--- | :--- | :--- | :--- | :--- |

Figure 6. Implemented Bit Oriented Protocols

A message may be terminated at any time by setting the TABT bit in the TCR to 1. This causes the transmitter to send an Abort character followed by the remainder of the current frame data in the TxFIFO.

The serial data from the Transmitter Shift Register is continuously monitored for five consecutive 1s, and a 0 is inserted in the data stream each time this condition occurs (excluding Flag and Abort characters).

CRC accumulation begins with the first non-Flag character and includes all subsequent characters. The CRC remainder is transmitted as the FCS following the last data character. If the CTLCRC bit in the ECR is set to 1 , an intermediate CRC remainder is appended after the Address and Control field. The final Frame Check Sequence is calculated over the balance of the frame.

## BISYNC (BSC)

The structure of messages utilizing the IBM Binary Synchronous Communications (BSC) protocol, commonly called Bisync, is shown in Figure 7. The MPCC can process both transparent and nontransparent messages using either the EBCDIC or the ASCII codes. The CRC-16 polynomial should be selected by setting the appropriate CRCSEL bits in the ECR for both transparent and non-transparent EBCDIC and for transparent ASCII coded messages. VRC/LRC should be selected for non-transparent ASCII coded messages. BSC messages are formatted using defined data-link control characters. Data-link control characters generated and recognized by the MPCC are listed in Table 4.

Table 4. BSC Data-Link Control Characters

| ASCII |  |  | EBCDIC |  |  |
| :--- | :---: | :---: | :--- | :---: | :---: |
| Command | Byte 1 | Byte 2 | Command | Byte 1 | Byte 2 |
| SYN | $16^{*}$ | - | SYN | $32^{*}$ | - |
| SOH | 01 | - | SOH | 01 | - |
| STX | 02 | - | STX | 02 | - |
| ETB | 17 | - | EOB (ETB) | 26 | - |
| ETX | 03 | - | ETX | 03 | - |
| ENQ | 05 | - | ENQ | $2 D$ | - |
| DLE | 10 | - | DLE | 10 | - |
| ITB | $1 F$ | - | ITB | $1 F$ | - |
| EOT | 04 | - | EOT | 37 | - |
| ACK N* | 10 | $30-37$ | ACK 0 | 10 | 70 |
| NAK | 15 | - | ACK 1 | 10 | 61 |
| WACK | 10 | $3 B$ | NAK | $3 D$ | - |
| RVI | 10 | $3 C$ | WACK | 10 | $6 B$ |
|  |  |  | RVI | 10 | $7 C$ |

Note: *Programmable

A heading is a block of data starting with an SOH and containing one or more characters that are used for message control (e.g., message identification, routing, and priority). The SOH initiates the block-check-character (BCC) accumulation, but is not included in the accumulation. The heading is terminated by STX when it is part of a block containing both heading and text. A block containing only a heading is terminated with an ITB or an ETB followed by the BCC. Only the first SOH or STX in a transmission block following a line turnaround causes the BCC to reset. All succeeding STX or SOH characters are included in the BCC. This permits the entire transmission (excluding the first SOH or STX) to be block-checked.

The text data is transmitted in complete units called messages, which are initiated by STX and concluded with ETX. A message can be subdivided into smaller blocks for ease in processing and more efficient error control. Each block starts with STX and ends with ETB (except for the last block of a message, which ends with ETX). A single transmission can contain any number of blocks (ending with ETB) or messages (ending with ETX). An EOT following the last ETX block indicates a normal end of transmission. Message blocking without line turnaround can be accomplished by using ITB (see the Additional Data Link Capabilities section, IBM GA 27-3004-2).

Two modes of data transfers are used in BSC. In non-transparent mode, data link control characters may not appear as text data. In transparent mode, each control character is preceded by a data link escape (DLE) character to differentiate it from the text data. Table 5 indicates which control characters are excluded in the CRC generation. All characters not shown in the table are included in the CRC generation. Figure 8 shows various formats for Control/Response Blocks and Heading and Text Blocks.

Table 5. BSC Control Sequences - Inclusion in CRC Accumulation

| Character of Sequence | Included in CRC Accumulation |  |  |
| :---: | :---: | :---: | :---: |
|  | Yes | No |  |
| TSYN | - | DLESYN |  |
| TSOH | - | DLESOH |  |
| TSTX* | - | DLESTX |  |
| TETB | ETB | DLE |  |
| TETX | ETX | DLE |  |
| TDLE | (DLE)DLE | DLE(DLE) |  |
| *If not preceded within the same block by transparent heading |  |  |  |
| information. |  |  |  |


| LEADING PAD <br> 1 BYTE <br> (AR1) | SYN <br> 1 BYTE <br> (AR2) | SYN <br> 1 BYTE <br> (AR2) | BODY | BCC | TRAILING |
| :--- | :--- | :--- | :--- | :--- | :--- |

Figure 7. BSC Block Format

| LEADING <br> PAD | SYN | SYN | EOT | FOLLOW- <br> ING PAD | SYN | SYN | ADDRESS | ENQ | FOLLOW- <br> ING PAD |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |


| LEADING <br> PAD | SYN | SYN | ACKO | FOLLOW- <br> ING PAD |
| :--- | :--- | :--- | :--- | :--- |

POSITIVE ACKNOWLEDGEMENT

negative acknowledgement
heading and text blocks

HEADING ONLY

NONTRANSPARENT HEADING AND TEXT


Figure 8. BSC Message Format Examples

## BSC Receiver Operation

Character length defaults to eight bits in BSC mode. When ASCII is selected, the eighth bit is used for parity provided that VRC/LRC polynomial is selected. Character assembly starts after the receipt of two consecutive SYN characters. Serial data bits are shifted through the Receiver Shift Register into the Serial-to-Parallel Register and transferred to the RxFIFO. The RDA status bit in the RSR is set to 1 each time data is transferred to the RxFIFO. The SYN character in non-transparent mode and DLE-SYN pairs in transparent mode are discarded.

The receiver starts each block in the non-transparent mode. It switches to transparent mode if a block begins with a DLE-SOH or DLE-STX pair. The receiver remains in transparent mode until a DLE-ITB, DLE-ETB, DLE-ETX or DLE-ENQ pair is received. BCC accumulation begins after an opening SOH, STX, or DLESTX. SYN characters in non-transparent mode or DLE-SYN pairs in transparent mode are excluded from the BCC accumulation. The first DLE of a DLE-DLE sequence is not included in the BCC accumulation and is discarded. The BCC is checked after receipt of an ITB, ETB, or ETX in non-transparent mode or DLE-ITB, DLE-ETB, DLE-ETX in transparent mode. If a CRC error is detected, the C/PERR and EOF bits in the RSR are set to 1. If no error is detected only the EOF bit is set. If the closing character was an ITB, BCC accumulation and character assembly starts again on the first character following the BCC.

## BSC Transmitter Operation

BSC transmission begins with the sending of an opening pad (PAD) and two sync (SYN) characters. These characters are programmable and stored in AR1(PAD) and AR2(SYN). SOH or STX initiates the block-check-character (BCC) accumulation. An initial SOH or STX is not included in the BCC accumulation. Should an underrun condition occur, the content of AR2 (normally SYN character) is transmitted until new characters become available.

The message is terminated by the transmission of the BCC followed by a closing pad when an ETB, ITB, or ETX is fetched from the TxFIFO. The closing PAD is generated by the MPCC.

In transparent mode, the BCC accumulation is initiated by DLESTX and is terminated by the sequences DLE-ETX, DLE-ETB, or DLE-ITB. See Table 5 for character sequence and inclusion in CRC accumulation. If an underrun occurs, DLE-SYN characters will be transmitted until new characters are available in the TxFIFO, ETC, ETX, ITB, or ENQ with a TLAST tag is treated as a control character and the MPCC automatically inserts a DLE immediately preceding these characters, DLE-ETB, DLE-ETX, DLE-ITB, or DLE-ENQ terminates a block of transparent text, and returns the data link to normal mode. BCC generation is not used for messages beginning with characters other than SOH, STX, DLE-SOH, or DLE-STX. On all message types, if the TSYN bit is set to 1 in the TCR, a SYN-SYN (DLE-SYN sequence on transparent messages) sequence is transmitted before the next character is fetched from the TxFIFO.

## CHARACTER ORIENTED PROTOCOLS

The character oriented protocol (COP) option uses the format shown in Figure 9. It may be used for various character oriented protocols with 5-8 bit character sizes and optional parity checking. The input data is checked on a bit-by-bit basis for a pair of consecutive SYN characters to establish character synchronization. These SYN characters are discarded after detection. The PAD and SYN characters may be 5-8 bits long and are user programmable as stored in AR1 and AR2, respectively.

If parity checking is enabled the characters assembled after character sync are checked for parity errors. If STRSYN is set in the RCR, all SYN characters detected within the message will be discarded and will not be passed on to the RxFIFO. If STRSYN is reset, SYNs detected within the message will be treated as data.


Figure 9. Character Oriented Protocol Format


Figure 10. Typical Interface to 6500-Based System


Figure 11. Typical Interface to $\mathbf{6 8 0 0}$-Based System


NOTES: TIMING MEASUREMENTS ARE REFERENCED TO AND FROM A LOW VOLTAGE OF 0.8 VOLTS AND A HIGH VOLTAGE OF 2.0 VOLTS, UNLESS OTHERWISE NOTED.

Figure 12. MPCC Read Cycle Timing


NOTES: TIMING MEASUREMENTS ARE REFERENCED TO AND FROM A LOW VOLTAGE OF 0.8 VOLTS AND A HIGH VOLTAGE OF 2.0 VOLTS, UNLESS OTHERWISE NOTED.

Figure 13. MPCC Write Cycle Timing


Figure 14. MPCC to Memory DMA Transfer Cycle Timing (Receiver DMA Mode).


Figure 15. Memory to MPCC DMA Transfer Cycle Timing (Transmitter DMA Mode).

## HIGH SPEED APPLICATION



LOW SPEED APPLICATION (RS-232 COMPATIBLE)


Figure 16. Serial Interface Timing


NOTE: TIMING MEASUREMENTS ARE REFERENCED TO AND FROM A LOW VOLTAGE OF 0.8 VOLTS AND A HIGH VOLTAGE OF 2.0 VOLTS, UNLESS OTHERWISE NOTED.

Figure 17. Serial Interface Echo Mode Timing

## AC CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Number | Parameter | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | R/ $\bar{W}$ High to $\emptyset 2$ High | $\mathrm{t}_{\text {RH2H }}$ | 0 | - | ns |
| 2 | Address Valid to $\overline{\mathrm{CS}}$ Low | $\mathrm{t}_{\text {AVSL }}$ | 30 | - | ns |
| 3 | $\overline{C S}$ Low to $\emptyset 2$ High | $\mathrm{t}_{\text {SL2H }}$ | 30 | - | ns |
| 4 | 02 High to Data Valid | $\mathrm{t}_{2 \mathrm{HDV}}$ | 0 | 140 | ns |
| 5 | 02 Low to Data Invalid | $\mathrm{t}_{\text {LLOXR }}$ | 10 | 150 | ns |
| 6 | ¢2 Low to R/ $\bar{W}$ Low | $\mathrm{t}_{\text {LLRL }}$ | 20 | - | ns |
| 7 | Q2 Low to Address Invalid | $\mathrm{t}_{\text {LLAI }}$ | 20 | - | ns |
| 8 | R/ $\bar{W}$ Low to $\emptyset 2$ High | $\mathrm{t}_{\text {RL2H }}$ | 0 | - | ns |
| 9 | Data Valid to 02 Low | $t_{\text {DV2L }}$ | 60 | - | ns |
| 10 | ¢2 Low to Data Invalid | $\mathrm{t}_{\text {LLDXW }}$ | 0 | - | ns |
| 11 | 02 Low to R/W High | $\mathrm{t}_{\text {LLRH }}$ | 20 | - | ns |
| 15 | DACK Low to 02 High | $\mathrm{t}_{\text {AL2 }}$ | 125 | - | ns |
| 16 | @2 Low to DACK High | $\mathrm{t}_{\text {LLAH }}$ | 65 | - | ns |
| 17 | DTS Low to $\downarrow 2$ Low | $\mathrm{t}_{\text {SL2L }}$ | 60 | - | ns |
| 18 | $\overline{\text { DACK Low to Data Valid, } \overline{\text { DONE }} \text { Low }}$ | $\mathrm{t}_{\text {ALDV }}$ | 0 | 140 | ns |
| 19 | Q2 Low to Data Invalid | $\mathrm{t}_{\text {LLOXDR }}$ | 10 | 150 | ns |
| 20 | $\overline{\text { DACK, }}$ DONE Low to $\emptyset 2$ High | $\mathrm{t}_{\text {AL2H }}$ | 125 | - | ns |
| 21 | Data Valid to 02 Low | $\mathrm{t}_{\text {DV2L }}$ | 60 | - | ns |
| 22 | $\emptyset 2$ Low to Data Invalid | $\mathrm{t}_{\text {LLDXDW }}$ | 0 | - | ns |
| 23 | Ø2 Low to DACK, $\overline{\text { DONE }}$ High | $\mathrm{t}_{\text {LLDH }}$ | 65 | - | ns |
| 30 | RxC and TxC Period | $\mathrm{t}_{\mathrm{CP}}$ | 248 | - | ns |
| 31 | TxC Low to TxD Delay | ${ }_{\text {t }}^{\text {TCLTD }}$ | 0 | 200 | ns |
| 32 | RxC Low to RxD Transition (Hold) | $\mathrm{t}_{\text {RCLRD }}$ | 0 | - | ns |
| 33 | RxD Transition to RxC Low (Setup) | $\mathrm{t}_{\text {RDRCL }}$ | 30 | - | ns |
| 34 | RxD to TxD Delay (Echo Mode) | $\mathrm{t}_{\text {RDTD }}$ | - | 200 | ns |


| MDCC1 | MPCC2 |
| :---: | :---: |
| TxC | RxC |
| TxD | RxD |
| RxC | TxC |
| RxD | TxD |

HIGH SPEED INTERFACE


LOW SPEED (RS-232) INTERFACE

Figure 18. Serial Interface

## ABSOLUTE MAXIMUM RATINGS*

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

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

## THERMAL CHARACTERISTICS

| Parameter | Symbol | Value | Rating |
| :---: | :---: | :---: | :---: |
| Thermal Resistance | $\theta_{\mathrm{JA}}$ |  | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic |  | 50 |  |
| Plastic | 68 |  |  |

## OPERATING CONDITIONS

| Parameter | Range |
| :---: | :---: |
| $V_{\text {CC }}$ Power Supply | $5.0 \mathrm{~V} \pm 5 \%$ |
| Operating Temperature | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage All Inputs | $\mathrm{V}_{\mathrm{IH}}$ | +2.0 | $\mathrm{V}_{\mathrm{Cc}}$ | V |  |
| Input Low Voltage All Inputs | $\mathrm{V}_{\text {IL }}$ | -0.3 | +0.8 | V |  |
| Input Leakage Current R/ $\bar{W}, \overline{R E S}, \overline{C S}$ | $\mathrm{I}_{1}$ | - | 10.0 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\mathrm{IN}}=0 \text { to } 5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \end{aligned}$ |
| Three-State (Off State) Input Current IRQ, DO-D7 | $\mathrm{T}_{\text {TSI }}$ | - | 10.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.0 \mathrm{~V} \end{aligned}$ |
| Output High Voltage <br> $\overline{R D S R}, \overline{T D S R}, \overline{I R Q}, D O-D 7, \overline{D S R}, \overline{D T R}, \overline{R T S}$, TxD, TxC | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\text {SS }}+2.4$ | - | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-400 \mu \mathrm{~A}, \\ & \mathrm{C}_{\mathrm{LOAD}}=130 \mathrm{pF} \end{aligned}$ |
| BCLK | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{SS}}+2.4$ | - | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=0 \\ & \mathrm{C}_{\text {LOAD }}=30 \mathrm{pF} \end{aligned}$ |
| Output Low Voltage $\overline{\text { RDSR }}, \overline{\text { TDSR }}, \overline{\text { IRQ }}, \mathrm{DO}-\mathrm{D7}, \overline{\mathrm{DSR}}, \overline{\mathrm{DTR}}, \overline{\mathrm{RTS}}$, TxD, TxC, BCLK | $\mathrm{V}_{\text {OL }}$ | - | 0.5 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=3.2 \mathrm{~mA} \end{aligned}$ |
| $\overline{\text { DONE }}$ |  |  |  |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=8.8 \mathrm{~mA} \end{aligned}$ |
| Internal Power Dissipation | $\mathrm{P}_{\text {INT }}$ | - | 1 | W | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | 13 | pF | $\begin{aligned} & V_{\mathbb{I N}}=O V \\ & T_{A}=25^{\circ} \mathrm{C} \\ & f=1 \mathrm{MHz} \end{aligned}$ |

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



|  | MLLLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
|  | 50.29 | 59.56 | 1.980 | 2.030 |
| B | 14.73 | 15.49 | 0.580 | 0.610 |
| C | 1.78 | 3.05 | 0.070 | 0.120 |
| D | 0.38 | 0.58 | 0.015 | 0.023 |
| F | 1.02 | 1.65 | 0.040 | 0.065 |
| G | 2.29 | 2.80 | 0.090 | 0.110 |
| J | 0.20 | 0.38 | 0.008 | 0.015 |
| K | 3.18 | 3.81 | 0.125 | 0.150 |
| L | 14.99 | 16.51 | 0.590 | 0.650 |
| M | $0^{\circ}$ | $100^{\circ}$ | $0^{\circ}$ | $10^{\circ}$ |
| N | 0.58 | 1.78 | 0.020 | 0.070 |

## 40-PIN PLASTIC DIP



| DIM | MILLIMETEAS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | max | MIN | max |
| $A$ | 51.28 | 52.32 | 2.040 | 2.060 |
| B | 13.72 | 14.22 | 0.540 | 0.560 |
| c | 3.55 | 5.08 | 0.140 | 0.200 |
| D | 0.36 | 0.51 | 0.014 | 0.020 |
| $F$ | 1.02 | 1.52 | 0.040 | 0.060 |
| c | 2.54 BSC |  | 0.100 BSC |  |
| H | 1.65 | 2.16 | 0.065 | 0.085 |
| J | 0.20 | 0.30 | 0.008 | 0.012 |
| K | 3.05 | 3.56 | 0.120 | 0.140 |
| $L$ | 15.24 BSC |  | 0.600 BSC |  |
| m | $T$ | $10^{\circ}$ | 7 | $10^{\circ}$ |
| N | 0.51 | 1.02 | 0.020 | 0.040 |

## R65C02, R65C102, AND R65C112 R65C00 MICROPROCESSORS (CPU)

## DESCRIPTION

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

Three CPU devices are available. All are software-compatible and provide 64 K bytes of addressable memory, interrupt input, and on-chip clock oscillators and drivers options. All are buscompatible with the NMOS R6500 family devices.

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

## ENHANCEMENTS OVER R6502

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

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


## FEATURES

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


## ORDERING INFORMATION

Part Number:
R65C02 _ - -
R65C102_-_-
R65C112


## FUNCTIONAL DESCRIPTION

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

NOTES:
(1) R65C02 ONLY
(2) R65C02, R65C102 ONLY
(3) R65C102 ONLY
(4) R65C112 ONLY
(5) R65C102, R65C112 ONLY

REGISTER SECTION

A8



## CRYSTAL OSCILLATOR (R65C102 Only)

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

## CLOCK GENERATOR

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

## TIMING CONTROL

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

## PROGRAM COUNTER

The 16 -bit program counter provides the addresses which step the microprocessor through sequential instructions in a program.

Each time the microprocessor fetches an instruction from program memory, the lower byte of the program counter ( PCL ) is placed on the low-order bits of the address bus and the higher byte of the program counter ( PCH ) is placed on the high-order 8 bits. The counter is incremented each time an instruction or data is fetched from program memory.

## INSTRUCTION REGISTER AND DECODE

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

## ARITHMETIC AND LOGIC UNIT (ALU)

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

## ACCUMULATOR

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

## INDEX REGISTERS

There are two 8 -bit index registers ( $X$ and $Y$ ), which may be used to count program steps or to provide an index value to be used in generating an effective address.

When executing an instruction which specifies indexed addressing, the CPU fetches the op code and the base address,
and modifies the address by adding the index register to it prior to performing the desired operation. Pre- or post-indexing of indirect addresses is possible (see addressing modes).

## STACK POINTER

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

## PROCESSOR STATUS REGISTER

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

## HARDWARE ENHANCEMENTS

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

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


## MAJOR FEATURES AND DIFFERENCES

The functional aspects of and differences between the microprocessor configurations are shown in Table 1.

Table 1. Family Comparison Chart

| Feature | 응 | 응 | N |
| :---: | :---: | :---: | :---: |
| Pin compatible with NMOS R6502 | X |  |  |
| 64 K addressable bytes of memory | X | X | X |
| $\overline{\mathrm{RQ}}$ interrupt | X | X | X |
| On-chip clock oscillator | X | X |  |
| External clock only |  |  | X |
| TTL level single phase clock input | X | X |  |
| RC time base clock input | X | $x$ |  |
| Crystal time base clock input | X | X |  |
| Single phase clock input |  |  | X |
| Two phase output clock | x | X |  |
| SYNC and RDY signals | X | x | $x$ |
| Bus Enable (BE) signal |  | X | X |
| Memory Lock ( $\overline{\mathrm{ML}}$ ) output signal |  | X | x |
| Direct Memory Access (DMA) capacity |  | X | X |
| $\overline{\mathrm{NMI}}$ interrupt signal | x | X | X |

## PIN ASSIGNMENTS

Figure 2 shows the pin assignments for the three members of the R65C00 CPU family. All three devices are housed in 40-pin, dual-in-line, ceramic or plastic packages.


Figure 2. Pin Assignments

## SIGNAL DESCRIPTIONS

Reference the timing diagrams for the particular device in the following discussion.

## CLOCK SIGNALS (R65C02)

The R65C02 requires an external $\emptyset 0$ clock. $\emptyset 0$ is a TTL level input that is used to generate the internal clocks of the R65C02. Two full level output clocks are generated by the R65C02. The $\emptyset 2$ clock is in phase with $\emptyset 0$. The $\emptyset 1$ clock output is $180^{\circ}$ out of phase with $\emptyset 0$. When the input clock is stopped, the CPU is in the standby mode.

For non-critical timing configurations, a simple RC or crystal network may be strapped between $\emptyset 0(\mathrm{IN})$ and $\emptyset 1$ (OUT).

## CLOCK SIGNALS (R65C102)

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

## CLOCK SIGNALS (R65C112)

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

## ADDRESS BUS (A0-A15)

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

## DATA BUS (D0-D7)

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

## BUS ENABLE (BE)

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

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

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

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

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

## NON-MASKABLE INTERRUPT (NMI)

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

## NOTE

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

## READY (RDY)

This input allows the user to single-cycle the microprocessor on all cycles including write cycles. A negative transition to the low state, during or coincident with $\emptyset 1$, will halt the microprocessor with the output address lines reflecting the current address being fetched. This condition will remain through a subsequent

02 in which the ready signal is low. This feature allows microprocessor interfacing with low-speed memory as well as direct memory access (DMA).

## READ/WRITE (R/W)

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

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

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

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

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

## SYNCHRONIZE (SYNC)

This output line identifies those cycles during which the microprocessor is fetching the instruction operation code (OP CODE). The SYNC line goes high during $\emptyset 1$ of an OP CODE fetch and stays high for the remainder of that cycle. If the RDY line is pulled low during the $\emptyset 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.

## OPERATIONAL ENHANCEMENTS

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

Table 2. CMOS Operational Enhancements

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

## ADDRESSING MODES

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

## NOTE

[^5]
## INSTRUCTION SET

Table 3 lists the instruction set for the CMOS CPU family in alphabetic order according to mnemonic. Table 4 lists the hexadecimal codes for each of the instructions that are new to the CMOS family and were not available in the NMOS R6502 device
family. Table 5 lists those instructions that were available on the NMOS family, but have been assigned new addressing modes in the CMOS CPU family.

Table 3. Alphabetic Listing of Instruction Set

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

Notes:
(1) Instruction not available on the NMOS family.
(2) R6502 instruction with additional addressing mode(s).

Table 4. Hexadecimal Codes For New Instructions in The CMOS Family


Table 5. Hexadecimal Codes For Instructions With New CMOS Addressing Modes

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

## INSTRUCTION SET OP CODE MATRIX

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


7．If in Decimal Mode，$Z$ flag is is invalid．Accumulator must pe checked for zero result．
＝Memory Bit 7

## AC CHARACTERISTICS

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

## CLOCK TIMING

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

## READ/WRITE TIMING

| R/W Setup Time | $\mathrm{t}_{\text {RwS }}$ | - | 125 | - | 100 | - | 75 | - | 60 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R $\bar{W}$ Hold Time | $\mathrm{t}_{\text {HRW }}$ | 15 | - | 15 | - | 15 | - | 15 | - | ns |
| Address Setup Time | $\mathrm{t}_{\text {ADS }}$ | - | 125 | - | 100 | - | 75 | - | 60 | ns |
| Address Valid to $\emptyset 4$ High ${ }^{(4)}$ | $t_{\text {A } 94}$ | 100 | - | 25 | - | 10 | - | 0 | - | ns |
| Address Hold Time | $\mathrm{t}_{\mathrm{HA}}$ | 15 | - | 15 | - | 15 | - | 15 | - | ns |
| Read Access Time | $t_{\text {ACC }}$ | 775 | - | 340 | - | 215 | - | 160 | - | ns |
| Read Data Setup Time | tosu | 100 | - | 60 | - | 40 | - | 30 | - | ns |
| Read Data Hold Time | $\mathrm{t}_{\mathrm{HR}}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| Write Data Delay Time ${ }^{(2)}$ | $\mathrm{t}_{\text {MDS }}$ | - | 200 | - | 110 | - | 85 | - | 55 | ns |
| Write Data Delay Time ${ }^{(4)}$ | $\mathrm{t}_{\text {Dow }}$ | - | 200 | - | 110 | - | 85 | - | 55 | ns |
| Write Data Delay Time ${ }^{(6)}$ | $\mathrm{t}_{\mathrm{DD1}}$ | - | 450 | - | 235 | - | 170 | - | 120 | ns |
| Write Data Hold Time | $\mathrm{thw}^{\text {w }}$ | 30 | - | 30 | - | 30 | - | 30 | - | ns |

## CONTROL LINE TIMING

| SYNC Delay | $\mathrm{t}_{\text {SYS }}$ | - | 125 | - | 100 | - | 75 | - | 60 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RDY Setup Time | $\mathrm{t}_{\text {RDS }}$ | 200 | - | 110 | - | 80 | - | 60 | - | ns |
| $\overline{\text { SO }}$ Setup Time | $\mathrm{t}_{\text {SOS }}$ | 75 | - | 50 | - | 40 | - | 30 | - | ns |
| ML Delay Time ${ }^{(5)}$ | ${ }_{\text {LMLS }}$ | - | 125 | - | 100 | - | 75 | - | 60 | ns |
| ML Hold Time ${ }^{(4)}$ | $\mathrm{t}_{\text {MLH }}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| ML Hold Time ${ }^{(6)}$ | $\mathrm{t}_{\text {MLH }}$ | 15 | - | 15 | - | 15 | - | 15 | - | ns |
| BE Delay Time ${ }^{(5)(9)}$ | $\mathrm{t}_{\text {BE }}$ | - | 40 | - | 40 |  | 40 |  | 40 | ns |
| BE Setup Time ${ }^{(5)(9)}$ | $\mathrm{t}_{\mathrm{BV}}$ | - | 60 | - | 60 | - | 60 - | - | 60 | ns |
| $\overline{\text { IRQ, }} \overline{\text { RES }}$ Setup Time | tis | 200 | - | 110 | - | 80 | - | 60 | - | ns |
| तलMI Setup Time | $\mathrm{t}_{\text {NMI }}$ | 200 | - | 150 | - | 100 | - | 70 | - | ns |

[^6]

NOTE: ALL TIMING IS REFERENCED FROM A HIGH VOLTAGE OF 2.4 VOLTS AND A LOW OF 0.5 VOLTS. *ML (MEMORY LOCK) AND BE (BUS ENABLE) NOT APPLICABLE TO R65C02.

Figure 3. Timing Diagram for the R65C02 and R65C112


NOTE: ALL TIMING IS REFERENCED FROM A High VOLTAGE OF 2.4 VOLTS AND A LOW OF 0.5 VOLTS.

Figure 4. Timing Diagram for the R65C102

## CRYSTAL/CLOCK CONSIDERATIONS

## CRYSTAL/CLOCK CIRCUITS

Figure 5 shows a time base generation scheme, for 4 MHz operation of the R65C02, that has been tested and proven reliable for normal environments. As with any clock oscillator circuit, stray capacitance due to board layout can cause unpredictable results requiring "fine tuning" of the circuit. Figure 6 shows a possible external clock scheme for a R65C102 and R65C112 master/slave configuration. Table 6 identifies nominal crystal parameters for five crystal frequencies.

Table 6. Nominal Crystal Parameters

| FREQ | $\mathbf{3 . 5 8}$ | $\mathbf{4 . 0}$ | $\mathbf{6 . 0}$ | $\mathbf{8 . 0}$ | $\mathbf{1 6 . 0}$ | $\mathbf{M H z}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RS | 60 | 50 | $30-50$ | $20-40$ | $10-30$ | $\Omega$ |
| C0 | 3.5 | 6.5 | $4-6$ | $4-6$ | $3-5$ | pF |
| C1 | .015 | .025 | $.01-.02$ | $.01-.02$ | $.01-.02$ | pF |
| Q | 740 K | 730 K | 720 K | 720 K | 720 K | K |

Note: These represent at-cut crystal parameters only. Others may be used.


Figure 5. Example of R65C02 Time Base Generation


THE OSCILLATOR IN THE R65C102 IS SERIES RESONANT. THE CRYSTAL INPUT IS DIVIDED BY 4: (R65C102 ONLY)

$$
02=\frac{X T A L}{4}
$$

SEE CAUTION FOR STANDBY OPERATION.

## STOPPING THE CLOCK-STANDBY MODE

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


Figure 7. Standby Mode Circuit

MAXIMUM RATINGS*

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

## OPERATING CONDITIONS

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

## *Note

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

## DC CHARACTERISTICS

| Parameter | Symbol | Min | Typ | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage All Other Input Pins $\varnothing 0$ on R65C02 Ø2 on R65C112 |  | $\begin{gathered} 2.0 \\ 2.4 \\ V_{c c}-0.4 \end{gathered}$ |  | $\begin{aligned} & v_{c c}+0.3 \\ & v_{c c}+0.3 \\ & v_{c c}+0.3 \end{aligned}$ | V |  |
| Input Low Voltage <br> All Other Input Pins <br> 00 on R65C02 <br> $\emptyset 2$ on R65C112 | $\mathrm{V}_{\text {IL }}$ | $\begin{aligned} & -0.3 \\ & -0.3 \\ & -0.3 \end{aligned}$ |  | $\begin{aligned} & +0.8 \\ & +0.4 \\ & +0.4 \end{aligned}$ | V |  |
| Input Leakage Current $\overline{\mathrm{NMI}}, \overline{\mathrm{RQ}}, \mathrm{BE}, \mathrm{RDY} ; \overline{\mathrm{RES}}, \overline{\mathrm{SO}}$ $\emptyset 2 \mathrm{IN}, \emptyset 0 \mathrm{IN}, \mathrm{XT}$ LI | $\mathrm{I}_{\mathrm{N}}$ | - |  | $\begin{array}{r} -50 \\ 1.0 \end{array}$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{1 \mathrm{~N}}=0 \mathrm{~V} \text { to } 5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V} \end{aligned}$ |
| Three-State (Off State) Input Current Data Lines | $\mathrm{I}_{\text {TS }}$ | - |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage <br> SYNC, Data, A0-A15, R $\bar{W}, \emptyset 1, \emptyset 2, ~ \emptyset 4, \overline{M L}$ | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | - | V | $\begin{aligned} & V_{C C}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \end{aligned}$ |
| Output Low Voltage SYNC, Data, A0-A15, R $\bar{W}, ~ \emptyset 1, ~ \emptyset 2, ~ \emptyset 4, \overline{M L}$ | $\mathrm{V}_{\mathrm{OL}}$ | - |  | +0.4 | V | $\begin{aligned} & V_{C C}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=1.6 \mu \mathrm{~A} \end{aligned}$ |
| Supply Current <br> Standby ${ }^{4}$ <br> Active (R65C02) <br> Active (R65C102) <br> Active (R65C112) <br> Low Power (R65C02) <br> Low Power (R65C102) <br> Low Power (R65C112) | $\mathrm{I}_{\mathrm{Cc}}$ | - | $\begin{aligned} & 2 \\ & 2.6 \\ & 5 \\ & 2 \\ & 1.1 \\ & 3 \\ & 0.7 \end{aligned}$ | 10 4 7 4 2 4 1 | $\begin{gathered} \mu \mathrm{A} \\ \mathrm{~mA} / \mathrm{MHz} \\ \mathrm{~mA} / \mathrm{MHz} \\ \mathrm{~mA} / \mathrm{MHz} \\ \mathrm{~mA} / \mathrm{MHz} \\ \mathrm{~mA} / \mathrm{MHz} \\ \mathrm{~mA} / \mathrm{MHz} \end{gathered}$ | $V_{c c}=5.0 \mathrm{~V}$ $\begin{aligned} & \operatorname{RDY}=0 \\ & \operatorname{RDY}=0 \end{aligned}$ |
| Capacitance <br> $\overline{\mathrm{NMI}}, \overline{\mathrm{RQ}}, \overline{\mathrm{SO}}, \mathrm{BE}, \mathrm{RDY}$ Data, Ø1, $_{1}$ 2, ©4, $\overline{M L}, ~ X T L O ~$ AO-A15, R $\bar{W}$, SYNC Ø0 (IN), XTLI 02 (IN) | C $\mathrm{C}_{\text {IN }}$ <br> $\mathrm{C}_{\text {OUt }}$ <br> $\mathrm{C}_{0}$ <br> $\mathrm{C}_{2}$ | - |  | $\begin{array}{r} 7 \\ 10 \\ \\ 10 \\ 30 \end{array}$ | pF | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V} \\ & V_{I N}=0 \mathrm{~V} \\ & f_{=1}=1 \mathrm{MHZ} \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |

## Notes:

1. All units are direct current (dc).
2. Negative sign indicates outward current flow, positive indicates inward flow.
3. IRQ and $\overline{N M I}$ require external pull-up resistor.
4. Typical values are shown for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\hat{r}}=25^{\circ} \mathrm{C}$.

## PRELIMINARY

## DESCRIPTION

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

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

## ORDERING INFORMATION

The R65C21 is available in both a ceramic and a plastic 40 -pin package, a commercial or industrial operating temperature range, and operating frequencies of $1,2,3$, or 4 MHz . These versions are coded into the part number as follows:

$$
\begin{aligned}
& \text { Part Number: } \\
& \text { R65C21 }\left[\begin{array}{rl}
\text { LTemperature Range }\left(T_{\perp} \text { to } T_{H}\right): \\
\text { Blank } & =0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\
\mathrm{E} & =-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\
\text { Frequency Range: } \\
1 & =1 \mathrm{MHz} \\
2 & =2 \mathrm{MHz} \\
3 & =3 \mathrm{MHz} \\
4 & =4 \mathrm{MHz} \\
\text { Package: } \\
\mathrm{C} & =\text { Ceramic } \\
\mathrm{P} & =\text { Plastic }
\end{array}\right.
\end{aligned}
$$

## FEATURES

- Low power CMOS N -well silicon gate technology
- Direct replacement for NMOS R6520 or MC6821 PIA
- Two 8-bit bidirectional I/O ports with individual data direction control
- Automatic "Handshake" control of data transfers
- Two interrupts (one for each port) with program control
- 1, 2, 3, and 4 MHz versions
- Commercial and industrial temperature range versions
- 40-pin plastic and ceramic versions
- 5 volt $\pm 5 \%$ supply requirements
- Compatible with the R6500, R6500/* and R65C00 family of microprocessors


Figure 1. R65C21 Pin Configuration

## FUNCTIONAL DESCRIPTION

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


Figure 2. R65C21 PIA Block Diagram

## DATA INPUT REGISTER (DIR)

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

## CONTROL REGISTERS (CRA AND CRB)

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

## DATA DIRECTION REGISTERS (DDRA, DDRB)

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

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

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

## PERIPHERAL OUTPUT REGISTERS (ORA, ORB)

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

## INTERRUPT STATUS CONTROL (ISCA, ISCB)

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

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

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

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

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

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

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

Table 1. Control Registers Bit Designations

CRA \begin{tabular}{|c|c|c|c|c|}
\hline $\mathbf{7}$ \& $\mathbf{6}$ \& $\mathbf{5}$ \& $\mathbf{4}$ \& $\mathbf{3}$ <br>
\hline IRQA1 \& IRQA2 \& $\mathbf{2}$ \& $\mathbf{1}$ <br>

\hline CRB \& | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ |
| :---: | :---: | :---: | :---: |
| Access |  |  |  | \& CA1 Control <br>

\hline IRQB1 \& IRQB2 \& \& CB2 Control \& $\mathbf{2}$ <br>
\hline
\end{tabular}

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

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

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

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

## DATA BUS BUFFERS (DBB)

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

## INTERFACE SIGNALS

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

The PIA interfaces to the peripheral devices with four interrupt/ control lines and two 8-bit bidirectional data buses.

Figure 1 (on the front page) shows the pin assignments for these interface signals and Figure 3 shows the interface relationship of these signal as they pertain to the CPU and the peripheral devices.

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

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

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

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

## CLOCK SIGNAL (02)

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

## READ/WRITE SIGNAL (R/W)

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

## REGISTER SELECT (RS0, RS1)

The two Register Select lines (RS0, RS1), in conjunction with the Control Registers (CRA, CRB) Data Direction Register access bits (see Table 1, bit 2) select the various R65C21 registers to be accessed by the CPU. RS0 and RS1 are normally connected to the microprocessor (CPU) address output lines. Through control of these lines. the CPU can write directly into the Control


Figure 3. Interface Signals Relationship

Registers (CRA, CRB) the Data Direction Registers (DDRA, DDRB) and the Peripheral Output Registers (ORA, ORB). In addition, the processor may directly read the contents of the Control Registers and the Data Direction Registers. Accessing the Peripheral Output Register for the purpose of reading data back into the processor operates differently on the ORA and the ORB registers and therefore are shown separately in Table 2.

Table 2. ORA and ORB Register Addressing

| Register Address (Hex) | Register Select Lines |  | Data Direction Control |  | Register Operation |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS1 | RS0 | $\begin{aligned} & \hline \text { CRA } \\ & \text { (Bit 2) } \end{aligned}$ | $\begin{array}{\|c\|} \hline \text { CRB } \\ \text { (Bit 2) } \end{array}$ | $\mathbf{R} / \bar{W}=\mathbf{H}$ | $\mathbf{R} \bar{W}=\mathbf{L}$ |
| 0 | L | L | 1 | - | Read PIBA | Write ORA |
| 0 | L | L | 0 | - | Read DDRA | Write DDRA |
| 1 | L | H | - | - | Read CRA | Write CRA |
| 2 | H | L | - | 1 | Read PIBB | Write ORB |
| 2 | H | L | - | 0 | Read DDRB | Write DDRB |
| 3 | H | H | - |  | Read CRB | Write CRB |

## INTERRUPT REQUEST LINES (IRQA, $\overline{\text { IRQB }}$ )

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

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

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

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

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

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

| Control Register Bits | Action |
| :---: | :---: |
| CRA-7 $=1$ and CRA-0 $=1$ | $\overline{\text { IRQA }}$ goes low (Active) |
| CRA $-6=1$ and CRA-3 $=1$ | $\overline{\text { IRQA }}$ goes low (Active) |
| CRB-7 $=1$ and CRB-0 $=1$ | $\overline{\mathrm{RQB}}$ goes low (Active) |
| CRB-6=1 and CRB-3=1 | $\overline{\text { IRQB }}$ goes low (Active) | and the processor interrupt inputs. The interrupt disable bits allow the processor to control the interrupt function.

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

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

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

## NOTE:

A negative transition is defined as a transition from a high to a low, and a positive transition is defined as a transition from a low to a high voltage.

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

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

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

CONTROL REGISTER A (CRA)
CA2 INPUT MODE (BIT $5=0$ )

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

CA2 OUTPUT MODE (BIT $5=1$ )

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

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

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

## CA2 INPUT MODE (BIT $5=0$ )

Bit 6 IRQA2 FLAG
1 A transition has occurred on CA2 that satisfies the bit 4 IRQA2 transition polarity criteria. This flag is cleared by a read of Output Register A or by RES.
0 No transition has occurred on CA2 that satisfies the bit 4 IRQA2 transition polarity criteria.

Bit 5 CA2 MODE SELECT
0 Select CA2 Input Mode.
Bit 4 IRQA2 POSITIVE TRANSITION
1 Set IRQA2 Flag (bit 6) on a positive (low-to-high) transition of CA2.
0 Set IRQA2 Flag (bit 6) on a negative (high-to-low) transition of CA2.

Bit 3 IRQA ENABLE FOR IRQA2
1 Enable assertion of IRQA when IRQA2 Flag (bit 6) is set.
0 Disable assertion of $\overline{\mathrm{RQA}}$ when IRQA2 Flag (bit 6 ) is set.

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

Bit 3 CA2 READ STROBE RESTORE CONTROL ( $4=0$ )

1. CA2 returns high on the next $\emptyset 2$ clock negative transition following a read of Output Register A.
0 CA2 returns high on the next active CA1 transition following a read of Output Register A as specified by bit 1 .

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

## CONTROL REGISTER B (CRB)

CB2 INPUT MODE (BIT $5=0$ )

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

CB2 OUTPUT MODE (BIT 5 = 1)

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

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

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

CB2 INPUT MODE (BIT $5=0$ )
Bit 6 IRQB2 FLAG
1 A transition has occurred on CB2 that satisfies the bit 4 IRQB2 transition polarity criteria. This flag is cleared by a read of Output Register B or by RES.
0 No transition has occurred on CB2 that satisfies the bit 4 IRQB2 transition polarity criteria.

Bit 5 CB2 MODE SELECT
0 Select CB2 Input Mode.
Bit 4 IRQB2 POSITIVE TRANSITION
1 Set IRQB2 Flag (bit 6) on a positive (low-to-high) transition of CB2.
0 Set IRQB2 Flag (bit 6) on a negative (high-to-low) transition of CB2.

Bit 3 IRQB ENABLE FOR IRQB2
1 Enable assertion of $\overline{\mathrm{RQB}}$ when IRQB2 Flag (bit 6) is set.
0 Disable assertion of $\overline{\mathrm{RQB}}$ when IRQB2 Flag (bit 6 ) is set.

CB2 OUTPUT MODE (BIT $5=1$ )

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

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

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

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

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

## READING THE PERIPHERAL A I/O PORT

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

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

## READING THE PERIPHERAL B I/O PORT

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


Figure 5. Read Timing Waveforms


Figure 6. Write Timing Waveforms

## BUS TIMING CHARACTERISTICS

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | 3 MHz |  | 4 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| 02 Cycle | ${ }^{\text {t }} \mathrm{CYC}$ | 1.0 | - | 0.5 | - | 0.33 | - | 0.25 | - | $\mu \mathrm{S}$ |
| 02 Pulse Width | $\mathrm{t}_{\mathrm{c}}$ | 480 | - | 240 | - | 180 | - | 120 | - | ns |
| ¢2 Rise and Fall Time | $\mathrm{trc}_{\mathrm{cc}}, \mathrm{t}_{\mathrm{fc}}$ | - | 25 | - | 15 | - | 12 | - | 10 | ns |

## READ TIMING

| Address Set-Up Time | $\mathrm{t}_{\mathrm{ACR}}$ | 140 | - | 70 | - | 53 | - | 35 | - | ns |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address Hold Time | $\mathrm{t}_{\mathrm{CAR}}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| Peripheral Data Set-Up Time | $\mathrm{t}_{\text {PCR }}$ | 300 | - | 150 | - | 110 | - | 75 | - | ns |
| Data Bus Delay Time | - | $\mathbf{n}$ |  |  |  |  |  |  |  |  |
| Data Bus Hold Time | $\mathrm{t}_{\mathrm{CDR}}$ | - | $\mathbf{2 0}$ | - | - | 190 | - | 100 | - | 75 |
| ns |  |  |  |  |  |  |  |  |  |  |

## WRITE TIMING



## PERIPHERAL INTERFACE TIMING

| Peripheral Data Set-Up | $t_{\text {PCR }}$ | 300 | - | 150 | - | 110 | - | 75 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ¢2 Low to CA2 Low Delay | $t_{\text {cal }}$ | - | 1.0 | - | 0.5 | - | 0.33 | - | 0.25 | $\mu \mathrm{S}$ |
| 02 Low to CA2 High Delay | $\mathrm{t}_{\mathrm{RS} 1}$ | - | 1.0 | - | 0.5 | - | 0.33 | - | 0.25 | $\mu \mathrm{S}$ |
| CA1 Active to CA2 High Delay | $\mathrm{t}_{\text {RS2 }}$ | - | 2.0 | - | 1.0 | - | 0.67 | - | 0.5 | $\mu \mathrm{S}$ |
| 02 High to CB2 Low Delay | $\mathrm{t}_{\mathrm{CB2} 2}$ | - | 1.0 | - | 0.5 | - | 0.33 | - | 0.25 | $\mu \mathrm{S}$ |
| Peripheral Data Valid to CB2 Low Delay | $t_{\text {DC }}$ | 0 | 1.5 | 0 | 0.75 | 0 | 0.5 | 0 | 0.37 | $\mu \mathrm{S}$ |
| 02 High to CB2 High Delay | $t_{\text {RS } 1}$ | - | 1.0 | - | 0.5 | - | 0.33 | - | 0.25 | $\mu \mathrm{S}$ |
| CB1 Active to CB2 High Delay | $\mathrm{t}_{\text {RS2 }}$ | - | 2.0 | - | 1.0 | - | 0.67 | - | 0.5 | $\mu \mathrm{S}$ |
| CA1, CA2, CB1 and CB2 Input Rise and Fall Time | $t_{r}, t_{f}$ | - | 1.0 | - | 1.0 | - | 1.0 | - | 1.0 | $\mu \mathrm{S}$ |

## ABSOLUTE MAXIMUM RATINGS＊

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

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

## OPERATING CONDITIONS

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

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min． | Typ．${ }^{3}$ | Max． | Unit ${ }^{2}$ | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage All except PB0－PB7，$\overline{\text { RES }}$ PBO－PB7，RES | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{aligned} & +2.0 \\ & +2.4 \\ & \hline \end{aligned}$ | － | $\begin{aligned} & \mathrm{V}_{\mathrm{cc}} \\ & \mathrm{~V}_{\mathrm{cc}} \end{aligned}$ | v |  |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | －0．3 | － | ＋0．8 | V |  |
| Input Leakage Current R $\bar{W}, \overline{R E S}, \mathrm{RS} 0, \mathrm{RS} 1, \mathrm{CS} 0, \mathrm{CS} 1, \overline{\mathrm{CS}} 2, \mathrm{CA} 1$, CB1，ø2 | $\mathrm{I}^{\mathrm{N}}$ | － | $\pm 1$ | $\pm 2.5$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\mathrm{IN}}=0 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{cc}} \\ & \mathrm{~V}_{\mathrm{cc}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three－State Off D0－D7，PB0－PB7，CB2 | ${ }^{\text {TSI }}$ | － | $\pm 2$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input High Current PAO－PA7，CA2 | ${ }_{1 H}$ | －200 | －300 | － | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ |
| Input Low Current PAO－PA7，CA2 | $1 / 2$ | － | －2 | －3．2 | mA | $\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}$ |
| Output High Voltage Logic PB0－PB7，CB2（Darlington Drive） | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 2.4 \\ & 1.5 \\ & \hline \end{aligned}$ | 二 | － |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-200 \mu \mathrm{~A} \\ & \mathrm{I}_{\text {LOAD }}=-3.2 \mathrm{~mA} \end{aligned}$ |
| $\begin{aligned} & \text { Output Low Voltage } \\ & \text { PAO-PA7, CA2, PB0-PB7, CB2 } \\ & \text { D0-D7, } \overline{\text { IRQA }, ~ / \mathbb{R Q B}} \end{aligned}$ | $\mathrm{V}_{\text {OL }}$ | － | － | ＋0．4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=3.2 \mathrm{~mA} \\ & \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current（Sourcing Logic <br> PBO－PB7，CB2（Darlington Drive） | $\mathrm{IOH}^{\text {O}}$ | $\begin{aligned} & -200 \\ & -3.2 \\ & \hline \end{aligned}$ | $\begin{array}{r} -1500 \\ -6 \\ \hline \end{array}$ | － | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V} \end{aligned}$ |
| Output Low Current（Sinking） PAO－PA7，PB0－PB7，CB2，CA2 D0－D7，$\overline{\mathrm{RQQA}}, \overline{\mathrm{RQQB}}$ | 1 OL | $\begin{aligned} & 3.2 \\ & 1.6 \end{aligned}$ | － | － | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Output Leakage Current（Off State） IRQA，IRQB | Ioff | － | 1 | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ |  | 7 | 10 |  | mW／MHz |
| Input Capacitance D0－D7，PAO－PA7，PB0－PB7，CA2，CB2 R／ $\bar{W}$ ，$\overline{\text { RES }}$, RSO，RS1，CSO，CS1，$\overline{\text { CS2 }}$ CA1，CB1，$\emptyset 2$ | $\mathrm{C}_{\text {IN }}$ | 二 | － | $\begin{gathered} 10 \\ 7 \\ 20 \end{gathered}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V} \\ & V_{I N}=0 \mathrm{~V} \\ & \mathrm{f}=2 \mathrm{MHz} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUt }}$ | － | － | 10 | pF |  |
| Notes： <br> 1．All units are direct current（dc）except capacitance． <br> 2．Negative sign indicates outward current flow，positive indicates inward flow． <br> 3．Typical values are shown for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ ． |  |  |  |  |  |  |

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



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

40-PIN PLASTIC DIP


|  | MILLIMETERS |  |  | INCHES |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 51.28 | 52.32 | 2.040 | 2.060 |  |
| B | 13.72 | 14.22 | 0.540 | 0.560 |  |
| C | 3.55 | 5.08 | 0.140 | 0.200 |  |
| D | 0.36 | 0.51 | 0.014 | 0.020 |  |
| F | 1.02 | 1.52 | 0.040 | 0.060 |  |
| G | 2.54 | BSC | 0.100 |  | BSC |
| H | 1.65 | 2.16 | 0.065 | 0.085 |  |
| J | 0.20 | 0.30 | 0.008 | 0.012 |  |
| K | 3.05 | 3.56 | 0.120 | 0.140 |  |
| L | 15.24 | BSC | 0.600 |  | BSC |
| M | 7 | 10 |  |  | 10 |
| N | 0.51 | 1.02 | 0.020 | 0.040 |  |

## R65C24 PERIPHERAL INTERFACE ADAPTER/TIMER (PIAT)

## DESCRIPTION

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

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

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

## ORDERING INFORMATION

The R65C24 is available in both a ceramic and a plastic 40-pin package, a commercial or industrial temperature range, and operating frequencies of $1,2,3$, or 4 MHz . These versions are coded into the part number as follows:

## Part Number:

R65C24
LTemperature Range:
Blank $=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$
$E=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$
Frequency Range
$1=1 \mathrm{MHz}$
$2=2 \mathrm{MHz}$
$3=3 \mathrm{MHz}$
$4=4 \mathrm{MHz}$
-Package:
$C=$ Ceramic
$\mathrm{P}=$ Plastic

## FEATURES

- Low power CMOS N-well silicon gate technology
- Two 8-bit bidirectional I/O ports with individual data direction control
- Programmable 16 -bit Counter/Timer with eight modes of operation
- Three 8-bit latches associated with the Counter/Timer
- Selectable divide-by-sixteen prescaler for all modes
- Automatic "Handshake" control of data transfers
- Two interrupts (one for each port) with program control
- 1, 2, 3, and 4 MHz versions
- Commercial and industrial temperature range versions
- 40-pin plastic and ceramic versions
- Single $5 \mathrm{~V} \pm 5 \%$ supply requirements
- Compatible with the R6500, R6500/* and R65C00 family of microprocessors

| VSS | 40 | $\square \mathrm{CA1}$ |
| :---: | :---: | :---: |
| PAO | 39 | CA2 |
| PA1 ${ }^{\text {c }}$ | 38 | IRQ |
| PA2 - | 37 | $\square$ CNTR |
| PA3 5 | 36 | RSO |
| PA4 6 | 35 | RS1 |
| PA5 ${ }^{\text {P }}$ | 34 | RES |
| PA6 8 | 33 | D0 |
| PA7 ${ }^{\text {c }}$ | 32 | $\square \mathrm{D} 1$ |
| PBO- 10 | 31 | - D2 |
| PB1 다 11 | 30 | D3 |
| PB2 12 | 29 | D4 |
| PB3 ${ }^{\text {c }} 13$ | 28 | D5 |
| PB4 14 | 27 | D6 |
| PB5 15 | 26 | صD7 |
| PB6 16 | 25 |  |
| PB7 17 | 24 | RS2 |
| CB1- 18 | 23 | CS2 |
| CB2 [- 19 | 22 | CSO |
| vcc 20 | 21 | $\mathrm{R} / \overline{\mathrm{W}}$ |

Figure 1. R65C24 Pin Configuration

## FUNCTIONAL DESCRIPTION

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


Figure 2. R65C24 PIAT Block Diagram

## DATA INPUT REGISTER (DIR)

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

## CONTROL REGISTERS (CRA AND CRB)

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

## DATA DIRECTION REGISTERS (DDRA, DDRB)

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

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

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

## PERIPHERAL OUTPUT REGISTERS (ORA, ORB)

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

## INTERRUPT STATUS CONTROL (ISCA, ISCB)

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

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

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

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

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

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

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

Table 1. Control Registers Bit Designations

CRA
$\left.\begin{array}{|c|c|c|c|c|}\hline \mathbf{7} & \mathbf{6} & \mathbf{5} & \mathbf{4} & \mathbf{3} \\ \hline \text { IRQA1 } & \text { IRQA2 } & \text { CA2 Control } & \mathbf{2} & \mathbf{1} \\ \hline \mathbf{7} & \mathbf{6} & \mathbf{5} & \mathbf{4} & \mathbf{3} \\ \text { Access }\end{array}\right]$

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

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

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

The final characteristic is the high-impedance input state which is a function of the Peripheral B push-pull buffers. When the

Peripheral B $/ / O$ lines are programmed to act as inputs, the output buffer enters the high impedance state.

## DATA BUS BUFFERS (DBB)

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

## COUNTER/TIMER

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


Figure 3. Counter/Timer

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

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

Disable Counter/Timer<br>One-Shot Interval Timer<br>Free-Run Interval Timer<br>Pulse Width Measurement<br>Event Counter<br>One-Shot Pulse Width Generation<br>Free-Run Pulse Generation<br>Retriggerable Interval Timer

Bit 7 of the CMCR determines whether the $\overline{\mathrm{RQT}}$ line is enabled or disabled for generating an interrupt request on the $\overline{\mathrm{RQ}}$ output to the processor. When bit 7 is set to a $1, \overline{\mathrm{RQT}}$ is enabled so that an Underflow Flag (UF bit in the Status Register set to a 1) will cause $\overline{\mathrm{RQ}}$ to be asserted. When bit 7 is set to a 0 , the $\overline{\mathrm{IRQT}}$ is disabled.

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

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

## INTERFACE SIGNALS

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

The PIAT interfaces to the peripheral devices with four interrupt/ control lines and two 8 -bit bidirectional data buses. A Counter/ Timer input/output line (CNTR) also interfaces to a peripheral device.

Figure 1 (on the front page) shows the pin assignments for these interface signals and Figure 4 shows the interface relationship of these signal as they pertain to the CPU and the peripheral devices.

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

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

## Note:

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


Figure 4. Interface Signals Relationship

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

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

## CLOCK SIGNAL ( $\phi_{2}$ )

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

## READ/WRITE SIGNAL (R/W)

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

## REGISTER SELECT (RS0, RS1, RS2)

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

Note:
In order to address the ORA and ORB Registers in the PIAT, Register Select line RS2 must be high. When RS2 is low, the Counter/Timer registers are selected (as shown in Table 3).

Table 2. Peripheral Register Addressing

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

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

Table 3. Counter/Timer Register Addressing

| Register Address (Hex) | Register Select Lines |  |  | Counter/Timer Operation |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS2 | RS1 | RSO | $(\mathrm{R} / \overline{\mathrm{W}}=\mathrm{H}$ ) | ( $\mathrm{R} / \overline{\mathbf{W}}=\mathrm{L}$ ) |
| 0 | L | L | L | Read Snapshot Latch (SL) SL $\rightarrow$ D0-D7 $0 \rightarrow$ UF | Write Upper Latch (UL) $\begin{aligned} \text { DO-D7 } & \rightarrow U L \\ 0 & \rightarrow U F \end{aligned}$ <br> Load and Enable Counter <br> $\mathrm{UL} \rightarrow \mathrm{UC}$, <br> LL $\rightarrow$ LC |
| 1 | L | L | H | $\begin{aligned} & \text { Read Upper } \\ & \text { Counter (UC) } \\ & \text { UC } \rightarrow \text { DO-D7 } \end{aligned}$ | Write Upper Latch (UL) D0-D7 $\rightarrow$ UL |
| 2 | L | H | L | $\begin{aligned} & \text { Read Lower } \\ & \quad \text { Counter (LC) } \\ & \mathrm{LC} \rightarrow \mathrm{DO} \text {-D7 } \\ & \mathrm{UC} \rightarrow \mathrm{SL} \end{aligned}$ | Write Lower Latch (LL) $\begin{aligned} \mathrm{DO} \mathrm{D} 7 & \rightarrow \mathrm{LL} \\ \mathrm{UC} & \rightarrow \mathrm{SL} \end{aligned}$ |
| 3 | L | H | H | $\begin{gathered} \text { Read Status } \\ \text { Register (SR) } \\ \mathrm{SR} \rightarrow \mathrm{DO}-\mathrm{DT} \\ 0 \rightarrow \mathrm{UF} \end{gathered}$ | Write Counter Control Mode Register (CMCR) D0-D7 $\rightarrow$ CMCR |

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

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

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

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

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

Control of $\overline{\mathrm{IRQB}}$ is performed in exactly the same manner as that described above for $\overline{\mathrm{RQA}}$. Bit 7 in CRB (IRQB1) is set by an active transition on CB1 and IRQB from this flag is controlled by CRB bit 0 . Likewise, bit 6 (IRQB2) in CRB is set by an active transition on CB2, and $\overline{\mathrm{RQB}}$ from this flag is controlled by CRB bit 3.

Also, both bit 6 and bit 7 of CRB are reset by a "Read Peripheral B Output Register" operation. A summary of $\overline{\mathrm{IRQB}}$ control is shown in Table 4.

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

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

The flags act as the link between the peripheral interrupt signals and the processor interrupt inputs. The interrupt disable bits allow the processor to control the interrupt function.
$\overline{\text { IRQT }}$ Line-The internal $\overline{\text { IRQT }}$ line is associated with the Counter/Timer and is controlled by the $\overline{\mathrm{IRQT}}$ Enable bit in the Counter Mode Control Register and the Underflow Flag in the Status Register. A thorough discussion of the functions and operation of the IRQT line is given in the Counter/Timer Operation section of this product description.

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

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

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

## Note:

A negative transition is defined as a transition from a high to a low, and a positive transition is defined as a transition from a low to a high voltage.

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

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

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

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

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

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

CA2 INPUT MODE (BIT $5=0$ CONTROL REGISTER A (CRA)

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

CA2 OUTPUT MODE (BIT $5=1$ )

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

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


## CA2 INPUT MODE (BIT $5=0$ )

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

CA2 OUTPUT MODE (BIT $5=1$ )

| Bit 6 <br> 0 | NOT USED <br> Always zero. |
| :---: | :--- |
| Bit 5 | CA2 MODE SELECT |
| 1 |  |$\quad$| Select CA2 Output Mode. |
| :--- |
| Bit 4 |
| 1 |$\quad$| CA2 OUTPUT CONTROL |
| :--- |
| 0 |$\quad$| CA2 goes low when a zero is written into CRA bit 3. CA2 goes high when a one is written into CRA bit 3. 3. |
| :--- |
| by bit 3. |

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

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

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

CB2 OUTPUT MODE (BIT 5 = 1)

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

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

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

CB2 INPUT MODE (BIT $5=0$ )

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

CB2 OUTPUT MODE (BIT 5 = 1)

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

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

## COUNTER/TIMER REGISTERS

## COUNTER MODE CONTROL REGISTER (CMCR)

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

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


| Bit 7 | $\overline{\text { IRQT }}$ Enabled |
| :---: | :---: |
| 0 | $\frac{\overline{\mid R Q T}}{}$ Disabled |
| 1 | $\overline{\text { IRQT }}$ Enabled |

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

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

Bit 3 Not used, don't care value during write.
Bits 2-0 Counter/Timer Mode

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

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

## STATUS REGISTER (SR)

The 8-bit Status Register (SR) reports the status of two interrupt conditions: Counter underflow (IRQT) and Port A interrupt (IRQA). The format of the Status Register is:

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


| Bit 7 | Counter Underflow (UF) Interrupt Flag |
| :---: | :--- |
| 0 | Counter underflow has not occurred. |
| 1 | Counter underflow has occurred. |
| Bit 6 | IRQA Interrupt Flag |
| 0 | Port A interrupt has not occurred. <br> 1 |
| Port A interrupt has not occurred. |  |
| Bit 5-0 | Not used, always read as shown in register <br> figure. |

The Counter underflow (UF), bit 7 , is updated in the same clock cycle that an underflow condition occurs on the Counter/Timer. The IRQA interrupt flag (bit 6) is updated at the rising edge of the next $\varnothing_{2}$ clock immediately following the setting of corresponding interrupt bits (IRQA1, IRQA2) in the CRA register. IRQA is set whenever IRQA1 or IRQA2 is set. The underflow bit is cleared whenever the Status Register is read, the Snapshot Latch is read, the UL is written to at register address 0 , Mode 0 is selected in the CMCR, or a RES occurs. Reading the Status Register also clears the $\overline{1 R Q A}$ interrupt flag. The Status Register is read when the register address is 3 and $R / \bar{W}$ is high.

## LOWER LATCH (LL)

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

## UPPER LATCH (UL)

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

## Register Address 0

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

## Register Address 1

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

## LOWER COUNTER (LC)

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

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

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

## UPPER COUNTER

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

## Note:

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

## SNAPSHOT LATCH (SL)

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

## COUNTER/TIMER OPERATION

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

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

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

## MODE 0-DISABLE COUNTER/TIMER

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

## MODE 1-ONE SHOT INTERVAL TIMER

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

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

## MODE 2-FREE-RUN INTERVAL TIMER

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

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


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


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

## MODE 3-PULSE WIDTH MEASUREMENT

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

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

## MODE 4-EVENT COUNTER

CNTR is an input and the Counter/Timer counts the number of positive transitions on CNTR. The counter is initially loaded with the UL and LL value when the UL is written to register address 0 . The counter then decrements one count on the rising edge of the $\varnothing 2$ clock after a rising edge (low to high transition) is detected on the CNTR input (as scaled by the Prescaler). The maximum rate at which this rising edge can be detected is onehalf the $\phi 2$ clock rate. When the counter decrements below $\$ 0000$, the UF bit in the SR is set, the counter is reloaded with the UL and LL value and the operation repeats. Figure 9 shows the timing relationship of a Mode 4 operation.

Typical Application: Can be used with a timed software loop to count external events (i.e., a frequency counter).


Figure 8. Mode 3-Pulse Width Measurement Timing


Figure 9. Mode 4-Event Counter Timing

## MODE 5-ONE-SHOT PULSE WIDTH GENERATION

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

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

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

## MODE 6-FREE-RUN PULSE GENERATION

CNTR is an output and the Counter/Timer can be programmed to generate a symmetrical waveform, an asymmetrical waveform, or a string of varying width pulses on CNTR. The CNTR line is forced low (if high upon mode selection) or remains low
(if low upon mode selection) when data is written to the UL at register address 0 which also starts the counter. The counter decrements at the $\varnothing 2$ clock rate as scaled by the Prescaler. When the counter decrements below \$0000, CNTR toggles from low to high (or high to low deperiding upon its initial state), the counter is reloaded with the UL and LL value and the counter continues down-counting. The UF bit in the SR is set the first time the counter decrements past $\$ 0000$ and is cleared only if a new write to UL at register address 0 occurs. Figure 11 shows the timing relationship of a Mode 6 operation.

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

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


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


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

## MODE 7-RETRIGGERABLE INTERVAL TIMER

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

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

## PRESCALER

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

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

## INITIALIZING THE COUNTER/TIMER

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

| SL | $=\$ X X X 0$ | ;Snapshot Latch |
| :--- | :--- | :--- |
| UC | \$ \$XXX1 | ;Upper Counter |
| LC | $=\$ X X X 2$ | ;Lower Counter |
| SR | $=\$ X X X 3$ | ;Status Register |
| ULEC | $=\$ X X X 0$ | ;Upper Latch and Enable Counter |
| UL | $=\$ X X X 1$ | ;Upper Latch |
| LL | $=\$ X X X 2$ | ;Lower Latch |
| CMCR | $=\$ X X X 3$ | ;Counter Mode Control Register |

## ;Program

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


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

The following instructions is a way to change modes while the Counter/Timer is in operation:

| LDA | \#\$mode | ;select desired mode, except |
| :---: | :---: | :---: |
| STA | CMCR | ;write to mode register |

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

## READING THE COUNTER/TIMER

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

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

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

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

LDA \$LC ; get low counter value ;upper counter transferred to snapshot
;any miscellaneous code to store value if desired
LDA $\$$ SL ;get high counter value

## READ/WRITE TIMING CHARACTERISTICS OF PIAT

Figure 12 is a timing diagram for the R65C24 PIAT during a Read operation (input mode). Figure 13 is a timing diagram for the PIAT during a Write operation (output mode). Table 5 shows the characteristics of the times shown in Figures 12 and 13.


Figure 12. Mode 7-Retriggerable Interval Timer Timing


Figure 13. Read Timing Diagram


Figure 14. Write Timing Diagram

## READING THE PERIPHERAL A I/O PORT

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

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

## READING THE PERIPHERAL B I/O PORT

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

## BUS TIMING CHARACTERISTICS

| Parameter | Symbol | 1MHz |  | 2MHz |  | 3 MHz |  | 4MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| ¢2 Cycle | $\mathrm{T}_{\text {CYC }}$ | 1.0 | - | 0.5 | - | 0.33 | - | 0.25 | - | $\mu \mathrm{s}$ |
| ¢2 Pulse Width | $\mathrm{t}_{\mathrm{c}}$ | 480 | - | 240 | - | 180 | - | 120 | - | ns |
| $\phi 2$ Rise and Fall Time | $\mathrm{trc}_{\mathrm{cc}}, \mathrm{t}_{\mathrm{fc}}$ | - | 25 | - | 15 | - | 12 | - | 10 | ns |

READ TIMING

| Address Set-Up Time | $t_{A C R}$ | 140 | - | 70 | - | 53 | - | 35 | - | $n s$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address Hold Time | $t_{C A R}$ | 0 | - | 0 | - | 0 | - | 0 | - | $n s$ |
| Peripheral Data Set-Up Time | $\mathrm{t}_{\text {PCR }}$ | 300 | - | 150 | - | 110 | - | 75 | - | ns |
| Data Bus Delay Time | $\mathrm{t}_{\mathrm{CDR}}$ | - | 395 | - | 190 | - | 100 | - | 75 | ns |
| Data Bus Hold Time | $\mathrm{t}_{\mathrm{HR}}$ | 20 | - | 20 | - | 20 | - | 20 | - | ns |

## WRITE TIMING

| Address Set-Up Time | $\mathrm{t}_{\text {ACW }}$ | 140 | - | 70 | - | 53 | - | 53 | - | ns |
| :--- | ---: | ---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address Hold Time | $\mathrm{t}_{\text {CAW }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $\mathrm{R} \bar{W}$ Set-Up Time | $\mathrm{t}_{\text {WCW }}$ | 180 | - | 90 | - | 67 | - | 45 | - | ns |
| $\mathrm{R} \overline{\bar{W}}$ Hold Time | $\mathrm{t}_{\text {CWW }}$ | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| Data Bus Set-Up Time | $\mathrm{t}_{\text {DCW }}$ | 180 | - | 90 | - | 67 | - | 45 | - | ns |
| Data Bus Hold Time | $\mathrm{t}_{\text {HW }}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| Peripheral Data Delay Time | $\mathrm{t}_{\text {CPW }}$ | - | 1.0 | - | 0.5 | - | 0.33 | - | 0.25 | $\mu \mathrm{~s}$ |
| Peripheral Data Delay Time <br> to CMOS Level | $\mathrm{t}_{\text {CMOS }}$ | - | 2.0 | - | 1.0 | - | 0.7 | - | 0.5 | $\mu \mathrm{~s}$ |

## PERIPHERAL INTERFACE TIMING

| Parameter | Symbol | 1 MHz |  | $\mathbf{2 M H z}$ |  | 3 MHz |  | 4MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| Peripheral Data Setup | $t_{\text {PCR }}$ | 300 | - | 150 | - | 110 | - | 75 | - | ns |
| ¢2 Low to CA2 Low Delay | $\mathrm{t}_{\mathrm{CA} 2}$ | - | 1.0 | - | 0.5 | - | 0.33 | - | 0.25 | $\mu \mathrm{S}$ |
| ¢2 Low to CA2 High Delay | $\mathrm{t}_{\mathrm{RSI} 1}$ | - | 1.0 | - | 0.5 | - | 0.33 | - | 0.25 | $\mu \mathrm{S}$ |
| CA1 Active to CA2 High Delay | $\mathrm{t}_{\mathrm{RS} 2}$ | - | 2.0 | - | 1.0 | - | 0.67 | - | 0.5 | $\mu \mathrm{S}$ |
| ¢2 High to CB2 Low Delay | $\mathrm{t}_{\mathrm{CB} 2}$ | - | 1.0 | - | 0.5 | - | 0.33 | - | 0.25 | $\mu \mathrm{s}$ |
| Peripheral Data Valid to CB2 Low Delay | $\mathrm{t}_{\mathrm{DC}}$ | 0 | 1.5 | 0 | 0.75 | 0 | 0.5 | 0 | 0.37 | $\mu \mathrm{S}$ |
| ¢2 High to CB2 Hgh Delay | $t_{\text {RS } 1}$ | - | 1.0 | - | 0.5 | - | 0.33 | - | 0.25 | $\mu \mathrm{s}$ |
| CB1 Active to CB2 High Delay | $t_{\text {RS2 }}$ | - | 2.0 | - | 1.0 | - | 0.67 | - | 0.5 | $\mu \mathrm{s}$ |
| CA1, CA2, CB1 and CB2 Input Rise and Fall Time | $t_{r}, t_{f}$ | - | 1.0 | - | 1.0 | - | 1.0 | - | 1.0 | $\mu \mathrm{S}$ |

## ABSOLUTE MAXIMUM RATINGS*

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

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

## OPERATING CONDITIONS

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

## DC CHARACTERISTICS

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

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

## PACKAGE DIMENSIONS

40-PIN CERAMIC DIP


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

40-PIN PLASTIC DIP


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

ASYNCHRONOUS COMMUNICATIONS
INTERFACE ADAPTER (ACIA)

## PRELIMINARY

## DESCRIPTION

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

The ACIA has an internal baud rate generator. This feature eliminates the need for multiple component support circuits, a crystal being the only other part required. The Transmitter baud rate can be selected under program control to be 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 ACIA has programmable word lengths of $5,6,7$, or 8 bits; even; odd, or no parity; $1,11 / 2$, or 2 stop bits.

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

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

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

The Status Register indicates the states of the $\overline{\mathrm{RQ}}, \overline{\mathrm{DSR}}$, and $\overline{D C D}$ lines, Transmitter and Receiver Data Registers, and Overrun, Framing, and Parity Error conditions.

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

## ORDERING INFORMATION



## FEATURES

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


Figure 1. R65C51 ACIA Pin Configuration


Figure 2. ACIA Internal Organization

## FUNCTIONAL DESCRIPTION

A block diagram of the ACIA is presented in Figure 2 followed by a description of each functional element of the device.

## 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 $\mathrm{R} / \overline{\mathrm{W}}$ line is high and the chip is selected, the Data Bus Buffer passes the data from the system data lines to the ACIA 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.

## INTERRUPT LOGIC

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

## I/O CONTROL

The I/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 Receiver Select (RS1, RSO) and Read/Write (R/W) lines as described later in Table 1.

## 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 $\varnothing 2$ clock input. The chip will perform data transfers to or from the microcomputer data bus during the $\varnothing 2$ high period when selected.

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

## TRANSMITTER AND RECEIVER DATA REGISTERS

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

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

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.

## STATUS REGISTER

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


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

*No interrupt occurs for these conditions

## Reset Initialization



Hardware reset
Program reset

## Parity Error (Bit 0), Framing Error (Bit 1), and

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

## Receiver Data Register Full (Bit 3)

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

## Transmitter Data Register Empty (Bit 4)

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

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

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

## Interrupt (Bit 7)

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

## CONTROL REGISTER

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


$$
\begin{array}{cl}
\hline \text { Bit } 7 & \text { Stop Bit Number (SBN) } \\
0 & 1 \text { Stop bit } \\
1 & 2 \text { Stop bits } \\
1 & 11 / 2 \text { Stop bits } \\
& \text { For WL }=5 \text { and no parity } \\
1 & 1 \text { Stop bit } \\
& \text { For WL }=8 \text { and parity }
\end{array}
$$

Bits 6.5 Word Length (WL)

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


| Bit 4 | Receiver Clock Source (RCS) |
| :---: | :--- |
| 0 | External receiver clock |
| 1 | Baud rate |

Bits 3-0 Selected Baud Rate (SBR)

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

## Reset Initialization

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| - | - | - | - | - | - | - | - |
| Hardware reset ( $\overline{\text { RES }}$ ) |  |  |  |  |  |  |  |
| Program reset |  |  |  |  |  |  |  |

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

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

If the Receiver clock uses the same baud rate as the transmitter, then RxC becomes an output and can be used to slave other circuits to the ACIA. Figure 3 shows the Transmitter and Receiver layout.


Figure 3. Transmitter/Receiver Clock Circuits

## Receiver Clock Source (Bit 4)

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

## Word Length (Bits 5, 6)

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

## Stop Bit Number (Bit 7)

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

## COMMAND REGISTER

The Command Register controls specific modes and functions.

| 76 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PMC | PME | REM | Tic |  | IRD | DTR |
| PNC1/PNCO |  |  | TIC1 | TICO |  |  |


| Bits 7-6 | Parity Mode Control (PMC) |
| :---: | :---: |
| 76 |  |
| 00 | Odd parity transmitted/received |
| 0 | Even parity transmitted/received |
| 10 | Mark parity bit transmitted |
|  | Parity check disabled |
| 11 | Space parity bit transmitted |
|  | Parity check disabled |
| Bit 5 | Parity Mode Enabled (PME) |
| 0 | Parity mode disabled |
|  | No parity bit generated |
|  | Parity check disabled |
| 1 | Parity mode enabled |
| Bit 4 | Receiver Echo Mode (REM) |
| 0 | Receiver normal mode |
| 1 | Receiver echo mode bits 2 and 3 |
|  | Must be zero for receiver echo mode, RTS will be low. |

Bits 3-2 Transmitter Interrupt Control (TIC)

| $\frac{3}{0}$ | $\frac{2}{0}$ | $\overline{\text { RTS }}$ | $=$ High, transmit interrupt disabled |
| :---: | :---: | :---: | :---: |
| 0 | 1 | $\overline{\text { RTS }}=$ | Low, transmit interrupt enabled |
| 1 | 0 | $\overline{\text { RTS }}=$ | Low, transmit interrupt disabled |
| 1 | 1 | $\overline{\text { RTS }}=$$=$ Low, transmit interrupt disabled <br>   <br>   |  |
|  |  |  |  |


| Bit 1 | Interrupt Request Disabled (IRD) |
| :---: | :--- |
| 0 | $\frac{\mathrm{IRQ}}{\text { enabled }}$ |
| 1 | $\overline{\mathrm{IRQ}}$ disabled |
| Bit 0 | Data Terminal Ready (DTR) |
| 0 | Data terminal not ready $\overline{\text { (DTR }}$ high) |
| 1 | Data terminal ready (DTR low) |

## Reset Initialization

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Hardware reset (RES) |  |  |  |  |  |  |  |
| - | - | - | 0 | 0 | 0 | 0 | 0 |

## INTERFACE SIGNALS

Figure 4 shows the ACIA interface signals associated with the microprocessor and the modem.


Figure 4. ACIA Interface Diagram

## MICROPROCESSOR INTERFACE

## Reset (RES)

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

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

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

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

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

## Interrupt Request (IRQ)

The $\overline{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{RQ}}$ microprocessor input. Normally a high level, $\overline{\mathrm{IRQ}}$ goes low when an interrupt occurs.

## Data Bus (D0-D7)

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

## Chip Selects (CS0, CS1)

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

## Register Selects (RSO, RS1)

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

Table 1. ACIA Register Selection

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

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

## ACIA/MODEM INTERFACE

## Crystal Pins (XTLI, XTLO)

These pins are normally directly connected to the external crystal ( 1.8432 MHz ) to derive the various baud rates. Alternatively, an externally generated clock can drive the XTLI pin, in which case the XTLO pin must float. XTLI is the input pin for the transmit clock.

## Transmit Data (TxD)

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

## Receive Data (RxD)

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

## Receive Clock (RxC)

The RxC is a bi-directional pin which is either the receiver 16x 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.

Request to Send ( $\overline{\mathrm{RTS}}$ )
The RTS output pin controls the modem from the processor. The state of the RTS pin is determined by the contents of the Command Register.

## Clear to Send (CTS)

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

## Data Terminal Ready (ITR)

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

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

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

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

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

## TRANSMITTER AND RECEIVER OPERATION

## Continuous Data Transmit

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

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


Figure 5. Continuous Data Transmit

## Continuous Data Receive

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


Figure 6. Continuous Data Receive

## Transmit Data Register Not Loaded by Processor

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

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


Figure 7. Transmit Data Register Not Loaded by Processor

## Effect of $\overline{\text { CTS }}$ on Transmitter

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


Figure 8. Effect of CTS on Transmitter

## Effect of Overrun on Receiver

If the processor does not read the Receiver data Register in the allocated time, 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 9 shows the timing relationship for this mode.


Figure 9. Effect of Overrun on Receiver

## Echo Mode Timing

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


Figure 10. Echo Mode Timing

## Effect of CTS on Echo Mode Operation

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


Figure 11. Effect of CTS on Echo Mode

## Overrun In Echo Mode

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


Figure 12. Overrun in Echo Mode

## Framing Error

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


Figure 13. Framing Error

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

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

Once such a change of state occurs, subsequent transitions will not cause interrupts or changes in the Status Register until the first interrupt is serviced. When the Status Register is read by the processor, the ACIA automatically checks the level of the $\overline{D C D}$ line, and if it has changed, another $\overline{\mathrm{RQ}}$ occurs (see Figure 14).


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

## Timing with $11 / 2$ Stop Bits

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


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

## Transmit Continuous "BREAK"

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

## Note

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


Figure 16. Transmit Continuous "BREAK"

## Receive Continuous "BREAK"

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


Figure 17. Receive Continuous "BREAK"

## STATUS REGISTER OPERATION

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

## 1. Read Status Register

This operation automatically clears Bit 7 ( $\overline{\mathrm{RQQ}})$. Subsequent transitions on $\overline{\mathrm{DSR}}$ and $\overline{\mathrm{DCD}}$ will cause another interrupt.
2. Check $\overline{\mathrm{RQ}}$ (Bit 7) in the data read from the Status Register

If not set, the interrupt source is not the ACIA.
3. Check $\overline{\mathrm{DCD}}$ and $\overline{\mathrm{DSR}}$

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

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

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

## PROGRAM RESET OPERATION

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

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

## MISCELLANEOUS

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

## GENERATION OF NON-STANDARD BAUD RATES

## Divisors

The internal counter/divider circuit selects the appropriate divisor for the crystal frequency by means of bits 0-3 of the ACIA Control Register, as shown in Table 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 ACIA with an off-chip oscillator to achieve other baud rates. In this case, XTALI (pin 6 ) must be the clock input and XTALO (pin 7) must be a noconnect.

Table 2. Divisor Selection

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

## DIAGNOSTIC LOOP-BACK OPERATING MODES

A simplified block diagram for a system incorporating an ACIA is shown in Figure 18.

It may be desirable to include in the system a facility for "loopback" 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 ACIA does not contain automatic loop-back operating modes, but they may be implemented with the addition of a small amount of external circuitry. Figure 19 indicates the necessary logic to be used with the ACIA. The LLB line is the pos-itive-true signal to enable local loop-back operation. Essentially, LLB $=$ high does the following:

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

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

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 1, so that the transmitter clock equals the 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{\mathrm{RQ}}$ 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.


Figure 18. Simplified System Diagram


Figure 19. Loop-Back Circuit Schematic

## READ TIMING DIAGRAM

Timing diagrams for transmit with external clock, receive with external clock, and IRQ generation are shown in Figures 20, 21 and 22, respectively. The corresponding timing characteristics are listed in Table 3.

Table 3. Transmit/Receive Characteristics

| Characteristic | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Transmit/Receive Clock Rate | ${ }^{\text {tecr }}$ | 400* | - | 400* | - | ns |
| Transmit/Receive Clock High Time | $\mathrm{t}_{\mathrm{CH}}$ | 175 | - | 175 | - | ns |
| Transmit/Receive Clock Low Time | $\mathrm{t}_{\mathrm{CL}}$ | 175 | - | 175 | - | ns |
| XTLI to TXD Propagation Delay | $t_{D D}$ | - | 500 | - | 500 | ns |
| RTS Propagation Delay | $\mathrm{t}_{\mathrm{DLY}}$ | - | 500 | - | 500 | ns |
| $\overline{\mathrm{IRQ}}$ Propagation Delay (Clear) | $\mathrm{t}_{\text {IRQ }}$ | - | 500 | - | 500 | ns |

Notes:
( $\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}=10$ to 30 ns )
*The baud rate with external clocking is: Baud Rate $=\frac{1}{16 \times \mathrm{t}_{\mathrm{CCr}}}$


2

Figure 20. Transmit Timing with External Clock


Figure 21. Receive External Clock Timing


Figure 22. Interrupt and Output Timing

## AC CHARACTERISTICS

| Parameter | Symbol | 2 MHz |  | 4 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| \$2 Cycle Time | $\mathrm{t}_{\mathrm{cYC}}$ | 500 | - | 250 | - | ns |
| \$2 Pulse Width | $\mathrm{t}_{6}$ | 200 | - | 100 | - | ns |
| Address Set-Up Time | $t_{A C}$ | 60 | - | 30 | - | ns |
| Address Hold Time | $\mathrm{t}_{\text {CAH }}$ | 0 | - | 0 | - | ns |
| R/W Set-Up Time | ${ }^{\text {tw }}$ c | 60 | - | 30 | - | ns |
| $\mathrm{R} \overline{\mathrm{W}}$ Hold Time | $\mathrm{t}_{\text {cWh }}$ | 0 | - | 0 | - | ns |
| Data Bus Set-Up Time | $t_{\text {dCW }}$ | 60 | - | 35 | - | ns |
| Data Bus Hold Time | $\mathrm{t}_{\mathrm{HW}}$ | 10 | - | 5 | - | ns |
| Read Access Time (Valid Data) | $\mathrm{t}_{\text {CDR }}$ | - | 150 | - | 50 | ns |
| Read Hold Time | $\mathrm{t}_{\text {HR }}$ | 10 | - | 10 | - | ns |
| Bus Active Time (Invalid Data) | $t_{\text {cDA }}$ | 20 | - | 10 | - | ns |

## Notes:

1. $V_{C C}=5.0 \mathrm{~V} \pm 5 \%$.
2. $T_{A}=T_{L}$ to $T_{H}$.
3. $t_{R}$ and $t_{F}=10$ to 30 ns .


Figure 23. Write Timing Diagram


Figure 24. Read Timing Characteristics

## ABSOLUTE MAXIMUM RATINGS*

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

## OPERATING CONDITIONS

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

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

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min | Typ | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\text {IH }}$ | 2.0 | - | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | -0.3 | - | +0.8 | V |  |
| Input Leakage Current: <br>  | IN | - | $\pm 1$ | $\pm 2.5$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{iN}}=0 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{Cc}} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current (Three State Off) D0-D7 | $\mathrm{I}_{\text {TSI }}$ | - | $\pm 2$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage: DO-D7, TxD, RxC, $\overline{\text { RTS }}, \overline{\text { DTR }}$ | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | - | V | $\begin{aligned} & V_{C C}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \end{aligned}$ |
| Output Low Voltage: D0-D7, TxD, RxC, $\overline{R T S}, \overline{D T R}, \overline{\mathrm{IRQ}}$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing): D0-D7, TxD, RxC, RTS, DTR | $\mathrm{IOH}^{\text {I }}$ | -200 | -400 | - | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}$ |
| Output Low Current (Sinking): D0-D7, TxD, RxC, $\overline{\text { RTS }}, \overline{D T R}, \overline{\mathrm{IRQ}}$ | lol | 1.6 | - | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Output Leakage Current (off state): $\overline{\mathrm{IRQ}}$ | loff | - |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.0 \mathrm{~V}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | - | 7 | 10 | mW/MHz |  |
| Input Capacitance All except $\emptyset_{2}$ $\emptyset 2$ | $\begin{aligned} & \mathrm{C}_{\mathrm{CLK}} \\ & \mathrm{C}_{\mathrm{IN}} \end{aligned}$ | - |  | $\begin{aligned} & 20 \\ & 10 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V} \\ & V_{I N}=0 \mathrm{~V} \\ & f^{2}=2 \mathrm{MHZ} \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | - |  | 10 | pF |  |
| Notes: <br> 1. All units are direct current (dc) except for capacitance. <br> 2. Negative sign indicates outward current flow, positive indica <br> 3. Typical values are shown for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{TA}=25^{\circ} \mathrm{C}$. | inward |  |  |  |  |  |

## PACKAGE DIMENSIONS



## R65C52 <br> DUAL ASYNCHRONOUS COMMUNICATIONS INTERFACE ADAPTER (DACIA)

## PRELIMINARY

## DESCRIPTION

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

The DACIA 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 38,400 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 DACIA is programmable for word lengths of 5,6 , 7 or 8 bits; even, odd, or no parity; and 1 or 2 stop bits.

The DACIA is designed for maximum programmed control from the microprocessor (MPU) to simplify hardware implementation. Dual sets of registers allow independent control and monitoring of each channel. The DACIA also provides a unique, programmable Automatic Address Recognition Mode for use in a multidrop environment.

The Control Register and Status Register permit the MPU to easily select the R65C52's operating modes and determine operational status.

The Interrupt Enable Registers (IER) and Interrupt Status Registers (ISR) allow the MPU to control and monitor the interrupt capabilities of the DACIA.

The Control and Format Register (CFR) permits selection of baud rates, word lengths, parity and stop bits as well as control of DTR and RTS output signals.

The Status Register (SR) gives the MPU access to the state of the modem control lines, framing error, transmitter underrun and break conditions.

The Compare Data Registers (CDR) hold the data value to be used in the compare mode and the Transmit Break Register (TBR) commands a Transmit Break and provides for parity/address recognition, for Automatic Address Mode.

The Transmitter Data Register and Receiver Data Register are used for temporary data storage of input and output data.

## FEATURES

- Low power CMOS N -well silicon gate technology
- Two independent full duplex channels with buffered receivers and transmitters.
- Data set/modem control functions
- Internal baud rate generator with 15 programmable baud rates $(50$ to 38,400 )
- Program-selectable internally or externally controlled receiver rate
- Programmable word lengths, number of stop bits, and parity bit generation and detection
- Programmable interrupt control
- Programmable control of edge detect for DCD, DSR, DTR, RTS, and CTS
- Program-selectable serial echo mode for each channel
- Automatic Address Recognition Mode for multi-drop operation.
- Up to 4 MHz host bus operation
- 5.0 Vdc $\pm 5 \%$ supply requirements
- 40-pin plastic or ceramic DIP
- Full TTL or CMOS input/output compatibility
- Compatible with R6500 and R65C00 microprocessors and R6500/* microcomputers.


## ORDERING INFORMATION

Part Number:
R65C52


*Note: Must be tied to $\mathbf{V}_{\mathbf{c c}}$.
Figure 1. R65C52 Pin Configuration

## INTERFACE SIGNALS

Figure 2 shows the DACIA interface signals associated with the microprocessor and the modem.

## DATA BUS (D0-D7)

The D0-D7 pins are eight data lines that transfer data between the microprocessor (MPU) and the DACIA. These lines are bidirectional and are normally high-impedance except during READ cycle when the DACIA is selected.

REGISTER SELECTS (RS0, RS1, RS2)
The three register select lines are normally connected to the processor address lines to allow the MPU to select the various internal registers. Table 1 shows the internal register select coding and identifies the abbreviations (ABBR) used throughout the text for each register.

## READ/WRITE (R/W)

The $R \bar{W}$ input, generated by the microprocessor, controls the direction of data transfer. A high on the $R \bar{W}$ line indicates a read cycle, while a low indicates a write cycle.

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

The chip select input is normally connected to the processor address lines either directly or through decoders. The DACIA latches address and $\mathrm{R} \overline{\mathrm{W}}$ inputs on the falling edge of $\overline{\mathrm{CS}}$ and latches the data bus inputs on the rising edge of $\overline{C S}$.

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

During system initialization a low level on the $\overline{\operatorname{RES}}$ input causes a RESET to occur. At this time the IER's are set to $\$ 80$, the DTR and $\overline{\text { RTS }}$ lines go to the high state, the RDR register is cleared, the TBR is set to $\$ 0 F$, the compare mode is disabled, and the CTS, $\overline{D C D}, \overline{D S R}$ flags are cleared. No other bits are affected.

TRANSMIT DATA (TXD1, TXD2)
The TxD outputs transfer serial non-return to zero (NRZ) data to the data communications equipment (DCE). The data is transferred, LSB first, at a rate determined by the baud rate generator.

RECEIVE DATA (RXD1, RXD2)
The RxD inputs transfer serial NRZ data into the DACIA from the DCE, LSB first. The receiver baud rate is determined by the baud rate generator.


Figure 2. DACIA Interface Signals

## CLEAR TO SEND (ㄷTS1, $\overline{\text { CTS2 }})$

The $\overline{C T S}$ control line inputs allow handshaking by the transmitter. When $\overline{\mathrm{CTS}}$ is low, the data is transmitted continuously. When $\overline{\mathrm{CTS}}$ is high, the Transmit Data Register empty bit in the ISR is not set. The word presently in the Transmit Shift Register is sent normally. Any active transition on the CTS lines sets the CTS bit in the appropriate ISR. The CTS status bit in the CSR reflects the current high or low state of CTS.

## DATA CARRIER DETECT ( $\overline{\text { CDD1 }}, \overline{\mathrm{DCD2}}$ )

These two lines may be used as general purpose inputs. An active transition sets the $\overline{\mathrm{DCD}}$ bit in the ISR. The $\overline{\mathrm{DCD}}$ bit in the CSR reflects the current state of the $\overline{\mathrm{DCD}}$ line.

## DATA SET READY ( $\overline{\text { DSR1 }}, \overline{\text { DSR2 }})$

These two lines may be used as general purpose inputs. An active transition sets the $\overline{\mathrm{DSR}}$ bit in the IȘR. The $\overline{\mathrm{DSR}}$ bit in the CSR reflects the current state of the $\overline{\mathrm{DSR}}$ line.

## REQUEST TO SEND ( $\overline{\mathrm{RTS} 1}, \overline{\mathrm{RTS} 2}$ )

These two lines may be used as general purpose outputs. They are set high upon reset. Their state may be programmed by setting the appropriate bits in the CFR high or low. The state of the $\overline{R T S}$ line is reflected by the $\overline{R T S}$ bit in the CSR.

DATA TERMINAL READY ( $\overline{\mathrm{DTR1}}, \overline{\mathrm{DTR2}}$ )
These two lines may be used as general purpose outputs. They are set high upon reset. Their state may be programmed by setting the appropriate bits in the CFR high or low. The state of the $\overline{\text { DTR }}$ line is reflected by the $\overline{\mathrm{DTR}}$ bit in the CSR.

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

The $\overline{\mathrm{IRQ}}$ lines are open-drain outputs from the interrupt control logic. $\overline{\mathrm{IRQ1}}$ is associated with ACIA1 and $\overline{\mathrm{RQ} 2}$ is associated with ACIA2. These lines are normally high but go low when one of the flags in the ISR is set, provided that its corresponding enable bit is set in the IER.

Table 1. DACIA Register Selection

| $\begin{gathered} \text { HEX } \\ \text { ADDR } \end{gathered}$ | REGISTER SELECT LINES |  |  | CONTROL AND FORMAT REGISTER BITS |  | REG ABBR | REGISTER ACCESS |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RS2 | RS1 | RSO | CFR-7 | CFR-6 |  | WRITE | READ |
| 00 | L | L | L | - | - | $\begin{aligned} & \text { IER1 } \\ & \text { ISR1 } \end{aligned}$ | INTERRUPT ENABLE REGISTER 1 | INTERRUPT STATUS REGISTER 1 |
| 01 | L | L | H | 0 | - | CFR1 SR1 | CONTROL REGISTER 1 | STATUS REGISTER 1 |
|  |  |  |  | 1 | - | DFR1 | FORMAT REGISTER 1 | INVALID |
| 02 | L | H | L | - | 0 | CDR1 | COMPARE DATA REGISTER 1 | INVALID |
|  |  |  |  | - | 1 | TBR1 | TRANSMIT BREAK REGISTER 1 | INVALID |
| 03 | L | H | H | - | - | $\begin{aligned} & \text { TDR1 } \\ & \text { RDR1 } \end{aligned}$ | TRANSMIT DATA REGISTER 1 | RECEIVE DATA REGISTER 1 |
| 04 | H | L | L | - | - | $\begin{aligned} & \text { IER2 } \\ & \text { ISR2 } \end{aligned}$ | INTERRUPT ENABLE REGISTER 2 | INTERRUPT STATUS REGISTER 2 |
| 05 | H | L | H | 0 | - | $\begin{aligned} & \text { CFR2 } \\ & \text { SR2 } \end{aligned}$ | CONTROL REGISTER 2 | STATUS REGISTER 2 |
|  |  |  |  | 1 | - | CFR2 | FORMAT REGISTER 2 | INVALID |
| 06 | H | H | L | - | 0 | CDR2 | COMPARE DATA REGISTER 2 | INVALID |
|  |  |  |  | - | 1 | TBR2 | TRANSMIT BREAK REGISTER 2 | INVALID |
| 07 | H | H | H | - | - | TDR2 RDR2 | TRANSMIT DATA REGISTER 2 | RECEIVE DATA REGISTER 2 |

## FUNCTIONAL DESCRIPTION

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

## INTERRUPT LOGIC

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


Figure 3. DACIA Block Diagram

## DATA BUS BUFFER

The Data Bus Buffer is a bidirectional interface between the system data lines and the internal data bus. When $R \bar{W}$ is high and $\overline{C S}$ is low, the Data Bus Buffer passes data from the internal data bus to the system data lines. When $R \bar{W}$ is low and $\overline{C S}$ is low, data is brought into the DACIA from the system data bus. Table 2 summarizes the Data Bus Buffer states.

Table 2. Data Bus Buffer Summary

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

## TRANSMIT AND RECEIVE DATA REGISTERS

These registers are used as temporary data storage for the DACIA Transmit and Receive circuits. The Transmit Data Register is characterized as follows:

- Bit 0 is the leading bit to be transmitted.
- Unused data bits are the high-order bits and are "don't care" for transmission.
- Write-only register.

The Receive Data Register is characterized in a similar fashion as follows:

- Bit 0 is the leading bit received.
- Unused data bits are the high order bits and are " 0 " for the receiver.
- Parity bits are not contained in the Receive Data Register, but are stripped off after being used for external parity checking. Parity and all unused high-order bits are " 0 ".
- Read-only register

Figure 4 shows an example of a Parity Mode single transmitted or received data word. In this example, the data word is formatted with 8 data bits, parity, and two stop bits. Figure 4 also shows a single character transmitted or received in Address/Data Mode. In this example, the address or data word is 8 bits, there is no


Figure 4. Typical Character
parity bit, and there are two stop bits. The 10th bit (normal parity bit) is an address/data indicator. A 1 means the 8 bits are an address and a 0 means the 8 bits are data.

## CLOCK CIRCUIT

The internal clock oscillator supplies the time base for the baud rate generator. The oscillator can be driven by a crystal or an external clock, or it can be disabled, in which case the time base for the baud rate is generated by the Receiver External Clock ( RxC ) and Transmitter External Clock ( TxC ) input pins. Figure 5 shows the three possible clock configurations.

## Crystal (XTALI, XTALO)

These pins are normaliy connected to an external 3.6864 MHz crystal used as the time base for the baud rate generator. As an alternative, the XTLI pin may be driven with an externally generated clock in which case the XTALO pin must float.

## Receiver Clock ( $\mathbf{R x C}$ )

This pin is the Receiver $16 x$ clock input when the baud rate generator is programmed for external clock. Figure 15 shows timing considerations for RxC.

## Transmitter Clock (TxC)

This pin is the transmitter $16 x$ clock input when the baud rate generator is programmed for external clock. Figure 16 shows timing considerations for TxC.

## Note

When RxC and TxC are used for external clock input, XTALI must be tied to ground (Vss) and XTALO must be left open (floating).

## Clock Out (CLK OUT)

This output is a buffered output from the 3.6864 MHz crystal oscillator. It may be used to drive the XTALI input of another DACIA. This allows multiple DACIA chips to be used in a system with only one crystal needed. CLK OUT is in phase with XTALI.


Figure 5. DACIA Clock Generation

## CONTROL AND FORMAT REGISTER (CFR)

The Control and Format Register (CFR) is a dual-function, writeonly register which allows control of word length, baud rate, control line outputs, parity, echo mode, and compare/TBR access. When the CFR is written to with bit $7=0$, the CFR functions as a Control Register. When the CFR is written to with bit $7=1$, the CFR operates as a Formal Register.

Control Register (CFR Addressed with Bit $7=0$ )

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


| $\begin{gathered} \text { Bit } 7 \\ 0 \end{gathered}$ |  |  | Control or Format Register Control Register |
| :---: | :---: | :---: | :---: |
| $\begin{gathered} \text { Bit } 6 \\ 1 \\ 0 \end{gathered}$ |  |  | TBR/CDR |
|  |  |  | Access the Transmit Break Register (TBR) |
|  |  |  | Access the Compare Data Register (CDR) |
| $\begin{gathered} \text { Bit } 5 \\ 1 \\ 0 \end{gathered}$ |  |  | Number of Stop Bits |
|  |  |  | Two stop bits |
|  |  |  | One stop bit |
| $\begin{gathered} \text { Bit } 4 \\ 1 \\ 0 \end{gathered}$ |  |  | Echo Selection (ECHO) |
|  |  |  | Echo activated |
|  |  |  | Echo deactivated |
| Bits 3-0 |  |  | Baud Rate Selection |
| 3 | 21 | 0 | Baud Rate |
| 0 | 00 | 0 | 50 |
| 0 | 00 | 1 | 109.2 |
| 0 | 01 | 0 | 134.58 |
| 0 | 01 | 1 | 150 |
| 0 | 10 | 0 | 300 |
| 0 | 10 | 1 | 600 |
| 0 | 11 | 0 | 1200 |
| 0 | 11 | 1 | 1800 |
| 1 | 00 | 0 | 2400 |
| 1 | 00 | 1 | 3600 |
| 1 | 01 | 0 | 4800 |
| 1 | 01 | 1 | 7200 |
| 1 | 10 | 0 | 9600 |
| 1 | 10 | 1 | 19200 |
| 1 | 11 | 0 | 38400 |
| 1 | 11 | 1 | External TxC and RxC Clocks |

Format Register (CFR Addressed with Bit $7=1$ )

| $\mathbf{7}$ | $\mathbf{6} \quad \mathbf{5}$ | $\mathbf{4} \mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{1}$ | NUMBER <br> OF DATA <br> BITS | PARITY <br> SELECTION | PARITY <br> ENABLE | $\overline{\text { DTR }}$ <br> CONTROL | $\overline{\text { RTS }}$ <br> CONTROL |


| Bit 7 | Control or Format Register |
| :---: | :--- |
| 1 | Format Register |


| Bits | $6-5$ |  | Number of Data Bits Per Channel |
| ---: | ---: | :--- | :--- |
| $\mathbf{6}$ | $\mathbf{5}$ | No. Bits |  |
| 0 | 0 | 5 |  |
| 0 | 1 | 6 |  |
| 1 | 0 | 7 |  |
| 1 | 1 | 8 |  |

Bits 4-3 Parity Mode Selection

| 4 | 3 | Selects |
| :---: | :--- | :--- |
| 0 | 0 | Odd Parity |
| 0 | 1 | Even Parity |
| 1 | 0 | Mark Parity |
| 1 | 1 | Space Parity |
| Bit 2 |  |  |
| 1 | Parity Enable |  |
| 0 | Parity as specified by bits 4-3 |  |
|  | No Parity |  |
| Bit 1 | $\overline{\text { DTR Control }}$ |  |
| 1 | $\overline{\text { DTR }}$ high |  |
| 0 | $\overline{\text { DTR low }}$ |  |
| Bit 0 | $\overline{\text { RTS }}$ Control |  |
| 1 | $\overline{R T S}$ high |  |
| 0 | $\overline{\text { RTS low }}$ |  |

## INTERRUPT ENABLE REGISTER (IER)

The Interrupt Enable Register (IER) is a write-only register that allows each of the possible IRQ sources to be enabled, or disabled, individually without affecting any of the other interrupt enable bits in the register. IRQ sources are enabled by writing to the IER with bit 7 set to a 1 and every bit set to a 1 that corresponds to the IRQ source to be enabled. IRQ sources are disabled by writing to the IER with bit 7 set to a 0 and every bit set to a 1 that corresponds to the IRQ source to be disabled. Any bit (except bit 7) to which a 0 is written is unaffected and remains in its original state. As an example, writing $\$ 7 \mathrm{~F}$ to the IER will disable all IRQ source bits, but writing \$FF to the IER will enable all IRQ source bits. A hardware reset ( $\overline{R E S}$ ) clears all IRQ source bits to the 0 state. Bit assignments for the IER are as follows:

| 7 | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CLEAR/ <br> SET <br> BITS | TDR <br> EMPTY <br> IE | $\overline{\text { CTS }}$ | $\overline{\text { IE }}$ | DCD <br> IE | $\overline{\text { DSR }}$ <br> IE | PARITY <br> ERROR <br> IE | FRM <br> OVR <br> BRK <br> IE |
| RDR <br> FULL <br> IE |  |  |  |  |  |  |  |

## R65C52

## INTERRUPT STATUS REGISTER (ISR)

The Interrupt Status Register (ISR) is a read-only register that identifies the current status condition for each DACIA internal IRQ source. Bits 6 through 0 of the ISR are set to a 1 whenever the corresponding IRQ source condition has occurred in the DACIA. Bit 7 identifies if any of the IRQ source status bits have been set in the ISR.

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ANY <br> BIT <br> SET | TDR <br> EMPTY | CTS <br> TRANS | $\overline{\text { DCD }}$ <br> TRANS | DSR <br> TRANS | PARITY <br> ERROR | FRM <br> OVR <br> BRK |  |
| RDR |  |  |  |  |  |  |  |
| FULL |  |  |  |  |  |  |  |


| Bit 7 | Any Bit Set |
| :---: | :---: |
| 1 | Any bit (6 through 0) has been set to a 1 |
| 0 | No bits have been set to a 1 |
| Bit 6 | Transmit Data Register Empty (TDR EMPTY) |
| 1 | Transmit Data Register has been transferred to the shift register |
| 0 | New data has been written to the Transmit Data Register |
| Bit 5 | Transition On $\overline{\text { CTS }}$ Line ( $\overline{\mathbf{C T S}}$ TRANS) |
| 1 | A positive or negative transition has occurred on $\overline{\text { CTS }}$ |
| 0 | No transition has occurred on $\overline{\text { CTS }}$, or ISR has been Read |
| Bit 4 | Transition On $\overline{\mathrm{DCD}}$ Line ( $\overline{\mathrm{DCD}}$ TRANS) |
| 1 | A positive or negative transition has occurred on DCD |
| 0 | No transition has occurred on $\overline{\mathrm{DCD}}$, or ISR has been Read |
| Bit 3 | Transition On $\overline{\text { DSR }}$ Line ( $\overline{\text { DSR }}$ TRANS) |
| 1 | A positive or negative transition has occurred on DSR |
| 0 | No transition has occurred on $\overline{\text { DSR }}$, or ISR has been Read |
| Bit 2 | Parity Error |
| 1 | A parity error has occurred in received data |
| 0 | No parity error has occurred, or the Receive Data Register (RDR) has been Read |
| Bit 1 | Frame Error, Overrun or Break (FRM OVR BRK) |
| 1 | A framing error, receive overrun, or receive break has occurred |
| 0 | No error, overrun, break has occurred or RDR has been Read |
| Bit 0 | Receive Data Register Full (RDR FULL) |
| 1 | Shift register data has been transferred to Receive Data Register |
| 0 | Receive Data Register has been Read |

## CONTROL STATUS REGISTER (CSR)

The Control Status Register (CSR) is a read-only register that provides I/O status and error condition information. The CSR is normally read after an IRQ has occurred to determine the exact cause of the interrupt condition.

| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FRAMING <br> ERROR | TRANS <br> UNDR | $\overline{C T S}$ <br> STATUS | $\overline{\mathrm{DCD}}$ <br> STATUS | $\overline{\mathrm{DSR}}$ <br> STATUS | REC <br> BREAK | $\overline{\overline{D T R}}$ | $\overline{\mathrm{RTSS}}$ |
| STATUS |  |  |  |  |  |  |  | STATUS | STAT |
| :--- |

## Bit 7

1
0

## Bit 6

1
0
Bit 5
1 0

Bit 4

## Framing Error

A framing error occurred in receive data No framing error occurred, or the RDR was Read

## Transmitter Underrun (TRANS UNDR)

Transmit shift register is empty and TDRE bits in IER and ISR are set
A write to the TDR has occurred

## $\overline{\text { CTS }}$ Status

A low-to-high transition occurred on CTS line
A high-to-low transition occurred on CTS line

## $\overline{\mathrm{DCD}}$ Status

A low-to-high transition occurred on $\overline{\mathrm{DCD}}$ line A high-to-low transition occurred on $\overline{\mathrm{DCD}}$ line

## $\overline{\text { DSR }}$ Status

A low-to-high transition occurred on $\overline{\mathrm{DSR}}$ line A high-to-low transition occurred on $\overline{\mathrm{DSR}}$ line

## REC Break

A Receive Break has occurred
No Receive Break occurred, or RDR, was read

## $\overline{\text { DTR Status }}$

A low-to-high transition occurred on DTR line
A high-to-low transition occurred on DTR line

## RTS Status

A low-to-high transition occurred on RTS line
A high-to-low transition occurred on RTS line

## TRANSMIT BREAK REGISTER (TBR)

The DACIA has two Transmit Break Registers which are writeonly registers. Only two bits of these registers are used; one during the Receive mode to command a Transmit Break and the other to provide for Parity/Address recognition. Writing a 1 to bit 1 of the TBR causes a continuous Break to be transmitted by the ACIA associated with the register. Writing a 0 to this bit allows normal transmission to resume. Writing a 1 to bit 0 of the TBR commands the value of the Parity bit to be sent to the Parity Error bit (bit 2 of the ISR). Writing a 0 to this bit allows normal Parity Error recognition to be in force. When an RES is received by the DACIA, both of these bits are reset to 0 . The bits format for the TBR are as follows:

| $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | NOT USED |  |  | TRANS <br> BRK | PAR/ <br> ADDR |  |  |

Bits 7-2 Not used (don't care)
Bit 1 Transmit Break (TRANS BRK)
1 Transmit continuous Break until disabled $0 \quad$ Resume normal transmission

Bit $0 \quad$ Parity/Address Recognition (PAR ADDR)
1 Send value of parity to ISR bit 2
0 Return to normal Parity Error recognition mode

## COMPARE DATA REGISTER

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

## SUMMARY OF REGISTERS

Table 3 shows the control and status registers associated with the DACIA in a single summary table. Each of the ACIA's has its own set of these seven registers.

## OPERATION

The following paragraphs describe ten modes (or conditions) of operation of the DACIA. The modes described are:

- Continuous Data Transmit
- Continuous Data Receive
- Transmit Underrun Condition
- Effects of CTS on Transmitter
- Effects of Overrun on Receiver
- Echo Mode Timing
- Framing Error
- Transmit Break Character
- Receive Break Character
- Automatic Address Recognition

Table 3. Control and Status Registers Format Summary

| REGISTER BIT NUMBERS |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CLEAR/SET BITS | $\begin{aligned} & \text { TDR } \\ & \text { EMPTY } \end{aligned}$ $\mathrm{IE}$ | $\begin{gathered} \overline{\text { CTS }} \\ \text { IE } \end{gathered}$ | $\begin{gathered} \overline{\mathrm{DCD}} \\ \mathrm{IE} \end{gathered}$ | $\begin{gathered} \overline{\mathrm{DSR}} \\ \mathrm{IE} \end{gathered}$ | PARITY ERROR IE | $\begin{gathered} \hline \text { FRM } \\ \text { OVR } \\ \text { BRK IE } \end{gathered}$ | $\begin{aligned} & \hline \text { RDR } \\ & \text { FULL } \\ & \text { IE } \\ & \hline \end{aligned}$ |
| ANY BIT SET | $\begin{gathered} \text { TDR } \\ \text { EMPTY } \end{gathered}$ | $\begin{aligned} & \overline{\text { CTS }} \\ & \text { TRANS } \end{aligned}$ | $\begin{gathered} \overline{\mathrm{DCD}} \\ \text { TRANS } \end{gathered}$ | $\begin{aligned} & \overline{\text { DSR }} \\ & \text { TRANS } \end{aligned}$ | PARITY ERROR | FRM OVR BRK | RDR FULL |
| FRAMING ERROR | TRANS UNDR | $\begin{gathered} \overline{\text { CTS }} \\ \text { STATUS } \end{gathered}$ | $\begin{gathered} \overline{\mathrm{DCD}} \\ \text { sTATUS } \end{gathered}$ | $\begin{gathered} \overline{\mathrm{DSR}} \\ \text { STATUS } \end{gathered}$ | $\begin{aligned} & \text { REC } \\ & \text { BREAK } \end{aligned}$ | $\begin{aligned} & \overline{\text { DTR }} \\ & \text { STATUS } \end{aligned}$ | $\overline{\text { RTS }}$ STATUS |
| 0 | TBR/ CDR | $\begin{aligned} & \text { NO. } \\ & \text { STOP } \\ & \text { BITS } \end{aligned}$ | ECHO |  | BAUD P | SELECTION |  |
| 1 | NUM DAT | $\begin{aligned} & \text { ROF } \\ & \text { ITS } \end{aligned}$ |  | $\begin{aligned} & \text { TY } \\ & \text { TION } \end{aligned}$ | PARITY <br> ENABLE | $\overline{\text { DTR }}$ CONTROL | $\overline{\text { RTS }}$ CONTROL |
| NOT USED |  |  |  |  |  | TRANS BRK | PARI ADDR |
| COMPARE BITS (ADDRESS RECOGNITION) |  |  |  |  |  |  |  |


| REGISTER | $\overline{\text { RES }}$ |
| :---: | :---: |
| INTERRUPT ENABLE REGISTERS | \$80 |
| INTERRUPT <br> STATUS <br> REGISTERS | - |
| Status REGISTERS | - |
| CONTROL REGISTERS AND FORMAT REGISTERS | - |
| TRANSMIT BREAK REGISTERS | \$0F |
| COMPARE <br> DATA <br> REGISTERS | - |

## CONTINUOUS DATA TRANSMIT

In the normal operating mode, the TDRE bit in the ISR signals the MPU that the DACIA is ready to accept the next data word. An $\overline{\mathrm{IRQ}}$ occurs if the corresponding TDRE IRQ enable bit is set in the IER. The TDRE bit is set at the beginning of the start bit.

When the MPU writes a word to the TDR the TDRE bit is cleared. In order to maintain continuous transmission the TDR must be loaded before the stop bit(s) are ended. Figure 6 shows the relationship between $\overline{\mathrm{RQ}}$ and TXD for the Continuous Data Transmit mode.


## CONTINUOUS DATA RECEIVE

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


Figure 7. Continuous Data Receive

## TRANSMIT UNDERRUN CONDITION

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


Figure 8. Transmit Underrun Condition Relationship

## EFFECTS OF $\overline{C T S}$ ON TRANSMITTER

The $\overline{\mathrm{CTS}}$ control line controls the transmission of data or the handshaking of data to a "busy"' device (such as a printer). When the CTS line is low, the transmitter operates normally. Any transition on this line sets the $\overline{\mathrm{CTS}}$ bit in the ISR. A high condition inhibits the TDRE bit in the ISR from becoming set. The word currently
in the shift register continues to be sent but any word in the TDR is held until CTS goes low. At the high-to-low transition the $\overline{\mathrm{CTS}}$ bit in the ISR is again set. Figure 9 shows the relationship of $\overline{I R Q}$, TXD, and $\overline{\mathrm{CTS}}$ for the effects of CTS on the transmitter.


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

## EFFECTS OF OVERRUN ON RECEIVER

If the processor does not read the RDR before the stop bit of the next word, an overrun error occurs, the overrun bit is set in the ISR, and the new data word is not transferred to the RDR. The RDR contains the last word not read by the MPU and all follow-
ing data is lost. The receiver will return to normal operation when the RDR is read. Figure 10 shows the relation of $\overline{\mathrm{RQ}}$ and RxD for the effects of overrun on the receiver.


Figure 10. Effects of Overrun on Receiver

## ECHO MODE TIMING

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


Figure 11. Echo Mode Timing

## FRAMING ERROR

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


Figure 12. Framing Error

## TRANSMIT BREAK CHARACTER

A Break may be transmitted by storing a value of $\$ 00$ in the IER. After storing zero in the IER the Break is transmitted immediately. Care should be exercised so that a character in transmission is not disturbed inadvertently. The Break level lasts until other than $\$ 00$ is stored in the IER at which time a stop bit is sent and
transmission may resume. At least one full word time of Break will be sent regardless of the length of time between starting and stopping the Break character. Figure 13 shows the relationship of $\overline{\mathrm{RQ}}$ and TxD for a Transmit Break character.


Figure 13. Transmit Break Character

## RECEIVE BREAK CHARACTER

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


Figure 14. Receive Break Character

## AUTOMATIC ADDRESS RECOGNITION

The DACIA offers a unique solution to the standard problem associated with multi-drop environment UARTs and communication interface controllers. In the standard configuration used by other devices, the slave CPU must be constantly interrupted to analyze incoming characters on the communications net to determine if an address word is present and if so, does that address match the address assigned to the slave UART. This CPU interrupt scheme can become intolerable in very large multi-drop networks because every slave on the communications net must "wake-up" it's CPU for every character sent down the network by the master. The end result is that the CPUs on the communications net are constantly being interrupted for the mundane task of address recognition.

To avoid this constant CPU interrupt problem, the DACIA has been designed to do address comparison and recognition internally without the need for CPU intervention. Therefore, the slave CPU is not interrupted until the DACIA has determined that the character sent over the communications net by the master was an address and the address matched the address stored in the DACIA Compare Register. At this point the DACIA interrupts the CPU, goes out of Compare Mode, and receives the string of characters being transmitted by the master, (i.e., the data characters). When all data has been received by the slave, it's CPU must again write the slave address into the DACIA Compare Register which automatically puts it back into the Compare Mode, waiting for another address character.

## GENERATION OF NON-STANDARD BAUD RATES

## Divisors

The internal counter/divider circuit selects the appropriate divisor for the crystal frequency by means of bits $0-3$ of the CFR Control Register, as shown in Table 4.

## 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 DACIA with an off-chip oscillator to achieve other baud rates. In this case, XTALI (pin 3) must be the clock input and XTALO (pin 4) must be a nonconnect.

Table 4. Divisor Selection

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




Figure 15. DACIA External Clock Timing - Receive Data


Figure 16. DACIA External Clock Timing - Transmit Data

## AC CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0 \mathrm{~V}, T_{A}=T_{L}\right.$ to $\left.T_{H}\right)$
READ/WRITE TIMING

| Characteristic | Symbol | 2 MHz |  | 4 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| R/ $\bar{W}$, RSO-RS2 Valid to $\overline{\mathrm{CS}}$ Low (Setup Time) | $t_{\text {wc }}$ | 0 | - | 0 | - | ns |
| $\overline{\text { CS }}$ Low to R/ $\bar{W}$, RSO-RS2 (Hold Time) | $\mathrm{t}_{\text {cWH }}$ | 65 | - | 65 | - | ns |
| $\overline{\mathrm{CS}}$ Low to Data Valid. | ${ }^{\text {chav }}$ | - | 100 | - | 100 | ns |
| $\overline{\mathrm{CS}}$ High to Data Invalid (Hold Time) | $\mathrm{t}_{\mathrm{CDZ}}$ | - | 10 | - | 10 | ns |
| Data Valid to $\overline{\mathrm{CS}}$ High | $\mathrm{t}_{\mathrm{DVCH}}$ | 20 |  | 20 |  | ns |

## Note:

1. All times are in nanoseconds.


DACIA Read Cycle Waveforms


DACIA Write Cycle Waveforms

TRANSMIT/RECEIVE TIMING

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Transmit/Receive Clock Rate | $\mathrm{t}_{\mathrm{CCY}}$ | 250 | - | ns |
| Transmit/Receive Clock High Time | $\mathrm{t}_{\mathrm{CH}}$ | 100 | - | ns |
| Transmit/Receive Clock Low Time | $\mathrm{t}_{\mathrm{CL}}$ | 100 | - | ns |
| XTALI to TxD Propagation Delay | $t_{\text {DD }}$ | - | 250 | ns |
| XTALI to $\overline{\mathrm{IRQ}}$ Propagation Delay | $t_{D I}$ | - | 250 | ns |
| $\overline{\mathrm{CTS}}, \overline{\mathrm{DCD}}, \overline{\mathrm{DSR}}$ to IRQ | $\mathrm{t}_{\mathrm{CT}}$ | - | 150 | ns |
| $\overline{\mathrm{IRQ}}$ Propagation Delay (Clear) | $\mathrm{t}_{\text {IRQ }}$ | - | 150 | ns |
| $\overline{\text { RTS, }} \overline{\text { DTR }}$ Propagation Delay | $\mathrm{t}_{\text {DLY }}$ | - | 150 | ns |
| Note: <br> 1. All times are in nanoseconds. |  |  |  |  |



## ABSOLUTE MAXIMUM RATINGS*

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

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

## OPERATING CONDITIONS

| Parameter | Symbol | Value |
| :--- | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{~V} \pm 5 \%$ |
| Temperature Range <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ |  |

## DC CHARACTERISTICS

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

| Characteristic | Symbol | Min | Tур | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage Except XTALI and XTALO XTALI and XTALO | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{aligned} & +2.0 \\ & +2.4 \end{aligned}$ | - | $\begin{aligned} & v_{c c}+0.3 \\ & v_{c c}+0.3 \end{aligned}$ | V |  |
| Input Low Voltage Except XTALI and XTALO XTALI and XTALO | $\mathrm{V}_{\mathrm{IL}}$ | $\begin{aligned} & -0.3 \\ & -0.3 \end{aligned}$ | - | $\begin{aligned} & +0.8 \\ & +0.4 \end{aligned}$ | v |  |
| Input Leakage Current <br> R $\bar{W}, \overline{\text { RES }}$, RSO, RS1, RS2, RxD, $\overline{C T S}, \overline{D C D}, \overline{D S R}, \overline{R \times C}$, $\overline{T X C}, \overline{C S}$ | וn | - | 10 | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{cc}} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State Off D0-D7 | ${ }_{\text {ITSI }}$ | - | $\pm 2$ | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage D0-D7, TxD, CLK OUT, RTS, DTR | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{gathered} +2.4 \\ 1.5 \end{gathered}$ | - | - | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \end{aligned}$ |
| Output Low Voltage DO-D7, TxD, CLK OUT, RTS, DTR | $\mathrm{V}_{\mathrm{OL}}$ | - | - | +0.4 | V | $\begin{array}{\|l\|} \hline \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA} \\ \hline \end{array}$ |
| Output Leakage Current (Off State) $\overline{\mathrm{IRQ}}$ | Ioff | - | $\pm 2$ | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} \\ & \mathrm{~V}_{\text {OUT }}=0 \text { to } 2.4 \mathrm{~V} \end{aligned}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | - |  | 10 | mW/MHz |  |
| Input Capacitance Except XTALI and XTALO XTALI and XTALO | $\mathrm{C}_{\text {IN }}$ | - | - | $\begin{gathered} 5 \\ 10 \end{gathered}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & V_{\mathrm{CC}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\ & \mathrm{f}=2 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUt }}$ | - | - | 10 | pF | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| Notes: <br> 1. All units are direct current (dc) except for capacitance. <br> 2. Negative sign indicates outward current flow, positive indicates inward flow. <br> 3. Typical values are shown for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{A}=25^{\circ} \mathrm{C}$. |  |  |  |  |  |  |

## PACKAGE DIMENSIONS

## 40-PIN PLASTIC DIP



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

# R6265 <br> MICRO FLOPPY DISK <br> CONTROLLER (MFDC) 

## PRELIMINARY

## DESCRIPTION

The R6265 Micro Floppy Disk Controller (MFDC) interfaces up to four Sony microfloppy and floppy disk drives to an 8-bit or 16-bit microprocessor-based system including Z-80, 8080A, 8085A, 8086, and 8088. The MFDC simplifies the system design by minimizing both the number of external hardware components and software steps needed to implement the floppy disk drive (FDD) interface. Control signals supplied by the MFDC reduce the number of components required in external phase locked loop and write precompensation circuitry. Memory-mapped registers containing commands, status and data simplify the software interface. Built-in functions reduce the software overhead needed to control the FDD interface. The MFDC provides full compatibility with the single- and double-density formats recommended by Sony Corporation as well as the ability to read the IBM 3740 single-density (FM) and IBM System 34 double-density (MFM) formats.

The MFDC interfaces directly to the synchronous microprocessor bus and operates with 8 -bit byte length data transferred on the bus in either DMA or non-DMA mode. In DMA mode, the CPU need only load the command into the MFDC and all data transfers occur under DMA control. The R6265 is directly compatible with the Z8410/ $\mu$ PD8257 Direct Memory Access Controller (DMAC). In non-DMA mode, the MFDC generates an interrupt to the CPU indicating that a byte of data is available.

Controller commands, command or device status, and data are transferred between the MFDC and the CPU via six internal registers. The Main Status Register (MSR) stores the MFDC' status information while four additional status registers provide result information to the CPU following each controller command. The Data Register (DR) stores actual disk data, parameters, controller commands and FDD status information for use by the CPU.

The R6265 executes 15 separate multi-byte commands:

| Read Data | Specify |
| :--- | :--- |
| Write Data | Format a Track |
| Read Deleted Data | Scan Equal |
| Write Deleted Data | Scan High or Equal |
| Read a Track | Scan Low or Equal |
| Read ID | Sense Interrupt Status |
| Seek | Sense Drive Status |

Read Data
Write Data
Read Deleted Data
Write Deleted Data
Read a Track
Read ID
Recalibrate (Restore to Track 0)

Specify
Format a Track
Scan Equal
Scan High or Equal
Scan Low or Equal
Sense Drive Status

## FEATURES

- Address mark detection circuitry
- Software control of
-Track stepping rate
-Head load time
-Head unload time
- Compatible with Sony recommended format in both single-and double-density recording formats
- Reads standard IBM formats
- Reads and writes in same format as NEC $\mu$ PD7265 for Sony microfloppy and floppy disk drives
- Programmable data record lengths: 128,256, 512 or 1024 bytes/sector
- Multi-sector and multi-track transfer capability
- Controls up to four floppy disk drives
- Data scan capability-will scan a single sector or an entire track of data fields, comparing on a byte-by-byte basis, data in the processor's memory with data read from the disk
- Data transfers in DMA or non-DMA mode
- Parallel seek operations on up to four drives
- Directly compatible with an 8 -bit or 16 -bit synchronous microprocessor bus including Z-80/8080A/8085A, 8086, and 8088
- Alternative to NEC $\mu$ PD7265
- Pin, software, and electrically compatible with the R6265
- Single phase 8 MHz Clock
- Single +5 Volt Power Supply


## ORDERING INFORMATION




Figure 1. MFDC Input and Output Signals

## PIN DESCRIPTION

Throughout this document signals are presented using the terms active and inactive, or asserted and negated, independent of whether the signal is active in the high-voltage state or lowvoltage state. (The active state of each logic pin is described below.) Active low signals are denoted by a superscript bar.

## BUS INTERFACE

D0-D7-Data Lines. The bidirectional data lines transfer data between the MFDC and the 8 -bit data bus.

CLK-CLOCK. The clock is a TTL compatible 8 MHz square wave signal.

RST-RESET. This active high input places the MFDC in the idle state and resets the output lines to the floppy disk drive (FDD) to the low state.
$\overline{\mathrm{CS}}$-Chip Select. The MFDC is selected when the $\overline{\mathrm{CS}}$ input is low.

A0-Data/Status Register Select. This input selects the Data or Status Register for reading from or writing to. When $A 0=$ high, the Data Register is selected and the state of $\overline{R D}$ or $\overline{W R}$ determines whether it is a read ( $\overline{\mathrm{RD}}=$ low) or a write ( $\overline{\mathrm{WR}}=$ low) operation. When AO = low, the Status Register is selected. This register may only be read ( $\overline{\mathrm{RD}}=$ low); the state $\overline{\mathrm{WR}}=$ low is invalid when the Status Register is selected.

INT-Interrupt Request. This active high output is the interrupt request generated by the MFDC to the CPU. INT is asserted upon completion of some MFDC commands and before a data byte is transferred between the MFDC and the data bus (in the NonDMA mode).

RD-Read. This active low input defines the data bus transfer as a read cycle. When low, the data transfer is from the MFDC to the data bus.

WR-Write. This active low input defines the data bus transfer as a write cycle. When low, the data transfer is from the data bus to the MFDC.

## DIRELT MEMORY ACCESS CONTROLLER (DMAC) INTERFACE

$\overline{\text { DACK -DMA Acknowledge. The DMA transfer acknowledge }}$ signal is a TTL compatible input generated by the DMA controller (DMAC) controlling the MFDC. The DMA cycle is active when DACK is low and the MFDC is performing a DMA transfer.

DRQ-Data DMA Request. The transfer request signal is a TTL compatible output generated by the MFDC to request a data transfer operation under control of the DMAC (in the DMA mode). The request is active when DRQ = high. The signal is reset inactive when DMA Acknowledge ( $\overline{\mathrm{DACK}}$ ) is asserted (low).

TC-Terminal Count. This input signal is issued to the MFDC when the DMA transfer for a channel is complete. The signal is active high concurrent with the $\overline{\mathrm{DACK}}$ input when the DMA operation is complete as a result of that transfer.

## FDD SERIAL DATA INTERFACE

RDD-Read Data. Read Data input from the floppy disk drive (FDD) containing clock and data bits.

RDW-Read Data Window. Data Window input generated by the Phase Locked Loop (PLL) and used to sample data from the FDD.

VCO—Varlable Frequency Oscillator Sync. This output signal inhibits the VCO in the PLL circuit when low and enables the VCO in the PLL circuit when high. This inhibits RDD and RDW from being generated until valid data is detected from the FDD.

WCK-Write Clock. This input clock determines the Write Data rate to the FDD. The data rate is 500 KHz in the FM mode (MFM $=$ low) and 1 MHz in the MFM mode (MFM = high). The pulse width is 250 ns (typical) in both modes.

WDA-Write Data. Serial write data output to the FDD containing both clock and data bits.

WE-Write Enable. This output signal enables the Write Data into the FDD when high.

PSO-PS1-Preshift. These outputs are encoded to convey write compensation status during the MFM mode to determine early, late or normal times as follows:

| Write Precompensation Status | Preshift Outputs |  |
| :---: | :---: | :---: |
|  | PS0 | PS1 |
| Normal | 0 | 0 |
| Late | 0 | 1 |
| Early | 1 | 0 |
| Invalid | 1 | 1 |
| $0=$ Low, $1=$ High |  |  |

## FDD STATUS INTERFACE

RDY-Ready. An active high input signal indicates the FDD is ready to send data to, or receive data from, the MFDC.

IDX-Index. An active high input signal from the FDD indicates the index hole is under the index sensor. Index is used to synchronize MFDC timing.
$\overline{\mathbf{R W}} /$ SEEK - Read Write/Seek. Mode selection signal to the FDD which controls the multiplexer from the multiplexed signals. When RW/SEEK is low, the Read/Write mode is commanded; when RW/SEEK is high, the Seek mode is commanded.

| $\overline{\text { RW/SEEK }}$ | Mode | Active FDD Interface Signals |
| :---: | :---: | :---: |
| Low | Read/Write | WP, FLT, LCT, FR |
| High | Seek | TS, TRKO, DIR, STP |

WP/TS-Write Protect/Two Side. An active high multiplexed input signal from the FDD. In the Read/Write mode, WPITS high indicates the media is write-protected. In the Seek mode, WPITS high indicates the media is two-sided.

FLT/TRKO-Fault/Track Zero. An active high multiplexed input from the FDD. In the Read/Write mode (RW/SEEK = low), FLT/TRKO high indicates an FDD fault. In the Seek mode, FLT/TRKO high indicates that the read/write head is positioned over track zero.

LCT/DIR-Low Current/Direction. A multiplexed output to the FDD. In the Read/Write mode, LCT/DIR is low when the read/write head is to be positioned over the inner tracks and the LCT/DIR is high when the head is to be positioned over the outer tracks. In the Seek mode, LCT/DIR controls the head direction. When LCT/DIR is high, the head steps to the outside of the disk; when LCT/DIR is low, the head steps to the inside of the disk.

FR/STP-Fault Reset/Step. A multiplexed output to the FDD. In the Read/Write mode, FR/STP high resets the fault indicator in the FDD. An FR pulse is issued at the beginning of each read or write command prior to issuing HDL. In the Seek mode, FR/STP provides the step pulses to move the read/write head to another track in the direction indicated by the LCT/DIR signal.

HDL-Head Load. An active high output to notify the FDD that the read/write head should be loaded (placed in contact with the media). A low level indicates the head should be unloaded.


R6265 DDFDC Pin Diagram

HD-Head Select. An output to the FDD to select the proper read/write head. Head One is selected when HD = high and Head Zero is selected when HD = low.

USO-US1-Unit Select. Output signals for floppy disk drive selection as follows:

| Unit Select |  | Floppy Dlak <br> Drive Solect |
| :---: | :---: | :---: |
| USO | US1 |  |
| 0 | 0 | 1 |
| 0 | 1 | 2 |
| 1 | 0 | 3 |
| 1 | 1 |  |
| $0=$ Low, $1=$ High |  |  |

MFM-MFM Mode. Output signal to the FDD to indicate MFM or FM mode. Selects the MFM mode when MFM = high and the FM mode when MFM = low.

## MFDC REGISTERS

The MFDC contains six registers which may be accessed by the processor or DMA controller via the system (i.e., microprocessor) bus: a Main Status Register, a Data Register, and four Result Status Registers. The 8-bit Main Status Register (MSR) contains the status information of the MFDC, and may be accessed at any time. The 8-bit Data Register, consisting of several registers in a stack with only one register presented to the data bus at a time, stores data, commands, parameters and FDD status information. Bytes of data are read out of, or written into, the Data Register in order to initiate a command or to obtain the results of a command execution.

The read-only Main Status Register facilitates the transfer of data between the system and the MFDC. The other Status Registers (STO, ST1, ST2 and ST3) are only available during the result phase, and may be read only after completing a command. The particular command which has been executed determines how many of the Status Registers will be read.

VCC-Power. +5V dc.
GND-Ground ( $\mathbf{V}_{\mathbf{8 8}}$ ).


Figure 2. R6265 MFDC Block Diagram

The relationship between the status/data registers and the $\overline{\mathrm{WR}}$, $\overline{R D}$ and $A O$ signals is shown below.

| A0 | $\overline{\text { RD }}$ | $\overline{\text { WR }}$ | Functon |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Illegal |
| 0 | 0 | 1 | Read Main Status Register |
| 0 | 1 | 0 | Illegal |
| 1 | 0 | 0 | Iliegal |
| 1 | 0 | 1 | Read from Data Register |
| 1 | 1 | 0 | Write into Data Register |
| 0 |  |  |  |

Table 1 shows each of the status registers used by the MFDC and each bit assignment within the individual registers. Table 2 defines the symbols used throughout the command definitions. Each register bit symbol is defined in the register descriptions that follow Table 2.

## REGISTER DEFINITIONS

Main Status Register (MSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RQM | DIO | EXM | CB | D3B | D2B | D1B | D0B |

The Main Status Register (MSR) contains the status information of the MFDC, and must be read by the processor before each byte is written to, or read from, the Data Register during the command or result phase. MSR reads are not required during the execution phase. The Data Input/Output (DIO) and Request for Master (RQM) bits in the MSR indicate when data is ready and in which direction data will be transferred on the data bus. The maximum time between the last $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ during command or result phases and the DIO and RQM getting set or reset is $12 \mu \mathrm{~s}$. For this reason, every time the MSR is read the processor should wait $12 \mu \mathrm{~s}$. The maximum time from the trailing edge of the last $\overline{R D}$ in the result phase to when bit 4 (MFDC Busy) goes low is also $12 \mu \mathrm{~s}$.

The DIO and RQM timing chart is shown in Figure 3.

## MSR



## MSR

5 EXM -Execution Mode. (Non-DMA mode only).
0 Execution phase ended, result phase begun.

1. Execution phase started.

MSR
4 CB -Controlier (MFDC) Busy.
$\overline{0} \quad$ MFDC is not busy, will accept a command.
1 MFDC is busy, will not accept a command.

```
MSR
    3 D3B -Floppy Disk Drive (FDD) 3 Busy.
    0}\mathrm{ FDD 3 is not busy, MFDC will accept read or write
        command.
    1 FDD 3 is busy, MFDC will not accept read or write
        command.
MSR
    2 D2B -FDD 2 Busy.
    0}\mathrm{ FDD 2 is not busy, MFDC will accept read or write
        command.
    1. FDD 2 is busy, MFDC will not accept read or write
        command.
MSR
    1 D1B -FDD 1 Busy.
        FDD 1 is not busy, MFDC will accept read or write
        command.
        FDD 1 is busy, MFDC will not accept read or write
        command.
MSR
    O DOB -FDD O Busy.
        FDD 0 is not busy, MFDC will accept read or write
        command.
1 FDD 0 is busy, MFDC will not accept read or write command.
Status Register \(\mathbf{0}\) (STO)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{2}{|c|}{ IC } & \multirow{2}{*}{ SE } & \multirow{2}{*}{ EC } & \multirow{2}{*}{ NR } & \multirow{2}{*}{ HD } & \multicolumn{2}{|c|}{ US } \\
\cline { 7 - 8 } & & & & & US1 & USO \\
\hline
\end{tabular}
```

The Status Register 0 (STO) as well as the other status registers (ST1-ST3), are available only during the result phase, and may be read only after completing a command. The particular command executed determines which status registers are used and may be read.

## STO

76 IC -Interrupt Code.
$\overline{0} \quad \overline{0} \quad$ Normal Termination (NT). Command was properly executed and completed.
0 Abnormal Termination (AT). Command execution was started, but was not successfully completed.
10 Invalid Command (IC). Received command was invalid.
11 Abnormal Termination (AT). The Ready (RDY) signal from the FDD changed state during command execution.

STO
5 SE -Seek End.
0 Seek command is not completed.
Seek command completed by MFDC.

STO
4 EC $\quad$-Equipment Check.
1 No error.
Either a fault signal is received from the FDD or the track
0 signal failed to occur after 256 step pulses (Recalibrate
Command).

Table 1. MFDC Status Register Bit Assignments

Main Status Register (MSR)
Status Register 0 (STO)
Status Register 1 (ST1)
Status Register 2 (ST2)
Status Register 3 (ST3)

| Bit Number |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| RQM | DIO | EXM | CB | D3B | D2B | D1B | DOB |
| IC |  | SE | EC | NR | HD | US |  |
|  |  | US1 |  |  |  | USO |
| EN | 0 |  | DE | OR | 0 | ND | NW | MA |
| 0 | CM | DD | WT | SH | SN | BT | MD |
| FLT | WP | RDY | TRKO | TS | HD | US1 | USO |

Table 2. Command Symbol Description

| Symbol | Name | Description |
| :---: | :---: | :---: |
| A0 | Address Line AO | Controls selection of Main Status Register ( $A 0=$ low) or Data Register ( $A 0=$ high). |
| D | Data | The data pattern which is going to be written into a sector. |
| D0-D7 | Data Bus | 8 -bit data bus, where D0 is the least significant data line and D7 is the most significant data line. |
| DTL | Data Length | When N is defined as 00 , DTL is the number of data bytes to read from or write into the sector. |
| EOT | End of Track | The final sector number on a track. During read or write operation, the DDFDC stops data transfer after reading from or writing to the sector equal to EOT. |
| GPL | Gap Length | The length of Gap 3. During read/write commands this value determines the number of bytes that the VCO will stay low after two CRC bytes. During the Format a Track command it determines the size of Gap 3. |
| H | Head Address | Head number 0 or 1, as specified in ID field. |
| HD (H) | Head | A selected head number 0 or 1 which controls the polarity of pin 27. ( $\mathrm{H}=\mathrm{HD}$ in all command words). |
| HLT | Head Load Time | The head load time in the FDD (2 to 254 ms in 2 ms increments). |
| HUT | Head Unload Time | The head unload time after a read or write operation has occurred (16 to 240 ms in 16 ms increments). |
| MF | FM or MFM Mode | When MF $=0$, FM mode is selected; and when MF $=1$, MFM mode is selected. |
| MT | Multi-Track | When $M T=1$, a multi-track operation is to be performed. After finishing a read/write operation on side 0 , the DDFDC will automatically start searching for sector 1 on side 1 . |
| N | Bytes/Sector | The number of data bytes written in a sector. |
| ND | Non-DMA Mode | When ND $=1$, operation is in the Non-DMA mode; when ND $=0$, operation is in the DMA mode. |
| NTN | New Track Number | A new track number, which will be reached as a result of the Seek command. Desired head position. |
| PTN | Present Track Number | The track number at the completion of Sense Interrupt Status command. Present head position. |
| R | Record (Sector) | The sector number to be read or written. |
| R/W | Read/Write | Either read (R) or write (W) signal. |
| ST | Sectors/Track | The number of sectors per track. |
| SK | Skip | Skip Deleted Data Address Mark. |
| SRT | Step Rate Time | The stepping rate for the FDD ( 1 to 16 ms in 1 ms increments). Stepping rate applies to all drives ( $F=1 \mathrm{~ms}, E=2 \mathrm{~ms}$, etc.) |
| $\begin{aligned} & \hline \text { ST0 } \\ & \text { ST1 } \\ & \text { ST2 } \\ & \text { ST3 } \end{aligned}$ | Status 0 Status 1 Status 2 Status 3 | Four registers which store the status information after a command has been executed. This information is available during the result phase after command execution. These registers should not be confused with the Main Status Register (selected by AO = low). STO-ST3 may be read only after a command has been executed and contain information relevant to that particular command. |
| STP | Sector Test Process | During a Scan command, if STP $=01$, the data in contiguous sectors is compared byte by byte with data sent from the processor (or DMA controller); and if STP $=02$, then alternate sectors are read and compared. |
| T | Track Number | The current/selected track number of the medium (0-255). |
| US0,US1 | Unit Select | A selected drive number (0-3). |


| STO |  |
| :--- | :--- |
| $\frac{3}{3}$ | NR |
| $\mathbf{F D D}$-Not Ready. |  |
| 1 | FDD is ready. |
| If a read or write command is issued to side 1 of a single- |  |
|  | sided drive, this bit is also set. |


| STO |  |
| :--- | :--- |
| $\frac{2}{2}$ | Head Select 0. |
| 1 | Head Select 1. |

STO
10 US -Unit Select. (At Interrupt).
00 FDD 0 selected.
01 FDD 1 selected.
10 FDD 2 selected.
11 FDD 3 selected.

## Status Register 1 (ST1)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $E N$ | 0 | $D E$ | OR | 0 | ND | NW | MA |

ST1
$\frac{7}{0}$ EN $\quad$ No error.
$1 \quad$ MFDC attempted to access a sector beyond the last
sector of a track.

ST1
$6 \quad$-Not Used. Always Zero.

ST1
5 DE -Data Error.
0 No error.
1 MFDC detected a CRC error in ID field or the Data field.

## ST1

4 OR -Over Run. No error. MFDC was not serviced by the system during data transfers, within a predetermined time interval.

ST1
$3 \quad$-Not Used. Always Zero.
ST1
ND -No Data.
No error.
$1 \quad 3$ possible errors.

1. MFDC cannot find sector specified in ID Register during execution of Read Data, Write Deleted Data or Scan commands.
2. MFDC cannot read ID field without an error during Read ID command.
3. MFDC cannot find starting sector during execution of Read a Track command.

## ST1

1 NW -Not Writable. No error. MFDC detected a write protect signal from FDD during execution of Write Data, Write Deleted Data or Format a Track commands.

ST1
0 MA -Missing Address Mark.
No error.
2 possible errors.

1. MFDC cannot detect the ID Address Mark after encountering the index hole twice.
2. MFDC cannot detect the Data Address Mark or Deleted Data Address Mark. The MD (Missing Address Mark in Data field) of Status Register 2 is also set.

Status Register 2 (ST2)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | CM | DD | WT | SH | SN | BT | MD |

ST2
$1 \quad$-Not Used. Always Zero.

ST2
6 CM -Control Mark.
No error.
MFDC encountered a sector which contained a Deleted Data Address Mark during execution of a Read Data, Read a Track, or Scan command, or which contained a Data Address Mark during execution of a Read Deleted Data command.

ST2
5 DD -Data Error in Data Field.
No error. MFDC detected a CRC error in the Data field.

ST2
4 WT -Wrong Track. No error. Contents of T on the disk is different from that stored in IDR. Bit is related to ND (Bit 2) of Status Register 1.

ST2
SH - Scan Equal Hit.
No "equal" condition during a scan command. "Equal" condition satisfied during a scan command.

ST2
SN -Scan Not Satisfied.
0 No error.
1 MFDC cannot find a sector on the track which meets the scan command condition.

## ST2

1 BT -Bad Track.
No error.
1 Contents of $T$ on the disk is different from that stored in the IDR and $T=F F$. Bit is related to ND (Bit 2 ) of Status Register 1.

## ST2

0 MD -Missing Address Mark in Data Field. No error.
MFDC cannot find a Data Address Mark or Deleted Data Address Mark during a data read from the disk.

Status Register $\mathbf{3}$ (ST3)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FLT | WP | RDY | TRKO | TS | HD | US1 | US0 |

Status Register 3 (ST3) holds the results of the Sense Drive Status command.

```
ST3
    7 FLT -Fault.
    Fault (FLT) signal from the FDD is low.
    1 Fault (FLT) signal from the FDD is high.
ST3
    6 WP -Write Protect.
        Write Protect (WP) signal from the FDD is low.
    1 Write Protect (WP) signal from the FDD is high.
ST3
    5 RDY -Ready.
    0 Ready (RDY) signal from the RDD is low.
    1 Ready (RDY) signal from the FDD is high.
ST3
    4 TRKO -Track O.
        Track 0 (TRKO) signal from the FDD is low.
        Track 0 (TRKO) signal is from the FDD is high.
ST3
    TS -Two Side.
        Two Side (TS) signal from the FDD is low.
    0 Two Side (TS) signal from the FDD is low.
ST3
    HD -Head Select.
        Head Select (HD) signal to the FDD is low.
        Head Select (HD) signal to the FDD is high.
ST3
    US1 -Unit Select 1.
        Unit Select 1 (US1) signal to the FDD is low.
        Unit Select 1(US1) signal to the FDD is high.
ST3
    USO -Unit Select 0.
        Unit Select 0 (USO) signal to the FDD is low.
        Unit Select 0 (US1) signal to the FDD is high.
```


## COMMAND SEQUENCE

The MFDC is capable of performing 15 different commands. Each command is initiated by a multi-byte transfer of data from the system. After command execution, the result of the command may be a multi-byte transfer of data back to the system. Because of this multi-byte transfer of information between the MFDC and the system, each command consists of three phases:

Command Phase-The MFDC receives all information required to perform a particular operation from the system.

Execution Phase-The MFDC performs the instructed operation.

Result Phase-After completion of the operation, status and other housekeeping information are made available to the system.

The bytes of data sent to the MFDC to form a command, and read out of the MFDC in the result phase, must occur in the order shown for each command sequence. That is, the command code byte must be sent first followed by the other bytes in the specified sequence. All command bytes must be written and all result bytes must be read in each phase. After the last byte of data in the command phase is received by the MFDC, the execution phase starts. Similarly, when the last byte of data is read out in the result phase, the command is ended and the MFDC is ready to accept a new command. A command can be terminated by asserting the Terminal Count (TC) signal to the MFDC. This ensures that the processor can always get the MFDC's attention even if the command in process hangs up in an abnormal manner.

## COMMAND DESCRIPTION

## READ DATA

A command set of nine bytes places the MFDC into the Read Data mode. After the Read Data command has been received the MFDC loads the head (if it is unloaded), waits the specified Head Settling Time (defined in the Specify command), then begins reading ID Address Marks and ID fields from the disk. When the current sector number ( $R$ ) stored in the ID Register (IDR) matches the sector number read from the disk, the MFDC transfers data from the disk Data field to the data bus.

After completion of the read operation from the current sector, the MFDC increments the Sector Number (R) by one, and the data from the next sector is read and output to the data bus. This continuous read function is called a "Multi-Sector Read Operation." The Read Command terminates after reading the last data byte from sector $R$ when $R=E O T$. STO bits 7 and 6 are set to 0 and 1, respectively, and ST1 bit 7 (EN) is set to a 1.

The Read Data command can also be terminated by a high Terminal Count (TC) signal. TC should be issued at the same time that the $\overline{\text { DACK }}$ for the last byte of data is sent. Upon receipt of TC, the MFDC stops outputting data to the data bus, but continues to read data from the current sector, checks CRC (Cyclic Redundancy Count) bytes, and then at the end of that sector terminates the Read Data command and sets bits 7 and 6 in STO

Micro Floppy Disk Controller (MFDC)

to 0 . The amount of data which can be handled with a single command to the MFDC depends upon MT (Multi-Track), MF (MFM/FM), and N (Number of Bytes/Sector) values. Table 3 shows the transfer capacity.

The multi-track function (MT) allows the MFDC to read data from both sides of the disk. For a particular track, data is transferred starting at sector 1 , side 0 and completed at sector $L$, side 1 (sector $\mathrm{L}=$ last sector on the side). This function pertains to only one track (the same track) on each side of the disk.

When $\mathrm{N}=0$ in command byte 6 (FM mode), the Data Length (DTL) in command byte 9 defines the data length that the MFDC must treat as a sector. If DTL is smaller than the actual data length in a sector, the data beyond the DTL is not sent to the data bus. The MFDC reads (internally) the complete sector, performs the CRC check, and depending upon the manner of command termination, may perform a multi-sector Read operation. When $N$ is non-zero (MFM mode), DTL has no meaning and should be set to FF.

At the completion of the Read Data command, the head is not unloaded until the Head Unload Time (HUT) interval defined in the Specify command has elapsed. The head settling time may be avoided between subsequent reads if the processor issues another command before the head unloads. This time savings is considerable when disk contents are copied from one drive to another.

If the MFDC detects the Index Hole twice in succession without finding the right sector (indicated in R), then the MFDC sets the No Data (ND) flag in Status Register 1 (ST1) to a 1, sets Status Register 0 (STO) bits 7 and 6 to 0 and 1, respectively, and terminates the Read Data command.

After reading the ID and Data fields in each sector, the MFDC checks the CRC bytes. If a read error is detected (incorrect CRC in ID field), the MFDC sets the Data Error (DE) flag in ST1 to a 1, sets the Data Error in Data Field (DD) flag in ST2 to a 1 if a CRC error occurs in the Data field, sets bits 7 and 6 in STO to 0 and 1 , respectively, and terminates the command.

If the MFDC reads a Deleted Data Address Mark from the disk, and the Skip Deleted Data Address Mark bit in the first command byte is not set $(S K=0)$, then the MFDC reads all the data in the sector, sets the Control Mark (CM) flag in ST2 to a 1, and terminates the command. If SK = 1, the MFDC skips the sector with the Deleted Data Address Mark and reads the next sector. The CRC bits in the deleted data field are not checked when $S K=1$.

During disk data transfers from the MFDC to the system, the MFDC must be serviced by the system within $27 \mu \mathrm{~s}$ in the FM mode, and within $13 \mu \mathrm{~s}$ in the MFM mode, otherwise the MFDC sets the Over Run (OR) flag in ST1 to a 1, sets bits 7 and 6 in STO to 0 and 1 , respectively, and terminates the command.

If the processor terminates a read (or write) operation in the MFDC, then the ID information in the result phase is dependent upon the state of the MT bit in the first command byte and the End of Track (EOT) byte. Table 4 shows the values for Track Number (T), Head Number (H), Sector Number (R), and Number of Data Bytes/Sector ( N ), when the processor terminates the command.

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 0 | 0 | 1 | 1 | 0 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

Table 3. MFDC Transfer Capacity

| Multi-Track (MT) | MFM/FM (MF) | Bytes/Sector (N) | Maximum Transfer Capacity <br> (Bytes/Sector) (Number of Sectors) | Final Sector Read* from Disk |
| :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 00 \\ & 01 \end{aligned}$ | $\begin{aligned} & (128)(16)=2,048 \\ & (256)(16)=4,096 \end{aligned}$ | 16 at Side 0 or 16 at Side 1 |
| $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 00 \\ & 01 \end{aligned}$ | $\begin{aligned} & (128)(32)=4,096 \\ & (256)(32)=8,192 \end{aligned}$ | 16 at Side 1 |
| $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 01 \\ & 02 \end{aligned}$ | $\begin{aligned} & (256)(9)=2,304 \\ & (512)(9)=4,608 \end{aligned}$ | 9 at Side 0 or 9 at Side 1 |
| $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 01 \\ & 02 \end{aligned}$ | $\begin{aligned} & (256)(18)=4,608 \\ & (512)(18)=9,216 \end{aligned}$ | 9 at Side 1 |
| $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 02 \\ & 03 \end{aligned}$ | $\begin{aligned} (512)(5) & =2,560 \\ (1024)(5) & =5,120 \end{aligned}$ | 5 at Side 0 or 5 at Side 1 |
| $\begin{array}{r} 1 \\ 1 \end{array}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{array}{r} 02 \\ \therefore \quad 03 \end{array}$ | $\begin{array}{rr} (512)(10) & =5,120 \\ (1024)(10) & =10,240 \end{array}$ | 8 at Side 1 |

*Note: Typical values are for Sony recommended format.

Table 4. MFDC Command Termination Values

| Command Phase ID |  | Final Sector Transferred to/from Data Bus | Result Phase ID |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MultiTrack (MT) | Head Number (HD) |  | Track Number (T) | Head Number (H) | Sector Number (R) | No. of Data Bytes (N) |
| 0 | 0 | Less than EOT | NC | NC | R + 1 | NC |
|  | 0 | Equal to EOT | T + 1 | NC | 01 | NC |
|  | 1 | Less than EOT | NC | NC | R + 1 | NC |
|  | 1 | Equal to EOT | T + 1 | NC | 01 | NC |
| 1 | 0 | Less than EOT | NC | NC | R + 1 | NC |
|  | 0 | Equal to EOT | NC | LSB | 01 | NC |
|  | 1 | Less than EOT | NC | NC | R + 1 | NC |
|  | 1 | Equal to EOT | T+1 | LSB | 01 | NC |

## Notes:

1. NC (No Change): The same value as the one at the beginning of command execution.
2. LSB (Least Significant Bit): The least significant bit of $H$ is complemented.

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
| 2 | Status Register 1 (ST1) |  |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
|  | 7 | Number of Data Bytes per Sector (N) |

## WRITE DATA

A command set of nine bytes places the MFDC in the Write Data mode. After the Write Data command has been received the MFDC loads the head (if it is unloaded), waits the specified Head Settling Time (defined in the Specify command), then begins reading ID fields from the disk. When the four bytes (T, H, R, N) loaded during the command match the four bytes of the ID field from the disk, the MFDC transfers data from the data bus to the disk Data field.

After writing data into the current sector, the MFDC increments the sector number (R) by one, and writes into the Data field in the next sector. The MFDC continues this multi-sector write operation until the last byte is written to sector $R$ when $R=E O T$. STO bits 7 and 6 are set to 0 and 1, respectively, and ST1 bit 7 (EN) is set to a 1 .

The command can also be terminated by a high on Terminal Count (TC). If TC is sent to the MFDC while writing into the current sector, then the remainder of the Data field is filled with 00 (zeros). In this case, STO bits 7 and 6 are set to 0 and the command is terminated.

The MFDC reads the ID field of each sector and checks the CRC bytes. If the MFDC detects a read error (incorrect CRC) in one
of the ID fields, it terminates the Write Data command, sets the DE flag in ST1 to a 1 , and sets bits 7 and 6 in STO to 0 and 1 , respectively.

The Write Data command operates in much the same manner as the Read Data command. Refer to the Read Data command for the handling of the following items:

## - Transfer Capacity

- End of Track (EN) flag
- No Data (ND) flag
- Head Unload Time (HUT) interval
- ID information when the processor terminates command (see Table 4)
- Definition of Data Length (DTL) when $N=0$ and when $N \neq 0$

In the Write Data mode, data transfers from the data bus to the MFDC must occur within $27 \mu \mathrm{~s}$ in the FM mode, and within $13 \mu \mathrm{~s}$ in the MFM mode. If the time interval between data transfers is longer than this, then the MFDC terminates the Write Data command, sets the Over Run (OR) flag in ST1 to a 1, and sets bits 7 and 6 in STO to 0 and 1 , respectively.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | 0 | 0 | 0 | 1 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register O (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## WRITE DELETED DATA

The Write Deleted Data command is the same as the Write Data command except a Deleted Data Address Mark is written at the beginning of the Data field instead of the normal Data Address Mark.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| w | 1 | MT | MF | 0 | 0 | 1 | 0 | 0 | 1 |
|  | 2 | x | X | x | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (ST0) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
| 3 | Status Register 2 (ST2) |  |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector(N) |  |

## READ DELETED DATA

The Read Deleted Data command is the same as the Read Data command except that if SK $=0$ when the MFDC detects a Data Address Mark at the beginning of a Data field, it reads all the data in the sector and sets the CM flag in ST2 to a 1, and then terminates the command. If $S K=1$, then the MFDC skips the sector with the Data Address Mark and reads the next sector.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 0 | 1 | 1 | 0 | 0 |
|  | 2 | X | X | X | X | X | HD | US1 | Uso |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## READ A TRACK

The Read a Track command is similar to the Read Data command except that this is a continuous read operation where all Data fields from each of the sectors on a track are read and transferred to the data bus. Immediately after encountering the Index Hole, the MFDC starts reading the Data fields as continuous blocks of data. This command terminates when the number of sectors read is equal to EOT. Multi-track operations are not allowed with this command.

If the MFDC finds an error in the ID or Data CRC check bytes, it continues to read data from the track. The MFDC compares the ID information read from each sector with the value stored in the IDR, and sets the ND flag in ST1 to a 1 if there is no match.

If the MFDC does not find an ID Address Mark on the disk after it encounters the Index Hole for the second time it terminates the command, sets the Missing Address Mark (MA) flag in ST1 to a 1 , and sets bits 7 and 6 of STO to 0 and 1, respectively.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | MF | SK | 0 | 0 | 0 | 1 | 0 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number ( H ) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :--- | :--- | :--- |
|  | 2 | Status Register 1 (ST1) |
| 3 | Status Register 2 (ST2) |  |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## READ ID

The two-byte Read ID command returns the present position of the read/write head. The MFDC obtains the value from the first ID field it is able to read, sets bits 7 and 6 in STO to 0 and terminates the command.

If no proper ID Address Mark is found on the disk before the Index Hole is encountered for the second time then the Missing Address Mark (MA) flag in ST1 is set to a 1, and if no data is found then the ND flag in ST1 is also set a 1 . Bits 7 and 6 in STO are set to 0 and 1 , respectively and the command is terminated.

During this command there is no data transfer between MFDC and the data bus except during the result phase.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $W$ | 1 | 0 | MF | 0 | 0 | 1 | 0 | 1 | 0 |
|  | 2 | $X$ | $X$ | $X$ | $X$ | $X$ | HD | US1 | USO |

## Result Phase:

| $R$ | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## FORMAT A TRACK

The six-byte Format a Track command formats an entire track. After the Index Hole is detected, data is written on the disk: Gaps, Address Marks, ID fields and Data fields; all are recorded per the format recommended by Sony Corporation. The particular format written is also controlled by the values of Number of Bytes/ Sector (N), Sectors/Track (ST), Gap Length (GPL) and Data Pattern ( D ) which are supplied by the processor during the command phase. The Data field is filled with the data pattern stored in D.

The ID field for each sector is supplied by the processor in response to four data requests per sector issued by the MFDC. The type of data request depends upon the Non-DMA flag (ND) in the Specify command. In the DMA mode ( $\mathrm{ND}=0$ ), the MFDC asserts the DMA Request (DRQ) output four times per sector. In the Non-DMA mode (ND = 1), the MFDC asserts Interrupt Request (INT) output four times per sector.

The processor must write one data byte in response to each request, sending (in the consecutive order) the Track Number (T), Head Number (H), Sector Number (R) and Number of Bytes/ Sector ( N ). This allows the disk to be formatted with nonsequential sector numbers, if desired.

The processor must send new values for $T, H, R$, and $N$ to the MFDC for each sector on the track. For sequential formatting $R$ is incremented by one after each sector is formatted, thus, R contains the total numbers of sectors formatted when it is read during the result phase. This incrementing and formatting continues for the whole track until the MFDC, upon encountering the Index Hole for the second time, terminates the command and sets bits 7 and 6 in STO to 0.

If the Fault (FLT) signal is high from the FDD at the end of a write operation, the MFDC sets the Equipment Check (EC) flag in STO to a 1, sets bits 7 and 6 of STO to 0 and 1, respectively, and terminates the command. Also, a low (RDY) signal at the beginning of a command execution phase causes bits 7 and 6 of STO to be set to 0 and 1 , respectively.

Table 5 shows the relationship between N, ST, and GPL for various disk and sector sizes.

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | MF | 0 | 0 | 1 | 1 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Number of Bytes per Sector ( N ) |  |  |  |  |  |  |  |
|  | 4 | Sectors per Track (ST) |  |  |  |  |  |  |  |
|  | 5 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 6 | Data Pattern (D) |  |  |  |  |  |  |  |

Table 5. Micro Floppy Disk Sector Size Relationship

| Format | Mode | Sector Size Bytes/Sector | No. of Data Bytes/Sector (N) | No. of Sectors/Tracks (ST) ${ }^{1}$ | Gap Length (GPL) ${ }^{1}$ Format Command |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Sony (Read and Write) | FM | $\begin{aligned} & 128 \\ & 256 \\ & 512 \end{aligned}$ | 00 <br> 01 02 | 10 <br> 09 <br> 05 | $\begin{aligned} & 1 B \\ & 2 A \\ & 3 A \end{aligned}$ |
|  | MFM ${ }^{2}$ | $\begin{gathered} 256 \\ 512 \\ 1024 \end{gathered}$ | $\begin{aligned} & 01 \\ & 02 \\ & 03 \end{aligned}$ | $10$ $09$ <br> 05 | 36 <br> 54 <br> 74 |
| IBM <br> (Read Only) | FM | $\begin{aligned} & 128 \\ & 128 \\ & 256 \\ & \hline \end{aligned}$ | $\begin{aligned} & 00 \\ & 00 \\ & 01 \\ & \hline \end{aligned}$ | OF <br> 09 <br> 04 | $\begin{aligned} & 1 B \\ & 2 A \\ & 3 A \end{aligned}$ |
|  | MFM ${ }^{2}$ | $\begin{gathered} 256 \\ 512 \\ .1024 \end{gathered}$ | $\begin{aligned} & 01 \\ & 02 \\ & 03 \end{aligned}$ | $\begin{aligned} & 0 F \\ & 09 \\ & 04 \end{aligned}$ | $\begin{aligned} & 36 \\ & 54 \\ & 74 \end{aligned}$ |

## Notes:

1. Values of ST and GPL are hexadecimal.
2. In MFM mode the MDFC cannot perform a read/write/format operation with 128 bytes/sector ( $\mathrm{N}=00$ ).

## Result Phase

| R | 1 | Status Register 0 (ST0) |
| :---: | :---: | :---: |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
|  | 4 | Track Number ( ${ }^{\text {\% }}$ |
|  | 5 | Head Number (H)* |
|  | 6 | Sector Number (R)* |
|  | 7 | Number of Data Bytes per Sector (N)* |
| (1) | nat | has no meaning in this command. |

## SCAN COMMANDS

The scan commands compare data read from the disk to data supplied from the data bus. The MFDC compares the data, and looks for a sector of data which meets the conditions of $D_{\text {FDD }}$ $=D_{\text {BUS }}, D_{\text {FDD }} \leq D_{\text {BUS }}$, or $D_{\text {FDD }} \geq D_{\text {BUS }}$ ( $D=$ the data pattern in hexadecimal). A magnitude comparison is performed ( $\mathrm{FF}=$ largest number, $00=$ smallest number). The hexadecimal byte of FF either from the bus or from FDD can be used as a mask byte because it always meets the condition of the compare. After a whole sector of data is compared, if the conditions are not met, the sector number is incremented $(R+S T P \rightarrow R)$, and the scan operation is continued. The scan operation continues until one of the following events occur: the conditions for scan are met (equal, low or equal, or high or equal), the last sector on the track is reached (EOT), or TC is received.

If conditions for scan are met, the MFDC sets the Scan Hit (SH) flag in ST2 to a 1, and terminates the command. If the conditions for scan are not met between the starting sector (as specified by R) and the last sector on the track (EOT), then the MFDC sets the Scan Not Satisfied (SN) flag in ST2 to a 1, and terminates the command. The receipt of TC from the processor or DMA controller during the scan operation will cause the MFDC to complete the comparison of the particular byte which is in process, and then to terminate the command. Table 6 shows the status of bits SH and SN under various conditions of scan.

If SK = 0 and the MFDC encounters a Deleted Data Address Mark on one of the sectors, it regards that sector as the last sector of the track, sets the Control Mark (CM) bit in ST2 to a 1 and terminates the command. If $S K=1$, the MFDC skips the sector with the Deleted Data Address Mark, sets the CM flag to a 1 in order to show that a Deleted Sector has been encountered, and reads the next sector.

When either the STP sectors are read (contiguous sectors $=$ 01 , or alternate sectors $=02$ ) or MT (Multi-Track) is set, the last sector on the track must be read. For example, if STP $=02, M T=0$, the sectors are numbered sequentially 1 through 26, and the scan command starts reading at sector 21. Sectors 21, 23, and 25 are read, then the next sector (26) is skipped and the Index Hole is encountered before the EOT value of 26 can be read. This results in an abnormal termination of the command. If the EOT had been set at 25 or the scanning started at sector 20 , then the scan command would be completed in a normal manner.

Table 6. Scan Status Codes

| Command | Status Register 2 |  | Comments |
| :---: | :---: | :---: | :---: |
|  | Bit $2=\mathbf{S N}$ | Bit $3=\mathbf{S H}$ |  |
| Scan Equal | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & \hline \end{aligned}$ | $\begin{aligned} & D_{\text {FDD }}=D_{\text {BUS }} \\ & D_{\text {FDD }} \neq D_{\text {BUS }} \end{aligned}$ |
| Scan Low or Equal | $\begin{aligned} & \hline 0 \\ & 0 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \\ & \hline \end{aligned}$ | $\begin{aligned} & D_{\text {FDD }}=D_{\text {BUS }} \\ & D_{\text {FDD }}<D_{\text {Bus }} \\ & D_{\text {FDD }}>D_{\text {BUS }} \end{aligned}$ |
| Scan High or Equal | $\begin{aligned} & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & D_{\text {FDD }}=D_{\text {BUS }} \\ & D_{\text {FDD }}>D_{\text {Bus }} \\ & D_{\text {FDD }}<D_{\text {BuS }} \end{aligned}$ |

During a scan command data is supplied from the data bus for comparison against the data read from the disk. In order to avoid having the Over Run (OR) flag set in ST1, data must be available from the data bus in less than $27 \mu \mathrm{~s}$ (FM mode) or $13 \mu \mathrm{~S}$ (MFM mode). If an OR occurs, the MFDC terminates the command and sets bits 7 and 6 of STO to 0 and 1, respectively.

The following tables specify the command bytes and describe the result bytes for the three scan commands.

## SCAN EQUAL

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 1 | 0 | 0 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number ( $T$ ) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Lerigth (GPL) |  |  |  |  |  |  |  |
|  | 9 | Sector Test Process (STP) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## SCAN LOW OR EQUAL

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 1 | 1 | 0 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Sector Test Process (STP) |  |  |  |  |  |  |  |

Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
| 3 | Status Register 2 (ST2) |  |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
|  | 7 | Number of Data Bytes per Sector (N) |

## SCAN HIGH OR EQUAL

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| w | 1 | MT | MF | SK | 1 | 1 | 1 | 0 | 1 |
|  | 2 | x | x | X | x | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Sector Test Process (STP) |  |  |  |  |  |  |  |

## Result Phase:

| $R$ | 1 | Status Register 0 (ST0) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## SEEK

The three-byte Seek command steps the FDD read/write head from track to track. The MFDC has two independent Present Track Registers for each drive. They are cleared only by the Recalibrate command. The MFDC compares the Present Track Number (PTN) which is the current head position with the New Track Number (NTN), and if there is a difference, performs the following operation:

If PTN < NTN: Sets the direction output (LCT/DIR) high and issues step pulses (FR/STP) to the FDD to cause the read/write head to step in.
If PTN $>$ NTN: Sets the direction output (LCT/DIR) low and issues step pulses to the FDD to cause the read/write head step out.

The rate at which step pulses are issued is controlled by the Step Rate Time (SRT) in the Specify command. After each step pulse is issued, NTN is compared against PTN. When NTN = PTN, then the Seek End (SE) flag in STO is set to a 1, bits 7 and 6 in STO are set to 0 , and the command is terminated. At this point MFDC asserts INT.

The FDD Busy flag (bit 0-3) in the Main Status Register (MSR) corresponding to the FDD performing the Seek operation is set to a 1 .

After command termination, all FDD Busy bits set are cleared by the Sense Interrupt Status command.

During the command phase of the Seek operation the MFDC sets the Controller Busy (CB) flag in the MSR to 1; but during the execution phase the CB flag is set to 0 to indicate MFDC non-busy. While the MFDC is in the non-busy state, another Seek command may be issued, and in this manner parallel seek operations may be performed on all drives at once.

No command other than Seek will be accepted while the MFDC is sending step pulses to any FDD. If a different command type is attempted, the MFDC will set bits 7 and 6 in STO to a 1 and 0 , respectively, to indicate an invalid command.

If the FDD is in a not ready state at the beginning of the command execution phase or during the Seek operation, then the MFDC sets the Not Ready (NR) flag in STO to a 1, sets STO bits 7 and 6 to 0 and 1, respectively, and terminates the command.

If the time to write the three bytes of the Seek command exceeds $150 \mu \mathrm{~s}$, the time between the first two step pulses may be shorter than the Step Rate Time (SRT) defined by the Specify command by as much as 1 ms .

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | 2 | X | X | X | X | X | 0 | US 1 | US 0 |
|  | 3 | New Track Number (NTN) |  |  |  |  |  |  |  |

## Result Phase: None.

## RECALIBRATE

This two-byte command retracts the FDD read/write head to the Track 0 position. The MFDC clears the contents of the PTN counters, and checks the status of the Track 0 signal from the FDD. As long as the Track 0 signal (TRKO) is low, the direction signal (LCT/DIR) output remains low and step pulses are issued on FR/STP. When TRKO goes high the MFDC sets the Seek End (SE) flag in STO to a 1 and terminates the command. If the TRKO is still low after 256 step pulses have been issued, the MFDC sets Seek End (SE) and Equipment Check (EC) flags in STO to 1 s , sets bits 7 and 6 of STO to 0 and 1, respectively, and terminates the command.

The ability to do overlap Recalibrate commands to multiple FDDs and the loss of the RDY signal, as described in the Seek command, also applies to the Recalibrate command.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | $\mathbf{3}$ | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $W$ | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
|  | 2 | $X$ | $X$ | $X$ | $X$ | $X$ | 0 | US1 | US0 |

Result Phase: None.

## SENSE INTERRUPT STATUS

Interrupt Request (INT) is asserted by the MFDC when any of the following conditions occur:

1. Upon entering the result phase of:
a. Read Data command
b. Read a Track command
c. Read ID command
d. Read Deleted Data command
e. Write Data command
f. Format a Track command
g. Write Deleted Data command
h. Scan commands
2. Ready (RDY) line from the FDD changes state
3. Seek or Recalibrate command termination
4. During execution phase in the Non-DMA mode

INT caused by reasons 1 and 4 above occur during normal command operations and are easily discernible by the processor. During an execution phase in Non-DMA mode, bit 5 in the MSR is set to 1 . Upon entering result phase this bit is set to 0 . Reasons 1 and 4 do not require the Sense Interrupt Status command. The interrupt is cleared by reading or writing data to MFDC. Interrupts caused by reasons 2 and 3 are identified with the aid of the Sense Interrupt Status command. This command resets INT and sets/resets bits 5, 6, and 7 of STO to identify the cause of the interrupt. Table 7 defines the seek and interrupt codes.

Neither the Seek or Recalibrate command has a result phase. Therefore, it is mandatory to use the Sense Interrupt Status command after these commands to effectively terminate them and to verify where the head is positioned by checking the Present Track Number (PTN).

Issuing a Sense Interrupt Status command without an interrupt pending is treated as an invalid command.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $W$ | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |

## SPECIFY

The three-byte Specify command sets the initial values for each of the three internal timers. The Head Unload Time (HUT) defines the time from the end of the execution phase of one of the read/write commands to the head unload state. This timer is programmable from 16 to 240 ms in increments of $16 \mathrm{~ms}(1=16 \mathrm{~ms}$, $2=32 \mathrm{~ms}, \ldots \mathrm{~F}=240 \mathrm{~ms}$ ).

The Step Rate Time (SRT) defines the time interval between adjacent step pulses. This timer is programmable from 1 to 16 ms in increments of 1 ms ( $F=1 \mathrm{~ms}, E=2 \mathrm{~ms}, \mathrm{D}=3 \mathrm{~ms}, \ldots$ $0=16 \mathrm{~ms}$.)

The Head Load Time (HLT) defines the time between the Head Load (HDL) signal going high and the start of the read/write operation. This timer is programmable from 2 to 254 ms in increments of $2 \mathrm{~ms}(01=2 \mathrm{~ms}, 02=4 \mathrm{~ms}, 03=6 \mathrm{~ms}, \ldots$ $7 F=254 \mathrm{~ms}$ ).

The time intervals are a direct function of the clock (CLK on pin 19). Times indicated above are for an 8 MHz clock. If the clock is reduced to 4 MHz (mini-floppy application) then all time intervals are increased by a factor of two.

The choice of DMA or Non-DMA operation is made by the NonDMA mode (ND) bit. When this bit = 1 the Non-DMA mode is selected, and when ND $=0$ the DMA mode is selected.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
|  | 2 | SRT |  |  |  | HUT |  |  |  |
|  | 3 | HLT |  |  |  |  |  |  | ND |

SRT - Step Rate Time
HUT - Head Unload Time
HLT - Head Load Time
ND - Non-DMA mode
Result Phase: None.

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Present Track Number (PTN) |

Table 7. STO Seek and Interrupt Code Definition for Sense Interrupt Status

| Status Register $\mathbf{0}$ (STO) Bits |  |  |  |
| :---: | :---: | :---: | :---: |
| Interrupt Code (IC) | Seek End (SE) |  |  |
| 7 | 6 |  | Cause |
| 1 | 1 |  | RDY line changed state, either polarity |
| 0 | 0 | 1 | Normal termination of Seek or Recalibrate command |
| 0 | 1 | 1 | Abnormal termination of Seek or Recalibrate command |

## SENSE DRIVE STATUS

This two-byte command obtains and reports the status of the FDDs. Status Register 3 (ST3) is returned in the result phase and contains the drive status.

## Command Phase:

| R/W | BYTE | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{W}$ | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
|  | 2 | $X$ | $X$ | $X$ | $X$ | $X$ | $H D$ | US1 | US0 |

## Result Phase:

| $R$ | 1 | Status Register 3 (ST3) |
| :--- | :--- | :--- |

## INVALID COMMAND

If an invalid command (i.e., a command not previously defined) is received by the MFDC, then the MFDC terminates the command after setting bits 7 and 6 of STO to 1 and 0 , respectively. The MFDC does not generate an interrupt during this condition. Bits 6 and 7 (DIO and RQM) in the MSR are both set to a 1 indicating to the processor that the MFDC is in the result phase and that STO must be read. A hex 80 in STO indicates that an invalid command was received.

A Sense Interrupt Status command must be sent after a Seek or Recalibrate interrupt, otherwise the MFDC considers the next command to be an invalid command.

In some applications the user may wish to use this command as a No-Op command, to place the MFDC in a standby or no operation state.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $W$ | 1 | Invalid Codes |  |  |  |  |  |  |  |

## Result Phase:

| $R$ | 1 | Status Register $0(\mathrm{STO})=80$ |
| :---: | :---: | :--- |

## PROCESSOR INTERFACE

During the command or result phases, the Main Status Register (MSR) must be read by the processor before each byte of information is transferred to, or from, the MFDC Data Register. After each byte of data is written to, or read from, the Data Register, the processor should wait $12 \mu \mathrm{~s}$ before reading the MSR. Bits 6 and 7 in the MSR must be a 0 and 1, respectively, before each command byte can be written to the MFDC. During the result phase, bits 6 and 7 of the MSR must both be 1s prior to reading each byte from the Data Register onto the data bus. Note that this status reading of bits 6 and 7 of the MSR before each byte transfer to and from the MFDC is required in only the command and result phases and not during the execution phase.

During the result phase all bytes shown in the result phase must be read by the processor. The Read Data command, for example, has seven bytes of data in the result phase. All seven
bytes must be read to successfully complete the Read Data command. The MFDC will not accept a new command until all seven bytes have been read. Other commands may require fewer bytes to be read during the result phase.

## INTERRUPT REQUEST MODE

During the execution phase, the MSR need not be read. The receipt of each data byte from the FDD is indicated by INT high on pin 18. When the MFDC is in Non-DMA mode, INT is asserted during the execution phase. When the MFDC is in the DMA mode, INT is asserted at the result phase. The INT signal is reset by a read ( $\overline{\mathrm{RD}}$ low) or write (WR low) of data to the MFDC. A further explanation of the INT signal is described in the Sense Interrupt Status command on page 16. If the system cannot handle interrupts fast enough (within $13 \mu \mathrm{~s}$ for MFM mode or $27 \mu \mathrm{~S}$ for FM mode), it should poll bit 7 (RQM) in the MSR. In this case, RQM in the MSR functions as an Interrupt Request (INT). If the RQM bit is not set, the Over Run (OR) flag in ST1 will be set to a 1 and bits 7 and 6 of STO will be set to a 0 and 1 , respectively.

## DMA MODE

When the MFDC is in the DMA mode (ND $=0$ in the third command byte of the Specify command), DRQ (DMA Request) is asserted during the execution phase (rather than INT) to request the transfer of a data byte between the data bus and the MFDC.

During a read command, the MFDC asserts DRQ as each byte of data is available to be read. The DMA controller responds to this request with $\overline{D A C K}$ low (DMA Acknowledge) and RD low (read). When DACK goes low the DMA Request is reset (DRQ low). After the execution phase has been completed (TC high or the EOT sector is read), INT is asserted to indicate the beginning of the result phase. When the first byte of data is read during the result phase, INT is reset low.

During a write command, the MFDC asserts DRQ as each byte of data is required. The DMA controller responds to this request with DACK low (DMA Acknowledge) and $\overline{W R}$ low (write). When DACK goes low the DMA Request is reset (DRQ low). After the execution phase has been completed (TC high or the EOT sector is written), INT is asserted. This signals the beginning of the result phase. When the first byte of data is read during the result phase, the INT is reset low.

## FDD POLLING

After the Specify command has been received by the MFDC, the Unit Select lines (USO and US1) begin the polling mode. Between commands (and between step pulses in the Seek Command) the MFDC polls all the FDD's looking for a change in the RDY line from any of the drives. If the RDY line changes state (usually due to the door opening or closing) then the MFDC asserts INT. When Status Register 0 (STO) is read (after Sense Interrupt Status command is issued), Not Ready ( $N R=1$ ) will be indicated. The polling of the RDY line by the MFDC occurs continuously between commands, thus notifying the processor which drives are on- or off-line. Each drive is polled every 1.024 ms except during read/write commands.


Figure 3. MFDC and System Data Transfer Timing



Figure 5. Clock Timing


Figure 6. Read Cycle Timing


Figure 7. Write Cycle Timing


Figure 8. DMA Operation Timing


Figure 9. FDD Write Operation Timing


NOTE:
EITHER POLARITY DATA WINDOW IS VALID

Figure 10. FDD Read Operation Timing


Figure 11. Seek Operation Timing


Figure 12. Fault Reset Timing

TERMINAL COUNT
(TC)


Figure 14. Terminal Count Timing


Figure 13. Index Timing


Figure 15. Reset Timing


CLOCKS ARE DRIVEN AT 3.0V FOR A LOGIC " 1 " AND 0.3V FOR A LOGIC ' 0 :' TIMING MEASUREMENTS ARE MADE AT 2.4V FOR A LOGIC " 1 " AND 0.65V FOR A LOGIC " 0 "'

Figure 16. AC Timing Measurement Conditions

## AC CHARACTERISTICS

$\left(V_{c c}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{ss}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}$ )


Notes:

1. | MFM | Mini | Standard |
| :---: | :---: | :---: |
| 0 | $4 \mu \mathrm{~S}$ | $2 \mu \mathrm{~S}$ |
| 1 | $2 \mu \mathrm{~S}$ | $1 \mu \mathrm{~S}$ |
2. For MFM $=0$ : Typ. $=2 \mu \mathrm{~S}$

For MFM $=1$ : Typ. $=1 \mu \mathrm{~S}$
3. $\mathrm{t}_{\mathrm{SC}}=33 \mu \mathrm{~s} \mathrm{~min}$. is for different drive units. In the case of the same unit, $\mathrm{t}_{\mathrm{sc}}$ can range from 1 ms to 16 ms with 8 MHz clock period.

## ABSOLUTE MAXIMUM RATINGS*

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

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

## OPERATING CONDITIONS

| Parameter | Range |
| :---: | :---: |
| $V_{C C}$ Power Supply | $5.0 \mathrm{~V} \pm 5 \%$ |
| Operating Temperature | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input Low Voltage Logic CLK and WCK | $\mathrm{V}_{\mathrm{IL}}$ | $\begin{aligned} & -0.5 \\ & -0.5 \end{aligned}$ | $\begin{gathered} 0.8 \\ 0.65 \end{gathered}$ | V |  |
| Input High Voltage Logic CLK and WCK | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{aligned} & 2.0 \\ & 2.4 \end{aligned}$ | $\begin{aligned} & v_{c c}+0.5 \\ & v_{c c}+0.5 \end{aligned}$ | V |  |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ |  | 0.45 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | $\mathrm{V}_{\mathrm{cc}}$ | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\text {cc }}$ Supply Current | $\mathrm{I}_{\mathrm{CC}}$ |  | 150 | mA | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Load Current | $1 / 1$ |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ |
| All Inputs |  |  | -10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{OV}$ |
| High Level Output Leakage Current | $\mathrm{I}_{\text {LOH }}$ |  | 10 | ${ }_{\mu} \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V} \text { to } 5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| Low Level Output Leakage Current | ILOL |  | -10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V} \text { to } 5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OUT}}=+0.45 \mathrm{~V} \end{aligned}$ |
| Internal Power Dissipation | $\mathrm{P}_{\text {INT }}$ | - | 1.0 | W | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |

## CAPACITANCE

$\left(T_{A}=25^{\circ} \mathrm{C} ; \mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz} ; \mathrm{V}_{\mathrm{cc}}=\mathrm{OV}\right.$ )

| Parameter | Symbol | Max Limit | Unit |
| :--- | :---: | :---: | :---: |
| Clock Input | $\mathrm{C}_{\text {IN(0) }}$ | 20 | pF |
| Input | $\mathrm{C}_{\text {IN }}$ | 10 | pF |
| Output | $\mathrm{C}_{\text {OUT }}$ | 20 | pF |

Note: All pins except pin under test tied to ground.

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



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

## 40-PIN PLASTIC DIP



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

R6765 DOUBLE-DENSITY FLOPPY DISK CONTROLLER (DDFDC)

PRELIMINARY

## DESCRIPTION

The R6765 Double-Density Floppy Disk Controller (DDFDC) interfaces up to four floppy disk drives to an 8 -bit or 16-bit microprocessor-based system including Z-80, 8080A, 8085A, 8086, and 8088 . The DDFDC simplifies the system design by minimizing both the number of external hardware components and software steps needed to implement the floppy disk drive (FDD) interface. Control signals supplied by the DDFDC reduce the number of components required in external phase locked loop and write precompensation circuitry. Memory-mapped registers containing commands, status and data simplify the software interface. Built-in functions reduce the software overhead needed to control the FDD interface. The DDFDC supports both the IBM 3740 Single-Density (FM) and IBM System 34 DoubleDensity (MFM) formats.

The DDFDC interfaces directly to the synchronous microprocessor bus and operates with 8 -bit byte length data transferred on the bus in either DMA or non-DMA mode. In DMA mode, the CPU need only load the command into the DDFDC and all data transfers occur under DMA control. The R6765 is directly compatible with the Z8410/ $\mu$ PD8257 Direct Memory Access Controller (DMAC). In non-DMA mode, the DDFDC generates an interrupt to the CPU indicating that a byte of data is available.

Controller commands, command or device status, and data are transferred between the DDFDC and the CPU via six internal registers. The Main Status Register (MSR) stores the DDFDC status information while four additional status registers provide result information to the CPU following each controller command. The Data Register (DR) stores actual disk data, parameters, controller commands and FDD status information for use by the CPU.

The R6765 executes 15 separate multi-byte commands:

| Read Data | Specify |
| :--- | :--- |
| Write Data | Format a Track |
| Read Deleted Data | Scan Equal |
| Write Deleted Data | Scan High or Equal |
| Read a Track | Scan Low or Equal |
| Read ID | Sense Interrupt Status |
| Seek | Sense Drive Status |
| Recalibrate (Restore to Track 0) |  |

Read Data

Writ Daled Data
Read a Track
Read ID
Recalibrate (Restore to Track 0)

## FEATURES

- Address mark detection circuitry
- Software control of
-Track stepping rate
-Head load time
-Head unload time
- IBM compatible in both single- and double-density recording formats
- Programmable data record lengths: 128, 256, 512, 1024, 2048, 4096 or 8192 bytes/sector
- Multi-sector and multi-track transfer capability
- Controls up to four floppy disk drives
- Data scan capability-will scan a single sector or an entire track of data fields, comparing on a byte-by-byte basis data in the processor's memory with data read from the disk
- Data transfers in DMA or non-DMA mode
- Parallel seek operations on up to four drives
- Directly compatible with an 8 -bit or 16 -bit synchronous microprocessor bus including Z-80/8080A/8085A, 8086, and 8088
- Replacement for NEC $\mu$ PD765A and Intel 8272
- Single phase 4 or 8 MHz Clock
- Single +5 Volt Power Supply


## ORDERING INFORMATION

| Part Number |  |
| :---: | :---: |
| R6765 | Temperature Range <br> $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| CLK Frequency: |  |
| $5 \quad=4 \mathrm{MHz}$ |  |
| Blank $=8 \mathrm{MHz}$ |  |
| Package: |  |
| $P=$ Plastic |  |
| $C=$ Ceramic |  |



Figure 1. DDFDC Input and Output Signals

## PIN DESCRIPTION

Throughout this document signals are presented using the terms active and inactive, or asserted and negated, independent of whether the signal is active in the high-voltage state or lowvoltage state. (The active state of each logic pin is described below.) Active low signals are denoted by a superscript bar.

## BUS INTERFACE

D0-D7-Data Lines. The bidirectional data lines transfer data between the DDFDC and the 8 -bit data bus.

CLK-CLOCK. The clock is a TTL compatible 4 or 8 MHz square wave signal.

RST-RESET. This active high input places the DDFDC in the idle state and resets the output lines to the floppy disk drive (FDD) to the low state.
$\overline{\mathbf{C S}}$-Chip Select. The DDFDC is selected when the $\overline{\mathrm{CS}}$ input is low.

A0-Data/Status Register Select. This input selects the Data or Status Register for reading from or writing to. When AO = high, the Data Register is selected and the state of $\overline{R D}$ or $\overline{W R}$ determines whether it is a read ( $\overline{\mathrm{RD}}=\mathrm{low}$ ) or a write $(\overline{\mathrm{WR}}=$ low) operation. When $A O=$ low, the Status Register is selected. This register may only be read ( $\overline{\mathrm{RD}}=$ low); the state $\overline{\mathrm{WR}}=$ low is invalid when the Status Register is selected.

INT-Interrupt Request. This active high output is the interrupt request generated by the DDFDC to the CPU. INT is asserted upon completion of some DDFDC commands and before a data byte is transferred between the DDFDC and the data bus (in the Non-DMA mode).

RD-Read. This active low input defines the data bus transfer as a read cycle. When low, the data transfer is from the DDFDC to the data bus.

WR-Write. This active low input defines the data bus transfer as a write cycle. When low, the data transfer is from the data bus to the DDFDC.

## DIRECT MEMORY ACCESS CONTROLLER (DMAC) INTERFACE

DACK-DMA Acknowledge. The DMA transfer acknowledge signal is a TTL compatible input generated by the DMA controller (DMAC) controlling the DDFDC. The DMA cycle is active wher DACK is low and the DDFDC is performing a DMA transfer.

DRQ—Data DMA Request. The transfer request signal is a TTL compatible output generated by the DDFDC to request a data transfer operation under control of the DMAC (in the DMA mode). The request is active when DRQ = high. The signal is reset inactive when DMA Acknowledge $(\overline{\mathrm{DACK}})$ is asserted (low).

TC-Terminal Count. This input signal is issued to the DDFDC when the DMA transfer for a channel is complete. The signal is active high concurrent with the DACK input when the DMA operation is complete as a result of that transfer.

## FDD SERIAL DATA INTERFACE

RDD-Read Data. Read Data input from the floppy disk drive (FDD) containing clock and data bits.

RDW-Read Data Window. Data Window input generated by the Phase Locked Loop (PLL) and used to sample data from the FDD.

VCO-Variable Frequency Oscillator Sync. This output signal inhibits the VCO in the PLL circuit when low and enables the VCO in the PLL circuit when high. This inhibits RDD and RDW from being generated until valid data is detected from the FDD.

WCK-Write Clock. This input clock determines the Write Data rate to the FDD. The data rate is 500 KHz in the FM mode (MFM = low) and 1 MHz in the MFM mode (MFM = high). The pulse width is $\mathbf{2 5 0} \mathbf{n s}$ (typical) in both modes.

WDA-Write Data. Serial write data output to the FDD containing both clock and data bits.

WE-Write Enable. This output signal enables the Write Data into the FDD when high.

PS0-PS1-Preshift. These outputs are encoded to convey write compensation status during the MFM mode to determine early, late or normal times as follows:

| Write Precompensation Status | Preshift Outputs |  |
| :---: | :---: | :---: |
|  | PS0 | PS1 |
| Normal | 0 | 0 |
| Late | 0 | 1 |
| Early | 1 | 0 |
| Invalid | 1 | 1 |
| $0=$ Low, $1=$ High |  |  |

## FDD STATUS INTERFACE

RDY-Ready. An active high input signal indicates the FDD is ready to send data to, or receive data from, the DDFDC.

IDX-Index. An active high input signal from the FDD indicates the index hole is under the index sensor. Index is used to synchronize DDFDC timing.

RW/SEEK-Read Write/Seek. Mode selection signal to the FDD which controls the multiplexer from the multiplexed signals. When RW/SEEK is low, the Read/Write mode is commanded; when $\overline{\text { RW}} /$ SEEK is high, the Seek mode is commanded.

| RW/SEEK | Mode | Active FDD Interface Signals |
| :---: | :---: | :---: |
| Low | Read/Write | WP, FLT, LCT, FR |
| High | Seek | TS, TRKO, DIR, STP |

WP/TS-Wrtte Protect/Two Side. An active high multiplexed input signal from the FDD. In the Read/Write mode, WPTS high indicates the media is write-protected. In the Seek mode, WP/TS high indicates the media is two-sided.

FLT/TRK0-Fault/Track Zero. An active high multiplexed input from the FDD. In the Read/Write mode ( $\overline{\mathrm{RW}} / \mathrm{SEEK}=\mathrm{low}$ ), FLT/TRKO high indicates an FDD fault. In the Seek mode, FLT/TRKO high indicates that the read/write head is positioned over track zero.

LCT/DIR-Low Current/Direction. A multiplexed output to the FDD. In the Read/Write mode, LCT/DIR is low when the read/write head is to be positioned over the inner tracks and the LCT/DIR is high when the head is to be positioned over the outer tracks. In the Seek mode, LCT/DIR controls the head direction. When LCT/DIR is high, the head steps to the outside of the disk; when LCT/DIR is low, the head steps to the inside of the disk.

FR/STP—Fault Reset/Step. A multiplexed output to the FDD. In the Read/Write mode, FR/STP high resets the fault indicator in the FDD. An FR pulse is issued at the beginning of each read or write command prior to issuing HDL. In the Seek mode, FR/STP provides the step pulses to move the read/write head to another track in the direction indicated by the LCT/DIR signal.

HDL-Head Load. An active high output to notify the FDD that the read/write head should be loaded (placed in contact with the media). A low level indicates the head should be unloaded.


R6765 DDFDC Pin Diagram

HD-Head Select. An output to the FDD to select the proper read/write head. Head One is selected when HD = high and Head Zero is selected when HD = low.

USO-US1-Unit Select. Output signals for floppy disk drive selection as follows:

| Unit Select |  | Floppy Disk <br> Drive Select |
| :---: | :---: | :---: |
| USO | US1 |  |
| 0 | 0 | 1 |
| 0 | 1 | 2 |
| 1 | 0 | 3 |
| 1 | 1 |  |
| $0=$ Low, $1=$ High |  |  |

MFM-MFM Mode. Output signal to the FDD to indicate MFM or FM mode. Selects the MFM mode when MFM = high and the FM mode when MFM = low.

## DDFDC REGISTERS

The DDFDC contains six registers which may be accessed by the processor or DMA controller via the system (i.e., microprocessor) bus: a Main Status Register, a Data Register, and four Result Status Registers. The 8-bit Main Status Register (MSR) contains the status information of the DDFDC, and may be accessed at any time. The 8-bit Data Register, consisting of several registers in a stack with only one register presented to the data bus at a time, stores data, commands, parameters and FDD status information. Bytes of data are read out of, or written into, the Data Register in order to initiate a command or to obtain the results of a command execution.

The read-only Main Status Register facilitates the transfer of data between the system and the DDFDC: The other Status Registers (ST0, ST1, ST2 and ST3) are only available during the result phase, and may be read only after completing a command. The particular command which has been executed determines how many of the Status Registers will be read.

VCC-Power. +5 V dc.
GND-Ground $\left(V_{s s}\right)$.


Figure 2. DDFDC Block Diagram

The relationship between the status/data registers and the $\overline{\mathrm{WR}}$, $\overline{\mathrm{RD}}$ and AO signals is shown below.

| $\mathbf{A 0}$ | $\overline{\mathbf{R D}}$ | $\overline{\mathrm{WR}}$ | Function |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Illegal |
| 0 | 0 | 1 | Read Main Status Register |
| 0 | 1 | 0 | Illegal |
| 1 | 0 | 0 | Illegal |
| 1 | 0 | 1 | Read from Data Register |
| 1 | 1 | 0 | Write into Data Register |
|  |  |  |  |

Table 1 shows each of the status registers used by the DDFDC and each bit assignment within the individual registers. Table 2 defines the symbols used throughout the command definitions. Each register bit symbol is defined in the register descriptions that follow Table 2.

## REGISTER DEFINITIONS

Main Status Register (MSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RQM | DIO | EXM | CB | D3B | D2B | D1B | D0B |

The Main Status Register (MSR) contains the status information of the DDFDC, and must be read by the processor before each byte is written to, or read from, the Data Register during the command or result phase. MSR reads are not required during the execution phase. The Data Input/Output (DIO) and Request for Master (RQM) bits in the MSR indicate when data is ready and in which direction data will be transferred on the data bus. The maximum time between the last $\overline{R D}$ or $\overline{W R}$ during command or result phases and the DIO and RQM getting set or reset is $12 \mu \mathrm{~s}$. For this reason, every time the MSR is read the processor should wait $12 \mu \mathrm{~s}$. The maximum time from the trailing edge of the last $\overline{R D}$ in the result phase to when bit 4 (DDFDC Busy) goes low is also $12 \mu \mathrm{~s}$.

The DIO and RQM timing chart is shown in Figure 3.

| MSR |  |
| :---: | :---: |
| 7 | RQM -Request for Master: |
| 0 | Data Register is not ready. |
| 1 | Data Register is ready. |
| MSR |  |
| 6 | DIO -Data Input/Output. |
| 0 | Data transfer is from system to the Data Register. |
| 1 | Data transfer is from Data Register to the system. |
| MSR |  |
| 5 | EXM -Execution Mode. (Non-DMA mode only). |
| 0 | Execution phase ended, result phase begun. |
| 1 | Execution phase started. |
| MSR |  |
| 4 | CB -Controller (DDFDC) Busy. |
| 0 | DDFDC is not busy, will accept a command. |
| 1 | DDFDC is busy, will not accept a command. |

MSR
3 D3B -Floppy Disk Drive (FDD) 3 Busy. FDD 3 is not busy, DDFDC will accept read or write command.
1 FDD 3 is busy, DDFDC will not accept read or write command.

## MSR

2 D2B -FDD 2 Busy.
$\frac{2}{0}$ FDD 2 is not busy, DDFDC will accept read or write command.
1 FDD 2 is busy, DDFDC will not accept read or write command.

## MSR

1 D1B -FDD 1 Busy.
$\overline{0} \quad$ FDD 1 is not busy, DDFDC will accept read or write command.
1 FDD 1 is busy, DDFDC will not accept read or write command.

MSR
$\frac{0}{0}$ DOB -FDD 0 Busy.
FDD 0 is not busy, DDFDC will accept read or write command.
1 FDD 0 is busy, DDFDC will not accept read or write command.

## Status Register 0 (STO)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IC | SE | EC | NR | HD | US |  |  |
|  |  |  |  | US1 | USO |  |  |

The Status Register 0 (STO) as well as the other status registers (ST1-ST3), are available only during the result phase, and may be read only after completing a command. The particular command executed determines which status registers are used and may be read.

## STO

76 IC -Interrupt Code.
$\overline{0} \quad \mathbf{0} \quad$ Normal'Termination (NT). Command was properly executed and completed.
$\begin{array}{lll}0 & 1 & \text { Abnormal Termination (AT). Command execution was }\end{array}$ started, but was not successfully completed.
10 Invalid Command (IC). Received command was invalid.
11 Abnormal Termination (AT). The Ready (RDY) signal from the FDD changed state during command execution.

## STO

5 SE -Seek End.
$\overline{0}$ Seek command is not completed.
1 Seek command completed by DDFDC.
STO
4 EC -Equipment Check.
No error.
Either a fault signal is received from the FDD or the track 0 signal failed to occur after 256 step pulses (Recalibrate command).

Table 1. DDFDC Status Register Bit Assignments

Main Status Register (MSR)
Status Register 0 (STO)
Status Register 1 (ST1)
Status Register 2 (ST2)
Status Register 3 (ST3)

| Bit Number |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| RQM | DIO | EXM | CB | D3B | D2B | D1B | DOB |
| IC |  | SE | EC | NR | HD | US |  |
|  |  | US1 |  |  |  | USO |
| EN | 0 |  | DE | OR | 0 | ND | NW | MA |
| 0 | CM | DD | WT | SH | SN | BT | MD |
| FLT | WP | RDY | TRKO | TS | HD | US1 | USO |

Table 2. Command Symbol Description

| Symbol | Name | Description |
| :---: | :---: | :---: |
| AO | Address Line A0 | Controls selection of Main Status Register ( $A 0=$ low) or Data Register ( $A 0=$ high). |
| D | Data | The data pattern which is going to be written into a sector. |
| DO-D7 | Data Bus | 8 -bit data bus, where DO is the least significant data line and D7 is the most significant data line. |
| DTL | Data Length | When N is defined as 00, DTL is the number of data bytes to read from or write into the sector. |
| EOT | End of Track | The final sector number on a track. During read or write operation, the DDFDC stops data transfer after reading from or writing to the sector equal to EOT. |
| GPL | Gap Length | The length of Gap 3. During read/write commands this value determines the number of bytes that the VCO will stay low after two CRC bytes. During the Format a Track command it determines the size of Gap 3. |
| H | Head Address | Head number 0 or 1, as specified in ID field. |
| HD (H) | Head | A selected head number 0 or 1 which controls the polarity of pin 27. ( $H=H D$ in all command words). |
| HLT | Head Load Time | The head load time in the FDD (2 to 254 ms in 2 ms increments). |
| HUT | Head Unload Time | The head unload time after a read or write operation has occurred ( 16 to 240 ms in 16 ms increments). |
| MF | FM or MFM Mode | When MF = 0, FM mode is selected; and when MF = 1, MFM mode is selected. |
| MT | Multi-Track | When MT = 1, a multi-track operation is to be performed. After finishing a read/write operation on side 0 , the DDFDC will automatically start searching for sector 1 on side 1. |
| N | Bytes/Sector | The number of data bytes written in a sector. |
| ND | Non-DMA Mode | When ND $=1$, operation is in the Non-DMA mode; when ND $=0$, operation is in the DMA mode. |
| NTN | New Track Number | A new track number, which will be reached as a result of the Seek command: Desired head position. |
| PTN | Present Track Number | The track number at the completion of Sense Interrupt Status command. Present head position. |
| R | Record (Sector) | The sector number to be read or written. |
| RNW | Read/Write | Either read (R) or write (W) signal. |
| ST | Sectors/Track | The number of sectors per track. |
| SK | Skip | Skip Deleted Data Address Mark. |
| SRT | Step Rate Time | The stepping rate for the FDD ( 1 to 16 ms in 1 ms increments). Stepping rate applies to all drives ( $F=1 \mathrm{~ms}, E=2 \mathrm{~ms}$, etc.) |
| $\begin{aligned} & \text { ST0 } \\ & \text { ST1 } \\ & \text { ST2 } \\ & \text { ST3 } \end{aligned}$ | Status 0 <br> Status 1 <br> Status 2 <br> Status 3 | Four registers which store the status information after a command has been executed. This information is available during the result phase after command execution. These registers should not be confused with the Main Status Register (selected by AO = low). STO-ST3 may be read only after a command has been executed and contain information relevant to that particular command. |
| STP | Sector Test Process | During a Scan command, if STP $=01$, the data in contiguous sectors is compared byte by byte with data sent from the processor (or DMA controller); and if STP $=02$, then alternate sectors are read and compared. |
| T | Track Number | The current/selected track number of the medium (0-255). |
| USO,US1 | Unit Select | A selected drive number (0-3). |

```
STO
    3 NR -Not Ready.
    FDD is ready.
    FDD is not ready at issue of read or write command. If
    a read or write command is issued to side 1 of a single-
    sided drive, this bit is also set.
STO
    HD -Head Address. (At Interrupt).
    Head Select 0.
    Head Select 1.
STO
1 0 US -Unit Select. (At Interrupt).
0}\mathrm{ FDD 0 selected.
1 FDD 1 selected.
0 FDD 2 selected.
1 FDD 3 selected.
```

Status Register 1 (ST1)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $E N$ | 0 | $D E$ | OR | 0 | ND | NW | MA |

## ST1

7 EN -End of Track.
No error.
DDFDC attempted to access a sector beyond the last sector of a track.

ST1
$6 \quad$-Not Used. Always Zero.
ST1
DE -Data Error.
No error. DDFDC detected a CRC error in ID field or the Data field.

## ST1

OR -Over Run.
No error.
DDFDC was not serviced by the system during data transfers, within a predetermined time interval.

ST1
$3 \quad$-Not Used. Always Zero.
ST1
ND -No.Data.
No error.
3 possible errors.

1. DDFDC cannot find sector specified in ID Register during execution of Read Data, Write Deleted Data or Scan commands.
2. DDFDC cannot read ID field without an error during Read ID command.
3. DDFDC cannot find starting sector during execution of Read a Track command.

## ST1

1 NW -Not Writable.
No error.
1 DDFDC detected a write protect signal from FDD during execution of Write Data, Write Deleted Data or Format a Track commands.

## ST1

MA —Missing Address Mark.
No error.
2 possible errors.

1. DDFDC cannot detect the ID Address Mark after encountering the index hole twice.
2. DDFDC cannot detect the Data Address Mark or Deleted Data Address Mark. The MD (Missing Address Mark in Data field) of Status Register 2 is also set.

Status Register 2 (ST2)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | CM | DD | WT | SH | SN | BT | MD |

## ST2

$7 \quad$-Not Used. Always Zero.

## ST2

6 CM -Control Mark.
No error
1 DDFDC encountered a sector which contained a Deleted Data Address Mark during execution of a Read Data, Read a Track, or Scan command, or which contained a Data Address Mark during execution of a Read Deleted Data command.

## ST2

5 DD -Data Error in Data Field.
No error. DDFDC detected a CRC error in the Data field.

## ST2

4 WT -Wrong Track.
No error.
Contents of T on the disk is different from that stored in IDR. Bit is related to ND (Bit 2) of Status Register 1.

ST2
3 SH -Scan Equal Hit.
0 No "equal" condition during a scan command.
1 "Equal" condition satisfied during a scan command.

ST2
2 SN -Scan Not Satisfied.
0 No error.
1 DDFDC cannot find a sector on the track which meets the scan command condition.

## ST2

1 BT —Bad Track.
$\overline{0}$ No error.
1 Contents of T on the disk is different from that stored in the IDR and T = FF. Bit is related to ND (Bit 2) of Status Register 1.

ST2
MD -Missing Address Mark in Data Field. No error. DDFDC cannot find a Data Address Mark or Deleted Data Address Mark during a data read from the disk.

## Status Register 3 (ST3)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| FLT | WP | RDY | TRKO | TS | HD | US 1 | USO |

Status Register 3 (ST3) holds the results of the Sense Drive Status command.

```
ST3
    FLT -Fault.
    Fault (FLT) signal from the FDD is low.
    Fault (FLT) signal from the FDD is high.
ST3
    WP -Write Protect.
        Write Protect (WP) signal from the FDD is low.
        Write Protect (WP) signal from the FDD is high.
ST3
    RDY -Ready.
        Ready (RDY) signal from the FDD is low.
        Ready (RDY) signal from the FDD is high.
ST3
    TRKO -Track 0.
        Track 0 (TRKO) signal from the FDD is low.
        Track 0 (TRKO) signal is from the FDD is high.
ST3
    TS -Two Side.
    Two Side (TS) signal from the FDD is low.
    Two Side (TS) signal from the FDD is high.
ST3
    HD -Head Select.
        Head Select (HD) signal to the FDD is low.
        Head Select (HD) signal to the FDD is high.
ST3
    US1 -Unit Select 1.
        Unit Select 1 (US1) signal to the FDD is low.
        Unit Select 1 (US1) signal to the FDD is high.
ST3
    USO -Unit Select 0.
        Unit Select 0 (USO) signal to the FDD is low.
        Unit Select 0 (US1) signal to the FDD is high.
```


## COMMAND SEQUENCE

The DDFDC is capable of performing 15 different commands. Each command is initiated by a multi-byte transfer of data from the system. After command execution, the result of the command may be a multi-byte transfer of data back to the system. Because of this multi-byte transfer of information between the DDFDC and the system, each command consists of three phases:

Command Phase-The DDFDC receives all information required to perform a particular operation from the system.

Execution Phase-The DDFDC performs the instructed operation.

Result Phase-After completion of the operation, status and other housekeeping information are made available to the system.

The bytes of data sent to the DDFDC to form a command, and read out of the DDFDC in the result phase, must occur in the order shown for each command sequence. That is, the command code byte must be sent first followed by the other bytes in the specified sequence. All command bytes must be written and all result bytes must be read in each phase. After the last byte of data in the command phase is received by the DDFDC, the execution phase starts. Similarly, when the last byte of data is read out in the result phase, the command is ended and the DDFDC is ready to accept a new command. A command can be terminated by asserting the Terminal Count (TC) signal to the DDFDC. This ensures that the processor can always get the DDFDC's attention even if the command in process hangs up in an abnormal manner.

## COMMAND DESCRIPTION

## READ DATA

A command set of nine bytes places the DDFDC into the Read Data mode. After the Read Data command has been received the DDFDC loads the head (if it is unloaded), waits the specified Head Settling Time (defined in the Specify command), then begins reading ID Address Marks and ID fields from the disk. When the current sector number (R) stored in the ID Register (IDR) matches the sector number read from the disk, the DDFDC transfers data from the disk Data field to the data bus.

After completion of the read operation from the current sector, the DDFDC increments the Sector Number (R) by one, and the data from the next sector is read and output to the data bus. This continuous read function is called a "Multi-Sector Read Operation." The Read Command terminates after reading the last data byte from sector R when $\mathrm{R}=$ EOT. STO bits 7 and 6 are set to 0 and 1, respectively, and ST1 bit 7 (EN) is set to a 1.

The Read Data command can also be terminated by a high Terminal Count (TC) signal. TC should be issued at the same time that the $\overline{\text { DACK }}$ for the last byte of data is sent. Upon receipt of TC, the DDFDC stops outputting data to the data bus, but continues to read data from the current sector, checks CRC (Cyclic Redundancy Count) bytes, and then at the end of that sector terminates the Read Data command and sets bits 7 and 6 in STO
to 0 . The amount of data which can be handled with a single command to the DDFDC depends upon MT (Multi-Track), MF (MFM/FM), and N (Number of Bytes/Sector) values. Table 3 shows the transfer capacity.

The multi-track function (MT) allows the DDFDC to read data from both sides of the disk. For a particular track, data is transferred starting at sector 1 , side 0 and completed at sector $L$, side 1 (sector $L=$ last sector on the side). This function pertains to only one track (the same track) on each side of the disk.

When $N=0$ in command byte 6 ( $F M$ mode), the Data Length (DTL) in command byte 9 defines the data length that the DDFDC must treat as a sector. If DTL is smaller than the actual data length in a sector, the data beyond the DTL is not sent to the data bus. The DDFDC reads (internally) the complete sector, performs the CRC check, and depending upon the manner of command termination, may perform a multi-sector Read operation. When N is non-zero (MFM mode), DTL has no meaning and should be set to FF.

At the completion of the Read Data command, the head is not unloaded until the Head Unload Time (HUT) interval defined in the Specify command has elapsed. The head settling time may be avoided between subsequent reads if the processor issues another command before the head unloads. This time savings is considerable when disk contents are copied from one drive to another.

If the DDFDC detects the Index Hole twice in succession without finding the right sector (indicated in R), then the DDFDC sets the No Data (ND) flag in Status Register 1 (ST1) to a 1, sets Status Register 0 (STO) bits 7 and 6 to 0 and 1, respectively, and terminates the Read Data command.

After reading the ID and Data fields in each sector, the DDFDC checks the CRC bytes. If a read error is detected (incorrect CRC in ID field), the DDFDC sets the Data Error (DE) flag in ST1 to a 1, sets the Data Error in Data Field (DD) flag in ST2 to a 1 if a CRC error occurs in the Data field, sets bits 7 and 6 in STO to 0 and 1 , respectively, and terminates the command.

If the DDFDC reads a Deleted Data Address Mark from the disk, and the Skip Deleted Data Address Mark bit in the first command byte is not set $(S K=0)$, then the DDFDC reads all the data in the sector, sets the Control Mark (CM) flag in ST2 to a 1, and terminates the command. If $\mathrm{SK}=1$, the DDFDC skips the sector with the Deleted Data Address Mark and reads the next sector. The CRC bits in the deleted data field are not checked when $\mathrm{SK}=1$.

During disk data transfers from the DDFDC to the system, the DDFDC must be serviced by the system within $27 \mu \mathrm{~s}$ in the FM mode, and within $13 \mu \mathrm{~s}$ in the MFM mode, otherwise the DDFDC sets the Over Run (OR) flag in ST1 to a 1, sets bits 7 and 6 in STO to 0 and 1 , respectively, and terminates the command.

If the processor terminates a read (or write) operation in the DDFDC, then the ID information in the result phase is dependent upon the state of the MT bit in the first command byte and the End of Track (EOT) byte. Table 4 shows the values for Track Number (T), Head Number (H), Sector Number (R), and Number of Data Bytes/Sector ( N ), when the processor terminates the command.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 0 | 0 | 1 | 1 | 0 |
|  | 2 | X | X | X | x | X | HD | US1 | uso |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

Table 3. DDFDC Transfer Capacity

| Multi-Track <br> (MT) | MFM/FM <br> (MF) | Bytes/Sector <br> (N) | Maximum Transfor Capacity <br> (Bytes/Sector) (Number of Sectors) | Final Sector Read <br> trom Disk |
| :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 00 | $(128)(26)=3,328$ | 26 at Side 0 <br> or 26 at Side 1 |
| 0 | 1 | 01 | $(256)(26)=6,656$ | 26 at Side 1 |
| 1 | 0 | 00 | $(128)(52)=6,656$ | $(256)(52)=13,312$ |

Table 4. DDFDC Command Termination Values

| Command Phase ID |  | Final Sector Transferred to/from Data Bus | Result Phase ID |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Multi- <br> Track <br> (MT) | Head Number (HD) |  | Track Number (T) | Head Number (H) | Sector Number (R) | No. of Data Bytes (N) |
| 0 | 0 | Less than EOT | NC | NC | $R+1$ | NC |
|  | 0 | Equal to EOT | $T+1$ | NC | 01 | NC |
|  | 1 | Less than EOT | NC | NC | $\mathrm{R}+1$ | NC |
|  | 1 | Equal to EOT | $T+1$ | NC | 01 | NC |
| 1 | 0 | Less than EOT | NC | NC | $R+1$ | NC |
|  | 0 | Equal to EOT | NC | LSB | 01 | NC |
|  | 1. | Less than EOT | NC | NC | - $R+1$ | NC |
|  | 1 | Equal to EOT | $\therefore T+1$ | LSB | 01 | NC |
| Notes: <br> 1. NC (No Change): The same value as the one at the beginning of command execution. <br> 2. LSB (Least Significant Bit): The least significant bit of H is complemented. |  |  |  |  |  |  |

## Result Phase:

| $R$ | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
|  | 4 | Track Number (T) |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## WRITE DATA

A command set of nine bytes places the DDFDC in the Write Data mode. After the Write Data command has been received the DDFDC loads the head (if it is unloaded), waits the specified Head Settling Time (defined in the Specify command), then begins reading ID fields from the disk. When the four bytes (T, H, R, N) loaded during the command match the four bytes of the ID field from the disk, the DDFDC transfers data from the data bus to the disk Data field.

After writing data into the current sector, the DDFDC increments the sector number (R) by one, and writes into the Data field in the next sector. The DDFDC continues this multi-sector write operation until the last byte is written to sector $R$ when $R=E O T$. STO bits 7 and 6 are set to 0 and 1, respectively, and ST1 bit $7(\mathrm{EN})$ is set to a 1.

The command can also be terminated by a high on Terminal Count (TC). If TC is sent to the DDFDC while writing into the current sector, then the remainder of the Data field is filled with 00 (zeros). In this case, STO bits 7 and 6 are set to 0 and the command is terminated.

The DDFDC reads the ID field of each sector and checks the CRC bytes. If the DDFDC detects a read error (incorrect CRC)
in one of the ID fields, it terminates the Write Data command, sets the DE flag in ST1 to a 1 , and sets bits 7 and 6 in STO to 0 and 1, respectively.

The Write Data command operates in much the same manner as the Read Data command. Refer to the Read Data command for the handling of the following items:

- Transfer Capacity
- End of Track (EN) flag
- No Data (ND) flag
- Head Unload Time (HUT) interval
- ID information when the processor terminates command (see Table 4)
- Definition of Data Length (DTL) when $N=0$ and when $N \neq 0$

In the Write Data mode, data transfers from the data bus to the DDFDC must occur within $27 \mu \mathrm{~s}$ in the FM mode, and within $13 \mu \mathrm{~s}$ in the MFM mode. If the time interval between data transfers is longer than this, then the DDFDC terminates the Write Data command, sets the Over Run (OR) flag in ST1 to a 1, and sets bits 7 and 6 in STO to 0 and 1, respectively.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | 0 | 0 | 0 | 1 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| $R$ | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
|  | 7 | Number of Data Bytes per Sector (N) |

## WRITE DELETED DATA

The Write Deleted Data command is the same as the Write Data command except a Deleted Data Address Mark is written at the beginning of the Data field instead of the normal Data Address Mark.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | 0 | 0 | 1 | 0 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
| 2 | Status Register 1 (ST1) |  |
| 3 | Status Register 2 (ST2) |  |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
|  | 7 | Number of Data Bytes per Sector(N) |

## READ DELETED DATA

The Read Deleted Data command is the same as the Read Data command except that if SK = 0 when the DDFDC detects a Data Address Mark at the beginning of a Data field, it reads all the data in the sector and sets the CM flag in ST2 to a 1, and then terminates the command. If SK = 1, then the DDFDC skips the sector with the Data Address Mark and reads the next sector.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 0 | 1 | 1 | 0 | 0 |
|  | 2 | x | X | X | X | X | HD | US1 | Uso |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| $R$ | 1 | Status Régister 0 (ST0) |
| :--- | :--- | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## READ A TRACK

The Read a Track command is similar to the Read Data command except that this is a continuous read operation where all Data fields from each of the sectors on a track are read and transferred to the data bus. Immediately after encountering the Index Hole, the DDFDC starts reading the Data fields as continuous blocks of data. This command terminates when the number of sectors read is equal to EOT. Multi-track operations are not allowed with this command.

If the DDFDC finds an error in the ID or Data CRC check bytes, it continues to read data from the track. The DDFDC compares the ID information read from each sector with the value stored in the IDR, and sets the ND flag in ST1 to a 1 if there is no match.

If the DDFDC does not find an ID Address Mark on the disk after it encounters the Index Hole for the second time it terminates the command, sets the Missing Address Mark (MA) flag in ST1 to a 1 , and sets bits 7 and 6 of STO to 0 and 1, respectively.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | MF | SK | 0 | 0 | 0 | 1 | 0 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Data Length (DTL) |  |  |  |  |  |  |  |

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :---: |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
|  | 4 | Track Number (T) |
|  | 5 | Head Number (H) |
|  | 6 | Sector Number (R) |
|  | 7 | Number of Data Bytes per Sector (N) |

## READ ID

The two-byte Read ID command returns the present position of the read/write head. The DDFDC obtains the value from the first ID field it is able to read, sets bits 7 and 6 in STO to 0 and terminates the command.

If no proper ID Address Mark is found on the disk before the Index Hole is encountered for the second time then the Missing Address Mark (MA) flag in ST1 is set to a 1, and if no data is found then the ND flag in ST1 is also set to a 1. Bits 7 and 6 in ST0 are set to 0 and 1 , respectively and the command is terminated.

During this command there is no data transfer between DDFDC and the data bus except during the result phase.

## Command Phase:

| R/W | BYTE | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{W}$ | $\mathbf{W}$ | 0 | MF | 0 | 0 | 1 | 0 | 1 | 0 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |

## Result Phase:

| $R$ | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
|  | 6 | Sector Number (R) |
|  | 7 | Number of Data Bytes per Sector (N) |

## FORMAT A TRACK

The six-byte Format a Track command formats an entire track. After the Index Hole is detected, data is written on the disk: Gaps, Address Marks, ID fields and Data fields; all are recorded in either the double-density IBM System 34 format (MF = 1) or the singledensity IBM 3740 format ( $M F=0$ ). The particular format written is also controlled by the values of Number of Bytes/Sector ( N ), Sectors/Track (ST), Gap Length (GPL) and Data Pattern (D) which are supplied by the processor during the command phase. The Data field is filled with the data pattern stored in D.

The ID field for each sector is supplied by the processor in response to four data requests per sector issued by the DDFDC. The type of data request depends upon the Non-DMA flag (ND) in the Specify command. In the DMA mode ( $\mathrm{ND}=0$ ), the DDFDC asserts the DMA Request (DRQ) output four times per sector. In the Non-DMA mode ( $\mathrm{ND}=1$ ), the DDFDC asserts Interrupt Request (INT) output four times per sector.

The processor must write one data byte in response to each request, sending (in the consecutive order) the Track Number (T), Head Number (H), Sector Number (R) and Number of Bytes/ Sector ( $N$ ). This allows the disk to be formatted with nonsequential sector numbers, if desired.

The processor must send new values for $T, H, R$, and $N$ to the DDFDC for each sector on the track. For sequential formatting $R$ is incremented by one after each sector is formatted, thus, R contains the total numbers of sectors formatted when it is read during the result phase. This incrementing and formatting continues for the whole track until the DDFDC, upon encountering the Index Hole for the second time, terminates the command and sets bits 7 and 6 in STO to 0 .

If the Fault (FLT) signal is high from the FDD at the end of a write operation, the DDFDC sets the Equipment Check (EC) flag in STO to a 1 , sets bits 7 and 6 of STO to 0 and 1, respectively, and terminates the command. Also, a low (RDY) signal at the beginning of a command execution phase causes bits 7 and 6 of STO to be set to 0 and 1 , respectively.

Table 5 shows the relationship between N, ST, and GPL for various disk and sector sizes.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | MF | 0 | 0 | 1 | 1 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Number of Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 4 | Sectors per Track (ST) |  |  |  |  |  |  |  |
|  | 5 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 6 | Data Pattern (D) |  |  |  |  |  |  |  |

Table 5. Standard Fioppy Disk Sector Size Relationship

| Disk Size | Mode | Sector Size Bytes/Sector | No. of Data Bytes/Sector ( N ) | No. of Sectors/Tracks (ST) | Gap Length (GPL) ${ }^{4}$ |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Read/Write Command ${ }^{1}$ | Format Command ${ }^{2}$ |  |
| 8" | FM | 128 | 00 | 1A | 07 | 1B | IBM Disk 1 IBM Disk 2 |
|  |  | 256 | 01 | OF | OE | 2A |  |
|  |  | 512 | 02 | 08 | 18 | 3A |  |
|  |  | 1024 | 03 | 04 | 47 | 8A |  |
|  |  | 2048 | 04 | 02 | C8 | FF. |  |
|  |  | 4096 | 05 | 01 | C8 | FF |  |
|  | MFM ${ }^{3}$ | 256 | 01 | 1A | OE | 36 | IBM Disk 2D IBM Disk 2D |
|  |  | 512 | 02 | OF | 18 | 54 |  |
|  |  | 1024 | 03 | 08 | 35 | 74 |  |
|  |  | 2048 | 04 | 04 | 99 | FF |  |
|  |  | 4096 | 05 | 02 | C8 | FF |  |
|  |  | 8192 | 06 | 01 | C8 | FF |  |
| 51/4" | FM | 128 | 00 | 12 | 07 | 09 |  |
|  |  | 128 | 00 | 10 | 10 | 19 | - |
|  |  | 256 | 01 | 08 | 18 | 30 |  |
|  |  | 512 | 02 | 04 | 46 | 87 |  |
|  |  | 1024 | 03 | 02 | C8 | FF |  |
|  |  | 2048 | 04 | 01 | C8 | FF |  |
|  | MFM ${ }^{3}$ | 256 | 01 | 12 | OA | OC |  |
|  |  | 256 | 01 | 10 | 20 | 32 |  |
|  |  | 512 | 02 | 08 | 2A | 50 |  |
|  |  | 1024 | 03 | 04 | 80 | F0 |  |
|  |  | 2048 | 04 | 02 | C8 | FF |  |
|  |  | 4096 | 05 | 01 | C8 | FF |  |

Notes:

1. Suggested values of GPL in Read or Write commands to avoid overlapping between Data field and ID field of contiguous sections.
2. Suggested values of GPL in Format a Track command.
3. In MFM mode the DDFDC cannot perform a read/write/format operation with 128 bytes/sector ( $\mathrm{N}=00$ ).
4. Values of ST and GPL are in hexadecimal.

Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :---: |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
|  | 4 | Track Number (T)* |
|  | 5 | Head Number (H)* |
|  | 6 | Sector Number (R)* |
|  | 7 | Number of Data Bytes per Sector (N)* |
| e | a | has no meaning in this command. |

## SCAN COMMANDS

The scan commands compare data read from the disk to data supplied from the data bus. The DDFDC compares the data, and looks for a sector of data which meets the conditions of $D_{F D D}=$ $D_{\text {BUS }}, D_{F D D} \leq D_{B U S}$, or $D_{F D D} \geq D_{\text {BUS }}(D=$ the data pattern in hexadecimal). A magnitude comparison is performed ( $\mathrm{FF}=$ largest number, $00=$ smallest number). The hexadecimal byte of FF either from the bus or from FDD can be used as a mask byte because it always meets the condition of the compare. After a whole sector of data is compared, if the conditions are not met,
the sector number is incremented $(R+S T P \rightarrow R)$, and the scan operation is continued. The scan operation continues until one of the following events occur: the conditions for scan are met (equal, low or equal, or high or equal), the last sector on the track is reached (EOT), or TC is received.

If conditions for scan are met, the DDFDC sets the Scan Hit (SH) flag in ST2 to a 1, and terminates the command. If the conditions for scan are not met between the starting sector (as specified by R) and the last sector on the track (EOT), then the DDFDC sets the Scan Not Satisfied (SN) flag in ST2 to a 1, and terminates the command. The receipt of TC from the processor or DMA controller during the scan operation will cause the DDFDC to complete the comparison of the particular byte which is in process, and then to terminate the command. Table 6 shows the status of bits SH and SN under various conditions of scan.

If SK $=\mathbf{0}$ and the DDFDC encounters a Deleted Data Address Mark on one of the sectors, it regards that sector as the last sector of the track, sets the Control Mark (CM) bit in ST2 to a 1 and terminates the command. If SK $=1$, the DDFDC skips the sector with the Deleted Data Address Mark, sets the CM flag to a 1 in order to show that a Deleted Sector has been encountered, and reads the next sector.

Table 6. Scan Status Codes

| Command | Status Register 2 |  | Comments |
| :---: | :---: | :---: | :---: |
|  | Bit $2=S N$ | Bit $3=\mathbf{S H}$ |  |
| Scan Equal | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | $\begin{aligned} D_{\text {FDD }} & =D_{\text {BUS }} \\ D_{\text {FDD }} & \neq D_{\text {BuS }} \end{aligned}$ |
| Scan Low or Equal | $\begin{aligned} & 0 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & D_{\text {FDD }}=D_{\text {Bus }} \\ & D_{\text {FDD }}<D_{\text {BUS }} \\ & D_{\text {FDD }}>D_{\text {BUS }} \end{aligned}$ |
| Scan High or Equal | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \mathrm{D}_{\text {FDD }}=\mathrm{D}_{\text {Bus }} \\ & \mathrm{D}_{\text {FDD }}>\mathrm{D}_{\text {Bus }} \\ & \mathrm{D}_{\mathrm{FDD}}<\mathrm{D}_{\text {BUS }} \end{aligned}$ |

When either the STP sectors are read (contiguous sectors $=01$, or alternate sectors $=02$ ) or MT (Multi-Track) is set, the last sector on the track must be read. For example, if STP $=02$, MT $=0$, the sectors are numbered sequentially 1 through 26 , and the scan command starts reading at sector 21 . Sectors 21, 23, and 25 are read, then the next sector (26) is skipped and the Index Hole is encountered before the EOT value of 26 can be read. This results in an abnormal termination of the command. If the EOT had been set at 25 or the scanning started at sector 20, then the scan command would be completed in a normal manner.

During a scan command data is supplied from the data bus for comparison against the data read from the disk. In order to avoid having the Over Run (OR) flag set in ST1, data must be available from the data bus in less than $27 \mu \mathrm{~S}$ (FM mode) or $13 \mu \mathrm{~S}$ (MFM mode). If an OR occurs, the DDFDC terminates the command and sets bits 7 and 6 of STO to 0 and 1, respectively.

The following tables specify the command bytes and describe the result bytes for the three scan commands.

## SCAN EQUAL

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 1 | 0 | 0 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector ( N ) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Sector Test Process (STP) |  |  |  |  |  |  |  |

Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
| 3 | Status Register 2 (ST2) |  |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
| 7 | Number of Data Bytes per Sector (N) |  |

## SCAN LOW OR EQUAL

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | MT | MF | SK | 1 | 1 | 0 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | US0 |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Sector Test Process (STP) |  |  |  |  |  |  |  |

Result Phase:

| $R$ | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
| 6 | Sector Number (R) |  |
|  | 7 | Number of Data Bytes per Sector (N) |

## SCAN HIGH OR EQUAL

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 : | MT | MF | SK | 1 | 1 | 1 | 0 | 1 |
|  | 2 | X | X | X | X | X | HD | US1 | USO |
|  | 3 | Track Number (T) |  |  |  |  |  |  |  |
|  | 4 | Head Number (H) |  |  |  |  |  |  |  |
|  | 5 | Sector Number (R) |  |  |  |  |  |  |  |
|  | 6 | Number of Data Bytes per Sector (N) |  |  |  |  |  |  |  |
|  | 7 | End of Track (EOT) |  |  |  |  |  |  |  |
|  | 8 | Gap Length (GPL) |  |  |  |  |  |  |  |
|  | 9 | Sector Test Process (STP) |  |  |  |  |  |  |  |

Result Phase:

| R | 1 | Status Register 0 (STO) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 5 | Head Number (H) |  |
|  | 6 | Sector Number (R) |
|  | 7 | Number of Data Bytes per Sector (N) |

## SEEK

The three-byte Seek command steps the FDD read/write head from track to track. The DDFDC has two independent Present Track Registers for each drive. They are cleared only by the Recalibrate command. The DDFDC compares the Present Track Number (PTN) which is the current head position with the New Track Number (NTN), and if there is a difference, performs the following operation:

If PTN < NTN: Sets the direction output (LCT/DIR) high and issues step pulses (FR/STP) to the FDD to cause the read/write head to step in.
If PTN > NTN: Sets the direction output (LCT/DIR) low and issues step pulses to the FDD to cause the read/write head to step out.

The rate at which step pulses are issued is controlled by the Step Rate Time (SRT) in the Specify command. After each step pulse is issued, NTN is compared against PTN. When NTN = PTN, then the Seek End (SE) flag in STO is set to a 1, bits 7 and 6 in STO are set to 0 , and the command is terminated. At this point DDFDC asserts INT.

The FDD Busy flag (bit 0-3) in the Main Status Register (MSR) corresponding to the FDD performing the Seek operation is set to a 1.

After command termination, all FDD Busy bits set are cleared by the Sense Interrupt Status command.

During the command phase of the Seek operation the DDFDC sets the Controller Busy (CB) flag in the MSR to 1; but during the execution phase the CB flag is set to 0 to indicate DDFDC non-busy. While the DDFDC is in the non-busy state, another Seek command may be issued, and in this manner parallel seek operations may be performed on all drives at once.

No command other than Seek will be accepted while the DDFDC is sending step pulses to any FDD. If a different command type is attempted, the DDFDC will set bits 7 and 6 in STO to a 1 and 0 , respectively, to indicate an invalid command.

If the FDD is in a not ready state at the beginning of the command execution phase or during the seek operation, then the DDFDC sets the Not Ready (NR) flag in STO to a 1, sets STO bits 7 and 6 to 0 and 1 , respectively, and terminates the command.

If the time to write the three bytes of the Seek command exceeds $150 \mu \mathrm{~s}$, the time between the first two step pulses may be shorter than the Step Rate Time (SRT) defined by the Specify command by as much as 1 ms .

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 |
|  | 2 | X | X | X | X | X | 0 | US1 | Uso |
|  | 3 | New Track Number (NTN) |  |  |  |  |  |  |  |

Result Phase: None.

## RECALIBRATE

This two-byte command retracts the FDD read/write head to the Track 0 position. The DDFDC clears the contents of the PTN counters, and checks the status of the Track 0 signal from the FDD. As long as the Track 0 signal (TRKO) is low, the direction signal (LCT/DIR) output remains low and step pulses are issued on FRISTP. When TRKO goes high the DDFDC sets the Seek End (SE) flag in STO to a 1 and terminates the command. If the TRKO is still low after 256 step pulses have been issued, the DDFDC sets Seek End (SE) and Equipment Check (EC) flags in STO to 1s, sets bits 7 and 6 of STO to 0 and 1, respectively, and terminates the command.

The ability to do overlap Recalibrate commands to multiple FDDs and the loss of the RDY signal, as described in the Seek command, also applies to the Recalibrate command.

## Command Phase:

| RW | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $W$ | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
|  | 2 | $X$ | $X$ | $X$ | $X$ | $X$ | 0 | US1 | USO |

Result Phase: None.

## SENSE INTERRUPT STATUS

Interrupt Request (INT) is asserted by the DDFDC when any of the following conditions occur:

1. Upon entering the result phase of:
a. Read Data command
b. Read a Track command
c. Read ID command
d. Read Deleted Data command
e. Write Data command
f. Format a Track command
g. Write Deleted Data command
h. Scan commands
2. Ready (RDY) line from the FDD changes state
3. Seek or Recalibrate command termination
4. During execution phase in the Non-DMA mode

INT caused by reasons 1 and 4 above occur during normal command operations and are easily discernible by the processor. During an execution phase in Non-DMA mode, bit 5 in the MSR is set to 1 . Upon entering result phase this bit is set to 0 . Reasons 1 and 4 do not require the Sense Interrupt Status command. The interrupt is cleared by reading or writing data to DDFDC. Interrupts caused by reasons 2 and 3 are identified with the aid of the Sense Interrupt Status command. This command resets INT and sets/resets bits 5,6 , and 7 of STO to identify the cause of the interrupt. Table 7 defines the seek and interrupt codes.

Neither the Seek or Recalibrate command has a result phase. Therefore, it is mandatory to use the Sense Interrupt Status command after these commands to effectively terminate them and to verify where the head is positioned by checking the Present Track Number (PTN).

Issuing a Sense Interrupt Status command without an interrupt pending is treated as an invalid command.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $W$ | 1 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |

## SPECIFY

The three-byte Specify command sets the initial values for each of the three internal timers. The Head Unload Time (HUT) defines the time from the end of the execution phase of one of the read/write commands to the head unload state. This timer is programmable from 16 to 240 ms in increments of 16 ms ( $1=16 \mathrm{~ms}, 2=32 \mathrm{~ms}, \ldots . \mathrm{F}=240 \mathrm{~ms}$ ).

The Step Rate Time (SRT) defines the time interval between adjacent step pulses. This timer is programmable from 1 to 16 ms in increments of $1 \mathrm{~ms}(F=1 \mathrm{~ms}, E=2 \mathrm{~ms}$, $\mathrm{D}=3 \mathrm{~ms}, . \quad 0=16 \mathrm{~ms}$.)

The Head Load Time (HLT) defines the time between the Head Load (HDL) signal going high and the start of the read/write operation. This timer is programmable from 2 to 254 ms in increments of $2 \mathrm{~ms}(01=2 \mathrm{~ms}, 02=4 \mathrm{~ms}, 03=6 \mathrm{~ms}, \ldots$ $7 \mathrm{~F}=254 \mathrm{~ms})$.

The time intervals are a direct function of the clock (CLK on pin 19). Times indicated above are for an 8 MHz clock. If the clock is reduced to 4 MHz (mini-floppy application) then all time intervals are increased by a factor of two.

The choice of DMA or Non-DMA operation is made by the NonDMA mode (ND) bit. When this bit $=1$ the Non-DMA mode is selected, and when ND $=0$ the DMA mode is selected.

Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| W | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |
|  | 2 | SRT |  |  |  | HUT |  |  |  |
|  | 3 | HLT |  |  |  | ND |  |  |  |

SRT - Step Rate Time
HUT - Head Unload Time
HLT - Head Load Time
ND - Non-DMA mode
Result Phase: None.

## Result Phase:

| R | 1 | Status Register 0 (STO) |
| :--- | :--- | :--- |
|  | 2 | Present Track Number (PTN) |

Table 7. STO Seek and Interrupt Code Definition for Sense Interrupt Status

| Status Register 0 (ST0) Bits |  |  | Cause |
| :---: | :---: | :---: | :---: |
| Interrupt Code (IC) |  | Seek End (SE) |  |
| 7 | 6 | 5 |  |
| 1 | 1 | 0 | RDY line changed state, either polarity |
| 0 | 0 | 1 | Normal termination of Seek or Recalibrate command |
| 0 | 1 | 1 | Abnormal termination of Seek or Recalibrate command |

## SENSE DRIVE STATUS

This two-byte command obtains and reports the status of the FDDs. Status Register 3 (ST3) is returned in the result phase and contains the drive status.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $W$ | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 |
|  | 2 | $X$ | $X$ | $X$ | $X$ | $X$ | HD | US1 | USO |

## Result Phase:

| $R$ | 1 | Status Register 3 (ST3) |
| :--- | :--- | :--- |

## INVALID COMMAND

If an invalid command (i.e., a command not previously defined) is received by the DDFDC, then the DDFDC terminates the command after setting bits 7 and 6 of STO to 1 and 0 , respectively. The DDFDC does not generate an interrupt during this condition. Bits 6 and 7 (DIO and RQM) in the MSR are both set to a 1 indicating to the processor that the DDFDC is in the result phase and that STO must be read. A hex 80 in STO indicates that an invalid command was received.

A Sense Interrupt Status command must be sent after a Seek or Recalibrate interrupt, otherwise the DDFDC considers the next command to be an invalid command.

In some applications the user may wish to use this command as a No-Op command, to place the DDFDC in a standby or no operation state.

## Command Phase:

| R/W | BYTE | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $W$ | 1 | Invalid Codes |  |  |  |  |  |  |  |

## Result Phase:

| $R$ | 1 | Status Register $0(S T O)=80$ |
| :--- | :--- | :--- |

## PROCESSOR INTERFACE

During the command or result phases, the Main Status Register (MSR) must be read by the processor before each byte of information is transferred to, or from, the DDFDC Data Register. After each byte of data is written to, or read from, the Data Register, the processor should wait $12 \mu s$ before reading the MSR. Bits 6 and 7 in the MSR must be a 0 and 1, respectively, before each command byte can be written to the DDFDC. During the result phase, bits 6 and 7 of the MSR must both be 1s prior to reading each byte from the Data Register onto the data bus. Note that this status reading of bits 6 and 7 of the MSR before each byte transfer to and from the DDFDC is required in only the command and result phases and not during the execution phase.

During the result phase all bytes shown in the result phase must be read by the processor. The Read Data command, for example, has seven bytes of data in the result phase. All seven bytes must be read to successfully complete the Read Data command. The DDFDC will not accept a new command until all seven bytes have been read. Other commands may require fewer bytes to be read during the result phase.

## INTERRUPT REQUEST MODE

During the execution phase, the MSR need not be read. The receipt of each data byte from the FDD is indicated by INT high on pin 18. When the DDFDC is in Non-DMA mode, INT is asserted during the execution phase. When the DDFDC is in the DMA mode, INT is asserted at the result phase. The INT signal is reset by a read ( $\overline{R D}$ low) or write (WR low) of data to the DDFDC. A further explanation of the INT signal is described in the Sense Interrupt Status command on page 16. If the system cannot handle interrupts fast enough (within $13 \mu$ s for MFM mode or $27 \mu \mathrm{~s}$ for FM mode), it should poll bit 7 (RQM) in the MSR. In this case, RQM in the MSR functions as an Interrupt Request (INT). If the RQM bit is not set, the Over Run (OR) flag in ST1 will be set to a 1 and bits 7 and 6 of STO will be set to a 0 and 1 , respectively.

## DMA MODE

When the DDFDC is in the DMA mode (ND = 0 in the third command byte of the Specify command), DRQ (DMA Request) is asserted during the execution phase (rather than INT) to request the transfer of a data byte between the data bus and the DDFDC.

During a read command, the DDFDC asserts DRQ as each byte of data is available to be read. The DMA controller responds to this request with $\overline{\text { DACK }}$ low (DMA Acknowledge) and $\overline{\text { RD }}$ low (read). When DACK goes low the DMA Request is reset (DRQ low). After the execution phase has been completed (TC high or the EOT sector is read), INT is asserted to indicate the beginning of the result phase. When the first byte of data is read during the result phase, INT is reset low.

During a write command, the DDFDC asserts DRQ as each byte of data is required. The DMA controller responds to this request with DACK (DMA Acknowledge) and WR low (write). When DACK goes low the DMA Request is reset (DRQ low). After the execution phase has been completed (TC high or the EOT sector is written), INT is asserted. This signals the beginning of the result phase. When the first byte of data is read during the result phase, the INT is reset low.

## FDD POLLING

After the Specify command has been received by the DDFDC, the Unit Select lines (USO and US1) begin the polling mode. Between commands (and between step pulses in the Seek Command) the DDFDC polls all the FDD's looking for a change in the RDY line from any of the drives. If the RDY line changes state (usually due to the door opening or closing) then the DDFDC asserts INT. When Status Register 0 (STO) is read (after Sense Interrupt Status command is issued), Not Ready ( $\mathrm{NR}=1$ ) will be indicated. The polling of the RDY line by the DDFDC occurs continuously between commands, thus notifying the processor which drives are on- or off-line. Each drive is polled every 1.024 ms except during read/write commands.


Figure 3. DDFDC and System Data Transfer Timing


Figure 4. R6765 DDFDC Interface to Z-80


Figure 5. Clock Timing


Figure 6. Read Cycle Timing


Figure 7. Write Cycle Timing


Figure 8. DMA Operation Timing


Figure 9. FDD Write Operation Timing


NOTE:
EITHER POLARITY DATA WINDOW IS VALID

Figure 10. FDD Read Operation Timing


Figure 11. Seek Operation Timing


Figure 12. Fault Reset Timing


Figure 14. Terminal Count Timing


Figure 13. Index Timing


Figure 15. Reset Timing


INPUTS ARE DRIVEN AT 2.4V FOR A LOGIC " 1 " AND 0.45 V FOR A LOGIC " 0 :" TIMING MEASUREMENTS ARE MADE AT 2.0V FOR A LOGIC " 1 " AND $0.8 V$ FOR A LOGIC " 0 .'


CLOCKS ARE DRIVEN AT 3.OV FOR A LOGIC "1" AND O.3V FOR A LOGIC " 0 :" TIMING MEASUREMENTS ARE MADE AT 2.4V FOR A LOGIC " 1 " AND $0.65 V$ FOR A LOGIC " 0 ."

Figure 16. AC Timing Measurement Conditions

## AC CHARACTERISTICS

$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}$ )


## ABSOLUTE MAXIMUM RATINGS*

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

## OPERATING CONDITIONS

| Parameter | Range |
| :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ Power Supply | $5.0 \mathrm{~V} \pm 5 \%$ |
| Operating Temperature | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |

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

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input Low Voltage Logic CLK and WCK | $\mathrm{V}_{\text {IL }}$ | $\begin{aligned} & -0.5 \\ & -0.5 \end{aligned}$ | $\begin{gathered} 0.8 \\ 0.65 \end{gathered}$ | V |  |
| Input High Voltage Logic CLK and WCK | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{aligned} & 2.0 \\ & 2.4 \end{aligned}$ | $\begin{aligned} & v_{c c}+0.5 \\ & v_{c C}+0.5 \end{aligned}$ | v |  |
| Output Low Voltage | $\mathrm{V}_{\text {OL }}$ |  | 0.45 | V | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=2.0 \mathrm{~mA}$ |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | $\mathrm{V}_{\mathrm{cc}}$ | $\checkmark$ | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\text {cC }}$ Supply Current | $\mathrm{I}_{\mathrm{cc}}$ |  | 150 | mA | $\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ |
| Input Load Current | ILL |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}$ |
| All Inputs |  |  | -10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=0 \mathrm{~V}$ |
| High Level Output Leakage Current | $\mathrm{I}_{\mathrm{LOH}}$ |  | 10 | $\mu \mathrm{A}$. | $\begin{aligned} & \mathrm{V}_{\mathrm{cC}}=\mathrm{OV} \text { to } 5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OUT}}=\mathrm{V}_{\mathrm{CC}} \end{aligned}$ |
| Low Level Output Leakage Current | LoL |  | -10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=\mathrm{O} \text { to } 5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{SS}}=\mathrm{OV} \\ & \mathrm{~V}_{\mathrm{OUT}}=+0.45 \mathrm{~V} \end{aligned}$ |
| Internal Power Dissipation | $\mathrm{P}_{\text {INT }}$ | - | 1.0 | W | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |

## CAPACITANCE

$\left(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz} ; \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}\right.$ )

| Parameter | Symbol | Max Limit | Unit |
| :--- | :---: | :---: | :---: |
| Clock Input | $\mathrm{C}_{\text {IN }(0)}$ | 20 | pF |
| Input | $\mathrm{C}_{\text {IN }}$ | 10 | pF |
| Output | $\mathrm{C}_{\text {OUT }}$ | 20 | pF |
| Note: All pins |  |  |  |

[^7]
## PACKAGE DIMENSIONS



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

## 40-PIN PLASTIC DIP



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

## SECTION 3 R6500/* MICROCOMPUTERS

Page
Product Family Overview ..... 3-2
R65C00/21 and R65C29 Dual CMOS Microcomputer and Dual CMOS Microprocessor ..... 3-3
R65F11 and R65F12 FORTH One-Chip Microcomputers ..... 3-35
R65FRX and R65FKX RSC FORTH Development and Kernel ROMs ..... 3-67
R6501Q One-Chip Microprocessor ..... 3-75
R6500/1 One-Chip Microcomputer ..... 3-104
R6500/1E Emulator Device ..... 3-135
R6500/1EB and R6500/1EAB Backpack Emulator ..... 3-142
R6500/11 and R6500/12 One-Chip Microcomputers ..... 3-147
R65/11EB and R65/11EAB Backpack Emulator ..... 3-182
R6500/13 and R6511Q One-Chip Microcomputer and One-Chip Microprocessor ..... 3-187
R6500/41 and R6500/42 One-Chip Intelligent Peripheral Controllers ..... 3-222
R65/41EB and R65/41EAB Backpack Emulator ..... 3-251
R6500/43 and R6541Q One-Chip Intelligent Peripheral Controllers ..... 3-256

# R6500/* SINGLE-CHIP MICROCOMPUTER FAMILY Higher Performance, Broader Applications, Software Compatibility 

The R6500/* single-chip microcomputers are completely software compatible with the 8 -bit multi-chip family. They let you move easily from a multi-chip to a single-chip system solution when the application warrants it. They also function as intelligent peripheral controllers. The family continues to expand to include dual processors and CMOS versions. The R6500/* devices have faster execution speeds for most applications, based on our competitors own figures, even though some others use higher frequency crystals.

Features include 1.5 to 3 K bytes of ROM, 64 to 192 bytes of RAM, 23 to 56 I/O ports, multiple use counter/timers, serial communication channels, new bit manipulation instructions, expansion bus, multiple bus interfaces, directly executable RAM with low power standby, multiple interrupts, all from a single 5 V power supply.

Three intelligent peripheral controllers offer design effective upgrading potentials for existing 6800, 8080, Z80 and 6500 systems. They're also available in ROM-less
versions, for large memory system applications and for developing and simulating products in prototype, with external memory.
And, two versions even have all system software on chip, including an operating system and high level FORTH language. It's an extremely versatile single-chipper.
Three different sets of development ROM permit systems from 16 to $40 \mathrm{I} / \mathrm{O}$ and 8 K to 48 K of application program memory.
As the highest performance single-chip family, the R6500/* devices are in use now in applications such as printers, telephone answering equipment, fixed disk drives, stereos, industrial controllers, telecom, cash registers, sewing machines, test equipment and more.
Check for yourself and see how a Rockwell R6500/* can solve your system problem. There are no higher performing 8 -bit single chippers, regardless of clock speeds.

ROCKWELL NMOS MICROCOMPUTERS-THE TOP PERFORMERS IN INDUSTRY

| Features/Models | R6500/1 | R6500/11 | R6500/12 | R6501Q/11Q | R6500/41 | R6500/42 | R6541Q |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - ROM (x8) | 2048 | 3072 | 3072 | - | 1536 | 1536 | 256 |
| - RAM (x8). | 64 | 192 | 192 | 192 | 64 | 64 | 64 |
| - I/O Lines | 32 | 32 | 56 | 32 | 23 | 47 | 23 |
| - Serial Comm. | - | USART | USART | USART | - | - | - |
| - 16-Bit Counters | ONE | TWO | TWO | TWO | ONE | ONE | ONE |
| - Host/Slave Bus | - | - | - | - | 80/65 | 80/65 | 80/65 |
| - Expansion Bus | - | 16K | 16K | 65K | 4K | 4K | $8 \mathrm{~K} / 4 \mathrm{~K}$ |
| - Interrupts - External | 4 | 6 | 6 | 6 | 4 | 4 | 5 |
| - Internal | 1 | 4 | 4 | 4 | 1 | 1 | 1 |
| - Host | - | - | - | - | 2 | 2 | 2 |
| - Standby RAM (mW) | 35 | 12 | 12 | 12 | - | - | - |
| - Package | 40 DIP | 40 DIP | 64 QUIP | 64 QUIP | 40 DIP | 64 QUIP | 64 QUIP |
| Alternatives for | 8048/49 | 8051 |  | 8031 |  | 8041 |  |

## R65C00/21 DUAL CMOS MICROCOMPUTER AND R65C29 DUAL CMOS MICROPROCESSOR

## PRELIMINARY <br> INTRODUCTION

## FEATURES

- Two enhanced CMOS R6502 CPU's in one device
-Common memory and I/O
-Shared data and subroutines
-Independent CPU registers and interrupt vectors
-Independent reset operation and programs
-R6502 software and timing compatible
- 10 new instructions for faster and smaller programs
-Unsigned Multiply (MUL)
-Set and Reset Memory Bit (SMB and RMB)
-Branch on Bit Set and Reset (BBS and BBR)
-Unconditional Branch (BRA)
-Push and Pull Index Registers (PHX, PHY; PLX, PLY)
- Microcomputer/microprocessor/peripheral controller operation
-Stand-alone microcomputer $2048 \times 8$ mask programmable ROM $128 \times 8$ random access memory (RAM)
-Enhanced microprocessor Built-in RAM, ROM and I/O with expandability 8-, 12- or 16-bit extension address bus
-Programmable peripheral controller Host data bus interface (Z80/8080 or 6500/6800 option) Self-contained or expandable
- 16-bit Counter/Timer A with eight modes, and prescaler
-Timer Off
-Free-Run Event Counter
-Free-Run Pulse Width Measurement
-One-Shot Retriggerable Timer
-One-Shot Interval Timer
—Free-Run Interval Timer
-One-Shot Pulse Generator
-Free-Run Pulse Generator
- 16-bit Counter/Timer B with four modes
-Free-Run Interval Timer
-Free-Run Pulse Generator
-Event Counter
-Pulse Width Measurement
- Up to 52 general purpose input/output lines
-Five bidirectional 8-bit ports (PA, PB, PC, PD and PF)
-One 8-bit output port (PE)
-One 4-bit input port (PG)
-Multi-purpose operation for selected ports
- Nine interrupts
- Positive and negative edge detect
-Low level detect (external IRQ)
-Counter/Timer A and B underflow
-Inter-processor communication
- Host computer data transfer
-Non-maskable
-Reset
- Flexible system operation
-Memory mapped I/O for easy programming
-Page zero location for memory efficient access
- Low power at normal frequency ( 40 mw at 2 MHz )
- Reduced power at low frequency ( 2.0 mw at $2 \mathrm{MHz} / 128$ )
- System clock rates from 10 KHz to 4 MHz
- $5 \mathrm{~V} \pm 10 \%$ power supply
- 64-pin QUIP


## SUMMARY

The Rockwell R65C00/21 is a complete, high performance 8 -bit, CMOS dual microcomputer in a single chip and is compatible with all R6500 microprocessors except that it has additional instructions including a 10 -clock time multiply.

The R65C00/21 consists of two enhanced instruction set 6502 CPU's in one device. The device also has 2048 bytes of ReadOnly Memory (ROM), 128 bytes of Random Access Memory (RAM) and versatile interface circuitry. The interface circuitry consists of two multimode programmable 16-bit counter/timers and 52 general purpose input/output lines. Some of these input/ output lines may be used as address, data and control lines for expanded systems or as data and control lines when the R65C00/21 is used as a programmable peripheral controller.

The two CPU's in the R65C00/21 are functionally independent. Each has its own set of registers, its own reset and interrupt vectors and operates under control of its own program. The two CPU's do, however, share the same memory and system I/O resources. This allows direct communication between the two CPU's and allows sharing of subroutines and common data areas where desired. Programming and system design for applications which require simultaneous control of two or more independent asynchronous processes is thus simplified because one CPU may control one process while the other controls
another one. Consequently, complex programming usually needed to interleave the control functions or to implement an interrupt driven system, is not required.

In a multiple computer approach, both processors may need the same subroutines so that some portions of memory must be duplicated in both systems. The dual CPU's share the same program memory, therefore only one set of subroutines is required and both CPU's may even be using them at the same time without interference.

In addition to the dual CPU's, the R65C00/21 also has the innovative architecture and the demonstrated high performance of the well established R6502 CPU, flexible input/output which provides improvements over the R6522 Versatile Interface Adapter (VIA) device, and production efficient on-chip ROM and RAM. These features make the R65C00/21 a leading candidate for most imbedded microcomputer applications.

A system using the R65C00/21 Dual CMOS Microcomputer will be simpler in design, use less program memory, require fewer components, reduce circuit board sizes, simplify test requirements, and minimize field maintenance-all contributing to lower production and support costs. In addition, simpler designs shorten development effort and time-leading to reduced development costs and faster product to market.

The R65C29 Dual CMOS Microprocessor, a ROM-less version of the R65C00/21 with permanently extended data and address bus, is also available. The R65C29 is ideal for dual CPU applications requiring changeable ROM and/or extended RAM, ROM or I/O, and can also be used for R65C00/21 prototype circuit development. The R65C00/21 can also operate in an emulation mode, like the R65C29, with its internal ROM disabled.

## DEVELOPMENT SYSTEM SUPPORT

Prototype circuit and software development support are available using the Rockwell Design Center (RDC) and R65C00/21 Personality Module. Program development and debugging aids such as text editing, symbolic assembly with conditionals and macros at the absolute and relocatable/linking level, and single/ multiple step execution with instruction/data tracing are provided. Real-time in-circuit emulation in the target environment is also supported.

## NOTE

All descriptions of R65C00/21 operation in this document also apply to the R65C29 except for internal ROM, and as otherwise noted.

## ORDERING INFORMATION

The R65C00/21 Dual CMOS Microcomputer can be ordered in volume quantities with the following speed capability and mask option indicated in the R65C00/21 ROM Code Order Form (Document Order No. 2134)

- 1, 2, 3, or 4 MHz system clock (ø2)
- Crystal/master clock or slaved clock input mask option

The R65C29 Dual CMOS Microprocessor has the following characteristics:

- Crystal/master clock input
- 8 -bit data bus and 16 -bit address bus extension
- No internal ROM


## INTERFACE

The interfaces for the R65C00/21 and R65C29 are illustrated in Figure 1.

The pin assignments for the R65C00/21 and the R65C29 are shown in Figure 2. The R65C29 pin assignments are the same as the R65C00/21 except that bus expansion functions are permanently assigned instead of general purpose ports $D$ and $E$.

The interface signals for the R65C00/21 and R65C29 are described in Table 2. The descriptions of the selectable bus expansion pins (16-bit address mode) for the R65C00/21 apply to permanent bus expansion pins for the R65C29.


Figure 1. R65C00/21 and R65C29 Interface Diagram


Figure 2. R65C00/21 and R65C29 Pin Asignments

Table 1. R65C00/21 Pin Descriptions

| Signal Name | Pin No. | 1/0 | Description |
| :---: | :---: | :---: | :---: |
| PAO-PA7 | 31-24 | VO | Port A. General purpose 8-bit I/O Port A. |
| PB0-PB7 | 40-33 | VO | Port B. General purpose 8-bit I/O Port B. |
| PCO-PC7 | 48-41 | 10 | Port C. General purpose 8-bit I/O Port C. Host Data Bus in Host Mode. |
| PD0-PD7 | 56-49 | 1/O | Port D. General purpose 8-bit I/O Port D. Multiplexed lower address (AO to A7) and Data Bus (D0-D7) when Bus Extension Mode is selected. |
| PE0-PE7 | 15-8 | 0 | Port E. General purpose 8-bit output Port E. Upper address (A8 to A11 or A8 to A15) when Bus Expansion Mode is selected. |
| PF0-PF7 | 23-16 | 1/O | Port F. General purpose 8-bit I/O Port F. Under software control, each line has alternate functions as follows: |
| PFONEG (PFO) | 23 | 1 | PFO Positive Edge Detect. Maskable CPU interrupt on PFO Positive Transition. |
| PF1POS (PF) | 22 | 1 | PF1 Negative Edge Detect. Maskable CPU interrupt on PF1 Negative Transition. |
| PF2LOW (PF2) | 21 | I | PF2 Low Level Detect. Maskable CPU interrupt on PF2 Low (external IRQ). |
| TIMA (PF3) | 20 | 1/0 | Timer A External Input/Output. |
| TIMB (PF4) | 19 | 1/0 | Timer B External Input/Output. |
| $\overline{\text { HINT (PF7) }}$ | 16 | 0 | Host Interrupt. Active-low maskable interrupt request to Host. |
| PG0-PG3 | 60-57 | I | Port G. General purpose 4-bit input Port G. Under software control, Port G serves as the Host Control Bus as follows: |
| $\mathrm{H} \varnothing 2 / \overline{\mathrm{HRD}}$ (PGO) | 60 | 1 | Host Bus Clock/Read Strobe Input. $\varnothing 2$ for 6500/6800 bus; Read Strobe for Z80/8080 bus. |
| $\mathrm{HR} / \bar{W} / \overline{\mathrm{HWR}}$ (PG1) | 59 | 1 | Host Bus Read-Write/Write Strobe Input. R/W for 6500/6800 bus; Write Strobe for Z80/8080 bus. |
| HRS (PG2) | 58 | 1 | Host Bus Register Select Input. Low selects Data Buffer; high selects Status Flags. |
| $\overline{\mathrm{CS}}$ (PG3) | 57 | 1 | Host Bus Active-Low Chip Select Input. Low selects Host Bus operation depending on HRS and HR/W/HWR coding and Host Control and Status Register contents; high disables Host Bus interface. |
| $\overline{R E S}$ | 63 | I | Reset. Active-low Reset input initializes R65C00/21 to initial conditions-resets all registers and $I / O$ lines. |
| $\overline{\text { NMIA }}$ | 62 | 1 | CPU A Non-Maskable Interrupt. Non-maskable negative edge sensitive interrupt input to CPU A. |
| $\overline{\text { NMIB }}$ | 61 | 1 | CPU B Non-Maskable Interrupt. Non-maskable negative edge sensitive interrupt input to CPU B. |
| EMS | 5 | 0 | External Memory Strobe. Active-low. |
| $\varnothing 2$ | 3 | 0 | System Phase 2 Clock Output. Maskable as system clock input for slave operation. |
| $\mathrm{R} / \overline{\mathrm{W}}$ | 7 | 0 | Read/Write. Read/write control output. High during read, low during write. |
| SYNC | 6 | 0 | Sync. Instruction sync output. High When Op Code fetched |
| $\varnothing$ A | 4 | 0 | Phase A. Phase A clock output. High during CPU A bus cycle, low during CPU B bus cycle. |
| XTALO | 1 | 0 | Crystal/Master Clock Return. Output connection to crystal (or no connection if external master clock connected to XTALI). Input frequency is two times system clock ( $\varnothing 2$ ) rate. |
| XTALI | 2 | 1 | Crystal/Master Clock Input. Input connection from crystal (or external master clock). |
| VCC | 64 |  | Power, 5.0 Vdc. |
| VSS | 32 |  | GND. Signal and power ground. |

## FUNCTIONAL DESCRIPTION

The R65C00/21 consists of two central processor units (CPU's), a $2048 \times 8$ read-only memory (ROM), a $128 \times 8$ random access memory (RAM), five 8 -bit parallel I/O ports, one 8 -bit output port, one 4 -bit input port, two 16 -bit counter/timer systems, a variety of I/O control registers, and an independent interrupt control system for each CPU. All of the ROM, RAM, I/O, internal buses, and the arithmetic logic unit (ALU) are shared by the two CPU's. A memory map of the system is shown in Figure 3. An overall block diagram of the R65C00/21 is shown in Figure 4.

## NOTE

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

## INTERNAL MEMORY

## INTERNAL READ-ONLY-MEMORY (ROM)

The ROM in the R65C00/21 consists of 2048 (2K) bytes of mask programmable memory with an address space from F800 to FFFF. ROM locations FFF2 through FFFF are assigned to interrupt and reset vectors for the two CPU's.

## INTERNAL RANDOM ACCESS MEMORY (RAM)

The internal RAM consists of 128 bytes of read/write memory with assigned page zero addresses of 0080 through 00FF.

## EXTERNAL MEMORY

External memory can be addressed by selecting the Bus Expansion. Mode in the Bus Control Register. Address space from 0200 through EFFF may be accessed for either RAM, ROM, or I/O purposes as the particular application requires it. In addition, there are 32 bytes from 0020 through 003F which may be used for VO expansion and 256 bytes from 0100 through 01FF which may be external RAM.

## CPU LOGIC

Each CPU in the R65C00/21 is effectively a standard R6502 CPU with 10 extra instructions utilizing 40 operation codes which are unused in the R6502. Therefore, each CPU has an 8 -bit accumulator, two 8-bit index registers ( X and Y ), an 8-bit Stack Register, a 16 -bit Program Counter, independent interrupt circuitry, and an instruction register with state counter. The internal buses, memory, instruction decoding circuitry, and ALU are shared by the two CPU's on alternate clock cycles.

## ACCUMULATORS

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

## INDEX REGISTERS

Each CPU has two index registers, $X$ and $Y$. Each index register may be used as a modifier to a base address supplied as a part of the instruction being processed. The resulting effective address is usually the sum of the base address plus the contents of the indicated index register. The index registers are used in a number of the addressing modes including zero page indexed, absolute indexed, post-indexed indirect and pre-indexed indirect. Each index register also has a family of instructions which allow loading, storing, incrementing, decrementing, and comparing the contents of the register. These are discussed thoroughly in the R6500 Programming Manual (Order No. 202).

| $\begin{aligned} & 0000 \\ & 001 F \\ & 0020 \end{aligned}$ | I/O AND CONTROL REGISTERS |
| :---: | :---: |
|  | EXTERNAL I/O EXPANSION2 |
| $\begin{aligned} & 003 F \\ & 0040 \\ & 007 F \end{aligned}$ | NOT ACCESSIBLE |
|  | INTERNAL RAM (128 BYTES) ${ }^{1}$ (SHARED WITH 0180-01FF) |
| $\begin{aligned} & 017 \mathrm{~F} \\ & 0180 \end{aligned}$ | EXTERNAL RAM EXPANSION2 |
|  | INTERNAL RAM (128 BYTES) ${ }^{1}$ (SHARED WITH 0080-00FF) |
| $\begin{aligned} & \text { 01FF } \\ & 0200 \end{aligned}$ | EXTERNAL MEMORY AND I/O EXPANSION ${ }^{2}$ |
| $\begin{aligned} & \text { EFFF } \\ & \text { F000 } \\ & \text { F7FFF } \end{aligned}$ | NOT ACCESSIBLE |
| F800 FFF1 | INTERNAL ROM (2048 BYTES) |
| FFF2 | NMIB VECTOR |
| FFF4 | RESB VECTOR |
| FFF6 FFF7 | IRQB VECTOR |
| $\begin{aligned} & \text { FFF8 } \\ & \text { FFFF9 } \end{aligned}$ | NOT USED |
| FFFA FFFB | NMIA VECTOR |
| FFFC <br> FFFD | RESA VECTOR |
| FFFE FFFF | IRQA VECTOR |

Notes:

1. When bit 4 of the Bus Control Register (BCR) is a 0 (default value), the 128 bytes of internal RAM are redundantly mapped into both page zero and page one and are addressable as either 0080-00FF or $0180-01$ FF. When BCR bit 4 is a 1 , all of page one RAM ( 256 bytes) is mapped externally ( $0100-01$ FF) and the 128 bytes of internal RAM are dedicated to page zero (0080-00FF).
2. Accessible in bus expansion mode.

Figure 3. R65C00/21 Memory Map


Figure 4. R65C00/21 and R65C29 Block Diagram

## STACK POINTERS

Each CPU in the R65C00/21 has its own independent 8-bit Stack Register located in RAM on page zero/one and is pointed to by a Stack Pointer. Each Stack Register is automatically incremented and decremented under control of the appropriate CPU to perform proper stack manipulations in response to user instructions, an IRQ interrupt or an external NMI interrupt of the appropriate CPU. The Stack Pointers must be initialized by the user program.

These stacks allow simple implementation of multiple level independent interrupts in each CPU, subroutine nesting, and simplification of many types of data manipulation without the programmer continually being aware of specific memory addresses. The JSR, BRK, RTI, RTS, PHA, PLA, PHP, PLP, PHX, PLX, PHY and PLY instructions all make use of the stack and the appropriate CPU's Stack Pointer.

Each stack may be visualized as a deck of cards which may only be accessed from the bottom of the deck. The value to be stored is written on a card and then that card is placed on the bottom of the deck (pushed onto the stack). When the data are to be read, the bottom card is removed from the deck and the value on it transferred to the appropriate register (pulled from the stack to the specific register). Each time data are to be used as an address, the value is stored in the addressed memory cell, and the Stack Pointer is decremented by 1 . When the data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1 and the resulting value can be used to address the data. The data are read from the addressed memory cell and then transferred to the appropriate register in the CPU.

Each CPU must have an independent starting location for its stack. It is the programmer's responsibility to see that the RAM utilized for each CPU stack does not conflict. It is recommended that the CPU requiring less depth in its stack be assigned the OXFF location and the other stack be started a safe distance below it. The two stacks are physically located either on page zero (although addressed as page one) for single-chip operation, or externally on page one when extended addressing is selected. (See Note 1 in Figure 3). The default areas for the stacks are on page zero. In either case, both stacks are on the same page.

## ARITHMETIC AND LOGIC UNIT (ALU)

All arithmetic and logic operations for both CPU's take place in a shared ALU. Incrementing and decrementing of the index registers and memory also take place here. The ALU stores data for only one cycle. Consequently, data placed on the inputs at the beginning of a cycle are processed and gated to one of the registers, or to memory, during the next cycle.

Each bit of the ALU has two inputs. These inputs may be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, etc.) using the data on the two inputs.

## PROGRAM COUNTERS

The 16 -bit program counters for each CPU provide addresses that step each processor through sequential instructions in a stored program. The program counter for each CPU is initially set to the value stored as the reset vector in CPU A (RESA at

FFFC) and in CPU B (RESB at FFF4) when power is applied to the R65C00/21. Each time a processor fetches an instruction from memory, the lower (least significant) byte of its program counter (PCL) is placed on the low-order eight bits of the address bus and the higher (most significant) byte of the program counter ( PCH ) is placed on the high-order eight bits of the address bus. The counter is incremented each time an instruction or operand is fetched from memory.

The contents of the program counter are replaced with a new value when a JMP, JSR, RTS, RTI, BRK, or any of the branch instructions are executed. Also, the program counter value is replaced when an external non-maskable interrupt $\overline{\text { NMIA }}$ or $\overline{\text { NMIB, }}$ an internal interrupt request, an external interrupt request via PF2 (see Port F description) or reset ( $\overline{\mathrm{RES}}$ ) occurs.

## INSTRUCTION REGISTERS AND INSTRUCTION DECODE

Instructions selected by the program counter are fetched from ROM or RAM (or Port D if in Expanded Bus Mode) and gated onto the internal data bus. These instructions are latched into the proper instruction register and then decoded using common decoding circuits for both CPU's. Timing, status bits, and interrupt controls are interpreted together with the instruction code to generate control signals for the various registers in the appropriate CPU.

## INTERRUPT LOGIC

Each CPU has its own logic which controls the sequencing of three types of interrupts: $\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}$, and $\overline{\mathrm{RQ}}$. The same RESET ( $\overline{\mathrm{RES}}$ ) pin is used for both CPU's; consequently, reset occurs on both CPU's at the same time. A different reset vector (RESA and RESB) exists for each CPU to allow initialization of the separate and independent programs.

Separate pins are used for the two processors' non-maskable interrupts ( $\overline{\text { NMIA }}$ and $\overline{\text { NMIB }}$ ). Each processor has its own NMI vector; CPU A uses NMIA Vector at FFFA and CPU B uses NMIB Vector at FFF2.

Three different types of external interrupt conditions can be detected by connecting the external signal to one of three Port $F$ input pins. A positive-going edge, a negative-going edge, and an external interrupt request ( $\overline{\mathrm{RQ}})$, i.e., a low level, can be detected on PF0, PF1 and PF2, respectively. Internally, IRQ conditions can be generated by time-out of either of the two 16bit counter/timers, upon interprocessor-communication request by the other CPU, or by the Host Interface Port.

In each case, the interrupt condition is reported as an interrupt flag in a control/status register associated with the functional area. Each CPU can either enable or disable IRQ generation by setting or resetting a corresponding interrupt enable bit in the same or associated control/status register.

Furthermore, each CPU can control whether or not its processing is interrupted when an interrupt request ( $\overline{\mathrm{RQ}})$ is generated. Each CPU has its own Processor Status Register (PSRA and PSRB) with the capability of disabling $\overline{\mathrm{IRQ}}$ interrupts when its own "I flag" bit is a 1.

## NEW AND MODIFIED INSTRUCTIONS

In addition to the standard R6502 instruction set, ten new instructions have been added and minor timing and other changes have been made to a few other instructions. All of these additions and changes are discussed in this section. Refer to the Instruction Set Op Code Matrix for the operation codes and addressing modes of all instructions. The times indicated for each instruction are given in terms of CPU clock-times.

## UNSIGNED MULTIPLY (MUL)

The 10 clock-time hardware multiply instruction multiplies the 8bit contents of the Y register by the 8 -bit contents of the A register to give a 16 -bit product. At the completion of the multiply operation, the most significant half of the product resides in the A register and the least significant half in the $Y$ register. This operation uses unsigned numbers only. This instruction uses the implied addressing mode and, consequently, requires one byte for the op code.

## SET MEMORY BIT (SMB m, ADDRESS.)

This instruction uses zero page addressing only and requires five cycle times. It sets the designated bit in the addressed memory cell or I/O port to a 1. The first byte of the two-byte instruction identifies the operation and the bit to be set while the second byte designates the address of the word in which the bit is to be set. Eight op codes are used for the eight bit locations in a byte.

## RESET MEMORY BIT (RMB m, ADDRESS.)

This instruction operates in the same way as the SMB instruction except that the bit is set to 0 .

## BRANCH ON BIT SET RELATIVE (BBS m, ADDRESS, DESTINATION)

This instruction tests one of eight bits designated by a three-bit immediate field within the first byte of the instruction. The second byte designates the address of the byte to be tested within the zero page address range (memory or l/O ports). The third byte of the instruction specifies the 8 -bit relative address to which the
instruction branches if the bit tested is a 1. If the bit tested is not set to a 1, the next sequential instruction is executed. This instruction requires five cycles if the branch is not executed, six cycles if the branch executes to the same page, or seven cycles if it branches to a different page.

## bRANCH ON BIT RESET RELATIVE (BBR m, ADDRESS, DESTINATION)

This instruction is similar to the BBS instruction except that the branch takes place if the bit tested is a 0 .

## INDEX REGISTER STACK OPERATIONS (PHX, PLX, PHY, AND PLY)

These instructions are similar to the PHA and PLA instructions in the conventional R6502 except that they push or pull the $X$ or $Y$ registers to and from the stack, respectively. The push instructions require three instruction cycles and the pull instructions require four cycles.

## UNCONDITIONAL BRANCH (BRA)

This unconditional branch is a branch always instruction. It operates similar to the conditional branches of the R6502 except that the relative branch always occurs. It executes in three cycles if the branch is to the same page or four cycles if it is not. Two bytes are required, one for the op code and the other for the relative address.

## INSTRUCTION DIFFERENCES FROM R6502

Decimal add and decimal subtract instructions on the R65C00/ 21 require one cycle time longer than their binary equivalents. The add and subtract times are the same for both decimal and binary operation on the R6502.

The decimal mode flag (D) in the processor status registers default to binary $(\mathrm{D}=0)$ operation when the R65C00/21 is RESET, whereas this bit is uninitialized on the R6502.

The indirect jump instruction increments the page address when the indirect pointer crosses a page boundary, whereas on the R6502 it does not.

## PROCESSOR STATUS REGISTERS

Each CPU has its own 8-bit Processor Status Register. Each register contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the appropriate CPU. The R65C00/21 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags.

## CARRY BIT (C)

The carry bit (C) can be considered the ninth bit of an arithmetic operation. It is set to a 1 if a carry from the eighth bit has occurred, or it is cleared to 0 if no carry has occurred, as a result of arithmetic or shift operations.

The carry bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instructions, respectively. Other operations which affect the carry bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

## ZERO BIT (Z)

The zero bit $(Z)$ is set to a 1 by the CPU during any data movements, or calculations, which sets all eight bits of the result to zero for that CPU. This bit is cleared to a 0 when all eight bits of a data movement, or calculation, operations are not all zero for that CPU. The R6500 instruction set contains no instruction to specifically set or clear the $Z$ flag bit. The $Z$ flag bit is, however, affected by the following instructions: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LSR, ORA, PLA, PLP, PLX, PLY, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

## INTERRUPT DISABLE BIT (I)

The interrupt disable bit (I) controls the servicing of an interrupt request ( $\overline{\mathrm{RQ}})$. If the 1 bit is set to a 0 in the Processor Status Register of one, or both, of the CPU's, the $\overline{\mathrm{RQ}}$ signal will be serviced by that particular CPU. If the bit is set to a 1 for one or both of the CPU's, the $\overline{\mathrm{IRQ}}$ signal will be ignored by that CPU. Each CPU will set its interrupt disable bit to a 1 if a $\overline{\text { RES, }}$, an $\overline{\mathrm{IRQ}}$, or its non-maskable interrupt (NMI) signal is detected. Interrupting one processor does not affect the other one unless it is programmed to respond to the same interrupt.

The I bit is cleared for each CPU when that CPU executes a Clear Interrupt Disable (CLI) instruction and is set under software control by a Set Interrupt Disable (SEI) instruction. This bit is also set by the Break (BRK) instruction. The Return From Interrupt (RTI) and Pull Processor Status (PLP) instructions also affect the I bit by setting it to the value which was stored on the stack.

## DECIMAL MODE BIT (D)

The decimal mode bit (D) controls the arithmetic mode of its CPU. When this bit is set to a 1 , the adder operates as a decimal adder for the Add with Carry (ADC) and the Subtract With Carry (SBC) instructions. These instructions, in the decimal mode, require one additional CPU cycle time compared with binary mode or the decimal mode in the conventional R6500. (In the conventional R6500, the decimal and binary arithmetic operations are the same speed.) When the bit is a 0 , the arithmetic is performed in straight binary. The decimal mode is controlled only by the programmer for each of the CPU's. The Set Decimal Mode (SED) instruction causes decimal arithmetic to be performed and the Clear Decimal Mode (CLD) instruction causes binary arithmetic to be performed by that CPU. The PLP and RTI instructions also affect the decimal mode bit.

The $D$ bit for each CPU is automatically set to the zero state (binary mode) when the R65C00/21 is reset by $\overline{\mathrm{RES}}$.

## BREAK BIT (B)

The break bit ( $B$ ) determines the type of condition which caused the IRQ service routine to be entered. If the IRQ service routine was entered because a BRK instruction was executed by its CPU, the B bit is set to a 1 . If the service routine was entered because of an $\overline{\mathbb{R Q}}$ signal being generated, the $B$ is set to a 0 . There are no instructions which directly set or clear this bit.

## OVERFLOW BIT (V)

The overflow bit $(\mathrm{V})$ indicates that the result of a signed binary addition or subtraction operation is a value which cannot be contained in seven bits (outside the range of -128 to +127 ). This indicator only has meaning when signed arithmetic is performed. In this case, the arithmetic operations are being performed on the sign and seven magnitude bits for one byte, or the most significant byte of a longer signed number. When the ADC or SBC instruction is executed, the overflow bit is set to a 1 if the polarity of the sign bit is changed because the result exceeds +127 or -128 in absolute magnitude. Otherwise, the V bit is cleared to a 0 . The V bit may be cleared by the programmer by executing a Clear Overflow (CLV) instfuction in the appropriate CPU.

The overflow bit is also affected by the BIT instruction. The BIT instruction samples specific bits in memory or 1/O interrupt status words. Most of the I/O devices used in the R6500 family and most of the interrupt flags in the R65C00/21 have interrupt flags in the upper two bits of the register. The BIT command copies these two most significant bits of the addressed word into the N and V flags. The V flag is set to the same state as bit 6 of the addressed words and the N flag copies bit 7.

The instructions which affect the $\dot{V}$ flag are ADC, BIT, CLV, PLP, RTI and SBC.

## NEGATIVE BIT (N)

The negative bit ( N ) indicates that the sign bit (bit 7) in the resulting value of a data movement or arithmetic operation is a 1. If the value represents a signed number, the most significant bit being a 1 indicates a negative number. If the sign bit is a 0 , the result is interpreted as a positive value. The BIT instruction copies the most significant bit of the addressed memory cell or $\mathrm{I} / \mathrm{O}$ register into the N flag bit.

There are no instructions that set or clear the N bit directly since the N bit represents only the status of a result. The instructions which produce a result that affects the state of the N bit are AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, PLX, PLY, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

Processor Status Registers (PSRA and PSRB)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NEG <br> $(N)$ | OVFL <br> $(V)$ | NOT <br> USED | BRK <br> $(B)$ | DEC <br> $(D)$ | IRQ <br> ENBL <br> $(I)$ | ZERO <br> $(Z)$ | CARRY <br> $(C)$ |


| Bit 7 | Negative (N) ${ }^{1}$ |
| :---: | :---: |
| 1 | Negative Value |
| 0 | Positive Value |
| Bit 6 | Overflow (0)' |
| 1 | Overflow Set |
| 0 | Overflow Clear |
| Bit 5 | Not Used (Don't care value) |
| Bit 4 | Break Command (B) ${ }^{1}$ |
| 1 | Break Command |
| 0 | Non-break Command |
| Bit 3 | Decimal Mode (D) ${ }^{3}$ |
| 1 | Decimal Mode |
| 0 | Binary Mode |
| Bit 2 | Interrupt Enable (I) ${ }^{2}$ |
| 1 | IRQ Interrupt Disable |
| 0 | IRQ Interrupt Enable |
| Bit 1 | Zero (Z) ${ }^{1}$ |
| 1 | Zero Result |
| 0 | Non-Zero Result |
| Bit 0 | Carry (C) ${ }^{1}$ |
| 1 | Carry Set |
| 0 | Carry Clear |

Notes:

1. Not initialized by $\overline{\mathrm{RES}}$.
2. Set logic 1 by $\overline{\mathrm{RES}}$.
3. Cleared to logic 0 by $\overline{\text { RES. }}$
4. There are two Processor Status Registers, one for each CPU.

## INPUT/OUTPUT AND CONTROL/STATUS REGISTERS

## REGISTER ADDRESSES

Table 2 shows the input/output, control/status and timer/counter registers which are addressed on page zero from locations 00 through 1D. Some of the registers combine other functions when they are read or written. The table lists both the primary and secondary types of functions. Table 3 summarizes the register formats.

All control/status registers and data direction registers are cleared to zero by a $\overline{\text { RES }}$. Thus, the zero state of each bit defines the default operating modes. Each register is associated with a functional area in the microcomputer, e.g., parallel input/output, timer/counter, bus control, etc. The detail operation of each register is defined in the appropriate sections.

Thirteen registers are used for input/output functions and nine registers used for timer/counter functions. The use of these registers is discussed in later sections.

Seven controlstatus registers control and monitor the basic operation of the R65C00/21. The registers and their primary functions are as follows:

BCR Bus Control Register-defines expansion bus modes
HCSR Host Control and Status Register-defines host bus and interrupts
ICSR Interrupt Control and Status Register-enables and reports interrupt conditions
CIFR Clear Interrupt Flags Register
PCR Power Control Register-selects low power mode
TACSR Timer A Control and Status Register-controls and monitors Timer A operation
TBCSR Timer B Control and Status Register-controls and monitors Timer B operation

Table 2. I/O, Control/Status and Timer Registers


Table 3. Control/Status Registers Formats Summary

| Address (Hex) | Bit Number |  |  |  |  |  |  |  | BUS CONTROL REGISTER (BCR) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| 10. | CPU A ACTIVE | NOT USED |  | PAGE ONE EXT | PORT A NIBBLE MODE |  | BUSEXTENSIONMODE |  |  |
| 11 | O/P <br> BUFF <br> FULL INT FLAG (OBF) | VP <br> BUFF <br> FULL <br> INT <br> FLAG <br> (IBF) | VO REG SEL (RSI) (RSO) | NOT USED | I/OA INT <br> ENBL <br> I/OB INT <br> ENBL | HOST INT ENBL | HOST BUS <br> ENBL | HOST BUS <br> TYPE | HOST CONTROL AND STATUS REGISTER (HCSR) |
| 12 | IPCA INT FLAG | PF2 <br> LOW <br> INT <br> FLAG | PF1 <br> NEG <br> EDGE <br> INT <br> FLAG | PFO <br> POS <br> EDGE <br> INT <br> FLAG | IPCA INT <br> ENBL | PF2A INT <br> ENBL | $\begin{aligned} & \text { PF1A } \\ & \text { INT } \\ & \text { ENBL } \end{aligned}$ | $\begin{aligned} & \text { PFOA } \\ & \text { INT } \\ & \text { ENBL } \end{aligned}$ | INTERRUPT CONTROL AND STATUS REGISTER (ICSR) |
|  | $\begin{aligned} & \text { IPCB } \\ & \text { INT } \\ & \text { FLAG } \end{aligned}$ |  |  |  | $\begin{aligned} & \hline \text { IPCB } \\ & \text { INT } \\ & \text { ENBL } \end{aligned}$ | $\begin{aligned} & \text { IPCB } \\ & \text { INT } \\ & \text { ENBL } \end{aligned}$ | PF1B INT ENBL | $\begin{aligned} & \text { PFOB } \\ & \text { INT } \\ & \text { ENBL } \end{aligned}$ |  |
| 13 | CLR <br> IPCA <br> INT <br> FLAG <br> CLR <br> IPCB <br> INT <br> FLAG | NOT USED | CLR <br> PF1 <br> NEG <br> INT <br> FLAG | CLR <br> PFO <br> POS <br> INT <br> FLAG | NOT USED |  |  |  | CLEAR INTERRUPT FLAGS REGISTER (CIFR) |
| 14 | WRITE ONLY REGISTER-NO SPECIFIC BIT (IPCIR) |  |  |  |  |  |  |  | INTER- <br> PROCESSOR COMMUNICATION INTERRUPT REGISTER (IPCIR) |
| 15 | NOT USED |  |  |  |  |  | LOW PWR CPU B (LPB) | LOW PWR CPU A (LPA) | POWER CONTROL REGISTER (PCR) |
| 16 | TMR A UNFL FLAG (UFA) | $\begin{aligned} & \text { PF3 } \\ & \text { LEVEL } \\ & \text { IND } \end{aligned}$ | NOT USED | TMR A INT ENBL | TMR A CLK PRESC SEL | TIMER A MODE SELECT |  |  | TIMER A CONTROL AND STATUS REGISTER (TACSR) |
| 1A | TMR B UNFL FLAG (UFB) | PF4 LEVEL IND | NOT USED | TMR B INT ENBL | NOT USED |  | TIMER B MODE SELECT |  | TIMER B CONTROL AND STATUS REGISTER (TBCSR) |
| Note: All control and status registers are cleared to zero by RES |  |  |  |  |  |  |  |  |  |

## INTERRUPT CONTROL AND STATUS

Unlike other R6500 family devices, the R65C00/21 does not concentrate the interrupt flags into a single register. The R65C00/21, in general, places the interrupt flags in registers which also have to do with the control of the particular function which can cause the interrupt.

Interrupt enable control is located in the following registers:
HCSR Host Control and Status Register
ICSR Interrupt Control and Status Register

TACSR Timer A Control and Status Register
TBCSR Timer B Control and Status Register
Portions of each of these registers relating to interrupt enables are duplicated for each of the two CPU's. However, only one memory address has been allocated so that each CPU uses the same address to select its own interrupt enables. The specific details of the usage of the interrupt control bits are discussed in the corresponding functional area.

## CLOCK CIRCUITS

## CLOCK OSCILLATOR

The internal clock oscillator generates the system clock ( $\varnothing 2$ ) which clocks all R65C00/21 operations. The system clock frequency ranges from 10 KHz to 4 MHz (the upper limit determined by the R65C00/21 part number) which is one-half the external crystal (or master clock) frequency. Each CPU in turn operates at one-half the system clock frequency (alternate cycles). All operations to memory or VO take place at the system clock frequency. Since each CPU shares the common segments of the system on alternate system clock cycles, all internal operations occur at the system clock rate but, for CPU timing purposes, a CPU cycle rate of half the system rate is used. Thus with a 4 MHz crystal frequency, the system clock rate is 2 MHz and each CPU operates at an effective 1 MHz rate. Every two system clock periods sees one cycle devoted to CPU A and one cycle devoted to CPU B.

The $\$ 2$ clock is normally routed externally to clock external memory operations in the extended bus mode. A mask option allows the $\emptyset 2$ clock to be configured as an input so the R65C00/21 can operate in a slaved clock mode. In this case, the crystal input (XTALI) is grounded and crystal output (XTALO) is left open as shown in Figure 5.

## LOW POWER OPERATION

The divide-by- 128 clock prescaler operates in one of three ways (see Figure 6). One is the prescaler switched completely out which gives a system clock rate ( $\varnothing 2$ ) at one-half of the crystal frequency. Another way is to select the low power operation for both CPUs which switches in the clock prescaler. The clock prescaler divides the system clock frequency by 128 to generate the prescaled system clock rate ( $\varnothing 2 \mathrm{PS}$ ). This reduces the device power requirements and also reduces the counting rate of both counter/timers by a factor of 128. The third operating mode for the prescaler is to use it for prescaling Timer A only. This mode is discussed under the Counter/Timer Operation.

## POWER CONTROL REGISTER (PCR)

Two bits in the Power Control Register (PCR) determine operation of the clock prescaler. Each CPU can set its own power control bit and read both of them. When both power control bits are a 1 , the system switches to the low power operation at a clock rate of $\varnothing 2 / 128$ ( $\varnothing 2$ PS). The system reverts to normal power and speed when either power control bit is a 0 or when an enabled interrupt occurs. In the latter case, the system continues to operate at the low rate until the current instruction is completed, then it switches to the normal rate. The Power Control Register is shown in Figure 7.

## NOTE

An enabled interrupt automatically clears the PCR bit for the affected CPU. It must be set again by software to resume low power mode.

Bits 7-2
$\frac{\text { Bit } 1}{1}$
0
$\frac{\text { Bit } 0}{1}$
0

Not Used (Don't care)
Low Power Mode Select for CPU B (LPB) Low power mode requested by CPU B Normal power mode requested by CPU B
Low Power Mode Select for CPU A (LPA) Low power mode requested by CPU A Normal power mode requested by CPU A

## Notes:

1. Both CPU's can read both bits.
2. Each CPU can only write its power control bit.
3. Both bits must be set to enable low power mode.


Figure 5. Master/Slave Cock Connection


Figure 6. System Clock Operation

## PARALLEL INPUT/OUTPUT PORTS

The R65C00/21 parallel input/output interface consists of five 8 -bit, bidirection input/output ports, one 8 -bit output only port, and one 4-bit input only port.

## BIDIRECTIONAL PORTS A, B, C, D AND F

The five 8 -bit bidirectional ports (Ports A, B, C, D and F) each have an associated data direction register which configures individual data ports for either input or output. Port $E$ is output only and port G is input only, therefore, no data direction registers are required for these two ports.

## OUTPUT MODE

If the data direction register for a particular bit position in a bidirectional port is a 1 , that bit is defined as an output pin. The information written into each bit position of the data word is loaded into a latch. The information will remain in that latch until new data is transmitted to the data word or the power is shut off. The output latches are individually connected to output drivers for each bit position for which a corresponding bit in the data direction register is a 1 . The output drivers are doubleended, push-pull type. The drivers force the output pins high ( $\geqslant 2.4 \mathrm{~V}$ ) if the output data bit is a 1 , or low ( $\geqslant 0.4 \mathrm{~V}$ ) if the output data bit is a 0 . The output drivers are TTL compatible.

## INPUT MODE

If the data direction register for a particular bit position in a bidirectional port is 0 , that bit position is defined as an input pin. When the input/output port is read via an LDA, LDX, LDY, ADC, SBC, ORA, AND, EOR, or a BIT instruction, all of the information on that port's pins are read into the corresponding register and processed as directed by the instruction. Since the input signal lines are at a "float" state, the logic level on them will be read as either a 1 or a 0 for that pin position. A low ( $\geqslant 0.8 \mathrm{~V}$ ) input causes a logic 0 to be read and a high ( $\geqslant 2.0 \mathrm{~V}$ ) input causes a logic 1 to be read. The output values can also be read (if the direction bit $=1$ ) since the outputs are also on the pins. The input receivers are TTL compatible, are not latched, and are sampled near the end of each clock cycle $\varnothing 2$ and gated onto the internal bus when selected.

## PORT A NIBBLE ADDRESSING

Whenever a port is shared as an output, care must be exercised that one CPU does not destroy the other CPU's output data. In general, this can be avoided by allocating complete output ports to each CPU so that there is no possibility of conflict. However, there may be some situations where at least one port must be shared for outputs to get the proper mix for the required application. Port A is slightly different from the other bidirectional ports to allow port A to be safely shared as an output port by both CPU's.

Port A is divided into two 4-bit "nibble ports". Each half (nibble) of Port A may be independently addressed by each CPU as defined by two bits in the Bus Control Register (BCR2 and BCR3) as described in Bus Extension and Host Interface section. Depending upon the control bits, either CPU may be
assigned to write to both halves, write to neither half (only read-the other CPU writes to the whole register), write to top half, or write to bottom half. When a mode has been selected for writing to only one-half of the port, the other half is unaffected.

## ALTERNATIVE MODES OF OPERATION

Bidirectional Ports C, D, and F all have alternative modes of operation which may be selected in lieu of the bidirectional port capabilities.

Port C is a data bus for a host computer when the R65C00/21 is being used as a programmable peripheral device. This is discussed in more detail under Bus Extension and Host Interface.

Port D is a multiplexed data bus ( D 0 through D 7 ) and address bus (A0 through A7) when the R65C00/21 is used as a microcomputer with external memory and I/O devices. This is also detailed under Bus Extension and Host Interface.

Port F also has the capability of operating in conjunction with other segments of the R65C00/21 architecture as described below.

## PORT F CONTROL AND STATUS

The Interrupt Control and Status Register (ICSR) and the Clear Interrupt Flags Register (CIFR) control and monitor the operation of the Port $F$ external interrupts (bits $2,1,0$ ) as well as interprocessor communication interrupts.

When the PFO edge-sensitive circuit detects a positive transition, bit 4 of the ICSR is set to a 1 . An internal interrupt request ( $\overline{\mathrm{RQ}})$ is generated to a CPU whenever this bit is set and the corresponding PFO Interrupt Enable Flag (ICSR bit 0 ) is set to a 1 for that CPU. Similarly, a negative going transition on PF1 sets the edge detect flag in ICR bit 5 . ICSR bit 1 is the corresponding PF1 Interrupt Enable bit. As in all cases of the interrupt enable bits, each CPU has its own set, addressed at the same location, but held separately.

Port F signal PF2 has an external interrupt request ( $\overline{\mathrm{RQ}}$ ) capability. When this signal goes low, bit 6 of the Interrupt Control and Status Register is set and remains set as long as the signal is low. If the corresponding PF2 Interrupt Enable bit (bit 2) in its segment of the Interrupt Control and Status Register is a 1 while the PF2 Low Interrupt bit (bit 6) is a 1, an interrupt request is generated.

Each CPU may thus control the external interrupt independently of the internal interrupts. If the I flag in the Processor Status Register of a particular CPU is a 1, no /रQ's will be honored. If the I flag is a 0 and that CPU's interrupt enable in bit 2 of the Interrupt Control and Status Register is a 0 , only internal interrupts will interrupt that CPU. If bit 2 is a 1 , any $\overline{\mathrm{IRQ}}$ will be honored.

The Port F signals PF3 and PF4 can be used as external interfaces for Counter/Timers A and B, respectively (refer to the Counter/Timers description). Finally, PF7 can be used as an active-low interrupt to a host processor. The operation of the R65C00/21 with a host processor is discussed under Bus Extension mode.

The Inter-Processor Communication Interrupt (IPCA and IPCB) bit in the ICSR allows each CPU to interrupt the other CPU if all of the other normal IRQ conditions are correct. CPU A sets the IPCB Interrupt Flag in CPU B's Interrupt Control and Status Register and CPU B sets the IPCA Interrupt Flag in CPU A by any write to location 0014, the Inter-Processor communications Interrupt Register. This is not an actual register, but writing any value here sets the other CPU IPCI flag. This inter-processor communications is illustrated in Figure 7.

Interrupt Control And Status Register (ICSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IPCA | PF2 <br> LOW <br> INT <br> FLAG | PF1 NEG EDGE INT | PFO POS EDGE | IPCA | PF2A | PF1A | PFOA |
| INT |  |  |  | INT | INT | INT | INT |
| FLAG |  |  |  | ENBL | ENBL | ENBL | ENBL |
| IPCB |  |  | INT | IPCB | PF2B | PF1B | PFOB |
| INT |  |  | FLAG | INT | INT | INT | INT |
| FLAG |  |  |  | ENBL | ENBL | ENBL | ENBL |

Inter-Processor Communication (IPC) Interrupt Flag (A or B)
An inter-processor interrupt is requested by the other CPU
No internal interrupt is requested
PF2 Low Interrupt Flag (A and B)
PF2 is low
PF2 is high
PF1 Negative Edge Detect Interrupt Flag
A positive-to-negative transition on PF1 occurred
No positive-to-negative transition on PF1 occurred
PF0 Positive Edge Detect Interrupt Flag
A positive-to-negative transition on PF0 occurred
No positive-to-negative transition on PFO occurred
Inter-Processor Communication Interrupt Enable (A or B)

Enables inter-processor communication interrupt (bit 7)
Disables inter-processor communication interrupt (bit 7)
PF2 Interrupt Enable (A or B)
Enables PF2 interrupt (bit 6)
Disables PF2 interrupt (bit 6)
PF1 Interrupt Enable (A or B)
Enables PF1 interrupt (bit 5)
Disables PF1 interrupt (bit 5)
PFO Interrupt Enable (A or B)
Enables PFO interrupt (bit 4)
Disables PFO interrupt (bit 4)


Figure 7. Inter Processor Communication

## CLEAR INTERRUPT FLAGS REGISTER (CIFR)

The Clear Interrupt Flags Register (CIFR) is similar to the ICSR in that only one address is used but the bit pattern operates only on the status bits for its own processor. Thus only CPU A may clear IPCA but either may clear the edge detection flag bits. Bit 6 will only be cleared when the signal on PF2 goes high. Actually, the Clear Interrupt Flags Register is not a register at all, but addressing a bit pattern to this location performs the function. Any bit to which a zero is written will clear the corresponding interrupt flag. A read of this word returns logic one's so that the new Reset Memory Bit instructions may be used to clear these flags.

| Clear Interrupt Flags Register (CIFR) |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| CLR <br> IPCA <br> INT <br> FLAG | NOT USED | CLR <br> PF1 <br> NEG <br> INT <br> FLAG | CLR <br> PFO <br> POS <br> INT <br> FLAG | NOT USED |  |  |  |
| CLR <br> IPCB <br> INT <br> FLAG |  |  |  |  |  |  |  |

## COUNTER/TIMERS

There are two separate 16 -bit counter/timer systems in the R65C00/21: Counter/Timer A and Counter/Timer B. The block diagram of the counter/timers (also referred to as the timers, the counters, Timer A, or Timer B) is shown in Figure 8. Timer A has eight operating modes and five registers while Timer B has four operating modes and four registers. Both counter/timers have a 16 -bit counter comprised of two 8 -bit segments: Lower

Counter (LCA and LCB, where $A$ and $B$ refer to Counter/Timer A and B) and Upper Counter (UCA and UCB). Both counter/ timers also have a 16 -bit latch section consisting of two 8 -bit segments: Lower Latch (LLA and LLB) and Upper Latch (ULA and ULB). In addition, only Timer A has an 8-bit Snapshot Latch (SLA) register.


Figure 8. Counter/Timer Block Diagram

Data are written to the latches which act as holding registers for loading or reloading the initial counter/timer values upon mode initiation or counter/timer restart.

Both timers count down from the pre-set latch value and set an appropriate underflow flag when the counter counts through zero. The counter actually never counts below zero. At the time the counter would go negative, the contents of the latches replace the count value with no time delay.

Each counter/timer has three addresses for accessing the five (Counter/Timer A) or four (Counter/Timer B) 8-bit registers in its system. Consequently, the $R / \bar{W}$ line also aids in addressing the registers. Reading or writing to specific registers may also have other effects such as clearing an interrupt flag or transferring latch data to the counter. Consult the input/output and control register memory map in Table 2 for the effects of reading or writing to specific registers in the two counter/timer systems.

Each counter/timer has operating modes which are clocked either at the system clock rate ( $\varnothing 2$ ) or an external event clock rate. In addition, Timer A can operate with a prescaled $\varnothing 2 / 128$ clock rate.

## COUNTER/TIMER A (TA)

Counter/Timer A, with its four additional modes and Snapshot Latch, is generally more flexible than Counter/Timer B.

The Snapshot Latch (SLA) solves a problem which sometimes occurs when a timer is read. The problem is that between the time when the low byte of the 16 -bit counter is read and the time when the high byte is read it is possible for the high byte to have been decremented. The resulting 16 -bit value would, in this case be incorrect. In many modes of timer, the values are not actually read but the zero count transition is important. These types of applications do not require the use of the Snapshot Latch register. If the timer count value is to be used directly from a running timer, however, the Timer A Snapshot Latch should be used.

Timer A overcomes the problem stated above by sampling the value of the upper counter byte into the Snapshot Latch every time the lower counter byte is read. The value of the Upper Counter can be obtained by first reading the Lower Counter at address 0017, then reading the Snapshot Latch at address 0018 or 0019. Note that reading address 0019 also resets the Timer A Underflow (UFA) flag.

A second architectural difference between the two timers is that Timer A can have its clock input scaled down by a factor of 128 during normal power operation. This allows Timer A to measure longer periods of time internally while the microcomputer in operating at the $\varnothing 2$ system clock rate. With a 4 MHz system clock, more than two second time intervals (up to 2.097 seconds) can be measured directly without any software intervention. Without the prescaler, 16.384 ms is the longest time interval at 4 MHz .

## Timer A Mode Control

The operation of Timer $A$ is controlled and monitored by the Timer A Control and Status Register (TACRS).

Bits 0-2 select the Timer A mode of operation.
Bit 3, when set to a 1, causes the clock prescaler to be switched into the circuit so that the timer may count longer intervals in modes which allow it.

Timer A Interrupt Enable, TACSR bit 4, if set to a 1 by a CPU, enables generation of an internal $\overline{\mathrm{RQ}}$ to that CPU when the UFA flag is set.

Bit 6 copies bit 3 of Port $F$ (PF3) as this bit has several different uses with Timer A. However, when Timer A is not using this bit it may be used as any other input or output bit. In any event, bit 3 of the Port F Data Direction Register must be set appropriately, for either input or output, whether or not it is used with Timer A.

Bit 7 is the UFA bit which indicates that Timer A has counted down through zero. This may be detected by reading the bit or may be used to cause an IRQ interrupt if bit 4 of the TACSR is set to a 1 . The UFA flag is reset to a 0 by reading SLA or writing ULA at address 0019.

Timer A Control And Status Register (TACSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TMR A <br> UNFL <br> FLAG <br> (UFA) | PF3 LEVEL IND | NOT USED | TMR A INT ENBL | TMR A CLK PRESC SEL |  | TIMER A MODE SELECT |  |



## Timer A Operating Modes

The Timer A mode of operation is selected by setting bits 0-2 of the Timer A Control and Status Register (TACSR) to the appropriate code.

## Timer A Off, Mode 0

Timer A is turned off in this mode. The Timer A Underflow Flag (UFA) stays at its current state. The counter holds its current value and may be read. Writing to the registers performs the usual functions associated with that address but the counter remains stopped. This is the default condition.

## Timer A Free-Run Event Counter, Mode 1

The Timer A Upper Counter (UCA) and Lower Counter (LCA) is loaded with the Timer A Upper Latch (ULA) and Lower Latch (LLA) value when the data is written to the Timer A Upper Latch at address 0019. Timer $A$ then decrements by 1 at each negative transition of the signal on input Port PF3. (The Port F data direction register must have a 0 in bit 3.) The Timer A Underflow Flag (UFA) is set to 1 when the counter decrements below zero. At this same time, the latch value is reloaded into UCA and LCA. The maximum rate of the signal on PF3 which may be detected is one-half of the $\varnothing 2$ system clock rate.

## Timer A Free-Run Pulse Width Measurement, Mode 2

Writing to ULA at 0019 transfers the 16 -bit latch to the counter which operates as a timer in this mode. The initial value in the timer is decremented at the $\emptyset 2$ rate when the PF3 signal is low. Otherwise, the counter holds its value. Counting stops when the PF3 signal goes high and will resume if the signal goes low again. If the counter counts below zero, the counter initial value is reloaded from the latches and the UFA flag is set.

## Timer A One-Shot Retriggerable Timer, Mode 3

This mode is similar to Mode 4 except that the timer restarts each time PF3 goes through a high-to-low transition and counts down until the counter goes through zero. A second difference is that the clock prescaler may not be used with this mode. The data direction register bit 3 (PF3): must be zero to select input.

## Timer A One-Shot Interval Timer, Mode 4

Writing to ULA at 0019 transfers the initial value from the latches and starts the timer. The timer counts at either the $\emptyset 2$, or scaled Ø2 ( $\varnothing 2 / 128$ ), rate. When the counter counts through zero, the latch value is transferred to the counter, the UFA flag is set and the counter stops counting.

## Timer A Free-Run Interval Timer, Mode 5

Writing ULA at 0019 transfers the 16 -bit latch value to the timer and starts it running. The counter counts down at either the $\varnothing 2$, or the scaled $\varnothing 2$ ( $\varnothing 2 / 128$ ), rate. When the counter counts through zero the UFA flag is set, the value in the latches is transferred to the counter, and the counter continues to count down.

## Timer A One-Shot Pulse Generation, Mode 6

The PF3 data direction register bit must be set to a 1 before starting this mode to initially force a high output. Writing ULA at 0019 starts the timer and clears the PF3 data output bit to a 0 causing a low output. The PF3 output remains low until the timer counts through zero. At this time, the PF3 output goes high until the mode is restarted or a new mode is selected. The UFA flag is also set at this time and the counter is stopped. The timer counts at either the $\varnothing 2$, or the scaled $\varnothing 2(\varnothing 2 / 128)$, rate.

## Timer A Free-Run Pulse Generation, Mode 7

The data direction register for PF3 must be set to a 1 to select the PF3 output before starting this mode. Writing to ULA at 0019 sets PF3 to 0 forcing a low output and starts the timer. Each time the timer counts through zero, the PF3 output changes state to generate a square wave at a rate dependent upon the latch value. The timer counts at either $\varnothing 2$, or the scaled $\varnothing 2$ ( $\varnothing 2 /$ 128), rate. Each time the counter counts through zero, the latch contents are automatically transferred to the timer registers and the UFA flag is set.

## COUNTER/TIMER B (TB)

Timer B is a simpler timer than Timer A but it still retains great flexibility. Unlike Timer A, there is no "off" mode (the default mode is the Free-Run Interval Timer Mode) and there is no separate selectable clock prescaler. All counting (except for counting external events) is done either at the $\varnothing 2$ clock rate or $\varnothing 2 / 128$ rate (when low power mode is selected). Another difference is that Timer B does not have the snapshot latch register for freezing the upper timer byte for reading. However, in its normal modes the counter counts through zero to set the Underflow Flag B (UFB) so that a snapshot latch register is not required.

## Timer B Mode Control

The operation of Timer $B$ is controlled and monitored by the Timer B Control and Status Register (TBCSR).

Bits $0-1$ select the Timer B operating mode.
Timer B Interrupt Enable, bit 4, when set to a 1 by a CPU, enables generation of an internal interrupt request $(\overline{\mathrm{RQ}})$ to that CPU when the UFB flag is set.

Bit 6 of the TBCSR copies bit 4 of Port F (PF4) as this bit has several different uses with Timer B. However, when Timer B is not using this bit it may be used as any other input or output bit. In any event, bit 4 of the Port F Data Direction Register must be set appropriately for either input or output whether or not it is used with Timer $B$.

Bit 7 in the TBCSR is the UFB bit which indicates that Timer B has counted down through zero. This may be detected by reading the bit or may be used to cause an $\overline{\mathrm{RQ}}$ interrupt if bit 4 of the TBCSR is set to a 1 . The UFB bit is reset by either reading UCB or writing to ULB at address 001D.

Timer B Control and Status Register (TBCSR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| TMR B | PF4 <br> UNFL <br> FLAG <br> LEVEL <br> (UFB) | NOT <br> IND | TMR B <br> USED <br> INT <br> ENBL |  | NOT USED | TIMER B <br> MODE <br> SELECT |  |


| Bit 7 | Timer B Underflow Flag (UFB) |
| :---: | :---: |
| 1 | Underflow condition occurred |
| 0 | No underflow |
| Bit 6 | Port F Bit 4 (PF4) Level Indicator |
| 1 | PF4 High |
| 0 | PF4 Low |
| Bit 5 | Not Used (Don't care) |
| Bit 4 | Timer B Interrupt Enable |
| 1 | Enable Timer B Interrupt |
| 0 | Disable Timer B Interrupt |
| Bits 3-2 | Not Used (Don't care) |
| Bits 1-0 | Timer B Mode Select (TMS) |
| 1 0 |  |
| 0 | Free-Run Interval Timer Mode |
| 0 | Free-Run Pulse Generator Mode |
| 10 | Event Counter Mode |
| 11 | Puise Width Measurement Mode |

## Timer B Operating Modes

The Timer B operating mode is selected by setting bits 0 and 1 in the TBCSR to the appropriate code.

## Timer B Free-Run Interval Timer, Mode 0

Writing to Timer B Upper Latch (ULB) at 001D transfers the 16 -bit latch value to the timer and starts it running. The counter counts down at the $\varnothing 2$ rate. Wheh the counter counts through
zero, the Timer B Underflow Flag (UFB) is set to a 1 , the value in the latches is transferred to the counter and the counter continues to count down.

## Timer B Free-Run Pulse Generation, Mode 1

The data direction register for PF4 must be set to a 1 to select PF4 output before starting this mode. Writing to ULB at 001D sets PF4 to 0 to force the PF4 output low and starts the timer. Each time the timer counts through zero, the PF4 output changes state to generate a square wave at a rate dependent upon the initial value loaded into the latches. The timer counts at the $\varnothing 2$ rate. Each time the counter counts through zero, the latch values are automatically transferred to the timer registers and the UFB flag is set to a 1 .

## Timer B Event Counter, Mode 2

The data direction register bit for PF4 must be set to a 0 to select PF4 input prior to selecting this mode. The counter is loaded with the latch value when the ULB data is written to address 001D. Timer $B$ then decrements by 1 at each negative transition on input Port PF4. The Timer B Underflow Flag (UFB) is set to a 1, when Counter B counts through zero. At this same time, the latch value is reloaded into Timer B . The maximum rate of the signal on PF4 which may be detected is one-half of the $\varnothing 2$ clock rate.

## Timer B Pulse Width Measurement, Mode 3

Writing to ULB at 001D transfers the 16 -bit latch value to the counter. The initial value in the timer is decremented at the $\varnothing 2$ rate when the PF4 signal is low. Each time the PF4 signal goes high, the counter stops and then continues when the signal is low again. If the counter counts through zero, the UFB flag is set to 1 and the latch value transfers to reinitialize the counter and the countdown continues as long as PF4 is low.

## BUS EXTENSION

In addition to its application as a single-chip microcomputer, the bus extension mode allows the R65C00/21 to operate as a microprocessor with external memory and $1 / 0$.

## BUS EXTENSION MODE

When the R65C00/21 is used as a single-chip microcomputer, all of the output ports may be used as input or output ports. However, to use the R65C00/21 with external ROM, RAM, or I/O, a number of the ports act as extensions of the internal address and data buses. Specifically, Port D becomes dedicated as a multiplexed 8 -bit data and address bus. Port D provides both the data bus (D0 through D7) and the low bits of the address (A0 through A7) on pins PDO through PD7. When a bus extension mode is selected, the Port D Data Direction Register must be cleared to zero (its default condition) to configure Port D as all inputs. The R65C00/21 then controls Port D as an extension of the internal bus structure and provides an activelow External Memory Select (EMS) strobe signal at the time the address bits are available. The EMS signal is present even when Port $D$ is being used as a normal input/output register.

The R65C00/21 has the option of using 8-, 12- or 16 -bit address bus extensions. Selection of the bus extension mode is controlled by bits 0 and 1 of the Bus Control Register (BCR). When the 8 -bit mode is selected, only the Port D multiplexed address/ data bus function is required. However, if either the 12- or 16bit address bus extension is selected, either one half or all of output Port E also becomes dedicated to the bus extension function. If a 16 -bit bus extension is selected, then all of Port $E$ becomes the upper address bits A8 through A15 on pins PEO through PE7, respectively. If the 12-bit bus extension is selected, then the address lines A8 through A11 appear on PE0 through PE3. In this case, PE4 through PE7 have their usual output function.

Since Port D is multiplexed, it is necessary that external latches be supplied to hold the lower eight bits of the address bus. The EMS output is low when the address is being supplied from Port D. All of the other necessary control bus signals are also provided; these include $\emptyset 2$ and $\mathrm{R} / \overline{\mathrm{W}}$. The SYNC and $\emptyset \mathrm{A}$ signals are also brought out for use by development systems and bus analyzers for system debugging.

In a one-chip configuration, the 128 bytes of internal page one RAM (address 0180 through 01FF), is logically combined with page (0080-00FF). However, when an extended bus is used, the stack page may be addressed in its normal range in external memory (0100-01FF). When bit 4 of the Bus Control Register is a 0 , page one is internal and shared with page zero; when it is a 1 , page one is external allowing full 256 bytes available to the two stacks.

Figure 9 is an overall block diagram of a system using the R65C00/21 in the bus extension mode.

The CPU A Active signal (bit 7 of the BCR) is high when CPU $A$ is controlling the system bus, and low when CPU $B$ is active. This bit copies the state of the $\emptyset A$ output signal. Consequently, the bit may be sampled in common subroutines to determine the calling CPU, or for bank selection purposes. Thus, CPU A and CPU B may have some external memory or V/O dedicated to their exclusive use. Each may separately address as much as 59.5 K bytes of external memory map, or external memory may be shared.

Bus Control Register (BCR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CPU A <br> ACTIVE | NOT USED | PAGE <br> ONE <br> EXT | PORT A <br> NIBBLE <br> MODE | BUS <br> EXTENSION <br> MODE |  |  |  |




Figure 9. Bus Extension Mode Block Diagram

## PROGRAMMABLE PERIPHERAL TO A HOST MODE

An overall block diagram of a system using an R65C00/21 as an intelligent controller is shown in Figure 10.

In this configuration, three of the R65C00/21 input/output ports have special significance. Port C becomes the interface with the host data bus (Port C's Data Direction Register must specify as the input; i.e., all zeros). Pin PF7 becomes an active-low Host Interrupt (ㅍINT) line, and the 4-bit input Port G becomes the control pins interface to the Host computer.

The R65C00/21 is configured to operate as a peripheral for either the R6500 or 6800 families, or the Z80 or 8080 families. When operating in the 6500/6800 mode, PG0 is an input for the host $\varnothing 2$ (Hø2) and PG1 is the input for the host R/W (HRW) control lines.

When operating in the $\mathrm{Z80} / 8080$ mode, PG0 accepts the host $\overline{\mathrm{RD}}(\overline{\mathrm{HRD}})$ control and PG1 provides the host $\overline{\mathrm{WR}}$ ( $\overline{\mathrm{HWR}}$ ) control.

In both cases, PG2 serves as a register select (HRS) and PG3 acts as an active-low chip select ( $\overline{\mathrm{CS}}$ ) from the host. HRS is used in conjunction with the $\overline{\mathrm{CS}}$ and $\overline{\text { HWR }}$ to control reading or writing of data or status information as shown in Table 4.

Control of the host mode options is provided by the Host Control and Status Register (HCSR).

When the host writes a byte into the Input Buffer (Port C), the Input Buffer Full (IBF) flag is set to a 1. Similarly, when a byte is read from the Output Buffer (Port C) by the host, the Output Buffer Full (OBF) flag is cleared to a 0 . Setting bit 3 of the HCSR enables generation of an internal interrupt request (IRQ) when either the IBF flag is a 1 or the OBF flag is a 0 . This logic is duplicated for both CPU's.

Setting bit 2 of the HCSR to a 1 enables generation of any interrupt signal to the host computer. In this case, bit 7 of Port F is pulled low by either a write to Port C (Output Buffer) or a read from Port C (Input Buffer), by either of the R65C00/21 CPU's.

Bit 5 of the HCSR is actually two different bits representing Register Select Input (RSI) and Register Select Output (RSO). The R65C00/21 writes bit RSO and reads bit RSI, while the host writes RSI and reads RSO. The R65C00/21 writes a 0 to this bit when Port C is addressed at 0002 and a 1 when Port C is addressed at 0003. When the host writes to the R65C00/21 through Port C, the level of the HRS input is copied into the RSI bit. This bit allows the communications between the host system and the R65C00/21 to flag the type of data being transferred so that command information may be distinguished from data.

Table 4. Register Select Control

| $\begin{gathered} \overline{\mathbf{C S}} \\ \text { (PG3) } \end{gathered}$ | $\begin{aligned} & \text { HRS } \\ & \text { (PG2) } \end{aligned}$ | $\begin{aligned} & \text { HRW } \\ & \text { (PG1) } \end{aligned}$ | $\begin{gathered} \text { Hø12 } \\ \text { (PG0) } \end{gathered}$ | Host Function (6500/6800 Mode) |
| :---: | :---: | :---: | :---: | :---: |
| H | - | - | - | Host Interface Deselected |
| L | L | L | H | Write Input Buffer, HCSR5 RSI cleared, set IBF |
| L | L | H | H | Read Output Buffer, Clear OBF |
| L | H |  | H | Write Input Buffer, HCSR5 RS1 set, set IBF |
| L | H | H | H | Read upper 3 bits of HCSR; OBF, IBF \& RSO |
| $\begin{gathered} \overline{\mathbf{C S}} \\ \text { (PG3) } \end{gathered}$ | $\begin{aligned} & \text { HRS } \\ & \text { (PG2) } \end{aligned}$ | $\begin{aligned} & \hline \overline{\text { HWR }} \\ & \text { (PG1) } \end{aligned}$ | $\begin{aligned} & \overline{\text { HRD }} \\ & \text { (PGO) } \end{aligned}$ | Host Function (8080/Z80 Mode) |
| H | - | - | - | Deselected |
| L | L | L | H | Write Input Buffer, HCSR5 RSI cleared, set IBF |
| L | L | H | L | Read Output Buffer, Clear OBF |
| L | H | L | H | Write Input Buffer, HCSR5 RS1 set, set IBF |
| L | H | H | L | Read upper 3 bits of HCSR; OBF, IBF \& RSO |

Host Control and Status Register (HCSR)


| Bit 7 | Output Buffer Empty (OBE) Flag |
| :---: | :---: |
| 1 | Output Buffer Full |
| 0 | Output Buffer Empty |
| Bit 6 | Input Buffer Full (IBF) Flag |
| 1 | Input Buffer Full |
| 0 | Input Buffer Empty |
| Bit 5 | Register Select |
| - | Distinguishes commands from data. Host reads RSO and R65C00/21 reads RSI. Selection of 1 or 0 to represent commands or data is user defined. |
| Bit 4 | Not Used. (Don't care) |
| Bit 3 | Input/Output Buffer Interrupt Enable |
| 1 | Enable IRQ IBF = 1) |
| 0 | Disable IRQ |
| Bit 2 | Host Interrupt (-INT) Output Enable |
| 1 | Disable HINT Output to Host |
| 0 | Enable HINT Output to Host (OBF = 1) |
| Bit 1 | Host Bus Enable |
| 1 | Disable Host Bus |
| 0 | Enable Host Bus |
| Bit 0 | Host Bus Type |
| 1 | Host Bus is $\mathrm{Z80} / 8080$ |
| 0 | Host Bus is 6500/6800 |

Note:
Register is cleared to all zeros by $\overline{\mathrm{RES}}$.


Figure 10. Host Mode Block Diagam

## EMULATION MODE

The R65C00/21 can operate in an emulation mode under external signal control.

Emulation mode deselects the internal ROM and enables the 16-bit Expanded Bus mode, independent of the bus mode programmed in the Bus Control Register. Since the Expanded Bus mode uses peripheral Ports $D$ and $E$, provision is made for these to be emulated in external hardware. This is accomplished by forcing all memory references to Ports $D$ and $E$ to be External Bus cycles. Accesses to the Data Direction Register for Port D are also forced external.

To further aid program development in emulation mode, all bus cycles which perform a memory or I/O write operation, whether the true destination is internal or external, will assert the External Memory Strobe (EMS) signal. This allows a copy of internal register and memory values to be kept in external memory.

Emulation mode is selected by applying the $\varnothing 2$ output clock signal to the $\overline{\operatorname{RES}}$ input pin.

## INSTRUCTION SET IN ALPHABETIC SEQUENCE

The following table contains a summary of the R65C00/21 and R65C29 CPU instruction set. For detailed information, consult the R6502 Microcomputer System Programming Manual, Order No. 202.

The instructions notated with a * are added instructions for the R65C00/21 and R65C29 which are not part of the standard 6502 instruction set.

Instruction Set in Alphabetic Sequence

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



## 人 $4 \forall W W$ NS $1 \exists S$ NOIIONYLSNI

Dual CMOS Microcomputer/Microprocessor
©

## INSTRUCTION SET OPERATION CODE MATRIX

The following matrix shows the op codes associated with the R65C00/21 and R65C29 CPUs. The matrix identifies the hexadecimal code, the mnemonic code, the addressing mode,
the number of instruction bytes, and the number of machine cycles associated with each op code. Also, refer to the instruction set summary for additional information on these op codes.


I/O PORT WAVEFORMS-ALL PORTS


I/O PORT TIMING-ALL PORTS

| Parameter | Symbol | 2 MHz | 4 MHz | Min | Max |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max |  |  |
| Input Data Setup Time | $\mathrm{T}_{\mathrm{PS}}$ | 50 | - | 35 | - |
| Input Data Hold Time (Port D) | $\mathrm{T}_{\text {PH }}$ | 10 | - | 10 | - |
| Input Data Hold Time (All ports except D) |  | 25 | - | 25 | - |
| Output Data Delay Time | $\mathrm{T}_{\text {PD }}$ | - | 120 | - | 100 |

## EXPANSION BUS TIMING

$V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$

| Parameter | Symbol | $2 \mathrm{MHz}^{*}$ |  | $4 \mathrm{MHz}^{*}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| RW Delay Time | $\mathrm{T}_{\text {RWD }}$ | 20 | 100 | 10 | 80 | ns |
| PE Address Delay Time | $T_{\text {AED }}$ | 20 | 100 | 10 | 80 | ns |
| PD Address Delay Time | $T_{\text {ADD }}$ | 20 | 120 | 10 | 100 | ns |
| PD Address Hold Time-Read | $\mathrm{T}_{\text {ADH }}$ | 0 | 80 | 0 | 60 | ns |
| Data Delay Time - Write | ToDW | - | 120 | - | 100 | ns |
| Data Hold Time - Write | TDHW | 20 | - | 20 | - | ns |
| Data Setup Time-Read | TDSA | 50 | - | 35 | - | ns |
| Data Hold Time-Read | TDHR | 10 | - | 10 | - | ns |
| EMS Delay Time-Address Valid to EMS Low | TEMA | 10 | - | 10 | - | ns |
| EMS Delay Time - $\varnothing 2$ to EMS Low | TEMC | - | 150 | - | 115 | ns |
| EMS Hold Time | TEMH | 10 | - | 10 | - | ns |
| $\varnothing 2$ Cycle Time | TCrC | 500 | - | 250 | - | ns |
| Pulse Width 62 Low | TPWL | 235 | 265 | 115 | 135 | ns |
| Pulse Width 62 High | TPWH | 235 | 265 | 115 | 135 | ns |
| ØA Delay Time- $\varnothing 2$ to $\varnothing$ A | $\mathrm{T}_{2 \mathrm{AD}}$ | 0 | 60 | 0 | 50 | ns |

Note:

* $\varnothing 2$ Frequency


## EXPANSION BUS WAVE FORMS



## MAXIMUM RATINGS*

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

*NOTE: 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.

DC CHARACTERISTICS
$V_{C C}=+5.0 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Parameter | Symbol | Min | Max | Unit | Test Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | +2.0 | - | V |  |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | - | +0.8 | V |  |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | +2.4 | - | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=-100 \mu \mathrm{~A} \end{aligned}$ |
| Input Leakage Current | 1 N | - | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=\mathrm{OV} \text { or } \mathrm{V}_{\mathrm{CC}} . \\ & \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V} \end{aligned}$ |
| Output Low Voltage | VoL | - | +0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\ & \mathrm{~L}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output Low Current <br> (All ports except Port G) | lout | - | -1.6 | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Input Capacitance (XTALO, XTALI) (All Others) | $\mathrm{CIN}_{\text {IN }}$ |  | $\begin{array}{r} 25 \\ 5 \\ \hline \end{array}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \\ & \mathrm{I}=2 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | Cout | - | 10 | pF | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| Operating Frequency Crystal or Master Clock 02 Clock | - | $\begin{aligned} & .02 \\ & .01 \end{aligned}$ | $\begin{aligned} & 8.0 \\ & 4.0 \end{aligned}$ | $\begin{aligned} & \mathrm{MHz} \\ & \mathrm{MHz} \end{aligned}$ |  |
| Power Dissipation | $\mathrm{P}_{\text {D }}$ | - | 40 | mW | $\begin{aligned} & V_{C C}=5 \mathrm{~V} \\ & f=2 \mathrm{MHz} \\ & T_{A}=25^{\circ} \mathrm{C} \end{aligned}$ |

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

## PACKAGE DIMENSIONS



## R65F11 AND R65F12 FORTH BASED MICROCOMPUTERS

## SECTION 1 INTRODUCTION

### 1.1 FEATURES

- FORTH kernel in ROM
- Enhanced 6502 CPU
-Four new bit manipulation instructions:
Set Memory Bit (SMB)
Reset Memory Bit (RMB)
Branch on Bit Set (BBS)
Branch on Bit Reset (BBR)
-Decimal and binary arithmetic modes
-13 addressing modes
-True indexing
- 192-byte static RAM
- 16 bidirectional, TTL-compatible I/O lines (two ports, R65F11) or 40 bidirectional, TTL-compatible I/O lines (five ports, R65F12)
- One 8 -bit port with programmable latched input
- Two 16 -bit programmable counter/timers, with latches
-Pulse width measurement
-Asymmetrical pulse generation
-Pulse generation
-Interval timer
-Event counter
-Retriggerable interval timer
- Serial port
-Full-duplex asynchronous operation mode
-Selectable 5 - to 8 -bit characters
-Wake-up feature
-Synchronous shift register mode
-Standard programmable bit rates, programmable up to 62.5 K bits/sec
- Ten interrupts
-Four edge-sensitive lines; two positive, two negative
-Reset
-Non-maskable
- Two counter
-Serial data received
-Serial data transmitted
- Expandable to 16 K bytes of external memory
- Flexible clock circuitry
$-2-\mathrm{MHz}$ or $1-\mathrm{MHz}$ internal operation
-Internal clock with external XTAL at two times internal frequency
-External clock input divided by one or two
- $1 \mu \mathrm{~s}$ minimum instruction execution time @ 2 MHz
- NMOS silicon gate, depletion load technology
- Single +5 V power supply
- 12 mW standby power for 32 bytes of the 192-byte RAM
- 40-pin DIP (R65F11)
- 64-pin QUIP (R65F12) has three additional 8-bit I/O ports to provide a total of 40 I/O lines.


### 1.2 SUMMARY

The Rockwell R65F11 and R65F12 are complete, high-performance, 8-bit NMOS single chip microcomputers, and are compatible with all members of the R6500 family.

The kernel of the high level Rockwell Single Chip RSC-FORTH language is contained in the preprogrammed ROM of the R65F11 and R65F12. RSC-FORTH is based on the popular fig-FORTH model with extensions. All of the run time functions of RSCFORTH are contained in the ROM, including 16- and 32-bit mathematical, logical and stack manipulation, plus memory and input/output operators. The RSC-FORTH Operating System allows an external user program written in RSC-FORTH or Assembly Language to be executed from external EPROM, or development of such a program under the control of the R65FR1 RSC-FORTH Development ROM. Other development ROM's can also be accommodated.

The R65F11 and R65F12 consist of an enhanced 6502 CPU, an internal clock oscillator, 192 bytes of Random Access Memory (RAM) and versatile interface circuitry. The interface circuitry includes two 16 -bit programmable timer/counters, 16 bidirectional input/output lines (including four edge-sensitive lines and input latching on one 8 -bit port), a full-duplex serial VO channel, ten interrupts and bus expandability.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of
computational power. These features in combination with the FORTH high level operating system make the R65F11 and R65F12 ideal for microcomputer applications.

For systems requiring additional I/O ports, the 64-pin QUIP version, the R65F12, provides three additional 8-bit ports.

A complete RSC-FORTH development system can be created with three MOS parts: the R65F11, one RAM chip and the R65FR1 Development ROM.

This product description is for the reader familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual
(Order Number 201). A description of the instruction capabilites of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Order Number 202).

### 1.3 ORDERING INFORMATION

| Part No. | Description |  |
| :--- | :--- | :---: |
| R65F11P | 40-Pin FORTH Based Microcomputer at 1 MHz |  |
| R65F11AP | 40-Pin FORTH Based Microcomputer at 2 MHz |  |
| R65F12Q | 64-Pin FORTH Based Microcomputer at 1 MHz |  |
| R65F12AQ | 64-Pin FORTH Based Microcomputer at 2 MHz |  |
| R65FR1P | FORTH Development ROM for R65F11 or R65F12 |  |
| R65FR2P | FORTH Development ROM for expanded capacity |  |
| R65FK2P | FORTH Kernel ROM for expanded capacity <br> development |  |
| R65FR3P | FORTH Development ROM for R6501Q <br> R65FK3P <br> FORTH Kernel ROM for R6501Q |  |
| Order No. | Description |  |
| 2148 | FORTH Based Microcomputer User's Manual* |  |
| Note: |  |  |
| *Included with R65FR1. |  |  |

## SECTION 2 INTERFACE REQUIREMENTS

This section describes the interface requirements for the R65F11 and R65F12 single chip microcomputers. Figure 2-1 is the Interface Diagram for the R65F11 and R65F12, Figure 2-2 shows the pin out configuration and Table 2-1 describes the function of each pin of the R65F11 and R65F12. Figure 3-1 is a detailed block diagram.


MUTTPLEXED FUNCTION PNS

Figure 2-1. R65F11 and R65F12 Interface Diagram

Table 2-1. R65F11 and R65F12 Pin Descriptions

| Signal Name | Pin No. R65F11 | Pin No. R65F12 | Description |
| :---: | :---: | :---: | :---: |
| VCc | 21 | 50 | Main power supply +5V |
| $V_{\text {RR }}$ | 39 | 12 | Separate power pin for RAM. In the event that $\mathrm{V}_{\mathbf{C c}}$ power is lost, this power retains RAM data. |
| $\mathbf{V}_{\mathbf{S s}}$ | 40 | 11 | Signal and power ground (0V) |
| XTLI | 2 | 10 | Crystal or clock input for internal clock oscillator. Also allows input of X1 clock signal if XTLO is connected to $\mathbf{V}_{\text {SS, }}$ or X 2 or $\mathrm{X}_{4}$ clock if XTLO is floated. |
| XTLO | 1 | 9 | Cystal output from internal clock oscillator. |
| $\overline{R E S}$ | 20 | 41 | The Reset input is used to initialize the R65F11. This signal must not transition from low to high for at least eight cycles after $V_{\text {cc }}$ reaches operating range and the internal oscillator has stabilized. |
| \$2 | 3 | 13 | Clock signal output at internal frequency. |
| $\overline{\text { NMI }}$ | 22 | 51 | A negative going edge on the Non-Maskable Interrupt signal requests that a nonmaskable interrupt be generated within the CPU. |
| PAO-PA7 P80-PB7 | $\begin{aligned} & 30-23 \\ & 38-31 \end{aligned}$ | $\begin{gathered} 57-64 \\ 1-8 \end{gathered}$ | Two 8-bit ports used for either input/output. Each line of Ports A and B consist of an active transistor to $V_{\text {ss }}$ and a passive pull-up to $V_{c c}$. |
| $\begin{aligned} & \text { PCO-PC7 } \\ & \text { A0-A3 } \\ & \mathrm{A} 12, \mathrm{R} \bar{W} \\ & \mathrm{~A} 13, \mathrm{EMS} \end{aligned}$ | 4-11 | 25-32 | Port C has an active pull-up transistor. Port D has active pull-up and pull-down transistors. Ports C and D lines form the external multiplexed |
| $\begin{aligned} & \text { PD0-PD7 } \\ & \text { A4-A11 } \\ & \text { D0-D7 } \end{aligned}$ | 19-12 | $33-40$ | address and data bus to allow external memory addressing. |
| $\begin{aligned} & \text { PEO-PE7 } \\ & \text { PFO-PF7 } \\ & \text { PGO-PG7 } \end{aligned}$ |  | $\begin{aligned} & 42-49 \\ & 24-17 \\ & 14-16, \\ & 52-56 \end{aligned}$ | On the R65F12, Port E may be used for output only. Ports F and G are similar to Ports $A$ and $B$ in construction and may be used for inputs or outputs. |


aigure 2-2. Pin Out Configuration

## SECTION 3 SYSTEM ARCHITECTURE

This section provides a functional description of the R65F11 and R65F12. Functionally the R65F11 consists of a CPU, RAM memory, two 8 -bit parallel I/O ports (five in the 64-pin R65F12), a serial I/O port, dual counter/latch circuits, a mode control register, an interrupt flag/enable dual register circuit, and an internal Operating System. The kernet of FORTH in ROM complements the system hardware. A block diagram of the system is shown in Figure 3-1.

## NOTE

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

### 3.1 CPU LOGIC

The R65F11 internal CPU is a standard 6502 configuration with an 8-bit Accumulator register, two 8-bit Index Registers ( X and Y ); an 8-bit Stack Pointer register, and ALU, a 16-bit Program Counter, and standard instruction register/decode and internal timing control logic.

### 3.1.1 Accumulator

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

### 3.1.2 Index Registers

There are two 8-bit index registers, $X$ and $Y$. Each index register can be used as a base to modity the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

### 3.1.3 Stack Pointer

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal $\overline{\mathbb{R Q}}$ internupt, or the external interrupt line $\overline{\text { NMI. The Stack Pointer must be initialized by }}$ the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may only be accessed from the top. The address of a memory location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1 . Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus, and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 00FF-0040. After reset, which leaves the Stack Pointer indeterminate, normal usage calls for its initialization at OOFF.

### 3.1.4 Processor Status Register

The 8-bit Processor Status Register contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6500 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. See Appendix B for details.

### 3.1.5 Program Counter

The 16-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter ( PCH ) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

### 3.1.6 Arithmetic And Logic Unit (ALU)

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

### 3.1.7 Instruction Register and Instruction Decode

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register then decoded along with timing and interrupt signals to generate control signals for the various registers.


Figure 3-1. Detailed Block Diagram

### 3.1.8 Timing Control

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to TO each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.

### 3.1.9 Interrupt Logic

Interrupt logic controls the sequencing of three interrupts; $\overline{R E S}, \overline{N M I}$ and IRQ. $\overline{\operatorname{RQQ}}$ is generated by any one of eight conditions: 2 Counter Overflows, 2 Positive Edge Detects, 2 Negative Edge Detects, and 2 Serial Port Conditions.

### 3.2 CPU INSTRUCTION SET

The machine code instruction set of the R65F11 and R65F12 microcomputers are based on the popular R6500 microprocessor set. They contain all the instructions in the standard R6502 set, with the addition of the four new bit instructions added to the R6511 processor family. Refer to Appendix A for the Op Code mnemonics addressing matrix for details on these instructions.

### 3.3 READ-ONLY-MEMORY (ROM)

The ROM consists of preprogrammed memory with an address space from F400 to FFFF. It contains the run time kernel of the high level language Rockwell Single Chip FORTH. There are 133 included functions stored in the ROM. Codes are in the format of a two byte code field, which identifies the interpreter assigned to execute that word, followed by a variable length Parameter Field, which contains the instructions and data used by that interpreter according to the programmed intention of that definition. See Appendix D for a complete list of the names of all included words. All words needed for support of the run time operation of dedicated applications programs are included. The RSC-FORTH Operating System is also part of the ROM code and is entered upon Reset. This Operating System allow the R65F11 and R65F12 to auto start a user program written in either RSC-FORTH or Assembly Language or enter a Development ROM if one is present. If no auto start program is found, an attempt will be made to boot an operating program from floppy disk.

### 3.4 RANDOM ACCESS MEMORY (RAM)

The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The R65F11 and R65F12 provide a separate power pin ( $\mathrm{V}_{\mathrm{RR}}$ ) which may be used for standby power for 32 bytes located at $0040-005 \mathrm{~F}$. In the event of the loss of $\mathrm{V}_{\mathrm{cc}}$ power, the lowest 32 bytes of RAM data will be retained if standby power is supplied to the $V_{\text {RR }}$ pin. If the RAM data retention is not required then $V_{\text {RR }}$ must be connected to $V_{\text {Cc }}$. During operation $V_{R R}$ must be at the $V_{C C}$ level.

For the RAM to retain data upon loss of $V_{C C}, V_{R R}$ must be supplied within operating range and RES must be driven low at least eight $\phi 2$ clock pulses before $V_{c c}$ falls out of operating range. $\overline{\text { RES }}$ must then be held low while $V_{c c}$ is out of operating range and until at least eight $\emptyset 2$ clock cycles after $V_{C C}$ is again within operating range and the internal $\phi 2$ oscillator is stabilized. $\mathrm{V}_{\text {RR }}$ must remain within $\mathrm{V}_{\mathrm{CC}}$ operating range during normal operation. When $V_{\mathrm{Cc}}$ is out of operating range, $V_{R R}$ must remain within the $V_{R R}$ retention range in order to retain data. Figure 3-2 shows typical waveforms.


### 3.5 CLOCK OSCILLATOR

A reference frequency can be generated with the on-chip oscillator using an external crystal. The oscillator reference frequency passes through an internal countdown network (divide by 2) to obtain the internal operating frequency (see Figure 3-3a).

Internal timing can also be controlled by driving the XTLI pin with an external frequency source. Figure 3-3b shows typical connections. If XTLO is left floating, the external source is divided by the internal countdown network. However, if XTLO is tied to $V_{S s}$, the internal coundown network is bypassed causing the chip to operate at the frequency of the external source.

The R65F11 and R65F12 operate in the CLOCK MASTER mode. In this mode a frequence source (crystal or external source) must be applied to the XTLI and XTLO pins.

NOTE: When operating at a 1 MHz internal frequency place a 15-22 pt capacitor between XTLO and GND.
©2 is a buffered output signal which closely approximates the internal timing. When a common external source is used to drive multiple devices the internal timing between devices as well as their 02 outputs will be skewed in time. If skewing represents a system problem it can be avoided by the Master/Slave connection and options shown in Figure 3-4.

The R65F11 and R65F12 is operated in the CLOCK MASTER MODE. A second processor could be operated in the CLOCK

SLAVE MODE. Mask options in the SLAVE unit convert the $\$ 2$ signal into a clock input pin which is tightly coupled to the internal timing generator. As a result the internal timing of the MASTER and SLAVE units are synchronized with minimum skew. If the $\varnothing 2$ signal to the SLAVE unit is inverted, the MASTER and SLAVE UNITS WILL OPERATE OUT OF PHASE. This approach allows the two devices to share external memory using cycle stealing techniques.


Figure 3-3. Clock Oscillator Input Options


Figure 3-4. Master/Slave Connections

### 3.6 MODE CONTROL REGISTER (MCR)

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for Counter A and Counter B. Its setting, along with the setting of the Serial Communications Control Register (SCCR), determines the basic configuration of the R65F11 and R65F12 in any application. The Mode Control Register bit assignment is shown in Figure 3-5. MCR Bits 7, 6,5 must remain 1's in order for external memory referencing to be enabled.


Figure 3-5. Mode Control Register

The use of Counter A Mode Select is shown in Section 6.1.
The use of Counter B Mode Select is shown in Section 6.2.
The use of Port B Latch Enable is shown in Section 4.4.

### 3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)

An IRQ interrupt request can be initiated by any or all of eight possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple simultaneous interrupts will cause the $\overline{\mathrm{RQ}}$ interrupt request to remain active until all interrupting conditions have been serviced and cleared.

The Interrupt Flag Register contains the information that indicates which VO or counter needs attention. The contents of the Interrupt Flag Register may be examined at any time by reading at address: 0011. Edge detect IFR bits may be cleared in low level code by executing a RMB instruction at address location 0010. The RMB X; (0010) instruction reads FF, modifies bit $X$ to a " 0 ", and writes the modified value at address location 0011. In this way IFR bits set to a "1" after the read cycle of a Read-Modify-Write instruction (such as RMB) are protected from being cleared. A logic " 1 " is ignored when writing to edge detect IFR bits.

Each IFR bit has a corresponding bit in the Interrupt Enable Register which can be set to a "1" by writing a "1" in the respective bit position at location 0012. Individual IER bits may be cleared by writing a " 0 " in the respective bit position, or by $\overline{\text { EES }}$. If set to a " 1 ", an IRQ will be generated when the corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 3-6 and the functions of each bit are explained in Table 3-1.


Figure 3-6. Interrupt Enable and Fiag Registers

Table 3-1. Interrupt Flag Register Bit Codes


### 3.8 OPERATING SYSTEM

The system startup function, COLD, is executed upon Reset. COLD, a high level FORTH word, forms the basis of the RSC Operating System. Upon reset this function initializes the R65F11 or R65F12 registers to establish the external 16K byte memory map and disable all interrupt sources. It also sets up the serial channel for 1200 baud (assuming a 1 MHz internal clock) asynchronous transmission (seven bits, parity disabled). The internal FORTH structure "W" is prepared for use and the low level input/output vectors are forced to point to the system serial channel routines. The FORTH User Area Pointer, UP, is assigned the value 0300 Hex.

A test is made of the variable CLD/WRM in memory location O30E. If this contains a value other than A55A Hex a cold reset is assumed. In this case, the low level IRQ vector, IRQVEC; the low level NMI Vector, NMIVEC, and the high level interrupt vector, INTVEC, are all forced to point to the system reset routine. This prevents an unintentionally generated interrupt from crashing the system. System variables TIB, RO, SO, UC/L, UPAD, UR/W and BASE are also initialized to their default values.

Whether a warm or cold reset, the memory map is then searched at every 1K byte boundary starting at location 0400 Hex. The first two bytes at each boundary are checked against an A55A Hex bit pattern. This pattern indicates that an auto start program is installed. The next two bytes are assumed to point to the Parameter Field of the high level RSC-FORTH word to be executed upon reset. This may be the main function of a user defined program or the start up routine of a Development ROM. Figure 3-7 details proper alignment.

If no auto start ROM is found, the Operating System turns control over to a program that issues a "NO ROM" message to the systems terminal via the serial channel and attempts to boot a program from disk. A floppy disk controller, compatible with the WD1793 type, is assumed to be present at address 0100 Hex. The first half of Track 0 Sector 1 is loaded from a double density boot diskette into RAM starting at address 005F. When successfully loaded execution will be turned over to this boot program.


Figure 3-7. Auto Start ROM

# SECTION 4 PARALLEL INPUT/OUTPUT PORTS 

The R65F11 has 16 VO lines grouped into two 8-bit ports (PA, PB) and 16 lines programmed as an Address/Data bus (PC \& PD). Ports A and B may be used either for input or output individually or in groups of any combination. The R65F12 has 24 additional port lines grouped into three 8-bit ports (PE, PF, PG).

Multifunction l/O's such as Port A are protected from normal port I/O instructions when they are programmed to perform a multiplexed function.

Internal pull-up resistors (FET's with an impedance range of $3 \mathrm{~K} \leqslant \mathrm{Rpu} \leqslant 12 \mathrm{~K}$ ohm) are provided on all port pins.

The direction of the VO lines are controlled by 8 -bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, which simplifies I/O handling. The VO addresses are shown in Table 4-1.

Table 4-1. I/O Port Addresses

| Port | Address |
| :---: | :---: |
| A | 0000 |
| B | 0001 |
| E | 0004 |
| F | 0005 |
| G | 0006 |

Appendix F. 4 shows the I/O Port Timing.

### 4.1 INPUTS

Inputs for Ports A and B are enabled by loading logic 1 into all VO port register bit positions that are to correspond to VO input lines. A low ( $<0.8 \mathrm{~V}$ ) input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high ( $>2.0 \mathrm{~V}$ ) input will cause a logic 1 to be read. An $\overline{R E S}$ signal forces all VO port registers to logic 1 thus initially treating all I/O lines as inputs.

The status of the input lines can be interrogated at any time by reading the VO port addresses. Note that this will return the actual status of the input lines, not the data written into the VO port registers.

Read/Modify/Write instructions can be used to modify the operation of PA and PB. During the Read cycle of a Read/ Modify/Write instruction the Port VO register is read. For all other read instructions the port input lines are read. Read/ Modify/Write instructions are: ASL, DEC, INC, LSR, RMB, ROL, ROR, and SMB.

### 4.2 OUTPUTS

Outputs for Ports A and B are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( $>2.4 \mathrm{~V}$ ) output while a logic 0 will force a low ( $<0.4 \mathrm{~V}$ ) output.

### 4.3 PORT A (PA)

Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as a standard parallel 8-bit, bit independent, V/O port or as serial channel VO lines, counter VO lines, or an input data strobe for the Port B input latch option. Table 4-3 tabulates the control and usage of Port $A$.

In addition to their normal I/O functions, PAO and PA1 can detect positive going edges, and PA2 and PA3 can detect negative going edges. A proper transition on these pins will set a corresponding status bit in the IFR and generate an interrupt request if the respective Interrupt Enable Bit is set. The maximum rate at which an edge can be detecte $d$ is onehalf the $\$ 2$ clock rate. Edge detection timing is shown in Appendix F.4.

### 4.4 PORT B (PB)

Port B can be programmed as an 8 bit, bit independent I/O port. It has a latched input capability which may be enabled or disabled via the Mode Control Register (MCR). Table 4-2 tabulates the control and usage of Port B. An Input Data Strobe signal must be provided thru PAO when Port B is programmed to be used with latched input option. Input data latch timing for Port B is shown in Appendix F.4.

Table 4-2. Port B Control \& Usage

| $\begin{aligned} & \text { Pin } \\ & \text { No. } \\ & \text { R65F11 } \end{aligned}$ | $\begin{gathered} \text { Pin } \\ \text { No. } \\ \text { R65F12 } \end{gathered}$ | I/O Mode |  | Latch Mode |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MCR4 $=0$ |  | $\text { MCR4 }=1$ <br> (2) |  |
|  |  | Signal |  | Signal |  |
|  |  | Name | Type (1) | Name | Type |
| 38 | 8 | PBO | I/O | PBO | INPUT |
| 37 | 7 | PB1 | 1/0 | PB1 | INPUT |
| 36 | 6 | PB2 | I/O | PB2 | INPUT |
| 35 | 5 | PB3 | 1/0 | PB3 | INPUT |
| 34 | 4 | PB4 | $1 / 0$ | PB4 | INPUT |
| 33 | 3 | PB5 | $1 / 0$ | PB5 | INPUT |
| 32 | 2 | PB6 | 1/0 | PB6 | INPUT |
| 31 | 1 | PB7 | $1 / 0$ | PB7 | INPUT |

[^8]Table 4-3. Port A Control and Usage


### 4.5 PORT C (PC)

Port C is preprogrammed as part of the Address/Data bus. PC0-PC7 function as A0-A3, A12, R/W, A13, and EMS, respectively, as shown in Table 4-4. EMS (External Memory Select) is asserted (low) whenever the internal processor accesses memory area between 0100 and 3FFF. (See Memory Map, Appendix C). The leading edge of EMS may be used to strobe the eight address lines multiplexed on Port D. See Appendix F. 3 for Port C timing.

### 4.6 PORT D (PD)

Port $[$ is also preprogrammed as part of the Address/Data bus. Data bits DO through D7 are time multiplexed with address bits A4 through A11, respectively. Refer to the Memory Maps (Appendix C) for Multiplexed memory assignments. See Appendix F. 3 for Port D timing.

### 4.7 PORT E (PE), PORT F (PF), PORT G (PG)

Ports E, F and G are available on the R65F12 only. Port E can only be used as outputs. Port F and Port G can be used for inputs or outputs and are similar to Port A and Port B in operation.

Table 4-4. Port C Control and Usage


Table 4-5. Port D Control and Usage

| R65F11/ R65F12 Port | Multiplexed Mode |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=1 \\ & \text { MCR5 }=1 \end{aligned}$ |  |  |  |
|  | Signal |  | Signal |  |
|  | Phase 1 |  | Phase 2 |  |
|  | Name | Type (2) | Name | Type (3) |
| PDO | A4 | OUTPUT | DATA0 | 1/0 |
| PD1 | A5 | OUTPUT | DATA1 | 1/0 |
| PD2 | A6 | OUTPUT | DATA2 | 1/0 |
| PD3 | A7 | OUTPUT | DATA3 | 1/0 |
| PD4 | A8 | OUTPUT | DATA4 | 1/0 |
| PD5 | A9 | OUTPUT | DATA5 | 1/0 |
| PD6 | A10 | OUTPUT | DATA6 | 1/0 |
| PD7 | A11 | OUTPUT | DATA7 | $1 / 0$ |

(1) Active Buffer Pull-up and Pull-Down
(2) Tri-State Buffer is in Active Mode
(3) Tri-State Buffer is in Active Mode only during the Phase 2 Portion of a Write Cycle

# SECTION 5 <br> SERIAL INPUT/OUTPUT CHANNEL 

The R65F11 and R65F12 Microcomputers provide a full duplex Serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 5-1. The serial bit rate is determined by Counter A for all modes except the Receiver Shift Register (RCVR S/R) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5 K bits per second (@ $\varnothing 2$ $=1 \mathrm{MHZ}$ ). The transmitter (XMTR) and receiver (RCVR) can be independently programmed to operate in different modes and can be independently enabled or disabled.


Figure 5-1. Serial Communication Control Register
Except for the Receiver Shift Register Mode (RCVR S/R), all XMTR and RCVR bit rates will occur at one sixteenth of the Counter A interval timer rate. Counter $A$ is forced into an interval timer mode whenever the serial $I / O$ is enabled in a mode requiring an internal ctock.

Whenever Counter $\mathbf{A}$ is required as a timing source it must be loaded with the hexadecimal code that selects the data rate for the serial I/O Port. Refer to Counter A (paragraph 6.1) for a table of hexadecimal values to represent the desired data rate.

### 5.1 TRANSMITTER OPERATION (XTMR)

The XTMR operation and the transmitter related control/ status functions are enabled by bit 7 of the Serial Communications Control Register (SCCR). The transmitter, when in the Asynchronous (ASYN) mode, automatically adds a start bit, one or two stop bits, and, when enabled, a parity bit to the transmitted data. A word of transmitted data (in asynchronous parity mode) can have $5,6,7$, or 8 bits of data. The nine data modes are shown below. When parity is disabled, the $5,6,7$ or 8 bits of data are terminated with two stop bits.


Figure 5-2. Bit Allocations
In the S/R mode, eight data bits are always shifted out. Bits/ character and parity control bits are ignored. The serial data is shifted out via the SO output (PA6) and the shift clock is available at the CA (PA4) pin. When the transmitter underruns in the S/R mode the SO output and shift clock are held in a high state.

The XMTR Interrupt Flag bit (IFR7) is controlled by Serial Communication Status Register bits SCCR5, SCCR6 and SCCR7.

$$
\text { IFR7 }=\text { SCSR6 }(\overline{\text { SCCR5 }}+\text { SCCR7 })
$$

### 5.2 RECEIVER OPERATION (RCVR)

The receiver and its selected control and status functions are enabled when SCCR-6 is set to a "1." In the ASYN mode, data format must have a start bit, appropriate number of data bits, a parity bit (if enabled) and one stop bit. Refer to Figure $5-2$ for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start bit and a strobe signal is generated at the approximate center of each incoming bit. Refer to Figure 5-3 for ASYN Receive Data Timing. The character assembly process does not start if the start bit signal is less than one-half the bit time after a low level is detected on the Receive Data Input. Framing error, over-run, and parity error conditions or a RCVR Data Register Full will set the appropriate status bits, and any of the above conditions will cause an Interrupt Request if the Receiver Interrupt Enable bit is set to logic 1.


Figure 5-3. ASYN Receive Data Timing
In the S/R mode, an external shift clock must be provided at CA (PA4) pin along with 8 bits of serial data (LSB first) at the SI input (PA7). The maximum data rate using an external shift clock is one-eighth the internal clock rate. Refer to Figure 5-4 for S/R Mode Timing.


Figure 5-4. S/R Mode Timing
A RCVR interrupt (IFR6) is generated whenever any of SCSRO-3 are true.

### 5.3 SERIAL COMMUNICATION STATUS REGISTER (SCSR)

The Serial Communication Status Register (SCSR) holds information on various communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 5-5. Bit assignments and functions of the SCSR are as follows:

SCSR 0: Receiver Data Register Full-Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by $\overline{\text { RES }}$ and is disabled if SCCR $6=0$. The SCSR 0 bit will not be set to a logic 1 if the received data contains an error condition, however, a corresponding error bit will be set to a logic 1 instead.

SCSR 1: Over-Run Error-Set to a logic 1 when a new character is transferred from the Receiver Shift Register, with the last character still in the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by $\overline{\mathrm{RES}}$.

SCSR 2: Parity Error-Set to logic 1 when the RCVR is in the ASYN Mode, Parity Enable bit is set, and the
received data has a parity error. This bit is cleared by reading the Receiver Data Register or by $\overline{\text { RES }}$.
SCSR 3: Framing Error-Set to a logic 1 when the received data contains a zero bit after the last data or parity bit in the stop bit slot. Cleared by reading the Receiver Data Register or by $\overline{\text { RESS }}$. (ASYN Mode only).
SCSR 4: Wake-Up-Set to a logic 1 by writing a "1" in bit 4 of address: 0016. The Wake-Up bit is cleared by $\overline{\text { RES }}$ or when the receiver detects a string of ten consecutive 1 's. When the Wake-Up bit is set SCSRO through SCSR3 are inhibited.
SCSR 5: End of Transmission-Set to a logic 1 by writing a " 1 " in bit position 5 of address: 0016. The End of Transmission bit is cleared by RES or upon writing a new data word into the Transmitter Data Register. When the End-of-Transmission bit is true the Transmitter Register Empty bit is disabled until a Transmitter Under-Run occurs.
SCSR 6: Transmitter Data Register Empty-Set to a logic 1 when the contents of the Transmitter Data Register is transferred to the Transmitter Shift Register. Cleared upon writing new data into the Transmit Data Register. This bit is initialized to a logic 1 by $\overline{\text { RES }}$.
SCSR 7: Transmitter Under-Run-Set to a logic 1 when the last data bit is transmitted if the transmitter is in a S/R Mode or when the last stop bit is transmitted if the XMTR is in the ASYN Mode while the Transmitter Data Register Empty Bit is set. Cleared by a transfer of new data into the Transmitter Shift Register, or by RES.


Figure 5-5. SCSR Bit Allocations

### 5.4 WAKE-UP FEATURE

In a multi-distributed microprocessor or microcomputer applications, a destination address is usually included at the beginning of the message. The Wake-Up Feature allows non-selected CPU's to ignore the remainder of the message until the beginning of the next message by setting the WakeUp bit. As long as the Wake-Up flag is true, the Receiver Data Register Full Flag remains false. The Wake-Up bit is automatically cleared when the receiver detects a string of ten consecutive 1's which indicates an idle transmit line. When the next byte is received, the Receiver Data Register Full Flag signals the CPU to wake-up and read the received data.

# SECTION 6 COUNTER/TIMERS 

The R65F11 and R65F12 Microcomputers contain two 16-bit counters (Counter A and Counter B) and three 16-bit latches associated with the counters. Counter $A$ has one 16 -bit latch and Counter B has two 16-bit latches. Each counter can be independently programmed to operate in one of four modes:

## Counter A

- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Counter


## Counter B

- Retriggerable Interval Counter
- Asymmetrical Pulse Generation
- Interval Timer
- Event Counter

Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4.2).

### 6.1 COUNTER A

Counter A consists of a 16 -bit counter and a 16 -bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contains the count of either $\emptyset 2$ clock pulses or external events, depending on the counter mode selected. The contents of Counter A may be read any time by executing a read at location 0019 for the Upper Counter A and at location 001A or location 0018 for the Lower Counter A. A read at location 0018 also clears the Counter A Underflow Flag (IFR4).

The 16-bit latch contains the counter initialization value, and can be loaded at any time by executing a write to the Upper Latch A at location 0019 and the Lower Latch $A$ at location 0018. In either case, the contents of the accumulator are copied into the applicable latch register.

Counter A can be started at any time by writing to address: 001A. The contents of the accumulator will be copied into the


Figure 6-1. Interval Timer Timing Diagram

Upper Latch $A$ before the contents of the 16 -bit latch are transferred to Counter $A$. Counter $A$ is set to the latch value whenever Counter $A$ underflows. When Counter $A$ decrements from 0000 the next counter value wil! be the latch value, not FFFF, and the Counter A Underflow Flag (IFR 4) will be set to " 1 ". This bit may be cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by $\overline{R E S}$.

Counter A operates in any of four modes. These modes are selected by the Counter A Mode Control bits in the Control Register. See Table 6-1.

Table 6-1. Counter A Control Bits

| MCR1 <br> (bit 1) | MCRO <br> (bit 0) | Mode |
| :---: | :---: | :--- |
| 0 | 0 | Interval Timer |
| 0 | 1 | Pulse Generation |
| 1 | 0 | Event Counter |
| 1 | 1 | Pulse Width Measurement |

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

The Counter is set to the Interval Timer Mode (00) when a $\overline{R E S}$ signal is generated.

### 6.1.1 Interval Timer

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:

1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the $\varnothing 2$ clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore $1 \mu \mathrm{~s}$ to 65535 ms at the $1 \mathrm{MHz} \emptyset 2$ clock rate or $0.5 \mu \mathrm{~s}$ to 32.767 ms at the $2 \mathrm{MHz} \phi 2$ clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting $\overline{\mathrm{IRQ}}$ interrupt requests in the counter $\overline{\mathrm{RQ}}$ interrupt routine.

When Counter A decrements from 0000, the Counter A Underflow (IFR4) is set to logic 1 . If the Counter A Interrupt Enabie Bit (IER4) is also set, an $\overline{\operatorname{RQ} Q}$ interrupt request will be generated. The Counter A Underflow bit in the Interrupt Flag Register can be examined in the $\overline{\mathrm{RQ}}$ interrupt routine to determine that the $\overline{\mathrm{RQ}}$ was generated by the Counter $A$ Underflow.

While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.

### 6.1.2 Pulse Generation Mode

In the Pulse Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs, or a write is performed to address 001 A .

The normal output waveform is a symmetrical square-wave. The. CA output is initialized high when entering the mode and transitions low when writing to 001A.

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

### 6.1.3 Event Counter Mode

In this mode the CA is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the $\phi 2$ clock rate.

The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter A Underflow bit (IER4) is set to logic 1 if the underflow occurs.

Figure 6.2 is a timing diagram of the Event Counter Mode.


Figure 6-2. Event Counter Mode

### 6.1.4 Pulse Width Measurement Mode

This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the $\phi 2$ clock rate as long as the CA line is held in the low state. The Counter is stopped when CA is in the high state.

The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4.

A timing diagram for the Pulse Width Measurement Mode is shown in Figure 6-3.


Figure 6-3. Pulse Width Measurement

### 6.1.5 Serial I/O Data Rate Generation

Counter A also provides clock timing for the Serial I/O which establishes the data rate for the Serial I/O port. When the Serial $1 / O$ is enabled, Counter $A$ is forced to operate at the internal clock rate. Counter A is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4-2).

Table 6-2 identifies the values to be loaded in Counter A for selecting standard data rates with a $\phi 2$ clock rate of 1 MHz and 2 MHz . Although Table $6-2$ identifies only the more common data rates, any data rate from 1 to 62.5 K bps can be selected by using the formula:

$$
N=\frac{\phi 2}{16 \times b p s}-1
$$

where

$$
\begin{aligned}
\mathrm{N} \quad= & \text { decimal value to be loaded into Counter } A \text { using } \\
& \text { its hexadecimal equivalent. } \\
\phi 2 \quad= & \text { the clock frequency }(1 \mathrm{MHz} \text { or } 2 \mathrm{MHz}) \\
\mathrm{bps}= & \text { the desired data rate. }
\end{aligned}
$$

## NOTE

In Table 6-2 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of $1.5 \%$ or less are acceptable. A revised clock rate is included in Table $6-2$ for those baud rates which fall outside this limit.

Table 6-2. Counter A Values för Baud Rate Selection

| Standard Baud Rate | Hexadecimal Value |  | Actual Baud Rate At |  | Clock Rate Needed To Get Standard Baud Rate |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1 MHz | 2 MHz | 1 MHz | 2 MHz | 1 MHz | 2 MHz |
| 50 | 04E1 | 09C3 | 50.00 | 50.00 | 1.0000 | 2.0000 |
| 75 | 0340 | 0682 | 75.03 | 74.99 | 1.0000 | 2.0000 |
| 110 | 0237 | 046F | 110.04 | 110.04 | 1.0000 | 2.0000 |
| 150 | 01A0 | 0340 | 149.88 | 150.06 | 1.0000 | 2.0000 |
| 300 | 00CF | 0140 | 300.48 | 299.76 | 1.0000 | 2.0000 |
| 600 | 0067 | 00CF | 600.96 | 600.96 | 1.0000 | 2.0000 |
| 1200 | 0033 | 0067 | 1201.92 | 1201.92 | 1.0000 | 2.0000 |
| 2400 | 0019 | 0033 | 2403.85 | 2403.85 | 1.0000 | 2.0000 |
| 3600 | 0010 | 0021 | 3676.47 | 3676.47 | 0.9792 | 1.9584 |
| 4800 | 000C | 0019 | 4807.69 | 4807.69 | 1.0000 | 2.0000 |
| 7200 | 0008 | 0010 | 6944.44 | 7352.94 | 1.0368 | 1.9584 |
| 9600 | 0006 | 000C | 8928.57 | 9615.38 | 1.0752 | 2.0000 |

### 6.2 COUNTER B

Counter B conssists of a 16-bit counter and two 16-bit latches organized as follows: Lower Counter B (LCB), Upper Counter B (UCB), Lower Latch B (LLB), Upper Latch B (ULB), Lower Latch C (LLC), and Upper Latch C (ULC). Latch C is used only in the asymmetrical pulse generation mode. The counter contains the count of either ${ }_{0}$ clock pulses or external events depending on the counter mode selected. The contents of Counter B may be read any time by executing a read at location 001D for the Upper Counter B and at location 001 E or 001C for the Lower Counter B. A read at location 001 C also clears the Counter B Underflow Flag.

Latch B contains the counter initialization value, and can be loaded at any time by executing a write to the Upper Latch $B$ at location 001D and the Lower Latch B at location 001C. In each case, the contents of the accumulator are copied into the applicable latch register.

Counter B can be initialized at any time by writing to address: 001 E . The contents of the accumulator is copied into the Upper Latch B before the value in the 16 -bit Latch B is transferred to Counter $B$. Counter B will also be set to the latch value and the Counter B Underflow Flag bit (IFR5) will be set to a " 1 " whenever Counter $B$ underflows by decrementing from 0000.

IFR 5 may be cleared by reading the Lower Counter B at location 001C, by writing to address location 001 E , or by $\overline{\text { RES. }}$

Counter B operates in the same manner as Counter $A$ in the Interval Timer and Event Counter modes. The Pulse Width Measurement Mode is replaced by the Retriggerable Interval Timer mode and the Pulse Generation mode is replaced by the Asymmetrical Pulse Generation Mode.

### 6.2.1 Retriggerable Interval Timer Mode

When operating in the Retriggerable Interval Timer mode, Counter B is initialized to the latch value by writing to address 001E, by a Counter B underflow, or whenever a positive edge
occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the CB line. Figure 6-4 illustrates the operation.


Figure 6-4. Counter B. Retriggerable Interval Timer Mode

### 6.2.2 Asymmetrical Pulse Generation Mode

Counter B has a special Asymmetrical Pulse Generation Mode whereby a pulse train with programmable pulse width and period can be generated without the processor intervention once the latch values are initialized.

In this mode, the 16 -bit Latch $B$ is initialized with a value which corresponds to the duration between pulses (referred to as $D$ in the following descriptions). The 16 -bit Latch $C$ is initialized with a value which corresponds to the desired pulse width (referred to as $P$ in the following descriptions). The initialization sequence for Latch B and C and the starting of a counting sequence are as follows:

1. The lower 8 bits of $P$ are loaded into LLB by writing to address 001 C , and the upper 8 bits of $P$ are loaded into ULB and the full 16 bits are transferred to Latch C by writing to address location 001D. At this point both Latch $B$ and Latch $C$ contain the value of $P$.
2. The lower 8 bits of $D$ are loaded into LLB by writing to address 001C, and the upper 8 bits of $D$ are loaded into ULB by writing to address location 001E. Writing to address location 001E also causes the contents of the 16 -bit Latch B to be downloaded into the Counter $B$ and causes the CB output to go low as shown in Figure 6-5.
3. When the Counter $B$ underflow occurs the contents of the Latch C is loaded into the Counter B , and the CB output toggles to a high level and stays high until another underflow occurs. Latch $B$ is then down-loaded and the CB output toggles to a low level repeating the whole process.

1 AND 3. COUNTER B ఒ- LATCH B (D)
1 AND 3. COUNTER B ఒ- LATCH B (D)
2 AND 4. COUNTER B \& LATCH C (P)
2 AND 4. COUNTER B \& LATCH C (P)

Figure 6-5. Counter B Pulse Generation

## SECTION 7 POWER ON/INITIALIZATION CONSIDERATIONS

### 7.1 POWER-ON-RESET

The occurrence of $\overline{R E S}$ going from low to high will cause the R65F11 or R65F12 to reset and enter the RSC-FORTH Operating System. As was described in Section 3.8, upon reset certain system variables will be initialized. See Appendix C. 4 for a list of these variables names, locations and contents. The external memory map will be searched for an auto start ROM.

A bit pattern of A55A at a 1 K byte page boundary indicates that an auto start program follows. The next two bytes are assumed to be a pointer to the high level RSC-FORTH word that is the entry point to that program. Auto start programs is written in assembly language, rather than RSC-FORTH, a series of indirect pointers as shown in 3-7 can be used to initiate program execution.

### 7.2 POWER ON TIMING

After application of $V_{C C}$ and $V_{\text {RR }}$ power to the R65F11 or R65F12, $\overline{R E S}$ must be held low for at least eight $\varnothing 2$ clock cycles after $\mathrm{V}_{\mathrm{cc}}$ reaches operating range and the internal oscillator has stabilized. This stabilization time is dependent upon the input $V_{C C}$ voltage and performance of the internal oscillator. The clock can be monitored at $\varnothing 2$ (pin 3). Figure 7-1 illustrates the power turn-on waveforms. Clock stabilization time is typically 20 ms .


Figure 7-1. Power Turn-On Timing Detail

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

When $\overline{\text { RES }}$ is driven from low to high the R65F11 or R65F12 is put in a reset state. The registers and I/O ports are configured as shown in Table 7-1 when the external ROM is autostarted.

Table 7-1. RES Initialization of I/O Ports and Registers

|  | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| REGISTERS |  |  |  |  |  |  |  |  |
| $\quad$ Mode Control (MCR) | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 0 |
| Int. Enable (IER) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Int. Flag (IFR) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Ser. Com. Control (SCCR) | 1 | 1 | 0 | 0 | 0 | 1 | 0 | 0 |
| Ser. Com. Status (SCSR) | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| PORTS |  |  |  |  |  |  |  |  |
| $\quad$ PA Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PB Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

# APPENDIX A <br> R65F11 AND R65F12 INSTRUCTION SET 


#### Abstract

This appendix contains a summary of the R6500 instruction set. For detailed information, consult the R6500 Microcomputer System Programming Manual, Document 29650 N30. The four instructions notated with a * are added instructions for the R65F11 and R65F12 which are not part of the standard 6502 instruction set.


## A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE

| Mnemonic | Instruction | Mnemonic | Instruction |
| :---: | :---: | :---: | :---: |
| ADC | Add Memory to Accumulator with Carry | LDA | Load Accumulator with Memory |
| AND | "AND" Memory with Accumulator | LDX | Load Index X with Memory |
| ASL | Shift Left One Bit (Memory or Accumulator) | LDY | Load Index Y with Memory |
|  |  | LSR | Shift One Bit Right (Memory or |
| *BBR | Branch on Bit Reset Relative |  | Accumulator) |
| *BBS | Branch on Bit Set Relative |  |  |
| BCC | Branch on Carry Clear | NOP | No Operation |
| BCS | Branch on Carry Set |  |  |
| BEQ | Branch on Result Zero | ORA | "OR" Memory with Accumulator |
| BIT | Test Bits in Memory with Accumulator |  |  |
| BMI | Branch on Result Minus | PHA | Push Accumulator on Stack |
| BNE | Branch on Result not Zero | PHP | Push Processor Status on Stack |
| BPL | Branch on Result Plus | PLA | Pull Accumulator from Stack |
| BRK | Force Break | PLP | Pull Processor Status from Stack |
| BVC | Branch on Overflow Clear |  |  |
| BVS | Branch on Overflow Set | *RMB | Reset Memory Bit |
|  |  | ROL | Rotate One Bit Left (Memory or |
| CLC | Clear Carry Flag |  | Accumulator) |
| CLD | Clear Decimal Mode | ROR | Rotate One Bit Right (Memory or |
| CLI | Clear Interrupt Disable Bit |  | Accumulator) |
| CLV | Clear Overflow Flag | RTI | Return from Interrupt |
| CMP | Compare Memory and Accumulator | RTS | Return from Subroutine |
| CPX | Compare Memory and Index X |  |  |
| CPY | Compare Memory and Index Y | SBC | Subtract Memory from Accumulator with Borrow |
| DEC | Decrement Memory by One | SEC | Set Carry Flag. |
| DEX | Decrement Index $X$ by One | SED | Set Decimal Mode |
| DEY | Decrement Index Y by One | SEI | Set Interrupt Disable Status |
|  |  | *SMB | Set Memory Bit |
| EOR | "Exclusive-Or" Memory with | STA | Store Accumulator in Memory |
|  | Accumulator | STX | Store Index X in Memory |
|  |  | STY | Store Index Y in Memory |
| INC | Increment Memory by One |  |  |
| INX | Increment Index X by One | TAX | Transfer Accumulator to Index X |
| INY | Increment Index $Y$ by One | TAY | Transfer Accumulator to Index Y |
|  |  | TSX | Transfer Stack Pointer to Index X |
| JMP | Jump to New Location | TXA | Transfer Index X to Accumulator |
| JSR | Jump to New Location Saving Return Address | TXS | Transfer Index X to Stack Register Transfer Index $Y$ to Accumulator |



## A. 3 INSTRUCTION CODE MATRIX

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | $F$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\sum_{0}$ | BRK Implied 17 | $\begin{gathered} \text { ORA } \\ \text { (IND, } \mathrm{X}) \\ 26 \end{gathered}$ |  |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ZP } \\ & 2{ }_{3} \end{aligned}$ | $\begin{aligned} & \text { ASL } \\ & \mathrm{ZP} \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { RMBO } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | PHP Implied 13 | $\begin{aligned} & \text { ORA } \\ & \text { IMM } \\ & 2 \quad 2 \end{aligned}$ | ASL Accum 12 |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { ASL } \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{gathered} \text { BBRO } \\ \text { ZP } \\ 35^{* *} \end{gathered}$ | 0 |
| 1 | BṔL <br> Relative <br> 2 2** | $\begin{array}{\|c\|} \hline \text { ORA } \\ \text { (IND), } Y \\ 25^{\circ} \end{array}$ |  |  |  | $\begin{gathered} \text { ORA } \\ \text { ZP, X } \\ 24 \end{gathered}$ | $\begin{gathered} \text { ASL } \\ \text { ZP, } X \\ 26 \end{gathered}$ | $\begin{aligned} & \text { RMB1 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | CLC Implied 12 | $\left.\left\|\begin{array}{c} \text { ORA } \\ \text { ABS, } Y \\ 3 \end{array}\right\| 4^{*} \right\rvert\,$ |  |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ABS, } X \\ & 34^{*} \end{aligned}$ | $\begin{gathered} \text { ASL } \\ \text { ABS, } x \\ 37 \end{gathered}$ | $\begin{aligned} & \text { BBR1 } \\ & 3^{2 P} 5^{* *} \end{aligned}$ | 1 |
| 2 | JSR Absolute 36 | AND (IND, $X$ ) 26 |  |  | $\begin{aligned} & \text { BIT } \\ & 2 \mathrm{ZP} \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { AND } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { ROL } \\ & \mathrm{ZP} \\ & 2 \quad 5 \end{aligned}$ | $\begin{aligned} & \text { RMB2 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | PLP Implied 14 | $\begin{aligned} & \text { AND } \\ & \text { IMM } \\ & 22 \end{aligned}$ |  |  | $\begin{aligned} & \text { BIT } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { AND } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { ROL } \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{aligned} & \text { BBR2 } \\ & \text { ZP } \\ & 3 \text { 5** } \end{aligned}$ | 2 |
| 3 | BMI Relative 2 2** | $\begin{aligned} & \text { AND } \\ & \text { (IND, Y) } \\ & 25^{*} \end{aligned}$ |  |  |  | $\begin{aligned} & \text { AND } \\ & \text { ZP, } X \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { ROL } \\ & \text { ZP, } X \\ & 26 \end{aligned}$ | $\begin{aligned} & \text { RMB3 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | SEC Implied 12 |  |  |  |  |  |  | $\begin{aligned} & \text { BBR3 } \\ & \text { ZP } \\ & 3 \text { 5** } \end{aligned}$ | 3 |
| 4 | RTI Implied 16 | $\begin{array}{\|c} \text { EOR } \\ \text { (IND, X) } \\ 2.6 \end{array}$ |  |  |  | $\begin{aligned} & \text { EOR } \\ & Z P \\ & 23 \end{aligned}$ | $\begin{aligned} & \text { LSR } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { RMB4 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | PHA Implied 13 | $\begin{aligned} & \text { EOR } \\ & \text { IMM } \\ & 22 \end{aligned}$ | LSR Accum $1 \quad 2$ |  | $\begin{aligned} & \text { JMP } \\ & \text { ABS } \\ & 3 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { EOR } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { LSR } \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{aligned} & \text { BBR4 } \\ & \text { ZP } \\ & 35^{\prime \prime} \end{aligned}$ | 4 |
| 5 | BVC Relative 2 2** |  |  |  |  | $\begin{aligned} & \text { EOR } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { LSR } \\ & \text { ZP, } X \\ & 26 \end{aligned}$ | $\begin{gathered} \text { RMB5 } \\ 2 P \\ 2 \quad 5 \end{gathered}$ | CLI Implied 12 |  |  |  |  | EOR ABS, $X$ $34^{\circ}$ |  | $\begin{aligned} & \text { BBR5 } \\ & \text { ZP } \\ & 3 \quad 5^{\circ} \end{aligned}$ | 5 |
| 6 | RTS Implied 16 | $\begin{gathered} \text { ADC } \\ \text { (IND, X) } \\ 266 \end{gathered}$ |  |  |  | $\begin{aligned} & A D C \\ & Z P \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { ROR } \\ & Z \mathrm{ZP} \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { RMB6 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | PLA Implied 14 | $\begin{aligned} & \text { ADC } \\ & \text { IMM } \\ & 2 \quad 2 \end{aligned}$ |  |  | $\begin{array}{\|c\|} \hline \text { JMP } \\ \text { Indirect } \\ 3 \\ \hline \end{array}$ | $\begin{aligned} & \text { ADC } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { ROR } \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{gathered} \text { BBR6 } \\ \text { ZP } \\ 35^{*} \end{gathered}$ | 6 |
| 7 | BVS Relative 2 2** |  |  |  |  | $\begin{aligned} & \text { ADC } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{gathered} \text { ROR } \\ \text { ZP, X } \\ 266 \end{gathered}$ | $\begin{gathered} \text { RMB7 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | SEI Implied 12 |  |  |  |  |  |  | $\begin{aligned} & \text { BBR7 } \\ & \text { ZP } \\ & 3 \text { 5** } \end{aligned}$ | 7 |
| 8 |  | STA (IND, $X$ ) $2 \quad 6$ |  |  | $\begin{aligned} & \text { STY } \\ & Z P \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { STA } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { STX } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{gathered} \text { SMB0 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | DEY Implied 12 |  | TXA Implied 12 |  | $\begin{aligned} & \text { STY } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { STA } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { STX } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{gathered} \text { BBSO } \\ \text { ZP } \\ 3 \quad 5^{*} \end{gathered}$ | 8 |
| 9 | BCC Relative 2 2** | STA (IND, Y) 26 |  |  | $\begin{gathered} \text { STY } \\ \text { ZP, X } \\ 24 \end{gathered}$ | $\begin{gathered} \text { STA } \\ \text { ZP, X } \\ 24 \end{gathered}$ | $\begin{gathered} \text { STX } \\ \text { ZP, Y } \\ 24 \end{gathered}$ | $\begin{aligned} & \text { SMB1 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | TYA Implied 12 | STA ABS, Y $3 \quad 5$ | TXS Implied 12 |  |  | STA ABS, $X$ 35 |  | $\begin{aligned} & \text { BBS1 } \\ & \text { ZP } \\ & \mathbf{S P}^{* *} \end{aligned}$ | 9 |
| A | $\begin{aligned} & \text { LDY } \\ & \text { IMM } \\ & 22 \end{aligned}$ | $\begin{array}{\|c\|} \hline \text { LDA } \\ \text { (IND, X) } \\ 26 \end{array}$ | $\begin{aligned} & \text { LDX } \\ & \text { IMM } \\ & 22 \end{aligned}$ |  | $\begin{aligned} & \text { LDY } \\ & 2 P \\ & 28 \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & Z P \\ & 23 \end{aligned}$ | $\begin{aligned} & \text { LDX } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { SMB2 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | TAY Implied 12 | $\begin{aligned} & \text { LDA } \\ & \text { IMM } \\ & 22 \end{aligned}$ | TAX Implied 12 |  | $\begin{aligned} & \text { LDY } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & \text { ABS } \\ & 344 \end{aligned}$ | $\begin{aligned} & \text { LDX } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{gathered} \text { BBS2 } \\ \text { ZP } \\ 3 \quad 5 . \end{gathered}$ | A |
| B | BCS Relative 2 2** | $\begin{gathered} \text { LDA } \\ \text { (IND), Y } \\ 25^{*} \end{gathered}$ |  |  | $\begin{aligned} & \text { LDY. } \\ & \text { ZP, } \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{aligned} & L D X \\ & Z P, Y \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { SMB3 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{aligned} & \text { CLV } \\ & \text { Implied } \end{aligned}$ $12$ |  | TSX Implied 12 |  |  | $\begin{aligned} & \text { LDA } \\ & \text { ABS, } x \\ & 34^{*} \end{aligned}$ | $\left.\begin{gathered} \text { LDX } \\ \text { ABS, } Y \\ 34^{*} \end{gathered} \right\rvert\,$ | $\begin{gathered} \text { BBS3 } \\ \text { ZP } \\ 3 \quad 5^{* *} \end{gathered}$ | B |
| C | $\begin{aligned} & \text { CPY } \\ & \text { IMM } \\ & 22 \end{aligned}$ | $\begin{gathered} \text { CMP } \\ \text { (IND, X) } \\ 26 \end{gathered}$ |  |  | $\begin{aligned} & \text { CPY } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{aligned} & \text { SMB4 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | INY Implied 12 | $\begin{aligned} & \text { CMP } \\ & \text { IMM } \\ & 22 \end{aligned}$ | DEX Implied $1 \quad 2$ |  | $\begin{aligned} & \text { CPY } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{gathered} \text { BBS4 } \\ \text { ZP } \\ 3^{\prime \prime *} \end{gathered}$ | C |
| D |  |  |  |  |  | $\begin{gathered} \text { CMP } \\ \text { ZP, X } \\ 24 \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { ZP, } x \\ 26 \end{gathered}$ | $\begin{aligned} & \text { SMB5 } \\ & \text { ZP } \\ & 25 \end{aligned}$ | CLD Implied $1 \quad 2$ |  |  |  |  | $\begin{aligned} & \text { CMP } \\ & \begin{array}{c} \text { ABS, } X \\ 34^{*} \end{array} \end{aligned}$ | $\begin{array}{\|c\|} \hline \text { DEC } \\ \text { ABS, } x \\ 3.7 \end{array}$ | $\begin{aligned} & \text { BBS5 } \\ & \text { ZP } \\ & 3 \quad 5{ }^{\prime *} \end{aligned}$ | D |
| E | $\begin{aligned} & \hline \text { CPX } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { SBC } \\ (\text { IND }, X) \end{gathered}$ $26$ |  |  | $\begin{aligned} & \text { CPX } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \mathrm{SBC} \\ & \mathrm{ZP} \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \mathrm{ZP} \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { SMB6 } \\ \text { ZP } \\ 2 \quad 5 \\ \hline \end{gathered}$ | INX Implied 12 | $\begin{array}{r} \hline \text { SBC } \\ \text { IMM } \\ 2 \quad 2 \\ \hline \end{array}$ |  |  | $\begin{aligned} & \text { CPX } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { SBC } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{gathered} \text { BBS6 } \\ \text { ZP } \\ 3 \quad 5 * \\ \hline \end{gathered}$ | E |
| F | BEQ Relative 2 2** | $\begin{array}{\|c\|} \hline \mathrm{SBC} \\ \text { (IND), } Y \\ 25^{*} \end{array}$ |  |  |  | $\begin{aligned} & \text { SBC } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { ZP, X } \\ & 26 \end{aligned}$ | $\begin{aligned} & \text { SMB7 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | SED Implied 12 |  |  |  |  | $\begin{gathered} \text { SBC } \\ \text { ABS; } x \\ 34^{*} \end{gathered}$ | $\begin{array}{\|c\|} \hline \text { INC } \\ \text { ABS, } X \\ 3 \quad 7 \end{array}$ | $\begin{aligned} & \text { BBS7 } \\ & \text { ZP } \\ & 3 \quad 5^{* *} \end{aligned}$ | F |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | c | D | E | F |  |

*Add 1 to $\mathbf{N}$ if page boundary is crossed.
**Add 1 to N if branch occurs to same page; add 2 to N if branch occurs to different page.

## APPENDIX B

## KEY REGISTER SUMMARY


$1=$ Negative value $0=$ Postive Value
notes
(1) Not initualized by $\overline{\text { AES }}$

Set to Logic 1 by RES
Processor Status Register



Mode Control Register


Interrupt Enable and Flag Registers

> XMTR Date Reg Empty

XMTR Under-Run
Serial Communications Status Register

## APPENDIX C <br> ADDRESS ASSIGNMENTS/MEMORY MAPS/PIN FUNCTIONS

## C. 1 I/O AND INTERNAL REGISTER ADDRESSES

| ADDRESS (HEX) | READ | WRITE |
| :---: | :---: | :---: |
| $\begin{array}{r} 001 \mathrm{~F} \\ 1 \mathrm{E} \\ 1 \mathrm{D} \\ 1 \mathrm{C} \end{array}$ | Lower Counter B <br> Upper Counter B <br> Lower Counter B, CLR Flag | Upper Latch B, Cntr B↔Latch B, CLR Flag Upper Latch B, Latch C $\leftarrow$ Latch B Lower Lateh B. |
| $\begin{aligned} & 1 B \\ & 1 A \\ & 19 \\ & 18 \end{aligned}$ | Lower Counter A <br> Upper Counter A Lower Counter A, CLR Flag | Upper Latch A, Cntr A Latch A, CLR Flag Upper Latch A Lower Latch A |
| $\begin{aligned} & 17 \\ & 16 \\ & 15 \\ & 14 \end{aligned}$ | Serial Receiver Data Register Serial Comm. Status Register Serial Comm. Control Register Mode Control Register | Serial Transmitter Data Register <br> Serial Comm. Status Reg. Bits 4\&5 only <br> Serial Comm. Control Register <br> Mode Control Register |
| $\begin{aligned} & 13 \\ & 12 \\ & 11 \\ & 10 \end{aligned}$ | Interrupt Enable Register Interrupt Flag Register Read FF | Interrupt Enable Register <br> Clear int Flag (Bits 0-3 only, Write O's only) |
| $\begin{aligned} & O F \\ & O E \\ & O D \\ & O C \end{aligned}$ | $\begin{aligned} & \text { - - } \\ & -二 \end{aligned}$ |  |
| $\begin{aligned} & \text { OB } \\ & 0 A \\ & 09 \\ & 08 \\ & \hline \end{aligned}$ |  |  |
| $\begin{aligned} & 07 \\ & 06 \\ & 05 \\ & 04 \end{aligned}$ | Port G* Port F* Port E * | Port G* <br> Port F* <br> Port E* |
| $\begin{array}{r} 03 \\ 02 \\ 01 \\ 0000 \end{array}$ | Port B Port A | Port B Port A |

NOTE: *R65F12 Only

## C. 2 MULTIPLE FUNCTION PIN ASSIGNMENTSPORT C AND PORT D

| PIN <br> NUMBER |  | I/O PORT <br> FUNCTION <br> REPLACED | MULTIPLEXED PORT <br> FUNCTION |
| :---: | :---: | :---: | :---: |
| R65F11 | R65F12 |  |  |
| 4 | 25 | PC0 | A0 |
| 5 | 26 | PC1 | A1 |
| 6 | 27 | PC2 | A2 |
| 7 | 28 | PC3 | A3 |
| 8 | 29 | PC4 | A12 |
| 9 | 30 | PC5 | RW |
| 10 | 31 | PC6 | A13 |
| 11 | 32 | PC7 | EMS |
| 19 | 40 | PD0 | A4/D0 |
| 18 | 39 | PD1 | A5/D1 |
| 17 | 38 | PD2 | A6/D2 |
| 16 | 37 | PD3 | A7/D3 |
| 15 | 36 | PD4 | A8/D4 |
| 14 | 35 | PD5 | A9/D5 |
| 13 | 34 | PD6 | A10/D6 |
| 12 | 33 | PD7 | A11/D7 |

## C. 3 MULTIPLEXED MODE MEMORY MAP



## C. 4 SYSTEM VARIABLES IN RAM

| ADDRESS | NAME | COLD START VALUE | WARM START VALUE |
| :---: | :---: | :---: | :---: |
| 0040 | IRQVEC | (COLD) | - |
| 0042 | NMIVEC | (COLD) | - |
| 0044 | UKEY | (INK) | (INK) |
| 0046 | UEMIT | (OUT) | (OUT) |
| 0048 | UP | 0300 | 0300 |
| 004A | INTFLG | 00 | 00 |
| 004B | (W-1) | 6 C | 6 C |
| 004 C | W | - | - |
| 004E | IP | - | - |
| 0050 | ( $\mathrm{N}-1$ ) | - | - |
| 0051 | N | - | - |
| 0059 | XSAVE | - | - |
| 005B | INTVEC | (COLD) | - |
| 005D | TOS | - | - |
| 0300 | TIB | 0380 | 0380 |
| 0302 | RO | 00FF | 00FF |
| 0304 | so | $00 \mathrm{C2}$ | 00 C 2 |
| 0306 | UC/L | 0050 | - |
| 0308 | UPAD | 037 E | - |
| 030A | URW | (DISK) | - |
| 030C | BASE | 0010 | - |
| O30E | CLD/WRM | - | - |
| 0310 | IN | - | - |
| 0312 | DPL | - | - |
| 0314 | HLD | - | - |
| 0316 | DISKNO | - | - |
| 0318 | CURCYL | - | - |
| 031 C | B/SIDE | - | - |



## APPENDIX E ELECTRICAL SPECIFICATIONS

## MAXIMUM RATINGS*

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

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

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipation (Outputs High) Commercial at $25^{\circ} \mathrm{C}$ | $P_{\text {D }}$ | - |  | 1000 | mW |
| RAM Standby Voltage (Retention Mode) | $V_{\text {RR }}$ | 3.0 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| RAM Standby Current (Retention Mode) Commercial at $25^{\circ} \mathrm{C}$ | $\mathrm{I}_{\mathrm{RR}}$ | - | 4 | - | mAdc |
| Input High Voltage (Except XTLI) | $\mathrm{V}_{1}$ | +2.0 | - | $V_{c c}$ | Vdc |
| Input High Voltage (XTLI) | $\mathrm{V}_{\text {IH }}$ | +4.0 | - | $\mathrm{V}_{\text {CC }}$ | Vdc |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | - | +0.8 | Vdc |
| Input Leakage Current ( $\overline{\mathrm{RES}}, \overline{\mathrm{NMI}})$ $\mathrm{V}_{\text {in }}=0 \text { to } 5.0 \mathrm{Vdc}$ | $\mathrm{I}_{\text {N }}$ |  |  | $\pm 10.0$ | $\mu \mathrm{Adc}$ |
| Input Low Current PA, PB, PC, PF*, and PG* $\left(\mathrm{V}_{\mathrm{IL}}=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 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Output Low Voltage ( LLOAD $=1.6 \mathrm{mAdc}$ ) | VoL | - | - | +0.4 | Vdc |
| Darlingtón Current Drive, PE* $\left(V_{0}=1.5 \mathrm{Vdc}\right)$ | 1 OH | -1.0 | - | - | mAdc |
| Input Capacitance $\begin{aligned} & \left(V_{\text {in }}-0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right) \\ & \text { PA, PB, PC, PD, PF } \\ & \text { XTLI, XTLO } \end{aligned}$ | $\mathrm{C}_{\text {in }}$ | - |  | $\begin{aligned} & 10 \\ & 50 \end{aligned}$ | pF |
| I/O Port Pull-Up Resistance PAO-PA7, PB0-PB7, PC0-PC7, PF0-PF7 and PG0-PG7 | $R_{L}$ | 3.0 | 6.0 | 11.5 | K $\Omega$ |
| Output Leakage Current Tri-State I/Os while in High Impedance State | Iout | - | - | $\pm 10$ | $\mu \mathrm{Adc}$ |
| Output Capacitance Tri-State I/Os while in High Impedance State $V_{\text {IN }}=O V, T_{A}=25^{\circ} \mathrm{C}, f=25^{\circ} \mathrm{C}, f=1.0 \mathrm{MHz}$ | $\mathrm{C}_{\text {OUt }}$ | - | - | 10 | pF |
| Note: Negative sign indicates outward current flow, positive indicates inward flow. *R65F12 only. |  |  |  |  |  |

## APPENDIX F <br> TIMING REQUIREMENTS AND CHARACTERISTICS

## F. 1 GENERAL NOTES

1. $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, 0^{\circ} \mathrm{C} \leqslant T A \leqslant 70^{\circ} \mathrm{C}$
2. A valid $V_{C C}$ - RES sequence is required before proper operation is achieved.
3. All timing reference levels are 0.8 V and 2.0 V , unless otherwise specified.
4. All time units are nanoseconds, unless otherwise specified.
5. All capacitive loading is 130 pf maximum, except as noted below:

$$
\text { PA, PB, PE, PF, PG } \quad-50 \text { pf maximum }
$$

## F. 2 CLOCK TIMING

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| Tcre | Cycle Time | 1000 | $10 \mu \mathrm{~s}$ | 500 | $10 \mu \mathrm{~s}$ |
| $\mathrm{T}_{\text {PWX } 1}$ | XTLI Input Clock Pulse Width XTLO = VSS | $\begin{aligned} & 500 \\ & \pm 25 \end{aligned}$ | - | $\begin{aligned} & 250 \\ & \pm 10 \end{aligned}$ | - |
| $\mathrm{T}_{\text {PW02 }}$ | Output Clock Pulse Width at Minimum Tcyc | $\mathrm{T}_{\text {PWX } 1}$ | $\begin{gathered} T_{\text {PWX }} \\ \pm 25 \end{gathered}$ | TPWX1 | $\begin{array}{r} T_{\text {PWX1 }} \\ \pm 20 \end{array}$ |
| $\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}$ | Output Clock Rise, Fall Time | - | 25 | - | 15 |
| $\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}$ | Input Clock Rise, Fall Time | - | 10 | - | 10 |



## F. 3 MULTIPLEXED MODE TIMING-PC AND PD

$($ MCR $5=1$, MCR $6=1$, MCR $7=1)$

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $\mathrm{T}_{\text {PCRS }}$ | (PC5) RWW Setup Time | - | 225 | - | 140 |
| TPCAS | (PC0-PC4, PC6) Address Setup Time | - | 225 | - | 140 |
| $\mathrm{T}_{\text {PBAS }}$ | (PD) Address Setup Time | - | 225 | - | 140 |
| $\mathrm{T}_{\text {PBSU }}$ | (PD) Data Setup Time | 50 | - | 35 | - |
| $\mathrm{T}_{\text {PBHA }}$ | (PD) Data Read Hold Time | 10 | - | 10 | - |
| $T_{\text {PBHW }}$ | (PD) Data Write Hold Time | 30 | - | 30 | - |
| T PBoD | (PD) Data Output Delay | - | 175 | - | 150 |
| $\mathrm{T}_{\text {PCHA }}$ | (PC0-PC4, PC6) Address Hora Time | 30 | - | 30 | - |
| T PBHA | (PD) Address Hold Time | 10 | 100 | 10 | 80 |
| TPCHR | (PC5) R/W Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {PCHV }}$ | (PC7) EMS Hold Time | 10 | - | 10 | - |
| $\mathrm{T}_{\text {PCVD }}{ }^{(1)}$ | (PC7) Address to EMS Delay Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {PCVP }}$ | (PC7) EMS Stabilization Time | 30 | - | 30 | - |
| TESU: | $\overline{\text { EMS }}$ Set Up Time | - | 350 | - | 210 |

NOTE 1: Values assume PC0-PC4, PC6 and PC7 have the same capacitive load.

## F.3.1 Multiplex Mode Timing Diagram



## F. 4 I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $\begin{aligned} & T_{\text {Pow }}{ }^{(1)} \\ & \mathrm{T}_{\text {CMOS }}{ }^{(1)} \end{aligned}$ | Internal Write to Peripheral Data Valid <br> PA, PB TTL <br> PA, PB CMOS | - | 500 1000 | - | $\begin{array}{r} 500 \\ 1000 \end{array}$ |
| TpDSU | Peripheral Data Setup Time PA, PB | 200 | - | 200 | - |
| T ${ }_{\text {PHR }}$ | Peripheral Data Hold Time PA, PB | 75 | - | 75 | - |
| $\mathrm{T}_{\text {EPW }}$ | PAO-PA3 Edge Detect Pulse Width | T ${ }_{\text {cre }}$ | - | $\mathrm{T}_{\mathrm{CrC}}$ | - |
| $\begin{aligned} & T_{\text {CPW }} \\ & T_{C D}(1) \end{aligned}$ | Counters A and B PA4, PA5 Input Pulse Width PA4, PA5 Output Delay | $\mathrm{T}_{\text {cre }}$ | $\overline{500}$ | $\mathrm{T}_{\text {cre }}$ | - |
| $T_{\text {pBLw }}$ <br> Tplsu <br> TPBLH | Port B Latch Mode PAO Strobe Pulse Width PB Data Setup Time PB Data Hold Time | $\begin{gathered} T_{\mathrm{crc}} \\ 175 \\ 30 \end{gathered}$ | 二 | $\begin{gathered} T_{\text {CYC }} \\ 150 \\ 30 \end{gathered}$ | - |
|  | Serial I/O |  |  |  |  |
| $T_{\text {pow }}{ }^{(1)}$ | PA6 XMTR TTL | - | 500 | - | 500 |
| $\mathrm{T}_{\text {смоs }}{ }^{(1)}$ | PA6 XMTR CMOS | - | 1000 | - | 1000 |
| $T_{\text {cPW }}$ | PA4 RCVR S/R Clock Width | 4 Tcrc | - | 4 Tcrc | -0 |
| $T_{\text {Pow }}{ }^{(1)}$ | PA4 XMTR Clock-S/R Mode (TTL) | - | 500 | - | 500 |
| $\mathrm{T}_{\text {Cmos }}{ }^{(1)}$ | PA4 XMTR Clock-S/R Mode (CMOS) | - | 1000 | - | 1000 |

NOTE 1: Maximum Load Capacitance: 50pF Passive Pull-Up Required.

## F.4.1 I/O Edge Detect, Counter, and Serial I/O Timing



## APPENDIX G <br> INCLUDED FORTH FUNCTIONS IN ROM

| BANKEXECUTE | BANKEEC! | BANKC@ | BANKC! |
| :---: | :---: | :---: | :---: |
| EEC! | - | .R |  |
| ? | \#S | \# | SIGN |
| D.R | <\# | SPACES | SEEK |
| \# > | DWRITE | DREAD | SELECT |
| INIT | M/MOD | */ | */MOD |
| DISK | 1 | /MOD | * |
| MOD | M * | MAX | MIN |
| M/ | ABS | D+- | +- |
| DABS | COLD | (NUMBER) | HOLD |
| S $->$ D | ERASE | FILL | QUERY |
| BLANKS | (.") | -TRAILING | TYPE |
| EXPECT | DECIMAL | HEX | -DUP |
| COUNT | PICK | ROT | > |
| SPACE | U< | = | - |
| $<$ | 1- | 2+ | 1+ |
| $2-$ | C/L | HLD | DPL |
| PAD | CLD/WRM | BASE | UR/W |
| IN . | UC/L | RO | SO |
| UPAD | BL | 4 | 3 |
| TIB | 1 | 0 | C! |
| 2 | C@ | @ | TOGGLE |
| , | BOUNDS | 2DUP | DUP |
| +! | 2DROP | DROP | OVER |
| SWAP | NEGATE | D+ | + |
| DNEGATE | $0=$ | R | R> |
| $0<$ | LEAVE | ; | RP@ |
| $>\mathrm{R}$ | SP! | SP@ | XOR |
| RP! | AND | U/ | U* |
| OR | CR | ?TERMINAL | KEY |
| CMOVE | ENCLOSE | (FIND) | DIGIT |
| EMIT | (+LOOP) | (LOOP) | OBRANCH |
| $\begin{aligned} & \text { (DO) } \\ & \text { BRANCH } \end{aligned}$ | EXECUTE | CLIT | LIT |

## R65FRx AND R65FKx RSC FORTH DEVELOPMENT AND KERNEL ROMS

## INTRODUCTION

The Rockwell Single Chip (RSC) FORTH System can be configured using the R65F11, R65F12 microcomputers or the R6501Q ROM-less microcomputer. One of these microcomputers, when used in conjunction with a development ROM and a FORTH kernel ROM, provide the designer with maximum flexibility when developing FORTH applications.

RSC-FORTH is based on the popular fig-FORTH model with extensions. The R65F11 and R65F12 both have the kernel of the high level Rockwell Single Chip RSC-FORTH language contained in the preprogrammed ROM. The R65FK2 and R65FK3 Kernel ROMs are preprogrammed ROMs for use with the R6501Q when developing larger applications requiring more memory and I/O line support. All of the run time functions of the RSC-FORTH are contained in these ROMs, including 16- and 32-bit mathematical, logical and stack manipulation, plus memory and input/output operators. The RSC-FORTH Operating System allows an external user program written in RSC-FORTH or Assembly Language to be executed from external EPROM, or development of such a program under the control of the R65FR1, R65FR2 or R65FR3 RSC-FORTH Development ROMs.

This document describes five different RSC-FORTH system configurations using the development and kernel ROMs.
ORDERING INFORMATION

| Part No. | Description |  |
| :--- | :--- | :---: |
| R65FR1P | FORTH Development ROM for R65F11 or R65F12 |  |
| R65FR2P | FORTH Development ROM for R6501Q |  |
| R65FR3P | FORTH Development ROM for R6501Q |  |
| R65FK2P | FORTH Kernel ROM for R6501Q |  |
| R65FK3P | FORTH Kernel ROM for R6501Q |  |
| R65F11P | 40-Pin FORTH Based Microcomputer at 1 MHz |  |
| R65F11AP | 40-Pin FORTH Based Microcomputer at 2 MHz |  |
| R65F12Q | 64-Pin FORTH Based Microcomputer at 1 MHz |  |
| R65F12AQ | 64-Pin FORTH Based Microcomputer at 2 MHz |  |
| R6501Q | 64-Pin One-Chip Microprocessor at 1 MHz |  |
| R6501AQ | 64-Pin One-Chip Microprocessor at 2 MHz |  |
| Order No. | Description |  |
| 2145 | R6501Q One-Chip Microprocessor Product |  |
|  | Description |  |
| 2146 | R65F11 and R65F12 FORTH Based Microcomputer |  |
|  | Product Description |  |
| 2148 | RSC-FORTH User's Manual |  |
| 2162 | Application Note: A Low-Cost Development Module |  |
|  | for the R65F11 FORTH Microcomputer |  |

## FEATURES

- R65FR1 FORTH Development ROM
-8K ROM
-Addressable from $\$ 2000$ through $\$ 3 F F F$ in FORTH development configuration memory map
-R65F11 and R65F12 compatible
-Operates in the R65F11/F12 FORTH development configuration
- R65FR2 FORTH Development ROM
-8K ROM
-Addressable from $\$ 4000$ through $\$ 5 F F F$ in the FORTH development configuration memory map
-R6501Q compatible for use in emulation of the R65F11/F12 FORTH development configuration
- R65FR3 FORTH Development ROM
-8K ROM
-Addressable from \$COOO through \$DFFF in the FORTH development configuration memory map
-Operates in the R6501Q FORTH development configuration
- R65FK2 FORTH Kernel ROM
-4K ROM
-Addressable from \$F400 through \$FFFF in the FORTH development configuration memory map
-R6501Q compatible for use in the emulation of the R65F11/F12 FORTH development configuration
-Replaces the FORTH kernel contained in the R65F11 and R65F12 microcomputers during development
- R65FK3 FORTH Kernel ROM
-4K ROM
-Addressable from \$F400 through \$FFFF in the FORTH development and production configuration memory maps
-R6501Q compatible
-Operates in the R6501Q FORTH development and production configurations


## RSC-FORTH SYSTEM CONFIGURATIONS

The three configurations of the RSC-FORTH System are identified by the CPU-Development ROM combinations listed below:

RSC-FORTH System Configurations

| CPU | Kernel <br> ROM | Development <br> ROM | RSC <br> Configuration |
| :--- | :--- | :---: | :---: |
| R65F11 | none | R65FR1 | 1 |
| R65F12 | none | R65FR1 | 1 |
| R6501Q | R65FK2 | R65FR2 | 2 |
| R6501Q | R65FK3 | R65FR3 | 3 |

## RSC-FORTH CONFIGURATION 1 (R65FR1)

## R65F11/R65F12 DEVELOPMENT AND PRODUCTION

The RSC-FORTH Configuration 1 provides the designer with a FORTH development and application environment at a minimal cost. The application program is developed using an R65F11 or R65F12 microcomputer, an R65FR1 Development ROM and external RAM. Up to 8 K bytes of RAM space is available using this configuration. However, Configuration 1 is limited to 5 K or less bytes of RAM during development. This is the result of allocating 2 K bytes of RAM for disk buffers and at least 1 K bytes of RAM for the "Program heads". The program heads are contained in a dictionary containing the Name (NFA), Link Field Address (LFA) and the Parameter Field Address Pointer (PFA). This dictionary is a list of FORTH word words and user-defined FORTH words used in the development of a FORTH program and is not present during the execution of the FORTH program.

Although programs may reside in the upper 8 K bytes of memory area, normally filled by the R65FR1 Development ROM, it is difficult to develop code for that area using this configuration of the RSC-FORTH System.

The difference in using the R65F11 or the R65F12 is in the number of I/O lines available to the user. The R65F11 supports 16 I/O lines, the R65F12 supports 40 I/O lines.

Figure 1 shows the development and production configurations for the R65F11/F12. Configurations 1A and 1B list the features, memory maps, and the relationship of the R65F11 and R65F12 to the R65FR1 Development ROM in the development and production environment.


Figure 1. R65FR1 Configuration 1 Block Diagram

## CONFIGURATION 1A CONSIDERATIONS

## Features

- 8K Bytes of User Memory
- 16 I/O Lines

Device Configuration

| \% | DEVELOPMENT | PRODUCTION |
| :---: | :---: | :---: |
| R65F11 Microcomputer | $\nu$ | $\nu$ |
| R65FR1 Development ROM | , |  |

## User Memory-I/O Resource Matrix

User memory may be a mix of ROM, EEROM, UVPROM or RAM.


## CONFIGURATION 1B CONSIDERATIONS

Features

- 8 K Bytes of User Memory
- 40 I/O Lines


## Device Configuration



## User Memory-I/O Resource Matrix

User memory may be a mix of ROM, EEROM, UVPROM or RAM.


## Memory Map

FFFF $\quad$ KERNEL


## RSC-FORTH CONFIGURATION 2

(R65FR2, R65FK2)

## R6501Q DEVELOPMENT AND R65F11/F12 PRODUCTION

The RSC-FORTH Configuration 2 provides the designer with the capability of using the full 16 K bytes of external address space of the R65F11 and R65F12.

The R6501Q ROM-less microprocessor, when used with the R65FK2 Kernel ROM and the R65FR2 Development ROM, emulates the operation of the R65F11/F12. Because of the greater address space of the R6501Q, the R65FR2 Development ROM can be relocated to address $\$ 4000$ and the disk buffers and HEADS program to $\$ 6000$. This expands the available user memory space to 16 K bytes, $\$ 0000$ through \$3FFF.

Using this configuration, the application program can be developed using the R6501Q and then later installed in an R65F11 or R65F12 microcomputer without modification.

Figure 2 shows the development and production configuration for the R6501Q. Configurations 2A and 2B list the features, memory maps, and the relationship of the R6501Q to the R65FR2 Development ROM and R65FK2 Kernel ROM in the development and production environment. Figure 3 is a schematic of the R6501Q, R65FR2, R65FK2 development setup.


Figure 2. R65FR2 and R65FK2 Configuration 2 Block Diagrams

## CONFIGURATION 2A CONSIDERATIONS

Features

- 16 K Bytes of User "Headerless" Memory
- 16 I/O Lines


## Device Configuration

|  | DEVELOPMENT | PRODUCTION |
| :--- | :--- | :--- |
| R65F11 Microcomputer |  |  |
| R6501Q Microprocessor |  |  |
|  |  |  |
|  |  |  |
| R65FR2 Development ROM |  |  |
|  |  |  |

## Memory-l/O Matrix

If floppy disk is used in the application, space for the disk buffers must be allocated in memory from $\$ 0500$ through \$3FFF or $\$ 6000$ through $\$ 7 F F F$. User memory can be a mix of ROM, EEROM, UVROM or RAM.


## Memory Maps



## CONFIGURATION 2B CONSIDERATIONS

Features

- 16K Bytes of User "Headerless" Memory
- 40 I/O Lines

Device Configuration
DEVELOPMENT PRODUCTION


## Memory-I/O Matrix

If floppy disk is used in the application, space for the disk buffers must be allocated in memory $\$ 0000$ through $\$ 3 F F F$. User memory can be a mix of ROM, EEROM, UVROM or RAM.


## Memory Maps



R65FR2•R65FK2 RSC FORTH ROMs
Figure 3. R6501Q, R65FR2 and R65K2 Application Configuration Schematic

## RSC-FORTH CONFIGURATION 3 (R65FR3, R65FK3)

## R6501Q BASED SYSTEM DEVELOPMENT AND PRODUCTION

The RSC-FORTH Configuration 3 is designed for those applications which require a larger amount of ROM or RAM space than the R65F11 or R65F12 can provide.

In the development configuration, the user is provided with up to 48 K bytes of memory. The user memory is located from $\$ 0000$ through \$BFFF. The program heads will use some of this area but the user will still have considerably more memory space available then in the previous configurations.

The production configuration provides up to 56 K bytes of user memory. This is due to the fact that the R65FR3 Development ROM, used in the development configuration, is not required in the production configuration and releases the 8 K bytes of memory space. This memory is located at \$C000 through \$DFFF.

Figure 4 shows the development and production configurations for the R6501Q. Configuration 3 lists the features, memory maps, and the relationship of the R6501Q to the R65FR3 Development ROM and the R65FK3 Kernel ROM in the development and production environment.


Figure 4. R65FR3 and R65FK3 Configuration 3 Block Diagrams

CONFIGURATION 3 CONSIDERATIONS
Features

- R6501Q w/FORTH
- 48K Bytes of User Memory
- 30 I/O Lines


## Device Configuration

|  | DEVELOPMENT PRODUCTION |  |
| :--- | :--- | :--- |
|  |  |  |
|  |  |  |
| R6501Q Microcomputer |  |  |
| R65FK3 Development ROM |  |  |
|  |  |  |

3

## User Memory-I/O Resource Matrix

All ports act as I/O ports. Memory is on the bus. PC6 \& PC7 (I/O lines) are assigned to memory. User memory can be a mix of ROM, EEROM, UVPROM or RAM.


Memory Maps



RSC-FORTH ROM Pin Assignments

## SECTION 1 <br> INTRODUCTION

### 1.1 FEATURES OF THE R6501Q

- Enhanced 6502 CPU
- Four new bit manipulation instructions
- Set Memory Bit (SMB)
- Reset Memory Bit (RMB)
- Branch on Bit Set (BBS)
- Branch on Bit Reset (BBR)
-Decimal and binary arithmetic modes
-13 addressing modes
-True indexing
- 192-byte static RAM
- 32 bidirectional, TTL-compatible I/O lines (four ports)
- One 8-bit port may be tri-stated under software control
- One 8-bit port may have latched inputs under software control
- Two 16-bit programmable counter/timers, with latches
-Pulse width measurement
-Asymmetrical pulse generation
-Pulse generation
-Interval timer
-Event counter
-Retriggerable interval timer
- Serial port
-Full-duplex asynchronous operation mode
-Selectable 5- to 8-bit characters
-Wake-up feature
-Synchronous shift register mode
-Standard programmable bit rates programmable up to 62.5 K bits $/ \mathrm{sec} @ 1 \mathrm{MHz}$
- Ten interrupts
-Four edge-sensitive lines; two positive, two negative
-Reset
- Non-maskable
- Two counter underflows
-Serial data received
-Serial data transmitted
- Bus expandable to 64 K bytes of external memory
- Flexible clock circuitry
$-2-\mathrm{MHz}$ or $1-\mathrm{MHz}$ internal operation
-4 MHz Crystal used to generate internal clocks
- $1 \mu \mathrm{~s}$ minimum instruction execution time at 2 MHz
- NMOS-3 silicon gate, depletion load technology
- Single +5 V power supply
- 12 mW stand-by power for 32 bytes of the 192-byte RAM
- 64-pin QUIP


### 1.2 SUMMARY

The Rockwell R6501Q 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 R6501Q consists of an enhanced 6502 CPU, an internal clock oscillator, 192 bytes of Random Access Memory (RAM), and versatile interface circuitry. The interface circuitry includes two 16 -bit programmable timer/counters, 32 bidirectional input/output lines (including four edge-sensitive lines and input latching on one 8 -bit port), a full-duplex serial I/O channel, ten interrupts, and bus expandability.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of computational power. These features make the R6501Q a leading candidate for microcomputer applications.

Rockwell supports development of the R6501Q with the System 65 Microcomputer Development System and the R6500/* Family of Personality Modules. Complete in-circuit emulation with the R6500/* Family of Personality Modules allows total system test and evaluation.

This product description assumes that the reader is familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual (Document Number 29650N31). A description of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Document Number 29650N30).

### 1.3 CUSTOMER OPTIONS

The R6501Q has no customer specified mask options. It has the following characteristics.

- Crystal Oscillator
- Clock Divide by 4
- Clock MASTER Mode
- Reset Vector at FFFC
- Internal pull-up resistors on Ports PA, PB, and PC


### 1.4 ORDERING INFORMATION

R6501Q - 4 MHz Xtal, 1 MHz Operation
R6501AQ - 4 MHz Xtal, 2 MHz Operation



64 PIN QUIP

Figure 2-1. Mechanical Outline \& Pin Out Configuration

## SECTION 2 <br> R6501Q INTERFACE REQUIREMENTS

This section describes the interface requirements for the R6501Q. Figure 2-1 and 2-2 show the Interface Diagram and the pin out configuration for both devices. Table 2-1 describes the function of each pin. Figure 3-1 has a detailed block diagram of the R6501Q ports which illustrates the internal function of the device.


# SECTION 3 SYSTEM ARCHITECTURE 

This section provides a functional description of the R6501Q. Functionally the R6501Q consists of a CPU, RAM, four 8-bit parallel I/O ports, a serial I/O port, dual counter/latch circuits, a mode control register, and an interrupt flag/enable dual register circuit. A block diagram of the system is shown in Figure 3-1.

## NOTE

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

### 3.1 CPU LOGIC

The R6501Q internal CPU is a standard 6502 configuration with an 8-bit Accumulator register, two 8-bit Index Registers ( X and Y ); an 8 -bit Stack Pointer register, an ALU, a 16 -bit Program Counter, and standard instruction register/decode and internal timing control logic.

### 3.1.1 Accumulator

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

### 3.1.2 Index Registers

There are two 8 -bit index registers, $X$ and $Y$. Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

### 3.1.3 Stack Pointer

The Stack Pointer is an 8 -bit register: It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal $\overline{\mathrm{RQ}}$ interrupt, or the external interrupt line $\overline{\text { NMI. The Stack Pointer must be initialized by }}$ the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may be accessed only from the top. The address of a memory
location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1. Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 00FF-0040. After reset, which leaves the Stack Pointer indeterminate, normal usage calls for its initialization at 00FF.

### 3.1.4 Arithmetic And Logic Unit (ALU)

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

### 3.1.5 Program Counter

The 16-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter ( PCL ) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter $(\mathrm{PCH})$ is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

### 3.1.6 Instruction Register and Instruction Decode

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register, then decoded along with timing and interrupt signals to generate control signals for the various registers.

### 3.1.7 Timing Control

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to TO each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.

Figure 3-1. Detailed Block Diagram

### 3.1.8 Interrupt Logic

Interrupt logic controls the sequencing of three interrupts; $\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}$ and $\overline{\mathrm{RQ}} . \overline{\mathrm{IRQ}}$ is generated by any one of eight conditions: 2 Counter Overflows, 2 Positive Edge Detects, 2 Negative Edge Detects, and 2 Serial Port Conditions.

### 3.2 NEW INSTRUCTIONS

In addition to the standard R6502 instruction set, four new bit manipulation instructions have been added to the R6501Q. The added instructions and their format are explained in the following paragraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions. The four added instructions do not impact the CPU processor status register.

### 3.2.1 Set Memory Bit (SMB m, Addr.)

This instruction sets to "1" one of the 8-bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and one of eight bits to be set. The second byte of the instruction designates address $(0-255)$ of the byte to be operated upon.

### 3.2.2 Reset Memory Bit (RMB m, Addr.)

This instruction is the same operation and format as SMB instruction except a reset to " 0 " of the bit results.

### 3.2.3 Branch On Bit Set Relative (BBS m, Addr, DEST)

This instruction tests one of eight bits designated by a 3-bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction is used to specify the 8-bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

### 3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST)

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

### 3.3 READ-ONLY-MEMORY (ROM)

The R6501Q has no ROM and its Reset vector is at FFFC.

### 3.4 RANDOM ACCESS MEMORY (RAM)

The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The R6501Q provides a separate power pin ( $\mathrm{V}_{\mathrm{FR}}$ ) which may be used for standby power for 32 bytes located at 0040-005F. In the event of the loss of $V_{c c}$ power, the lowest 32 bytes of RAM data will be retained if standby power is supplied to the $V_{R A}$ pin. If the RAM data retention is not required then $V_{R R}$ must be connected to $\mathrm{V}_{\mathrm{cc}}$. During operation $\mathrm{V}_{\mathrm{RR}}$ must be at the $\mathrm{V}_{\mathrm{cc}}$ level.

For the RAM to retain data upon loss of $\mathrm{V}_{\mathrm{cc}}, \mathrm{V}_{\mathrm{RR}}$ must be supplied within operating range and RES must be driven low at least eight $\varnothing 2$ clock pulses before $\mathrm{V}_{c c}$ falls out of operating range. RES must then be held low while $V_{c c}$ is out of operating range and until at least eight $\emptyset 2$ clock cycles after $V_{c c}$ is again within operating range and the internal $\phi 2$ oscillator is stabilized. $\mathrm{V}_{\mathrm{AR}}$ must remain within $\mathrm{V}_{\mathrm{CC}}$ operating range during normal operation. When $\mathrm{V}_{\mathrm{cc}}$ is out of operating range, $\mathrm{V}_{\text {RR }}$ must remain within the $\mathrm{V}_{\mathrm{AR}}$ retention range in order to retain data. Figure 3.2 shows typical waveforms.


INITIAL APPLICATION OF $V_{C C}$ AND $V_{\text {RA }}$.
LOSS OF $V_{C C}$, RAM ON STANDBY POWER.
REAPPLICATION OF $V_{c c}$.
$>8 \phi 2$ CLOCK PULSES AFTER OSCILLATOR STABILIZATION. $>8$ ø2 CLOCK PULSES.

Figure 3-2. Data Retention Timing

### 3.5 CLOCK OSCILLATOR

The R6501Q has been configured for a crystal oscillator, a countdown network, and for Master Mode Operation.

A reference frequency can be generated with the on-chip oscillator using either an external crystal or an external oscillator. The oscillator reference frequency passes through an internal countdown network to obtain the internal operating frequency (see Figures 3-3a and 3-3b). The external crystal generated reference frequency is a preferred method since the resistor method can have tolerances approaching $50 \%$.

## Note:

When operating at 1 MHz interval frequency (R6501Q) place a 15-22 pt capacitor between XTLO and ground.

Internal timing can also be controlled by driving the XTLI pin with an external frequency source. Figure 3-3c shows typical connections. If XTLO is left floating, the external source is divided by the internal countdown network. However, if XTLO is tied to $V_{\text {ss }}$, the internal countdown network is bypassed causing the chip to operate at the frequency of the external source.

b. Clock Inputs

Figure 3-3. Clock Oscillator Input Options

### 3.6 MODE CONTROL REGISTER (MCR)

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for Counter A and Counter B. Its setting, along with the setting of the Serial Communications Control Register (SCCR), determines the basic configuration of the R6501Q in any application. Initializing this register is one of the first actions of any software program. The Mode Control Register bit assignment is shown in Figure 3-5.

### 3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)

An $\overline{\mathrm{RQ}}$ interrupt request can be initiated by any or all of eight possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple
simultaneous interrupts cause the $\overline{\mathrm{RQ}}$ interrupt request to remain active until all interrupting conditions have been serviced and cleared.

The Interrupt Flag Register contains the information that indicates which I/O or counter needs attention. The contents of the Interrupt Flag Register may be examined at any time by reading at address: 0011. Edge detect IFR bits may be cleared by executing a RMB instruction at address location 0010. The RMB X, (0010) instruction reads FF, modifies bit $X$ to a " 0 ", and writes the modified value at address location 0011. In this way IFR bits set to a "1" after the read cycle of a Read-Modify-Write instruction (such as RMB) are protected from being cleared. A logic " 1 " is ignored when writing to edge detect IFR bits.

Each IFR bit has a corresponding bit in the Interrupt Enable Register which can be set to a " 1 " by writing a " 1 " in the respective bit position at location 0012. Individual IER bits may be cleared by writing a " 0 " in the respective bit position, or by $\overline{R E S}$. If set to a " 1 ", an IRQ will be generated when the corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 3-6 and the functions of each bit are explained in Table 3-1.


Figure 3-5. Mode Control Register

The use of Counter A Mode Select is shown in Section 6.1.
The use of Counter B Mode Select is shown in Section 6.2.
The use of Port B Latch Enable is shown in Section 4.4.
The use of Port $D$ in Tri-State Enable is shown in Section 4.6.

The use of Bus Mode Select is shown in Section 4.5 and 4.6.


Figure 3-6. Interrupt Enable and Flag Registers

### 3.8 PROCESSOR STATUS REGISTER

The 8-bit Processor Status Register, shown in Figure $3-7$, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6502 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

### 3.8.1 Carry Bit (C)

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.


Figure 3-7. Processor Status Register

Table 3-1. Interrupt Flag Register Bit Codes

| $\begin{aligned} & \text { BIT } \\ & \text { CODE } \end{aligned}$ | FUNCTION |
| :---: | :---: |
| IFR 0: | PAO Positive Edge Detect Flag—Set to a "1" when a positive going edge is detected on PAO. Cleared by RMB O (0010) instruction or by $\overline{\text { RES }}$. |
| IFR 1: | PA1 Positive Edge Detect Flag-Set to a 1 when a positive going edge is detected on PA1. Cleared by RMB 1 (0010) instruction or by RES. |
| IFR 2: | PA2 Negative Edge Detect Flag-Set to a 1 when a negative going edge is detected on PA2. Cleared by RMB 2 (0010) instruction or by RES. |
| IFR 3: | PA3 Negative Edge Detect Flag-Set to 1 when a negative going edge is detected on PA3. Cleared by RMB 3 (0010) instruction or by RES. |
| IFR 4: | Counter A Underflow Flag-Set to a 1 when Counter A underflow occurs. Cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES. |
| IFR 5: | Counter B Underflow Flag-Set to a 1 when Counter B underflow occurs. Cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by RES. |
| IFR 6: | Receiver Interrupt Flag-Set to a 1 when any of the Serial Communication Status Register bits 0 through 3 is set to a 1. Cleared when the Receiver Status bits (SCSR 0-3) are cleared or by RES. |
| IFR 7: | Transmitter interrupt Flag-Set to a 1 when SCSR 6 is set to a 1 while SCSR 5 is a 0 or SCSR 7 is set to a 1 . Cleared when the Transmitter Status bits (SCSR $6 \& 7$ ) are cleared or by $\overline{R E S}$. |

### 3.8.2 Zero Bit (Z)

The Zero Bit $(Z)$ is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The R6500 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions; ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

### 3.8.3 Interrupt Disable Bit (I)

The Interrupt Disable Bit (I) is used to control the servicing of an interrupt request ( $\overline{\mathrm{RQ}}$ ). If the 1 Bit is reset to logic 0 , the $\overline{\mathrm{RQ}}$ signal will be serviced. If the bit is set to logic 1 , the $\overline{\mathrm{IRQ}}$ signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( $\overline{\mathrm{RES}}$ ), $\overline{\mathrm{RQ}}$, or Non-Maskable Interrupt (NMI) signal is detected.

The I bit is cleared by the Clear Interrupt Mask Instruction (CLI) and is set by the Set Interrupt Mask Instruction (SEI). This bit is set by the BRK Instruction. The Return from Interrupt (RTI) and Pull Processor Status (PLP) instructions will also affect the I bit.

### 3.8.4 Decimal Mode Bit (D)

The Decimal Mode Bit (D) is used to control the arithmetic mode of the CPU. When this bit is set to logic 1 , the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction clears it. The PLP and RTI instructions also affect the Decimal Mode Bit.

## CAUTION

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application. This bit must be initialized to the desired state by the user program or erroneous results may occur.

### 3.8.5 Break Bit (B)

The Break Bit $(B)$ is used to determine the condition which caused the $\overline{\mathrm{RQ}}$ service routine to be entered. If the $\overline{\mathrm{RQ}}$ service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1. If the $\overline{\mathrm{IRQ}}$ routine was entered as the result of an $\overline{\mathrm{TQ}}$ signal being generated, the $B$ bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

### 3.8.6 Overflow Bit (V)

The Overflow Bit (V) is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits ( $-128 \leqslant n \leqslant 127$ ). This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7 ) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction-which may be used to sample interface devices-allows the overflow flag to reflect the condition of bit 6 in the sampled field. During a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions affecting the $V$ flag are ADC, BIT, CLV, PLP, RTI and SBC.

### 3.8.7 Negative Bit ( N )

The Negative Bit ( $N$ ) is used to indicate that the sign bit (bit 7) in the resulting value of a data movement or data arithmetic operation is set to logic 1 . If the sign bit is set to logic 1, the resulting value of the data movement or arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

## SECTION 4 PARALLEL INPUT/OUTPUT PORTS \& BUS MODES

The devices have 32 I/O lines grouped into four 8-bit ports (PA, PB, PC, and PD). Ports A through C may be used either for input or output individually or in groups of any combination. Port D may be used as all inputs or all outputs.

Multifunction I/O's such as Port A and Port C are protected from normal port I/O instructions when they are programmed to perform a multiplexed function.

Internal pull-up resistors (FET's with an impedance range of $3 K \leqslant R_{L} \leqslant 12 K$ ohm) are provided on all port pins except Port D.

The direction of the 32 I/O lines are controlled by four 8-bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the $I / O$ ports, thus simplifying I/O handling. The I/O addresses are shown in Table 4-1. Appendix E. 4 shows the I/O Port Timing.

Table 4-1. I/O Port Addresses

| PORT | ADDRESS |
| :---: | :---: |
| A | 0000 |
| B | 0001 |
| D | 0002 |
|  | 0003 |

### 4.1 INPUTS

Inputs for Ports A, B, and C are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to $\mathrm{I} / \mathrm{O}$ input lines. A low $(<0.8 \mathrm{~V})$ input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high ( $>2.0 \mathrm{~V}$ ) input will cause ajogic 1 to be read. An $\overline{\text { RES }}$ signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

Port D may only be all inputs or all outputs. All inputs is selected by setting bit 5 of the Mode Control Register (MCR5) to a " 0 ".

The status of the input lines can be interrogated at any time by reading the I/O port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers.

Read/Modify/Write instructions can be used to modify the operation of PA, PB, PC, \& PD. During the Read cycle of a Read/Modify/Write instruction the Port I/O register is read. For all other read instructions the port input lines are read. Read/Modify/Write instructions are: ASL, DEC, INC, LSR, RMB, ROL, ROR, and SMB.

### 4.2 OUTPUTS

Outputs for Ports A thru D are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( $>2.4 \mathrm{~V}$ ) output while a logic 0 will force a low ( $<0.4 \mathrm{~V}$ ) output.

Port D all outputs is selected by setting MCR5 to a " 1 ".

### 4.3 Port A (PA)

Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as a standard parallel 8-bit, bit independent, I/O port or as serial channel I/O lines, counter I/O lines, or an input data strobe for the Port B input latch option. Table 4-2 tabulates the control and usage of Port A.

In addition to their normal I/O functions, PAO and PA1 can detect positive going edges and PA2 and PA3 can detect negative going edges. A proper transition on these pins will set a corresponding status bit in the IFR and generate an interrupt request if the respective Interrupt Enable Bit is set. The maximum rate at which an edge can be detected is onehalf the $\varnothing 2$ clock rate. Edge detection timing is shown in Appendix E.3.

Table 4-2. Port A Control and Usage


### 4.4 PORT B (PB)

Port B can be programmed as an 8-bit, bit-independent I/O port. It has a latched input capability which may be enabled or disabled via the Mode Control Register (MCR). Table 4-3 tabulates the control and usage of Port B. An Input Data Strobe signal must be provided thru PAO when Port B is programmed to be used with latched input option. Input data latch timing for Port $B$ is shown in Appendix E.3.

Table 4-3. Port B Control \& Usage

|  |  | I/O MODE |  | LATCH MODE |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MCR4 $=0$ |  | $\text { MCR } 4=1$ <br> (2) |  |
| $\begin{gathered} \text { PIN } \\ \# \end{gathered}$ | PIN NAME | SIGNAL |  | SIGNAL |  |
|  |  | NAME | TYPE <br> (1) | NAME | TYPE |
| 31 | PBO | PB0 | $1 / 0$ | PBO | INPUT |
| 30 | PB1 | PB1 | 1/0 | PB1 | INPUT |
| 29 | PB2 | PB2 | 1/0 | PB2 | INPUT |
| 28 | PB3 | PB3 | 1/0 | PB3 | INPUT |
| 27 | PB4 | PB4 | 1/0 | PB4 | INPUT |
| 26 | PB5 | PB5 | 1/0 | PB5 | INPUT |
| 25 | PB6 | PB6 | $1 / 0$ | PB6 | INPUT |
| 24 | PB7 | PB7 | 1/0 | PB7 | INPUT |

(1) RESISTIVE PULL-UP, ACTIVE BUFFER PULL DOWN
(2) INPUT DATA IS STORED IN PORT B LATCH BY PAO PULSE


Figure 4-1a. Full Address Mode

### 4.5 PORT C (PC)

Port C can be programmed as an I/O port, or as part of the full address bus. When operating in the Full Address Mode PC6 and PC7 serve as A13 and A14 with PC0-PC5 operating as normal I/O pins.

### 4.6 PORT D (PD)

Port D can be programmed as an I/O Port. Mode selection for Port $D$ is made by the Mode Control Register (MCR). The Port D output drivers can be selected as tri-state drivers by setting bit 5 of the MCR to 1 (one). Table 4-5 shows the necessary settings for the MCR to achieve the various modes for Port D.

### 4.7 BUS MODES

In the Full Address Mode, the separate address and data bus are used in conjunction with PC6 and PC7, which automatically provide A13 and A14. The remaining ports perform the normal I/O function.

In the I/O Bus Mode all ports serve as I/O. The address and data bus are still functional but without A13 and A14. Since the internal RAM and registers are in the OOXX location, A15 can be used for chip select and AO-A12 used for selecting 8 K of external memory.


Figure 4-1b. Normal Bus Mode

Table 4-4. Port C Control and Usage


## NOTES:

1. Resistive Pull-Up, Active Buffer Pull-Down
2. Active Buffer Pull-Up and Pull-Down

Table 4-5. Port D Control and Usage

|  |  | I/O MODES |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { MCR7 }=0 \\ & \text { MCR6 }=X \\ & \text { MCR5 }=0 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=0 \\ & \text { MCR6 }=\mathrm{X} \\ & \text { MCR5 }=1 \end{aligned}$ |  |
|  | $\begin{aligned} & \text { PIN } \\ & \text { NAME } \end{aligned}$ | SIGNAL |  | SIGNAL |  |
| PIN \# |  | NAME | TYPE <br> (1) | NAME | TYPE <br> (2) |
| 62 | PDO | PDO | INPUT | PDO | OUTPUT |
| 63 | PD1 | PD1 | INPUT | PD1 | OUTPUT |
| 64 | PD2 | PD2 | INPUT | PD2 | OUTPUT |
| 1 | PD3 | PD3 | INPUT | PD3 | OUTPUT |
| 2 | PD4 | PD4 | INPUT | PD4 | OUTPUT |
| 3 | PD5 | PD5 | INPUT | PD5 | OUTPUT |
| 4 | PD6 | PD6 | INPUT | PD6 | OUTPUT |
| 5 | PD7 | PD7 | INPUT | PD7 | OUTPUT |

NOTES:

1. Tri-State Buffer is in High Impedance Mode
2. Tri-State Buffer is in Active Mode

# SECTION 5 SERIAL INPUT/OUTPUT CHANNEL 

The device provides a full duplex Serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 5-1. The serial bit rate is determined by Counter A for all modes except the Receiver Shift Register (RCVR S/R) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5 K bits per second (at $\phi 2=1 \mathrm{MHZ}$ ). The transmitter (XMTR) and receiver (RCVR) can be independently programmed to operate in different modes and can be independently enabled or disabled.


Figure 5-1. Serial Communication Control Register

Except for the Receiver Shift Register Mode (RCVR S/R), all XMTR and RCVR bit rates will occur at one sixteenth of the Counter $\mathbf{A}$ interval timer rate. Counter A is forced into an interval timer mode whenever the serial $I / O$ is enabled in a mode requiring an internal clock.

Whenever Counter $A$ is required as a timing source it must be loaded with the hexadecimal code that selects the data rate for the serial I/O Port. Refer to Counter A (paragraph 6.1) for a table of hexadecimal values to represent the desired data rate.

### 5.1 TRANSMITTER OPERATION (XTMR)

The XTMR operation and the transmitter related control/ status functions are enabled by bit 7 of the Serial Communications Control Register (SCCR). The transmitter, when in the Asynchronous (ASYN) mode, automatically adds a start bit, one or two stop bits, and, when enabled, a parity bit to the transmitted data. A word of transmitted data (in asynchronous parity mode) can have $5,6,7$, or 8 bits of data. The nine data modes are shown in Figure 5-2. When parity is disabled, the $5,6,7$ or 8 bits of data are terminated with two stop bits.



Figure 5-2. SIO Data Modes
In the S/R mode, eight data bits are always shifted out. Bits/ character and parity control bits are ignored. The serial data is shifted out via the SO output (PA6) and the shift clock is available at the CA (PA4) pin. When the transmitter underruns in the S/R mode the SO output and shift clock are held in a high state.

The XMTR Interrupt Flag bit (IFR7) is controlled by Serial Communication Status Register bits SCSR5, SCSR6 and SCSR7.

$$
\text { IFR7 }=\text { SCSR6 }(\overline{\text { SCSR5 }}+\text { SCSR7 })
$$

### 5.2 RECEIVER OPERATION (RCVR)

The receiver and its selected control and status functions are enabled when SCCR-6 is set to a " 1. ." In the ASYN mode, data format must have a start bit, the appropriate number of data bits, a parity bit (if enabled), and one stop bit. Refer to paragraph 5.1 for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start bit and a strobe signal is generated at the approximate center of each incoming bit. Refer to Figure 5-3 for ASYN Receive Data Timing. The character assembly process does not start if the start bit signal is less than one-half the bit time after a low level is detected on the Receive Data Input. Framing error, over-run, and parity error conditions or a RCVR Data Register Full will set the appropriate status bits. Any of the above conditions will cause an Interrupt Request if the Receiver Interrupt Enable bit is set to logic 1.

*Serial Input Data Snifted In
Figure 5-3. ASYN Receive Data Timing

In the S/R mode, an external shift clock must be provided at CA (PA4) pin along with 8 bits of serial data (LSB first) at the SI input (PA7). The maximum data rate using an external shift clock is one-eighth the internal clock rate. Refer to Figure 5-4 for S/R Mode Timing.


- Serial Input Data Shifted In
*Serial Output Data Makes Transition
Figure 5-4. S/R Mode Timing

A RCVR interrupt (IFR6) is generated whenever any of SCSR0-3 are true.

### 5.3 SERIAL COMMUNICATION STATUS REGISTER (SCSR)

The Serial Communication Status Register (SCSR) holds information on various communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 5-5. Bit assignments and functions of the SCSR are as follows:

SCSR 0: Receiver Data Register Full-Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by $\overline{\text { RES }}$ and is disabled if SCCR $6=0$. The SCSR 0 bit will not be set to a logic 1 if the received data contains an error condition; instead, a corresponding error bit will be set to a logic 1.

SCSR 1: Over-Run Error-Set to a logic 1 when a new character is transferred from the Receiver Shift Register with the last character still in the Receiver Data Register. This bit is cleared by reading the Receiver Data Register or by $\overline{\mathrm{RES}}$.

SCSR 2: Parity Error-Set to logic 1 when the RCVR is in the ASYN Mode, Parity Enable bit is set, and the
received data has a parity error. This bit is cleared by reading the Receiver Data Register or by RES.
SCSR 3: Framing Error-Set to a logic 1 when the received data contains a zero bit after the last data or parity bit in the stop bit slot. Cleared by reading the Receiver Data Register or by RES (ASYN Mode only).
SCSR 4: Wake-Up-Set to a logic 1 by writing a " 1 " in bit 4 of address: 0016. The Wake-Up bit is cleared by $\overline{\text { RES }}$ or when the receiver detects a string of ten consecutive 1's. When the Wake-Up bit is set SCSR0 through SCSR3 are inhibited.
SCSR 5: End of Transmission-Set to a logic 1 by writing a " 1 " in bit position 5 of address: 0016. The End of Transmission bit is cleared by RES or upon writing a new data word into the Transmitter Data Register. When the End-of-Transmission bit is true the Transmitter Register Empty bit is disabled until a Transmitter Under-Run occurs.
SCSR 6: Transmitter Data Register Empty-Set to a logic 1 when the contents of the Transmitter Data Register are transferred to the Transmitter Shift Register. Cleared upon writing new data into the Transmit Data Register. This bit is initialized to a logic 1 by $\overline{\mathrm{RES}}$.
SCSR 7: Transmitter Under-Run-Set to a logic 1 when the last data bit is transmitted if the transmitter is in a S/R Mode or when the last stop bit is transmitted if the XMTR is in the ASYN Mode while the Transmitter Data Register Empty Bit is set. Cleared by a transfer of new data into the Transmitter Shift Register or by $\overline{\text { RESS }}$.


Figure 5-5. SCSR Bit Allocations

### 5.4 WAKE-UP FEATURE

In a multi-distributed microprocessor or microcomputer appliations, a destination address is usually included at the beginning of the message. The Wake-Up Feature allows non-selected CPU's to ignore the remainder of the message until the beginning of the next message by setting the Wake-Up bit. As long as the Wake-Up flag is true, the Receiver Data Register Full Flag remains false. The Wake-Up bit is automatically cleared when the receiver detects a string of eleven consecutive 1 's which indicates an idle transmit line. When the next byte is received, the Receiver Data Register Full Flag signals the CPU to wake-up and read the received data.

## SECTION 6 COUNTER/TIMERS

The device contains two 16-bit counters (Counter A and Counter B) and three 16 -bit latches associated with the counters. Counter $A$ has one 16 -bit latch and Counter $B$ has two 16-bit latches. Each counter can be independently programmed to operate in one of four modes:

## Counter A

- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Counter


## Counter B

- Retriggerable Interval Counter
- Asymmetrical Pulse Generation
- Interval Timer
- Event Counter

Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4.2).

### 6.1 COUNTER A

Counter A consists of a 16 -bit counter and a 16 -bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contains the count of either $\emptyset 2$ clock pulses or external events, depending on the counter mode selected. The contents of Counter A may be read any time by executing a read at location 0019 for the Upper Counter A and at location 001A or location 0018 for the Lower Counter A: A read at location 0018 also clears the Counter A Underflow Flag (IFR4).

The 16 -bit latch contains the counter initialization value and can be loaded at any time by executing a write to the Upper Latch A at location 0019 and the Lower Latch $A$ at location 0018. In either case, the contents of the accumulator are copied into the applicable latch register.

Counter A can be started at any time by writing to address: 001A. The contents of the accumulator will be copied into the


Figure 6-1. Interval Timer Timing Diagram

Upper Latch A before the contents of the 16-bit latch are transferred to Counter $A$. Counter $A$ is set to the latch value whenever Counter A underflows. When Counter A decrements from 0000 the next counter value will be the latch value-not FFFF-and the Counter A Underflow Flag (IFR $4)$ will be set to "1". This bit may be cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by $\overline{\text { RES. }}$

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

| MCR1 <br> (bit 1) | MCRO <br> (bit 0) | Mode |
| :---: | :---: | :---: |
| 0 | 0 | Interval Timer |
| 0 | 1 | Pulse Generation |
| 1 | 0 | Event Counter |
| 1 | 1 | Pulse Width Measurement |

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

The Counter is set to the Interval Timer Mode (00) when a $\overline{R E S}$ signal is generated.

### 6.1.1 Interval Timer

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:

1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the 02 clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore $1 \mu \mathrm{~s}$ to 65.535 ms at the $1 \mathrm{MHz} \emptyset 2$ clock rate or $0.5 \mu \mathrm{~s}$ to 32.767 ms at the $2 \mathrm{MHz} \emptyset 2$ clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting $\overline{\mathrm{IRQ}}$ interrupt requests in the counter $\overline{\mathrm{RQ}}$ interrupt routine.

When Counter A decrements from 0000, the Counter A Underflow (IFR4) is set to logic 1. If the Counter A Interrupt Enable Bit (IER4) is also set, an IRQ interrupt request will be generated. The Counter A Underflow bit in the Interrupt Flag Register can be examined in the $\overline{\mathrm{RQ}}$ interrupt routine to determine that the $\overline{\mathrm{RQ}}$ was generated by the Counter A Underflow.

While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.

### 6.1.2 Pulse Generation Mode

In the Puise Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs or a write is performed to address 001A.

The normal output waveform is a symmetrical square-wave. The CA output is initialized high when entering the mode and transitions low when writing to 001A.

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

### 6.1.3 Event Counter Mode

In this mode the CA is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the $\varnothing 2$ clock rate.

The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter A Underflow bit (IER4) is set to logic 1 if the underflow occurs.

Figure 6.2 is a timing diagram of the Event Counter Mode.


Figure 6-2. Event Counter Mode

### 6.1.4 Pulse Width Measurement Mode

This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the $\phi 2$ clock rate as long as the CA line is held in the low state. The Counter is stopped when CA is in the high state.

The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4.

A timing diagram for the Pulse Width Measurement Mode is shown in Figure 6.3.


Figure 6-3. Pulse Width Measurement

### 6.1.5 Serial I/O Data Rate Generation

Counter A also provides clock timing for the Serial I/O which establishes the data rate for the Serial I/O port. When the Serial I/O is enabled, Counter A is forced to operate at the internal clock rate. Counter $A$ is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4-2).

Table 6-1 identifies the values to be loaded in Counter A for selecting standard data rates with a $\phi 2$ clock rate of 1 MHz and 2 MHz . Although Table 6-1 identifies only the more common data rates, any data rate from 1 to 62.5 K bps can be selected by using the formula:

$$
N=\frac{\phi 2}{16 \times \mathrm{bps}}-1
$$

where

$$
\begin{aligned}
& \mathrm{N} \quad= \text { decimal value to be loaded into Counter } \mathrm{A} \text { using } \\
& \text { its hexadecimal equivalent. } \\
& \phi 2=\text { the clock frequency ( } 1 \mathrm{MHz} \text { or } 2 \mathrm{MHz}) \\
& \mathrm{bps}=\text { the desired data rate. }
\end{aligned}
$$

## NOTE

In Table 6-1 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of $1.5 \%$ or less are acceptable. A revised clock rate is included in Table 6-1 for those baud rates which fall outside this limit.

Table 6-1. Counter A Values for Baud Rate Selection

| STANDARD BAUD RATE | HEXADECIMAL VALUE |  | 03 <br> ACTUAL BAUD RATE AT |  | CLOCK RATE <br> NEEDED TO GET STANDARD BAUD RATE |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1 MHz | 2 MHz | 1 MHz | 2 MHz | 1 MHz | 2 M |
| 50 | 04E1 | 09C3 | 50.00 | 50.00 | 1.0000 | 2.0000 |
| 75 | 0340 | 0682 | 75.03 | 74.99 | 1.0000 | 2.0000 |
| 110 | 0237 | 046F | 110.04 | 110.04 | 1.0000 | -2.0000 |
| 150 | 01A0 | 0340 | 149.88 | 150.06 | 1.0000 | 2.0000 |
| 300 | 00CF | 01A0 | 300.48 | 299.76 | 1.0000 | 2.0000 |
| 600 | 0067 | 00CF | 600.96 | 600.96 | 1.0000 | 2.0000 |
| 1200 | 0033 | 0067 | 1201.92 | 1201.92 | 1.0000 | 2.0000 |
| 2400 | 0019 | 0033 | 2403.85 | 2403.85 | 1.0000 | 2.0000 |
| 3600 | 0010 | 0021 | 3676.47 | 3676.47 | 0.9792 | 1.9584 |
| 4800 | 000C | 0019 | 4807.69 | 4807.69 | 1.0000 | 2.0000 |
| 7200 | 0008 | 0010 | 6944.44 | 7352.94 | 1.0368 | 1.9584 |
| 9600 | 0006 | 000C | 8928.57 | 9615.38 | 1.0752 | 2.0000 |

### 6.2 COUNTER B

Counter B consists of a 16 -bit counter and two 16 -bit latches organized as follows: Lower Counter B (LCB), Upper Counter B (UCB), Lower Latch B (LLB), Upper Latch B (ULB), Lower Latch C (LLC), and Upper Latch C (ULC). Latch C is used only in the asymmetrical pulse generation mode. The counter contains the count of either $\varnothing 2$ clock pulses or external events depending on the counter mode selected. The contents of Counter B may be read any time by executing a Read at location 001D for the Upper Counter B and at location 001E or 001C for the Lower Counter B. A Read at location 001 C also clears the Counter B Underflow Flag.

Latch B contains the counter initialization value and can be loaded at any time by executing a Write to the Upper Latch $B$ at location 001D and the Lower Latch B at location 001C. In each case, the contents of the accumulator are copied into the applicable latch register.

Counter B can be initialized at any time by writing to address: 001 E . The contents of the accumulator is copied into the Upper Latch $B$ before the value in the 16 -bit Latch $B$ is transferred to Counter B. Counter B will also be set to the latch value and the Counter B Underflow Flag bit (IFR5), will be set to a "1" whenever Counter B underflows by decrementing from 0000.

IFR 5 may be cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by $\overline{\text { RES. }}$

Counter B operates in the same manner as Counter $A$ in the Interval Timer and Event Counter modes. The Pulse Width Measurement Mode is replaced by the Retriggerable Interval Timer mode and the Pulse Generation mode is replaced by the Asymmetrical Pulse Generation Mode. Mode Control Register bits MCR2 and MCR3 select the four Counter B modes in a similar manner and coding as MCRO and MCR1 select the modes of Counter $A$.

### 6.2.1 Retriggerable Interval Timer Mode

When operating in the Retriggerable Interval Timer mode, Counter $B$ is initialized to the latch value by writing to address 001E, by a Counter B underflow, or whenever a positive edge occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the CB line. Figure 6-4 illustrates the operation.


Figure 6-4. Counter B Retriggerable Interval Timer Mode

### 6.2.2 Asymmetrical Pulse Generation Mode

Counter B has a special Asymmetrical Pulse Generation Mode whereby a pulse train with programmable pulse width and period can be generated without the processor intervention once the latch values are initialized.

In this mode, the 16 -bit Latch $B$ is initialized with a value which corresponds to the duration between pulses (referred to as $D$ in the following descriptions). The 16 -bit Latch $C$ is initialized with a value corresponding to the desired pulse width (referred to as $P$ in the following descriptions). The initialization sequence for Latch B and C and the starting of a counting sequence are as follows:

1. The lower 8 bits of $P$ are loaded into LLB by writing to address 001C; the upper 8 bits of $P$ are loaded into ULB and the full 16 bits are transferred to Latch C by writing to address location 001D. At this point both Latch B and Latch C contain the value of $P$.
2. The lower 8 bits of $D$ are loaded into LLB by writing to address 001 C ; the upper 8 bits of $D$ are loaded into ULB by writing to address location 001E. Writing to address location 001E also causes the contents of the 16 -bit Latch $B$ to be downloaded into the Counter B and the CB output to go low as shown in Figure 6-5.
3. When Counter $B$ underflow occurs the contents of the Latch C are loaded into the Counter B and the CB output toggles to a high level, staying high until another underflow occurs. Latch $B$ is then down-loaded and the CB output toggles to a low level repeating the whole process.

## SECTION 7 <br> POWER ON/INITIALIZATION CONSIDERATIONS

### 7.1 POWER ON TIMING

After application of $V_{C C}$ and $V_{R R}$ power to the device, $\overline{R E S}$ must be held low for at least eight $\phi 2$ clock cycles after $V_{c c}$ reaches operating range and the internal oscillator has stabilized. This stabilization time is dependent upon the input $\mathrm{V}_{\mathrm{cc}}$ voltage and performance of the internal oscillator. The clock can be monitored at $\phi 2$ (pin 3). Figure 7-1 illustrates the power turn-on waveforms. Clock stabilization time is typically 20 ms .


Figure 7-1. Power Turn-On Timing Detail

### 7.2 POWER-ON RESET

When $\overline{\text { RES }}$ goes from low to high, the device sets the Interrupt Mask Bit-bit 2 of the Processor Status Registerand initiates a reset vector fetch at address FFFC and FFFD to begin user program execution. All of the I/O ports (PA, PB, PC, PD) will be forced to the high (logic 1) state. All bits of the Control Register will be cleared to logic 0 causing the interval Timers counter mode (mode 00) to be selected and all interrupt enabled bits to be reset.

183. Counter $B \rightarrow$ Latch $B$ (D)

2*4. Counter $B \longrightarrow$ Latch $C(P)$

Figure 6-5. Counter B Pulse Generation

### 7.3 RESET ( $\overline{\mathrm{RES}})$ CONDITIONING

When $\overline{\text { RES }}$ is driven from low to high the device is put in a reset state causing the registers and I/O ports to be configured as shown in Table 7-1.

Table 7-1. $\overline{R E S}$ Initialization of I/O Ports and Registers

|  | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| REGISTERS |  |  |  |  |  |  |  |  |
| Processor Status | - | - | - | - | - | 1 | - | - |
| Mode Control (MCR) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Int. Enable (IER) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Int. Flag (IFR) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Ser. Com. Control (SCCR) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Ser. Com. Status (SCSR) | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| PORTS |  |  |  |  |  |  |  |  |
| PA Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PB Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PC Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PD Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

All RAM and other CPU registers will initialize in a random, non-repeatable data pattern.

### 7.4 INITIALIZATION

Any initialization process for the device should include a RES, as indicated in the preceeding paragraphs. After stabilization of the internal clock (if a power on situation) an initialization routine should be executed to perform (as a minimum) the following functions:

1. The Stack Pointer should be set
2. Clear or Set Decimal Mode
3. Set or Clear Carry Flag
4. Set up Mode Controls as required
5. Clear Interrupts

A typical initialization subroutine could be as follows:
LDX Load stack pointer starting address into X Register
TXS Transfer X Register value to Stack Pointer
CLD Clear Decimal Mode
SEC Set Carry Flag
. . . . Set-up Mode Control and
. . . . special function registers
. . . and clear RAM as required
CLI Clear Interrupts

# APPENDIX A <br> ENHANCED R6502 INSTRUCTION SET 


#### Abstract

This appendix contains a summary of the Enhanced R6502 instruction set. For detailed information, consult the R6502 Microcomputer System Programming Manual, Document 29650 N30. The four instructions notated with a * are added instructions to enhance the standard 6502 instruction set.


## A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE

| ADC | Add Memory to Accumulator with Carry | LDA | Load Accumulator with Memory |
| :---: | :---: | :---: | :---: |
| AND | "AND" Memory with Accumulator | LDX | Load Index X with Memory |
| ASL | Shift Left One Bit (Memory or Accumulator) | LDY | Load Index Y with Memory |
|  |  | LSR | Shift One Bit Right (Memory or |
| *BBR | Branch on Bit Reset Relative |  | Accumulator) |
| *BBS | Branch on Bit Set Relative |  |  |
| BCC | Branch on Carry Clear | NOP | No Operation |
| BCS | Branch on Carry Set |  |  |
| BEQ | Branch on Result Zero | ORA | "OR" Memory with Accumulator |
| BIT | Test Bits in Memory with Accumulator |  |  |
| BMI | Branch on Result Minus | PHA | Push Accumulator on Stack |
| BNE | Branch on Result not Zero | PHP | Push Processor Status on Stack |
| BPL | Branch on Result Plus | PLA | Pull Accumulator from Stack |
| BRK | Force Break | PLP | Pull Processor Status from Stack |
| BVC | Branch on Overflow Clear |  |  |
| BVS | Branch on Overflow Set | *RMB | Reset Memory Bit |
|  |  | ROL | Rotate One Bit Left (Memory or |
| CLC | Clear Carry Flag |  | Accumulator) |
| CLD | Clear Decimal Mode | ROR | Rotate One Bit Right (Memory or |
| CLI | Clear Interrupt Disable Bit |  | Accumulator) |
| CLV | Clear Overflow Flag | RTI | Return from Interrupt |
| CMP | Compare Memory and Accumulator | RTS | Return from Subroutine |
| CPX | Compare Memory and Index X |  |  |
| CPY | Compare Memory and Index Y | SBC | Subtract Memory from Accumulator with Borrow |
| DEC | Decrement Memory by One | SEC | Set Carry Flag |
| DEX | Decrement Index $X$ by One | SED | Set Decimal Mode |
| DEY | Decrement Index Y by One | SEI | Set Interrupt Disable Status |
|  |  | *SMB | Set Memory Bit |
| EOR | "Exclusive-Or" Memory with | STA | Store Accumulator in Memory |
|  | Accumulator | STX | Store Index X in Memory |
|  |  | STY | Store Index Y in Memory |
| INC | Increment Memory by One |  |  |
| INX | Increment Index X by One | TAX | Transfer Accumulator to Index X |
| INY | Increment Index Y by One | TAY | Transfer Accumulator to Index Y |
|  |  | TSX | Transfer Stack Pointer to Index X |
| JMP | Jump to New Location | TXA | Transfer Index X to Accumulator |
| JSR | Jump to New Location Saving Return | TXS | Transfer Index $X$ to Stack Register |
|  | Address | TYA | Transfer Index Y to Accumulator |



## A. 3 INSTRUCTION CODE MATRIX




[^9]
## APPENDIX B KEY REGISTER SUMMARY



CPU Registers


Serial Communications Control Register


Processor Status Register


Counter A
Underfiow Flag
Counter B Underflow Flag

Flag
XMTR
Flag
Interrupt Enable and Flag Registers


XMTR Data Reg Empty
XMTR Under-Run
Serial Communications Status Register

## APPENDIX C ADDRESS ASSIGNMENTS/MEMORY MAPS/PIN FUNCTIONS

## C. 1 I/O AND INTERNAL REGISTER ADDRESSES

| ADDRESS (HEX) | READ | WRITE |
| :---: | :---: | :---: |
| $\begin{array}{r} 001 F \\ 1 E \\ 1 D \\ 1 C \end{array}$ | Lower Counter B <br> Upper Counter B Lower Counter B, CLR Flag | Upper Latch B, Cntr B↔Latch B, CLR Flag Upper Latch B, Latch C $\leftarrow$ Latch B Lower Latch B. |
| $\begin{aligned} & 1 B \\ & 1 A \\ & 19 \\ & 18 \end{aligned}$ | Lower Counter A <br> Upper Counter A Lower Counter A, CLR Flag | Upper Latch A, Cntr A↔Latch A, CLR Flag Upper Latch A Lower Latch A |
| $\begin{aligned} & 17 \\ & 16 \\ & 15 \\ & 14 \end{aligned}$ | Serial Receiver Data Register Serial Comm. Status Register Serial Comm. Control Register Mode Control Register | Serial Transmitter Data Register <br> Serial Comm. Status Reg. Bits 4 \& 5 only <br> Serial Comm. Control Register <br> Mode Control Register |
| $\begin{array}{r} 13 \\ 12 \\ 11 \\ 0010 \end{array}$ | Interrupt Enable Register Interrupt Flag. Register Read FF | Interrupt Enable Register <br> Clear Int Flag (Bits 0-3 only, Write 0's only) |
| $\begin{aligned} & O F \\ & O E \\ & O D \\ & O C \end{aligned}$ | RESERVED <br> These addresses are reserved and are used by the CPU during Read and Write operation over the external Data Bus (D0-D7). |  |
| $\begin{aligned} & \hline \text { OB } \\ & 0 A \\ & 09 \\ & 08 \\ & \hline \end{aligned}$ |  |  |
| $\begin{aligned} & 07 \\ & 06 \\ & 05 \\ & 04 \end{aligned}$ |  |  |
| $\begin{array}{r} 03 \\ 02 \\ 01 \\ 0000 \end{array}$ | Port D <br> Port C <br> Port B <br> Port A | Port D <br> Port C <br> Port B <br> Port A |

## C. 2 FULL ADDRESS MODE MEMORY MAP <br> R6501Q



## C. 4 MULTIPLE FUNCTION PIN ASSIGNMENTS -PORT C AND PORT D

| PIN <br> NUMBER | FULL ADDRESS <br> MODE | I/O PORT |
| :---: | :---: | :---: |
| FUNCTION |  |  |$|$| 54 | PC0 | PC0 |
| :---: | :---: | :---: |
| 55 | PC1 | PC1 |
| 56 | PC2 | PC2 |
| 57 | PC3 | PC4 |
| 58 | PC4 | PC5 |
| 59 | PC5 | PC6 |
| 60 | A13 | PC7 |
| 61 | A14 | PD0 |
| 62 | PD0 | PD1 |
| 63 | PD1 | PD2 |
| 64 | PD2 | PD3 |
| 1 | PD3 | PD4 |
| 2 | PD4 | PD5 |
| 3 | PD5 | PD6 |
| 5 | PD6 | PD7 |
|  | PD7 |  |

## APPENDIX D ELECTRICAL SPECIFICATIONS

Maximum Ratings

| RATING | SYMBOL | VALUE | UNIT |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}} \& \mathrm{~V}_{\text {AR }}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.3 to +7.0 | Vdc |
| Operating Temperature Range, Commercial |  | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

NOTE: 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 \mathrm{~V} \pm 5 \% ; V_{R R}=V_{c c} ; V_{S S}=0 ; T A=0\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| CHARACTERISTIC | SYMBOL | MIN | TYP | MAX | UNIT |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipation (Outputs High) Commercial @ $0^{\circ} \mathrm{C}$ | $P_{0}$ | - | $750^{(1)}$ | 1100 | mW |
| RAM Standby Voltage (Retention Mode) | $V_{\text {RR }}$ | 3.0 | - | $\mathrm{V}_{\text {cc }}$ | Vdc |
| RAM Standby Current (Retention Mode) Commercial @ $25^{\circ} \mathrm{C}$ | $\mathrm{I}_{\text {RR }}$ | - | 4 | - | mAdc |
| Input High Voltage (Except XTLI) | $\mathrm{V}_{\mathrm{IH}}$ | +2.0 | - | $V_{c c}$ | Vdc |
| Input High Voltage (XTLI) | $\mathrm{V}_{\text {IH }}$ | +4.0 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Input Low Voltage | $\mathrm{V}_{\mathrm{L}}$ | -0.3 | - | +0.8 | Vdc |
| input Leakage Current ( $\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}$ ) $V_{\text {in }}=0 \text { to } 5.0 \mathrm{Vdc}$ | $\mathrm{I}_{\text {IN }}$ |  |  | $\pm 10.0$ | $\mu \mathrm{Adc}$ |
| Input Low Current PA, PB, PC, PD $\left(\mathrm{V}_{\mathrm{lL}}=0.4 \mathrm{Vdc}\right)$ | $1 / 1$ | - | -1.0 | -1.6 | mAdc |
| Output High Voltage (Except XTLO) $\left(L_{\text {Load }}=.100 \mu \mathrm{~A} d c\right)$ | $\mathrm{V}_{\mathrm{OH}}$ | +2.4 | - | $V_{c c}$ | Vdc |
| Output Low Voltage $\left(I_{\text {Load }}=1.6 \mathrm{mAdc}\right)$ | $\mathrm{V}_{0}$ | - | - | +0.4 | Vdc |
| ```Input Capacitance ( \(\mathrm{V}_{\text {in }}-0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\) ) XTLI, XTLO All Others``` | $\mathrm{C}_{\mathrm{in}}$ | - | - | $\begin{aligned} & 50 \\ & 10 \\ & \hline \end{aligned}$ | pF |
| I/O Port Pull-Up Resistance PA0-PA7, PB0-PB7, PC0-PC7 | $\mathrm{R}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | $K \Omega$ |
| Output Leakage Current Tri-State I/O's while in High Impedance State | $\mathrm{l}_{\text {out }}$ | - | - | $\pm 10$ | $\mu$ Adc |
| Output Capacitance <br> Tri-State I/O's while in High Impedance State $V_{\text {IN }}=O V, T A=25^{\circ} \mathrm{C}, f=1.0 \mathrm{MHz}$ | $\mathrm{C}_{\text {out }}$ | - | - | 10 | pF |

NOTE: Negative sign indicates outward current flow, positive indicates inward flow.
(1) at $25^{\circ} \mathrm{C}$

## APPENDIX E <br> TIMING REQUIREMENTS AND CHARACTERISTICS

## E. 1 GENERAL NOTES

1. $V_{\mathrm{cc}}=5 \mathrm{~V} \pm 5 \%, 0^{\circ} \mathrm{C} \leqslant \mathrm{TA} \leqslant 70^{\circ} \mathrm{C}$
2. A valid $V_{c c}-\overline{R E S}$ sequence is required before proper operation is achieved.
3. All timing reference levels are 0.8 V and 2.0 V , unless otherwise specified.
4. All time units are nanoseconds, unless otherwise specified.
5. All capacitive loading is 130pf maximum, except as noted below:

| PA, PB | - 50 pf maximum |
| :--- | :--- |
| PC (I/O Modes Only) | - 50 pf maximum |
| PC (ABB and Mux Mode) | - 130 pf maximum |
| PC6, PC7 (Full Address Mode) | - 130 pf maximum |

## E. 2 CLOCK TIMING

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| Tcrc | Cycle Time | 1000 | $10 \mu \mathrm{~s}$ | 500 | $10 \mu \mathrm{~s}$ |
| $\mathrm{T}_{\mathrm{PW} \times 1}$ | XTLI Input Clock <br> Pulse Width <br> XTLO = VSS | $\begin{gathered} 500 \\ \pm 25 \end{gathered}$ | - | $\begin{aligned} & 250 \\ & \pm 10 \end{aligned}$ | - |
| Tewoz | Output Clock Pulse Width at Minimum Tcyc | $\mathrm{T}_{\text {pwx }}$ | $\begin{aligned} & T_{p w \times 1} \\ & \pm 25 \end{aligned}$ | $\mathrm{T}_{\text {Pwx1 }}$ | $\begin{aligned} & T_{p w x} \\ & \pm 20 \end{aligned}$ |
| $\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}$ | Output Clock Rise, Fall Time | - | 25 | - | 15 |
| $\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}$ | Input Clock Rise, Fall Time | - | 10 | - | 10 |



## E. 3 I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
|  | Internal Write to Peripheral Data Valid <br> PA, PB, PC TTL <br> PA, PB, PC CMOS <br> PD | - | $\begin{array}{r} 500 \\ 1000 \\ 175 \end{array}$ | - | 500 1000 150 |
| $\begin{aligned} & T_{\text {posu }} \\ & T_{\text {posu }} \end{aligned}$ | Peripheral Data Setup Time $\mathrm{PA}, \mathrm{~PB}, \mathrm{PC}$ $P D$ | $\begin{array}{r} 200 \\ 50 \\ \hline \end{array}$ | - | $\begin{array}{r} 200 \\ 50 \end{array}$ | - |
| $\begin{aligned} & \mathrm{T}_{\text {PHR }} \\ & \mathrm{T}_{\text {PHR }} \end{aligned}$ | Peripheral Data Hold Time $\mathrm{PA}, \mathrm{~PB}, \mathrm{PC}$ PD | $\begin{aligned} & 75 \\ & 10 \\ & \hline \end{aligned}$ | - | 75 10 | - |
| $\mathrm{T}_{\text {EPW }}$ | PA0-PA3 Edge Detect Pulse | Tcrc | - | Tcrc |  |
| $\begin{aligned} & T_{\text {cpw }} \\ & T_{\text {cD }}{ }^{(1)} . \end{aligned}$ | Counters A and B <br> PA4, PA5 Input Pulse Width PA4, PA5 Output Delay. | Tcrc |  | Tcyc | $\overline{500}$ |
| $T_{\text {petw }}$ <br> Tplsu <br> $T_{\text {PeLH }}$ | Port B Latch Mode PAO Strobe Pulse Width PB Data Setup Time PB Data Hold Time | $\begin{array}{r} T_{\text {cyc }} \\ 175 \\ 30 \end{array}$ | - | $\begin{array}{r} T_{\text {cre }} \\ 150 \\ 30 \end{array}$ | - |
| $T_{\text {Pow }}{ }^{\text {(1) }}$ <br> $\mathrm{T}_{\mathrm{Cmos}}{ }^{(1)}$ <br> $\mathrm{T}_{\text {cpw }}$ <br> $T_{\text {pow }}{ }^{(1)}$ <br> $\mathrm{T}_{\text {CMos }}{ }^{(1)}$ | Serial I/0 <br> PA6 XMTR TTL <br> PA6 XMTR CMOS <br> PA4 RCVR S/R Clock Width PA4 XMTR Clock-S/R Mode (TTL) <br> PA4 XMTR Clock - S/R Mode (CMOS) |  | $\begin{array}{r} 500 \\ 1000 \\ \hline- \\ 500 \\ 1000 \end{array}$ | $4 \bar{T}_{\text {crc }}$ | 500 <br> 1000 <br> 500 <br> 1000 |

NOTE 1: Maximum Load Capacitance: 50pF
Passive Pull-Up Required

## E.3.1 I/O, Edge Detect, Counter, and Serial I/O Timing



## E. 4 MICROPROCESSOR TIMING (D0-D7, A0-A12, A15, SYNC, R/W)



## E.4.1 Microprocessor Timing Diagram



## SECTION 1 INTRODUCTION

The Rockwell R6500/1 microcomputer is a complete 8 -bit computer fabricated on a single chip using an N -channel silicon gate MOS process. The R6500/1 complements an established and growing line of R6500 products and has a wide range of microcomputer applications.

The R6500/1 consists of an R6502 Central Processing Unit (CPU), 2048 bytes of Read Only Memory (ROM), 64 bytes of Random Access Memory (RAM) and interface circuitry for peripheral devices.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of computational power. These features make the R6500/1 a leading candidate for microcomputer applications.

To facilitate system and program development for the R6500/1, Rockwell has developed an R6500/1E Emulator part. A description of the R6500/1E is contained in Appendix $D$.

This product description is for the reader familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual (Document Number 29650N31). A description of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Document Number 29650N30).

## FEATURES

- Single-chip microcomputer
- R6502 software compatible
- Eight-bit parallel processing
- Decimal or binary arithmetic
- Variable length stack
- True indexing capability
- Thirteen addressing modes
- 1 or 2 MHz clock operation, with the following options:
- External single clock input
- RC time base input
- Crystal time base input
- Single +5 V power supply
- 500 mw operating power
- Separate power pin for RAM with standby power only $10 \%$ of operating power
- $2 \mathrm{~K} \times 8$ ROM on chip
- $64 \times 8$ RAM on chip
- 40-pin dual in-line package
- 64-pin Emulator part available, with 40 signals identical to production part
- Pipeline architecture
- 32 bidirectional TTL compatible I/O lines
- 1 positive edge sensitive I/O line
- 1 negative edge sensitive I/O line
- 1 bidirectional TTL compatible counter I/O line
- 16-bit timer/counter
- Four timer/counter modes
- Internal timer
- Pulse generator
- Event counter
- Pulse width measurement
- Three maskable interrupts
- 1 counter overflow
-2 I/O edge detect
- NMI and Reset interrupts


## SECTION 2 R6500/1 INTERFACE REQUIREMENTS

This section describes the interface requirements for the R6500/1-single chip microcomputer. Figure 2-1 is the Interface Diagram for the R6500/1. Figure 2-2 shows the pin out


Figure 2-1. R6500/1 Interface Diagram
configuration and Table 2-1 describes the function of each pin of the R6500/1.

Table 2-1. R6500/1 Pin Description


## SECTION 3 SYSTEM ARCHITECTURE

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

### 3.1 INDEX REGISTERS

There are two 8-bit index registers, $X$ and $Y$. Each index register can be used as a base to modify the address data program counter and thus obtain a new address - the sum of the program counter contents and the and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

### 3.2 STACK POINTER

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to
either user instructions or the interrupt lines $\overline{\mathrm{NMI}}$ and $\overline{\mathrm{IRQ}}$. The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may only be accessed from the top. The address of a memory location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1. Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus, and data are read from the memory location addressed by the Pointer.

### 3.3 ARITHMETIC AND LOGIC UNIT (ALU)

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers


Figure 3-1. R6500/1 Block Diagram
(except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

### 3.4 ACCUMULATOR

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

### 3.5 PROGRAM COUNTER

The 12-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter (PCH) is placed on the high-order 4 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

### 3.6 INSTRUCTION REGISTER AND INSTRUCTION DECODE

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register then decoded along with timing and interrupt signals to generate control signals for the various registers.

### 3.7 TIMING CONTROLS

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to TO each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.

### 3.8 INTERRUPT LOGIC

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

### 3.9 CLOCK OSCILLATOR

The Clock Oscillator provides the basic timing signals used by the R6500/1 CPU. The reference frequency is provided by an external source, and can be from a crystal, 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 ( $\varnothing 2$ ) frequency is one-half the external reference frequency. Figure $3-2$ shows typical connections.

c. RC Network Input (Mask Option)

NOTE (1) C IS PROVIDED INTERNALLY BY THE R6500/1.
(2) THE RC OPTION IS AVAILABLE ONLY ON THE 1 MHz R6500/1.

Figure 3-2. Clock Oscillator Input Options

### 3.10 PROCESSOR STATUS REGISTER

The 8-bit Processor Status Register, shown in Figure 3-3, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6500 instruction
set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

### 3.10.1 CARRY BIT (C)

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

### 3.10.2 ZERO BIT (Z)

The Zero Bit (Z) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are
not all zero. The R6500 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions: ADC, AND; ASt, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

### 3.10.3 INTERRUPT DISABLE BIT (I)

The Interrupt Disable Bit (I) is used to control the servicing of an interrupt request (IRQ). If the I Bit is reset to logic 0 , the $\overline{\mathrm{RQ}}$ signal will be serviced. If the bit is set to logic 1 , the $\overline{\mathrm{RQ}}$ signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET (RES) or NonMaskable Interrupt (NMI) signal is detected.

The $I$ bit is cleared by the Clear Interrupt (CLI) instruction, the Pull Processor Status from Stack (PLP) instruction, or as the result of executing a Return from Interrupt (RTI) instruction (providing the Interrupt Disable Bit was cleared prior to the interrupt). The Interrupt Disable Bit may be set or cleared under program control using a Set Interrupt Disable (SEI) or a Clear Interrupt Disable (CLI) instruction, respectively.


Figure 3-3. Processor Status Register

### 3.10.4 DECIMAL MODE BIT (D)

The Decimal Mode Bit (D), is used to control the arithmetic mode of the CPU. When this bit is set to logic 1, the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction will clear it. The PLP and RTI instructions also effect the Decimal Mode Bit.

## CAUTION

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application to R6500/1. This bit must be initialized to the desired state by the user program or erroneous results may occur.

### 3.10.5 BREAK BIT (B)

The Break Bit $(B)$ is used to determine the condition which caused the $\overline{\mathrm{RQ}}$ service routine to be entered. If the $\overline{\mathrm{RQ}}$ service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1. If the $\overline{\mathrm{IRQ}}$ routine was entered as the result of an $\overline{\mathrm{RQ}}$ signal being generated, the B bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

### 3.10.6 OVERFLOW BIT (V)

The Overflow Bit $(\mathrm{V})$ is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits $(-128 \leqslant n \leqslant$ 127). This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction which may be used to sample interface devices, allows the overflow flag to reflect the condition of bit 6 in the sampled field. Duriing a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions which affect the $V$ flag are ADC, BIT, CLV, PLP, RTI and SBC.

### 3.10.7 NEGATIVE BIT (N)

The Negative Bit ( N ) is used to indicate that the sign bit (bit 7), in the resulting value of a data movement or data arithmetic operation, is set to logic 1. If the sign bit is set to logic 1 , the resulting value of the data movement or
arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation $s$ positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

## $3.11 \mathbf{2 K} \times 8$ ROM

The R6500/1 2048 byte $\times 8$-bit Read Only Memory (ROM) usually contains the user's program instructions and other fixed constants. These program instructions and constants are mask-programmed into the ROM during fabrication of the R6500/1 device. The R6500/1 ROM is memory mapped from 800 to FFF.

## $3.1264 \times 8$ RAM

The 64 byte $\times 8$-bit Random Access Memory (RAM) contains the user program stack and is used for scratchpad memory during system operation. This RAM is completely static in operation and requires no clock or dynamic refresh. The data contained in RAM is read out nondestructively with the same polarity as the input data. A standby power pin, VRR allows RAM memory to be maintained on $10 \%$ of the operating power. In the event that VCC power is lost and execution stops, this standby power retains RAM data until execution resumes.

In order to take advantage of zero page addressing capabilities, the R6500/1 RAM is assigned page zero memory address 0 to 03F.

### 3.13 CONTROL REGISTER

The Control Register (CR), shown in Figure 3-4, is located at address 08F. The CR contains five control signals and three status signals.

The control signals are summarized in Table 3-1. The control signals are set to logic 1 by writing logic 1 into the respective bit positions and cleared to logic 0 either by writing logic 0 into the respective bit position or by the occurrence of a $\overline{\mathrm{RES}}$ signal.

Table 3-1. CR Control Signals

| Control Signal Name | Bit <br> Number |
| :--- | :---: |
| Counter Mode Control 0 (CMCO) | 0 |
| Counter Mode Control 1 (CMC1) | 1 |
| PA1 Interrupt Enabled (A1IE) | 2 |
| PA0 Interrupt Enabled (AOIE) | 3 |
| Counter Interrupt Enabled (CIE) | 4 |

The three status signals are summarized in Table 3-2.


Figure 3-4. Control Register (CR)

Table 3-2. CR Status Signals

| Status Signal Name | Blt <br> Number |
| :--- | :---: |
| PA1 Negative Edge Detected (A1ED) | 5 |
| PA0 Positive Edge Detected (A0ED) | 6 |
| Ccunter Overflow (CTRO) | 7 |

The status signals are read-only information. The status bits are set to logic 1 by hardware monitoring logic and cleared to logic 0 by the occurrence of $\overline{\mathrm{RES}}$ signal or by specific address commands. Each of these signals is described in the following sections.

### 3.13.1 COUNTER MODE CONTROL 0 AND 1

Counter Mode Control signals CMCO and CMC1 (bits 0 and 1) control the Counter operating modes. The modes of operation and the corresponding configuration of CMCO and CMC1 are summarized in Table 3-3.

These modes are controlled by writing the appropriate bit values into the Counter Mode Control bits.

Table 3-3. Counter Mode Control Selection

| CMC1 <br> (Bit 1) | CMC0 <br> (Blt 0) | Mode |
| :---: | :---: | :---: |
| 0 | 0 | Interval Timer |
| 0 | 1 | Pulse Generator |
| 1 | 0 | Event Counter |
| 1 | 1 | Pulse Width Measurement |

The Counter is set to the Interval Timer Mode (00) when a $\overline{R E S}$ signal is generated or if the user program stores logic 0 into Bits 0 and 1 of the Control Register. A complete description of each of the Counter modes is given in Section 3.14.1.

### 3.13.2 PA1 INTERRUPT ENABLE BIT (A1IE)

If the PA1 Interrupt Enable Bit (CR2) is set to logic 1, an $\overline{\mathrm{RQ}}$ interrupt request signal will be generated when the PA1 Negative Edge Detected Bit (CR5) is set.

### 3.13.3 PAO INTERRUPT ENABLE BIT (AOIE)

If the PAO Interrupt Enable Bit (CR3) is set to logic 1, the $\overline{\mathrm{IRQ}}$ interrupt request signal will be generated when the PAO Positive Edge Detected Bit (CR6) is set.

### 3.13.4 COUNTER INTERRUPT ENABLE BIT (CIE)

If the Counter Interrupt Enable Bit (CR4) is set to logic 1, the $\overline{\mathrm{RQ}}$ interrupt request signal will be generated when Counter Overflow (CR7) is set.

### 3.13.5 PA1 NEGATIVE EDGE DETECTED BIT (A1ED)

The PA1 Negative Edge Detected Bit (CR5) is set to logic 1 whenever a negative (falling) edge is detected on PA1. This bit is cleared to logic 0 by $\overline{R E S}$ or by writing to address 08A.

The edge detecting circuitry is active when PA1 is used either as an input or as an output. When PA1 is used as an output, A1ED will be set when the negative edge is detected during a logical 1 to 0 transition.

When PA1 is used as an input and the negative edge detecting circuitry is used, A1ED should be cleared by the user program upon initialization and when the PA1 Negative Edge Detected $\overline{\mathrm{RQ}}$ processing is completed.

### 3.13.6 PAO POSTIIVE EDGE DETECTED BIT (AOED)

The PAO Positive Edge Detected Bit (CR6) is set to logic 1 whenever a positive (rising) edge is detected on PAO. The bit is cleared to logic 0 by $\overline{\text { RES }}$ or by writing to address 089.

The edge detecting circuitry is active when PAO is used either as an input or as an output. When PAO is used as an output, AOED will be set when the positive edge is detected during a logical 0 to 1 transition.

When PAO is used as an input and the positive edge detecting circuitry is used, AOED should be cleared by the user program upon initialization and upon completion of PAO Positive Edge Detected $\overline{\mathrm{RQ}}$ processing.

### 3.13.7 COUNTER OVERFLOW BIT (CTRO)

The Counter Overflow Bit (CR7) is set to logic 1 whenever a counter overflow occurs in any of the four counter operating modes. Overflow occurs when the counter is decremented one count from 0000. This bit is cleared to logic 0 by $\overline{\text { RES }}$ or by reading from address 087 or writing to address 088.

This bit should be cleared by the user program upon initialization and upon completion of Counter Overflow $\overline{\mathrm{RQ}}$ interrupt processing.
When a Counter Overflow occurs, the Upper Count (UC) in address 086 and the Lower Count (LC) in address 087 are reset to
the values contained in the Upper Latch (UL) in address 084 and in the Lower Latch (LL) in address 085, respectively. Therefore, it is important to load the Lower Latch value prior to executing the Write to Upper Latch and Transfer Latch to Counter (address 088) in order to prevent an unpredicted reoccurrence of Counter Overflow and, if enabled, an IRQ interrupt request.

### 3.14 COUNTER/LATCH

The Counter/Latch consists of a 16 -bit Counter and a 16-bit Latch. The Counter resides in two 8 -bit registers: address 086 contains the Upper Count value (bits 8-15 of the Counter) and address 087 contains the Lower Count value (bits $0-7$ of the Counter). The Counter contains the count of either $\emptyset 2$ clock periods or external events depending on which counter mode is selected in the Control Register (Section 3.13.1).

The Latch contains the Counter initialization value. The Latch resides in two 8-bit registers: address 084 contains the Upper Latch value (bits 8-15 of the Latch) and address 085 contains the Lower Latch value (bits 0-7 of the Latch). The 16-bit Latch can hold values from 0 to 65535 .

The Latch registers can be loaded at any time by executing a write to the Upper Latch Address (084) and the Lower Latch Address (085). In each case, the contents of the Accumulator are copied into the applicable Latch register. The Upper Latch and Lower Latch can be loaded independently; it is not required to load both registers at the same time or sequentially. The Upper Latch can also be loaded by writing to address 088.

The Counter can be initialized at any time by writing to address 088. The contents of the Accumulator will be copied into the Upper Latch before the value in the Upper Latch is transferred to the Upper Counter.

The Counter will also be initialized to the Latch value whenever the Counter overflows. When the Counter decrements from 0000, the next Counter value will be the Latch value, not FFFF.

Whenever the Counter overflows, the Counter Overflow Bit (CR7) is set to logic 1. This bit is cleared whenever the lower eight bits of the counter are read from address 087 or by writing to address 088.

### 3.14.1 COUNTER MODES

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

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

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

## Interval TImer (Mode 0)

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:

1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to counter address (088), the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the $\phi 2$ clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The

Counter Timer capacity is therefore $1 \mu \mathrm{~s}$ to 65.535 ms at the 1 $\mathrm{MHz} \emptyset 2$ clock rate or $0.5 \mu \mathrm{~s}$ to 32.768 ms at the $2 \mathrm{MHz} \phi 2$ clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting $\overline{\mathbb{R Q}}$ interrupt requests in the counter IRQ interrupt routine.

When the Counter decrements from 0000, the Counter Overflow (CR7) is set to logic 1 at the next $\emptyset 2$ clock pulse. If the Counter Interrupt enable bit (CR4) is also set, an IRQ interrupt request will be generated. The Counter Overflow bit in the Control Register can be examined in the $\overline{R Q Q}$ interrupt routine to determine that the $\overline{\mathrm{RQ}}$ was generated by the Counter Overflow.

While the timer is operating in the Interval Timer Mode, the Counter Out/Event line is held in the high (output disabled) state.

A timing diagram of the Interval Timer Mode is shown in Figure 3-5.


Figure 3-5. Interval Timer (Mode 0) Timing Diagram

## Pulse Generator Mode (Mode 1)

In the Pulse Generator mode, the Counter Out/Event In line (CNTR) operates as a Counter Out. The CNTR line toggles from low to high or from high to low whenever a Counter Overflow occurs, or a write is performed to address 088.

Either a symmetric or asymmetric output waveform can be
output on the CNTR line in this mode. The CNTR output is initialized high by a $\overline{R E S}$ since the Interval Timer mode is established by $\overline{\mathrm{RES}}$.

A one-shot waveform can be easily generated by changing from Mode 1 Pulse Generator to Mode 0 (Interval Timer) after only one occurrence of the output toggle condition.

## Event Counter Mode (Mode 2)

In this mode the CNTR line is used as an Event In line, and the Counter with decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the $\varnothing 2$ clock rate.

The Counter can count up to 65,535 occurrences before overflowing. As in the other modes, the Counter Overflow bit (CR7) is set to logic 1 if the overflow occurs.

Figure 3-6 is a timing diagram of the Event Counter Mode.

## Pulse Width Measurement Mode (Mode 3)

This mode allows the accurate measurement of a low pulse duration on the CNTR line. In this mode, CNTR is used in the Event In capacity. The Counter decrements by one
count at the $\varnothing 2$ clock rate as long as the CNTR line is held in the low state. The Counter is stopped when CNTR is in the high state.

If the CNTR pin is left disconnected, this mode may be selected to stop the Counter since the internal pull-up device will cause the CNTR input to be in the high ( $>2.0 \mathrm{~V}$ ) state.
A timing diagram for the Pulse Width Measurement Mode is shown in Figure 3-7.

### 3.15 INPUT/OUTPUT PORTS

The R6500/1 provides four 8-bit Input/Output (I/O) ports (PA, PB, PC, PD). These 32 I/O lines are completely bidirectional. All lines may be used either for input or output in any combination; that is, there are no line grouping or port association restrictions.


Figure 3-6. Event Counter Mode (Mode 2)


Figure 3-7. Pulse Width Measurement (Mode 3)

The direction of the $32 \mathrm{I} / \mathrm{O}$ lines are controlled by four 8 -bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, which simplifies I/O handling. The I/O addresses are shown in Table 3-4.

Table 3-4. I/O Port Addresses

| Port | Address |
| :---: | :---: |
| A | 080 |
| B | 081 |
| C | 082 |
| D | 083 |

Figure 3-8 shows the I/O Port Timings.

### 3.15.1 INPUTS

Inputs are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to I/O input lines. A low ( $<0.8 \mathrm{~V}$ ) input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high ( $>2.0 \mathrm{~V}$ ) input will cause a logic 1 to be read. An RES signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

The status of the input lines can be interrogated at any time by reading the $I / O$ port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers.

### 3.15.2 OUTPUTS

Outputs are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( $>2.4 \mathrm{~V}$ ) output while a logic 0 will force a low ( $<0.4 \mathrm{~V}$ ) output.

### 3.15.3 EDGE DETECTION CAPABILITY

Ports PA0 and PA1 have an edge detection capability. Figure 3-9 shows the edge detection timing.

## PAO Positive Edge Detecting Capability

In addition to its normal I/O function, PAO will detect an asynchronous positive (rising) edge signal and set the PAO Positive Edge Detected signal (CR6) to logic 1. The maximum rate at which this positive edge can be detected is one-half the $\varnothing 2$ clock rate.

If the PAO Interrupt Enable Bit (CR3) is set, an $\overline{\mathrm{RQ}}$ interrupt request will also be generated. The PAO Positive Edge Detected signal can be cleared by writing to address 089.

## I/O PORT OUTPUT TIMING



I/O PORT INPUT TIMING


Figure 3-8. I/O Port Timing


Figure 3-9. PA0 and PA1 Edge Detection Timing

## PA1 Negative Edge Detecting Capability

In addition to its normal I/O function, PA1 will detect an asynchronous negative (falling) edge signal and set the PA1 Negative Edge Detected signal (CR5) to logic 1. The maximum rate at which this negative edge can be detected is one-half the $\phi 2$ clock rate.

If the PA1 Interrupt Enable signal (CR2) is set, an I $\bar{R} \bar{Q}$ interrupt request will also be generated. .The PA1 Negative Edge Detected signal may be cleared by writing to address 08A.

### 3.16 MASK OPTIONS

An option is provided to delete the internal pull-up resistance from PA, PB, PC and/or PD ports at mask time. This option is available for 8-bit port groups only, not for individual port lines. This option may by used to aid interface with CMOS drivers, or in order to interface with external pull-up devices.

An option is also provided to delete the internal pull-up resistance on the CNTR line.

## SECTION 4 IRQ INTERRUPT REQUEST GENERATION

An $\overline{\mathrm{RQ}}$ interrupt request can be initiated by any or all of three possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Control Register.

The first source of $\overline{\mathrm{RQ}}$ is Counter Overflow. The $\overline{\mathrm{RQ}}$ interrupt request will be driven low whenever both the Counter Interrupt Enable (CR4) and the Counter Overflow (CR7) are logic 1.

The second source of $\overline{\operatorname{RQ}}$ is detection of a positive edge on PAO. The $\overline{\mathrm{RQ}}$ inerrupt request will be driven low whenever both the PAO Interrupt Enable (CR3) and the PAO Positive Edge Detected (CR6) are logic 1.

The third source of $\overline{\mathrm{RQ}}$ is detection of a negative edge on PA1. The $\overline{\mathrm{RQ}}$ interrupt request will be driven low whenever both the PA1 Interrupt Enable (CR2) and the PA1 Negative Edge Detected (CR5) are logic 1.

Multiple simultaneous interrupts will cause the $\overline{\mathrm{RQ}}$ interrupt request to remain active until all interrupting conditions have been serviced and cleared.

## CAUTION

If the same data, i.e., the same RAM, counter/latch or I/O addresses, are operated on asynchronously by a normal processing routine and by an interrupt service routine, care must be taken to prevent loss of data due to the interrupt routine altering the data during update of the data by the normal processing routine. This situation can be prevented by disabling the $\overline{I R Q}$ interrupt with the SEI instruction before starting the data update in the normal processing and then enabling the interrupt with the CLI instruction upon completion of data update.

## SECTION 5 POWER ON/OFF CONSIDERATIONS

### 5.1 POWER-ON RESET

The occurrence of $\overline{R E S}$ going from low to high will cause the R6500/1 to set the Interrupt Mask Bit - bit 2 of the Processor Status Register - and initiate a reset vector fetch at address FFE and FFF to begin user program execution. All of the I/O ports (PA, PB, PC, and PD) and CNTR will be forced to the high (logic 1) state. All bits of the Control Register will be cleared to logic 0 causing the Interval Timer counter mode (mode 00 ) to be selected and causing all interrupt enabled bits to be reset.

### 5.2 POWER ON/OFF TIMING

After application of VCC power to the R6500/1, $\overline{\mathrm{RES}}$ must be held low for at least eight $\emptyset 2$ clock cycles after VCC reaches operating range and the internal clock oscillator has stabilized. This stabilization time is dependent upon the input VCC voltage and performance of the crystal, clock, or RC network input circuit. The clock oscillator output can be monitored on XTLO (pin 11).

Figure 5-1 illustrates the power turn-on waveforms.

### 5.3 RAM DATA RETENTION - VRR REQUIREMENTS

For the RAM to retain data upon loss of VCC, VRR must be supplied within operating range and $\overline{\mathrm{RES}}$ must be driven
low at least eight $\emptyset 2$ clock pulses before VCC falls out of operating range. RES must then be held low while VCC is out of operating range and until at least eight $\varnothing 2$ clock cycles after VCC is again within operating range and the internal $\varnothing 2$ oscillator is stabilzed. VRR must remain within VCC operation range during normal R6500/1 operation. When VCC is out of operating range, VRR must remain within the VRR retention range in order to retain data. Figure 5-2 shows typical waveforms.

### 5.4 RAM DATA RETENTION OPERATION

The requirement for R6500/1 RAM data retention and restart operation is application dependent. If R6500/1 RAM data retention is not required during loss of VCC, then VRR can be connected to the same power source as VCC. With this configuration a complete initialization of R6500/1 program variables in RAM is required upon VCC and VRR power application.

If the R6500/1 RAM is to retain data during loss of VCC, the following is required:

1. Connection of VCC and VRR to separate power supplies or to the same primary power supply with isolation diodes and battery or other backup power for VRR.
2. VCC power monitor hardware with power loss and cold/warm start indications to the R6500/1.
3 Power loss detection as well as cold and warm start initialization in the R6500/1 program.


Figure 5-1. Power Turn-On Timing Detail

(4) $\geqslant 8 \phi 2$ CLOCK PULSES AFTER $\phi 2$ OSCILLATOR STABILIZATION.
(5) $\geqslant 8 \phi 2$ CLOCK PULSES.

Figure 5-2. RAM Retention Mode Timing

The power monitor hardware must sense the loss of VCC power in sufficient time to allow the R6500/1 to save required CPU register data in RAM. The power loss indication line can be connected to the $\overline{\mathrm{NMI}}$ interrupt input in order to cause an immediate R6500/1 interrupt upon power loss detection.

The power monitor hardware should also provide an indication of cold start (initial VCC and VRR power application) or warm start (VCC power re-application while VRR is retained on backup power) provided as input on a data $1 / 0$ pin.

A level indication is sufficient. The R6500/1 program can then initialize all, or partial, program variables upon initialization then jump to any other starting address as required
depending upon cold/warm start condition.

Upon power loss detection, the R6500/1 should save all required CPU register data in either the stack or dedicated RAM. The stack may be preferred if dedicated RAM is not available. If the program is to restart at the interrupted address, then all CPU registers must be saved, i.e., $\mathrm{S}, \mathrm{P}, \mathrm{PC}, \mathrm{A}, \mathrm{X}$, and Y . The stack pointer must be saved in a dedicated RAM address. Note that processor status $P$ and the program counter, PC, are already saved on the stack by the NMI interrupt R6500/1 hardware processing. If the warm start can be performed at a specific address, then the saving of the register data at power loss detection may not be required. Figure 5-3 shows top level flowcharts of typical power down and power-up processing.


Figure 5-3. Typical R6500/1 Power Loss Recovery Flowcharts

## SECTION 6 TEST

### 6.1 TEST MODE

The R6500/1 test function is multiplexed on the $\overline{\mathrm{RES}}$ input pin. The three input states for this pin are:

| 1. $<0.8 \mathrm{~V}$ | Reset state. All R6500/1 outputs are <br> forced to the high state. |
| :--- | :--- |
| 2. $>2.0 \mathrm{~V}$ and | Normal run state. The low to high transi- <br> $<5.5 \mathrm{~V}$ |
| tion on the $\overline{\mathrm{RES}}$ pin initiates fetch of the <br> reset vector from address FFC and FFD <br> and starts user program execution at the |  |
| vectored address. |  |

The test mode allows instructions and data to be input externally through I/O port " $C$ ". This capability is used at Rockwell to test all of the R6500/1 logic, registers and internal data RAM. A ROM dump may be accomplished by using the test feature to load into the internal RAM a small program to fetch each byte of ROM and output it to an I/O port. After this program is loaded the CPU is directed to begin execution out of RAM, e.g., JMP to 00 . After the jump is executed, the $\overline{\mathrm{RES}}$ line is returned to the normal run state. The normal run state allows data fetches to occur out of the internal ROM and returns port " C " to its normal function.

The detail support hardware and software required to use the R6500/1 test mode is fairly complex and time critical. For normal application testing, it is recommended that a test program be loaded into RAM and executed as explained in Section 6.2.

### 6.2 PROGRAM LOADING INTO RAM

A test or application program can easily be loaded into the R6500/1 RAM and executed without forcing the R6500/1 into the test mode. To do this, a shcet program loader function must be permanently included in the application program stored in ROM. Upon test mode selection during R6500/1 initialization, the loader reads instructions or data from an I/O port and stores them into RAM. At the first completion of the load, the loader then jumps to the first instruction in RAM to start program execution.

A program is described which may be used to load test or
application program into RAM. It can easily be adapted to specific requirements by re-assigning $I / O$ as required. The loader uses positive handshake between the R6500/1 and the interfacing host equipment. One I/O line is dedicated to the test mode selection. The other pins assigned to loader interface signals may be assigned to normal application I/O interface signals when the test mode is not selected.

I/O is assigned for the RAM Program Loader as follows:

| PAO | Data Ready (DR) - Positive edge indicates data is ready for sampling by the R6500/1. |
| :---: | :---: |
| PA1 | End of Data ( $\overline{\mathrm{EOD}}$ ) - Negative edge indicates that all the data has been transferred to the R6500/1. |
| PA2 | Data Taken (DT) $0=$ Data Not Taken <br> 1 = Data Taken |
| PA7 | Normal Mode Select (NMS) $0=$ Test Mode <br> 1 = Normal Mode |
| PB7-PB0 | Data input, i.e., instruction or data (PB7 $=\mathrm{MSB}, \mathrm{PBO}=\mathrm{LSB})$ |

The flowchart in Figure 6-1 shows the loader operation. The handshake waveforms between the R6500/1 and the host are illustrated in Figure 6-2. The following description corresponds to the handshake events identified in Figure 6-2:

1) Host sees PA2 high, which indicates previous data, if any, has been taken by the R6500/1. The host then drops PAO low to indicate new data is not ready. This signal should be initialized low by the host.
2) R6500/1 detects PAO low then drops PA2 low to indicate that data has not been taken.
3) Host sees PA2 low then sets up new data.
4) Host sets PAO high to indicate new data is ready.
5) Upon detecting positive edge of PAO, R6500/1 reads data on PB7-PB0. R6500/1 then sets PA2 high to indicate that the data has been taken.
6 When no more data is available, the host drops PA1 low to indicate end of data ( $\overline{\mathrm{EOD}}$ ). The R6500/1 then jumps to address $\$ 000$ to start program execution. If all RAM is loaded without EOD detected, the R6500/1 also jumps to address $\$ 000$.

An assembly listing of the RAM Program Loader is shown in Table 6-1.



Figure 6-2. R6500/1 RAM Program Load Handshake

Table 6-1. RAM Program Loader Assembly Listing
R6500/1 RAM LOADER . . . . . . PAGE 001


Errors $=0000<0000>$
End of Assembly

## APPENDIX A — SYSTEM MEMORY MAP



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

## APPENDIX B - R6500 INSTRUCTION SET

This appendix contains a summary of the R6500 instruction set. For detailed information, consult the R6500 Microcomputer System Programming Manual, Document 29650 N30.

## B. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE

| ADC | Add Memory to Accumulator with Carry | LDA | Load Accumulator with Memory |
| :---: | :---: | :---: | :---: |
| AND | "AND" Memory with Accumulator | LDX | Load Index X with Memory |
| ASL | Shift Left One Bit (Memory or Accumulator) | LDY | Load Index Y with Memory |
|  |  | LSR | Shift One Bit Right (Memory or Accumulator) |
| BCC | Branch on Carry Clear |  |  |
| BCS | Branch On Carry Set | NOP | No Operation |
| BEQ | Branch on Result Zero |  |  |
| BIT | Test Bits in Memory with Accumulator | ORA | "OR" Memory with Accumulator |
| BMI | Branch on Result Minus |  |  |
| BNE | Branch on Result not Zero | PHA | Push Accumulator on Stack |
| BPL | Branch on Result Plus | PHP | Push Processor Status on Stack |
| BRK | Force Break | PLA | Pull Accumulator from Stack |
| BVC | Branch on Overflow Clear | PLP | Pull Processor Status from Stack |
| BVS | Branch on Overflow Set |  |  |
|  |  | ROL | Rotate One Bit Left (Memory or Accumulator) |
| CLC | Clear Carry Flag | ROR | Rotate One Bit Right (Memory or Accumulator) |
| CLD | Clear Decimal Mode | RTI | Return from Interrupt |
| CLI | Clear Interrupt Disable Bit | RTS | Return from Subroutine |
| CLV | Clear Overflow Flag |  |  |
| CMP | Compare Memory and Accumulator | SBC | Subtract Memory from Accumulator with Borrow |
| CPX | Compare Memory and Index X | SEC | Set Carry Flag |
| CPY | Compare Memory and Index Y | SED | Set Decimal Mode |
|  |  | SEI | Set Interrupt Disable Status |
| DEC | Decrement Memory by One | STA | Store Accumulator in Memory |
| DEX | Decrement Index $X$ by One | STX | Store Index X in Memory |
| DEY | Decrement Index Y by One | STY | Store Index Y in Memory |
| EOR | "Exclusive-Or" Memory with Accumulator | TAX | Transfer Accumulator to Index $X$ |
|  |  | TAY | Transfer Accumulator to Index Y |
| INC | Increment Memory by One | TSX | Transfer Stack Pointer to Index X |
| INX | Increment Index X by One | TXA | Transfer Index X to Accumulator |
| INY | Increment Index Y by One | TXS | Transfer Index X to Stack Register |
|  |  | TYA | Transfer Index Y to Accumulator |

## B2. INSTRUCTION SET SUMMARY TABLE

| instructions |  | Immeoiate |  |  | ABSOLute |  | zero page |  |  | accum |  | Implied |  | (iND. X) |  |  | (iNO). Y |  | z page. ${ }^{\text {x }}$ |  |  | ${ }^{\text {ABS } . ~} \mathrm{X}$ |  |  | ${ }^{\text {ABS }, ~ Y ~}$ |  | relative |  | inoirect |  | 2. PaGE. r |  | PROCESSOR STATUSCODES |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MNEMONIC | Operation | OP $n$ |  | OP | OP 1. | " ${ }^{\prime}$ | - 0 O | P | ${ }^{*}{ }^{\circ}$ | OP $n$ | $\cdots$ | OP | ก * | OP | P $n$ | * 0 | $\bigcirc$ | $n$ " | Op | P |  | OP | $n$ * | $\cdots$ OP | P $n$ | OP | n | 0 | OP | $\cdots$ - 0 | OP | " |  | nemonic |
| $\begin{aligned} & \text { ADC } \\ & A N D \\ & A S C \\ & B C C \\ & B C S \end{aligned}$ | $\begin{array}{ll} \hline A+M+C-A & \text { (4) (1) } \\ A A M-A & \text { (1) } \\ C-Z=0 & \\ \text { BRANCH ONC }=0 & \text { (2) } \\ \text { BRANCH ONC }=1 & \text { (2) } \end{array}$ |  | 2 <br> 2 <br> 2 | 2 60 <br> 2 20 <br>  20 <br>  $0 E$ | 60 4 <br> 20 4 <br> $0 E$ 6 | $\begin{array}{l\|l\|} \hline 4 & 3 \\ 4 & 3 \\ 6 & 3 \end{array}$ | $\begin{array}{l\|l\|} \hline 3 & 65 \\ 3 & 25 \\ 3 & 06 \end{array}$ | [\|l|l| | $\begin{array}{l\|l} 2 \\ 2 \\ 2 & \\ 2 & 0 A \end{array}$ | OA | 1 |  |  |  |  | 2 | 71 31 | 5  <br> 5 2 <br>  2 | 2 75 <br> 2 35 <br>  16 <br>  16 | 5 4 <br> 5 4 <br> 16 6 | 2 | 70 | 7 | 79 | $9{ }^{9} 4$ | 90 | 2 | $2$ |  |  |  |  |  | ADC $A N D$ $A S L$ $B C C$ $B C S$ |
|  | BRANCHONZ = 1 (2) AAM <br> BRANCHONN = 1 (2) <br> BRANCHONZ $=0$ (2) <br> BRANCHONN $=0$ (2) |  |  |  | 2 C 4 | 3 | 324 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | F0 | 2 | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \\ & \hline \end{aligned}$ |  |  |  |  |  | $\begin{aligned} & \text { BEO } \\ & \text { BIT } \\ & \text { BMI } \\ & \text { BNE } \\ & \text { BPL } \end{aligned}$ |
| BRK BVC BVS CLC $C L D$ | break <br> BRANCHONV $=0$ (2) <br> BRANCHONV=1 (2) $\begin{aligned} & 0-c \\ & 0 \rightarrow 0 \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{l\|l} \hline 7 & 1 \\ & 1 \\ 2 & 1 \\ 2 & 1 \end{array}$ |  |  |  |  |  |  |  |  |  |  |  |  | 50 | 2 | $\left\lvert\, \begin{aligned} & 2 \\ & 2 \end{aligned}\right.$ |  |  |  |  |  | BRK <br> BVC <br> BVS <br> $C L C$ <br> $C L D$ <br> $C L I$ |
| CLI <br> $C L V$ <br> $C M P$ <br> $C P X$ <br> $C P Y$ | $\begin{aligned} & O+1 \\ & O \rightarrow V \\ & A-M \\ & X-M \\ & Y-M \end{aligned}$ | Cg 2 <br> EO 2 <br> co 2 | 2 2 2 | $\begin{array}{l\|l\|} 2 & \mathrm{CD} \\ 2 & \mathrm{EC} \\ 2 & \mathrm{CD} \\ \hline \end{array}$ | CD 4 <br> CC 4 <br> C 4 <br>   | $\begin{aligned} & 3 \\ & 3 \\ & 3 \end{aligned}$ | $\begin{array}{l\|l\|} 3 & \mathrm{C5} \\ 3 & \mathrm{E4} \\ 3 & \mathrm{C} 4 \\ \hline \end{array}$ | 5  <br>  3 <br> 3  <br> 4  | 2 <br> 2 <br> 2 |  |  |  |  | $c_{1}$ | 6 | 2 | 01 | 52 | 2.05 | 5 | 2 | 00 | 4 | 3 D9 | 9.4 | 3 |  |  |  |  |  |  |  | $\begin{aligned} & \hline C L I \\ & C L V \\ & C M P \\ & C P X \\ & C P Y \\ & \hline \end{aligned}$ |
| $\begin{align*} & D E C \\ & D E X \\ & D E Y \\ & E O R  \tag{1}\\ & \text { INC } \\ & \hline \end{align*}$ | $\begin{aligned} & M-1 \rightarrow M \\ & X-1-X \\ & Y-1 \rightarrow Y \\ & A \forall M \rightarrow A \\ & M+B \rightarrow M \end{aligned}$ | 492 | 2 |  | $\begin{array}{l\|l\|} \hline \text { CE } & 6 \\ \text { CB } & \\ \text { EE } & 6 \\ \hline \end{array}$ | $3$ | $\begin{array}{l\|l\|} \hline 3 & c 6 \\ 3 & \\ 3 & 45 \\ 3 & 56 \\ \hline \end{array}$ |  | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & 2 \end{aligned}$ |  |  |  |  | 41 | 6 | 2 | 51 | 2 | $2{ }_{2}{ }^{06}$ |  | 2 2 2 | OE | 7 4 7 | $\begin{array}{\|l\|l} \hline & \\ & \\ & \\ 3 & 59 \\ 3 & 59 \\ \hline \end{array}$ | 59 | 3 |  |  |  |  |  |  |  | $\begin{aligned} & \text { DEC } \\ & \text { DEX } \\ & \text { DEY } \\ & \text { EOR } \\ & \text { INC } \\ & \hline \end{aligned}$ |
| $\begin{aligned} & \text { INX } \\ & \text { INY } \\ & \text { IMP } \\ & \text { JSR } \\ & \text { LDA } \\ & \hline \end{aligned}$ | $\begin{aligned} & x+1-x \\ & y+1-y \end{aligned}$ <br> JUMPTONEWLOC.: <br> Jump SUB <br> $M \rightarrow A$ | A9. 2 |  |  | $\begin{array}{c\|c} 4 C & 3 \\ 20 & 6 \\ A D & 4 \\ \hline \end{array}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \end{aligned}$ | $\begin{array}{l\|l\|} \hline & \\ 3 & \\ 3 & A S \\ \hline \end{array}$ |  | 2 |  |  |  |  | $A_{1}$ | 6 | 2 | B1 | 52 | 285 | ${ }_{5}{ }_{4}$ | 2 | BD | ${ }_{4}$ | 3 B9 | 94 | 3 |  |  | 6 C | 53 |  |  |  | $N X$ <br> $N Y$ <br> $N Y$ <br> $J M P$ <br> SR <br> LDA <br> L |
| $\begin{aligned} & \text { LOX } \\ & \text { LOY } \\ & \text { LSR } \\ & \text { NOP } \\ & \text { ORA } \end{aligned}$ | $\qquad$ | $A 2$ 2 <br> $A 0$ 2 <br>  2 <br>   <br>   <br> 09 2 | 2 2 2 |  | $\begin{array}{l\|l\|l} \hline A E & 4 \\ A C & 4 \\ \\ A E & 6 \\ & 4 \\ 00 & 4 \\ \hline \end{array}$ | $\begin{array}{\|c\|c} 4 & 3 \\ 4 & 3 \\ 6 & 3 \\ 4 & 3 \\ \hline \end{array}$ | $\begin{array}{l\|l\|} \hline 3 & A 6 \\ 3 & A 4 \\ 3 & 46 \\ 3 & 05 \\ \hline \end{array}$ | $\begin{array}{l\|l\|} \hline 6 & 3 \\ 4 & 3 \\ 6 & 5 \\ & \\ 5 & 3 \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\|4 A\| 2$ | 1 E |  | 2 |  | ${ }_{6}$ | 2 | 11 |  |  | 5 | $2$ | $\begin{array}{l\|l\|} \hline & B C \\ 2 & 5 E \\ 2 & \\ 2 & 10 \end{array}$ | 4 |  |  | $3$ |  |  |  |  | 86 | ${ }^{2}$ |  | $\begin{aligned} & \text { LOX } \\ & \text { LOY } \\ & \text { LSA } \\ & \text { NOP } \\ & \text { ORA } \\ & \hline \end{aligned}$ |
| PHA <br> PHP <br> PLA <br> PLP <br> ROL |  |  |  |  | 2 E 6 | 3 |  | 6 | 2.24 | 2A 2 |  |  | 3 1 <br> 3 1 <br> 4 1 <br> 4 1 | , |  |  |  |  |  | ${ }_{6} 6$ |  | 3 E | , | 3 |  |  |  |  |  |  |  |  |  | $\begin{aligned} & \hline \text { PHR } \\ & \text { PHP } \\ & \text { PLA } \\ & \text { PLP } \\ & \text { ROL } \end{aligned}$ |
| ROR <br> ROR <br> RT <br> RTS <br> SBC <br> SEC <br> SED <br> SES | $\square \mathrm{C}-\mathrm{C}$ <br> RTRNINT <br> rtan sub $\begin{align*} & A-M-\bar{C} \cdot A  \tag{1}\\ & 1 \because C \\ & 1 \rightarrow D \end{align*}$ | E9 2 | 2 |  |  |  | $\begin{array}{\|l\|l\|} \hline 3 & 66 \\ 3 & E 5 \end{array}$ | 5  <br> 5  | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{array}{\|l\|} 6 A \\ \hline \end{array}$ | 6 |  | $\begin{aligned} & 6 \\ & 6 \\ & 2 \\ & 2 \\ & 2 \end{aligned}$ |  | 56 | 2 | F1 | 52 | $2{ }_{2}{ }_{5}^{76}$ | 6.6 |  | TE | 4 | $3 \text { F9 }$ | 9.4 | 3 |  |  |  |  |  |  |  | $\begin{aligned} & \text { ROR } \\ & \text { RT } 1 \\ & \text { RTS } \\ & \text { SBC } \\ & \text { SEC } \\ & \text { SED } \end{aligned}$ |
| SEE <br> STA <br> STA <br> STA <br> STY <br> TAX <br> SA | $\begin{aligned} & X \rightarrow 1 \\ & A \rightarrow M \\ & X \rightarrow M \\ & Y \rightarrow M \\ & A \rightarrow X \end{aligned}$ |  |  |  | $\begin{array}{c\|c} 80 & 4 \\ 8 E & 4 \\ 8 C & 4 \end{array}$ | 3 3 3 | 3 85 <br> 3 86 <br> 3 84 | $\begin{array}{c\|c} 5 & 3 \\ 6 & 3 \\ 4 & 3 \end{array}$ | 2 2 2 |  |  |  | 2 1 <br>   <br> 2 1 <br> 2 1 | ${ }^{1} 81$ | 6 | 2 | 91 | 62 | $2{ }^{29}$ | 5 | 2 | 90 | 5 | 399 | 995 | 3 |  |  |  |  | 96 | 2 | $\cdots \cdots$ |  |
| TAX <br> TAY <br> TS <br> TXA <br> TXS <br> TYA | $\begin{aligned} & A \rightarrow Y \\ & S-X \\ & X-A \\ & X-S \\ & Y \rightarrow A \\ & \hline \end{aligned}$ |  |  |  |  |  |  |  |  |  |  | AB ${ }^{\text {A }}$ BA 2 | 2 211 | 1 <br> 1 <br> 1 <br> 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | TAXY <br> TAY <br> TSX <br> TXA <br> TXS <br> TYA <br> He |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | tor <br> feff ERTA |  |  | ADORE TER |  |  | $\begin{aligned} & - \\ & \hat{v} \\ & \forall \end{aligned}$ | ADD <br> SUBTR <br> AND <br> OR <br> EXCLU | TRACT <br> USIVE |  | Mr MEMORY <br> $M_{b}$ MEMORY <br> $n$ No. CYCLe <br> " no. gYtes |  |

## APPENDIX C — SYSTEM SPECIFICATIONS

## MAXIMUM RATINGS*

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

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

## STATIC DC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%\right.$, for $\mathrm{R} 6500 / 1, \mathrm{~V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$ for R6500/1A)

| Parameter | Symbol | Min | Typ | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { Power Dissipation (Outputs High) } \\ & 0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ | $\mathrm{P}_{\mathrm{D}}$ | - | $\begin{aligned} & 500 \\ & 550 \end{aligned}$ | - | mW |
| RAM Standby Voltage (Retention Mode) | $\mathrm{V}_{\text {RR }}$ | 3.5 | - | $\mathrm{V}_{\mathrm{CC}}$ | Vdc |
| RAM Standby Current (Retention Mode) $\begin{aligned} & 0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ & -40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ | $I_{\text {RR }}$ | - | $\begin{aligned} & 10 \\ & 12 \\ & \hline \end{aligned}$ | - | mAdc |
| Input High Voltage (Normal Operating Levels) | $\mathrm{V}_{\mathrm{IH}}$ | +2.0 | - | $\mathrm{V}_{\mathrm{CC}}$ | Vdc |
| Input Low Voltage (Normal Operating Levels) | $\mathrm{V}_{\mathrm{iL}}$ | -0.3 | - | +0.8 | Vdc |
| Input Leakage Current $\mathrm{V}_{\mathrm{iN}}=0 \text { to } 5.0 \mathrm{Vdc} \overline{\mathrm{RES}}, \overline{\mathrm{NMI}}$ | $\mathrm{I}_{\mathrm{N}}$ |  | $\pm 1.0$ | $\pm 2.5$ | $\mu \mathrm{Adc}$ |
| Input High Voltage (XTLI) | $\mathrm{V}_{\text {IHXT }}$ | +4.0 | - | $\mathrm{V}_{\mathrm{Cc}}$ | Vdc |
| Inpūt Low Voltage (XTLI) | $\mathrm{V}_{\text {ILXT }}$ | -0.3 | - | $+0.8$ | Vdc |
| Input Low Current $\left(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{Vdc}\right)$ | $\mathrm{I}_{1 /}$ | - | -1.0 | -1.6 | mAdc |
| Output High Voltage $\left(V_{C C}=\min , I_{\text {LOAD }}=-100 \mu \mathrm{AdC}\right)$ | $\mathrm{V}_{\mathrm{OH}}$ | -2.4 | - | - | Vdc |
| Output High Voltage $\left(\mathrm{V}_{\mathrm{CC}}=\mathrm{min}\right)$ | $\mathrm{V}_{\text {cmos }}$ | $\mathrm{V}_{\text {cc }}-30 \%$ | - | - | Vdc |
| Output Low Voltage $\left(V_{C C}=\min , I_{\text {LOAD }}=1.6 \mathrm{mAdc}\right)$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | +0.4 | Vdc |
| Output High Current (Sourcing) $\left(\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{Vdc}\right)$ | IOH | -100 |  | - | $\mu \mathrm{Adc}$ |
| Output Low Current (Sinking) $\left(\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{Vdc}\right)$ | $\mathrm{l}_{0}$ | 1.6 | - | - | mAdc |
| Input Capacitance $\begin{aligned} & \left(V_{I N}-0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right) \\ & \text { PA, PB, PC, PD, CNTR } \\ & \text { XTLI, XTLO } \end{aligned}$ | $\mathrm{C}_{\text {IN }}$ | - | - | $\begin{aligned} & 10 \\ & 50 \end{aligned}$ | pF |
| Output Capacitance $\left(\mathrm{V}_{I N}-0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$ | $\mathrm{C}_{\text {OUT }}$ | - | - | 10 | pF |
| I/O Port Résistance <br> PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7, CNTR | $\mathrm{R}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | K $\Omega$ |

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

## AC CHARACTERISTICS

( $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 10 \%$ for $\mathrm{R} 6500 / 1, \mathrm{~V}_{\mathrm{cc}}=5 \mathrm{~V} \pm \%$ for $\mathrm{R} 6500 / 1 \mathrm{~A}$ )

| Parameter | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIn | Max | Min | Max |  |
| XTLI Input Clock Cycle Time | $\mathrm{T}_{\text {cyc }}$ | 0.500 | 5.0 | 0.250 | 5.0 | $\mu \mathrm{sec}$ |
| Internal Write to Peripheral Data Valid (TTL) | $\mathrm{T}_{\text {PDW }}$ | 1.0 |  | 0.5 |  | $\mu s e c$ |
| Internal Write to Peripheral Data Valid (CMOS) | Tcmos | 2.0 |  | 1.0 |  | $\mu \mathrm{sec}$ |
| Peripheral Data Setup Time | $T_{\text {PDSU }}$ | 400 |  | 200 |  | nsec |
| Count and Edge Detect Pulse Width | $\mathrm{T}_{\text {pw }}$ | 1.0 | , | 0.5 |  | $\mu \mathrm{sec}$ |

## APPENDIX D - R6500/1E EMULATOR PART

## D. 1 INTRODUCTION

To aid the user in designing R6500/1 microcomputer systems, Rockwell has developed an R6500/1E Emulator. The basic architecture of the Emulator is the same as that of the R6500/1 single-chip microcomputer except the Emulator brings the address, data, and required control lines off the chip to an external memory.

This appendix describes only the differences between the R6500/1 single-chip microcomputer and the R6500/1E Emulator. All sections of the Emulator not described in this appendix are identical to the corresponding section of the R6500/1 single chip microcomputer.

## D. 2 R6500/1 EMULATOR INTERFACE REQUIREMENTS

This section describes the interface requirements for the R6500/1E Emulator. Figure D-1 is the Emulator Interface diagram. Figure D-2 shows the Emulator pin configuration. Table D-1 describes the function of each pin of the Emulator that differs from the R6500/1 device.


Figure D-2. Emulator Pin Configuration


Figure D-1. R6500/1 Emulator Interface Diagram

Table D-1. R6500/1E Emulator Pin Description

| Signal Name | $\begin{aligned} & \text { Pln } \\ & \text { No. } \end{aligned}$ | Description |
| :---: | :---: | :---: |
| $\overline{\mathrm{R} / W}$ | 62 | Read/Write allows the CPU to control the direction of data transfers between the R6500/1E Emulator CPU and external memory. This line is high when reading data from memory and is low when writing data to memory. |
| RDY | 3 | The Ready input delays execution of any cycle during which the RDY line is low. This allows the user to halt or single step the CPU on all cycles except write cycles. A negative transition to the low state during the $\varnothing 2$ clock low pulse will halt the CPU with the address lines containing the current address being fetched. If RDY is low during a write cycle, it is ignored until the following read operation. This condition will remain through a subsequent $\varnothing 2$ clock pulse in which the RDY line is low. This feature allows the CPU to interface with memories having slow access times, such as EPROMS used with the R6500/1 Emulator part during prototype system development. |
| SYNC | 6 | The Sync signal is provided to identify cycles in which the CPU is performing OP CODE fetch. SYNC goes high during the $\phi 2$ clock low pulse of an OP CODE fetch and stays high for the remainder of that cycle. If the RDY line is pulled low during the $\emptyset 2$ clock low pulse in which SYNC went high, the CPU will halt in its current state and will remain in that state until the RDY line goes high. Using this technique, the SYNC signal can be used to control RDY to cause single instruction execution. |
| $\emptyset 2$ | 1 | Phase 2 ( $\varnothing 2$ ) clock pulse. Data transfer takes place only during $\varnothing 2$ clock pulse high. |
| A0-A11 | 25-37 | Address Bus lines. The address bus buffers on 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 address commands are also placed on these lines. |
| D0-D7 | 53-46 | Data Bus lines. All transfers of instructions and data between the CPU and memory, I/O, and other interfacing circuitry take place on the data bus lines. The buffers driving the data bus lines have full three-state capability, which is necessitated by the fact that the lines are bidirectional. Each data bus pin is connected to an input and output buffer, with the output buffer remaining in the floating condition. |

## D. 3 SYSTEM ARCHITECTURE

Figure D-3 is a block diagram of the R6500/1E Emulator. The function of each block is identical to its counterpart in the R6500/1 microcomputer. The main differences between the two products are in the ROM, the clock oscillator, the input/output ports and write-only monitoring.

## D.3.1 ROM

To facilitate debugging, the R6500/1 ROM has been removed from the R6500/1E Emulator, and has been replaced by external memory. Also, an additional 1024 bytes of memory (400-7FF) are addressable.

## D.3.2 CLOCK OSCILLATOR

The external frequency reference for the R6500/1E Emulator may be either a crystal or a clock. The RC option is not available for this device.

## D.3.3 INPUT/OUTPUT PORTS

The R6500/1E has the internal I/O and CNTR port pull-up resistance only. The option to delete the pull-up resistance is not included in this device.


Figure D-3. R6500/1E Emulator Block Diagram

## D.3.4 WRITE-ONLY MONITORING

The R6500/1E allows the user to monitor write operations to the internal RAM and I/O by routing those operations externally as well as internally. Read operations are not routed externally.

## D. 4 R6500/1E I/O PORT INITIALIZATION

Ports A, B, C and D and the CNTR line in R6500/1E are initialized to the logic high state two $\emptyset 2$ clock cycles earlier
than in the R6500/1. It is still required, however, that the $\overline{R E S}$ line to the R6500/1E be held low for at least eight $\varnothing 2$ clock cycles after VCC reaches operating range and the $\varnothing 2$ clock oscillator has stabilized.


## D. 5 TYPICAL R6500/1E PROGRAM MEMORY INTERCONNECTIONS

Shown below and on the following page 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 2K ROM capacity, the contents of the PROM could be masked directly into the production R6500/1 ROM.

Example 1. R6500/1E Connected to One 2716 PROM (2K Bytes)


Example 2 shows a connection to 3K of 2708 PROMs. The extra 1K 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 2. R6500/1E Connected to Three PROMs (3K Bytes)


Truth Table

| Address |  | PROM Select |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A11 | A10 | 2708 No. 1 <br> CE | 2708 No. 2 <br> CE | Selected <br> Address Range |  |
| 0 | 0 | 1 | 1 | $\mathbf{C E}$. 3 | 000-3FF |
| 0 | 1 | 0 | 1 | 1 | $400-7 F F$ |
| 1 | 0 | 1 | 0 | 1 | $800-$ BFF |
| 1 | 1 | 1 | 1 | 0 | C00-FFF |

## D. 6 R6500/1E TIMING

| Signal | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{R} \overline{\mathrm{W}}$ setup time from CPU | $\mathrm{T}_{\text {Rws }}$ |  | 300 |  | 200 | ns |
| Address setup time from CPU | $\mathrm{T}_{\text {ADS }}$ |  | 300 |  | 200 | ns |
| Memory read access time | $\mathrm{T}_{\text {Acc }}$ |  | 525 |  | 225 | ns |
| Data stabilization time | $\mathrm{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 | $\mathrm{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 | $\mathrm{T}_{\mathrm{HA}}$ | 30 |  | 30 |  | ns |
| $\mathrm{R} / \bar{W}$ hold time | $\mathrm{T}_{\text {HRW }}$ | 30 |  | 30 |  | ns |
| Cycle Time | $\mathrm{T}_{\mathrm{crc}}$ | 1.0 | 10.0 | 0.5 | 10.0 | $\mu \mathrm{s}$ |

PHASE 2 ( $\phi 2$ ) TIMING REFERENCE

TIMING FOR READING DATA FROM EXTERNAL MEMORY

TIMING FOR WRITING DATA TO EXTERNAL MEMORY


## D. 7 R6500/1E ELECTRICAL CHARACTERISTICS

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

| Characteristlc | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Threshold Voltage DO-D7, RDY, | $\mathrm{V}_{\mathrm{IHT}}$ | $\mathrm{V}_{\mathrm{ss}}+2.4$ | - | - | Vdc |
| Input Low Threshold Voltage DO-D7, RDY, | $\mathrm{V}_{\text {ILT }}$ | - | - | $\mathrm{V}_{\mathrm{ss}}+0.8$ | Vdc |
| 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)$ D0-D7 | $\mathrm{I}_{\text {TS }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| Output High Voltage $\left(\mathrm{L}_{\text {LOAD }}=100 \mu \mathrm{Adc}, \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}\right)$ DO-D7, SYNC, AO-A11, RWW, $\$ 2$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{ss}}+2.4$ | - | - | Vdc |
| Output Low Voltage ( $\mathrm{L}_{\text {LOAD }}=1.6 \mathrm{mAdc}, \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ ) DO-D7, SYNC, AO-A11, RM, $\$ 2$ | VoL | - | - | $\mathrm{V}_{\mathrm{ss}}+0.6$ | Vdc |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | - | 0.50 | 1.00 | W |
| ```Capacitance \(\left(V_{\text {in }}=0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right.\) ) RDY D0-D7 AO-A11, \(\bar{R} / W\), SYNC \(\not \subset 2\)``` | C <br> $\mathrm{C}_{\text {in }}$ <br> Cout <br> $\mathrm{C}_{02}$ | 二 | 50 | $\begin{aligned} & 10 \\ & 15 \\ & 12 \\ & 80 \end{aligned}$ | pF |

## R6500/1E <br> MICROPROCESSOR EMULATOR DEVICE

## INTRODUCTION

The R6500/1EC and R6500/1EQ devices provide all the features of the R6500/1 Microcomputer in a ROMless form suitable for use as an advanced microprocessor complete with 16 bit counter and 32 I/O lines, and an address and data bus for 4 K of external memory.

To aid in designing R6500/1 microcomputer systems, it may also be used as an Emulator device. Device architecture is basically the same as the R6500/1 except that the address, data, and associated control lines are routed off the chip for connection to an external memory.

The functions and operation of the devices are identical to the R6500/1 except for minor differences. The R6500/1 Data Sheet Order No. D51 (Document No. 2900D51) contains a description
of R6500/1 and R6500/1 common interface signals and functions.

The device is available in both 64-pin DIP ceramic (R6500/1EC) and 64-pin QUIP Plastic (R6500/1EQ).

ORDERING INFORMATION

| Part <br> Number | Package <br> Type | Frequency <br> Option | Temperature <br> Range |
| :--- | :--- | :--- | :--- |
| R6500/1EC | Ceramic | 1 MHz | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| R6500/1EAC | Ceramic | 2 MHz | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| R6500/1EQ | Plastic | 1 MHz | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| R6500/1EAQ | Plastic | 2 MHz | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |




Pin Configuration

## SIGNAL DESCRIPTIONS

All R6500/1 interface signals are provided in the device. While the pin assignments are different from the R6500/1 in order to accommodate the 64-pin package, the interface electrical characteristics are identical. The 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 device.

## EXTERNAL FREQUENCY REFERENCE

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

## I/O PORT PULLUPS

The device has internal I/O port pullup resistance only.

## DEVICE ADDITIONAL SIGNALS

| Signal <br> Name | Pin <br> No. | Description |
| :---: | :---: | :---: |
| $\mathrm{R} / \overline{\mathrm{W}}$ | 62 | Read/Write. The Read/Write output con- <br> trois the direction of data transfer between <br> the CPU and external memory. This line <br> is high when reading data from memory <br> and low when writing data to memory. |

3 Ready. The Ready input delays execution of any cycle during which the RDY line is low. This allows the user to halt or single step the CPU on 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 fetched. If RDY is low during a write cycle, it is ignored until the following read operation. This condition will remain through a subsequent $\Phi 2$ clock pulse in which the RDY line is low.

SYNC 6 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 stay 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 its current state and will remain in that state until the RDY line goes high. Using this technique, the SYNC signal can be used to control RDY to cause single instruction execution.

| Signal | Pin |  |
| :--- | :--- | :--- |
| Name | No. | Description |

1 Phase 2 ( $\Phi 2$ ) clock pulse. Data transfer can take place only during $\Phi 2$ clock pulse.

Address Bus Lines. The address bus buffers on the device 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.

Data bus Lines. All transfers of instructions and data between the CPU and external memory 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.

## I/O PORT INITIALIZATION

Ports $A, B, C$ and $D$ and the CNTR line in the device are initialized to the logic high state two $\Phi 2$ clock cycles earlier than in the R6500/1. It is still required, however, that the $\overline{\operatorname{RES}}$ line be held low for at least eight $\Phi 2$ clock cycles after $V_{C C}$ reaches operating range (Figure 1).

## TYPICAL PROGRAM MEMORY INTERCONNECTIONS

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

Figure 3 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.


Figure 1. I/O Port Initialization

CONNECTION DIAGRAM


MEMORY MAP


Figure 2. Device Connected to One 2716 PROM (2K Bytes)


Figure 3. Device Connected to Three PROMS (3K Bytes)

## TRUTH TABLE

| Address |  | PROM Select |  |  | Selected Address Range |
| :---: | :---: | :---: | :---: | :---: | :---: |
| A11 | A10 | ${ }^{2708} \overline{\mathrm{NE}} .3$ | $\begin{gathered} 2708 \text { No. } 2 \\ \overline{C E} \end{gathered}$ | $\begin{gathered} 2808 \text { No. } 1 \\ \overline{C E} \end{gathered}$ |  |
| 0 | 0 | 1 | 1 | 1 | 000-3FF |
| 0 | 1 | 1 | 1 | 0 | 400-7FF |
| 1 | 0 | 1 | 0 | 1 | 800-BFF |
| 1 | 1 | 0 | 1 | 1 | C00-FFF |

## DEVICE TIMING

| Signal | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{R} \bar{W}$ setup time from CPU | $T_{\text {RWS }}$ |  | 300 |  | 200 | ns |
| Address setup time from CPU | $T_{\text {ADS }}$ |  | 300 |  | 200 | ns |
| Memory read access time | $\mathrm{T}_{\text {ACC }}$ |  | 525 |  | 225 | ns |
| Data stabilization time | TDSU | 150 |  | 75 |  | ns |
| Data hold time - Read | THR | 10 |  | 10 |  | ns |
| Data hold time - Write | THW | 30 |  | 30 |  | ns |
| Data delay time from CPU | TMDS |  | 200 |  | 150 | ns |
| RDY setup time | TRDY | 100 |  | 50 |  | ns |
| SYNC delay time from CPU | TSYNC |  | 350 |  | 175 | ns |
| Address hold time | THA | 30 |  | 30 |  | ns |
| $\mathrm{R} \bar{W}$ hold time | THRW | 30 |  | 30 |  | ns |
| Cycle Time | TCYC | 1.0 | 10.0 | 0.5 | 10.0 | $\mu \mathrm{S}$ |

## ELECTRICAL CHARACTERISTICS

( $\mathrm{V}_{\mathrm{CC}}=5.0 \pm 5 \%, \mathrm{~V}_{S S}=0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ )

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Threshold Voltage DO-D7, RDY, | $\mathrm{V}_{\text {IHT }}$ | $\mathrm{V}_{\text {SS }}+2.4$ | - | - | Vdc |
| Input Low Threshold Voltage DO-D7, RDY, | VILT | - | - | $\mathrm{V}_{\text {SS }}+0.8$ | Vdc |
| Three-State (Off State) Input Current ( $\mathrm{V}=0.4$ to $2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ ) DO-D7 | ITSI | - | - | 10 | $\mu \mathrm{A}$ |
| Output High Voltage <br> (LOAD $=100 \mu \mathrm{Adc}, \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ ) <br> DO-D7, SYNC, AO-A11, R $\bar{W}, \phi 2$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{SS}}+2.4$ | - | - | Vdc |
| Output Low Voltage ( $\mathrm{LOAD}=1.6 \mathrm{mAdc}, \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}$ ) DO-D7, SYNC, AO-A11, R $\bar{W}, \phi 2$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | $V_{S S}+0.6$ | Vdc |
| Power Dissipation | PD | - | 0.75 | 1.20 | W |
| ```Capacitance ( \(\mathrm{V}_{\mathrm{in}}=0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\) ) RDY DO-D7 AO-A.11, R/W, SYNC 中2``` | $\begin{gathered} \mathrm{C} \\ \mathrm{C}_{\text {in }} \\ \mathrm{C}_{\text {out }} \\ \mathrm{C}_{\phi 2} \end{gathered}$ | - | $\frac{-}{50}$ | $\begin{array}{r} 10 \\ 15 \\ 12 \\ 80 \\ \hline \end{array}$ | pF |
| I/O Port Pull-up Resistance | $\mathrm{R}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | kohm |

## DETAILED MEMORY MAP



## TIMING DIAGRAMS



## PACKAGE DIMENSIONS

R6500/1EC 64-PIN DIP CERAMIC


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


## R6500/1EB and R6500/1EAB BACKPACK EMULATOR

## INTRODUCTION

The Rockwell R6500/1EB and R6500/1EAB Backpack Emulator is the PROM prototyping version of the 8 -bit, masked-ROM R6500/1 one-chip microcomputer. Like the R6500/1, the backpack device is totally upward/downward compatible with all members of the R6500/1 family. It is designed to accept standard 5-volt, 24-pin EPROMs or ROMs directly, in a socket on top of the Emulator. This packaging concept allows a standard EPROM to be easily removed, reprogrammed, then reinserted as often as desired.

The backpack devices have the same pinouts as the maskedROM R6500/1 microcomputer. These 40 pins are functionally and operationally identical to the pins on the R6500/1, with some minor differences (described herein). The R6500/1 Microcomputer Data Sheet (Rockwell Document No. 29000D51) 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

BACKPACK EMULATOR

| Part <br> Number | Memory <br> Capacity | Compatible <br> Memories | Temperature <br> Range and Speed |
| :--- | :---: | :---: | :---: |
| R6500/1EB1 | $2 \mathrm{~K} \times 8$ | 2716,2516 <br> 2316 B | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| 1 MHz |  |  |  |
| R6500/1EB3 | $3 \mathrm{~K} \times 8$ | 2732 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
|  |  | 1 MHz |  |
| R6500/1EAB3 | $3 \mathrm{~K} \times 8$ | 2732 A <br> $(250 \mathrm{~ns})$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ <br> 2 MHz |

SUPPORT PRODUCTS

| Part <br> Number | Description |
| :---: | :---: |
| S65-101 | SYSTEM 65 Microcomputer Development System |
| M65-040 | PROM Programmer Module |
| M65-081 | 1-MHz R6500/1 Personality Module |
| M65-082 | 2-MHz R6500/1 Personality Module |

## FEATURES

- PROM version of the R6500/1
- Completely pin compatible with R6500/1 single-chip - microcomputers
- Profile approaches 40-pin DIP of R6500/1
- Accepts 5-volt, 24-pin industry-standard EPROMs
-4K memories-2732, 2732A (3K bytes addressable)
—2K memories-2716, 2516, 2316B
- 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 external time base
- Single +5 V power supply


R6500/1EB-R6500/1EAB Backpack Emulator

## CONFIGURATIONS

The Backpack Emulator is available in three different versions, to accommodate various 24 -pin 2 K - and 4 K -memories and speeds. All three 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{\mathrm{OE}, \mathrm{CE}}$, $V_{C C}$ and $V_{S S}$ signals (one line each). See the Interface Diagram.

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

## EXTERNAL FREQUENCY REFERENCE

The external frequency reference may be a crystal or a clockthe RC option is not available in the emulator device. The R6500/1EB and R6500/1EAB divide the input clock by two regardless of the source.

## I/O PORT PULLUPS

The emulator devices have internal I/O port pullup resistors.

## TEST MODE DELETED

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

## PRODUCT SUPPORT

The Backpack Emulator is just one of the products that Rockwell offers to facilitate system and program development for the R6500/1.

The 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 2K ROM of the R6500/1.

In addition to support products, Rockwell offers regularlyscheduled designer's courses at regional centers.


## DETAILED MEMORY MAP

|  |  | HEX |
| :---: | :---: | :---: |
| PROM | IRQ VECTOR HIGH | FFF |
|  | IRQ VECTOR LOW | FFE |
|  | RES VECTOR HIGH | FFD |
|  | RES VECTOR LOW | FFC |
|  | NMI VECTOR HIGH | FFB |
|  | NMI VECTOR LOW | FFA |
|  | R6500/1 USER PROGRAM | 400 |
| PROM | R6500/1EB EXTENDED PROGRAM AREA (1) |  |
| $\begin{array}{\|l} \hline \text { NOT } \\ \text { USE } \end{array}$ | UNASSIGNED | 08F |
| 1/0 | CONTROL REGISTER |  |
|  | $\cdots$ UNASSIGNED | E |
|  | CLEAR PA1 NEG EDGE DETECTED (2) | 08A |
|  | CLEAR PAO POS EDGE DETECTED (2) | 089 |
|  | UPPER LATCH AND TRANSFER LATCH TO COUNTER | 088 |
|  | LOWER COUNT (3) | 087 |
|  | UPPER COUNT | 086 |
|  | LOWER LATCH | 085 |
|  | UPPER LATCH | 084 |
|  | PORT D | 083 |
|  | PORT C | 082 |
|  | PORT B | 081 |
|  | PORT A | 080 |
| $\begin{aligned} & \hline \text { NOT } \\ & \text { USED } \end{aligned}$ | UNASSIGNED | 03F |
| RAM | USER RAM | 000 |

## NOTES

(1) Additional 1024 bytes are decoded for external memory addressing by the Backpack Emulator Device. This area can be used during debut, but cannot be used in a masked ROM R6500/1. (Available only on R6500/1EB3s)
(2) I/O command only; i.e., no stored data.
(3) Clears Counter Overflow-Bit 7 in Control Register
(4) CAUTION: The device allows RAM mapping into 040-07F, 100-13F, 140-17F, 200-23F, 240-27F, 300-33F, and 340-37F; as well as 000-03F. The production R6500/1, however allows RAM mapping only at 000-03F.

## RAM MAPPING

The Backpack Emulator allows RAM mapping into 040-07F, 100-13F, 140-17F, 200-23F, 240-27F, 300-33F and 340-37F, as well as 000-03F. The production R6500/1, however, allows RAM mapping only at 000-03F. This means that a write to location 40, for example, will write to location 0 in the Backpack Emulator, and to invalid RAM in the R6500/1 production part:

## I/O PORT INITIALIZATION

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

## BACKPACK MEMORY SIGNAL DESCRIPTION

| Signal Name | Pin No. | Description |
| :---: | :---: | :---: |
| D0-D7 | $\begin{aligned} & \text { 9S-11S, } \\ & \text { 13S-17S } \end{aligned}$ | Data Bus Lines. All instruction and data transfers take place on the data bus lines. The buffers driving the data bus lines have full threestate capability. Each data bus pin is connected to an input and an output buffer, with the output buffer remaining in the floating condition. |
| A0-A9 | $\begin{aligned} & 1 \mathrm{~S}-8 \mathrm{~S} \\ & 23 \mathrm{~S}, 24 \mathrm{~S} \end{aligned}$ | Address Bus Línes. 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 A0-A9. |
| $\overline{\mathrm{CE}}$ | 185 | Chip Enable. In the R6500/1EB1, $\overline{\mathrm{CE}}$ is active when the address is 800-FF. In the R6500/1EB3 and R6500/1EAB3, $\overline{C E}$ is active when the address is 400 -FFF. This line can drive one TTL load. |
| $\overline{\mathrm{OE}}$ | $20 S$ | Memory Enable Line. This signal provides the output enable for the memory to place information on the data bus lines. This signal is driven by the $R / \bar{W}$ signal from the CPU and then inverted by a standard TTL inverter, to form $\overline{\mathrm{OE}}$. |
| $\mathrm{V}_{\mathrm{Cc}}$ | 24S | Main Power Supply +5 V . This pin is tied directly to pin 30 ( $\mathrm{V}_{\mathrm{CC}}$ ). |
| $\mathrm{V}_{\mathrm{CC}} / \mathrm{A} 11$ | 215 | Main Power Supply +5 V . This pin is tied directly to pin $30\left(\mathrm{~V}_{\mathrm{cc}}\right)$, except in the R6500/1EB3 and R6500/1EAB3, where it is tied to A11. During backup power, power is supplied only to the RAM memory, and not to the PROMs. |
| $\mathrm{V}_{\mathrm{SS}}$ | 12 S | Signal and Power Ground (zero volts). This pin is tied directly to pin $12\left(\mathrm{~V}_{\mathrm{SS}}\right)$. |



NOTE: (1) PIN 21 IS $\mathbf{V}_{\text {cc }}$ FOR R6500/1EB1 OR A11 FOR R6500/1EB3

READ TIMING CHARACTERISTICS


## READ TIMING WAVEFORMS



* $\phi 2$ IS SHOWN FOR REFERENCE ONLY AND IS NOT AVAILABLE EXTERNAL TO THE DEVICE.

I/O PORT INITIALIZATION TIMING

$\overline{R E S}$ TRANSITION WINDOW
don't care state

## 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 | $\mathrm{V}_{\text {IHT }}$ | $\mathrm{V}_{\mathrm{ss}}+2.4$ | - | - | Vdc |
| Input Low Threshold Voltage D0-D7 | $V_{\text {ILT }}$ | - | - | $\mathrm{V}_{\mathrm{ss}}+0.8$ | Vdc |
| 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> D0-D7 | $\mathrm{I}_{\text {T }}$ | - | - | 10 | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { Output High Voltage } \\ & \text { ( } \mathrm{I}_{\text {LAAD }}=100 \mu \mathrm{Adc}, \mathrm{~V}_{\mathrm{cC}}=4.75 \mathrm{~V} \text { ) } \\ & \text { DO-D7, A0-A11, } \overline{\mathrm{OE}} \end{aligned}$ | $\mathrm{V}_{\text {OH }}$ | $\mathrm{V}_{\mathrm{ss}}+2.4$ | - | - | Vdc |
| $\begin{aligned} & \text { Output Low Voltage } \\ & \text { (ILOAD }=1.6 \mathrm{mAdc}, \mathrm{~V}_{\mathrm{cc}}=4.75 \mathrm{~V} \text { ) } \\ & \mathrm{DO}-\mathrm{D7}, \mathrm{AO}-\mathrm{A} 11, \overline{\mathrm{OE}} \end{aligned}$ | V OL | - | - | $\mathrm{V}_{\mathrm{ss}}+0.6$ | Vdc |
| Power Dissipation | Po | - | 0.80 | 1.30 | W |
| $\begin{aligned} & \text { Capacitance } \\ & \left(V_{\text {in }}=0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right) \\ & \text { D0-D7 } \\ & \text { AO-A11 } \end{aligned}$ | $\begin{aligned} & C \\ & C_{\text {in }} \\ & C_{\text {out }} \end{aligned}$ | - | - | $\begin{aligned} & 15 \\ & 12 \end{aligned}$ | pF |
| I/O Port Pull-up Resistance | $\mathrm{R}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | kohm |

## PACKAGE DIMENSIONS

40-PIN BACKPACK


# R6500/11 AND R6500/12 ONE-CHIP MICROCOMPUTERS 

## SECTION 1 INTRODUCTION

### 1.1 FEATURES OF THE R6500/11 \& /12

- Enhanced 6502 CPU
-Four new bit manipulation instructions:
Set Memory Bit (SMB)
Reset Memory Bit (RMB)
Branch on Bit Set (BBS)
Branch on Bit Reset (BBR)
-Decimal and binary arithmetic modes
- 13 addressing modes
-True indexing
- 3K-byte mask-programmable ROM
- 192-byte static RAM
- 32 TTL-compatible I/O lines (R6500/11)
- 56 TTL-compatible I/O lines (R6500/12)
- One 8-bit port may be tri-stated under software control
- One 8-bit port with programmable latched input
- Two 16-bit programmable counter/timers, with latches
-Pulse width measurement
-Asymmetrical pulse generation
-Pulse generation
- Interval timer
-Event counter
-Retriggerable interval timer
- Serial port
-Full-duplex asynchronous operation mode
-Selectable 5- to 8-bit characters
-Wake-up feature
-Synchronous shift register mode
-Standard programmable bit rates, programmable up to 62.5 K bits $/ \mathrm{sec}$ @ 1 MHz
- Ten interrupts
-Four edge-sensitive lines; two positive, two negative
-Reset
-Non-maskable
-Two counter underflows
-Serial data received
-Serial data transmitted
- Bus expandable to 16 K bytes of external memory
- Flexible clock circuitry
$-2-\mathrm{MHz}$ or $1-\mathrm{MHz}$ internal operation
-Internal clock with external 2 MHz to 4 MHz series resonant XTAL at two or four times internal frequency
-External clock input divided by one, two or four
- $1 \mu \mathrm{~s}$ minimum instruction execution time @ 2 MHz
- NMOS-3 silicon gate, depletion load technology
- Single +5 V power supply
- 12 mW stand-by power for 32 bytes of the 192-byte RAM
- 40-pin DIP (R6500/11)
- 64-pin QUIP (R6500/12)


### 1.2 SUMMARY

The Rockwell R6500/11 or R6500/12 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/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 fullduplex serial I/O channel, ten interrupts and bus expandability.

The R6500/12 consists of all the features of the R6500/11 plus three additional I/O ports. It is packaged in a 64 pin QUIP.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of computational power. These features make either device a leading candidate for microcomputer applications.

To allow prototype circuit development, Rockwell offers a PROM-compatible 64-pin extended microprocessor device. This device, the R6511Q, provides all R6500/11 interface lines, plus the address bus, data bus and control lines to interface with external memory. With the addition of external circuits it can also be used to emulate the R6500/12 (contact Rockwell offices for details).

A backpack emulator, the R65/11EB, is available for developing R6500/11 applications. No backpack part is available for the R6500/12.

The R6511Q may also be used as a CPU-RAM-I/O counter device in multichip systems.

Rockwell supports development of the devices with the System 65 Microcomputer Development System and the R6500/* Family of Personality Modules. Complete in-circuit emulation with the R6500/* Family of Personality Modules allows total system test and evaluation.

This product description is for the reader familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual (Order Number 201). A description of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Order Number 202).

### 1.3 CUSTOMER OPTIONS

The R6500/11 microcomputer is available with the following customer specified mask options:

- Option 1 Crystal or RC oscillator
- Option 2 Clock divide by 2 or 4
- Option 3 Clock MASTER Mode or SLAVE Mode
- Option 4 Port A with or without internal pull-up resistors
- Option 5 Port B with or without internal pull-up resistors
- Option 6 Port C with or without internal pull-up resistors

All options should be specified on an R6500/11 order form.
The R6500/12 is available with all of the above options plus:

- Option 7 Port F with or without internal pull-up resistors
- Option 8 Port G with or without internal pull-up resistors


## SECTION 2 INTERFACE REQUIREMENTS

This section describes the interface requirements for the single chip microcomputer devices. Figure 2-1 is the Interface Diagram for the devices, Figure 2-2 and Figure 2-3 show the mechanical outline and pin out configurations and Table 2-1 describes the function of each pin. Figure 3-1 has a detailed block diagram of the device which illustrates its internal functions.


Figure 2.1 Interface Diagram


Figure 2-2. R6500/11 Mechanical Outline and Pin Out Configuration


Figure 2-3. R6500/12 Siechanical Outline and Pin Out Configuration

Table 2-1. R6500/11 and R6500/12 Pin Descriptions

| Signal Name | Pin Number |  | Description |
| :---: | :---: | :---: | :---: |
|  | R6500/11 | R6500/12 |  |
| $\mathrm{V}_{\mathrm{cc}}$ | 21 | 50 | Main power supply +5 V |
| $V_{\text {RR }}$ | 39 | 12 | Separate power pin for RAM. In the event that $\mathrm{V}_{\mathrm{CC}}$ power is lost, this power retains RAM data. |
| $\mathrm{V}_{\text {SS }}$ | 40 | 11 | Signal and power ground (0V) |
| XTLI | 2 | 10 | Crystal or clock input for internal clock oscillator. Also allows input of X1 clock signal if XTLO is connected to $\mathrm{V}_{\mathrm{SS}}$, or X2 or X4 clock if XTLO is floated. |
| XTLO | 1 | 9 | Crystal output from internal clock oscillator. |
| $\overline{R E S}$ | 20 | 41 | The Reset input is used to initialize the device. This signal must not transition from low to high for at least eight cycles after $\mathrm{V}_{\mathrm{Cc}}$ reaches operating range and the internal oscillator is stabilized. |
| $\phi 2$ | 3 | 13 | Clock signal output at internal frequency. |
| $\overline{\mathrm{NMI}}$ | 22 | 51 | A negative going edge on the Non-Maskable Interrupt signal requests that a nonmaskable interrupt be generated within the CPU. |
| PAO-PA7 | 30-23 | 64-57 | Four 8-bit ports used for either input/output. Each line of Ports A, B and C consist |
| PB0-PB7 | 38-31 | 8-1 | of an active transistor to $\mathrm{V}_{S S}$ and an optional passive pull-up to $\mathrm{V}_{\mathrm{cc}}$. In the abbre- |
| PC0-PC7 | 4-11 | 25-32 | viated or multiplexed modes of operation Port C has an active pull-up transistor. |
| PD0-PD7 | 19-12 | 40-33 | Port D functions as either an 8 -bit input or 8 -bit output port. It has active pull-up and pull-down transistors. |
| PE0-PE7 | N/A | 49-42 | For the R6500/42, the 64 pin QUIP version, three additional ports (24 lines) are |
| PF0-PF7 | N/A | 24-17 | provided. Each line consists of an active transistor to $\mathrm{V}_{\text {Ss. }}$. PF0-PF7 and PG0-PG7 |
| PG0-PG7 | N/A | 52-56 4 14-16 | are bidirectional, and an optional passive pull-up to $\mathrm{V}_{\mathrm{cc}}$ is provided. PEO-PE7 is outputs only with an active pull-up. All ports will source $100 \mu \mathrm{amps}$. at 2.4 v except port E (PEO-PE7) which will source 1 ma . at 1.5 v . |

## SECTION 3 SYSTEM ARCHITECTURE

This section provides a functional description of the devices. Functionally they consist of a CPU, both ROM and RAM memories, four 8 -bit parallel I/O ports (seven in the 64-pin R6500/12), a serial I/O port, dual counter/latch circuits, a mode control register, and an interrupt flag/enable dual register circuit. A block diagram of the system is shown in Figure 3-1.

## NOTE

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

### 3.1 CPU LOGIC

The internal CPU is a standard 6502 configuration with an 8 -bit Accumulator register, two 8-bit Index Registers (X and Y); an 8-bit Stack Pointer register, an ALU, a 16-bit Program Counter, and standard instruction register/decode and internal timing control logic.

### 3.1.1 Accumulator

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

### 3.1.2 Index Registers

There are two 8-bit index registers, $X$ and $Y$. Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

### 3.1.3 Stack Pointer

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal $\overline{\mathrm{RQ}}$ interrupt, or the external interrupt line $\overline{\mathrm{NMI}}$. The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may only be accessed from the top. The address of a memory
location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1 . Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus, and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 00FF-0040. After reset, which leaves the Stack Pointer indeterminate, normal usage calls for its initialization at 00FF.

### 3.1.4 Arithmetic And Logic Unit (ALU)

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

### 3.1.5 Program Counter

The 16-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter (PCH) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

### 3.1.6 Instruction Register and Instruction Decode

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register then decoded along with timing and interrupt signals to generate control signals for the various registers.

### 3.1.7 Timing Control

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to TO each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.


### 3.1.8 Interrupt Logic

Interrupt logic controls the sequencing of three interrupts; $\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}$ and IRQ. IRQ is generated by any one of eight conditions: 2 Counter Overflows, 2 Positive Edge Detects, 2 Negative Edge Detects, and 2 Serial Port Conditions.

### 3.2 NEW INSTRUCTIONS

In addition to the standard 6502 instruction set, four instructions have been added to the devices to simplify operations that previously required a read/modify/write operation. In order for these instructions to be equally applicable to any //O ports, with or without mixed input and output functions, the $1 / O$ ports have been designed to read the contents of the specified port data register during the Read cycle of the read/ modify/write operation, rather than I/O pins as in normal read cycles. The added instructions and their format are explained in the following subparagraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions.

### 3.2.1 Set Memory Bit (SMB m, Addr.)

This instruction sets to " 1 " one of the 8 -bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and 1 of 8 bits to be set. The second byte of the instruction designates address $(00-\mathrm{FF})$ of the byte or I/O port to be operated upon.

### 3.2.2 Reset Memory Bit (RMB m, Addr.)

This instruction is the same operation and format as SMB instruction except a reset to " 0 " of the bit results.

### 3.2.3 Branch On Bit Set Relative (BBS m, Addr, DEST)

This instruction tests one of 8 bits designated by a three bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction is used to specify the 8 bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

### 3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST)

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

### 3.3 READ-ONLY-MEMORY (ROM)

The ROM consists of 3072 bytes ( 3 K ) mask programmable memory with an address space from F400 to FFFF. ROM locations FFFA through FFFF are assigned for interrupt and reset vectors.

### 3.4 RANDOM ACCESS MEMORY (RAM)

The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The R6500/11 provides a separate power pin ( $V_{\text {RR }}$ ) which may be used for standby power for 32 bytes located at 0040-005F. In the event of the loss of $V_{c c}$ power, the lowest 32 bytes of RAM data will be retained if standby power is supplied to the $V_{R R}$ pin. If the RAM data retention is not required then $V_{R R}$ must be connected to $V_{C C}$. During operation $V_{R R}$ must be at the $V_{c c}$ level.

For the RAM to retain data upon loss of $V_{C C}, V_{R R}$ must be supplied within operating range and $\overline{\text { RES }}$ must be driven low at least eight $\emptyset 2$ clock pulses before $\mathrm{V}_{\mathrm{cc}}$ falls out of operating range. RES must then be held low while $V_{c c}$ is out of operating range and until at least eight $\varnothing 2$ clock cycles after $V_{c c}$ is again within operating range and the internal $\phi 2$ oscillator is stabilized. $V_{R R}$ must remain within $V_{C C}$ operating range during normal operation. When $V_{c c}$ is out of operating range, $V_{R R}$ must remain within the $V_{R R}$ retention range in order to retain data. Figure 3.2 shows typical waveforms.


Figure 3-2. Data Retention Timing

### 3.5 CLOCK OSCILLATOR

Three customer selectable mask options are available for controlling the device timing. It can be ordered with a crystal or RC oscillator, a divide by 2 or divide by 4 countdown network and for clock master mode or clock slave mode operation.

For 2 MHz internal operations the divide by two option must be specified.

A reference frequency can be generated with the on-chip oscillator using either an external crystal or an external resistor depending on the mask option selected. The oscillator reference frequency passes through an internal countdown network (divide by 2 or divide by 4 option) to obtain the internal operating frequency (see Figure 3-3a and 3-3b). The external crystal generated reference frequency is a preferred method since the resistor method can have tolerances approaching 50\%.

## Note:

When operating at a 1 MHz internal frequency place a 15-22 pf capacitor between XTLO and ground.

a. Resistor Input

b. Crystal Input


NC $\left[\begin{array}{ll}\text { XTLO } & f_{E X T}=2 X \text { or } 4 X f i n t\end{array}\right.$

c. Clock Inputs

Figure 3-3. Clock Oscillator Input Options

Internal timing can also be controlled by driving the XTLI pin with an external frequency source. Figure 3-3c shows typical connections. If XTLO is left floating, the external source is divided by the internal countdown network. However, if XTLO is tied to $\mathrm{V}_{\mathrm{ss}}$, the internal countdown network is bypassed causing the chip to operate at the frequency of the external source.

The operation described above assumed a CLOCK MASTER MODE mask option. In this mode a frequence source (crystal, RC network or external source) must be applied to the XTLI and XTLO pins. $\varnothing 2$ is a buffered output signal which closely approximates the internal timing. When a common external source is used to drive multiple devices the internal timing between devices as well as their $\emptyset 2$ outputs will be skewed in time. If skewing represents a system problem it can be avoided by the Master/Slave connection and options shown in Figure 3-4.

One device is operated in the CLOCK MASTER MODE and a second in the CLOCK SLAVE MODE. Mask options in the SLAVE unit convert the $\varnothing 2$ signal into a clock input pin which is tightly coupled to the internal timing generator. As a result the internal timing of the MASTER and SLAVE units are synchronized with minimum skew. If the $\varnothing 2$ signal to the SLAVE unit is inverted, the MASTER and SLAVE UNITS WILL OPERATE OUT OF PHASE. This approach allows the two devices to share external memory using cycle stealing techniques.


Figure 3-4. Master/Slave Connections

### 3.6 MODE CONTROL REGISTER (MCR)

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for Counter A and Counter B. Its setting, along with the setting of the Serial Communications Control Register (SCCR); determines the basic configuration of the device in any application. Initializing this register is one of the first actions of any software program. The Mode Control Register bit assignment is shown in Figure 3-5.


Figure 3-5. Mode Control Register

The use of Counter A Mode Select is shown in Section 6.1.
The use of Counter B Mode Select is shown in Section 6.2.
The use of Port B Latch Enable is shown in Section 4.4.

The use of Port D in Tri-State Enable is shown in Section 4.6.

The use of Bus Mode Select is shown in Section 4.5 and 4.6.

### 3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)

An $\overline{\mathrm{RQ}}$ interrupt request can be initiated by any or all of eight possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple simultaneous interrupts will cause the IRQ interrupt request to remain active until all interrupting conditions have been serviced and cleared.

The Interrupt Flag Register contains the information that indicates which $\mathrm{I} / \mathrm{O}$ or counter needs attention. The contents of the Interrupt Flag Register may be examined at any time by reading at address: 0011. Edge detect IFR bits may be cleared by executing a RMB instruction at address location 0010. The RMB X, (0010) instruction reads FF, modifies bit $X$ to a " 0 ", and writes the modified value at address location 0011. In this way IFR bits set to a " 1 " after the read cycle of a Read-Modify-Write instruction (such as RMB) are protected from being cleared. A logic " 1 " is ignored when writing to edge detect IFR bits.

Each IFR bit has a corresponding bit in the Interrupt Enable Register which can be set to a "1" by writing a " 1 " in the respective bit position at location 0012. Individual IER bits may be cleared by writing a " 0 " in the respective bit position, or by $\overline{R E S}$. If set to a " 1 ", an IRQ will be generated when the corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 3-6 and the functions of each bit are explained in Table 3-1.


Figure 3-6. Interrupt Enable and Flag Registers

Table 3-1. Interrupt Flag Register Bit Codes

| $\begin{aligned} & \text { BIT } \\ & \text { CODE } \end{aligned}$ | FUNCTION |
| :---: | :---: |
| IFR 0: | PAO Positive Edge Detect Flag-Set to a "1" when a positive going edge is detected on PA0. Cleared by RMB O (0010) instruction or by RES. |
| IFR 1: | PA1 Positive Edge Detect Flag-Set to a 1 when a positive going edge is detected on PA1. Cleared by RMB 1 (0010) instruction or by $\overline{\text { RES. }}$ |
| IFR 2: | PA2 Negative Edge Detect Flag-Set to a 1 when a negative going edge is detected on PA2. Cleared by RMB 2 (0010) instruction or by $\overline{\text { RES }}$. |
| IFR 3: | PA3 Negative Edge Detect Flag-Set to 1 when a negative going edge is detected on PA3. Cleared by RMB 3 (0010) instruction or by RES. |
| IFR 4: | Counter A Underflow Flag-Set to a 1 when Counter A underflow occurs. Cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES. |
| IFR 5: | Counter B Underflow Flag-Set to a 1 when Counter B underflow occurs. Cleared by reading the Lower Counter B at location 001C, by writing to address location O01E, or by RES. |
| IFR 6: | Receiver Interrupt Flag-Set to a 1 when any of the Serial Communication Status Register bits 0 through 3 is set to a 1 . Cleared when the Receiver Status bits (SCSR 0-3) are cleared or by RES. |
| IFR 7: | Transmitter Interrupt Flag-Set to a 1 when SCSR 6 is set to a 1 while SCSR 5 is a 0 or SCSR 7 is set to a 1 . Cleared when the Transmitter Status bits (SCSR $6 \& 7$ ) are cleared or by RES. |

### 3.8 PROCESSOR STATUS REGISTER

The 8-bit Processor Status Register, shown in Figure 3-7, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6502 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

### 3.8.1 Carry Bit (C)

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

### 3.8.2 Zero Bit (Z)

The Zero Bit ( $Z$ ) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to
zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The R6500 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions; ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

### 3.8.3 Interrupt Disable Bit (I)

The Interrupt Disable Bit (I) is used to control the servicing of an interrupt request ( $\overline{\mathrm{RQ}}$ ). If the I Bit is reset to logic 0 , the $\overline{\mathrm{RQ}}$ signal will be serviced. If the bit is set to logic 1 , the $\overline{\mathrm{IRQ}}$ signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( $\overline{\operatorname{RES}}$ ), $\overline{\mathrm{RQ}}$, or Non-Maskable Interrupt ( $(\overline{\mathrm{NMI}})$ signal is detected.

The I bit is cleared by the Clear Interrupt Mask Instruction (CLI) and is set by the Set Interrupt Mask Instruction (SEI). This bit is set by the BRK Instruction. The Return from Interrupt (RTI) and Pull Processor Status (PLP) instructions will also affect the I bit.


Figure 3-7. Processor Status Register

### 3.8.4 Decimal Mode Bit (D)

The Decimal Mode Bit (D), is used to control the arithmetic mode of the CPU. When this bit is set to logic 1 , the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction will clear it. The PLP and RTI instructions also effect the Decimal Mode Bit.

## CAUTION

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application. This bit must be initialized to the desired state by the user program or erroneous results may occur.

### 3.8.5 Break Bit (B)

The Break Bit (B) is used to determine the condition which caused the $\overline{\mathrm{IRQ}}$ service routine to be entered. If the $\overline{\mathrm{RQ}}$ service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1. If the $\overline{\mathrm{RQ}}$ routine was entered as the result of an IRQ signal being generated, the $B$ bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

### 3.8.6 Overflow Bit (V)

The Overflow Bit (V) is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits $(-128 \leqslant n \leqslant 127)$.

This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7 ) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction which may be used to sample interface devices, allows the overflow flag to reflect the condition of bit. 6 in the sampled field. During a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions which affect the V flag are ADC, BIT, CLV, PLP, RTI and SBC.

### 3.8.7 Negative Bit ( N )

The Negative Bit $(\mathrm{N})$ is used to indicate that the sign bit (bit 7 ), in the resulting value of a data movement or data arithmetic operation, is set to logic 1 . If the sign bit is set to logic 1 , the resulting value of the data movement or arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

## SECTION 4 PARALLEL INPUT/OUTPUT PORTS

The R6500/11 has 32 VO lines grouped into four 8 -bit ports (PA, PB, PC, and PD). Ports A through $C$ may be used either for input or output individually or in groups of any combination. Port D may be used as all inputs or all outputs.

The R6500/12, a 64 pin QUIP device, has three additional ports: PE, PF and PG. PE is outputs only; PF and PG are bidirectional.

Multifunction I/O's such as Port A and Port C are protected from normal port $I / O$ instructions when they are programmed to perform a multiplexed function.

Internal pull-up resistors (FET's with an impedance range of $3 K \leqslant R p u \leqslant 12 K$ ohm) may be provided on all port pins except Port D and E as a mask option.

The direction of the I/O lines are controlled by four 8 -bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, which simplifies I/O handling. The //O addresses are shown in Table 4-1. Section E. 6 shows the $I / O$ Port Timing.

Table 4-1. I/O Port Addresses

| Port | Address |
| :---: | :---: |
| A | 0000 |
| B | 0001 |
| C | 0002 |
| D | 0003 |
| E | 0004 |
| F | 0005 |
| G | 0006 |

### 4.1 INPUTS

Inputs for Ports A, B, and C and also Ports F and G of the R6500/12 are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to I/O input lines. A low ( $<0.8 \mathrm{~V}$ ) input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high ( $>2.0 \mathrm{~V}$ ) input will cause a logic 1 to be read. An RES signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

Port D may only be all inputs or all outputs. All inputs is selected by setting bit 5 of the Mode Control Register (MCR5) to a "0".

The status of the input lines can be interrogated at any time by reading the I/O port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers.

Read/Modify/Write instructions can be used to modity the operation of PA, PB, PC, \& PD and also ports PF and PG of the R6500/12. During the Read cycle of a Read/Modify/ Write instruction the Port I/O register is read. For all other read instructions the port input lines are read. Read/Modify/ Write instructions are: ASL, DEC, $\mathbb{N C}$, LSR, RMB, ROL, ROR, and SMB.

### 4.2 OUTPUTS

Outputs for Ports A thru D and Ports E thru G of the R6500/ 12 are controlled by writing the desired $/ / O$ line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( $>2.4 \mathrm{~V}$ ) output while a logic 0 will force a low ( $<0.4 \mathrm{~V}$ ) output.

Port D all outputs is selected by setting MCR5 to a " 1 ".
Port E is always all outputs.

### 4.3 PORT A (PA)

Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as a standard parallel 8-bit, bit independent, I/O port or as serial channel I/O lines, counter I/O lines, or an input data strobe for the Port B input latch option. Table 4-2 tabulates the control and usage of Port A .

In addition to their normal I/O functions, PA0 and PA1 can detect positive going edges, and PA2 and PA3 can detect negative going edges. A proper transition on these pins will set a corresponding status bit in the IFR and generate an interrupt request if the respective Interrupt Enable Bit is set. The maximum rate at which an edge can be detected is onehalf the 02 clock rate. Edge detection timing is shown in Section E. 5 .

Table 4-2. Port A Control \& Usage


### 4.4 PORT B (PB)

Port $B$ can be programmed as an 8 bit, bit independent $I / O$ port. It has a latched input capability which may be enabled or disabled via the Mode Control Register (MCR). Table 4-3 tabulates the control and usage of Port B. An Input Data Strobe signal must be provided thru PAO when Port B is programmed to be used with latched input option. Input data latch timing for Port $B$ is shown in Section E.5.

Table 4-3. Port B Control \& Usage

| Pin Name | I/O Mode |  | Latch Mode |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MCR4 $=0$ |  | $\begin{gathered} \text { MCR4 }=1 \\ \text { (2) }=1 \end{gathered}$ |  |
|  | Signal |  | Signal |  |
|  | Name | Type (1) | Name | Type |
| PB0 | PBO | 1/O | PB0 | INPUT |
| PB1 | PB1 | I/O | PB1 | INPUT |
| PB2 | PB2 | I/O | PB2 | INPUT |
| PB3 | PB3 | I/O | PB3 | INPUT |
| PB4 | PB4 | 1/O | PB4 | INPUT |
| PB5 | PB5 | 1/0 | PB5 | INPUT |
| PB6 | PB6 | 1/0 | PB6 | INPUT |
| PB7 | PB7 | 1/O | PB7 | INPUT |

[^10]
### 4.5 PORT C (PC)

Port C can be programmed as an I/O port and in conjunction with Port D, as an abbreviated bus, or as a multiplexed bus. When used in the abbreviated or multiplexed bus modes, PCO-PC7 function as A0-A3, A12, R/W, A13, and EMS, respectively, as shown in Table 4-4. EMS (External Memory Select) is asserted (low) whenever the internal processor accesses memory area between 0100 and 3FFF. (See Memory Map, Appendix B). The leading edge of EMS may be used to strobe the eight address lines multiplexed on Port D in the Multiplexed Bus Mode. See Appendix E. 3 through E. 5 for Port C timing.

### 4.6 PORT D (PD)

Port D can be programmed as an I/O Port, an 8-bit tri-state data bus, or as a multiplexed bus. Mode selection for Port $D$ is made by the Mode Control Register (MCR). The Port D output drivers can be selected as tri-state drivers by setting bit 5 of the MCR to 0 (zero). Table 4-5 shows the necessary settings for the MCR to achieve the various modes for Port D. When Port $D$ is selected to operate in the Abbreviated Mode PDO-PD7 serves as data register bits DO-D7. When Port D is selected to operate in the Multiplexed Mode data bits D0 through D7 are time multiplexed with address bits A4 through A11, respectively. Refer to the Memory Maps (Appendix C) for Abbreviated and Multiplexed memory assignments. See Appendix E. 3 through E. 5 for Port D timing.

### 4.7 PORT E, PORT F AND PORT G (PE, PF \& PG) R6500/12 ONLY

Port E only operates in the Output mode. It provides a Darlington output that can source current at the high (1) level. Port $F$ and Port $G$ operate identically and can be programmed as bidirectional I/O ports. They have standard output capability. See Appendix E. 5 for Port E, F \& Port G timing.

Table 4-4. Port C Control and Usage

| Pin <br> Name | I/O Mode |  | Abbreviated Mode |  | Multiplexed Mode |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { MCR7 }=0 \\ & \text { MCR6 }=\mathrm{X} \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=0 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=1 \end{aligned}$ |  |
|  | Signal |  | Signal |  | Signal |  |
|  | Name | Type <br> (1) | Name | Type <br> (2) | Name | Type <br> (2) |
| PCO | PCO | $1 / 0$ | AO | OUTPUT | A0 | OUTPUT |
| PC1 | PC1 | $1 / 0$ | A1 | OUTPUT | A1 | OUTPUT |
| PC2 | PC2 | $1 / 0$ | A2 | OUTPUT | A2 | OUTPUT |
| PC3 | PC3 | $1 / 0$ | A3 | OUTPUT | A3 | OUTPUT |
| PC4 | PC4 | $1 / 0$ | A12 | OUTPUT | A12 | OUTPUT |
| PC5 | PC5 | $1 / 0$ | RW | OUTPUT | RW | OUTPUT |
| PC6 | PC6 | $1 / 0$ | A13 | OUTPUT | A13 | OUTPUT |
| PC7 | PC7 | $1 / 0$ | EMS | OUTPUT | EMS | OUTPUT |

(1) Resistive Pull-Up, Active Buffer Pull-Down
(2) Active Buffer Pull-Up and Pull-Down

Table 4-5. Port D Control and Usage

| Pin Name | I/O Modes |  |  |  | Abbreviated Mode |  | Multiplexed Mode |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { MCR7 }=0 \\ & \text { MCR6 }=\mathrm{X} \\ & \text { MCR5 }=0 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=0 \\ & \text { MCR6 }=X \\ & \text { MCR5 }=1 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=0 \\ & \text { MCR5 }=1 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR5 }=1 \\ & \text { MCR5 }=1 \end{aligned}$ |  |  |  |
|  | Signal |  | Signal |  | Signal |  | Signal |  | Signal |  |
|  | Name | Type (1) | Name | Type (2) | Name | Type (3) | Phase 1 |  | Phase 2 |  |
|  |  |  |  |  |  |  | Name | Type (2) | Name | Type (3) |
| PDO | PDO | INPUT | PDO | OUTPUT | DATAO | 1/0 | A4 | OUTPUT | DATAO | 1/0 |
| PD1 | PD1 | INPUT | PD1 | OUTPUT | DATA1 | $1 / 0$ | A5 | OUTPUT | DATA1 | 1/0 |
| PD2 | PD2 | INPUT | PD2 | OUTPUT | DATA2 | $1 / 0$ | A6 | OUTPUT | DATA2 | 1/0 |
| PD3 | PD3 | INPUT | PD3 | OUTPUT | DATA3 | $1 / 0$ | A7 | OUTPUT | DATA3 | \%O |
| PD4 | PD4 | INPUT | PD4 | OUTPUT | DATA4 | 1/0 | A8 | OUTPUT | DATA4 | $1 / 0$ |
| PD5 | PD5 | INPUT | PD5 | OUTPUT | DATA5 | $1 / 0$ | A9 | OUTPUT | DATA5 | 1/0 |
| PD6 | PD6 | INPUT | PD6 | OUTPUT | DATA6 | $1 / 0$ | A10 | OUTPUT | DATA6 | 1/0 |
| PD7 | PD7 | INPUT | PD7 | OUTPUT | DATA7 | $1 / 0$ | A11 | OUTPUT | DATA7 | $1 / 0$ |
| (1) Tri-State Buffer is in High Impedance Mode <br> (2) Tri-State Buffer is in Active Mode <br> (3) Tri-State Buffer is in Active Mode Only During the Phase 2 Portion of a Write Cycle |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

# SECTION 5 SERIAL INPUT/OUTPUT CHANNEL 

The device provides a full duplex Serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 5-1. The serial bit rate is determined by Counter A for all modes except the Receiver Shift Register (RCVR $S / R$ ) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5 K bits per second (@ $\varnothing 2=1 \mathrm{MHz}$ ). The transmitter (XMTR) and receiver (RCVR) can be independently programmed to operate in different modes and can be independently enabled or disabled.


Figure 5-1. Serial Communication Control Register
Except for the Receiver Shift Register Mode (RCVR S/R), all XMTR and RCVR bit rates will occur at one sixteenth of the Counter A interval timer rate. Counter A is forced into an interval timer mode whenever the serial $I / O$ is enabled in a mode requiring an internal clock.

Whenever Counter A is required as a timing source it must be loaded with the hexadecimal code that selects the data rate for the serial I/O Port. Refer to Counter A (paragraph 6.1) for a table of hexadecimal values to represent the desired data rate.

### 5.1 TRANSMITTER OPERATION (XTMR)

The XTMR operation and the transmitter related control/ status functions are enabled by bit 7 of the Serial Communications Control Register (SCCR). The transmitter, when in the Asynchronous (ASYN) mode, automatically adds a start bit, one or two stop bits, and, when enabled, a parity bit to the transmitted data. A word of transmitted data (in asynchronous parity mode) can have $5,6,7$, or 8 bits of data. The nine data modes are in Figure 5-2. When parity is disabled, the $5,6,7$ or 8 bits of data are terminated with two stop bits.


Figure 5-2. Transmitted Data Modes
In the $S / R$ mode, eight data bits are always shifted out. Bits/ character and parity control bits are ignored. The serial data is shifted out via the SO output (PA6) and the shift clock is available at the CA (PA4) pin. When the transmitter underruns in the S/R mode the SO output and shift clock are held in a high state.

The XMTR Interrupt Flag bit (IFR7) is controlled by Serial Communication Status Register bits SCSR5, BCSR6 and SCSR7.

$$
\text { IFR7 }=\text { SCSR6 }(\overline{\text { SCSR5 }}+\text { SCSR7 })
$$

### 5.2 RECEIVER OPERATION (RCVR)

The receiver and its selected control and status functions are enabled when SCCR-6 is set to a "1." In the ASYN mode, data format must have a start bit, appropriate number of data bits, a parity bit (if enabled) and one stop bit. Refer to paragraph 5.1 for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start bit and a strobe signal is generated at the approximate center of each incoming bit. Refer to Figure 5-3 for ASYN Receive Data Timing. The character assembly process does not start if the start bit signal is less than one-half the bit time after a low level is detected on the Receive Data Input. Framing error, over-run, and parity error conditions or a RCVR Data Register Full will set the appropriate status bits, and any of the above conditions will cause an Interrupt Request if the Receiver Interrupt Enable bit is set to logic 1.


Figure 5-3. ASYN Receive Data Timing
In the $\mathrm{S} / \mathrm{R}$ mode, an external shift clock must be provided at CA (PA4) pin along with 8 bits of serial data (LSB first) at the SI input (PA7). The maximum data rate using an external shift clock is one-eighth the internal clock rate. Refer to Figure 5-4 for S/R Mode Timing.


Figure 5-4. S/R Mode Timing
A RCVR interrupt (IFR6) is generated whenever any of SCSRO-3 are true.

### 5.3 SERIAL COMMUNICATION STATUS REGISTER (SCSR)

The Serial Communication Status Register (SCSR) holds information on various communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 5-5. Bit assignments and functions of the SCSR are as follows:

SCSR0: Receiver Data Register Full-Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by $\overline{\text { RES }}$ and is disabled if SCCR $6=0$. The SCSR 0 bit will not be set to a logic 1 if the received data contains an error condition, instead, a corresponding error bit will be set to a logic 1.

SCSR 1: Over-Run Error-Set to a logic 1 when a new character is transferred from the Receiver Shift Register, with the last character still in the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by $\overline{\mathrm{RES}}$.

SCSR 2: Parity Error-Set to logic 1 when the RCVR is in the ASYN Mode, Parity Enable bit is set, and the
received data has a parity error. This bit is cleared by reading the Receiver Data Register or by RES.
SCSR 3: Framing Error-Set to a logic 1 when the received data contains a zero bit-after the last data or parity bit in the stop bit slot. Cleared by reading the Receiver Data Register or by RES. (ASYN Mode only).
SCSR 4: Wake-Up-Set to a logic 1 by writing a " 1 " in bit 4 of address: 0016. The Wake-Up bit is cleared by $\overline{\text { RES }}$ or when the receiver detects a string of ten consecutive 1's. When the Wake-Up bit is set SCSR0 through SCSR3 are inhibited.
SCSR 5: End of Transmission-Set to a logic 1 by writing a " 1 " in bit position 5 of address: 0016. The End of Transmission bit is cleared by $\overline{\text { RES }}$ or upon writing a new data word into the Transmitter Data Register. When the End-of-Transmission bit is true the Transmitter Register Empty bit is disabled until a Transmitter Under-Run occurs.
SCSR 6: Transmitter Data Register Empty-Set to a logic 1 when the contents of the Transmitter Data Register is transferred to the Transmitter Shift Register. Cleared upon writing new data into the Transmit Data Register. This bit is initialized to a logic 1 by $\overline{\mathrm{RES}}$.
SCSR 7: Transmitter Under-Run-Set to a logic 1 when the last data bit is transmitted if the transmitter is in a S/R Mode or when the last stop bit is transmitted if the XMTR is in the ASYN Mode while the Transmitter Data Register Empty Bit is set. Cleared by a transfer of new data into the Transmitter Shift Register, or by RES.


Figure 5-5. SCSR Bit Allocation

### 5.4 WAKE-UP FEATURE

In a multi-distributed microprocessor or microcomputer applications, a destination address is usualiy included at the beginning of the message. The Wake-Up Feature allows non-selected CPU's to ignore the remainder of the message until the beginning of the next message by setting the WakeUp bit. As long as the Wake-Up flag is true, the Receiver Data Register Full Flag remains false. The Wake-Up bit is automatically cleared when the receiver detects a string of eleven consecutive 1's which indicates an idle transmit line. When the next byte is received, the Receiver Data Register Full Flag signals the CPU to wake-up and read the received data.

## SECTION 6 COUNTER/TIMERS

The device contains two 16-bit counters (Counter A and Counter B) and three 16 -bit latches associated with the counters. Counter A has one 16 -bit latch and Counter B has two 16-bit latches. Each counter can be independently programmed to operate in one of four modes:

## Counter A

- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Counter


## Counter B

- Retriggerable Interval Counter
- Asymmetrical Pulse Generation
- Interval Timer
- Event Counter

Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4.2).

### 6.1 COUNTER A

Counter A consists of a 16 -bit counter and a 16 -bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contains the count of either $\phi 2$ clock pulses or external events, depending on the counter mode selected. The contents of Counter A may be read any time by executing a read at location 0019 for the Upper Counter A and at location 001A or location 0018 for the Lower Counter A. A read at location 0018 also clears the Counter A Underflow Flag (IFR4).

The 16-bit latch contains the counter initialization value, and can be loaded at any time by executing a write to the Upper Latch A at location 0019 and the Lower Latch A at location 0018. In either case, the contents of the accumulator are copied into the applicable latch register.

Counter A can be started at any time by writing to address: 001 A . The contents of the accumulator will be copied into the


Figure 6-1. Interval Timer Timing Diagram

Upper Latch A before the contents of the 16 -bit latch are transferred to Counter $A$. Counter $A$ is set to the latch value whenever Counter A underflows. When Counter A decrements from 0000 the next counter value will be the latch value, not FFFF, and the Counter A Underflow Flag (IFR 4) will be set to " 1 ". This bit may be cleared by reading the Lower Counter A at location 0018, by writing to address location 001 A , or by $\overline{\mathrm{RES}}$.

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

| MCR1 <br> (bit 1) | MCR0 <br> (bit 0) | Mode |
| :---: | :---: | :--- |
| 0 | 0 | Interval Timer |
| 0 | 1 | Pulse Generation |
| 1 | 0 | Event Counter |
| 1 | 1 | Pulse Width Measurement |

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

The Counter is set to the Interval Timer Mode (00) when a $\overline{R E S}$ signal is generated.

### 6.1.1 Interval Timer

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:

1. When the Counter is decremented from 0000 , the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the $\emptyset 2$ clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore $1 \mu \mathrm{~s}$ to 65.535 ms at the $1 \mathrm{MHz} \emptyset 2$ clock rate or $0.5 \mu \mathrm{~s}$ to 32.767 ms at the $2 \mathrm{MHz} \phi 2$ clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting $\overline{\operatorname{IRQ}}$ interrupt requests in the counter $\overline{\mathrm{IRQ}}$ interrupt routine.

When Counter A decrements from 0000, the Counter A Underflow (IFR4) is set to logic 1. If the Counter A Interrupt Enable Bit (IER4) is also set, an $\overline{\operatorname{RQ}}$ interrupt request will be generated. The Counter A Underflow bit in the Interrupt Flag Register can be examined in the $\overline{\mathrm{RQ}}$ interrupt routine to determine that the $\overline{\mathrm{RQ}}$ was generated by the Counter A Underflow.

While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.

### 6.1.2 Pulse Generation Mode

In the Pulse Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs, or a write is performed to address 001 A .

The normal output waveform is a symmetrical square-wave. The CA output is initialized high when entering the mode and transitions low when writing to 001 A .

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

### 6.1.3 Event Counter Mode

In this mode the CA is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the $\varnothing 2$ clock rate.

The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter A Underflow bit (IER4) is set to logic 1 if the underflow occurs.

Figure 6.2 is a timing diagram of the Event Counter Mode.


Figure 6-2. Event Counter Mode

### 6.1.4 Pulse Width Measurement Mode

This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the $\phi 2$ clock rate as long as the CA line is held in the low state. The Counter is stopped when CA is in the high state.

The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4.

A timing diagram for the Pulse Width Measurement Mode is shown in Figure 6.3.


### 6.1.5 Serial I/O Data Rate Generation

Counter A also provides clock timing for the Serial I/O which establishes the data rate for the Serial I/O port. When the Serial I/O is enabled, Counter $A$ is forced to operate at the internal clock rate. Counter $A$ is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4-2).

Table 6-1 identifies the values to be loaded in Counter A for selecting standard data rates with a $\phi 2$ clock rate of 1 MHz and 2 MHz . Although Table 6-1 identifies only the more common data rates, any data rate from 1 to 62.5 K bps can be selected by using the formula:

$$
N=\frac{\phi 2}{16 \times \mathrm{bps}}-1
$$

where
$\mathrm{N} \quad=$ decimal value to be loaded into Counter A using its hexadecimal equivalent.
$\phi 2$ = the clock frequency ( 1 MHz or 2 MHz )
$\mathrm{bps}=$ the desired data rate .

## NOTE

In Table 6-1 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of $1.5 \%$ or less are acceptable. A revised clock rate is included in Table 6-1 for those baud rates which fall outside this limit.

Table 6-1. Counter A Values for Baud Rate Selection

| Standard Baud Rate | Hexadecimal Value |  | Actual Baud Rate At |  | Clock Rate Needed To Get Standard Baud Rate |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1 MHz | 2 MHz | 1 MHz | 2 MHz | 1 MHz | 2 MHz |
| 50 | 04E1 | 09C3 | 50.00 | 50.00 | 1.0000 | 2.0000 |
| 75 | 0340 | 0682 | 75.03 | 74.99 | 1.0000 | 2.0000 |
| 110 | 0237 | 046F | 110.0 | 110.04 | 1.000 | 2.0000 |
| 150 | 01A0 | 0340 | 149.88 | 150.06 | 1.0000 | 2.0000 |
| 300 | OOCF | 01A0 | 300.48 | 299.76 | 1.0000 | 2.0000 |
| 600 | 0067 | 00CF | 600.96 | 600.96 | 1.0000 | 2.0000 |
| 1200 | 0033 | 0067 | 1201.92 | 1201.92 | 1.0000 | 2.0000 |
| 2400 | 0019 | 0033 | 2403.85 | 2403.85 | 1.0000 | 2.0000 |
| 3600 | 0010 | 0021 | 3676.47 | 3676.47 | 0.9792 | 1.9584 |
| 4800 | 000C | 0019 | 4807.69 | 4807.69 | 1.0000 | 2.0000 |
| 7200 | 0008 | 0010 | 6944.44 | 7352.94 | 1.0368 | 1.9584 |
| 9600 | 0006 | 000 C | 8928.57 | 9615.38 | 1.0752 | 2.0000 |

### 6.2 COUNTER B

Counter B consists of a 16 -bit counter and two 16 -bit latches organized as follows: Lower Counter B (LCB), Upper Counter B (UCB), Lower Latch B (LLB), Upper Latch B (ULB), Lower Latch C (LLC), and Upper Latch C (ULC). Latch C is used only in the asymmetrical pulse generation mode. The counter contains the count of either $\varnothing 2$ clock pulses or external events depending on the counter mode selected. The contents of Counter B may be read any time by executing a read at location 001D for the Upper Counter B and at location 001E or 001C for the Lower Counter B. A read at location 001C also clears the Counter B Underflow Flag.

Latch B contains the counter initialization value, and can be loaded at any time by executing a write to the Upper Latch $B$ at location 001D and the Lower Latch B at location 001C. In each case, the contents of the accumulator are copied into the applicable latch register.

Counter B can be initialized at any time by writing to address: 001 E . The contents of the accumulator is copied into the Upper Latch B before the value in the 16 -bit Latch B is transferred to Counter B. Counter B will also be set to the latch value and the Counter B Underflow Flag bit (IFR5) will be set to a "1" whenever Counter $B$ underflows by decrementing from 0000.

IFR 5 may be cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by RES.

Counter B operates in the same manner as Counter A in the Interval Timer and Event Counter modes. The Pulse Width Measurement Mode is replaced by the Retriggerable Interval Timer mode and the Pulse Generation mode is replaced by the Asymmetrical Pulse Generation Mode.

### 6.2.1 Retriggerable Interval Timer Mode

When operating in the Retriggerable Interval Timer mode, Counter $B$ is initialized to the latch value by writing to address 001E, by a Counter B underflow, or whenever a positive edge occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the CB line. Figure 6-4 illustrates the operation.


Figure 6-4. Counter B Retriggerable Interval Timer Mode

### 6.2.2 Asymmetrical Pulse Generation Mode

Counter B has a special Asymmetrical Pulse Generation Mode whereby a pulse train with programmable pulse width and period can be generated without the processor intervention once the latch values are initialized.

In this mode, the 16 -bit Latch $B$ is initialized with a value which corresponds to the duration between pulses (referred to as $D$ in the following descriptions). The 16 -bit Latch $C$ is initialized with a value which corresponds to the desired pulse width (referred to as $P$ in the following descriptions). The initialization sequence for Latch B and C and the starting of a counting sequence are as follows:

1. The lower 8 bits of $P$ are loaded into LLB by writing to address 001C, and the upper 8 bits of $P$ are loaded into ULB and the full 16 bits are transferred to Latch C by writing to address location 001D. At this point both Latch $B$ and Latch $C$ contain the value of $P$.
2. The lower 8 bits of $D$ are loaded into LLB by writing to address 001 C , and the upper 8 bits of $D$ are loaded into ULB by writing to address location 001E. Writing to address location 001E also causes the contents of the 16 -bit Latch $B$ to be downloaded into the Counter $B$ and causes the CB output to go low as shown in Figure 6-5.
3. When the Counter $B$ underflow occurs the contents of the Latch $C$ is loaded into the Counter $B$, and the CB output toggles to a high level and stays high until another underflow occurs. Latch $B$ is then down-loaded and the CB output toggles to a low level repeating the whole process.

## SECTION 7 <br> POWER ON/INITIALIZATION CONSIDERATIONS

### 7.1 POWER-ON TIMING

After application of $V_{C C}$ and $V_{R A}$ power to the R6500/11, $\overline{\operatorname{RES}}$ must be held low for at least eight $\varnothing 2$ clock cycles after $V_{c c}$ reaches operating range and the internal oscillator has stabilized. This stabilization time is dependent upon the input $\mathrm{V}_{c c}$ voltage and performance of the internal oscillator. The clock can be monitored at $\emptyset 2$ (pin 3). Figure 7-1 illustrates the power turn-on waveforms. Clock stabilization time is typically 20 ms .


Figure 7-1. Power Turn-on Timing Detail

### 7.2 POWER-ON RESET

The occurrence of $\overline{R E S}$ going from low to high will cause the R6500/11 to set the Interrupt Mask Bit—bit 2 of the Processor Status Register-and initiate a reset vector fetch at address FFFC and FFFD to begin user program execution. All of the I/O ports (PA, PB, PC, PD) will be forced to the high (logic 1) state. All bits of the Control Register will be cleared to logic 0 causing the Interval Timers counter mode (mode 00 ) to be selected and causing all interrupt enabled bits to be reset.


Figure 6-5. Counter B Pulse Generation

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

When $\overline{\text { RES }}$ is driven from low to high the R6500/11 is put in a reset state causing the registers and I/O ports to be configured as shown in Table 7-1.

Table 7-1. $\overline{R E S}$ Initialization of I/O Ports and Registers

|  | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Registers |  |  |  |  |  |  |  |  |
| Processor Status | - | - | - | - | - | 1 | - | - |
| Mode Control (MCR) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Int. Enable (IER) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Int. Flag (IFR) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Ser. Com. Control (SCCR) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Ser. Com. Status (SCSR) | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| Ports |  |  |  |  |  |  |  |  |
| PA Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PB Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PC Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PD Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

All RAM and other CPU registers will initialize in a random, non-repeatable data pattern.

### 7.4 INITIALIZATION

Any initialization process for the R6500/11 should include a $\overline{\mathrm{RES}}$, as indicated in the preceeding paragraphs. After stabilization of the internal clock (if a power on situation) an initialization subroutine should be executed to perform (as a minimum) the following functions:

1. The Stack Pointer should be set
2. Clear or Set Decimal Mode
3. Set or Clear Carry Flag
4. Set up Mode Controls as required
5. Clear Interrupts

A typical initialization subroutine could be as follows:

| LDX | Load stack pointer starting address into $X$ |
| :--- | :--- |
|  | Register |

# APPENDIX A <br> ENHANCED R6502 INSTRUCTION SET 


#### Abstract

This appendix contains a summary of the R6502 instruction set. For detailed information, consult the R6502 Microcomputer System Programming Manual, Document 29650 N30. The four instructions notated with a * are added instructions to enhance the standard 6502 instruction set.


## A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE

| ADC | Add Memory to Accumulator with Carry | LDA | Load Accumulator with Memory |
| :---: | :---: | :---: | :---: |
| AND | "AND" Memory with Accumulator | LDX | Load Index X with Memory |
| ASL | Shift Left One Bit (Memory or Accumulator) | LDY | Load Index Y with Memory |
|  |  | LSR | Shift One Bit Right (Memory or |
| *BBR | Branch on Bit Reset Relative |  | Accumulator) |
| *BBS | Branch on Bit Set Relative |  |  |
| BCC | Branch on Carry Clear | NOP | No Operation |
| BCS | Branch on Carry Set |  |  |
| BEQ | Branch on Result Zero | ORA | "OR" Memory with Accumulator |
| BIT | Test Bits in Memory with Accumulator |  |  |
| BMI | Branch on Result Minus | PHA | Push Accumulator on Stack |
| BNE | Branch on Result not Zero | PHP | Push Processor Status on Stack |
| BPL | Branch on Result Plus | PLA | Pull Accumulator from Stack |
| BRK | Force Break | PLP. | Pull Processor Status from Stack |
| BVC | Branch on Overflow Clear |  |  |
| BVS | Branch on Overflow Set | $\begin{gathered} \text { *RMB } \\ \text { ROL } \end{gathered}$ | Reset Memory Bit Rotate One Bit Left (Memory or |
| CLC | Clear Carry Flag |  | Accumulator) |
| CLD | Clear Decimal Mode | ROR | Rotate One Bit Right (Memory or |
| CLI | Clear Interrupt Disable Bit |  | Accumulator) |
| CLV | Clear Overflow Flag | RTI | Return from Interrupt |
| CMP | Compare Memory and Accumulator | RTS | Return from Subroutine |
| CPX | Compare Memory and Index X |  |  |
| CPY | Compare Memory and Index Y | SBC | Subtract Memory from Accumulator with Borrow |
| DEC | Decrement Memory by One | SEC | Set Carry Flag |
| DEX | Decrement Index $X$ by One | SED | Set Decimal Mode |
| DEY | Decrement Index $Y$ by One | SEI | Set Interrupt Disable Status |
|  |  | *SMB | Set Memory Bit |
| EOR | "Exclusive-Or" Memory with | STA | Store Accumulator in Memory |
|  | Accumulator | STX | Store Index X in Memory |
|  |  | STY | Store Index Y in Memory |
| INC | Increment Memory by One |  |  |
| INX | Increment Index $X$ by One | TAX | Transfer Accumulator to !ndex X |
| INY | Increment Index Y by One | TAY | Transfer Accumulator to Index $Y$ |
|  |  | TSX | Transfer Stack Pointer to Index X |
| JMP | Jump to New Location | TXA | Transfer Index $X$ to Accumulator |
| JSR | Jump to New Location Saving Return | TXS | Transfer Index $X$ to Stack Register |
|  | Address | TYA | Transfer Index Y to Accumulator |



## A． 3 INSTRUCTION CODE MATRIX



|  | ${ }^{0}$ | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\sum_{0} 0$ | BRK Implied 17 | $\begin{array}{\|c\|} \hline \text { ORA } \\ \text { (IND, X) } \\ 2 \quad 6 \\ \hline \end{array}$ |  |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | ASL ZP 25 | $\begin{gathered} \text { RMBO } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | PHP Implied 13 | $\begin{aligned} & \hline \text { ORA } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ | ASL Accum 12 |  |  | $\begin{aligned} & \hline \text { ORA } \\ & \text { ABS } \\ & 3 \quad 4 \\ & \hline \end{aligned}$ | ASL ABS <br> 36 | $\begin{aligned} & \text { BBRO } \\ & \text { ZP } \\ & 3 \quad 5^{* *} \end{aligned}$ | 0 |
| 1 | BPL <br> Relative 2 2＊＊ | $\begin{gathered} \text { ORA } \\ \text { (IND), Y } \\ 25^{*} \end{gathered}$ |  |  |  | $\begin{gathered} \hline \text { ORA } \\ \text { ZP, } X \\ 24 \\ \hline \end{gathered}$ | $\begin{gathered} \text { ASL } \\ \text { ZP, } \mathrm{X} \\ 26 \end{gathered}$ | $\begin{gathered} \text { RMB1 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | CLC Implied $1 \quad 2$ 12 |  |  |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ABS, } X \\ & 34^{*} \end{aligned}$ | $\begin{gathered} \text { ASL } \\ \text { ABS, } X \\ 37 \end{gathered}$ | $\begin{aligned} & \text { BBR1 } \\ & \text { ZP } \\ & 3 \quad 5^{* *} \end{aligned}$ | 1 |
| 2 | $\begin{array}{\|c\|} \hline \text { JSR } \\ \text { Absolute } \\ 3 \\ \hline \end{array}$ | $\begin{aligned} & \text { AND } \\ & \text { (IND, X) } \\ & 266 \end{aligned}$ |  |  | $\begin{aligned} & \text { BIT } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { AND } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \mathrm{ROL} \\ & \mathrm{ZP} \\ & 2 \quad 5 \end{aligned}$ | $\begin{aligned} & \text { RMB2 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{aligned} & \text { PLP } \\ & \text { Implied } \\ & 14 \end{aligned}$ | AND <br> IMM <br> 22 |  |  | $\begin{aligned} & \text { BIT } \\ & \text { ABS } \end{aligned}$ | $\begin{aligned} & \text { AND } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \mathrm{ROL} \\ & \mathrm{ABS} \\ & 36 \end{aligned}$ | $\begin{gathered} \text { BBR2 } \\ \text { ZP } \\ 3 \quad 5^{* *} \end{gathered}$ | 2 |
| 3 | BMI <br> Relative 2 2＊＊ | $\begin{aligned} & \text { AND } \\ & \text { (IND, Y) } \\ & 25^{*} \end{aligned}$ |  |  |  | AND ZP，X 24 | $\begin{gathered} \hline \mathrm{ROL} \\ \mathrm{ZP}, \mathrm{X} \\ 2 \quad 6 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { RMB3 } \\ & \text { ZP } \\ & 2 \quad 5 \\ & \hline \end{aligned}$ | SEC Implied 12 | AND ABS，$Y$ 3 4＊ |  |  |  | AND ABS，$X$ $34^{*}$ |  | $\begin{gathered} \text { BBR3 } \\ \text { ZP } \\ 3 \quad 5^{n *} \end{gathered}$ | 3 |
| 4. |  | $\begin{gathered} \text { EOR } \\ \left(\begin{array}{l} N D, X) \\ 2 \quad 6 \\ \hline \end{array} ⿳ ⺈ ⿴ 囗 十 一 ~\right. \end{gathered}$ |  |  |  | $\begin{aligned} & \mathrm{EOR} \\ & \mathrm{ZP} \\ & 23 \end{aligned}$ | $\begin{aligned} & \text { LSR } \\ & \text { ZP } \\ & 2 \quad 5 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { RMB4 } \\ \text { ZP } \\ 2.5 \end{gathered}$ | PHA Implied 13 | $\begin{aligned} & \text { EOR } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ | LSR Accum <br> 12 |  | JMP <br> ABS <br> 33 | $\begin{aligned} & \text { EOR } \\ & \text { ABS } \\ & 3 \quad 4 \\ & \hline \end{aligned}$ | LSR ABS <br> 36 | $\begin{aligned} & \text { BBR4 } \\ & \text { ZP }^{*} 5^{* *} \end{aligned}$ | 4 |
| 5 | BVC <br> Relative <br> 2 | EOR（IND），$Y$ <br> $25^{*}$,$~$ |  | － |  | $\begin{aligned} & \text { EOR } \\ & \text { ZP, } X \\ & 2 \quad 4 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { LSR } \\ \text { ZP, } X \\ 2 \quad 6 \\ \hline \end{gathered}$ | $\begin{gathered} \text { RMB5 } \\ \text { ZP } \\ 2 \quad 5 \\ \hline \end{gathered}$ | CLI Implied 12 |  |  |  |  |  | LSR ABS，$X$ 37 | $\begin{gathered} \text { BBR5 } \\ \text { ZP } \\ 35^{* *} \end{gathered}$ | 5 |
| 6 | RTS Implied 16 | $\begin{gathered} A D C \\ (I N D, X) \\ 2.6 \end{gathered}$ |  |  |  | $\begin{aligned} & A D C \\ & Z P \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { ROR } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{aligned} & \text { RMB6 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | PLA Implied 14 | $\begin{aligned} & \text { ADC } \\ & \text { IMM } \\ & 22 \end{aligned}$ | ROR <br> Accum 12 |  |  <br> JMP <br> Indirect <br> 3 | $\begin{aligned} & \text { ADC } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \hline \text { ROR } \\ & \text { ABS } \\ & 3 \quad 6 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { BBR6 } \\ \text { ZP } \\ 3 \quad 5 \\ \hline \end{gathered}$ | 6 |
| 7 | BVS <br> Relative 2 2＊＊ | $\begin{array}{\|c\|} \hline \text { ADC } \\ (\text { IND, Y) } \\ 2 \quad 5^{*} \\ \hline \end{array}$ |  |  |  | $\begin{aligned} & \hline \text { ADC } \\ & \text { ZP, } X \\ & 24 \\ & \hline \end{aligned}$ | $\begin{gathered} \hline \text { ROR } \\ \text { ZP, X } \\ 2 \quad 6 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { RMB7 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | SEI Implied 12 |  |  |  |  | ADC ABS，$X$ $34^{*}$ | ROR ABS，$X$ 37 | $\begin{aligned} & \text { BBR7 } \\ & \text { ZP }^{5^{* *}} \end{aligned}$ | 7 |
| 8 |  | $\begin{array}{\|c\|} \hline \text { STA } \\ \text { (IND, X) } \\ 2 \quad 6 \\ \hline \end{array}$ |  |  | $\begin{gathered} \text { STY } \\ \text { ZP } \\ 2 \quad 3 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { STA } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { STX } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { SMB0 } \\ \text { ZP } \\ 2 \quad 5 \\ \hline \end{gathered}$ |  |  | TXA Implied 12 |  | $\begin{aligned} & \text { STY } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { STA } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \hline \text { STX } \\ & \text { ABS } \\ & 3 \quad 4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { BBSO } \\ & \text { ZP } \\ & 3^{* *} \end{aligned}$ | 8 |
| 9 | BCC <br> Relative <br> 2 2＊＊ | $\begin{gathered} \text { STA } \\ \text { (IND, Y) } \\ 2.6 \end{gathered}$ |  |  | $\begin{aligned} & \text { STY } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{gathered} \text { STA } \\ \text { ZP, } X \\ 2.4 \end{gathered}$ | $\begin{gathered} \text { STX } \\ \text { ZP, Y } \\ 24 \end{gathered}$ | $\begin{aligned} & \text { SMB1 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | TYA Implied 12 | STA ABS，$Y$ 35 | TXS Implied 12 |  |  | STA ABS，$X$ 35 |  | $\begin{aligned} & \text { BBS1 } \\ & \text { ZP }^{* *} \end{aligned}$ | 9 |
| A | $\begin{aligned} & \text { LDY } \\ & \text { IMM } \\ & 22 \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & \text { (IND, X) } \\ & 266 \end{aligned}$ | $\begin{aligned} & \text { LDX } \\ & \text { IMM } \\ & 22 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \mathrm{LDY} \\ & \mathrm{ZP} \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { LDX } \\ Z P \\ 2 \quad 3 \\ \hline \end{gathered}$ | $\begin{gathered} \text { SMB2 } \\ \text { ZP } \\ 2 \quad 5 \\ \hline \end{gathered}$ | TAY Implied 12 | $\begin{aligned} & \text { LDA } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ | TAX Implied 12 |  | LDY ABS 34 | LDA ABS 34 | $\begin{array}{\|l\|} \hline \text { LDX } \\ \text { ABS } \\ 3 \quad 4 \\ \hline \end{array}$ | $\begin{aligned} & \text { BBS2 } \\ & 3^{\text {ZP }} 5^{* *} \end{aligned}$ | A |
| B | BCS <br> Relative 2 2＊＊ | $\begin{gathered} \text { LDA } \\ \text { (IND), Y } \\ 25^{*} \end{gathered}$ |  |  | $\begin{aligned} & \text { LDY } \\ & \text { ZP, } X \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & \text { ZP, X } \\ & 2 \quad 4 \end{aligned}$ | $\begin{gathered} \text { LDX } \\ \text { ZP, Y } \\ 24 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { SMB3 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | CLV Implied 12 |  | TSX Implied 12 |  | $\begin{gathered} \text { LDY } \\ \text { ABS, } X \\ 3 \end{gathered}$ | $\begin{aligned} & \text { LDA } \\ & \text { ABS, } X \\ & 34^{*} \end{aligned}$ | $\begin{gathered} \text { LDX } \\ \text { ABS, } Y \\ 34^{*} \end{gathered}$ | $\begin{aligned} & \text { BBS3 } \\ & \text { ZP } \\ & 3^{* *} \end{aligned}$ | B |
| C | $\begin{aligned} & \hline \text { CPY } \\ & \text { IMM } \\ & 22 \\ & \hline \end{aligned}$ | $\begin{gathered} \hline \text { CMP } \\ \text { (IND, X) } \\ 266 \\ \hline \end{gathered}$ |  |  | $\begin{aligned} & C P Y \\ & Z P \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { DEC } \\ & \text { ZP } \\ & 2 \quad 5 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { SMB4 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | INY Implied 12 | $\begin{aligned} & \hline \text { CMP } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \hline \text { CPY } \\ & \text { ABS } \\ & 3 \quad 4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { CMP } \\ & \text { ABS } \\ & 3 \quad 4 \\ & \hline \end{aligned}$ | DEC ABS 36 | $\begin{gathered} \text { BBS4 } \\ \text { ZP } \\ 3 \quad 5^{* *} \end{gathered}$ | C |
| D | BNE <br> Relative <br> 2 2＊＊ | $\begin{gathered} \text { CMP } \\ \text { (IND), Y } \\ 25^{*} \end{gathered}$ |  |  |  | $\begin{aligned} & \text { CMP } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{gathered} \text { DEC } \\ \text { ZP, } X \\ 26 \end{gathered}$ | $\begin{gathered} \text { SMB5 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | CLD Implied 12 | $\begin{gathered} \text { CMP } \\ \text { ABS, Y } \\ 34^{*} \end{gathered}$ |  |  |  | $\begin{gathered} \text { CMF } \\ \text { ABS, } X \\ 34^{*} \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { ABS, } X \\ 37 \end{gathered}$ | $\begin{aligned} & \text { BBS5 } \\ & \text { ZP } \\ & 3 \quad 5^{* *} \end{aligned}$ | D |
| E | $\begin{aligned} & \text { CPX } \\ & \text { IMM } \\ & 22 \\ & \hline \end{aligned}$ | $\begin{gathered} \hline \text { SBC } \\ \text { (IND, X) } \\ 2 \quad 6 \\ \hline \end{gathered}$ |  |  | $\begin{aligned} & \mathrm{CPX} \\ & \mathrm{ZP} \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{array}{r} \hline \mathrm{SBC} \\ \mathrm{ZP} \\ 2 \quad 3 \\ \hline \end{array}$ | $\begin{array}{r} \text { INC } \\ Z P \\ 2 \quad 5 \\ \hline \end{array}$ | $\begin{aligned} & \text { SMB6 } \\ & \text { ZP } \\ & 2 \quad 5 \\ & \hline \end{aligned}$ | INX Implied 12 | $\begin{aligned} & \text { SBC } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \hline \text { CPX } \\ & \text { ABS } \\ & 3 \quad 4 \\ & \hline \end{aligned}$ | SBC ABS <br> 34 | INC ABS 36 | $\begin{gathered} \text { BBS6 } \\ \text { ZP } \\ 3 \quad 5^{* *} \\ \hline \end{gathered}$ | E |
| F | BEQ <br> Relative $22^{* *}$ | $\begin{gathered} \text { SBC } \\ \text { (IND), Y } \\ 25^{*} \end{gathered}$ |  |  |  | $\begin{gathered} \text { SBC } \\ \text { ZP, } \mathrm{X} \\ 24 \end{gathered}$ | $\begin{aligned} & \text { INC } \\ & \text { ZP, } X \\ & 26 \end{aligned}$ | $\begin{aligned} & \text { SMB7 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | SED Implied 12 |  |  |  |  | $\begin{gathered} \text { SBC } \\ \text { ABS, } X \\ 34^{*} \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { ABS, } X \\ 37 \end{gathered}$ | $\begin{aligned} & \text { BBS7 } \\ & \text { ZP } \\ & 3^{5 * *} \end{aligned}$ | F |

＊Add 1 to N if page boundary is crossed．
＊＊Add 1 to N if branch occurs to same page； add 2 to N if branch occurs to different page．

## APPENDIX B <br> KEY REGISTER SUMMARY



CPU Registers


Mode Control Register


Interrupt Enable and Flag Registers


XMTR Under-Run
Serial Communications Status Register

# APPENDIX C <br> ADDRESS ASSIGNMENTS/MEMORY MAPS/PIN FUNCTIONS 

## C. 1 I/O AND INTERNAL REGISTER ADDRESSES

| ADDRESS (HEX) | READ | WRITE |
| :---: | :---: | :---: |
| 001F | - - | - |
| 1E | Lower Counter B | Upper Latch B, Cntr B $\leftarrow$ Latch B, CLR Flag |
| 1D | Upper Counter B | Upper Latch B, Latch C Latch B |
| 1C | Lower Counter B, CLR Flag | Lower Latch B. |
| 1 B | - - | - - |
| 1A | Lower Counter A | Upper Latch A, Cntr A Latch A, CLR Flag |
| 19 | Upper Counter A | Upper Latch A |
| 18 | Lower Counter A, CLR Flag | Lower Latch A |
| 17 | Serial Receiver Data Register | Serial Transmitter Data Register |
| 16 | Serial Comm. Status Register | Serial Comm. Status Reg. Bits 4 \& 5 only |
| 15 | Serial Comm. Control Register | Serial Comm. Control Register |
| 14 | Mode Control Register | Mode Control Register |
| 13 | - - | - - |
| 12 | Interrupt Enable Register | Interrupt Enable Register |
| 11 | Interrupt Flag Register | -- |
| 0010 | Read FF | Clear Int Flag (Bits 0-3 only, Write 0's only) |
| OF | - - | - - |
| OE | - - | - |
| OD | - - | - - |
| 0 C | - - | - - |
| OB | - - | - - |
| OA | - - | - - |
| 09 | -- | - - |
| 08 | - - | - - |
| 07 | - | - - |
| 06 | Port G* | Port G* |
| 05 | Port F* | Port F* |
| 04 | Port E* | Port E* |
| 03 | Port D | Port D |
| 02 | Port C | Port C |
| 01 | Port B | Port B |
| 0000 | Port A | Port A |

[^11]
## C. 2 ABBREVIATED MODE MEMORY MAP



## C. 3 MULTIPLEXED MODE MEMORY MAP



## C. 4 MULTIPLE FUNCTION PIN ASSIGNMENTS—PORT C AND PORT D

| PIN <br> NUMBER | I/O PORT <br> FUNCTION | ABBREVIATED PORT <br> FUNCTION | MULTIPLEXED PORT <br> FUNCTION |
| :---: | :---: | :---: | :---: |
| 4 | PC0 | A0 | AO |
| 5 | PC1 | A1 | A1 |
| 6 | PC2 | A2 | A2 |
| 7 | PC3 | A3 | A3 |
| 8 | PC4 | A12 | A12 |
| 9 | PC5 | R/W | R/W |
| 10 | PC6 | A13 | A13 |
| 11 | PC7 | EMS | EMS |
| 19 | PD0 | D0 | A4/D0 |
| 18 | PD1 | D1 | A5/D1 |
| 17 | PD2 | D2 | A6/D2 |
| 16 | PD3 | D3 | A7/D3 |
| 15 | PD4 | D4 | A8/D4 |
| 14 | PD5 | D5 | A9/D5 |
| 13 | PD6 | D6 | A10/D6 |
| 12 |  |  | A1 1/D7 |

# APPENDIX D <br> ELECTRICAL SPECIFICATIONS 

## MAXIMUM RATINGS*

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

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

## DC CHARACTERISTICS <br> $\left(V_{C C}=5 \mathrm{~V} \pm 5 \%, V_{S S}=0, T_{A}=0\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipation (Outputs High) Commercial (a) $25^{\circ} \mathrm{C}$ | $P_{\text {D }}$ | - |  | 1200 | mW |
| RAM Standby Voltage (Retention Mode) | $\mathrm{V}_{\text {RR }}$ | 3.0 | - | $\mathrm{V}_{\mathrm{CC}}$ | Vdc |
| RAM Standby Current (Retention Mode) Commercial © $25^{\circ} \mathrm{C}$ | $\mathrm{I}_{\text {RR }}$ | - | 4 | - | mAdc |
| Input High Voltage | $\mathrm{V}_{1 \mathrm{H}}$ | +2.0 | - | $\mathrm{V}_{\mathrm{CC}}$ | Vdc |
| Input High Voltage (XTLI and $\emptyset 2$ in Slave Option) | $\mathrm{V}_{\mathrm{IH}}$ | +4.0 | - | $\mathrm{V}_{\mathrm{CC}}$ | Vdc |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | - | +0.8 | Vdc |
| Input Leakage Current ( $\overline{\mathrm{RES}}, \overline{\mathrm{NMI}})$ $\mathrm{V}_{\text {in }}=0$ to 5.0 Vdc | $\mathrm{I}_{\mathrm{N}}$ |  |  | $\pm 10.0$ | $\mu \mathrm{Adc}$ |
| Input Low Current PA, PB, PC, PD, PF*, and PG* $\left(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{Vdc}\right)$ | ILL | - | - 1.0 | -1.6 | mAdc |
| Output High Voltage (Except XTLO) $\left(I_{\text {LOAD }}=.100 \mu \mathrm{AdC}\right)$ | $\mathrm{V}_{\mathrm{OH}}$ | +2.4 | - | $\mathrm{V}_{\mathrm{CC}}$ | Vdc |
| Output Low Voltage ( LOAD $=1.6 \mathrm{mAdc}$ ) | $\mathrm{V}_{\text {OL }}$ | - | - | +0.4 | Vdc |
| Darlington Current Drive, PE* $\left(\mathrm{V}_{0}=1.5 \mathrm{Vdc}\right)$ | $\mathrm{IOH}^{\text {I }}$ | -1.0 | - | - | mAdc |
| Input Capacitance $\begin{aligned} & \left(V_{\text {in }}-0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right) \\ & \text { PA, PB, PC, PD, PF* } \\ & \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, PF0-PF7 \& PG0-PG7 | $\mathrm{R}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | K $\Omega$ |
| Output Leakage Current <br> Tri-State I/Os while in High Impedance State | lout | - | - | $\pm 10$ | $\mu$ Adc |
| Output Capacitance <br> Tri-State I/Os while in High Impedance State $\mathrm{V}_{\mathrm{IN}}=\mathrm{OV}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ | $\mathrm{C}_{\text {Out }}$ | - | - | 10 | pF |
| Note: Negative sign indicates outward current flow, positive indicates inward flow. |  |  |  | *R6500/12Q only. |  |

## APPENDIX E TIMING REQUIREMENTS AND CHARACTERISTICS

## E. 1 GENERAL NOTES

1. $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 5 \%, 0^{\circ} \mathrm{C} \leqslant \mathrm{TA} \leqslant 70^{\circ} \mathrm{C}$
2. A valid $V_{c c}-\overline{R E S}$ sequence is required before proper operation is achieved.
3. All timing reference levels are 0.8 V and 2.0 V , unless otherwise specified.
4. All time units are nanoseconds, unless otherwise specified.
5. All capacitive loading is 130 pf maximum, except as noted below:

| PA, PB | - | 50pf maximum |
| :--- | :--- | :--- |
| PC (I/O Modes Only) | - | 50pf maximum |
| PC (ABB and Mux Mode) | - | 130pf maximum |
| PC6, PC7 (Full Address Mode) | - | 130 pf maximum |

- 50pf maximum

PC ( $1 / \mathrm{O}$ Modes Only) - 50pf maximum PC6, PC7 (Full Address Mode) - 130pf maximum

## E. 2 CLOCK TIMING

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| Tcrc | Cycle Time | 1000 | $10 \mu \mathrm{~s}$ | 500 | $10 \mu \mathrm{~s}$ |
| $\mathrm{T}_{\text {PWX }}$ | XTLI Input Clock Pulse Width XTLO = VSS | $\begin{aligned} & 500 \\ & \pm 25 \end{aligned}$ | - | $\begin{aligned} & 250 \\ & \pm 10 \end{aligned}$ | - |
| $\mathrm{T}_{\text {Pwo2 }}$ | Output Clock Pulse Width at Minimum Terc | $\mathrm{T}_{\text {Pwx1 }}$ | $\begin{aligned} & T_{p w \times 1} \\ & \pm 25 \end{aligned}$ | $\mathrm{T}_{\text {PWX1 }}$ | $\begin{aligned} & T_{P w x_{1}} \\ & \pm 20 \end{aligned}$ |
| $T_{R}, T_{F}$ | Output Clock Rise, Fall Time | - | 25 | - | 15 |
| $\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}$ | Input Clock Rise, Fall Time | - | 10 | - | 10 |



## E. 3 ABBREVIATED MODE TIMING-PC AND PD

$($ MCR $5=1$, MCR $6=0$, MCR $7=1)$

| SYMBOL | PARAMETER | $1 \mathbf{M H z}$ |  | $2 \mathbf{M H z}$ |  |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $T_{\text {PCRS }}$ | (PC5) R/W Setup Time | - | 225 | - | 140 |
| $T_{\text {PCAS }}$ | (PC0-PC4, PC6) Address Setup Time | - | 200 | - | 140 |
| $T_{\text {PBSU }}$ | (PD) Data Setup Time | 50 | - | 35 | - |
| $T_{\text {PBHR }}$ | (PD) Data Read Hold Time | 10 | - | 10 | - |
| $T_{\text {PBHW }}$ | (PD) Data Write Hold Time | 30 | - | 30 | - |
| $T_{\text {PBDD }}$ | (PD) Data Output Delay | - | 175 | - | 130 |
| $T_{\text {PCHA }}$ | (PC0-PC4, PC6) Address Hold Time | 30 | - | 30 | - |
| $T_{\text {PCHR }}$ | (PC5) R/W Hold Time | 30 | - | 30 | - |
| $T_{\text {PCHV }}$ | (PC7) EMS Hold Time | 10 | - | 10 | - |
| $T_{\text {PCVD }}{ }^{\text {(1) }}$ | (PC7) Address to EMS Delay Time | 30 | 220 | 30 | 130 |
| $T_{\text {PCVP }}$ | (PC7) EMS Stabilization Time | 30 | - | 30 | - |

NOTE 1: Values assume PC0-PC4, PC6 and PC7 have the same capacitive load.

## E.3.1 Abbreviated Mode Timing Diagram



## E. 4 MULTIPLEXED MODE TIMING-PC AND PD

(MCR $5=1$, MCR $6=1$, MCR $7=1$ )

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $\mathrm{T}_{\text {PCRS }}$ | (PC5) R/W Setup Time | - | 225 | - | 140 |
| $\mathrm{T}_{\text {PCAS }}$ | (PC0-PC4, PC6) Address Setup Time | - | 200 | - | 140 |
| $\mathrm{T}_{\text {PGAS }}$ | (PD) Address Setup Time | - | 220 | - | 120 |
| $\mathrm{T}_{\text {PBSU }}$ | (PD) Data Setup Time | 50 | - | 35 | - |
| $\mathrm{T}_{\text {PBHR }}$ | (PD) Data Read Hold Time | 10 | - | 10 | - |
| $\mathrm{T}_{\text {PBHW }}$ | (PD) Data Write Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {PBDD }}$ | (PD). Data Output Delay | - | 175 | - | 140 |
| $\mathrm{T}_{\text {PCHA }}$ | (PC0-PC4, PC6) Address Hold Time | 30 | - | 30 | - |
| T PBHA | (PD) Address Hold Time | 40 | 100 | 40 | 80 |
| $\mathrm{T}_{\text {PCHR }}$ | (PC5) R/W Hold Time | 30 | - | 30 | - |
| $T_{\text {PCHV }}$ | (PC7) EMS Hold Time | 10 | - | 10 | - |
| $\mathrm{T}_{\text {PcVo }}{ }^{(1)}$ | (PC7) Address to EMS Delay Time | 30 | 200 | 30 | 150 |
| $\mathrm{T}_{\text {PCVP }}$ | (PC7) EMS Stabilization Time | 30 | - | 30 | - |

NOTE 1: Values assume PDO-PD7 and PC7 have the same capactive load.

## E.4.1 Multiplex Mode Timing Diagram



## E. 5 I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $T_{\text {Pow }}{ }^{(1)}$ <br> $\mathrm{T}_{\text {смоз }}{ }^{\text {(1) }}$ <br> Tpoow | Internal Write to Peripheral Data Valid PA, PB, PC, PE, PF, PG, TTL PA, PB, PC, PE, PF, PG, CMOS PD | $-$ | $\begin{array}{r} 500 \\ 1000 \\ 175 \end{array}$ | - | $\begin{array}{r} 500 \\ 1000 \\ 150 \end{array}$ |
| $\begin{aligned} & T_{\text {PDSU }} \\ & T_{\text {PDSU }} \end{aligned}$ | Peripheral Data Setup Time PA, PB, PC, PF, PG PD | $\begin{array}{r} 200 \\ 50 \end{array}$ | 二 | $\begin{array}{r} 200 \\ 50 \end{array}$ | - |
| $\begin{aligned} & T_{\text {PHR }} \\ & T_{\text {PHR }} \end{aligned}$ | Peripheral Data Hold Time PA, PB, PC, PF, PG PD | $\begin{aligned} & 75 \\ & 10 \end{aligned}$ |  | $\begin{aligned} & 75 \\ & 10 \end{aligned}$ | - |
| $\mathrm{T}_{\text {EPW }}$ | PA0-PA3 Edge Detect Pulse Width | $\mathrm{T}_{\mathrm{crc}}$ | - | Tcrc | - |
| $\begin{aligned} & T_{\text {CPW }} \\ & T_{\text {CD }}{ }^{(1)} \\ & \hline \end{aligned}$ | Counters A and B <br> PA4, PA5 Input Pulse Width PA4, PA5 Output Delay | T $\mathrm{Tcrc}^{\text {- }}$ | $500$ | Tcrc | $\overline{500}$ |
| $\mathrm{T}_{\text {peLw }}$ <br> TPISU <br> $\mathrm{T}_{\text {PBLH }}$ | Port B Latch Mode PAO Strobe Pulse Width PB Data Setup Time PB Data Hold Time | $\begin{array}{r} T_{\text {crc }} \\ 175 \\ 30 \\ \hline \end{array}$ | - | $\begin{array}{r} \mathrm{T}_{\text {cre }} \\ 150 \\ 30 \end{array}$ | - |
|  | Serial I/0 |  |  |  |  |
| $\mathrm{T}_{\text {Pow }}{ }^{(1)}$ | PA6 XMTR TTL | - | 500 | - | 500 |
| $\mathrm{T}_{\text {cmos }}{ }^{\text {(1) }}$ | PA6 XMTR CMOS | - | 1000 | - | 1000 |
| $\mathrm{T}_{\text {cpw }}$ | PA4 RCVR S/R Clock Width | 4 Tcrc | $-$ | 4 Tcrc | - |
| $T_{\text {PDW }}{ }^{(1)}$ | PA4 XMTR Clock-S/R Mode (TTL) | - | 500 | - | 500 |
| $\mathrm{T}_{\text {cmos }}{ }^{\text {(1) }}$ | PA4 XMTR Clock-S/R Mode (CMOS) | - | 1000 | - | 1000 |

NOTE 1: Maximum Load Capacitance: 50pF Passive Pull-Up Required

## E.5.1 I/O, Edge Detect, Counter, and Serial I/O Timing



## R65/11EB AND R65/11EAB BACKPACK EMULATORS

## INTRODUCTION

The Rockwell R65/11EB and R65/11EAB Backpack Emulator is the PROM prototyping version of the 8 -bit, masked-ROM R6500/11 one-chip microcomputer. Like the R6500/11, the backpack device is totally upward/downward compatible with all members of the R6500/11 family. It is designed to accept standard 5-volt, 24-pin EPROMs or ROMs directly, in a socket on top of the Emulator. This packaging concept allows a standard EPROM to be easily removed, re-programmed, then reinserted as often as desired.

The backpack devices have the same pinouts as the maskedROM R6500/11 microcomputer. These 40 pins are functionally and operationally identical to the pins on the R6500/11. The R6500/11 Microcomputer Product Description (Rockwell Document No. 29651 N23, Order No. 2119) includes a description of the interface signals and their functions. Whereas the maskedROM R6500/11 provides 3K bytes of read-only memory, the R65/11EB will address 4K bytes of external program memory. This extra memory accommodates program patches, test programs or optional programs during breadboard and prototype development states.

ORDERING INFORMATION
Backpack Emulator

| Part <br> Number | Memory <br> Capacity | Compatible <br> Memories | Temperature <br> Range and Speed |
| :---: | :---: | :---: | :---: |
| R65/11EB | $4 \mathrm{~K} \times 8$ | 2732 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| 1 MHz |  |  |  |
| R65/11EAB | $4 \mathrm{~K} \times 8$ | 2732 A | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| 2 MHz |  |  |  |

Support Products

| Part <br> Number | Description |
| :--- | :--- |
| S65-101 | SYSTEM 65 Microcomputer <br> Development System |
| M65-040 | PROM Programmer Module |
| M65-131 | 1-MHz R6500/11 Personality Module |
| M65-132 | 2-MHz R6500/11 Personality Module |
| RDC-1001 | Rockwell Design Center |
| RDC-101 | 1 MHz R6500/11P Personality Module (RDC) |
| RDC-102 | 2 MHz R6500/11AP Personality Module (RDC) |

## FEATURES

- PROM version of the R6500/11
- Completely pin compatible with R6500/11 single-chip microcomputers
- Profile approaches 40-pin DIP of R6500/11
- Accepts 5 volt, 24-pin industry-standard EPROMs
-4K memories-2732, 2732A (4K bytes addressable)
- Use as prototyping tool or for low volume production
- 4 K bytes of memory capacity
- $192 \times 8$ static RAM
- Separate power pin for 32 bytes of RAM
- Software compatibility with the R6500 family
- 32 bi-directional TTL compatible I/O lines (4 ports)
- Two 16 bit programmable counter/latches with six modes (interval timer, pulse generator, event counter, pulse width measurement, asymmetrical pulse generator, and retriggerable interval timer)
- 10 interrupts (reset, non-maskable, four external edge sensitive, 2 counters, serial data received, serial data transmitted).
- Crystal or external time base
- Single +5 V power supply


R65/11EB Backpack Emulator

## CONFIGURATIONS

The Backpack Emulator is available in two different versions, to accommodate 1 MHz and 2 MHz speeds. Both versions provide 192 bytes of RAM and VO, as well as 24 signals to support the external memory "backpack" socket.

The emulator will relocate the EPROM address space to FXXX (see Memory Map). EPROM addresses FFA through FFF must contain the interrupt vectors.

## EXTERNAL FREQUENCY REFERENCE

The external frequency reference may be a crystal or a clock-the RC option of the R6500/11 is not available in the emulator device. The R65/11EB and R65/11EAB divide the input clock by two regardless of the source.

## I/O PORT PULLUPS

The devices have internal I/O port pullup resistors on ports $A, B, \& C$. Port $D$ has push-pull drivers.

## PRODUCT SUPPORT

The Backpack Emulator is just one of the products that Rockwell offers to facilitate system and program development for the R6500/11.

The SYSTEM 65 Microcomputer Development System with R6500/11 Personality Module supports both hardware and software development. Complete in-circuit user emulation with the R6500/11 Personality Module allows total system test and evaluation. With the optional PROM Programmer, 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 3K ROM of the R6500/11.

In addition to support products, Rockwell offers regularlyscheduled designer courses at regional centers.


R65/11EB Interface Diagram

| XTLO XTLI | $\underbrace{\boldsymbol{e}_{\mathbf{1}}}$ |  | $\begin{aligned} & \text { 24s } \\ & \text { 23s } \end{aligned}$ | $\mathrm{VVCl}_{\text {cc }} 40$ |  |  | $\begin{aligned} & \mathbf{V}_{\mathbf{S S}} \\ & \mathbf{V}_{\text {RR }} \\ & \mathbf{P B O}_{\mathbf{D B R}} \end{aligned}$ | BACKPACK MEMORY SIGNAL DESCRIPTION |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ¢2 | 3 |  | 22s | A9 | 38 | 吅 |  |  |  |  |
| PCO |  | A4 4 s | $21 s$ | A11 | 37 | 早 | PB1 | Name | Pin No． | Description |
| PC1 | 5 | A3 5s | 20s | $\overline{O E}$ | 36 | 1 | PB2 |  |  |  |
| PC2 | ${ }^{-1}$ | A2 6 6 | 19s | A10 | 35 | － | PB3 | D0－D7 | 9S-11S, | Data Bus Lines．All instruction and data |
| PC3． | 8 | A1 7 s | 18s | CE | 34 | $\square$ | PB4 |  |  | transfers take place on the data bus lines． |
| PC4 | 8 | A0 8s | 17s | D7 | 33 |  | PB5 |  |  | The buffers driving the data bus lines have |
| PC5 | 9 | D0－9s | 16s | D6 | 32 |  | PB6 |  |  | full three－state capability．Each data bus |
| PC6 | 10 | D1 10 s | 15s | D5 | 31 | ص | PB7 |  |  | pin is connected to an input and an output |
| PC7 | －11 | D2 112 | 14s | D4 | 30 | 2 | PAO |  |  | buffer，with the output buffer remaining in |
| PD7 | 12 | $\mathrm{V}_{\text {ss }}=12 \mathrm{~s}$ | 13s | D3 | 29 | ］ | PA1 |  |  | the floating condition． |
| PD6 | －13 |  |  |  | 28 | ص | PA2 | A0－A7 | 1S－8S， | Address Bus Lines．The address bus lines |
| PD5 | －14 | 24－P | CKET |  | 27 | 口 | PA3 | A8，A9 | 23S，24S | are buffered by push／pull type drivers that |
| PD4 | $\square 15$ |  |  |  | 26 | ص | PA4 | A10 | 19 S | can drive one standard TTL load． |
| PD3 | G16 |  |  |  | 25 | ص | PA5 | A11 | 215 |  |
| PD2 | 817 |  |  |  | 24 | 2 | PA6 | $\overline{C E}$ | 185 | Chip Enable．$\overline{C E}$ is active when the address |
| PD1 | －18 |  |  |  | 23 |  | PA7 |  |  | is 8000 －FFFF．This line can drive one TTL |
| PDO | 19 |  |  |  | 22 |  | NMI |  |  | load． |
| RES | －20 |  |  |  | 21 |  | $\mathrm{V}_{\mathrm{cc}}$ | $\overline{O E}$ | 203 | Memory Enable Line．This signal provides |
|  |  | Pin C | urati |  |  |  |  |  |  | the output enable for the memory to place information on the data bus lines．This signal is driven by an inverted $R / \bar{W}$ signal from the CPU．It can drive 1 TTL load． |
|  |  |  |  |  |  |  |  |  | 24S | Main Power Supply +5 V ．This pin is tied directly to pin 21 （ $\mathrm{V}_{\mathrm{cc}}$ ）． |
|  |  |  |  |  |  |  |  | $\mathrm{V}_{\mathrm{ss}}$ | 125 | Signal and Power Ground（zero volts）．This pin is tied directly to pin $40\left(\mathrm{~V}_{\mathrm{SS}}\right)$ ． |

## I／O AND INTERNAL REGISTER ADDRESSES

| Address （Hex） | Read | Write |
| :---: | :---: | :---: |
| 001F | － | － |
| 1 E | Lower Counter B | Upper Latch B，Cntr B↔Latch B，CLR Flag |
| 1 D | Upper Counter B | Upper Latch B，Latch C $\leftarrow$ Latch B |
| 1 C | Lower Counter B，CLR Flag | Lower Latch B |
| 1B | －－ | －－ |
| 1A | Lower Counter A | Upper Latch A，Cntr AזLatch A，CLR Flag |
| 19 | Upper Counter A | Upper Latch A |
| 18 | Lower Counter A，CLR Flag | Lower Latch A |
| 17 | Serial Receiver Data Register | Serial Transmitter Data Register |
| 16 | Serial Comm．Status Register | Serial Comm．Status Reg．Bits 4 \＆ 5 only |
| 15 | Serial Comm．Control Register | Serial Comm．Control Register |
| 14 | Mode Control Register | Mode Control Register |
| 13 | － | － |
| 12 | Interrupt Enable Register | Interrupt Enable Register |
| 11 | Interrupt Flag Register | －－ |
| 0010 | Read FF | Clear Int Flag（Bits 0－3 only，Write 0＇s only） |
| 04 thru OF | －－ | －－ |
| 03 | Port D | Port D |
| 02 | Port C | Port C |
| 01 | Port B | Port B |
| 0000 | Port A | Port A |

READ TIMING CHARACTERISTICS

| Signal | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\overline{\mathrm{OE}}$ and $\overline{\mathrm{CE}}$ setup time from CPU | Toes | - | 225 | - | 140 | ns |
| Address setup time from CPU | $\mathrm{T}_{\text {ADS }}$ | - | 225 | - | 140 | ns |
| Memory read access time | $\mathrm{T}_{\text {ACC }}$ | - | 700 | - | 315 | ns |
| Data set up time | T ${ }_{\text {dSU }}$ | 50 | - | 35 | - | ns |
| Data hold time-Read | $\mathrm{T}_{\text {HR }}$ | 10 | - | 10 | - | ns |
| Address hold time | $\mathrm{T}_{\mathrm{HA}}$ | 30 | - | 30 | - | ns |
| $\overline{\mathrm{OE}}$ and $\overline{\mathrm{CE}}$ hold time | $\mathrm{T}_{\text {Hoe }}$ | 30 | - | 30 | - | ns |
| Cycle Time | $\mathrm{T}_{\mathrm{CYC}}$ | 1.0 | 10.0 | 0.5 | 10.0 | $\mu \mathrm{s}$ |

## READ TIMING WAVEFORMS



## 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 D0-D7 | $\mathrm{V}_{\mathrm{IHT}}$ | $\mathrm{V}_{\text {SS }}+2.0$ | - | - | Vdc |
| Input Low Threshold Voltage D0-D7 | $\mathrm{V}_{\text {ILT }}$ | - | - | $\mathrm{V}_{\mathrm{ss}}+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}$ | $\mathrm{I}_{\text {TS }}$ | - | - | $\pm 10$ | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { Output High Voltage } \\ & \text { (ILOAD }=100 \mu \text { Adc, } \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \text { ) } \\ & \text { DO-D7, A0-A11, } \overline{\mathrm{OE}, \mathrm{CE}} \end{aligned}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{ss}}+2.4$ | - | - | Vdc |
| $\begin{aligned} & \text { Output Low Voltage } \\ & \left(I_{\text {LOAD }}=1.6 \mathrm{mAdc}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}\right. \text { ) } \\ & \text { DO-D7, AO-A11, } \mathrm{OE}, \mathrm{CE} \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | $\mathrm{V}_{\mathrm{ss}}+0.4$ | Vdc |
| Power Dissipation (less EPROM) | $\mathrm{P}_{\mathrm{D}}$ | - | 0.80 | 1.20 | W |
| Capacitance $\left(V_{\text {in }}=0, T_{A}=25^{\circ} \mathrm{C}, f=1 \mathrm{MHz}\right)$ <br> D0-D7 (High Impedance State) Input Capacitance | $\begin{aligned} & \mathrm{C} \\ & \mathrm{C}_{\text {out }} \\ & \mathrm{C}_{\text {in }} \\ & \hline \end{aligned}$ | - | - | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | pF |
| I/O Port Pull-up Resistance | $\mathrm{R}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | kohm |



# R6500/13 and R6511Q ONE-CHIP MICROCOMPUTER and ONE-CHIP MICROPROCESSOR 

## SECTION 1 <br> INTRODUCTION

### 1.1 FEATURES

- Enhanced 6502 CPU
-Four new bit manipulation instructions
- Set Memory Bit (SMB)
- Reset Memory Bit (RMB)
- Branch on Bit Set (BBS)
- Branch on Bit Reset (BBR)
-Decimal and binary arithmetic modes
- 13 addressing modes
-True indexing
- 256-byte mask-programmable ROM or no ROM*
- 192-byte static RAM
- 32 bidirectional, TTL-compatible I/O lines (four ports)
- One 8 -bit port may be tri-stated under software control
- One 8 -bit port may have latched inputs under software control
- Two 16-bit programmable counter/timers, with latches
-Pulse width measurement
-Asymmetrical pulse generation
-Pulse generation
- Interval timer
-Event counter
-Retriggerable interval timer
- Serial port
-Full-duplex asynchronous operation mode
-Selectable 5- to 8 -bit characters
-Wake-up feature
-Synchronous shift register mode
-Standard programmable bit rates programmable up to 62.5 K bits $/ \mathrm{sec} @ 1 \mathrm{MHz}$
- Ten interrupts
-Four edge-sensitive lines; two positive, two negative
-Reset
-Non-maskable
-Two counter underflows
-Serial data received
-Serial data transmitted
- Bus expandable to 64 K bytes of external memory
*R6511Q has no ROM.
- Flexible clock circuitry
$-2-\mathrm{MHz}$ or $1-\mathrm{MHz}$ internai operation
-Internal clock with external XTAL at two or four times internal frequency
-External clock input divided by one, two or four
- $1 \mu \mathrm{~s}$ minimum instruction execution time @ 2 MHz
- NMOS-3 silicon gate, depletion load technology
- Single +5 V power supply
- 12 mW stand-by power for 32 bytes of the 192-byte RAM
- 64-pin QUIP


## NOTE

This document uses the term R6500/13 to describe both parts. See section 1.3 for a description of the options available when using the R6500/13 and the fixed features of the R6511Q.

### 1.2 SUMMARY

The Rockwell R6500/13 is a complete, high-performance 8 -bit NMOS-3 microcomputer on a single chip and is compatible with all members of the R6500 family.

The R6500/13 consists of an enhanced 6502 CPU, an internal clock oscillator, an optional 256 bytes of Read-Only Memory, 192 bytes of Random Access Memory (RAM) and versatile interface circuitry. The interface circuitry includes two 16 -bit programmable timer/counters, 32 bidirectional input/output lines (including four edge-sensitive lines and input latching on one 8 -bit port), a full-duplex serial I/O channel, ten interrupts and bus expandability.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of computational power. These features make the R6500/13 a leading candidate for microcomputer applications.

The R6511Q contains all the features of the R6500/13 except it has no ROM and is thus intended as a high feature microprocessor with full 65 K address bus.

To allow prototype circuit development, Rockwell offers a PROM-compatible 64-pin extended microprocessor device. This device, the R6511Q, provides all R6500/11 interface lines, plus the address bus, data bus and control lines to interface with external memory. The R6511Q also can be used to emulate the R6500/13. With the addition of external circuits it can also emulate the R6500/12.

Rockwell supports development of the R6500/13 with the System 65 Microcomputer Development System and the R6500/* Family of Personality Modules. Complete in-circuit emulation with the R6500/* Family of Personality Modules allows total system test and evaluation.

This product description assumes that the reader is familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual (Document Number 29650N31). A description of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Document Number 29650N30).

### 1.3 CUSTOMER OPTIONS

The R6500/13 microcomputer is available with the following customer specified mask options.

- Option 1 Crystal or RC oscillator
- Option 2 Clock divide by 2 or 4
- Option 3 Clock MASTER Mode or SLAVE Mode
- Option 4 with or without a 256 byte ROM
- Option 5 Reset Vector at FFFC or 7FFF
- Option 6 Port A with or without internal pull-up resistors
- Option 7 Port B with or without internal pull-up resistors
- Option 8 Port C with or without internal pull-up resistors

All options should be specified on an R6500/13 order form.
The R6511Q has no customer specified mask options. It has the following characteristics.

- Crystal Oscillator
- Clock Divide by 2
- Clock MASTER Mode
- Without ROM
- Reset Vector at FFFC
- No internal pull-up resistors or any Port (PA, PB, or PC)


Figure 2-1. Mechanical Outline \& Pin Out Configuration

## SECTION 2 <br> R6511Q AND R6500/13 INTERFACE REQUIREMENTS

This section describes the interface requirements for the R6511Q and R6500/13. Figure 2-1 and 2-2 show the Interface Diagram and the pin out configuration for both devices. Table 2-1 describes the function of each pin. Figure 3-1 has a detailed block diagram of the R6500/13 ports which illustrates the internal function of the device.


Figure 2-2. Interface Diagram

Table 2-1. R6500/13 Pin Descriptions


# SECTION 3 SYSTEM ARCHITECTURE 

This section provides a functional description of the R6500/ 13. Functionally the R6500/13 consists of a CPU, both RAM and optional ROM memories, four 8-bit parallel I/O ports, a serial I/O port, dual counter/latch circuits, a mode control register, and an interrupt flag/enable dual register circuit. A block diagram of the system is shown in Figure 3-1.

## NOTE

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

### 3.1 CPU LOGIC

The R6500/13 internal CPU is a standard 6502 configuration with an 8-bit Accumulator register, two 8-bit Index Registers ( X and Y ); an 8-bit Stack Pointer register, an ALU, a 16-bit Program Counter, and standard instruction register/decode and internal timing control logic.

### 3.1.1 Accumulator

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

### 3.1.2 Index Registers

There are two 8-bit index registers, $X$ and $Y$. Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

### 3.1.3 Stack Pointer

The Stack Pointer is an 8-bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal $\overline{\mathrm{RQ}}$ interrupt, or the external interrupt line $\overline{\mathrm{NMI}}$. The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may be accessed only from the top. The address of a memory
location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1. Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 00FF-0040. After reset, which leaves the Stack Pointer indeterminate, normal usage calls for its initialization at 00FF.

### 3.1.4 Arithmetic And Logic Unit (ALU)

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

### 3.1.5 Program Counter

The 16-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter ( PCL ) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter ( PCH ) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

### 3.1.6 Instruction Register and Instruction Decode

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register, then decoded along with timing and interrupt signals to generate control signals for the various registers.

### 3.1.7 Timing Control

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to TO each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.


Figure 3-1. Detailed Block Diagram

### 3.1.8 Interrupt Logic

Interrupt logic controls the sequencing of three interrupts; $\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}$ and $\overline{\mathrm{RQ}}$. $\overline{\mathrm{RQ}}$ is generated by any one of eight conditions: 2 Counter Overflows, 2 Positive Edge Detects, 2 Negative Edge Detects, and 2 Serial Port Conditions.

### 3.2 NEW INSTRUCTIONS

In addition to the standard R6502 instruction set, four new bit manipulation instructions have been added to the R6500/ 13. The added instructions and their format are explained in the following paragraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions. The four added instructions do not impact the CPU processor status register.

### 3.2.1 Set Memory Bit (SMB m, Addr.)

This instruction sets to " 1 " one of the 8 -bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and one of eight bits to be set. The second byte of the instruction designates address (0-255) of the byte to be operated upon.

### 3.2.2 Reset Memory Bit (RMB m, Addr.)

This instruction is the same operation and format as SMB instruction except a reset to " 0 " of the bit results.

### 3.2.3 Branch On Bit Set Relative (BBS m, Addr, DEST)

This instruction tests one of eight bits designated by a 3-bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or $\mathrm{I} / \mathrm{O}$ ports). The third byte of the instruction is used to specify the 8 -bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

### 3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST)

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

### 3.3 READ-ONLY-MEMORY (ROM)

The optional ROM consists of 256 bytes mask programmable memory with an address space from 7F00 to 7FFF. ROM locations FFFA to FFFF are assigned for interrupt vectors. The reset vector can be optionally at 7FFE or FFFC.

The R6511Q has no ROM and its Reset vector is at FFFC.

### 3.4 RANDOM ACCESS MEMORY (RAM)

The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The R6500/13 provides a separate power pin ( $V_{\text {RR }}$ ) which may be used for standby power for 32 bytes located at 0040-005F. In the event of the loss of $\mathrm{V}_{\mathrm{cc}}$ power, the lowest 32 bytes of RAM data will be retained if standby power is supplied to the $V_{R R}$ pin. If the RAM data retention is not required then $V_{\text {RR }}$ must be connected to $\mathrm{V}_{\mathrm{CC}}$. During operation $\mathrm{V}_{\mathrm{RR}}$ must be at the $\mathrm{V}_{\mathrm{cc}}$ level.

For the RAM to retain data upon loss of $V_{C C}, V_{R R}$ must be supplied within operating range and $\overline{R E S}$ must be driven low at least eight $\emptyset 2$ clock pulses before $V_{c c}$ falls out of operating range. $\overline{\text { RES }}$ must then be held low while $V_{c c}$ is out of operating range and until at least eight $\varnothing 2$ clock cycles after $V_{c c}$ is again within operating range and the internal $\phi 2$ oscillator is stabilized. $\mathrm{V}_{\mathrm{FR}}$ must remain within $\mathrm{V}_{\mathrm{CC}}$ operating range during normal operation. When $\mathrm{V}_{\mathrm{cc}}$ is out of operating range, $\mathrm{V}_{\mathrm{RR}}$ must remain within the $\mathrm{V}_{\mathrm{RR}}$ retention range in order to retain data. Figure 3.2 shows typical waveforms.


Figure 3-2. Data Retention Timing

### 3.5 CLOCK OSCILLATOR

The R6511Q has been configured for a crystal oscillator, a divide by 2 countdown network, and for Master Mode Operation.

Three customer selectable mask options are available for controlling the R6500/13 timing. The R6500/13 can be ordered with a crystal or RC oscillator, a divide by 2 or divide by 4 countdown network and for clock master mode or clock slave mode operation.

For 2 MHz interval operation the divide-by-2 options must be specified.

A reference frequency can be generated with the on-chip oscillator using either an external crystal or an external resistor depending on the mask option selected. The oscillator reference frequency passes through an internal countdown network (divide by 2 or divide by 4 option) to obtain the internal operating frequency (see Figures 3-3a and 3-3b). The external crystal generated reference frequency is a preferred method since the resistor method can have tolerances approaching $50 \%$.

Internal timing can also be controlled by driving the XTLI pin with an external frequency source. Figure 3-3c shows typical connections. If XTLO is left floating, the external source is divided by the internal countdown network. However, if XTLO

A. RESISTOR INPUT

B. CRYSTAL INPUT

$\mathbf{f}_{\mathrm{INT}}=\leq 2 \mathrm{MHz}$
$3 \mathrm{f}_{\mathrm{EXT}}=2 \mathrm{X}$ or $4 \mathrm{X} \mathrm{f}_{\text {INT }}$

$\mathrm{f}_{\mathrm{INT}}=1$ or 2 MHz
$\mathbf{f}_{\mathrm{EXT}}=\mathbf{f}_{\mathrm{INT}}$
ss $\equiv$
C. CLOCK INPUTS
is tied to $V_{s s}$, the internal countdown network is bypassed causing the chip to operate at the frequency of the external source.

The operation escribed above assumed a CLOCK MASTER MODE mask option. In this mode a frequence source (crystal, RC network, or external source) must be applied to the XTLI and XTLO pins.

Note:
When operating at a 1 MHz internal frequency place a 15-22 pt capacitor between XTLO and GND.

Ø2 is a buffered output signal which closely approximates the internal timing. When a common external source is used to drive multiple devices the internal timing between devices as resents a system problem it can be avoided by the Master/Slave connection and options shown in Figure 3-4.

One R6500/13 is operated in the CLOCK MASTER MODE and a second in the CLOCK SLAVE MODE. Mask options in the SLAVE unit convert to $\emptyset 2$ signal into a clock input pin which is tightly coupled to the internal timing generator. As a result the internal timing of the MASTER and SLAVE units are synchronized with minimum skew. If the $\phi 2$ signal to the SLAVE unit is inverted, the MASTER and SLAVE UNITS WILL OPERATE OUT OF PHASE. This approach allows the two devices to share external memory using cycle stealing techniques.


Figure 3-4. Master/Slave Connections

Figure 3-3. Clock Oscillator Input Options

## R6511Q Microprocessor and R6500/13 Microcomputer

### 3.6 MODE CONTROL REGISTER (MCR)

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for Counter A and Counter B. Its setting, along with the setting of the Serial Communications Control Register (SCCR), determines the basic configuration of the R6500/13 in any application. Initializing this register is one of the first actions of any software program. The Mode Control Register bit assignment is shown in Figure 3-5.


Figure 3-5. Mode Control Register

The use of Counter A Mode Select is shown in Section 6.1.
The use of Counter B Mode Select is shown in Section 6.2.

The use of Port B Latch Enable is shown in Section 4.4.
The use of Port D in Tri-State Enable is shown in Section 4.6.

The use of Bus Mode Select is shown in Section 4.5 and 4.6.

### 3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)

An $\overline{\mathrm{RQ}}$ interrupt request can be initiated by any or all of eight possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple simultaneous interrupts cause the $\overline{\mathrm{RQ}}$ interrupt request to remain active until all interrupting conditions have been serviced and cleared.

The Interrupt Flag Register contains the information that indicates which I/O or counter needs attention. The contents of the Interrupt Flag Register may be examined at any time by reading at address: 0011. Edge detect IFR bits may be cleared by executing a RMB instruction at address location 0010. The RMB X, (0010) instruction reads FF, modifies bit $X$ to a " 0 ", and writes the modified value at address location 0011. In this way IFR bits set to a " 1 " after the read cycle of a Read-Modify-Write instruction (such as RMB) are protected from being cleared. A logic " 1 " is ignored when writing to edge detect IFR bits.

Each IFR bit has a corresponding bit in the Interrupt Enable Register which can be set to a "1" by writing a "1" in the respective bit position at location 0012 . Individual IER bits may be cleared by writing a " 0 " in the respective bit position, or by RES. If set to a " 1 ", an IRQ will be generated when the corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 3-6 and the functions of each bit are explained in Table 3-1.


Figure 3-6. Interrupt Enable and Flag Registers

Table 3-1. Interrupt Flag Register Bit Codes

| Bit Code | Function |
| :---: | :---: |
| IFR 0: | PA0 Positive Edge Detect Flag-Set to a " 1 " when a positive going edge is detected on PA0. Cleared by RMB O (0010) instruction or by $\overline{\text { RES }}$. |
| IFR 1: | PA1 Positive Edge Detect Flag-Set to a 1 when a positive going edge is detected on PA1. Cleared by RMB 1 (0010) instruction or by RES. |
| IFR 2: | PA2 Negative Edge Detect Flag-Set to a 1 when a negative going edge is detected on PA2. Cleared by RMB 2 (0010) instruction or by RES. |
| IFR 3: | PA3 Negative Edge Detect Flag-Set to 1 when a negative going edge is detected on PA3. Cleared by RMB 3 (0010) instruction or by RES. |
| IFR 4: | Counter A Underflow Flag-Set to a 1 when Counter A underflow occurs. Cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES. |
| IFR 5: | Counter B Underflow Flag-Set to a 1 when Counter B underflow occurs. Cleared by reading the Lower Counter B at location 001C, by writing to address location O01E, or by RES. |
| IFR 6: | Receiver Interrupt Flag-Set to a 1 when any of the Serial Communication Status Register bits 0 through 3 is set to a 1 . Cleared when the Receiver Status bits (SCSR 0-3) are cleared or by $\overline{\text { RES }}$. |
| IFR 7: | Transmitter Interrupt Flag-Set to a 1 when SCSR 6 is set to a 1 while SCSR 5 is a 0 or SCSR 7 is set to a 1 . Cleared when the Transmitter Status bits (SCSR 6 \& 7 ) are cleared or by RES. |

### 3.8 PROCESSOR STATUS REGISTER

The 8-bit Processor Status Register, shown in Figure 3-7, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6502 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

### 3.8.1 Carry Bit (C)

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

### 3.8.2 Zero Bit (Z)

The Zero Bit $(Z)$ is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to
zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The R6500 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions; ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

### 3.8.3 Interrupt Disable Bit (I)

The Interrupt Disable Bit (I) is used to control the servicing of an interrupt request ( $\overline{\mathrm{RQQ}})$. If the I Bit is reset to logic 0 , the $\overline{\mathrm{RQ}}$ signal will be serviced. If the bit is set to logic 1 , the $\overline{\mathrm{IRQ}}$ signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( $\overline{\mathrm{RES}}$ ), $\overline{\mathrm{RQ}}$, or Non-Maskable Interrupt (NMI) signal is detected.

The I bit is cleared by the Clear Interrupt Mask Instruction (CLI) and is set by the Set Interrupt Mask Instruction (SEI). This bit is set by the BRK Instruction. The Return from Interrupt (RTI) and Pull Processor Status (PLP) instructions will also affect the I bit.


Figure 3-7. Processor Status Register

### 3.8.4 Decimal Mode Bit (D)

The Decimal Mode Bit (D) is used to control the arithmetic mode of the CPU. When this bit is set to logic 1, the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction clears it. The PLP and RTI instructions also affect the Decimal Mode Bit.

## CAUTION

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application. This bit must be initialized to the desired state by the user program or erroneous results may occur.

### 3.8.5 Break Bit (B)

The Break Bit $(B)$ is used to determine the condition which caused the $\overline{\mathrm{RQ}}$ service routine to be entered. If the $\overline{\mathrm{RQ}}$ service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1. If the IRQ routine was entered as the result of an $\overline{\mathrm{IRQ}}$ signal being generated, the $B$ bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

### 3.8.6 Overflow Bit (V)

The Overflow Bit $(\mathrm{V})$ is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits $(-128 \leqslant n \leqslant 127)$.

This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7 ) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction-which may be used to sample interface devices-allows the overflow flag to reflect the condition of bit 6 in the sampled field. During a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions affecting

### 3.8.7 Negative Bit ( N )

The Negative Bit ( N ) is used to indicate that the sign bit (bit 7 ) in the resulting value of a data movement or data arithmetic operation is set to logic 1 . If the sign bit is set to logic 1 , the resulting value of the data movement or arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

# SECTION 4 PARALLEL INPUT/OUTPUT PORTS \& BUS MODES 

The devices have 32 I/O lines grouped into four 8-bit ports (PA, PB, PC, and PD). Ports A through C may be used either for input or output individually or in groups of any combination. Port D may be used as all inputs or all outputs.

Multifunction I/O's such as Port A and Port C are protected from normal port I/O instructions when they are programmed to perform a multiplexed function.

Internal pull-up resistors (FET's with an impedance range of $3 K \leqslant R_{L} \leqslant 12 \mathrm{~K}$ ohm ) are provided on all port pins except Port D. A mask option to delete the internal pull-ups in 8-bit port groups is available.

The direction of the $32 \mathrm{I} / \mathrm{O}$ lines are controlled by four 8 -bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, thus simplifying I/O handling. The I/O addresses are shown in Table 4-1. Appendix E. 6 shows the I/O Port Timing.

Table 4-1. I/O Port Addresses

| Port | Address |
| :---: | :---: |
| A | 0000 |
| B | 0001 |
| C | 0002 |
| D | 0003 |

### 4.1 INPUTS

Inputs for Ports A, B, and C are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to $\mathrm{I} / \mathrm{O}$ input lines. A low ( $<0.8 \mathrm{~V}$ ) input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high ( $>2.0 \mathrm{~V}$ ) input will cause a logic 1 to be read. An $\overline{\text { RES }}$ signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

Port $D$ may only be all inputs or all outputs. All inputs is selected by setting bit 5 of the Mode Control Register (MCR5) to a " 0 ".

The status of the input lines can be interrogated at any time by reading the $1 / O$ port addresses. Note that this will return the actual status of the input lines, not the data written into the $\mathrm{I} / \mathrm{O}$ port registers.

Read/Modify/Write instructions can be used to modify the operation of PA, PB, PC, \& PD. During the Read cycle of a Read/Modify/Write instruction the Port I/O register is read. For all other read instructions the port input lines are read. Read/Modify/Write instructions are: ASL, DEC, INC, LSR, RMB, ROL, ROR, and SMB.

### 4.2 OUTPUTS

Outputs for Ports A thru D are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( $>2.4 \mathrm{~V}$ ) output while a logic 0 will force a low ( $<0.4 \mathrm{~V}$ ) output.

Port D all outputs is selected by setting MCR5 to a "1".

### 4.3 Port A (PA)

Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as a standard parallel 8-bit, bit independent, I/O port or as serial channel I/O lines, counter I/O lines, or an input data strobe for the Port B input latch option. Table 4-2 tabulates the control and usage of Port A.

In addition to their normal I/O functions, PAO and PA1 can detect positive going edges and PA2 and PA3 can detect negative going edges. A proper transition on these pins will set a corresponding status bit in the IFR and generate an interrupt request if the respective Interrupt Enable Bit is set. The maximum rate at which an edge can be detected is onehalf the $\varnothing 2$ clock rate. Edge detection timing is shown in Appendix E.5.

Table 4-2. Port A Control \& Usage


### 4.4 PORT B (PB)

Port B can be programmed as an 8-bit, bit-independent I/O port. It has a latched input capability which may be enabled or disabled via the Mode Control Register (MCR). Table 4-3 tabulates the control and usage of Port B. An Input Data Strobe signal must be provided thru PAO when Port B is programmed to be used with latched input option. Input data latch timing for Port $B$ is shown in Appendix E.5.

Table 4-3. Port B Control \& Usage

|  |  | I/O Mode |  | Latch Mode |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MCR4 $=0$ |  | $\text { MCR4 }=1$ <br> (2) |  |
| $\begin{gathered} \text { Pin } \\ \# \end{gathered}$ | Pin <br> Name | Signal |  | Signal |  |
|  |  | Name | Type <br> (1) | Name | Type |
| 31 | PB0 | PBO | 1/0 | PBO | INPUT |
| 30 | PB1 | PB1 | I/O | PB1 | INPUT |
| 29 | PB2 | PB2 | 1/0 | PB2 | INPUT |
| 28 | PB3 | PB3 | I/O | PB3 | INPUT |
| 27 | PBA | PB4 | 1/O | PB4 | INPUT |
| 26 | PB5 | PB5 | $1 / 0$ | PB5 | INPUT |
| 25 | PB6 | PB6 | 1/0 | PB6 | INPUT |
| 24 | PB7 | PB7 | $1 / 0$ | PB7 | INPUT |

(1) Resistive Pull-Up, Active Buffer Pull-Down
(2) Input data is stored in Port B latch by PAO Puise

### 4.5 PORT C (PC)

Port C can be programmed as an I/O port, as part of the full address bus, and, in conjunction with Port D, as an abbreviated bus, or as a multiplexed bus. When operating in the Full Address Mode PC6 and PC7 serve as A13 and A14 with PCO-PC5 operating as normal I/O pins. When used in the abbreviated or multiplexed bus modes, PC0-PC7 function as A0-A3, A12, R/W, A13, and EMS, respectively, as shown in Table 4-4. EMS (External Memory Select) is asserted (low) whenever the internal processor accesses memory area between 0100 and 3FFF. (See Memory Map, Appendix B). The leading edge of EMS may be used to strobe the eight address lines multiplexed on Port D in the Multiplexed Bus Mode. See Appendices E. 3 through E. 5 for Port C timing.

### 4.6 PORT D (PD)

Port D can be programmed as an I/O Port, an 8-bit tri-state data bus, or as a multiplexed bus. Mode selection for Port $D$ is made by the Mode Control Register (MCR). The Port $D$ output drivers can be selected as tri-state drivers by setting
bit 5 of the MCR to 1 (one). Table 4-5 shows the necessary settings for the MCR to achieve the various modes for Port D. When Port D is selected to operate in the Abbreviated Mode PDO-PD7 serves as data register bits D0-D7. When Port $D$ is selected to operate in the Multiplexed Mode data bits D0 through D7 are time multiplexed with address bits A4 through A11, respectively. Refer to the Memory Maps (Appendix C) for Abbreviated and Multiplexed memory assignments. See Appendices E. 3 through E. 5 for Port D timing.

### 4.7 BUS MODES

A special attribute of Port $C$ and Port $D$ is their capability to be configured via the Mode Control Register (see Section 3.6) into four different modes.

In the Full Address Mode, the separate address and data bus are used in conjunction with PC6 and PC7, which automatically provide A13 and A14. The remaining ports perform the normal I/O function.

In the I/O Bus Mode all ports serve as I/O. The address and data bus are still functional but without A13 and A14. Since the internal RAM and registers are in the OOXX location, A15 can be used for chip select and A0-A12 used for selecting 8 K of external memory. Thus, the device can be used to emulate the R6500/11 in the Normal Bus Mode.

In the Abbreviated Bus Mode, the address and data lines can be used as in the I/O Bus Mode to emulate the R6500/11. Port C and Port D are automatically transformed into an abbreviated address bus and control signals (Port C) and a bidirectional data bus (Port D). 64 Peripheral addresses can be selected. In general usage, these 64 addresses would be distributed to several external I/O devices such as R6522 and R6520, etc., each of which may contain more than one unique address.

In the Multiplexed Bus Mode, the operation is similar to the Abbreviated Mode except that a full 16 K of external addresses are provided. Port C provides the lower addresses and control signals. Port D multiplexes functions. During the first half of the cycle it contains the remaining necessary 8 address bits for 16 K ; during the second half of the cycle it contains a bidirectional data bus. The address bits appearing on Port D must be latched into an external holding register. The leading edge of EMS, which indicates that the bus function is active, may be used for this purpose.

Figures 4-1a thru 4-1d show the possible configurations of the four bus modes. Figure 4-2 shows a memory map of the port as a function of the Bus Mode and further shows which addresses are active or inactive on each of the three possible buses.

R6511Q Microprocessor and R6500/13 Microcomputer
Table 4-4. Port C Control \& Usage

|  |  | Full Address Mode |  | I/O Mode |  | Abbreviated Mode |  | Multiplexed Mode |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { MCR7 }=0 \\ & \text { MCR6 }=0 \end{aligned}$ |  | $\begin{aligned} \text { MCR7 } & =0 \\ \text { MCR6 } & =1 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=0 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=1 \end{aligned}$ |  |
|  |  | Signal |  | Signal |  | Signal |  | Signal |  |
| $\begin{gathered} \text { Pin } \\ \# \end{gathered}$ | Pin Name | Name | Type | Name | Type <br> (1) | Name | Type <br> (2) | Name | Type <br> (2) |
| 54 | PC0 | PCO | 1/0 (1) | PCO | 1/0 | A0 | OUTPUT | AO | OUTPUT |
| 55 | PC1 | PC1 | 1/O (1) | PC1 | 1/O | A1 | OUTPUT | A1 | OUTPUT |
| 56 | PC2 | PC2 | I/O (1) | PC2 | 1/0 | A2 | OUTPUT | A2 | OUTPUT |
| 57 | PC3 | PC3 | 1/O (1) | PC3 | 1/O | A3 | OUTPUT | A3 | OUTPUT |
| 58 | PC4 | PC4 | I/O (1) | PC4 | $1 / 0$ | A12 | OUTPUT | A12 | OUTPUT |
| 59 | PC5 | PC5 | I/O (1) | PC5 | 1/0 | RW | OUTPUT | RWW | OUTPUT |
| 60 | PC6 | A13 | OUTPUT (2) | PC6 | 1/O | A13 | OUTPUT | A13 | OUTPUT |
| 61 | PC7 | A14 | OUTPUT (2) | PC7 | I/O | EMS | OUTPUT | EMS | OUTPUT |
| (1) Resistive Pull-Up, Active Buffer Pull-Down <br> (2) Active Buffer Pull-Up and Pull-Down |  |  |  |  |  |  |  |  |  |

Table 4-5. Port D Control \& Usage

|  |  | I/O Modes |  |  |  | Abbreviated Mode |  | Multiplexed Mode |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { MCR7 }=0 \\ & \text { MCR6 }=X \\ & \text { MCR5 }=0 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=0 \\ & \text { MCR6 }=\mathrm{X} \\ & \text { MCR5 }=1 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=0 \\ & \text { MCR5 }=1 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=1 \\ & \text { MCR5 }=1 \end{aligned}$ |  |  |  |
| $\begin{gathered} \text { Pin } \\ \# \end{gathered}$ | Pin Name | Signal |  | Signal |  | Signal |  | Signal |  | Signal |  |
|  |  | Name | Type <br> (1) | Name | Type <br> (2) | Name | Type (3) | 02 Low |  | 02 High |  |
|  |  |  |  |  |  |  |  | Name | Type (2) | Name | Type (3) |
| 62 | PD0 | PDO | INPUT | PDO | OUTPUT | DATAO | $1 / 0$ | A4 | OUTPUT | DATAO | 1/0 |
| 63 | PD1 | PD1 | INPUT | PD1 | OUTPUT | DATA1 | $1 / 0$ | A5 | OUTPUT | DATA1 | 1/O |
| 64 | PD2 | PD2 | INPUT | PD2 | OUTPUT | DATA2 | $1 / \mathrm{O}$ | A6 | OUTPUT | DATA2 | 1/0 |
| 1 | PD3 | PD3 | INPUT | PD3 | OUTPUT | DATA3 | I/O | A7 | OUTPUT | DATA3 | $1 / 0$ |
| 2 | PD4 | PD4 | INPUT | PD4 | OUTPUT | DATA4 | I/O | A8 | OUTPUT | DATA4 | $1 / 0$ |
| 3 | PD5 | PD5 | INPUT | PD5 | OUTPUT | DATA5 | $1 / \mathrm{O}$ | A9 | OUTPUT | DATA5 | $1 / \mathrm{O}$ |
| 4 | PD6 | PD6 | INPUT | PD6 | OUTPUT | DATA6 | I/O | A10 | OUTPUT | DATA6 | $1 / \mathrm{O}$ |
| 5 | PD7 | PD7 | INPUT | PD7 | OUTPUT | DATA7 | $1 / \mathrm{O}$ | A11 | OUTPUT | DATA7 | 1/O |

(1) Tri-State Buffer is in High Impedance Mode
(2) Tri-State Buffer is in Active Mode
(3) Tri-State Buffer is in Active Mode only during the phase 2 portion of a Write Cycle


Figure 4-1. Bus Mode Configurations


Figure 4-2. Memory Map

## SECTION 5 SERIAL INPUT/OUTPUT CHANNEL

The device provides a full duplex Serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 5-1. The serial bit rate is determined by Counter A for all modes except the Receiver Shift Register (RCVR S/R) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5 K bits per second (at $\phi 2=1 \mathrm{MHZ}$ ). The transmitter (XMTR) and receiver (RCVR) can be independently programmed to operate in different modes and can be independently enabled or disabled.


Figure 5-1. Serial Communication Control Register
Except for the Receiver Shift Register Mode (RCVR S/R), all XMTR and RCVR bit rates will occur at one sixteenth of the Counter A interval timer rate. Counter $\mathbf{A}$ is forced into an interval timer mode whenever the serial $I / O$ is enabled in a mode requiring an internal clock.

Whenever Counter $A$ is required as a timing source it must be loaded with the hexadecimal code that selects the data rate for the serial I/O Port. Refer to Counter A (paragraph 6.1) for a table of hexadecimal values to represent the desired data rate.

### 5.1 TRANSMITTER OPERATION (XTMR)

The XTMR operation and the transmitter related control/ status functions are enabled by bit 7 of the Serial Communications Control Register (SCCR). The transmitter, when in the Asynchronous (ASYN) mode, automatically adds a start bit, one or two stop bits, and, when enabled, a parity bit to the transmitted data. A word of transmitted data (in asynchronous parity mode) can have $5,6,7$, or 8 bits of data. The nine data modes are shown in Figure 5-2. When parity is disabled, the 5, 6, 7 or 8 bits of data are terminated with two stop bits.


Figure 5-2. SIO Data Modes
In the $S / R$ mode, eight data bits are always shifted out. Bits/ character and parity control bits are ignored. The serial data is shifted out via the SO output (PA6) and the shift clock is available at the CA (PA4) pin. When the transmitter underruns in the S/R mode the SO output and shift clock are held in a high state.

The XMTR Interrupt Flag bit (IFR7) is controlled by Serial Communication Status Register bits SCSR5, SCSR6 and SCSR7.

$$
\mathrm{IFR} 7=\text { SCSR6 }(\overline{\mathrm{SCSR} 5}+\mathrm{SCSR} 7)
$$

### 5.2 RECEIVER OPERATION (RCVR)

The receiver and its selected control and status functions are enabled when SCCR-6 is set to a " 1. . In the ASYN mode, data format must have a start bit, the appropriate number of data bits, a parity bit (if enabled), and one stop bit. Refer to paragraph 5.1 for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start bit and a strobe signal is generated at the approximate center of each incoming bit. Refer to Figure 5-3 for ASYN Receive Data Timing. The character assembly process does not start if the start bit signal is less than one-half the bit time after a low level is detected on the Receive Data Input. Framing error, over-run, and parity error conditions or a RCVR Data Register Full will set the appropriate status bits. Any of the above conditions will cause an Interrupt Request if the Receiver Interrupt Enable bit is set to logic 1.


Figure 5-3. ASYN Receive Data Timing
In the $S / R$ mode, an external shift clock must be provided at CA (PA4) pin along with 8 bits of serial data (LSB first) at the SI input (PA7). The maximum data rate using an external shift clock is one-eighth the internal clock rate. Refer to Figure 5-4 for S/R Mode Timing.


Figure 5-4. S/R Mode Timing
A RCVR interrupt (IFR6) is generated whenever any of SCSR0-3 are true.

### 5.3 SERIAL COMMUNICATION STATUS REGISTER (SCSR)

The Serial Communication Status Register (SCSR) holds information on various communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 5-5. Bit assignments and functions of the SCSR are as follows:

SCSR 0: Receiver Data Register Full-Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by $\overline{\operatorname{RES}}$ and is disabled if SCCR $6=0$. The SCSR 0 bit will not be set to a logic 1 if the received data contains an error condition; instead, a corresponding error bit will be set to a logic 1 .

SCSR 1: Over-Run Error-Set to a logic 1 when a new character is transferred from the Receiver Shift Register with the last character still in the Receiver Data Register. This bit is cleared by reading the Receiver Data Register or by RES.

SCSR 2: Parity Error-Set to logic 1 when the RCVR is in the ASYN Mode, Parity Enable bit is set, and the
received data has a parity error. This bit is cleared by reading the Receiver Data Register or by RES.
SCSR 3: Framing Error-Set to a logic 1 when the received data contains a zero bit after the last data or parity bit in the stop bit slot. Cleared by reading the Receiver Data Register or by RES (ASYN Mode only).
SCSR 4: Wake-Up-Set to a logic 1 by writing a "1" in bit 4 of address: 0016. The Wake-Up bit is cleared by $\overline{\text { RES }}$ or when the receiver detects a string of ten consecutive 1's. When the Wake-Up bit is set SCSR0 through SCSR3 are inhibited.
SCSR 5: End of Transmission-Set to a logic 1 by writing a "1" in bit position 5 of address: 0016. The End of Transmission bit is cleared by RES or upon writing a new data word into the Transmitter Data Register. When the End-of-Transmission bit is true the Transmitter Register Empty bit is disabled until a Transmitter Under-Run occurs.
SCSR 6: Transmitter Data Register Empty-Set to a logic 1 when the contents of the Transmitter Data Register are transferred to the Transmitter Shift Register. Cleared upon writing new data into the Transmit Data Register. This bit is initialized to a logic 1 by $\overline{R E S}$.
SCSR 7: Transmitter Under-Run-Set to a logic 1 when the last data bit is transmitted if the transmitter is in a S/R Mode or when the last stop bit is transmitted if the XMTR is in the ASYN Mode while the Transmitter Data Register Empty Bit is set. Cleared by a transfer of new data into the Transmitter Shift Register or by $\overline{\text { RESS. }}$


Figure 5-5. SCSR Bit Allocations

### 5.4 WAKE-UP FEATURE

In a multi-distributed microprocessor or microcomputer applications, a destination address is usually included at the beginning of the message. The Wake-Up Feature allows non-selected CPU's to ignore the remainder of the message until the beginning of the next message by setting the WakeUp bit. As long as the Wake-Up flag is true, the Receiver Data Register Full Flag remains false. The Wake-Up bit is automatically cleared when the receiver detects a string of 11 consecutive 1 's which indicates an idle transmit line. When the next byte is received, the Receiver Data Register Full Flag signals the CPU to wake-up and read the received data.

## SECTION 6 COUNTER/TIMERS

The device contains two 16 -bit counters (Counter A and Counter B) and three 16-bit latches associated with the counters. Counter A has one 16-bit latch and Counter B has two 16 -bit latches. Each counter can be independently programmed to operate in one of four modes:

## Counter A

- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Counter


## Counter B

- Retriggerable Interval Counter
- Asymmetrical Pulse Generation
- Interval Timer
- Event Counter

Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4.2).

### 6.1 COUNTER A

Counter A consists of a 16-bit counter and a 16 -bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contains the count of either $\phi 2$ clock pulses or external events, depending on the counter mode selected. The contents of Counter A may be read any time by executing a read at location 0019 for the Upper Counter A and at location 001A or location 0018 for the Lower Counter A. A read at location 0018 also clears the Counter A Underflow Flag (IFR4).

The 16 -bit latch contains the counter initialization value and can be loaded at any time by executing a write to the Upper Latch A at location 0019 and the Lower Latch A at location 0018. In either case, the contents of the accumulator are copied into the applicable latch register.

Counter A can be started at any time by writing to address: 001A. The contents of the accumulator will be copied into the


Figure 6-1. Interval Timer Timing Diagram

Upper Latch A before the contents of the 16 -bit latch are transferred to Counter $A$. Counter $A$ is set to the latch value whenever Counter A underflows. When Counter A decrements from 0000 the next counter value will be the latch value-not FFFF-and the Counter A Underflow Flag (IFR 4) will be set to " 1 ". This bit may be cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES.

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

| MCR1 <br> (bit 1) | MCRO <br> (bit 0) | Mode |
| :---: | :---: | :--- |
| 0 | 0 | Interval Timer |
| 0 | 1 | Pulse Generation |
| 1 | 0 | Event Counter |
| 1 | 1 | Pulse Width Measurement |

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

The Counter is set to the Interval Timer Mode (00) when a $\overline{R E S}$ signal is generated.

### 6.1.1 Interval Timer

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:

1. When the Counter is decremented from 0000 , the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the 02 clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore $1 \mu \mathrm{~s}$ to 65.535 ms at the $1 \mathrm{MHz} \emptyset 2$ clock rate or $0.5 \mu \mathrm{~s}$ to 32.767 ms at the $2 \mathrm{MHz} \emptyset 2$ clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting $\overline{\mathrm{IRQ}}$ interrupt requests in the counter IRQ interrupt routine.

When Counter A decrements from 0000, the Counter A Underflow (IFR4) is set to logic 1. If the Counter A Interrupt Enable Bit (IER4) is also set, an $\overline{\mathrm{RQ}}$ interrupt request will be generated. The Counter A Underflow bit in the Interrupt Flag Register can be examined in the $\overline{\mathrm{RQ}}$ interrupt routine to determine that the $\overline{\mathrm{RQ}}$ was generated by the Counter A Underflow.

## R6511Q Microprocessor and R6500/13 Microcomputer

While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.

### 6.1.2 Pulse Generation Mode

In the Pulse Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs or a write is performed to address 001A.

The normal output waveform is a symmetrical square-wave. The CA output is initialized high when entering the mode and transitions low when writing to 001A.

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

### 6.1.3 Event Counter Mode

In this mode the CA is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the $\varnothing 2$ clock rate.

The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter A Underflow bit (IER4) is set to logic 1 if the underflow occurs.

Figure 6.2 is a timing diagram of the Event Counter Mode.


Figure 6-2. Event Counter Mode

### 6.1.4 Pulse Width Measurement Mode

This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the $\varnothing 2$ clock rate as long as the CA line is held in the low state. The Counter is stopped when CA is in the high state.

The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4.

A timing diagram for the Pulse Width Measurement Mode is shown in Figure 6.3.


Figure 6-3. Pulse Width Measurement

### 6.1.5 Serial I/O Data Rate Generation

Counter A also provides clock timing for the Serial I/O which establishes the data rate for the Serial I/O port. When the Serial I/O is enabled, Counter $A$ is forced to operate at the internal clock rate. Counter $A$ is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4-2).

Table 6-1 identifies the values to be loaded in Counter A for selecting standard data rates with a $\phi 2$ clock rate of 1 MHz and 2 MHz . Although Table 6-1 identifies only the more common data rates, any data rate from 1 to 62.5 K bps can be selected by using the formula:

$$
N=\frac{\phi 2}{16 \times \mathrm{bps}}-1
$$

where

| $\mathrm{N}=$ | decimal value to be loaded into Counter A using |
| :--- | :--- |
|  | its hexadecimal equivalent. |
| $\phi 2$ | the clock frequency $(1 \mathrm{MHz}$ or 2 MHz$)$ |
| $\mathrm{bps}=$ | the desired data rate. |

## NOTE

In Table 6-1 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of $1.5 \%$ or less are acceptable. A revised clock rate is included in Table $6-1$ for those baud rates which fall outside this limit.

Table 6-1. Counter A Values for Baud Rate Selection

| Standard Baud Rate | Hexadecimal Value |  | Actual Baud Rate At |  | Clock Rate Needed To Get Standard Baud Rate |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1 MHz | 2 MHz | 1 MHz | 2 MHz | 1 MHz | 2 MHz |
| 50 | 04E1 | 09C3 | 50.00 | 50.00 | 1.0000 | 2.0000 |
| 75 | 0340 | 0682 | 75.03 | 74.99 | 1.0000 | 2.0000 |
| 110 | 0237 | 046F | 110.04 | 110.04 | 1.0000 | 2.0000 |
| 150 | 01A0 | 0340 | 149.88 | 150.06 | 1.0000 | 2.0000 |
| 300 | 00CF | 01A0 | 300.48 | 299.76 | 1.0000 | 2.0000 |
| 600 | 0067 | 00CF | 600.96 | 600.96 | 1.0000 | 2.0000 |
| 1200 | 0033 | 0067 | 1201.92 | 1201.92 | 1.0000 | 2.0000 |
| 2400 | 0019 | 0033 | 2403.85 | 2403.85 | 1.0000 | 2.0000 |
| 3600 | 0010 | 0021 | 3676.47 | 3676.47 | 0.9792 | 1.9584 |
| 4800 | 000C | 0019 | 4807.69 | 4807.69 | 1.0000 | 2.0000 |
| 7200 | 0008 | 0010 | 6944.44 | 7352.94 | 1.0368 | 1.9584 |
| 9600 | 0006 | 000C | 8928.57 | 9615.38 | 1.0752 | 2.0000 |

### 6.2 COUNTER B

Counter B consists of a 16-bit counter and two 16-bit latches organized as follows: Lower Counter B (LCB), Upper Counter B (UCB), Lower Latch B (LLB), Upper Latch B (ULB), Lower Latch C (LLC), and Upper Latch C (ULC). Latch C is used only in the asymmetrical pulse generation mode. The counter contains the count of either $\phi 2$ clock pulses or external events depending on the counter mode selected. The contents of Counter B may be read any time by executing a Read at location 001D for the Upper Counter B and at location 001E or 001C for the Lower Counter B. A Read at location 001C also clears the Counter B Underflow Flag.

Latch B contains the counter initialization value and can be loaded at any time by executing a Write to the Upper Latch $B$ at location 001D and the Lower Latch B at location 001C. In each case, the contents of the accumulator are copied into the applicable latch register.

Counter B can be initialized at any time by writing to address: 001 E . The contents of the accumulator is copied into the Upper Latch B before the value in the 16 -bit Latch B is transferred to Counter B. Counter B will also be set to the latch value and the Counter B Underflow Flag bit (IFR5) will be set to a "1" whenever Counter B underflows by decrementing from 0000.

IFR 5 may be cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by $\overline{R E S}$.

Counter B operates in the same manner as Counter $A$ in the Interval Timer and Event Counter modes. The Pulse Width Measurement Mode is replaced by the Retriggerable Interval Timer mode and the Pulse Generation mode is replaced by the Asymmetrical Pulse Generation Mode. Mode Control Register bits MCR2 and MCR3 select the four Counter B modes in a similar manner and coding as MCR0 and MCR1 select the modes of Counter A.

### 6.2.1 Retriggerable Interval Timer Mode

When operating in the Retriggerable Interval Timer mode, Counter B is initialized to the latch value by writing to address 001E, by a Counter B underflow, or whenever a positive edge occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the CB line. Figure 6-4 illustrates the operation.


Figure 6-4. Counter B. Retriggerable Interval Timer Mode

### 6.2.2 Asymmetrical Pulse Generation Mode

Counter B has a special Asymmetrical Pulse Generation Mode whereby a pulse train with programmable pulse width and period can be generated without the processor intervention once the latch values are initialized.

In this mode, the 16 -bit Latch B is initialized with a value which corresponds to the duration between pulses (referred to as $D$ in the following descriptions). The 16-bit Latch $C$ is initialized with a value corresponding to the desired pulse width (referred to as P in the following descriptions). The initialization sequence for Latch $B$ and $C$ and the starting of a counting sequence are as follows:

1. The lower 8 bits of $P$ are loaded into LLB by writing to address 001 C ; the upper 8 bits of $P$ are loaded into ULB and the full 16 bits are transferred to Latch C by writing to address location 001D. At this point both Latch $B$ and Latch $C$ contain the value of $P$.
2. The lower 8 bits of $D$ are loaded into LLB by writing to address 001 C ; the upper 8 bits of $D$ are loaded into ULB by writing to address location 001E. Writing to address location 001E also causes the contents of the 16-bit Latch $B$ to be downloaded into the Counter $B$ and the CB output to go low as shown in Figure 6-5.
3. When Counter $B$ underflow occurs the contents of the Latch $C$ are loaded into the Counter B and the CB output toggles to a high level, staying high until another underflow occurs. Latch $B$ is then down-loaded and the CB output toggles to a low level repeating the whole process.

## SECTION 7 POWER ON/INITIALIZATION CONSIDERATIONS

### 7.1 POWER ON TIMING

After application of $V_{C C}$ and $V_{R R}$ power to the device, $\overline{R E S}$ must be held low for at least eight $\phi 2$ clock cycles after $V_{c c}$ reaches operating range and the internal oscillator has stabilized. This stabilization time is dependent upon the input $\mathrm{V}_{c c}$ voltage and performance of the internal oscillator. The clock can be monitored at $\phi 2$ (pin 3). Figure 7-1 illustrates the power turn-on waveforms. Clock stabilization time is typically 20 ms .


Figure 7-1. Power Turn-On Timing Detail

### 7.2 POWER-ON RESET

When $\overline{R E S}$ goes from low to high, the device sets the Interrupt Mask Bit-bit 2 of the Processor Status Registerand initiates a reset vector fetch at address FFFC and FFFD (or optionally 7FFE and 7FFF) to begin user program execution. All of the I/O ports (PA, PB, PC, PD) will be forced to the high (logic 1) state. All bits of the Control Register will be cleared to logic 0 causing the Interval Timers counter mode (mode 00 ) to be selected and all interrupt enabled bits to be reset.


Figure 6-5. Counter B Pulse Generation

### 7.3 RESET ( $\overline{\mathrm{RES}}$ ) CONDITIONING

When $\overline{\operatorname{RES}}$ is driven from low to high the device is put in a reset state causing the registers and I/O ports to be configured as shown in Table 7-1.

Table 7-1. $\overline{R E S}$ Initialization of I/O Ports and Registers

| Bit No. | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| REGISTERS |  |  |  |  |  |  |  |  |
| $\quad$ Processor Status | $\mathbf{0}$ | - | - | - | - | 1 | - | - |
| Mode Control (MCR) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Int. Enable (IER) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Int. Flag (IFR) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Ser. Com. Control (SCCR) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Ser. Com. Status (SCSR) | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 |
| PORTS |  |  |  |  |  |  |  |  |
| PA Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PB Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PC Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PD Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

All RAM and other CPU registers will initialize in a random, non-repeatable data pattern.

### 7.4 INITIALIZATION

Any initialization process for the device should include a $\overline{\mathrm{RES}}$, as indicated in the preceeding paragraphs. After stabilization of the internal clock (if a power on situation) an initialization subroutine should be executed to perform (as a minimum) the following functions:

1. The Stack Pointer should be set
2. Clear or Set Decimal Mode
3. Set or Clear Carry Flag
4. Set up Mode Controls as required
5. Clear Interrupts

A typical initialization subroutine could be as follows:

| LDX | Load stack pointer starting address into <br> X Register |
| :--- | :--- |
| TXS | Transfer X Register value to Stack Pointer |
| CLD | Clear Decimal Mode |
| SEC | Set Carry Flag |
| $\ldots$. | Set-up Mode Control and |
| $\ldots$. | special function registers |
| $\ldots$ | and clear RAM as required |
| CLI | Clear Interrupts |

# APPENDIX A <br> ENHANCED R6502 INSTRUCTION SET 


#### Abstract

This appendix contains a summary of the Enhanced R6502 instruction set. For detailed information, consult the R6502 Microcomputer System Programming Manual, Document 29650 N30. The four instructions notated with a * are added instructions to enhance the standard 6502 instruction set.


## A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE

| MNEMONIC | INSTRUCTION | MNEMONIC | INSTRUCTION |
| :---: | :---: | :---: | :---: |
| ADC | Add Memory to Accumulator with Carry | LDA | Load Accumulator with Memory |
| AND | "AND" Memory with Accumulator | LDX | Load Index X with Memory |
| ASL | Shift Left One Bit (Memory or Accumulator) | LDY | Load Index Y with Memory |
|  |  | LSR | Shift One Bit Right (Memory or |
| *BBR | Branch on Bit Reset Relative |  | Accumulator) |
| *BBS | Branch on Bit Set Relative |  |  |
| BCC | Branch on Carry Clear | NOP | No Operation |
| BCS | Branch on Carry Set |  |  |
| BEQ | Branch on Result Zero | ORA | "OR" Memory with Accumulator |
| BIT | Test Bits in Memory with Accumulator |  |  |
| BMI | Branch on Result Minus | PHA | Push Accumulator on Stack |
| BNE | Branch on Result not Zero | PHP | Push Processor Status on Stack |
| BPL | Branch on Result Plus | PLA | Pull Accumulator from Stack |
| BRK | Force Break | PLP | Pull Processor Status from Stack |
| BVC | Branch on Overflow Clear |  |  |
| BVS | Branch on Overflow Set | *RMB | Reset Memory Bit |
|  |  | ROL | Rotate One Bit Left (Memory or |
| CLC | Clear Carry Flag |  | Accumulator) |
| CLD | Clear Decimal Mode | ROR | Rotate One Bit Right (Memory or |
| CLI | Clear Interrupt Disable Bit |  | Accumulator) |
| CLV | Clear Overflow Flag | RTI | Return from Interrupt |
| CMP | Compare Memory and Accumulator | RTS | Return from Subroutine |
| CPX | Compare Memory and Index X |  |  |
| CPY | Compare Memory and Index Y | SBC | Subtract Memory from Accumulator with Borrow |
| DEC | Decrement Memory by One | SEC | Set Carry Flag |
| DEX | Decrement Index $X$ by One | SED | Set Decimal Mode |
| DEY | Decrement Index Y by One | SEI | Set Interrupt Disable Status |
|  |  | *SMB | Set Memory Bit |
| EOR | "Exclusive-Or" Memory with | STA | Store Accumulator in Memory |
|  | Accumulator | STX | Store Index X in Memory |
|  |  | STY | Store Index Y in Memory |
| INC | Increment Memory by One |  |  |
| INX | Increment Index $X$ by One | TAX | Transfer Accumulator to Index X |
| INY | Increment Index Y by One | TAY | Transfer Accumulator to Index Y |
|  |  | TSX | Transfer Stack Pointer to Index X |
| JMP | Jump to New Location | TXA | Transfer Index X to Accumulator |
| JSR | Jump to New Location Saving Return | TXS | Transfer Index X to Stack Register |
|  | Address | TYA | Transfer Index Y to Accumulator |

## A. 2 R6511Q AND R6500/13 INSTRUCTION SET SUMMARY TABLE



## A. 3 INSTRUCTION CODE MATRIX

| 0 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\sum_{0}$ | BRK Implied 17 | $\begin{array}{\|c\|} \hline \text { ORA } \\ \text { (INE; X) } \\ 26 \end{array}$ |  |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { ASL } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{aligned} & \text { RMBO } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{aligned} & \text { PHP } \\ & \text { Implied } \\ & 1 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { ORA } \\ & \text { IMM } \\ & 2 \quad 2 \end{aligned}$ | ASL Accum 12 |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ABS } \\ & 34 \end{aligned}$ | ASL ABS <br> 36 | $\begin{aligned} & \text { BBRO } \\ & \text { ZP } \\ & 3 \quad 5^{* *} \end{aligned}$ | 0 |
| 1 | BPL <br> Relative <br> 2 2*» | $\begin{array}{\|c\|} \hline \text { ORA } \\ \text { (IND), Y } \\ 25^{*} \end{array}$ |  |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | ASL ZP, X <br> 26 | $\begin{aligned} & \text { RMB1 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { CLC } \\ \text { Implied } \end{gathered}$ $12$ | $\begin{gathered} \text { ORA } \\ \text { ABS, Y } \\ 3 \quad 4^{*} \end{gathered}$ |  |  |  | $\begin{gathered} \text { ORA } \\ \text { ABS, } x \\ 3 \quad 4^{*} \end{gathered}$ | $\begin{array}{\|c\|} \hline \text { ASL } \\ \text { ABS, } \mathrm{x} \\ 37 \end{array}$ | $\begin{aligned} & \text { BBR1 } \\ & \text { ZP } \\ & 3 \quad 5 * \end{aligned}$ | 1 |
| 2 |  | AND (IND, X$)$ 2 |  |  | $\begin{aligned} & \hline \text { BIT } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { AND } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{ROL} \\ & \mathrm{ZP} \\ & 2 \quad 5 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { RMB2 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | $\begin{aligned} & \text { PLP } \\ & \text { Implied } \end{aligned}$ $1.4$ | $\begin{aligned} & \text { AND } \\ & \text { IMM } \\ & 2 \quad 2 \end{aligned}$ | ROL Accum 12 |  | BIT ABS 34 | $\begin{aligned} & \hline \text { AND } \\ & \text { ABS } \\ & 3 \quad 4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{ROL} \\ & \mathrm{ABS} \\ & 3 \quad 6 \end{aligned}$ | $\begin{aligned} & \text { BBR2 } \\ & \text { ZP } \\ & 3 \quad 5^{* *} \end{aligned}$ | 2 |
| 3 | BMI <br> Relative <br> 2 2** | $\begin{array}{\|c\|} \hline \text { AND } \\ (\text { IND, Y) } \\ 2 \\ \hline \end{array}$ |  |  |  | $\begin{aligned} & \text { AND } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{aligned} & \mathrm{ROL} \\ & \mathrm{ZP}, \mathrm{X} \\ & 26 \end{aligned}$ | $\begin{aligned} & \text { RMB3 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { SEC } \\ \text { Implied } \\ 12 \end{gathered}$ | $\begin{array}{\|c} \text { AND } \\ \text { ABS, Y } \\ 3 \end{array}$ |  |  |  | AND <br> ABS, $X$ <br> 3 4* |  | $\begin{aligned} & \text { BBR3 } \\ & \text { ZP } \\ & 3 \quad 5^{* *} \end{aligned}$ | 3 |
| 4 | RTI Implied 16 | EOR $($ IND, X) 26 |  |  |  | $\begin{aligned} & \text { EOR } \\ & Z P \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { LSR } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { RMB4 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | PHA Implied 13 | $\begin{aligned} & \text { EOR } \\ & \text { IMM } \\ & 2 \quad 2 \end{aligned}$ | LSR Accum 12 |  | JMP ABS <br> 33 | $\begin{aligned} & \text { EOR } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { LSR } \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{aligned} & \text { BBR4 } \\ & \text { ZP } \\ & 3 \quad 5^{* *} \end{aligned}$ | 4 |
| 5 | BVC <br> Relative <br> 2 2** |  |  |  |  | $\begin{aligned} & \text { EOR } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{gathered} \text { LSR } \\ \text { ZP, } \mathrm{X} \\ 26 \end{gathered}$ | $\begin{gathered} \text { RMB5 } \\ \text { ZP } \\ 2 \quad 5 \\ \hline \end{gathered}$ |  |  |  |  |  | EOR ABS, X 3. $4^{*}$ | LSR ABS, $X$ 37 | $\begin{aligned} & \text { BBR5 } \\ & \text { ZP } \\ & 3 \quad 5^{* *} \end{aligned}$ | 5 |
| 6 | RTS Implied 16 | ADC (IND, X ) 26 |  |  |  | $\begin{aligned} & A D C \\ & Z P \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { ROR } \\ & \text { ZP } \\ & 2 \quad 5 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { RMB6 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { PLA } \\ \text { Implied } \\ 14 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { ADC } \\ & \text { IMM } \\ & 22 \end{aligned}$ | ROR Accum 12 |  | JMP Indirect $3 \quad 5$ | $\begin{aligned} & \text { ADC } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { ROR } \\ & \text { ABS } \\ & 3 \quad 6 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { BBR6 } \\ & \text { ZP } \\ & 3^{\prime \prime *} \end{aligned}$ | 6 |
| 7 | BVS <br> Relative <br> 2 2** | $\begin{gathered} \text { ADC } \\ (\text { IND, Y) } \\ 25^{*} \end{gathered}$ |  |  |  | $\begin{gathered} \text { ADC } \\ \text { ZP, } X \\ 24 \end{gathered}$ | $\begin{aligned} & \text { ROR } \\ & \text { ZP, X } \\ & 26 \end{aligned}$ | $\begin{aligned} & \text { RMB7 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | SEI Implied 12 |  |  |  |  | ADC ABS, $X$ 3 4* |  | $\begin{aligned} & \text { BBR7 } \\ & \text { ZP } \\ & 3 \quad 5 * \end{aligned}$ | 7. |
| 8 |  | STA (IND, X) 26 |  |  | $\begin{aligned} & \text { STY } \\ & Z P \\ & 2.3 \end{aligned}$ | $\begin{aligned} & \text { STA } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { STX } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { SMBO } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | DEY Implied 12 |  | TXA Implied 12 |  | $\begin{aligned} & \text { STY } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { STA } \\ & \text { ABS } \\ & 34 \end{aligned}$ | STX ABS <br> 34 | $\begin{aligned} & \text { BBSO } \\ & 3^{Z P} 5^{* *} \end{aligned}$ | 8 |
| 9 | BCC <br> Relative <br> 2 2** | $\begin{gathered} \text { STA } \\ \text { (IND, Y) } \\ 2.6 \end{gathered}$ |  |  | $\begin{gathered} \text { STY } \\ \text { ZP, } X \\ 2.4 \end{gathered}$ | $\begin{gathered} \text { STA } \\ \text { ZP, X } \\ 24 \\ \hline \end{gathered}$ | $\begin{gathered} \text { STX } \\ \text { ZP, Y } \\ 24 \end{gathered}$ | $\begin{aligned} & \text { SMB1 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | TYA Implied 12 | STA ABS, Y <br> 35 |  |  |  | STA ABS, $X$ 35 |  | $\begin{aligned} & \text { BBS1 } \\ & \text { ZP } 5^{\prime *} \end{aligned}$ | 9 |
| A | $\begin{aligned} & \text { LDY } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { LDA } \\ \text { (IND, X) } \\ 266 \end{gathered}$ | $\begin{aligned} & \text { LDX } \\ & \text { IMM } \\ & 22 \end{aligned}$ |  | $\begin{aligned} & \text { LDY } \\ & Z P \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & Z P \\ & 2 \quad 3 \end{aligned}$ | $\begin{array}{r} \mathrm{LDXX} \\ \mathrm{ZP} \\ 2 \quad 3 \\ \hline \end{array}$ | $\begin{aligned} & \text { SMB2 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | TAY Implied 12 | $\begin{aligned} & \text { LDA } \\ & \text { IMM } \\ & 22 \end{aligned}$ | TAX Implied 12 |  | $\begin{aligned} & \text { LDY } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { LDX } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { BBS2 } \\ & 3^{\text {ZP }} 5^{* *} \end{aligned}$ | A |
| B | BCS <br> Relative <br> 2 2** | $\begin{array}{\|c\|} \hline \text { LDA } \\ \text { (IND), Y } \\ 25^{*} \end{array}$ |  |  | $\begin{gathered} \text { LDY } \\ \text { ZP, X } \\ 24 \end{gathered}$ | $\begin{aligned} & \text { LDA } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { LDX } \\ & \text { ZP, Y } \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { SMB3 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { CLV } \\ \text { Implied } \end{gathered}$ $12$ |  | $\begin{gathered} \text { TSX } \\ \text { Implied } \end{gathered}$ $12$ |  | $\left.\begin{gathered} \text { LDY } \\ \text { ABS, } x \\ 3 \end{gathered} \right\rvert\,$ | $\begin{aligned} & \text { LDA } \\ & \text { ABS, } \mathrm{X} \\ & 34^{*} \end{aligned}$ |  | $\begin{aligned} & \text { BBS3 } \\ & \text { ZP } \\ & 3 \quad 5 * * \end{aligned}$ | B |
| C | $\begin{aligned} & \text { CPY } \\ & \text { IMM } \\ & 22 \end{aligned}$ | $\begin{gathered} \text { CMP } \\ \text { (IND, X) } \\ 266 \end{gathered}$ |  |  | $\begin{aligned} & \text { CPY } \\ & Z P \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & D E C \\ & Z P \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { SMB4 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | INY Implied 12 | $\begin{aligned} & \text { CMP } \\ & \text { IMM } \\ & 22 \end{aligned}$ | $\begin{array}{\|c\|} \text { DEXX } \\ \text { Implied } \end{array}$ $12$ |  | CPY <br> ABS <br> 34 | $\begin{aligned} & \text { CMP } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { ABS } \\ & 3 \quad 6 \end{aligned}$ | $\begin{aligned} & \text { BBS4 } \\ & 3^{\text {ZP }} 5^{\star \star} \end{aligned}$ | C |
| D | BNE <br> Relative 2 2** |  |  |  |  | $\begin{gathered} \text { CMP } \\ \text { ZP, X } \\ 24 \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { ZP, X } \\ 26 \end{gathered}$ | $\begin{aligned} & \text { SMB5 } \\ & \text { ZP } \\ & 2 \quad 5 \\ & \hline \end{aligned}$ | CLD Implied 12 |  |  |  |  |  |  | $\begin{gathered} \text { BBS5 } \\ \text { ZP } \\ 3 \quad 5 * * \end{gathered}$ | D |
| E | $\begin{aligned} & \hline \text { CPX } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ |  |  |  | $\begin{aligned} & \mathrm{CPX} \\ & \mathrm{ZP} \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{SBC} \\ & \mathrm{ZP} \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{array}{r} \mathrm{INC} \\ \mathrm{ZP} \\ 2 \quad 5 \\ \hline \end{array}$ | $\begin{aligned} & \text { SMB6 } \\ & \text { ZP } \\ & 2 \quad 5 \\ & \hline \end{aligned}$ | INX Implied 12 | $\begin{aligned} & \text { SBC } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ | NOP Implied 12 |  | $\begin{aligned} & \text { CPX } \\ & \text { ABS } \\ & 3 \quad 4 \\ & \hline \end{aligned}$ | SBC <br> ABS <br> 34 | INC ABS 36 | $\begin{gathered} \text { BBS6 } \\ \text { ZP } \\ 3 \quad 5 * \\ \hline \end{gathered}$ | E |
| F | BEQ <br> Relative 2 2** | SBC (IND), Y 2 5* |  |  |  | $\begin{gathered} \hline \text { SBC } \\ \text { ZP, X } \\ 2 \quad 4 \\ \hline \end{gathered}$ | $\begin{aligned} & \text { INC } \\ & \text { ZP, X } \\ & 26 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { SMB7 } \\ & \text { ZP } \\ & 2 \quad 5 \\ & \hline \end{aligned}$ | SED <br> Implied <br> 12 |  | , |  |  |  | INC ABS, $X$ <br> 37 | $\begin{gathered} \text { BBS7 } \\ \text { ZP } \\ 3 \quad 5^{* *} \end{gathered}$ | F |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |  |

0 | 0 |  |
| :---: | :---: |
| $\begin{array}{c}\text { BRK } \\ \text { Implied } \\ 1 \\ 7\end{array}$ | $\begin{array}{l}\text {-OP Code } \\ \text {-Addressing Mode } \\ \text {-Instruction Bytes; Machine Cycles }\end{array}$ |

## APPENDIX B KEY REGISTER SUMMARY



CPU Registers


Serial Communications Control Register


Interrupt Enable and Flag Registers


XMTR Data Reg Empty

- XMTR Under-Run

Serial Communications Status Register

## APPENDIX C ADDRESS ASSIGNMENTS/MEMORY MAPS/PIN FUNCTIONS

## C. 1 I/O AND INTERNAL REGISTER ADDRESSES

| ADDRESS (HEX) | READ | WRITE |
| :---: | :---: | :---: |
| $\begin{array}{r} 001 \mathrm{~F} \\ 1 \mathrm{E} \\ 1 \mathrm{D} \\ 1 \mathrm{C} \end{array}$ | Lower Counter B <br> Upper Counter B <br> Lower Counter B, CLR Flag | Upper Latch B, Cntr B $\leftarrow$ Latch B, CLR Flag Upper Latch B, Latch C $\leftarrow$ Latch B Lower Latch B. |
| $\begin{aligned} & 1 \mathrm{~B} \\ & 1 \mathrm{~A} \\ & 19 \\ & 18 \end{aligned}$ | Lower Counter A <br> Upper Counter A <br> Lower Counter A, CLR Flag | Upper Latch A, Cntr A Latch A, CLR Flag Upper Latch A Lower Latch A |
| $\begin{aligned} & 17 \\ & 16 \\ & 15 \\ & 14 \end{aligned}$ | Serial Receiver Data Register Serial Comm. Status Register Serial Comm. Control Register Mode Control Register | Serial Transmitter Data Register <br> Serial Comm. Status Reg. Bits 4 \& 5 only Serial Comm. Control Register Mode Control Register |
| $\begin{array}{r} 13 \\ 12 \\ 11 \\ 0010 \end{array}$ | Interrupt Enable Register Interrupt Flag Register Read FF | Interrupt Enable Register <br> Clear Int Flag (Bits 0-3 only, Write 0's only) |
| $\begin{aligned} & \mathrm{OF} \\ & \mathrm{OE} \\ & \mathrm{OD} \\ & \mathrm{OC} \end{aligned}$ | RESERVED <br> These addresses are reserved and are used by the CPU during Read and Write operation over the external Data Bus (DO-D7). |  |
| $\begin{aligned} & \hline 0 B \\ & 0 A \\ & 09 \\ & 08 \\ & \hline \end{aligned}$ |  |  |
| $\begin{aligned} & 07 \\ & 06 \\ & 05 \\ & 04 \end{aligned}$ |  |  |
| $\begin{array}{r} 03 \\ 02 \\ 01 \\ 0000 \end{array}$ | Port D <br> Port C <br> Port B <br> Port A | Port D <br> Port C <br> Port B <br> Port A |

R6511Q Microprocessor and R6500/13 Microcomputer

## C. 2 FULL ADDRESS MODE <br> MEMORY MAP <br> R6511Q OR R6500/13

## C. 3 FULL ADDRESS MODE <br> MEMORY MAP <br> R6500/13 ONLY


C. 4 MULTIPLE FUNCTION PIN ASSIGNMENTS—PORT C AND PORT D

| PIN <br> NUMBER | FULL ADDRESS <br> MODE | I/O PORT <br> FUNCTION | ABBREVIATED PORT <br> FUNCTION | MULTIPLEXED PORT <br> FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| 54 | PC0 | PC0 | AO | AO |
| 55 | PC1 | PC1 | A1 | A1 |
| 56 | PC2 | PC2 | A2 | A2 |
| 57 | PC3 | PC3 | A3 | A12 |
| 58 | PC4 | PC4 | A12 | A12 |
| 59 | PC5 | PC5 | R/W |  |
| 60 | A13 | PC6 | A13 | A13 |
| 61 | A14 | PC7 | EMS | EMS |
| 62 | PD0 | PD0 | D0 | A4/D0 |
| 63 | PD1 | PD1 | A5/D1 | A6/D2 |
| 64 | PD2 | PD2 | D2 | A7/D3 |
| 1 | PD3 | PD3 | D3 | A8/D4 |
| 2 | PD4 | PD4 | A9/D5 | A10/D6 |
| 3 | PD5 | PD5 | P5 | A11/D7 |
| 4 | PD6 | PD6 | D6 |  |

# APPENDIX D <br> ELECTRICAL SPECIFICATIONS 

MAXIMUM RATINGS*

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

*NOTE: 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.

## DC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \% ; \mathrm{V}_{\mathrm{RR}}=\mathrm{V}_{\mathrm{CC}} ; \mathrm{V}_{\mathrm{SS}}=0 ; \mathrm{TA}=0\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipation (Outputs High) Commercial @ $0^{\circ} \mathrm{C}$ Industrial @ $-40^{\circ}$ | $P_{\text {D }}$ | - | 750(1) | $\begin{aligned} & 1100 \\ & 1200 \end{aligned}$ | mW |
| RAM Standby Voltage (Retention Mode) | $\mathrm{V}_{\mathrm{RR}}$ | 3.0 | - | $\mathrm{V}_{C C}$ | Vdc |
| RAM Standby Current (Retention Mode) Commercial @ $25^{\circ} \mathrm{C}$ Industrial (1) $25^{\circ} \mathrm{C}$ | $\mathrm{I}_{\mathrm{RR}}$ | - | $\begin{gathered} 4 \\ 5.2 \\ \hline \end{gathered}$ | - | mADC |
| Input High Voltage (Except XTLI and $\emptyset 2$ in slave option) | $\mathrm{V}_{\mathrm{IH}}$ | +2.0 | - | $\mathrm{V}_{C C}$ | Vdc |
| Input High Voltage (XTLI and $\emptyset 2$ in slave option) | $\mathrm{V}_{\mathrm{IH}}$ | +4.0 | - | $\mathrm{V}_{C C}$ | Vdc |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | - | +0.8 | Vdc |
| Input Leakage Current ( $\overline{\mathrm{RES}}, \overline{\mathrm{NMI}})$ $\mathrm{V}_{\text {in }}=0$ to 5.0 Vdc | $\mathrm{I}_{\mathrm{N}}$ |  |  | $\pm 10.0$ | $\mu \mathrm{Adc}$ |
| Input Low Current PA, PB, PC, PD $\left(\mathrm{V}_{\mathrm{lL}}=0.4 \mathrm{Vdc}\right)$ | IIL | - | -1.0 | -1.6 | mAdc |
| Output High Voltage (Except XTLO) ( ${ }_{\text {LOAD }}=.100 \mu \mathrm{Adc}$ ) | $\mathrm{V}_{\mathrm{OH}}$ | +2.4 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Output Low Voltage ( $\mathrm{L}_{\text {LOAD }}=1.6 \mathrm{mAdc}$ ) | $\mathrm{V}_{\mathrm{DL}}$ | - | - | +0.4 | Vdc |
| Input Capacitance $\begin{aligned} & \left.\mathrm{V}_{\text {in }}-0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right) \\ & \text { XTLI, XTLO } \\ & \text { All Others } \end{aligned}$ | $\mathrm{C}_{\text {in }}$ | - | - | $\begin{aligned} & 50 \\ & 10 \end{aligned}$ | pF |
| I/O Port Pull-Up Resistance PAO-PA7, PB0-PB7, PCO-PC7 | $\mathrm{R}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | K $\Omega$ |
| Output Leakage Current Tri-State I/O's while in | Iout | - | - | $\pm 10$ | $\mu \mathrm{Adc}$ |
| Output Capacitance Tri-State I/O's while in High Impedance State $\mathrm{V}_{\text {IN }} \mathrm{OV}, \mathrm{TA}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}$ | $\mathrm{C}_{\text {out }}$ | - | - | 10 | pF |
| NOTE: Negative sign indicates outward current flow, positive indicates inward flow. <br> (1) at $25^{\circ} \mathrm{C}$ |  |  |  |  |  |

## APPENDIX E <br> TIMING REQUIREMENTS AND CHARACTERISTICS

## E. 1 GENERAL NOTES

1. $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, 0^{\circ} \mathrm{C} \leqslant \mathrm{TA} \leqslant 70^{\circ} \mathrm{C}$
2. A valid $V_{c c}-\overline{R E S}$ sequence is required before proper operation is achieved.
3. All timing reference levels are 0.8 V and 2.0 V , unless otherwise specified.
4. All time units are nanoseconds, unless otherwise specified.
5. All capacitive loading is 130pf maximum, except as noted below:

$$
\begin{array}{ll}
\text { PA, PB } & \text { - } 50 \mathrm{pf} \text { maximum } \\
\text { PC (I/O Modes Only) } & \text { - 50pf maximum } \\
\text { PC (ABB and Mux Mode) } & \text { - } 130 \mathrm{pf} \text { maximum } \\
\text { PC6, PC7 (Full Address Mode) } & \text { 130pf maximum }
\end{array}
$$

## E. 2 CLOCK TIMING

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $\mathrm{T}_{\mathrm{crc}}$ | Cycle Time | 1000 | $10 \mu \mathrm{~s}$ | 500 | $10 \mu \mathrm{~s}$ |
| $\mathrm{T}_{\text {PWx1 }}$ | XTLI Input Clock Pulse Width XTLO = VSS | $\begin{aligned} & 500 \\ & \pm 25 \end{aligned}$ | - | $\begin{aligned} & 250 \\ & \pm 10 \end{aligned}$ | - |
| $\mathrm{T}_{\text {Pwo2 }}$ | Output Clock Pulse Width at Minimum $\mathrm{T}_{\mathrm{cyc}}$ | $\mathrm{T}_{\text {Pwx } 1}$ | $\begin{aligned} & T_{p w x} 1 \\ & \pm 25 \end{aligned}$ | $\mathrm{T}_{\text {PWx1 }}$ | $\begin{aligned} & T_{p w x} \\ & \pm 20 \end{aligned}$ |
| $\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}$ | Output Clock Rise, Fall Time | - | 25 | - | 15 |
| $\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}$ | Input Clock Rise, Fall Time | - | 10 | - | 10 |

6. Example of External Chip Select (Multiplexed Bus)


Note that both EMS and Phase $2\left(\phi_{2}\right)$ must be used to correctly enable the chip selects in the multiplexed or abbreviated bus modes.


## E. 3 ABBREVIATED MODE TIMING-PC AND PD

(MCR $5=1$, MCR $6=0$, MCR $7=1$ )

| SYMBOL | PARAMETER | $\mathbf{1}$ MHz |  | $\mathbf{2 ~ M H z ~}$ |  |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $T_{\text {PCRS }}$ | (PC5) R/W Setup Time | - | 225 | - | 140 |
| $T_{\text {PCAS }}$ | (PC0-PC4, PC6) Address Setup Time | - | 200 | - | 100 |
| $T_{\text {PBSU }}$ | (PD) Data Setup Time | 50 | - | 35 | - |
| $T_{\text {PBHR }}$ | (PD) Data Read Hold Time | 10 | - | 10 | - |
| $T_{\text {PBHW }}$ | (PD) Data Write Hold Time | 30 | - | 30 | - |
| $T_{\text {PBDO }}$ | (PD) Data Output Delay | - | 175 | - | 130 |
| $T_{\text {PCHA }}$ | (PC0-PC4, PC6) Address Hold Time | 30 | - | 30 | - |
| $T_{\text {PCHR }}$ | (PC5) R/W Hold Time | 30 | - | 30 | - |
| $T_{\text {PCHV }}$ | (PC7) EMS Hold Time | 10 | - | 10 | - |
| $T_{\text {PCVP }}$ | (PC7) EMS Stabilization Time | 30 | - | 30 | - |
| $T_{\text {ESU }}$ | EMS Setup Time | - | 350 | - | 210 |

## E.3.1 Abbreviated Mode Timing Diagram



R6511Q Microprocessor and R6500/13 Microcomputer

## E. 4 MULTIPLEXED MODE TIMING-PC AND PD

(MCR $5=1$, MCR $6=1$, MCR $7=1$ )

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $\mathrm{T}_{\text {PCRS }}$ | (PC5) R/W Setup Time | - | 225 | - | 140 |
| $\mathrm{T}_{\text {pcas }}$ | (PC0-PC4, PC6) Address Setup Time | - | 200 | - | 100 |
| $\mathrm{T}_{\text {PBAS }}$ | (PD) Address Setup Time | - | 220 | - | 120 |
| $\mathrm{T}_{\text {PBSU }}$ | (PD) Data Setup Time | 50 | - | 35 | - |
| $\mathrm{T}_{\text {PBHR }}$ | (PD) Data Read Hold Time | 10 | - | 10 | - |
| $\mathrm{T}_{\text {PBHW }}$ | (PD) Data Write Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {PBDD }}$ | (PD) Data Output Delay | - | 175 | - | 140 |
| $\mathrm{T}_{\text {PCHA }}$ | (PC0-PC4, PC6) Address Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {PBHA }}$ | (PD) Address Hold Time | 10 | 100 | . 10 | 80 |
| $\mathrm{T}_{\text {PCHR }}$ | (PC5) R/W Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {PCHV }}$ | (PC7) EMS Hoid Time | 10 | - | 10 | - |
| $\mathrm{T}_{\text {PcVI }}{ }^{(1)}$ | (PC7) Address to EMS Delay Time | 30 |  | 30 |  |
| $\mathrm{T}_{\text {Pcve }}$ | (PC7) EMS Stabilization Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {ESU }}$ | EMS Setup Time | - | 350 | - | 210 |
| NOTE 1: Values assume PC0-PC4, PC6 and PC7 have the same capacitive load. |  |  |  |  |  |

## E.4.1 Multiplex Mode Timing Diagram



## E. 5 I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $T_{\text {pow }}{ }^{(1)}$ <br> $\mathrm{T}_{\text {CMos }}{ }^{(1)}$ <br> $T_{\text {pDow }}$ | Internal Write to Peripheral Data Valid PA, PB, PC TTL <br> $P A, P B, P C C M O S$ PD | - | $\begin{array}{r} 500 \\ 1000 \\ 175 \end{array}$ | - | $\begin{array}{r} 500 \\ 1000 \\ 150 \end{array}$ |
| $T_{\text {posu }}$ <br> $T_{\text {posu }}$ | Peripheral Data Setup Time PA, PB, PC <br> PD | $\begin{array}{r} 200 \\ 50 \end{array}$ | - | $\begin{array}{r} 200 \\ 50 \end{array}$ | - |
| $\begin{aligned} & T_{\text {PHR }} \\ & T_{\text {PHH }} \end{aligned}$ | Peripheral Data Hold Time $P A, P B, P C$ PD | $\begin{aligned} & 75 \\ & 10 \end{aligned}$ | - | $\begin{aligned} & 75 \\ & 10 \end{aligned}$ | - |
| $\mathrm{T}_{\text {EPW }}$ | PAO-PA3 Edge Detect Pulse Width | $\mathrm{T}_{\text {cre }}$ | - | $\mathrm{T}_{\mathrm{crc}}$ | - |
| $\begin{aligned} & T_{C P W} \\ & T_{C O}{ }^{(1)} \end{aligned}$ | Counters A and B <br> PA4, PA5 Input Pulse Width PA4, PA5 Output Delay | $\mathrm{T}_{\mathrm{crc}}$ | $\overline{500}$ | $\mathrm{T}_{\mathrm{crc}}$ | $\overline{500}$ |
| $T_{\text {petw }}$ <br> $\mathrm{T}_{\text {PLSU }}$ <br> $T_{\text {PeLh }}$ | Port B Latch Mode PAO Strobe Pulse Width PB Data Setup Time PB Data Hold Time | $\begin{gathered} T_{c r c} \\ 175 \\ 30 \end{gathered}$ | - | $\begin{array}{r} \mathbf{T}_{\mathrm{Crc}} \\ 150 \\ 30 \end{array}$ | - |
| $T_{\text {Pow }}{ }^{\text {(1) }}$ <br> $\mathrm{T}_{\text {cmos }}{ }^{\text {(1) }}$ <br> $T_{\text {CPW }}$ <br> $T_{\text {Pow }}{ }^{(1)}$ <br> $\mathrm{T}_{\text {смоs }}{ }^{(1)}$ | Serial I/0 <br> PA6 XMTR TTL <br> PA6 XMTR CMOS <br> PA4 RCVR S/R Clock Width PA4 XMTR Clock-S/R Mode (TTL) PA4 XMTR Clock-S/R Mode (CMOS) |  | $\begin{array}{r} 500 \\ 1000 \\ - \\ 500 \\ 1000 \end{array}$ |  | $\begin{array}{r} 500 \\ 1000 \\ - \\ 500 \\ 1000 \end{array}$ |

NOTE 1 : Maximum Load Capacitance: 50pF
Passive Pull-Up Required

## E.5.1 I/O, Edge Detect, Counter, and Serial I/O Timing



## R6511Q Microprocessor and R6500/13 Microcomputer

## E. 6 MICROPROCESSOR TIMING (D0-D7,

 A0-A12, A15, SYNC, R/W)| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $\mathrm{T}_{\text {Rws }}$ | R/W Setup Time | - | 225 | - | 140 |
| $\mathrm{T}_{\text {ADS }}$ | A0-A12, A15 Setup Time | - | 225 | - | 140 |
| Tosu | D0-D7 Data Setup Time | 50 | - | 35 | - |
| $T_{\text {HR }}$ | D0-D7 Read Hold Time | 10 | - | 10 | - |
| $\mathrm{T}_{\text {Hw }}$ | D0-D7 Write Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {Mos }}$ | D0-D7 Write Output Delay | - | 175 | - | 150 |
| $\mathrm{T}_{\text {SYN }}$ | SYNC Setup | - | 225 | - | 175 |
| $\mathrm{T}_{\mathrm{HA}}$ | A0-A12, A15 Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {HRW }}$ | R/W Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {ACC }}$ | External Memory Access <br> Time $T_{A C C}=T_{C Y C}-T_{F}$ - <br> $T_{\text {ADS }}-T_{\text {DSU }}$ | - | $\mathrm{T}_{\text {ACC }}$ | - | $\mathrm{T}_{\text {ACC }}$ |
| $\mathrm{T}_{\text {syH }}$ | SYNC Hold Time | 30 | - | 30 | - |

## E.6.1 Microprocessor Timing Diagram



## R6500/41 AND R6500/42 ONE-CHIP INTELLIGENT PERIPHERAL CONTROLLERS

## SECTION 1 INTRODUCTION

### 1.1 FEATURES

- Directly compatible with $6500,6800,8080$, and $\mathbf{Z 8 0}$ bus families
- Asynchronous Host interface that allows independent clock operation
- Input, Output and Status Registers for CPU/Host data transfer
- Status register for CPU/Host data transfer operations
- Interrupt or polled data interchange with Host
- Enhanced 6502 CPU
-Four new bit manipulation instructions:
Set Memory Bit (SMB)
Reset Memory Bit (RMB)
Branch on Bit Set (BBS)
Branch on Bit Reset (BBR)
-Decimal and binary arithmetic modes
- 13 addressing modes
-True indexing
- 1536-byte mask-programmable ROM
- 64-byte static RAM
- 23 TTL-compatible I/O lines (R6500/41 only)
- 47 TTL-compatible I/O lines (R6500/42 only)
- A 16-bit programmable counter/timer, with latch
-Pulse width measurement
-Pulse generation
-Interval timer
-Event counter
- Seven interrupts
- Two edge-sensitive lines; one positive, one negative
—Reset
-Counter Underflow
—Host data received
-Output Data Register full
-Input Data Register empty
- Multiplexed bus expandable to 4 K bytes of external memory
- Unmultiplexed bus for Peripheral I/O expansion
- $68 \%$ of the instructions are executed in less than $2 \mu \mathrm{~s}$ @ 2 MHz
- NMOS-3 silicon gate, depletion load technology
- Single +5 V power supply
- 40-pin DIP (R6500/41 only)
- 64-pin QUIP (R6500/42 only)

NOTE
This document describes both the R6500/41 and R6500/42. In the text, the terms IPC or device will be used when describing both parts. The few differences will be described in the text using the terms R6500/41 or R6500/ 42.

### 1.2 SUMMARY

The Rockwell R6500/41 and R6500/42 One-Chip Intelligent Peripheral Controllers (IPC) are general purpose, programmable interface //O devices designed for use with a variety of 8 -bit and 16 -bit microprocessor systems. The one-chip R6500/41 IPC has an enhanced R6502 CPU, 1.5 K by 8 -bit ROM, 64 by 8 -bit RAM, three I/O ports with multiplexed special functions, and a multi-function timer all contained within a 40pin package.

For systems requiring additional I/O ports, the device is also available in a 64-pin QUIP version, R6500/42, that provides three additional 8 -bit ports. In both versions, special interface registers allow these IPC devices to function as peripheral controllers for the 6500, 6800, Z80, 8080, and other 8-bit or 16-bit host microcomputer systems.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of computational power. These features make the device a leading candidate for IPC computer applications.

To facilitate system and program development for the device Rockwell has developed the R6541Q which can be used as an Emulator. A description of the R6541Q is contained in the R6541Q Product Description (Document Order No. 2136).

Rockwell supports development of the R6500/41 and R6500/ 42 with the System 65 Microcomputer Development System and the R6500/ $\star$ Family of Personality Modules. Complete in-circuit emulation with the R6500/ * Family of Personality Modules allows total system test and evaluation.

This product description is for the reader familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual (Order Number 201). A description of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Order Number 202).

### 1.3 MASK OPTIONS

The R6500/41 has provision for internal pull-up resistors on PA and PC ports as a mask option. This option is available for port groups only, not for individual port lines.

The R6500/42 has provision for pull-up resistors on PA, PC, PF, and PG ports as a mask option. This option is available for port groups only, not for individual port lines.

## SECTION 2 R6500/41 INTERFACE REQUIREMENTS

This section describes the interface requirements for the Intelligent Peripheral Controller. Figure 2-1 is the Interface Diagram for the devices. Figures 2-2 and 2-4 show the pin out configurations and Table 2-1 describes the function of each
pin of the devices. Figures 2-3 and 2-5 show the mechanical dimensions of the devices. Section 5 describes the Host computer interface protocol and timing requirements.


Figure 2-1. Interface Diagram


Figure 2.2 R6500/41 Pin Out Designation (40 PIN DIP)


Figure 2-4. R6500/42 Pin Out Designation (64 PIN QUIP)



Figure 2-5. R6500/42 Dimensional Outline

Table 2-1. Pin Description

| SIGNAL NAME | PIN NO. |  | DESCRIPTION | SIGNAL NAME | PIN NO. |  | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | R6500/41 | R6500/42 |  |  | R6500/41 | R6500/42 |  |
| CLKIN | 39 | 3 | Symmetrical square wave 100 KHz to 2 MHZ , TTL compatible input. | PAD-PA7 | 22-29 | 25-32 | 8 tit l/O port used for either input or output. Each line consists of an active transis- |
| $\phi 2$ | 20 | 23 | Output timing signal-This is an internally synchronized $1 \times$ clock output suitable for external memory or peripheral interfacing. |  |  |  | tor to $\mathrm{V}_{\mathrm{ss}}$ and an optional passive pull-up to $\mathrm{V}_{\mathrm{cc}}$. The two lower bits PA0 and PA1 also serve as edge detect inputs. PA2 is time shared with the 16 bit Counter Input or |
| $\overline{\text { RES }}$ | 38 | 57 | The reset input is used to initialize the device. Section 7 |  |  |  | output pin, CNTR, and is mode selected. |
|  |  |  | describes the process and conditions of the RES procedure. | PB0-PB7 | 30-37 | 49-56 | 8 bit I/O port used for either input or output. Each line consists of an active transis- |
| vcc | 40 | 58 | Power supply input ( +5 V ) |  |  |  | tor to $\mathrm{V}_{\text {ss }}$ and an active pull- |
| VSS | 21 | 24 | Signal and power ground ( OV ). |  |  |  | up to $\mathrm{V}_{\mathrm{cc}}$. This port becomes a tri-state data bus, D0-D7, in the Abbreviated or Multi- |
| $\overline{\text { CS }}$ | 1 | 4 | Chip select pin. |  |  |  | plexed Bus Mode. D0-D7 are |
| RS (AO) | 4 | 7 | Register select input pin used by the Host processor to indicate that information being |  |  |  | multiplexed with address lines A4-A11 in the Multiplexed Bus Mode. |
|  |  |  | written into the IPC is a data or command byte or to indicate that information being read from the IPC is a status or data byte. | PC0-PC6 | 13-19 | 16-22 | 7 bit I/O port used for either input or output. Each line consists of an active transistor to $\mathrm{V}_{\text {ss }}$ and an optional passive pull-up to $\mathrm{V}_{\mathrm{cc}}$. The pins PC0 to PC5 are mul- |
| $E(\overline{R D})$ | 2 | 5 | Host timing control signal for data register write and read. |  |  |  | tiplexed with address and control signals for use in |
| $\mathrm{R} / \overline{\mathrm{W}}$ ( $\overline{\mathrm{WR}})$ | 3 | 6 | Host timing control signal for data register write and read. |  |  |  | abbreviated and multiplex modes. PC6 is multiplexed with $\mathbb{I N T}$ and is program se- |
| HBO-HB7 | 5-12 | 8-15 | Data bus between Host and IPC data input and output registers. |  |  |  | lectable. In these two modes PC0-PC5 have active pullups. |
|  |  | . |  | PEO-PE7 PFO-PF7 PGo-PG7 | $\begin{aligned} & N / A \\ & N / A \\ & N / A \end{aligned}$ | $\begin{aligned} & 1,2,64-59 \\ & 33-40 \\ & 41-48 \end{aligned}$ | For the R6500/42, the 64 pin QUIP version, three additional ports ( 24 lines) are provided. Each line consists of an active transistor to $\mathrm{V}_{\mathrm{ss}}$. PF0-PF7 and PG0-PG7 are bidirectional, and an optional passive pull-up to $\mathrm{V}_{\mathrm{cc}}$ is provided. PEO-PE7 is outputs only with an active pullup. All ports will source $100 \mu \mathrm{amps}$. at 2.4 v except port E (PEOPE7) which will source 1 ma . at 1.5 v . |

This section provides a functional description of the IPC device. Functionally, the device consists of a CPU, both ROM and RAM memories, three parallel I/O ports (six in the 64-pin R6500/42), counter/latch circuit, a mode control register, and an interrupt flag/enable dual register circuit. A block diagram of the system is shown in Figure 3-1.

## NOTE

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

### 3.1 CPU LOGIC

The internal CPU of the device is an enhanced R6502 configuration with an 8-bit Accumulator register, two 8-bit Index Registers ( X and Y ); an 8-bit Stack Pointer register, an ALU, a 16-bit Program Counter, and standard instruction register/ decode and internal timing control logic.

### 3.1.1 Accumulator

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

### 3.1.2 Index Registers

There are two 8 -bit index registers, $X$ and $Y$. Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

### 3.1.3 Stack Pointer

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, or an internal $\overline{\mathbb{R Q}}$ interrupt. The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may only be accessed from the top. The address of a memory location is stored (or "pushed") onto the stack. Each time
data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1. Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus, and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 007F-0040. Normal usage calls for the initialization of the Stack Pointer at 007F.

### 3.1.4 Arithmetic and Logic Unit (ALU)

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

### 3.1.5 Program Counter

The 16 -bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter ( PCH ) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

### 3.1.6 Instruction Register and Instruction Decode

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register then decoded along with timing and interrupt signals to generate control signals for the various registers.

### 3.1.7 Timing Control

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is initialized each time an instruction fetch is executed and is advanced at the beginning of each low level of the Clock in pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.


Figure 3-1. R6500/41 \& R6500/42 Block Diagram

### 3.1.8 Interrupt Logic

Interrupt logic controls the sequencing of two interrupts: $\overline{\operatorname{RES}}$ and $\overline{\mathrm{IRQ}} \mathrm{I} \mathrm{IR}$ is generated by any one of four conditions: Counter Overflow, Positive Edge Detect, Negative Edge Detect, and Input Data Register Full.

### 3.2 NEW INSTRUCTIONS

In addition to the standard 6502 instruction set, four instructions have been added to the devices to simplify operations that previously required a read/modify/write operation. In order for these instructions to be equally applicable to any I/O ports, with or without mixed input and output functions, the I/O ports have been designed to read the contents of the specified port data register during the Read cycle of the read/ modify/write operation, rather than I/O pins as in normal read cycles. The added instructions and their format are explained in the following subparagraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions.

### 3.2.1 Set Memory Bit (SMB m, Addr.)

This instruction sets to "1" one of the 8-bit data field specified by the zero page address (memory or $1 / \mathrm{O}$ port). The first byte of the instruction specifies the SMB operation and 1 of 8 bits to be set. The second byte of the instruction designates address ( $00-\mathrm{FF}$ ) of the byte or $1 / O$ port to be operated upon.

### 3.2.2 Reset Memory Bit (RMB m, Addr.)

This instruction is the same operation and format as SMB instruction except a reset to " 0 " of the bit results.

### 3.2.3 Branch on Bit Set Relative (BBS m, Addr, DEST)

This instruction tests one of 8 bits designated by a three bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction is used to specify the 8 bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

### 3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST)

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

### 3.3 READ-ONLY-MEMORY (ROM)

The ROM consists of 1536 bytes ( 1.5 K ) mask programmable memory with an address space from FAOO to FFFF: ROM locations FFFC through FFFF are assigned for interrupt and reset vectors.

### 3.4 RANDOM ACCESS MEMORY (RAM)

The RAM consists of 64 bytes of read/write memory with an assigned page zero address of 0040 through 007 F .

### 3.5 SYSTEM CLOCK

The device functions with an external clock. It is fully asynchronous in reference to the Host computer timing. The device clock frequency equals the external clock frequency. It is also made available for any external device synchronization at pin $\phi 2$.

### 3.6 MODE CONTROL REGISTER (MCR)

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for the Counter, the 6500 or 8080 Bus Select, and the Interrupt (INT). Its setting determines the basic configuration of the device in any application. Initializing this register is one of the first actions of any software program. The Mode Control Register bit assignment is shown in Figure 3-2.

The use of Counter A Mode Select is shown in Section 6.
The use of the 6500/8080 Host Bus Select is shown in Section 6.

The use of Interrupt Select is shown in Section 4.5.
The use of Bus Mode Select is shown in Sections 4.4 and 4.5.


Figure 3-2. Mode Control Register Bit Allocations


Figure 3-3. Interrupt Enable and Flag Registers

Table 3-1. Interrupt Enable Signals

| Control Signal | Description |
| :---: | :---: |
| IER 0 | Positive Edge Detect, Interrupt Enablewhen this bit is true, a positive going signal on PAO will generate an $\overline{\mathrm{RQ}}$ and set the corresponding flag bit. |
| IER 1 | Negative Edge Detect Interrupt Enablewhen this bit is set to a "1" a negative going signal on PA1 will generate an IRQ and set the corresponding flag bit. |
| IER 2 | Input Data Register Full Interrupt Ena-ble-setting this bit to a "1" allows an $\overline{\mathrm{IRQ}}$ to be generated each time the Host fills the IDR setting the IDFR bit. |
| IER 3 | Output Data Register Full Interrupt Ena-ble-when this bit is an interrupt request to the Host is generated each time the ODRF flag is set to a "1". (See External Interrupts, Paragraph 3.7.1). Reading the ODR clears INT-1 and ODRF flags. |
| IER 4 | Input Data Register Empty Interrupt En-able-when this is set to a " 1 " an interrupt is generated to the Host each time the IDR is read by the CPU. The interrupt occurs when the IDRF flag is cleared. INT-2 is cleared when the Host reads the status flag register. (See External Interrupts, Paragraph 3.7.1). |
| IER 5 | Counter Interrupt Enable-if enabled, an $\overline{\operatorname{IRQ}}$ is generated whenever the Counter overflows. |

### 3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)

An $\overline{\mathrm{RQ}}$ interrupt request can be initiated by any or all of four possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple simultaneous interrupts will cause the IRQ interrupt request to remain active until all interrupting conditions have been serviced and cleared.

The Interrupt Flag Register contains the information that indicates which I/O or counter needs attention. The contents of the Interrupt Flag Register may be examined at any time by reading at address: 0011. Edge detect IFR bits may be cleared by executing a RMB instruction at address location 0010. The RMB X, (0010) instruction reads FF, modifies bit $X$ to a " 0 ", and writes the modified value at address location 0011. In this way IFR bits set to a " 1 " after the read cycle of a Read-Modify-Write instruction (such as RMB) are protected from being cleared. IFR bits 6 and 7 are indeterminate on a Read.

Each. IFR bit has a corresponding bit in the Interrupt Enable Register which can be set to a " 1 " by writing a " 1 " in the respective bit position at location 0012 . Individual IER bits may be cleared by writing a " 0 " in the respective bit position, or by $\overline{R E S}$. If set to a " 1 ", an $\overline{\mathrm{IRQ}}$ will be generated when the corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 3-3 and the functions of each bit are explained in Table 3-1.

### 3.7.1 External Interrupts (INT)

An external interrupt $\overline{\operatorname{INT}}$ to the Host computer may be selected in two modes. (See Section 5 for information on the Host/Device interface).

## OUTPUT DATA REGISTER (ODR) FULL

When IER 3 of the Interrupt Enable Register is set to a "1", the device will assert the INT (PC6) line each time it loads the ODR. The ODRF flag of the Status Flag Register and the IFR 3 of the IFR will be set to a " 1 " indicating the ODR is full. The ODRF and IFR 3 flags are cleared and $\overline{\mathbb{N T}}$ is negated when the Host processor reads the ODR.

## INPUT DATA REGISTER (IDR) EMPTY

When IER 4 of the Interrupt Enable Register is set to a "1", the device will assert the $\overline{\mathrm{NT}}$ (PC6) line each time it reads the IDR. The IDRF flag of the Host Status Flag Register will be cleared and the IFR 4 flag of the IFR will be set to a "1" indicating the IDR has just been read by the device. The IFR 4 flag is cleared and INT is negated when the Host processor reads the Host Status Flag Register. $\overline{\text { RES }}$ clears the IDR and sets the IFR4 flag to indicate the register is empty.

### 3.8 PROCESSOR STATUS REGISTER

The 8-bit Processor Status Register, shown in Figure 3-4, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6502 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

### 3.8.1 Carry Bit (C)

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.
zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The R6502 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions; ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

### 3.8.3 Interrupt Disable Bit (I)

The Interrupt Disable Bit $(I)$ is used to control the servicing of an interrupt request (IRQ). If the I Bit is reset to logic 0 , the $\overline{\mathrm{IRQ}}$ signal will be serviced. If the bit is set to logic 1 , the $\overline{\mathrm{IRQ}}$ signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( $\overline{R E S}$ ) or Non-Maskable Interrupt ( $\overline{\mathrm{NMI} \text { ) signal is detected. }}$

The I bit is cleared by the Clear Interrupt Mask Instruction (CLI) and is set by the Set Interrupt Mask Instruction (SEI). This bit may also be set by the BRK Instruction. The Return from Interrupt (RTI) and Pull Processor Status (PLP) instructions will also affect the 1 bit.

### 3.8.2 Zero Bit (Z)

The Zero Bit $(Z)$ is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to


Figure 3-4. Processor Status Register

### 3.8.4 Decimal Mode Bit (D)

The Decimal Mode Bit (D), is used to control the arithmetic mode of the CPU. When this bit is set to logic 1, the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction will clear it. The PLP and RTI instructions also effect the Decimal Mode Bit.

## CAUTION

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application to the device. This bit must be initialized to the desired state by the user program or erroneous results may occur.

### 3.8.5 Break Bit (B)

The Break Bit $(B)$ is used to determine the condition which caused the $\overline{\mathrm{IRQ}}$ service routine to be entered. If the IRQ service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1. If the $\overline{\operatorname{RQ}}$ routine was entered as the result of an $\overline{\mathrm{RQ}}$ signal being generated, the B bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

### 3.8.6 Overflow Bit (V)

The Overflow Bit (V) is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits $(-128 \leqslant n \leqslant 127)$.

This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7 ) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction which may be used to sample interface devices, allows the overflow flag to reflect the condition of bit 6 in the sampled field. During a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instrction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions which affect the V flag are ADC, BIT, CLV, PLP, RTI and SBC.

### 3.8.7 Negative Bit (N)

The Negative Bit ( N ) is used to indicate that the sign bit (bit 7), in the resulting value of a data movement or data arithmetic operation, is set to logic 1 . If the sign bit is set to logic 1 , the resulting value of the data movement or arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

## SECTION 4 PARALLEL INPUT/OUTPUT PORTS

## INPUT/OUTPUT PORTS

The IPC device provides three ports (PA, PB, and PC). The 15 lines of PA and PC are completely bidirectional, that is, there are no line grouping or port association restrictions. The eight lines of Port B may be programmed as all inputs or all outputs. Port PC, however, may be multiplexed under program control with seven other signals. Six of these signals form an address and control bus for extended addressing. The seventh signal is multiplexed with an external interrupt output, INT. All eight Port B lines are tri-state to permit their use as a data bus during extended addressing modes.

The R6500/42, a 64 pin QUIP device, has three additional ports: PE, PF, and PG. PE is outputs only. PF and PG are bidirectional.

Internal pull-up resistors (FET's with an impedance range of $3 \mathrm{~K} \leqslant \mathrm{Rpu} \leqslant 12 \mathrm{~K}$ ohm) may be provided on ports PA and PC and ports PF \& PG (R6500/42 only), as a mask option.

The direction of the I/O lines are controlled by 8 -bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, which simplifies I/O handling. The I/O addresses are shown in Table 4-1. Section E. 6 shows the I/O Port Timing.

Table 4-1. I/O Port Addresses
$\left.\begin{array}{|c|c|}\hline \text { PORT } & \text { ADDRESS } \\ \hline \text { A } & 0000 \\ \text { B } & 0001 \\ \text { C } & 0002 \\ \text { E } \\ \text { F } \\ \text { G }\end{array}\right\}$ R6500/42 only $\quad 0004$

### 4.1 INPUTS

Inputs for Ports A and C, and also Ports F and G of the R6500/42, are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to $\mathrm{I} / \mathrm{O}$ input lines. A
low ( $<0.8 \mathrm{~V}$ ) input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high ( $>2.0 \mathrm{~V}$ ) input will cause a logic 1 to be read. An RES signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

Port B may be all inputs or all outputs. All inputs is selected by setting bits MCR6 and MCR7 of the Mode Control Register to a " 0 ".

The status of the input lines can be interrogated at any time by reading the I/O port addresses. Note that this will return the actual status of the input lines, not the data written into the $1 / O$ port registers.

Read/Modify/Write instructions can be used to modify the operation of PA, PB, PC, and also PF, \& PG of the R6500/ 42. During the Read cycle of a Read/Modify/Write instruction the Port I/O register is read. For all other read instructions the port input lines are read. Read/Modify/Write instructions are: ASL, BBS, BBR, DEC, INC, LSR, RMB, ROL, ROR, and SMB.

### 4.2 OUTPUTS

Outputs for Ports A thru C, and Ports E thru G of the R6500/ 42 , are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( $>2.4 \mathrm{~V}$ ) output while a logic 0 will force a low ( $<0.4 \mathrm{~V}$ ) output. Port B also requires that MCR 6 be set to a " 1 " and MCR7 be set to a " 0 ".

### 4.3 PORT A (PA)

Port A can be programmed via the Mode Control Register (MCR) as a standard parallel 8 -bit, bit independent, I/O port, or a counter I/O line. Table 4-2 tabulates the control and usage of Port $A$.

In addition to their normal I/O functions, PAO can detect positive going edges, and PA1 can detect negative going edges. An edge transition on these pins will set a corresponding status bit in the IFR and generate an interrupt request if the respective Interrupt Enable Bit is set. The maximum rate at which an edge can be detected is one-half the $\phi 2$ clock rate. Edge detection timing is shown in Section E.5.

Table 4-2. Port A Control \& Usage

| PAO-PA1 I/O |  | $\begin{gathered} \text { PA2 I/O } \\ \hline \text { MCRO }=0 \\ \text { MCR1 }=0 \end{gathered}$ |  | PA2 COUNTER |  |  |  | PA3-PA7 I/O |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\begin{aligned} & \text { MCRO }=1 \\ & \text { MCR1 }=0 \end{aligned}$ |  | $\begin{aligned} & \text { MCRO }=\mathbf{x} \\ & \text { MCR1 }=1 \end{aligned}$ |  |  |  |
|  |  |  |  |  |  |  |  |  |  |
| NAME | TYPE | NAME | TYPE | NAME | TYPE | NAME | TYPE | NAME | TYPE |
| $\begin{aligned} & \text { PAO (1) } \\ & \text { PA1 (2) } \end{aligned}$ | $\begin{aligned} & 1 / 0 \\ & 1 / 0 \end{aligned}$ | PA2 | 1/0 | CNTR | OUTPUT | CNTR | INPUT (3) | PA3-PA7 | 1/0 |

(1) POSITIVE EDGE DETECT
(2) NEGATIVE EDGE DETECT
(3) HARDWARE BUFFER FLOAT

### 4.4 PORT B (PB)

Port B can be programmed as an I/O Port, an 8-bit tri-state data bus, or as a multiplexed bus. Mode selection for Port B is made by the Mode Control Register (MCR). The Port B output drivers can be selected as tri-state output drivers by setting bit 7 of the MCR to 0 (zero) and bit 6 of the MCR to 1. An all inputs condition is created by setting both MCR6 and MCR7 to 0 (zero). Table 4-3 shows the necessary settings for the MCR to achieve the various modes for Port B. When Port $B$ is selected to operate in the Abbreviated Mode PB0-PB7 serves as data register bits D0-D7. When Port B is selected to operate in the Multiplexed Mode data bits D0 through D7 are time multiplexed with address bits A4 through A11, respectively. Refer to the Memory Maps (Appendix B) for Abbreviated and Multiplexed memory assignments. See Appendix E. 3 through E. 5 for Port B timing.

### 4.5 PORT C (PC)

Port $C$ can be programmed as an I/O port and in conjunction with Port B, as an abbreviated bus, or as a multiplexed bus.

When used in the abbreviated or multiplexed bus modes, PCO-PC5 function as AO-A3, R/W, and EMS, respectively, as shown in Table 4-4. EMS (External Memory Select) is asserted (low) whenever the internal processor accesses memory area between 0080 and OFFF. (See Memory Map, Appendix C). The leading edge of EMS may be used to strobe the eight address lines multiplexed on Port $B$ in the Multiplexed Bus Mode. See Appendix E. 3 through E. 5 for Port $C$ timing.

### 4.6 PORT E, PORT F AND PORT G (PE, PF \& PG) R6500/42 ONLY

Port E only operates in the Output mode. It provides a Darlington output that can source current at the high (1) level. Port F and Port G operate identically and can be programmed as bidirectional I/O ports. They have standard output capability. See Appendix E. 3 through E. 5 for Port E, F \& Port $G$ timing.

Table 4-3. Port B Control \& Usage

|  |  | I/O MODES |  |  |  | ABBREVIATED MODE |  | MULTIPLEXED MODE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \hline \text { MCR7 }=0 \\ & \text { MCR6 }=0 \\ & \hline \text { SIGNAL } \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=0 \\ & \text { MCR6 }=1 \\ & \hline \text { SIGNAL } \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=0 \\ & \hline \text { SIGNAL } \end{aligned}$ |  | $\begin{aligned} & \text { MCRT }=1 \\ & \text { MCR6 }=1 \end{aligned}$ |  |  |  |
|  |  | PHASE 1 | PHASE 2 |  |  |  |
|  |  |  |  | NAME | TYPE <br> (1) | NAME | TYPE <br> (2) | NAME | TYPE <br> (3) | SIGNAL |  | SIGNAL |  |
| \# | \# | NAME | TYPE (2) |  |  |  |  |  |  | NAME | TYPE (3) |
| 30 | 49 | PB0 | INPUT | PB0 | OUTPUT | D0 | 1/0 | A4 | OUTPUT | D0 | 1/0 |
| 31 | 50 | PB1 | INPUT | PB1 | OUTPUT | D1 | 1/0 | A5 | OUTPUT | D1 | 1/0 |
| 32 | 51 | PB2 | INPUT | PB2 | OUTPUT | D2 | 1/0 | A6 | OUTPUT | D2 | 1/0 |
| 33 | 52 | PB3 | INPUT | PB3 | OUTPUT | D3 | 1/0 | A7 | OUTPUT | D3 | 1/0 |
| 34 | 53 | PB4 | INPUT | PB4 | OUTPUT | D4 | 1/0 | A8 | OUTPUT | D4 | 1/0 |
| 35 | 54 | PB5 | INPUT | PB5 | OUTPUT | D5 | 1/0 | A9 | OUTPUT | D5 | 1/0 |
| 36 | 55 | PB6 | INPUT | PB6 | OUTPUT | D6 | 1/0 | A10 | OUTPUT | D6 | 1/0 |
| 37 | 56 | PB7 | INPUT | PB7 | OUTPUT | D7 | 1/0 | A11 | OUTPUT | D7 | 1/0 |

(1) TRI-STATE BUFFER IS IN HIGH IMPEDANCE MODE (2) TRI-STATE BUFFER IS IN ACTIVE MODE
(3) TRI-STATE BUFFER IS IN ACTIVE MODE ONLY DURING THE PHASE 2 PORTION OF A WRITE CYCLE

Table 4-4. Port C Control \& Usage

|  |  | I/O MODE |  | ABBREVIATED MODE |  | $\begin{aligned} & \hline \hline \text { MULTIPLEXED } \\ & \text { MODE } \end{aligned}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { MCR7 }=0 \\ & \text { MCR6 }=\mathrm{X} \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=0 \end{aligned}$ |  | $\begin{aligned} \text { MCR7 } & =1 \\ \text { MCRE } & =1 \end{aligned}$ |  |
|  |  | SIGNAL |  | SIGNAL |  | SIGNAL |  |
| $\begin{gathered} \text { PIN } \\ \# \end{gathered}$ | $\begin{gathered} \text { PIN } \\ \# \end{gathered}$ | NAME | TYPE <br> (1) | NAME | TYPE <br> (2) | NAME | TYPE <br> (2) |
| 13 | 16 | PC0 | 1/0 | AO | OUTPUT | A0 | OUTPUT |
| 14 | 17 | PC 1 | I/O | A1 | OUTPUT | A1 | OUTPUT |
| 15 | 18 | PC2 | 1/0 | A2 | OUTPUT | A2 | OUTPUT |
| 16 | 19 | PC3 | 1/0 | A3 | OUTPUT | A3 | OUTPUT |
| 17 | 20 | PC4 | 1/0 | EMS | OUTPUT | EMS | OUTPUT |
| 18 | 21 | PC5 | 1/0 | $\mathrm{R} / \overline{\mathbf{W}}$ | OUTPUT | $\mathrm{R} / \overline{\mathrm{W}}$ | OUTPUT |
| 19 | 22 | PC6* | 1/O | $\overline{\mathrm{NT}}$ * | OUTPUT | INT* | OUTPUT |

[^12](2) ACTIVE BUFFER PULL-UP AND PULL-DOWN

Two way data transfers are performed between the IPC and the Host microprocessor by means of the Output Data Register and the Input Data Register. The Host can also write a command to the IDR and read from the Host Status Flag Register. Table $5-1$ shows the Host addressing matrix. A hardware interrupt procedure and a software polling procedure is available to control data traffic between the CPU and Host.

Table 5-1. Host Addressing Matrix

| RS $\left(A_{0}\right)$ | READ | WRITE |
| :---: | :---: | :---: |
| 1 | HOST <br> STATUS FLAG | COMMAND <br> INPUT |
| 0 | DATA REG <br> OUTPUT | DATA REG <br> INPUT |

### 5.1 DATA REGISTERS

The device has an 8-bit Input Data Register (IDR) and an 8 -bit Output Data Register (ODR). The IDR serves as a temporary storage for commands and data from the Host to the device. When transferring data from the Host to the device, the following conditions are in effect:

- $\overline{\mathrm{CS}}$ is asserted
- RS (AO) indicates command input or data input.
- The contents of the host data bus (HBO-HB7) are copied into the IDR when the appropriate Host bus write signals are asserted.

The ODR serves as a temporary storage for data from the device to the Host. When the Host is reading data from the device, the following conditions are in effect:

- $\overline{\mathrm{CS}}$ is asserted
- RS (AO) input selects ODR or HSFR
- The contents of ODR or the Flag Register are placed on the host data bus (HB0-HB7) when the appropriate Host read signals are asserted.


### 5.2 HOST STATUS FLAG REGISTER

A Host Status Flag Register facilitates a software protocol that permits independent and uninterrupted flow of data asynchronously between the host computer and the device.

The Host Status Flag Register contains 8 flag bits that can be read at anytime by either the Host or the device. See Figure 5-1. General purpose flags F2 through F6 are serviced by the device in either read or write modes and monitored by the Host (Read Only).

Flag F1 can be read at anytime by either the host or the device. The F1 flag copies the A0 (RS) input signal during any
host write data exchange. The device can write to the F1 flag at any time.

The ODRF (Output Data Register Full) flag is set each time the device writes to the Output Data Register. The setting of the ODRF sets the device Interrupt Status Register IFR3 flag. An Output Interrupt (INT) may be generated under program control by setting IER3 in the interrupt enable register. The ODRF flag is reset only by a hardware reset or by the host performing a read on the output data register. The ODRF flag is reset following the conclusion of any host output data register read. The resetting of the ODRF causes the reset of the IFR3 flag and thus the reset of the external interrupt (INT).

The IDRF (Input Data Register Full) flag is set following the conclusion of any host write data exchange. The setting of the IDRF causes IFR2 of the device status register to be set. An internal interrupt may be generated under program control by setting IER2 in the Interrupt Enable Register. The setting of IDRF also causes IFR4 to be reset. The IDRF resets during device read of the input data register. IFR2 sets and IFR4 resets following the reset of IDRF. IFR4 may generate an external output interrupt (INT, input buffer empty), under program control by setting. IER4 in the interrupt enable register.

The Host Status Flag Register is cleared by the $\overline{\operatorname{RES}}$ input.


Figure 5-1. Host Status Flag Register Bit Allocation

### 5.3 HOST COMPUTER INTERFACE

The device will work with a variety of Host Computers. The HOST interface consists of a chip select, one address line, 2 control lines and an 8 bit three state data bus. Internal logic of the device, controlled by MCR4, configures, the address and two control lines to either a 6500 or 8080 operational methodology. The interface is completely asynchronous and will work with a Host Computer up to a 5 MHz bus transfer rate. The device clock input frequency need not be the same as the Host's. A mode control register is set to match the interface to that of the Host device as follows:

MCR4 = $0 \quad$ When MCR4 is set to a logic zero, the IPC is configured to operate on a 6502/6800 type host bus. In this mode, the E input is connected to the host transfer strobe (VMA or 02 for 6800, 02 for 6500) and the R/W input is connected to the host microprocessor R/W output line. Figure $5-3$ and Table 5-2, together, specify the relevant timing for read and write cycles on this type of host bus.

Table 5-2. Host Interface Timing Characteristics BSEL $=0$ (6500)

| CHARACTERISTICS <br> 1 AND 2 MHz | SYMBOL | MIN | MAX |
| :--- | :---: | :---: | :---: |
| $\overline{\text { CS, R/ } \bar{W}, \text { RS Setup Time }}$ | $\mathrm{t}_{\mathrm{cs}}$ | 10 | - |
| Access Time | $\mathrm{t}_{\text {DA }}$ | - | $90^{*}$ |
| Data Hold Time | $\mathrm{t}_{\text {OHR }}$ | 10 | - |
| Control Hold Time | $\mathrm{t}_{\text {HC }}$ | 10 | - |
| Write Data Setup Time | $\mathrm{t}_{\text {WOS }}$ | 75 | - |
| Write Data Hold Time | $\mathrm{t}_{\text {DHW }}$ | 10 | - |
| Write Stroke Width | $\mathrm{t}_{\text {WR }}$ | 75 | - |

*NOTE:
90 ns when loading $=130 \mathrm{pf}+1$ TTL LOAD and
75 ns when loading $=90 \mathrm{pf}+1 \mathrm{TLL}$ LOAD.

MCR4 $=1$ When MCR4 is set to a logic one, the IPC is configured for operation on an 8080/Z80 type bus. In this mode, the RD input is used as a read strobe and the WR input is connected to the write strobe of the host microprocessor bus. Figure 5-4 and Table 5-3 show the relevant timing characteristics for this mode of operation.

Table 5-3. Host Interface Timing Characteristics BSEL =1 (8080)

| CHARACTERISTICS <br> 1 <br> 1 AND 2 MH | SYMBOL | MIN | MAX |
| :--- | :---: | :---: | :---: |
| $\overline{\overline{C S}}$, AO Setup Time | $\mathrm{t}_{\mathrm{cs}}$ | 10 | - |
| Data Access Time on Read | $\mathrm{t}_{\text {DA }}$ | - | $90^{*}$ |
| Data Hold Time | $\mathrm{t}_{\text {OHR }}$ | 10 | - |
| Control Hold Time | $\mathrm{t}_{\text {HC }}$ | 10 | - |
| Write Data Setup Time | $\mathrm{t}_{\text {wos }}$ | 75 | - |
| Write Data Hold Time | $\mathrm{t}_{\text {oHW }}$ | 10 | - |
| Write Stroke Width | $\mathrm{t}_{\text {Wr }}$ | 75 | - |

"NOTE:
90 ns when loading $=130 \mathrm{pf}+1$ TTL LOAD and
75 ns when loading $=90 \mathrm{pf}+1 \mathrm{TLL}$ LOAD.


Figure 5-3. $\quad$ Timing Diagram—Host Interface $(\mathbf{M C R 4}=\mathbf{0})(\mathbf{6 5 0 0}$ Version)


Figure 5-4. $\quad$ Timing Diagram—Host Interface $(M C R 4=1)(8080$ Version)

## SECTION 6 COUNTER/TIMERS

The device contains a 16 -bit counter and a 16 -bit latch associated with it. The counter can be independently programmed to operate in one of four modes:

## Counter

- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Counter

Operating modes of the Counter are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA2 is selected for Counter I/O.

### 6.1 COUNTER

The Counter consists of a 16-bit counter and a 16 -bit latch organized as follows: Lower Counter (LC), Upper Counter (UC), Lower Latch (LL), and Upper Latch (UL). The counter contains the count of either $\phi 2$ clock pulses or external events, depending on the counter mode selected. The contents of the Counter may be read any time by executing a read at location 0018 for the Upper Counter and at location 001 A or location 0019 for the Lower Counter. A read at location 0019 also clears the Counter Underflow Flag (IFR5).

The 16 -bit latch contains the counter initialization value, and can be loaded at any time by executing a write to the Upper Latch at location 0018 and the Lower Latch at location 001A. In either case, the contents of the accumulator are copied into the applicable latch register.

The Counter can be started at any time by writing to address 0019. The contents of the accumulator will be copied into the Upper Latch before the contents of the 16 -bit latch are transferred to the Counter. The counter is set to the latch value whenever the Counter underflows. When the Counter decrements from 0000 the next counter value will be the latch value, not FFFF, and the Counter Underflow Flag (IFR 5) will be set to " 1 ". This bit may be cleared by reading the Lower Counter at location 0019, by writing to address location 0019, or by RES.

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

| MCR1 <br> (bit 1) | MCR0 <br> (bit 0) |  |
| :---: | :---: | :--- |
| 0 | 0 | Mode |
| 0 | 1 | Interval Timer |
| 1 | 0 | Pulse Generation |
| 1 | 1 | Event Counter |

The Interval Timer, Pulse Generation, and Pulse Width Measurement Modes are $\phi 2$ clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line (PA2).

The Counter is set to the Interval Timer Mode (00) when a $\overline{R E S}$ signal is generated.

### 6.1.1 Interval Timer Mode

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:

1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 0019, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the $\varnothing 2$ clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore $1 \mu \mathrm{~s}$ to 65.535 ms at the $1 \mathrm{MHz} \phi 2$ clock rate or $0.5 \mu \mathrm{~s}$ to 32.767 ms at the $2 \mathrm{MHz} \varnothing 2$ clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting $\overline{\mathrm{RQ}}$ interrupt requests in the counter $\overline{\mathrm{RQ}}$ interrupt routine.

When the Counter decrements from 0000, the Counter Underflow (IFR5) is set to logic 1. If the Counter Interrupt Enable Bit (IER5) is also set, an IRQ interrupt request will be generated. The Counter Underflow bit in the Interrupt Flag Register can be examined in the $\overline{\mathrm{RQ}}$ interrupt routine to determine that the $\overline{\mathrm{RQ}}$ was generated by the Counter Underflow.

While the timer is operating in the Interval Timer Mode, PA2 operates as a PA I/O.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.


Figure 6-1. Interval Timer Timing Diagram

### 6.1.2 Pulse Generation Mode

In the Pulse Generation mode, the PA2 line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter Underflow occurs, or a write is performed to address 0019 .

The normal output waveform is a symmetrical square-wave. The PA2 output is initialized high when entering the mode and transitions low when writing to 0019.

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

### 6.1.3 Event Counter Mode

In this mode PA2 is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the $\varnothing 2$ clock rate.

The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter Underflow bit (IER5) is set to logic 1 if the underflow occurs.

Figure 6.2 is a timing diagram of the Event Counter Mode.


Figure 6-2. Event Counter Mode

### 6.1.4 Pulse Width Measurement Mode

This mode allows the accurate measurement of a low pulse duration on the PA2 line. The Counter decrements by one count at the $\varnothing 2$ clock rate as long as the PA2 line is held in the low state. The Counter is stopped when PA2 is in the high state.

The Counter underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the PA2 pin is held low. After the counter is stopped by a high level on PA2, the count will hold as long as PA2 remains high. Any further low levels on PA2 will again cause the counter to count down from its present value. The state of the PA2 line can be determined by testing the state of PA2.


## SECTION 7 POWER ON/INITIALIZATION CONSIDERATIONS

### 7.1 POWER ON TIMING

After application of VCC power to the device, $\overline{\text { RES }}$ must be held low for at least eight stable $\emptyset 2$ clock cycles after $V_{c c}$ reaches operating range.

Figure 7-1 illustrates the power turn-on waveforms. External clock stabilization time is typically 20 ms .


Figure 7-1. Power Turn-On Timing Detail

### 7.2 POWER-ON RESET

The occurrence of $\overline{R E S}$ going from low to high will cause the device to set the Interrupt Mask Bit-bit 2 of the Processor Status Register-and initiate a reset vector fetch at address FFFC and FFFD to begin user program execution. All of the I/O ports will be initialized to the high (logic 1) state. All bits of the Control Register will be cleared causing the Interval Timer counter mode to be selected and causing all interrupt enabled bits to be reset.

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

When $\overline{R E S}$ is driven from low to high the device is put in a reset state causing the registers and I/O ports to be set as shown in Table 7-1.

Table 7-1. $\overline{R E S}$ Initialization of I/O Ports and Registers

| BIT NO. $\longrightarrow$ | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| REGISTERS |  |  |  |  |  |  |  |  |
| Processor Status | - | - | - | - | - | 1 | - | - |
| Mode Control (MCR) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Int. Enable (IER) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Int. Flag (IFR) | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| Host Status Flag | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Input Data | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Output Data | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| PORTS |  |  |  |  |  |  |  |  |
| PA Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PB Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PC Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PE Latch (R6500/42 | 1 | 1 |  | 1 | 1 | 1 | 1 | 1 |
| PF Latch R6500/42 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PG Latch only | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

All RAM and other CPU registers will initialize in a random, nonrepeatable data pattern.

### 7.4 INITIALIZATION

Any initialization process for the device should include a $\overline{\operatorname{RES}}$ as indicated in the preceding paragraphs. After stabilization of the external clock (if a power on situation) an initialization routine should be executed to perform (as a minimum) the following functions:

1. The Stack Pointer should be set
2. Clear or Set Decimal Mode
3. Set or Clear Carry Flag
4. Set up Mode Controls and Counter as required
5. Clear Interrupts.

A typical initialization routine could be as follows:
LDX Load stack pointer starting address into X Register
TXS Transfer X Register value to Stack Pointer
CLD Clear Decimal Mode
SEC Set Carry Flag
. . . . Set-up Mode Control,
. . . . Counter, special function
. . . . registers and Clear RAM as required
CLI Clear Interrupts

## APPENDIX A EXPANDED R6502 INSTRUCTION SET

This appendix contains a summary of the R6502 instruction set. For detailed information, consult the R6502 Microcomputer System Programming Manual, Document 29650 N3O.

The four instructions notated with a * are added instructions for the IPC devices which enhance the standard 6502 instruction set.

## A. 1 INSTRUCTION SET IN ALPHABETIC

 SEQUENCE| MNEMONIC | INSTRUCTION | MNEMONIC | INSTRUCTION |
| :---: | :---: | :---: | :---: |
| ADC | Add Memory to Accumulator with Carry | LDA | Load Accumulator with Memory |
| AND | "AND" Memory with Accumulator | LDX | Load Index X with Memory |
| ASL | Shift Left One Bit (Memory or Accumulator) | LDY | Load Index Y with Memory |
|  |  | LSR | Shift One Bit Right (Memory or Accumulator) |
| *BER | Branch on Bit Reset Relative |  |  |
| *BBS | Branch on Bit Set Relative |  |  |
| BCC | Branch on Carry Clear | NOP | No Operation |
| BCS | Branch on Carry Set |  |  |
| BEQ | Branch on Result Żero |  |  |
| BIT | Test Bits in Memory with Accumulator | ORA | "OR" Memory with Accumulator |
| BMI | Branch on Result Minus |  |  |
| BNE | Branch on Result not Zero |  |  |
| BPL | Branch on Result Plus | PHA | Push Accumulator on Stack |
| BRK | Force Break | PHP | Push Processor Status on Stack |
| BVC | Branch on Overflow Clear | PLA | Pull Accumulator from Stack |
| BVS | Branch on Overflow Set | PLP | Pull Processor Status from Stack |
| CLC | Clear Carry Flag | *RMB | Reset Memory Bit |
| CLD | Clear Decimal Mode | ROL | Rotate One Bit Left (Memory or |
| CLI | Clear Interrupt Disable Bit |  | Accumulator) |
| CLV | Clear Overflow Flag | ROR | Rotate One Bit Right (Memory or |
| CMP | Compare Memory and Accumulator |  | Accumulator) |
| CPX | Compare Memory and Index X | RTI | Return from Interrupt |
| CPY | Compare Memory and Index Y | RTS | Return from Subroutine |
| DEC | Decrement Memory by One | SBC | Subtract Memory from Accumulator with |
| DEX | Decrement Index $X$ by One |  | Borrow |
| DEY | Decrement Index Y by One | SEC | Set Carry Flag |
|  |  | SED | Set Decimal Mode |
|  |  | SEI | Set Interrupt Disable Status |
| EOR | "Exclusive-Or" Memory with Accumulator | *SMB STA | Set Memory Bit <br> Store Accumulator in Memory |
|  |  | STX | Store Index X in Memory |
|  |  | STY | Store Index Y in Memory |
| INC | Increment Memory by One |  |  |
| INX | Increment Index X by One |  |  |
| INY | Increment Index $Y$ by One | TAX | Transfer Accumulator to Index $\mathbf{X}$ |
|  |  | TAY | Transfer Accumulator to Index Y Transfer Stack Pointer to Index X |
| JMP | Jump to New Location | TXA | Transfer Index $X$ to Accumulator |
| JSR | Jump to New Location Saving Return | TXS | Transfer Index $X$ to Stack Register |
|  | Address | TYA | Transfer Index Y to Accumulator |



## A. 3 INSTRUCTION CODE MATRIX



| 0 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | c | D | E | F |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\sum_{0}$ | BRK Implied 17 | $\begin{aligned} & \text { ORA } \\ & \text { (IND, X) } \\ & 2.6 \end{aligned}$ |  |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ZP } \\ & 23 \end{aligned}$ | $\begin{aligned} & \text { ASL } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{aligned} & \text { RMBO } \\ & \text { ZP } \\ & 2.5 \end{aligned}$ | PHP Implied 13 | $\begin{aligned} & \text { ORA } \\ & \text { IMM } \\ & 22 \end{aligned}$ | ASL Accum 12 |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { ASL } \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{aligned} & \text { BBRO } \\ & \text { ZP } \\ & 35 * \end{aligned}$ | 0 |
| 1 | $\begin{array}{c\|} \hline \text { BPL } \\ \text { Relative } \\ 2 \end{array} \mathbf{2}^{* *}$ | $\begin{aligned} & \text { ORA } \\ & \text { (IND), } Y \\ & 25^{*} \end{aligned}$ |  |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ZP, } X \\ & 24 \end{aligned}$ | $\begin{gathered} \text { ASL } \\ \text { ZP, } \mathrm{X} \\ 26 \end{gathered}$ | $\begin{aligned} & \text { RMB1 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\underset{\text { Implied }}{\text { CLL }}$ 12 | $\begin{array}{\|c\|} \hline \text { ORA } \\ \text { ABS, } Y \\ 3.4^{\circ} \end{array}$ |  |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ABS, } X \\ & 34^{*} \end{aligned}$ | $\begin{gathered} \text { ASL } \\ \text { ABS, } x \\ 37 \end{gathered}$ | $\begin{aligned} & \begin{array}{l} \text { BBR1 } \\ \text { ZP } \\ 35^{\circ} \end{array} \end{aligned}$ | 1 |
| 2 | $\begin{array}{\|c\|} \hline \text { JSR } \\ \text { Absolute } \\ 3 \\ \hline \end{array}$ | $\begin{gathered} \text { AND } \\ \text { (IND, X) } \\ 266 \end{gathered}$ |  |  | $\begin{aligned} & \text { BIT } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { AND } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \mathrm{ROL} \\ & \mathrm{ZP} \\ & 2 \quad 5 \end{aligned}$ | $\begin{aligned} & \text { RMB2 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | PLP Implied 14 | $\begin{aligned} & \text { AND } \\ & \text { IMM } \\ & 2.2 \end{aligned}$ | ROL Accum 12 |  | $\begin{aligned} & \text { BIT } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { AND } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \mathrm{ROL} \\ & \mathrm{ABS} \\ & 36 \end{aligned}$ | $\begin{gathered} \text { BBR2 } \\ 3 \text { ZP } 5^{* *} \end{gathered}$ | 2 |
| 3 | BMI <br> Relative <br> 2 2** | $\begin{gathered} \text { AND } \\ \text { (IND, Y) } \\ 25^{\circ} \end{gathered}$ |  |  |  | AND <br> ZP, X <br> 24 | $\begin{gathered} \mathrm{ROL} \\ \mathrm{ZP}, \mathrm{X} \\ 26 \end{gathered}$ | $\begin{aligned} & \text { RMB3 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | SEC Implied 12 |  |  |  |  | $\begin{aligned} & \text { AND } \\ & \text { ABS, } x \\ & 34^{*} \end{aligned}$ | $\begin{gathered} \text { ROL } \\ \text { ABS, } x \\ 37 \end{gathered}$ | $\begin{aligned} & \text { BBR3 } \\ & \text { ZP } \\ & 35^{* *} \end{aligned}$ | 3 |
| 4 | $\begin{gathered} \text { RTI } \\ \text { Implied } \\ 16 \end{gathered}$ | $\begin{gathered} \text { EOR } \\ \text { (ND, X) } \\ 266 \end{gathered}$ |  |  |  | $\begin{aligned} & \text { EOR } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { LSR } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { RMB4 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | PHA Implied 13 | $\begin{aligned} & \text { EOR } \\ & \text { IMM } \\ & 22 \end{aligned}$ | LSR <br> Accum <br> 12 |  | $\begin{aligned} & \text { JMP } \\ & \text { ABS } \\ & 3 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { EOR } \\ & \text { ABS } \\ & \text { 3. } 4 \end{aligned}$ | $\begin{aligned} & \text { LSR } \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{gathered} \text { BBR4 } \\ \begin{array}{c} \text { ZP } \\ 3 \end{array} \end{gathered}$ | 4 |
| 5 | BVC <br> Relative <br> 2 2** | $\begin{gathered} \hline \text { EOR } \\ \text { (ND), Y } \\ 25^{*} \end{gathered}$ |  |  |  | $\begin{aligned} & \text { EOR } \\ & \text { ZP, } X \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { LSR } \\ & \text { ZP, X } \\ & 26 \end{aligned}$ | $\begin{gathered} \text { RMB5 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | CLI Implied 12 |  |  |  |  | $\begin{gathered} \text { EOR } \\ \text { ABS; } x \\ 34^{*} \end{gathered}$ | LSR $37$ | $\begin{aligned} & \text { BBR5 } \\ & \text { ZP } \\ & 3 \quad 5^{* *} \end{aligned}$ | 5 |
| 6 | RTS Implied 16 | $\begin{gathered} \text { ADC } \\ \text { (ND, X) } \\ 2.6 \end{gathered}$ |  |  |  | $\begin{gathered} \text { ADC } \\ \text { ZP } \\ 2 \quad 3 \end{gathered}$ | $\begin{aligned} & \text { ROR } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{aligned} & \text { RMB6 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | PLA Implied 14 | $\begin{aligned} & \text { ADC } \\ & \text { IMM } \\ & 2 \quad 2 \end{aligned}$ | ROR <br> Accum <br> 12 |  |  <br> $\begin{array}{c}\text { JMP } \\ \text { Indirect } \\ 3\end{array}$ | ADC ABS <br> 34 | $\begin{aligned} & \text { ROR } \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{gathered} \text { BBR6 } \\ 3^{\text {ZP }} \\ 5^{* *} \end{gathered}$ | 6 |
| 7 | BVS <br> Relative <br> 2 2** | $\begin{gathered} \text { ADC } \\ (\text { (ND, Y) } \\ 25^{\circ} \end{gathered}$ |  |  |  | ADC <br> ZP, $X$ <br> 24 | $\begin{aligned} & \text { ROR } \\ & \text { ZP, X } \\ & 26 \end{aligned}$ | $\begin{aligned} & \text { RMB7 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | SEI Implied 12 |  |  |  |  | $\begin{gathered} \text { ADC } \\ \text { ABS; } x \\ 3 \\ 3 \end{gathered} 4^{*} .$ | $\begin{gathered} \text { ROR } \\ \text { ABS, } x \\ 37 \end{gathered}$ | $\begin{aligned} & \text { BBR7 } \\ & \text { ZP } 5^{\circ} \end{aligned}$ | 7 |
| 8 |  | $\begin{gathered} \text { STA } \\ \text { (ND, X) } \\ 266 \end{gathered}$ |  |  | $\begin{aligned} & \text { STY } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { STA } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { STX } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { SMBO } \\ & \text { ZP } \\ & 25 \end{aligned}$ | DEY Implied 12 |  | TXA Implied 12 |  | STY ABS <br> 34 | $\begin{aligned} & \text { STA } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { STX } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { BBSO } \\ & \text { ZP } \\ & 3^{5 * *} \end{aligned}$ | 8 |
| 9 | BCC <br> Relative <br> 2 2** | $\begin{gathered} \text { STA } \\ \text { (ND, Y) } \\ 2.6 \end{gathered}$ |  |  | $\begin{aligned} & \text { STY } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { STA } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{gathered} \text { STX } \\ \text { ZP, Y } \\ 24 \end{gathered}$ | $\begin{aligned} & \text { SMB1 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | TYA Implied 12 | STA ABS, $Y$ <br> 35 | TXS Implied 12 |  |  | STA ABS, $X$ 35 |  | $\begin{aligned} & \text { BBS1 } \\ & \text { ZP } \\ & 3 \text { 5** } \end{aligned}$ | 9 |
| A | $\begin{aligned} & \text { LDY } \\ & \text { IMM } \\ & 22 \end{aligned}$ | $\begin{gathered} \text { LDA } \\ \text { (IND, X) } \\ 266 \end{gathered}$ | $\begin{aligned} & \text { LDX } \\ & \text { IMM } \\ & 22 \end{aligned}$ |  | $\begin{aligned} & \text { LDY } \\ & Z P \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { LDX } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { SMB2 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | TAY Implied 12 | $\begin{aligned} & \text { LDA } \\ & \text { IMM } \\ & 2 \quad 2 \end{aligned}$ | TAX Implied 12 |  | $\begin{aligned} & \text { LDY } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | LDA ABS 34 | $\begin{aligned} & \text { LDX } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { BBS2 } \\ & \text { ZP } \\ & 3 \quad 5^{*} \end{aligned}$ | A |
| B | BCS <br> Relative <br> 2 2** | $\begin{gathered} \text { LDA } \\ \text { (IND), Y } \\ 25^{*} \end{gathered}$ |  |  | $\begin{aligned} & \text { LDY } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & \text { ZP, } X \\ & 24 \end{aligned}$ | $\begin{aligned} & L D X \\ & \text { ZP, } Y \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { SMB3 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { CLV } \\ \text { Implied } \end{gathered}$ $12$ |  | TSX Implied 12 |  |  | $\begin{gathered} \text { LDA } \\ \text { ABS, } x \\ \begin{array}{c} 3 \\ 4^{*} \end{array} \end{gathered}$ | $\begin{gathered} \text { LDX } \\ \text { ABS, } Y \\ 34^{\circ} \end{gathered}$ | $\begin{aligned} & \text { BBS3 } \\ & \text { ZP } \\ & 3 \text { 5.* } \end{aligned}$ | B |
| C | $\begin{aligned} & \text { CPY } \\ & \text { IMM } \\ & 22 \end{aligned}$ | $\begin{gathered} \text { CMP } \\ \text { (IND, X) } \\ 266 \end{gathered}$ |  |  | $\begin{aligned} & \text { CPY } \\ & Z P \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { SMB4 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | INY Implied 12 | $\begin{aligned} & \text { CMP } \\ & \text { IMM } \\ & 2 \quad 2 \end{aligned}$ | DEX Implied 12 |  | $\begin{aligned} & \text { CPY } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & \text { ABS } \\ & 3.4 \end{aligned}$ | $\begin{aligned} & \mathrm{DEC} \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{aligned} & \text { BBS4 } \\ & \text { ZP } \\ & 3 \text { 5** } \end{aligned}$ | C |
| D | BNE <br> Relative $22^{* *}$ | $\begin{gathered} \text { CMP } \\ \text { (IND), Y } \\ 25^{*} \end{gathered}$ |  |  |  | $\begin{gathered} \text { CMP } \\ \text { ZP, X } \\ 2 \quad 4 \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { ZP, } X \\ 26 \end{gathered}$ | $\begin{aligned} & \text { SMB5 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { CLD } \\ \text { Implied } \\ 1 \quad 2 \\ \hline \end{gathered}$ |  |  |  |  | $\begin{aligned} & \text { CMP } \\ & \text { ABS, } X \\ & 34^{*} \end{aligned}$ | $\begin{gathered} \text { DEC } \\ \text { ABS, } x \\ 3 \quad 7 \end{gathered}$ | $\begin{aligned} & \text { BBS5 } \\ & \text { ZP } \\ & 35^{* *} \end{aligned}$ | D |
| E | $\begin{aligned} & \text { CPX } \\ & \text { IMM } \\ & 22 \end{aligned}$ | $\begin{gathered} \text { SBC } \\ \text { (IND, } x \text { ) } \\ 2.6 \end{gathered}$ |  |  | $\begin{aligned} & C P X \\ & Z P \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { SBC } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { SMB6 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | $\begin{gathered} \text { INX } \\ \text { Implied } \\ 122 \end{gathered}$ | $\begin{aligned} & \text { SBC } \\ & \text { IMM } \\ & 2 \quad 2 \end{aligned}$ | NOP Implied 12 |  | $\begin{aligned} & \text { CPX } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { SBC } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{aligned} & \text { BBS6 } \\ & \text { ZP } \\ & 3 \quad 5 * \end{aligned}$ | E |
| F | BEQ <br> Relative <br> 2 2** | $\begin{array}{\|c} \hline \text { SBC } \\ \text { (ND), Y } \\ 25^{*} \end{array}$ |  |  |  | $\begin{aligned} & \text { SBC } \\ & \text { ZP, X } \\ & 24 \end{aligned}$ | $\begin{gathered} \text { INC } \\ \text { ZP, } x \\ 2.6 \end{gathered}$ | $\begin{aligned} & \text { SMB7 } \\ & \text { ZP } \\ & 2 \quad 5 \\ & \hline \end{aligned}$ | SED Implied 12 |  |  |  |  | $\begin{gathered} \text { SBC } \\ \text { ABS, } X \\ 3 \quad 4^{*} \end{gathered}$ | INC ABS, $X$ 37 | $\begin{aligned} & \text { BBS7 } \\ & \text { ZP } \\ & 3^{\prime \prime *} \end{aligned}$ | F |

*Add 1 to $\mathbf{N}$ if page boundary is crossed.
*"Add 1 to N if branch occurs to same page; add 2 to N if branch occurs to different page.

## APPENDIX B <br> KEY REGISTER SUMMARY

CPU Registers


Mode Control Register


Processor Status Register




| RS $\left(A_{0}\right)$ | READ | WRITE |
| :---: | :---: | :--- |
| 1 | HOST <br> STATUS FLAG | COMMAND <br> INPUT |
| 0 | DATA REG <br> OUTPUT | DATA REG <br> INPUT |

## APPENDIX C MEMORY MAPS AND ADDRESS AND PIN ASSIGNMENTS

## C. 1 ABBREVIATED BUS MODE MEMORY MAP



## C. 2 MULTIPLEXED BUS MODE MEMORY MAP



## C. 3 I/O AND INTERNAL REGISTER ADDRESSES

| ADDRESS | READ | WRITE |
| :---: | :---: | :---: |
| $\begin{array}{r} 001 F \\ 1 E \\ 1 D \\ 1 C \end{array}$ | Host Status Flag Register Input Data Register (IDR) | Host Status Flag Register <br> Output Data Register (ODR) |
| $\begin{aligned} & 1 B \\ & 1 A \\ & 19 \\ & 18 \end{aligned}$ | Lower Counter <br> Lower Counter \& Clear Flag (IFR5) Upper Counter | Lower Latch <br> Upper Latch/Transfer Latch to Counter \& Clear Flag (IFR5) <br> Upper Latch |
| $\begin{aligned} & 17 \\ & 16 \\ & 15 \\ & 14 \end{aligned}$ | Mode Control Register | Mode Control Register |
| $\begin{aligned} & 13 \\ & 12 \\ & 11 \\ & 10 \end{aligned}$ | Interrupt Enable Register Interrupt Flag Register Read "FF" | Interrupt Enable Register <br> Clear Int Flag Bit |
| $\begin{aligned} & O F \\ & O E \\ & O D \\ & O C \end{aligned}$ |  |  |
| $\begin{aligned} & 0 B \\ & 0 A \\ & 09 \\ & 08 \end{aligned}$ | $\begin{aligned} & -- \\ & -- \\ & -- \end{aligned}$ |  |
| $\begin{aligned} & 07 \\ & 06 \\ & 05 \\ & 04 \end{aligned}$ | Port G (R6500/42 only) <br> Port F (R6500/42 only) <br> Port E (R6500/42 only) | Port G (R6500/42 only) <br> Port F (R6500/42 only) <br> Port E (R6500/42 only) |
| 03 02 01 00 | Port C Port B Port A | Port C <br> Port B <br> Port A |

## C. 4 MULTIPLE FUNCTION PIN ASSIGNMENTS

| PIN NUMBER | $\begin{aligned} & \text { BER } \\ & \text { R6500/42 } \end{aligned}$ | 1/0 FUNCTION | ABBREVIATED PORT FUNCTION | MULTIPLEXED PORT FUNCTION |
| :---: | :---: | :---: | :---: | :---: |
| 13 | 16 | PCO | AO | A0 |
| 14 | 17 | PC1 | A1 | A1 |
| 15 | 18 | PC2 | $\therefore \quad \mathbf{A} 2$ | A2 |
| 16 | 19 | PC3 | A3 | A3 |
| 17 | 20 | PC4 | R/W | $R / \bar{W}$ |
| 18 | 21 | PC5 | EMS | EMS |
| 19 | 22 | PC6/INT | PC6/INT | PC6/INT |
| 30 | 49 | PB0 | D0 | A4/D0 |
| 31 | 50 | PB1 | D1 | A5/D1 |
| 32 | 51 | PB2 | D2 | A6/D2 |
| 33 | 52 | PB3 | D3 | A7/D3 |
| 34 | 53 | PB4 | D4 | A8/D4 |
| 35 | 54 | PB5 | D5 | A9/D5 |
| 36 | 55 | PB6 | D6 | A10/D6 |
| 37 | 56 | PB7 | D7 | A.11/D7 |

## MAXIMUM RATINGS*

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

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

## DC CHARACTERISTICS

$V_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0$ )

| Parameter | Symbol | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipation (Outputs High) Commercial $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $P_{\text {D }}$ | - | 500 | - | mW |
| Input High Voltage (Normal Operating Levels) | $\mathrm{V}_{\mathrm{IH}}$ | +2.0 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Input Low Voltage (Normal Operating Levels) | $\mathrm{V}_{\text {IL }}$ | -0.3 | - | +0.8 | Vdc |
| Input Leakage Current $\mathrm{V}_{\text {in }}=0$ to 5.25 Vdc | In | -10.0 |  | + 10.0 | $\mu \mathrm{Adc}$ |
| Input Low Current ( $\left.\mathrm{V}_{\mathrm{iL}}=0.4 \mathrm{Vdc}\right)$ | $1 / 1$ |  | -1.0 | -1.6 | mAdc |
| Output High Voltage $\left(V_{C C}=\min , I_{\text {LOAD }}=-100 \mu \mathrm{AdC}\right)$ | $\mathrm{V}_{\mathrm{OH}}$ | +2.4 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Output High Voltage $\left(\mathrm{V}_{\mathrm{CC}}=\mathrm{min}\right)$ | $\mathrm{V}_{\text {cmos }}$ | $\mathrm{V}_{\text {cc }}-30 \%$ | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| $\begin{aligned} & \text { Output Low Voltage } \\ & \quad\left(V_{C C}=\min , I_{\text {LOAD }}=1.6 \mathrm{mAdc}\right) \end{aligned}$ | $\mathrm{V}_{\mathrm{OL}}$ | - | - | +0.4 | Vdc |
| Output High Current (Sourcing) $\left(\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{Vdc}\right)$ | $\mathrm{I}_{\mathrm{OH}}$ | -100 | - | - | $\mu \mathrm{Adc}$ |
| Output Low Current (Sinking) $\left(V_{\mathrm{OL}}=0.4 \mathrm{Vdc}\right)$ | IOL | 1.6 | - | $\square$ | mAdc |
| Darlington Current Drive, PE* $\left(\mathrm{V}_{\mathrm{OH}}=1.5 \mathrm{Vdc}\right.$ | IOH | -1.0 | - | - | mAdc |
| Output Low Current, PE* $\left(\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{Vdc}\right)$ | 1 OL | 1.6 | - | - | mAdc |
| Input Capacitance $\begin{aligned} & \left(V_{\text {in }}-0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right) \\ & \mathrm{PA}, \mathrm{~PB}, \mathrm{PC}, \mathrm{PF}^{*}, \mathrm{PG}^{*} \end{aligned}$ | $\mathrm{C}_{\text {in }}$ | - | - | 10 | pF |
| Output Capacitance $\left(V_{\text {in }}-0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$ | Cout | - | - | 10 | pF |
| I/O Port Resistance PAO-PA7, PC0-PC6 PF0-PF7, PG0-PG7 | $\mathrm{R}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | K $\Omega$ |
| Note: Negative sign indicates outward current flow, positive indicates inward flow. $\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm 5 \%$. |  |  |  |  |  |

## APPENDIX E <br> TIMING REQUIREMENTS AND CHARACTERISTICS

## E. 1 GENERAL NOTES

1. $V_{c c} 5 \mathrm{~V} \pm 5^{\circ}{ }_{\mathrm{o}}, 0 \mathrm{C} \leqslant \mathrm{TA} \leqslant 70 \mathrm{C}$
2. A valid $V_{c c}-$ RES sequence is required before proper operation is achieved.
3. All timing reference levels are 0.8 V and 2.0 V . unless otherwise specified
4. All time units are nanoseconds, unless otherwise specified
5. All capacitive loading is 130 pf maximum, except as noted below:

| PA, PB | -50 pf maximum |
| :--- | :--- |
| PB, PC (I/O Modes Only) | -50 pf maximum |
| PB, PC (ABB and Mux Mode) | $-\quad 130 \mathrm{pf}$ maximum |

## E. 2 CLOCK TIMING

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | Max | MIN | Max |
| $\mathrm{T}_{\text {cre }}$ | Cycle Time | 1000 | $10 \mu \mathrm{~s}$ | 500 | $10 \mu \mathrm{~s}$ |
| $\mathrm{T}_{\text {pwfo }}$ | CLKIN Input Clock Pulse Width | 475 | - | 240 | - |
| $T_{\text {pwoz }}$ | Output Clock Pulse Width at Minımum $T_{\text {cre }}$ | $\mathrm{T}_{\text {pwio }}$ | $\begin{aligned} & T_{\text {Pwoo }} \\ & +25 \end{aligned}$ | Tpwpo | $\begin{aligned} & \mathrm{T}_{\text {Pwfo }} \\ & +20 \end{aligned}$ |
| $\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}$ | Output Clock Rise. Fall Time | - | 25 | - | 15 |
| $\mathrm{T}_{\text {IR }} \mathrm{T}_{\text {IF }}$ | Input Clock Rise. <br> Fall Time | - | 10 | - | 10 |



## E. 3 ABBREVIATED MODE TIMING-PB AND PC

(MCR $5=1$, MCR $6=0$, MCR $7=1$ )

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| TPCRS | (PC5) R/W Setup Time | - | 225 | - | 140 |
| $\mathrm{T}_{\text {PCAS }}$ | (PC0-PC3) Address Setup Time | - | 225 | - | 140 |
| $\mathrm{T}_{\text {Pesu }}$ | (PB) Data Setup Time | 50 | - | 35 | - |
| $\mathrm{T}_{\text {P日нR }}$ | (PB) Data Read Hold Time | 10 | - | 10 | - |
| $\mathrm{T}_{\text {PBHW }}$ | (PB) Data Write Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {PBoD }}$ | (PB) Data Output Delay | - | 175 | - | 150 |
| $\mathrm{T}_{\text {PCHA }}$ | (PC0-PC3) Address Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {PCHR }}$ | (PC5) R/W Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {PCHV }}$ | (PC4) EMS Hold Time | 10 | - | 10 | - |
| Tpevp | (PC4) EMS Stabilization Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {ESV }}$ | EMS Setup Time | - | 350 | - | 210 |

NOTE 1: Values assume PCO-PC5 have the same capacitive load.

## E.3.1 Abbreviated Mode Timing Diagram



## R6500/41 and R6500/42

## E. 4 MULTIPLEXED MODE TIMING-PB AND PC

(MCR $5=1$, MCR $6=1$, MCR $7=1$ )

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $\mathrm{T}_{\text {PCAS }}$ | (PC5) R/W Setup Time | - | 225 | - | 140 |
| $\mathrm{T}_{\text {PCAS }}$ | (PC0-PC3) Address Setup Time | - | 225 | - | 140 |
| $\mathrm{T}_{\text {Peas }}$ | (PB) Address Setup Time | - | 225 | - | 140 |
| $\mathrm{T}_{\text {PBSU }}$ | (PB) Data Setup Time | 50 | - | 35 | - |
| $\mathrm{T}_{\text {PBHR }}$ | (PB) Data Read Hold Time | 10 | - | 10 | - |
| $\mathrm{T}_{\text {PGHW }}$ | (PB) Data Write Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {PboD }}$ | (PB) Data Output Delay | - | 175 | - | 150 |
| $\mathrm{T}_{\text {PCHA }}$ | (PCO-PC3) Address Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {PbHA }}$ | (PB) Address Hold Time | 0 | 100 | 0 | 80 |
| $\mathrm{T}_{\text {PCHR }}$ | (PC5) R/W Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {PCHV }}$ | (PC4) EMS Hold Time | 10 | - | 10 | - |
| $\mathrm{T}_{\text {PcVI }}{ }^{\text {(1) }}$ | (PC4) Address to EMS Delay Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {PCVP }}$ | (PC4) EMS Stabilization Time | 30 | - | 30 | - |
| Tesu | EMS Setup Time | - | 350 | - | 210 |

NOTE 1: Values assume PCO-PC5 have the same capacitive load.

## E.4.1 Multiplex Mode Timing Diagram



## E. 5 I/O, EDGE DETECT AND COUNTER TIMING

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $T_{\text {pow }}{ }^{(1)}$ <br> $T_{\text {смоз }}{ }^{\text {(1) }}$ <br> $T_{\text {poow }}$ | Internal Write to Peripheral Data Valid <br> PA, PC TTL <br> PA, PC CMOS <br> PB | - | $\begin{array}{r} 500 \\ 1000 \\ 175 \\ \hline \end{array}$ | - | $\begin{array}{r} 500 \\ 1000 \\ 150 \\ \hline \end{array}$ |
| $\left\lvert\, \begin{aligned} & T_{\text {Posu }} \\ & T_{\text {PoSU }} \end{aligned}\right.$ | Peripheral Data Setup Time PA, PC PB | $\begin{array}{r} 200 \\ 50 \\ \hline \end{array}$ | - | $\begin{array}{r} 200 \\ 50 \\ \hline \end{array}$ | - |
| $\begin{aligned} & T_{\text {PHA }} \\ & T_{\text {PHA }} \end{aligned}$ | Peripheral Data Hold Time PA, PC PB | $\begin{aligned} & 75 \\ & 10 \end{aligned}$ | - | $\begin{aligned} & 75 \\ & 10 \end{aligned}$ | - |
| $\mathrm{T}_{\text {EPW }}$ | PA0-PA1 Edge Detect Pulse Width | Tcrc | - | $\mathrm{T}_{\text {crc }}$ | - |
| $\begin{aligned} & T_{c p w} \\ & T_{c \mathrm{c}}{ }^{\prime \prime \prime} \end{aligned}$ | Counter <br> PA2 Input Pulse Width PA2 Output Delay | Tcrc <br> - | $500$ | $\xrightarrow{\text { Tcrc }}$ | $\overline{500}$ |

NOTE 1: Maximum Load Capacitance: 50pF Passive Pull-Up Required

## E.5.1 I/O, Edge Detect, Counter



# R65/41EB AND R65/41EAB BACKPACK EMULATORS 

## INTRODUCTION

The Rockwell R65/41EB and R65/41EAB Backpack Emulator is the PROM prototyping version of the 8-bit, masked-ROM R6500/41 one-chip microcomputer. Like the R6500/41, the backpack device is totally upward/downward compatible with all members of the R6500/41 family. It is designed to accept standard 5-volt, 24 -pin EPROMs or ROMs directly, in a socket on top of the Emulator. This packaging concept allows a standard EPROM to be easily removed, re-programmed, then reinserted as often as desired.

The backpack devices have the same pinouts as the maskedROM R6500/41 microcomputer. These 40 pins are functionally and operationally identical to the pins on the R6500/41. The R6500/41 Microcomputer Product Description (Rockwell Document No. 29651N38, Order No. 2135) includes a description of the interface signals and their functions. Whereas the maskedROM R6500/41 provides 1.5 K bytes of read-only memory, the R65/41EB will address 4.0 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

Backpack Emulator

| Part <br> Number | Memory <br> Capacity | Compatible <br> Memories | Temperature <br> Range and Speed |
| :---: | :---: | :---: | :---: |
| R65/41EB | $4 \mathrm{~K} \times 8$ | 2732 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| 1 MHz |  |  |  |
| R65/41EAB | $4 \mathrm{~K} \times 8$ | 2732 A | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| 2 MHz |  |  |  |

Support Products

| Part <br> Number | Description |
| :--- | :--- |
| S65-101 | SYSTEM 65 Microcomputer |
|  | Development System |
| M65-040 | PROM Programmer Module |
| M65-131 | $1-\mathrm{MHz}$ R6500/41 Personality Module |
| M65-132 | 2-MHz R6500/41 Personality Module |
| RDC-1001 | Rockwell Development Center |
| RDC-131 | $1 \mathrm{MHz} \mathrm{R6500/41} \mathrm{Personality} \mathrm{Set} \mathrm{(RDC)}$ |
| RDC-132 | 2 MHz R6500/41 Personality Set (RDC) |

## FEATURES

- PROM version of the R6500/41
- All Host bus features of R6500/41
- Completely pin compatible with R6500/41 single-chip microcomputers
- Profile approaches 40-pin DIP of R6500/41
- Accepts 5 volt, 24-pin industry-standard EPROMs -4K memories-2732, 2732A
- Use as prototyping tool or for low volume production
- 4 K bytes of memory capacity
- $64 \times 8$ static RAM
- Software compatibility with the R6500 family
- 23 bi-directional TTL compatible I/O lines
- 16 bit programmable counter/latch with four modes (interval timer, pulse generator, event counter, pulse width measurement)
- 7 interrupts (reset, two external edge sensitive, counter underflow, Host data received, Output data register full, Input data register empty).
- External time base
- Single +5 V power supply


R65/41EB-R65/41EAB Backpack Emulator

## CONFIGURATIONS

The Backpack Emulator is available in two different versions, to accommodate 1 MHz and 2 MHz speeds. Both versions provide 192 bytes of RAM and I/O, as well as 24 signals to support the external memory "backpack" socket.

External 4K memories with addresses of 000 to FFF, are upward translated to addresses F000 to FFFF when assembled to form the Backpack Emulator.

## EXTERNAL FREQUENCY REFERENCE

The external frequency reference is an output timing signal ф2. This is an internally synchronized $1 \times$ clock output suitable for external memory or peripheral interfacing.

## I/O PORT PULLUPS

The emulator devices have internal I/O port pullup resistors on ports $A$ and $C$. Port $B$ has tri-state drivers.

## PRODUCT SUPPORT

The Backpack Emulator is just one of the products that Rockwell offers to facilitate system and program development for the R6500/41.

The SYSTEM 65 Microcomputer Development System with R6500/41 Personality Module supports both hardware and software development. Complete in-circuit user emulation with the R6500/41 Personality Module allows total system test and evaluation. With the optional PROM Programmer, SYST,EM 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 1.5 K ROM of the R6500/41.

In addition to support products, Rockwell offers regularlyscheduled designer courses at regional-centers.


R65/41EB Interface Diagram

| $\overline{\mathrm{CS}}$ | ${ }^{\circ} 1$ |  | ${ }^{1} \mathrm{~s}$ | 24 s | $\mathrm{V}_{\text {cc }}$ | 40 |  | $\mathrm{V}_{\mathrm{cc}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| E ( $\overline{\mathrm{RD}})$ | 2 | A6 | 2s | 23s | -A8 | 39 |  | CLKIN |
| R/W (WR) | 3 | A5 | 3s | 22 s | -A9 | 38 |  | RES |
| RS (AO) | 4 | A4 | 4s | 21s | PA11 | 37 |  | PB7 |
| HDO | 5 | A3 | 5 s | 20 s | $\overline{O E}$ | 36 |  | PB6 |
| HD1 | 6 | A2 4 | 6s | 19s | PA10 | 35 | 仡 | PB5 |
| HD2 | 7 | A1 | 7s | 18s | उCE | 34 |  | PB4 |
| HD3 | 8 | a 0 | 8 s | 17 s | pD7 | 33 |  | PB3 |
| HD4 | 9 | DO | 9 s | 16s | D6 | 32 |  | PB2 |
| HD5 | 10 | D1 | 10s | 15s | D5 | 31 |  | PB1 |
| HD6 | 11 | D2 | 11s | 14s | PD | 30 |  | PB0 |
| HD7 | 12 | $\mathrm{v}_{\text {SS }} \mathrm{C}$ | 12s | 13s | po3 | 29 |  | PA7 |
| PCO | 13 |  |  |  |  | 28 |  | PA6 |
| PC1 | 14 |  | 24-PI | CKE |  | 27 |  | PA5 |
| PC2 | 15 |  |  |  |  | 26 |  | PA4 |
| PC3 | 16 |  |  |  |  | 25 |  | PA3 |
| PC4 | 17 |  |  |  |  | 24 |  | PA2 |
| PC5 | 18 |  |  |  |  | 23 |  | PA1 |
| PC6 | - 19 |  |  |  |  | 22 |  | PAO |
| \$2 | - 20 |  |  |  |  | 21 |  | $\mathrm{v}_{\text {ss }}$ |

Pin Configuration
(1) PIN 21 is $V_{C C}$ for R65/41EB or A11 for R65/41EB

BACKPACK MEMORY SIGNAL DESCRIPTION

| Signal Name | Pin No. | Description |
| :---: | :---: | :---: |
| D0-D7 | $\begin{aligned} & 9 \mathrm{~S}-11 \mathrm{~S}, \\ & 13 \mathrm{~S}-17 \mathrm{~S} \end{aligned}$ | Data Bus Lines. All instruction and data transfers take place on the data bus lines. The buffers driving the data bus lines have full 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. |
| A0-A9 | 15-8S, | Address Bus Lines. The address bus lines |
| A10, | 22S, 235 | are buffered by push/pull type drivers that |
| A11 | 19S, 21 S | can drive one standard TTL load. |
| $\overline{C E}$ | 185 | Chip Enable. |
| $\overline{O E}$ | 205 | Memory Enable Line. This signal provides the output enable for the memory to place information on the data bus lines. This signal is driven by the $R / W$ signal from the CPU and then inverted to form $\overline{\mathrm{OE}}$. This signal is driven by the inverted address line A11. The $\overline{O E}$ signal will be low for addresses greater than OFFF. |
| $\mathrm{V}_{\mathrm{cc}}$ | 24S | Main Power Supply +5 V . This pin is tied directly to pin 40 ( $\mathrm{V}_{\mathrm{cc}}$ ). |
| $\mathrm{V}_{\mathrm{ss}}$ | 12 S | Signal and Power Ground (zero volts). This pin is tied directly to pin $21\left(\mathrm{~V}_{\mathrm{SS}}\right)$. |

I/O AND INTERNAL REGISTER ADDRESSES

| Address | Read | Write |
| :---: | :---: | :---: |
| $\begin{array}{r} 001 \mathrm{~F} \\ 1 \mathrm{E} \\ 1 \mathrm{D} \\ 1 \mathrm{C} \end{array}$ | Host Status Flag Register <br> Input Data Register (IDR) | Host Status Flag Register <br> Output Data Register (ODR) |
| $\begin{aligned} & 1 B \\ & 1 A \\ & 19 \\ & 18 \end{aligned}$ | Lower Counter <br> Lower Counter \& Clear Flag (IFR5) Upper Counter | Lower Latch <br> Upper Latch/Transfer Latch to Counter \& Clear Flag (IFR5) Upper Latch |
| 17 16 15 14 | Mode Control Register | Mode Control Register |
| $\begin{aligned} & 13 \\ & 12 \\ & 11 \\ & 10 \end{aligned}$ | Interrupt Enable Register Interrupt Flag Register Read "FF" | Interrupt Enable Register <br> Clear Int Flag Bit |
| $\begin{gathered} 03 \text { thru } 0 F \\ 02 \\ 01 \\ 0000 \end{gathered}$ | $\begin{aligned} & \text { Port C } \\ & \text { Port B } \\ & \text { Port A } \end{aligned}$ | Port C <br> Port B <br> Port A |

## READ TIMING CHARACTERISTICS

| Sign | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\overline{O E}$ and $\overline{C E}$ setup time from CPU | Toes | - | 225 | - | 140 | ns |
| Address setup time from CPU | $\mathrm{T}_{\text {ADS }}$ | - | 225 | - | 140 | ns |
| Memory read access time | $\mathrm{T}_{\text {ACC }}$ | - | 700 | - | 315 | ns |
| Data set up time | $\mathrm{T}_{\text {DSU }}$ | 50 | - | 35 | - | ns |
| Data hold time-Read | $\mathrm{T}_{\mathrm{HR}}$ | 10 | - | 10 | - | ns |
| Address hold time | $\mathrm{T}_{\mathrm{HA}}$ | 30 | - | 30 | - | ns |
| $\overline{O E}$ and $\overline{C E}$ hold time | $\mathrm{T}_{\text {Hoe }}$ | 30 | - | 30 | - | ns |
| Cycle Time | T CrC | 1.0 | 10.0 | 0.5 | 10.0 | $\mu \mathrm{s}$ |

## READ TIMING WAVEFORMS



## ABBREVIATED BUS

MODE MEMORY MAP

## MULTIPLEXED BUS MODE MEMORY MAP



## ELECTRICAL CHARACTERISTICS

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Threshold Voltage D0-D7 | $\mathrm{V}_{\text {IHT }}$ | $\mathrm{V}_{\mathrm{ss}}+2.0$ | - | - | Vdc |
| Input Low Threshold Voltage D0-D7 | $V_{\text {ILT }}$ | - | - | $\mathrm{V}_{\text {ss }}+0.8$ | Vdc |
| 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)$ DO-D7 | $\mathrm{I}_{\text {TSI }}$ | - | - | $\pm 10$ | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { Output High Voltage } \\ & \quad\left(I_{\text {LOAD }}=100 \mu \mathrm{Adc}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}\right) \\ & \text { DO-D7, } \mathrm{AO}-\mathrm{A} 11, \mathrm{OE}, \mathrm{CE} \end{aligned}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\mathrm{V}_{\mathrm{ss}}+2.4$ | - | - | Vdc |
| $\begin{aligned} & \text { Output Low Voltage } \\ & \left(I_{\text {LOAD }}=1.6 \text { mAdc, } V_{C C}=4.75 \mathrm{~V}\right. \text { ) } \\ & \text { DO-D7, AO-A11, } \overline{O E}, \mathrm{CE} \end{aligned}$ | V OL | - | - | $\mathrm{V}_{\mathrm{ss}}+0.4$ | Vdc |
| Power Dissipation (less EPROM) | $\mathrm{P}_{\mathrm{D}}$ | - | 0.50 | - | W |
| Capacitance $\left(V_{i n}=0, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right)$ <br> D0-D7 (High Impedance State) Input Capacitance | C <br> $\mathrm{C}_{\text {out }}$ $\mathrm{C}_{\text {in }}$ | - | - | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | pF |
| I/O Port Pull-up Resistance | $\mathrm{R}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | kohm |



## R6541Q AND R6500/43

 INTELLIGENT PERIPHERAL CONTROLLERS
## SECTION 1 INTRODUCTION

### 1.1 FEATURES OF THE R6541Q \& R6500/43

- Directly compatible with 6500, 6800, 8080, and Z80 bus families
- Asynchronous Host interface that allows independent clock operation
- Input, Output and Status Registers for CPU/Host data transfer
- Status register for CPU/Host data transfer operations
- Interrupt or polled data interchange with Host
- Enhanced 6502 CPU
- Four new bit manipulation instructions
- Set Memory Bit (SMB)
- Reset Memory Bit (RMB)
- Branch on Bit Set (BBS)
- Branch on Bit Reset (BBR)
- Decimal and binary arithmetic modes
- 13 addressing modes
- True indexing
- 256-byte mask-programmable ROM*
- 64-byte static RAM
- 23 TTL-compatible I/O lines
- A 16-bit programmable counter/timer, with latch
- Pulse width measurement
- Pulse generation
- Interval timer
- Event counter
- Eight interrupts
- Two edge-sensitive lines; one positive, one negative
- Reset
- Counter Underflow
- Host data received
- Output Data Register full
- Input Data Register empty
- Non-maskable
- Multiplexed bus expandable to 4 K bytes of external memory
*R6541Q has no ROM.
- Unmultiplexed Address and Data buses for 4K of Peripheral I/O expansion
- $68 \%$ of the instructions are executed in less than $2 \mu \mathrm{~s}$ @ 2 MHz
- NMOS-3 silicon gate, depletion load technology
- Single +5 V power supply
- 64-pin QUIP


## NOTE

This document describes both the R6541Q and R6500/43. In the text, the terms IPC or device will be used when describing both parts. See Section 1.3 for a description of the options available for the R6500/13 and the fixed features of the R6541Q.

### 1.2 SUMMARY

The Rockwell R6541Q and R6500/43 One-Chip Intelligent Peripheral Controllers (IPC) are general purpose, programmable interface I/O devices designed for use with a variety of 8 -bit and 16 -bit microprocessor systems. They have an enhanced R6502 CPU, an optional 256 by 8 -bit ROM, 64 by 8 -bit RAM, three I/O ports with multiplexed special functions, a multi-function timer, and a full 4 K address and data buses all contained within a 64-pin Quad-in-line package.

In both versions, special interface registers allow these IPC devices to function as peripheral controllers for the 6500, $6800, \mathrm{Z80}, 8080$, and other 8 -bit or 16 -bit host microcomputer systems.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of computational power. These features make the device a leading candidate for IPC computer applications.

Rockwell supports development of the R6541Q and R6500/43 with the System 65 Microcomputer Development System and the R6500/* Family of Personality Modules. Complete in-circuit emulation with the R6500/* Family of Personality Modules allows total system test and evaluation.

This product description assumes that the reader is familiar with the R6502 CPU hardware and programming capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual (Document Order Number 201). A descrption of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Document Order Number 202).

### 1.3 CUSTOMER OPTIONS

The R6500/43 microcomputer is available with the following customer specified mask options.

- Option 1 with or without a 256 byte ROM
- Option 2 Reset Vector at FFFC or OFFC
- Option 3 Port A with or without internal pull-up resistors
- Option 4 Port C with or without internal pull-up resistors

All options should be specified on an R6500/43 order form.
The R6541Q has no customer specified mask options. It has the following characteristics.

- Without ROM
- Reset Vector at FFFC
- No internal pull-up resistors on any Port (PA or PC)


Figure 2-1. Interface Diagram


Figure 2-2. R6541Q \& R6500/43 Pin Out Designation (64 PIN QUIP)


Figure 2-3. R6541Q \& R6500/43 Dimensional Outline

# SECTION 2 <br> R6500/41 INTERFACE REQUIREMENTS 

This section describes the interface requirements for the Intelligent Peripheral Controller. Figure 2-1 is the Interface Diagram for the devices. Figure 2-2 shows the pin out configuration and Table 2-1 describes the function of each pin of the
devices. Figure 2-3 shows the mechanical dimensions of the devices. Section 5 describes the Host computer interface protocol and timing requirements.

Table 2-1. Pin Description

| SIGNAL NAME | PIN NO. R6541Q \& R6500/43 | DESCRIPTION | SIGNAL NAME | PIN No. R6541Q \& R6500/43 | DESCRIPTION |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CLKIN | 11 | Symmetrical square wave 100 KHz to 2 MHZ , TTL compatible input. | PB0-PB7 | 49-56 | 8 bit I/O port used for either input or output. Each line consists of an active transis- |
| $\phi 2$ | 24 | Output timing signal-This is an internally synchronized $1 \times$ clock output suitable for external memory or peripheral interfacing. |  |  | tor to $\mathrm{V}_{\mathrm{ss}}$ and an active pullup to $\mathrm{V}_{\mathrm{cc}}$. This port becomes a tri-state data bus, DO-D7, in the Abbreviated or Multiplexed Bus Mode. DO-D7 are multiplexed with address lines |
| $\overline{\text { RES }}$ | 57 | The reset input is used to initialize the device. Section 7 |  |  | A4-A11. in the Multiplexed Bus Mode. |
|  |  | describes the process and conditions of the RES procedure. | PC0-PC6 | $31-25$ | 7 bit I/O port used for either input or output. Each line consists of an active transis- |
| VCC | 64 | Power supply input ( +5 V ) |  |  | tor to $\mathrm{V}_{\text {ss }}$ and an optional |
| VSS | 32 | Signal and power ground (OV). |  |  | passive pull-up to $\mathrm{V}_{\mathrm{cc}}$. The pins PC0 to PC5 are multiplexed with address and |
| $\overline{\text { CS }}$ | 12 | Chip select pin for host interface. |  |  | control signals for use in abbreviated and multiplex |
| RS (A0) | 15 | Register select input pin used by the Host processor to indicate that information being written into the IPC is a data or command byte or to indi- |  |  | modes. PC6 is multiplexed with INT and is program selectable. In these two modes PCO-PC5 have active pullups. |
|  |  | cate that information being read from the IPC is a status or data byte. | AO-A11, A15 | $\begin{gathered} 7-1 \\ 63-58 \end{gathered}$ | Thirteen address lines used to address a complete 8 K external address space. |
| $E(\overline{R D})$ | 13 | Host timing control signal for data register write and read. | DB0-DB7 | 41-48 | Eight bidirectional data bus lines used to transmit data to and from external memory. |
| $\mathrm{R} / \overline{\mathrm{W}}(\overline{\mathrm{WR}})$ | 14 | Host timing control signal for data register write and read. | SYNC | 9 | and from external memory. <br> SYNC is a positive going sig- |
| HBO-HB7 | 16-23 | Data bus between Host and IPC data input and output registers. |  |  | nal for the full clock cycle whenever the CPU is performing an OP CODE fetch. |
| $\overline{\text { NMI }}$ | 8 | A negative going edge on the Non-Maskable Interrupt signal requests that a nonmaskable interrupt be generated with the CPU. | $R / \bar{W}$ | 10 | Controls the direction of data transfer between the CPU and the external 65 K address space. The signal is high when reading and low when writing. |
| PAO-PA7 | 33-40 | 8 bit I/O port used for either input or output. Each line consists of an active transistor to $\mathrm{V}_{\text {ss }}$ and an optional passive pull-up to $\mathrm{V}_{\mathrm{cc}}$. The two lower bits PA0 and PA1 also serve as edge detect inputs. PA2 is time shared with the 16 bit Counter Input or output pin, CNTR, and is mode selected. |  | . |  |

## SECTION 3 SYSTEM ARCHITECTURE

This section provides a functional description of the IPC device. Functionally, the device consists of a CPU, RAM and optional ROM memories, three parallel I/O ports (actually 23 I/O lines), counter/latch circuit, a mode control register, and an interrupt flag/enable dual register circuit. A block diagram of the system is shown in Figure 3-1.

## NOTE

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

### 3.1 CPU LOGIC

The internal CPU of the device is an enhanced R6502 configuration with an 8-bit Accumulator register, two 8-bit Index Registers ( X and Y ); an 8-bit Stack Pointer register, an ALU, a 16-bit Program Counter, and standard instruction register/ decode and internal timing control logic.

### 3.1.1 Accumulator

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

### 3.1.2 Index Registers

There are two 8 -bit index registers, X and Y . Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

### 3.1.3 Stack Pointer

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, or an internal $\overline{\mathrm{RQ}}$ interrupt. The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may only be accessed from the top. The address of a memory location is stored (or "pushed") onto the stack. Each time
data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1. Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus, and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 007F-0040. Normal usage calls for the initialization of the Stack Pointer at 007F.

### 3.1.4 Arithmetic and Logic Unit (ALU)

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

### 3.1.5 Program Counter

The 16-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter ( PCH ) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

### 3.1.6 Instruction Register and Instruction Decode

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register then decoded along with timing and interrupt signals to generate control signals for the various registers.

### 3.1.7 Timing Control

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is initialized each time an instruction fetch is executed and is advanced at the beginning of each low level of the Clock In pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.


Figure 3-1. R6541Q \& R6500/43 Block Diagram

### 3.1.8 Interrupt Logic

Interrupt logic controls the sequencing of three interrupts: $\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}$, and $\overline{\mathrm{IRQ}}$. $\overline{\mathrm{RQ}}$ is generated by any one of four conditions: Counter Overflow, Positive Edge Detect, Negative Edge Detect, and Input Data Register Full.

### 3.2 NEW INSTRUCTIONS

In addition to the standard 6502 instruction set, four instructions have been added to the devices to simplify operations that previously required a read/modify/write operation. In order for these instructions to be equally applicable to any I/O ports, with or without mixed input and output functions, the I/O ports have been designed to read the contents of the specified port data register during the Read cycle of the read/ modify/write operation, rather than I/O pins as in normal read cycles. The added instructions and their format are explained in the following subparagraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions.

### 3.2.1 Set Memory Bit (SMB m, Addr.)

This instruction sets to " 1 " one of the 8 -bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and 1 of 8 bits to be set. The second byte of the instruction designates address (00-FF) of the byte or I/O port to be operated upon.

### 3.2.2 Reset Memory Bit (RMB m, Addr.)

This instruction is the same operation and format as SMB instruction except a reset to " 0 " of the bit results.

### 3.2.3 Branch on Bit Set Relative (BBS m, Addr, DEST)

This instruction tests one of 8 bits designated by a three bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction is used to specify the 8 bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

### 3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST)

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

### 3.3 READ-ONLY-MEMORY (ROM)

The optional ROM consists of 256 bytes mask programmable memory with an address space from OFOO to OFFF. ROM locations FFFA through FFFF are assigned for interrupt vectors. The Reset vector can be optionally at OFFC or FFFC.

The R6541Q has no ROM and its reset vector is at FFFC.

### 3.4 RANDOM ACCESS MEMORY (RAM)

The RAM consists of 64 bytes of read/write memory with an assigned page zero address of 0040 through 007F.

### 3.5 SYSTEM CLOCK

The device functions with an external clock. It is fully asynchronous in reference to the Host computer timing. The device clock frequency equals the external clock frequency. It is also made available for any external device synchronization at pin $\varnothing 2$.

### 3.6 MODE CONTROL REGISTER (MCR)

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for the Counter, the 6500 or 8080 Bus Select, and the Interrupt (INT). Its setting determines the basic configuration of the device in any application. Initializing this register is one of the first actions of any software program. The Mode Control Register bit assignment is shown in Figure 3-2.

The use of Counter A Mode Select is shown in Section 6.
The use of the 6500/8080 Host Bus Select is shown in Section 6.

The use of Interrupt Select is shown in Section 4.5.
The use of Bus Mode Select is shown in Sections 4.4 and 4.5.


Figure 3-2. Mode Control Register Bit Allocations


Figure 3-3. Interrupt Enable and Flat Registers

Table 3-1. Interrupt Enable Signals

| Control Signal | Description |
| :---: | :---: |
| IER 0 | Positive Edge Detect, Interrupt Enablewhen this bit is true, a positive going signal on PAO will generate an $\overline{\mathrm{RQ}}$ and set the corresponding flag bit. |
| IER 1 | Negative Edge Detect Interrupt Enablewhen this bit is set to a " 1 " a negative going signal on PA1 will generate an $\overline{R Q}$ and set the corresponding flag bit. |
| IER 2 | Input Data Register Full Interrupt Ena-ble-setting this bit to a "1" allows an $\overline{\mathrm{IRQ}}$ to be generated each time the Host fills the IDR setting the IDFR bit. |
| IER 3 | Output Data Register Full Interrupt Ena-ble-when this bit is an interrupt request to the Host is generated each time the ODRF flag is set to a "1". (See External Interrupts, Paragraph 3.7.1). Reading the ODR clears INT-1 and ODRF flags. |
| IER 4 | Input Data Register Empty Interrupt En-able-when this is set to a " 1 " an interrupt is generated to the Host each time the IDR is read by the CPU. The interrupt occurs when the IDRF flag is cleared. INT-2 is cleared when the Host reads the status flag register. (See External Interrupts, Paragraph 3.7.1). |
| IER 5 | Counter Interrupt Enable-if enabled, an $\overline{\mathrm{IRQ}}$ is generated whenever the Counter overflows. |

### 3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)

An $\overline{\mathrm{IRQ}}$ interrupt request can be initiated by any or all of four possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple simultaneous interrupts will cause the $\overline{\mathrm{RQ}}$ interrupt request to remain active until all interrupting conditions have been serviced and cleared.

The Interrupt Flag Register contains the information that indicates which I/O or counter needs attention. The contents of the Interrupt Flag Register may be examined at any time by reading at address: 0011. Edge detect IFR bits may be cleared by executing a RMB instruction at address location 0010. The RMB X, (0010) instruction reads FF, modifies bit $X$ to a " 0 ", and writes the modified value at address location 0011. In this way IFR bits set to a " 1 " after the read cycle of a Read-Modify-Write instruction (such as RMB) are protected from being cleared. IFR bits 6 and 7 are indeterminate on a Read.

Each IFR bit has a corresponding bit in the Interrupt Enable Register which can be set to a " 1 " by writing a " 1 " in the respective bit position at location 0012. Individual IER bits may be cleared by writing a " 0 " in the respective bit position, or by $\overline{\mathrm{RES}}$. If set to a "1", an $\overline{\mathrm{IRQ}}$ will be generated when the corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 3-3 and the functions of each bit are explained in Table 3-1.

### 3.7.1 External Interrupts (INT)

An external interrupt $\overline{\mathrm{INT}}$ to the Host computer may be selected in two modes. (See Section 5 for information on the Host/Device interface).

## OUTPUT DATA REGISTER (ODR) FULL

When IER 3 of the Interrupt Enable Register is set to a "1", the device will assert the INT (PC6) line each time it loads the ODR. The ODRF flag of the Status Flag Register and the IFR 3 of the IFR will be set to a " 1 " indicating the ODR is full. The ODRF and IFR 3 flags are cleared and INT is negated when the Host processor reads the ODR.

## INPUT DATA REGISTER (IDR) EMPTY

When IER 4 of the Interrupt Enable Register is set to a " 1 ", the device will assert the $\overline{\mathrm{NT}}$ (PC6) line each time it reads the IDR. The IDRF flag of the Host Status Flag Register will be cleared and the IFR 4 flag of the IFR will be set to a "1" indicating the IDR has just been read by the device. The IFR 4 flag is cleared and $\overline{\mathrm{INT}}$ is negated when the Host processor reads the Host Status Flag Register. $\overline{\text { RES }}$ clears the IDR and sets the IFR4 flag to indicate the register is empty.

### 3.8 PROCESSOR STATUS REGISTER

The 8 -bit Processor Status Register, shown in Figure 3-4, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6502 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

### 3.8.1 Carry Bit (C)

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.
zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The R6502 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions; ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

### 3.8.3 Interrupt Disable Bit (I)

The Interrupt Disable Bit $(I)$ is used to control the servicing of an interrupt request (IRQ). If the I Bit is reset to logic 0 , the $\overline{\mathrm{IRQ}}$ signal will be serviced. If the bit is set to logic 1 , the $\overline{I R Q}$ signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( $\overline{\mathrm{RES}}$ ) or Non-Maskable Interrupt ( $\overline{\mathrm{NMI} \text { ) signal is detected. }}$

The I bit is cleared by the Clear Interrupt Mask Instruction (CLI) and is set by the Set Interrupt Mask Instruction (SEI). This bit may also be set by the BRK Instruction. The Return from Interrupt (RTI) and Pull Processor Status (PLP) instructions will also affect the I bit.

### 3.8.2 Zero Bit (Z)

The Zero Bit $(Z)$ is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to


Figure 3-4. Processor Status Register

### 3.8.4 Decimal Mode Bit (D)

The Decimal Mode Bit (D), is used to control the arithmetic mode of the CPU. When this bit is set to logic 1 , the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction will clear it. The PLP and RTI instructions also effect the Decimal Mode Bit.

## CAUTION

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application to the device. This bit must be initialized to the desired state by the user program or erroneous results may occur.

### 3.8.5 Break Blt (B)

The Break Bit $(B)$ is used to determine the condition which caused the $\overline{\mathrm{RQ}}$ service routine to be entered. If the $\overline{\mathrm{RQ}}$ service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1. If the $\overline{\mathrm{RQ}}$ routine was entered as the result of an $\overline{\mathrm{RQ}}$ signal being generated, the $B$ bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

### 3.8.6 Overflow Bit (V)

The Overflow Bit $(\mathrm{V})$ is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits $(-128 \leqslant n \leqslant 127)$.

This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction which may be used to sample interface devices, allows the overflow flag to reflect the condition of bit 6 in the sampled field. During a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instrction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions which affect the V flag are ADC, BIT, CLV, PLP, RTI and SBC.

### 3.8.7 Negative Bit ( N )

The Negative Bit ( N ) is used to indicate that the sign bit (bit 7), in the resulting value of a data movement or data arithmetic operation, is set to logic 1 . If the sign bit is set to logic 1 , the resulting value of the data movement or arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

# SECTION 4 PARALLEL INPUT/OUTPUT PORTS 

## INPUT/OUTPUT PORTS

The IPC device provides three ports (PA, PB, and PC). The 15 lines of PA and PC are completely bidirectional, that is, there is no line grouping or port association restrictions. The eight lines of Port B may be programmed as all inputs or all outputs. Port PC, however, may be multiplexed under program control with seven other signals. Six of these signals form an address and control bus for extended addressing. The seventh signal is multiplexed with an external interrupt output, $\overline{\mathrm{NT}}$. All eight Port B lines are tri-state to permit their use as a data bus during extended addressing modes.

Internal pull-up resistors (FET's with an impedance range of $3 \mathrm{~K} \leqslant \mathrm{Rpu} \leqslant 12 \mathrm{~K}$ ohm) may be provided on ports PA and/or PC. The R6541Q does not have these resistors.

The direction of the I/O lines are controlled by 8 -bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, which simplifies I/O handling. The I/O addresses are shown in Table 4-1. If a part is being used to emulate a R6500/42 the ports must be provided in external circuitry and addressed through locations 00040006.

Table 4-1. I/O Port Addresses
\(\left.\begin{array}{|c|c|}\hline PORT \& ADDRESS <br>
\hline A \& 0000 <br>
B \& 0001 <br>
C \& 0002 <br>
E <br>
F <br>

G\end{array}\right\}\) R6500/42 only | 0004 |
| :---: |
|  |

### 4.1 INPUTS

Inputs for Ports A and C, and also Ports F and G if emulating the R6500/42, are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to I/O input lines. A low ( $<0.8 \mathrm{~V}$ ) input signal will cause a logic 0 to be read when a read instruction is issued to the port register. A high
( $>2.0 \mathrm{~V}$ ) input will cause a logic 1 to be read. An $\overline{\mathrm{RES}}$ signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

Port B may be all inputs or all outputs. All inputs is selected by setting bits MCR6 and MCR7 of the Mode Control Register to a " 0 ".

The status of the input lines can be interrogated at any time by reading the I/O port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers.

Read/Modify/Write instructions can be used to modify the operation of PA, PB, PC, and also PF, \& PG of an emulated R6500/42. During the Read cycle of a Read/Modify/Write instruction the Port I/O register is read. For all other read instructions the port input lines are read. Read/Modify/Write instructions are: ASL, BBS, BBR, DEC, INC, LSR, RMB, ROL, ROR, and SMB.

### 4.2 OUTPUTS

Outputs for Ports A thru C, and emulated Ports E thru G of the R6500/42, are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( $>2.4 \mathrm{~V}$ ) output while a logic 0 will force a low ( $<0.4 \mathrm{~V}$ ) output. Port B also requires that MCR6 be set to a " 1 " and MCR7 be set to a " 0 ".

### 4.3 PORT A (PA)

Port A can be programmed via the Mode Control Register (MCR) as a standard parallel 8 -bit, bit independent, I/O port, or a counter I/O line. Table 4-2 tabulates the control and usage of Port $A$.

In addition to their normal I/O functions, PAO can detect positive going edges, and PA1 can detect negative going edges. An edge transition on these pins will set a corresponding status bit in the IFR and generate an interrupt request if the respective Interrupt Enable Bit is set. The maximum rate at which an edge can be detected is one-half the $\phi 2$ clock rate. Edge detection timing is shown in Section E.5.

Table 4-2. Port A Control \& Usage

| PAO-PA1 I/O |  | $\begin{gathered} \text { PA2 I/O } \\ \hline \text { MCR0 }=0 \\ \text { MCR1 }=0 \end{gathered}$ |  | PA2 COUNTER |  |  |  | PA3-PA7 I/O |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | $\begin{aligned} & \text { MCRO }=1 \\ & \text { MCR1 }=0 \end{aligned}$ |  | $\begin{aligned} & \text { MCR0 }=X \\ & \text { MCR1 }=1 \end{aligned}$ |  |  |  |
| SIGNAL |  | SIGNAL |  | SIGNAL |  | SIGNAL |  | SIGNAL |  |
| NAME | TYPE | NAME | TYPE | NAME | TYPE | NAME | TYPE | NAME | TYPE |
| $\begin{aligned} & \text { PAO (1) } \\ & \text { PA1(2) } \end{aligned}$ | $\begin{aligned} & 1 / 0 \\ & 1 / 0 \end{aligned}$ | PA2 | 1/0 | CNTR | OUTPUT | CNTR | INPUT (3) | PA3-PA7 | 1/0 |

[^13]
### 4.4 PORT B (PB)

Port B can be programmed as an I/O Port, an 8-bit tri-state data bus, or as a multiplexed bus. Mode selection for Port $B$ is made by the Mode Control Register (MCR). The Port B output drivers can be selected as tri-state output drivers by setting bit 7 of the MCR to 0 (zero) and bit 6 of the MCR to 1. An all inputs condition is created by setting both MCR6 and MCR7 to 0 (zero). Table 4-3 shows the necessary settings for the MCR to achieve the various modes for Port B. When Port $B$ is selected to operate in the Abbreviated Mode PB0-PB7 serves as data register bits D0-D7. When Port B is selected to operate in the Multiplexed Mode data bits DO through D7 are time multiplexed with address bits A4 through A11, respectively. Refer to the Memory Maps (Appendix B) for Abbreviated and Multiplexed memory assignments. See Appendix E. 3 through E. 5 for Port B timing.

### 4.5 PORT C (PC)

Port C can be programmed as an I/O port and in conjunction with Port B, as an abbreviated bus, or as a multiplexed bus. When used in the abbreviated or multiplexed bus modes, PCO-PC5 function as AO-A3, R/W, and EMS, respectively, as shown in Table 4-4. EMS (External Memory Select) is asserted (low) whenever the internal processor accesses memory area between 0080 and OFFF. (See Memory Map, Appendix C). The leading edge of EMS may be used to strobe the eight address lines multiplexed on Port $B$ in the Multiplexed Bus Mode. See Appendix E. 3 through E. 5 for Port C timing.

Table 4-3. Port B Control \& Usage

| R6541Q \& R6500/43 | I/O MODES |  |  |  | ABBREVIATED MODE |  | MULTIPLEXED MODE |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { MCR7 }=0 \\ & \text { MCR6 }=0 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=0 \\ & \text { MCR6 }=1 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=0 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=1 \end{aligned}$ |  |  |  |
|  | SIGNAL |  | SIGNAL |  | SIGNAL |  | PHASE 1 |  | PHASE 2 |  |
|  | NAME | TYPE <br> (1) | NAME | TYPE <br> (2) | NAME | TYPE <br> (3) | SIGNAL |  | SIGNAL |  |
|  |  |  |  |  |  |  | NAME | TYPE (2) | NAME | TYPE (3) |
| 49 | PB0 | INPUT | PB0 | OUTPUT | D0 | 1/0 | A4 | OUTPUT | D0 | I/O |
| 50 | PB1 | INPUT | PB1 | OUTPUT | D1 | 1/0 | A5 | OUTPUT | D1 | 1/0 |
| 51 | PB2 | INPUT | PB2 | OUTPUT | D2 | 1/0 | A6 | OUTPUT | D2 | 1/0 |
| 52 | PB3 | INPUT | PB3 | OUTPUT | D3 | 1/0 | A7 | OUTPUT | D3 | 1/0 |
| 53 | PB4 | INPUT | PB4 | OUTPUT | D4 | 1/0 | A8 | OUTPUT | D4 | 1/O |
| 54 | PB5 | INPUT | PB5 | OUTPUT | D5 | 1/0 | A9 | OUTPUT | D5 | 1/0 |
| 55 | PB6 | INPUT | PB6 | OUTPUT | D6 | 1/0 | A10 | OUTPUT | D6 | 1/0 |
| 56 | PB7 | INPUT | PB7 | OUTPUT | D7 | 1/0 | A11 | OUTPUT | D7 | 1/0 |

(1) TRI-STATE BUFFER IS IN HIGH IMPEDANCE MODE (2) TRI-STATE BUFFER IS IN ACTIVE MODE
(3) TRI-STATE BUFFER IS IN ACTIVE MODE ONLY DURING THE PHASE 2 PORTION OF A WRITE CYCLE

Table 4-4. Port C Control \& Usage

| R6541Q \& R6500/43 | I/O MODE |  | ABBREVIATED MODE |  | MULTIPLEXED MODE |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{aligned} & \text { MCR7 }=0 \\ & \text { MCR6 }=\mathrm{X} \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=0 \end{aligned}$ |  | $\begin{aligned} & \text { MCR7 }=1 \\ & \text { MCR6 }=1 \end{aligned}$ |  |
|  | SIGNAL |  | SIGNAL |  | SIGNAL |  |
| PIN \# | NAME | TYPE <br> (1) | NAME | TYPE <br> (2) | NAME | TYPE <br> (2) |
| 31 | PCO | 1/0 | AO | OUTPUT | A0 | OUTPUT |
| 30 | PC1 | 1/0 | A1 | OUTPUT | A1 | OUTPUT |
| 29 | PC2 | 1/0 | A2 | OUTPUT | A2 | OUTPUT |
| 28 | РС3 | 1/0 | A3 | OUTPUT | A3 | OUTPUT |
| 27 | PC4 | 1/0 | EMS | OUTPUT | EMS | OUTPUT |
| 26 | PC5 | 1/O | $\mathrm{R} / \mathrm{W}$ | OUTPUT | $\mathrm{R} / \bar{W}$ | OUTPUT |
| 25 | PC6* | 1/O | $\overline{1 T^{*}}$ | OUTPUT | $\overline{\text { INT*}}$ | OUTPUT |

(1) RESISTIVE PULL-UP, ACTIVE BUFFER PULL-DOWN $\quad$ *PC6 if MCR5 $=0$; $\overline{\text { INT }}$ if MCR5 $=1$
(2) ACTIVE BUFFER PULL-UP AND PULL-DOWN

### 4.7 BUS MODES

A special attribute of Port B and Port C is their capability to be configured via the Mode Control Register (see Section 3.6) into four different modes.

In the Port B All Inputs and Port B All Outputs modes the separate address and data bus are used. The difference lies in the direction of Port B-all inputs or all outputs. The receiving ports perform the normal I/O function. A15 is usually used as a chip select for external memory.

In the Abbreviated Bus Mode, the address and data lines can be used as above to emulate the R6500/41. Port B and Port $C$ are automatically transformed into an abbreviated address bus and control signals (Port C ) and a bidirectional data bus (Port B). 16 Peripheral addresses can be selected. In general usage, these 16 addresses would be distributed to several external I/O devices such as R6522 and R6520, etc., each of which may contain more than one unique address.

In the Multiplexed Bus Mode, the operation is similar to the Abbreviated Mode except that a full 4 K of external addresses are provided. Port C provides the lower addresses and control signals. Port B multiplexes functions. During the first half of the cycle it contains the remaining necessary 8 address bits for 4 K ; during the second half of the cycle it contains a bidirectional data bus. The address bits appearing on Port $B$ must be latched into an external holding register. The leading edge of EMS, which indicates that the bus function is active, may be used for this purpose.

Figures 4-1a thru 4-1d show the possible configurations of the four bus modes. Appendix C1 shows a memory map of the port as a function of the Bus Mode and further shows which addresses are active or inactive on each of the three possible buses.


Figure 4-1a.


Figure 4-1b.


Figure 4-1c.


Figure 4-1d.

[^14]
## SECTION 5 HOST INTERFACE BUS

Two way data transfers are performed between the IPC and the Host microprocessor by means of the Output Data Register and the Input Data Register. The Host can also write a command to the IDR and read from the Host Status Flag Register. Figure 5-1 shows the Host addressing matrix. A hardware interrupt procedure and a software polling procedure is available to control data traffic between the CPU and Host.

| RS $\left(A_{0}\right)$ | READ | WRITE |
| :---: | :--- | :--- |
| 1 | HOST <br> STATUS FLAG | COMMAND <br> INPUT |
| 0 | DATA REG <br> OUTPUT | DATA REG <br> INPUT |

Figure 5-1. Host Addressing Matrix

### 5.1 DATA REGISTERS

The device has an 8-bit Input Data Register (IDR) and an 8 -bit Output Data Register (ODR). The IDR serves as a temporary storage for commands and data from the Host to the device. When transferring data from the Host to the device, the following conditions are in effect:

- $\overline{\mathrm{CS}}$ is asserted
- RS (AO) indicates command input or data input.
- The contents of the host data bus (HBO-HB7) are copied into the IDR when the appropriate Host bus write signals are asserted.

The ODR serves as a temporary storage for data from the device to the Host. When the Host is reading data from the device, the following conditions are in effect:

- $\overline{\mathrm{CS}}$ is asserted
- RS (AO) input selects ODR or HSFR
- The contents of ODR or the Flag Register are placed on the host data bus (HBO-HB7) when the appropriate Host read signals are asserted.


### 5.2 HOST STATUS FLAG REGISTER

A Host Status Flag Register facilitates a software protocol that permits independent and uninterrupted flow of data asynchronously between the host computer and the device.

The Host Status Flag Register contains 8 flag bits that can be read at anytime by either the Host or the device. See Figure 5-2. General purpose flags F2 through F6 are serviced by the device in either read or write modes and monitored by the Host (Read Only).

Flag F1 can be read at anytime by either the host or the device. The F1 flag copies the AO (RS) input signal during any
host write data exchange. The device can write to the F1 flag at any time.

The ODRF (Output Data Register Full) flag is set each time the device writes to the Output Data Register. The setting of the ODRF sets the device Interrupt Status Register IFR3 flag. An Output Interrupt (INT) may be generated under program control by setting IER3 in the interrupt enable register. The ODRF flag is reset only by a hardware reset or by the host performing a read on the output data register. The ODRF flag is reset following the conclusion of any host output data register read. The resetting of the ODRF causes the reset of the IFR3 flag and thus the reset of the external interrupt (INT).

The IDRF (Input Data Register Full) flag is set following the conclusion of any host write data exchange. The setting of the IDRF causes IFR2 of the device status register to be set. An internal interrupt may be generated under program control by setting IER2 in the Interrupt Enable Register. The setting of IDRF also causes IFR4 to be reset. The IDRF resets during device read of the input data register. IFR2 sets and IFR4 resets following the reset of IDRF. IFR4 may generate an external output interrupt (INT, input buffer empty), under program control by setting IER4 in the interrupt enable register.

The Host Status Flag Register is cleared by the $\overline{\operatorname{RES}}$ input.


Figure 5-2. Host Status Flag Register Bit Allocation

### 5.3 HOST COMPUTER INTERFACE

The device will work with a variety of Host Computers. The HOST interface consists of a chip select, one address line, 2 control lines and an 8 bit three state data bus. Internal logic of the device, controlled by MCR4, configures, the address and two control lines to either a 6500 or 8080 operational methodology. The interface is completely asynchronous and will work with a Host Computer up to a 5 MHz bus transfer rate. The device clock input frequency need not be the same as the Host's. A mode control register is set to match the interface to that of the Host device as follows:

MCR4 $=0$ When MCR4 is set to a logic zero, the IPC is configured to operate on a 6502/6800 type host bus. In this mode, the E input is connected to the host transfer strobe (VMA or $\varnothing 2$ for 6800, $\emptyset 2$ for 6500 ) and the $R / \bar{W}$ input is connected to the host microprocessor R/W output line. Figure 5-3 and Table 5-1, together, specify the relevant timing for read and write cycles on this type of host bus.

Table 5-1. Host Interface
Timing Characteristics BSEL $=0$ (6500)

| CHARACTERISTICS <br> 1 AND 2 MHz | SYMBOL | MIN | MAX |
| :--- | :---: | :---: | :---: |
| CS, R/W, RS Setup Time | $t_{\mathrm{CS}}$ | 10 | - |
| Access Time | $\mathrm{t}_{\mathrm{DA}}$ | - | $90^{*}$ |
| Data Hold Time | $\mathrm{t}_{\text {DHR }}$ | 10 | - |
| Control Hold Time | $\mathrm{t}_{\mathrm{HC}}$ | 10 | - |
| Write Data Setup Time | $\mathrm{t}_{\text {WDS }}$ | 75 | - |
| Write Data Hold Time | $\mathrm{t}_{\text {DHW }}$ | 10 | - |
| Write Stroke Width | $\mathrm{t}_{\mathrm{WR}}$ | 75 | - |

*NOTE:
90 ns when loading $=130 \mathrm{pf}+1$ TTL LOAD and 75 ns when loading $=90 \mathrm{pf}+1 \mathrm{TTL}$ LOAD.

MCR4 = 1 When MCR4 is set to a logic one, the IPC is configured for operation on an 8080/Z80 type bus. In this mode, the $\overline{R D}$ input is used as a read strobe and the $\overline{W R}$ input is connected to the write strobe of the host microprocessor bus. Figure 5-4 and Table 5-2 show the relevant timing characteristics for this mode of operation.

Table 5-2. Host Interface Timing Characteristics BSEL $=1$ (8080)

| CHARACTERISTICS <br> 1 AND 2 MH | SYMBOL | MIN | MAX |
| :--- | :---: | :---: | :---: |
| CS, A0 Setup Time | $\mathrm{t}_{\mathrm{cs}}$ | 10 | - |
| Data Access Time on Read | $\mathrm{t}_{\mathrm{DA}}$ | - | $90^{\star}$ |
| Data Hold Time | $\mathrm{t}_{\mathrm{DHR}}$ | 10 | - |
| Control Hold Time | $\mathrm{t}_{\mathrm{HC}}$ | 10 | - |
| Write Data Setup Time | $\mathrm{t}_{\text {WDS }}$ | 75 | - |
| Write Data Hold Time | $\mathrm{t}_{\mathrm{DHW}}$ | 10 | - |
| Write Strobe Width | $\mathrm{t}_{\mathrm{WR}}$ | 75 | - |

*NOTE:
90 ns when loading $=130 \mathrm{pf}+1$ TTL LOAD and 75 ns when loading $=90 \mathrm{pf}+1$ TTL LOAD.


Figure 5-3. Timing Diagram—Host Interface (MCR4 = 0 ) ( $\mathbf{6 5 0 0}$ Version)


Figure 5-4. Timing Diagram-Host Interface (MCR4 = 1) (8080 Version)

## SECTION 6 COUNTER/TIMERS

The device contains a 16-bit counter and a 16-bit latch associated with it. The counter can be independently programmed to operate in one of four modes:

## Counter

- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Counter

Operating modes of the Counter are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA2 is selected for Counter I/O.

### 6.1 COUNTER

The Counter consists of a 16-bit counter and a 16-bit latch organized as follows: Lower Counter (LC), Upper Counter (UC), Lower Latch (LL), and Upper Latch (UL). The counter contains the count of either $\phi 2$ clock pulses or external events, depending on the counter mode selected. The contents of the Counter may be read any time by executing a read at location 0018 for the Upper Counter and at location 001A or location 0019 for the Lower Counter. A read at location 0019 also clears the Counter Underflow Flag (IFR5).

The 16-bit latch contains the counter initialization value, and can be loaded at any time by executing a write to the Upper Latch at location 0018 and the Lower Latch at location 001A. In either case, the contents of the accumulator are copied into the applicable latch register.

The Counter can be started at any time by writing to address 0019. The contents of the accumulator will be copied into the Upper Latch before the contents of the 16 -bit latch are transferred to the Counter. The counter is set to the latch value whenever the Counter underflows. When the Counter decrements from 0000 the next counter value will be the latch value, not FFFF, and the Counter Underflow Flag (IFR 5) will be set to " 1 ". This bit may be cleared by reading the Lower Counter at location 0019, by writing to address location 0019, or by $\overline{\text { RES }}$.

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

| MCR1 <br> (bit 1) | MCRO <br> (bit 0) | Mode |
| :---: | :---: | :--- |
| 0 | 0 | Interval Timer |
| 0 | 1 | Pulse Generation |
| 1 | 0 | Event Counter |
| 1 | 1 | Pulse Width Measurement |

The Interval Timer, Pulse Generation, and Pulse Width Measurement Modes are $\varnothing 2$ clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line (PA2).

The Counter is set to the Interval Timer Mode (00) when a $\overline{\mathrm{RES}}$ signal is generated.

### 6.1.1 Interval Timer Mode

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:

1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 0019, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the $\varnothing 2$ clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore $1 \mu$ s to 65.535 ms at the $1 \mathrm{MHz} \phi 2$ clock rate or $0.5 \mu \mathrm{~s}$ to 32.767 ms at the $2 \mathrm{MHz} \varnothing 2$ clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting $\overline{\mathrm{IRQ}}$ interrupt requests in the counter $\overline{\mathrm{RQ}}$ interrupt routine.

When the Counter decrements from 0000, the Counter Underflow (IFR5) is set to logic 1. If the Counter Interrupt Enable Bit (IER5) is also set, an $\overline{\mathrm{RQ}}$ interrupt request will be generated. The Counter Underflow bit in the Interrupt Flag Register can be examined in the $\overline{\mathrm{RQ}}$ interrupt routine to determine that the $\overline{\mathrm{RQ}}$ was generated by the Counter Underflow.

While the timer is operating in the Interval Timer Mode, PA2 operates as a PA I/O.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.


Figure 6-1. Interval Timer Timing Diagram

### 6.1.2 Pulse Generation Mode

In the Pulse Generation mode, the PA2 line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter Underflow occurs, or a write is performed to address 0019.

The normal output waveform is a symmetrical square-wave. The PA2 output is initialized high when entering the mode and transitions low when writing to 0019.

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

### 6.1.3 Event Counter Mode

In this mode PA2 is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be defected is one-half the $\varnothing 2$ clock rate.

The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter Underflow bit (IER5) is set to logic 1 if the underflow occurs.

Figure 6.2 is a timing diagram of the Event Counter Mode.


Figure 6-2. Event Counter Mode

### 6.1.4 Pulse Width Measurement Mode

This mode allows the accurate measurement of a low pulse duration on the PA2 line. The Counter decrements by one count at the $\varnothing 2$ clock rate as long as the PA2 line is held in the low state. The Counter is stopped when PA2 is in the high state.

The Counter underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the PA2 pin is held low. After the counter is stopped by a high level on PA2, the count will hold as long as PA2 remains high. Any further low levels on PA2 will again cause the counter to count down from its present value. The state of the PA2 line can be determined by testing the state of PA2.


## SECTION 7 <br> POWER ON/INITIALIZATION CONSIDERATIONS

### 7.1 POWER ON TIMING

After application of VCC power to the device, $\overline{\text { RES }}$ must be held low for at least eight stable $\varnothing 2$ clock cycles after $V_{c c}$ reaches operating range.

Figure 7-1 illustrates the power turn-on waveforms. External clock stabilization time is typically 20 ms .


Figure 7-1. Power Turn-On Timing Detail

### 7.2 POWER-ON RESET

The occurrence of $\overline{R E S}$ going from low to high will cause the device to set the Interrupt Mask Bit—bit 2 of the Processor Status Register-and initiate a reset vector fetch at address FFFC and FFFD to begin user program execution. All of the I/O ports will be initialized to the high (logic 1) state. All bits of the Control Register will be cleared causing the Interval Timer counter mode to be selected and causing all interrupt enabled bits to be reset.

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

When $\overline{\text { RES }}$ is driven from low to high the device is put in a reset state causing the registers and $I / O$ ports to be set as shown in Table 7-1.

Table 7-1. $\overline{R E S}$ Initialization of I/O Ports and Registers

|  | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| REGISTERS |  |  |  |  |  |  |  |  |
| Processor Status | - | - | - | - | - | 1 | - | - |
| Mode Control (MCR) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Int. Enable (IER) | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Int. Flag (IFR) | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| Host Status Flag | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Input Data | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Output Data | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  |  |  |  |  |  |  |  |  |
| PORTS | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PA Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PB Latch | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| PC Latch |  |  |  |  |  |  |  |  |

All RAM and other CPU registers will initialize in a random, nonrepeatable data pattern.

### 7.4 INITIALIZATION

Any initialization process for the device should include a $\overline{R E S}$ as indicated in the preceding paragraphs. After stabilization of the external clock (if a power on situation) an initialization routine should be executed to perform (as a minimum) the following functions:

1. The Stack Pointer should be set
2. Clear or Set Decimal Mode
3. Set or Clear Carry Flag
4. Set up Mode Controls and Counter as required
5. Clear Interrupts.

A typical initialization routine could be as follows:

| LDX | Load stack pointer starting address into |
| :--- | :--- |
|  | X Register |
| TXS | Transfer X Register value to Stack Pointer |
| CLD | Clear Decimal Mode |
| SEC | Set Carry Flag |
| $\ldots .$. | Set-up Mode Control, |
| $\ldots$. | Counter, special function |
| $\ldots$. | registers and Clear RAM as required |
| CLI | Clear Interrupts | X Register

TXS Transfer X Register value to Stack Pointer
CLD Clear Decimal Mode
SEC Set Carry Flag
. . . . Counter, special function
CLI Clear Interrupts

# APPENDIX A <br> EXPANDED R6502 INSTRUCTION SET 

This appendix contains a summary of the R6502 instruction set. For detailed information, consult the R6502 Microcomputer System Programming Manual, Document 29650 N30.

The four instructions notated with a * are added instructions for the IPC devices which are not part of the standard 6502 instruction set.

## A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE

| MNEMONIC | INSTRUCTION | MNEMONIC | INSTRUCTION |
| :---: | :---: | :---: | :---: |
| ADC | Add Memory to Accumulator with Carry | LDA | Load Accumulator with Memory |
| AND | "AND" Memory with Accumulator | LDX | Load Index $X$ with Memory |
| ASL | Shift Left One Bit (Memory or Accumulator) | LDY | Load Index Y with Memory |
|  |  | LSR | Shift One Bit Right (Memory or Accumulator) |
| *BBR | Branch on Bit Reset Relative |  |  |
| *BBS | Branch on Bit Set Relative |  |  |
| BCC | Branch on Carry Clear | NOP | No Operation |
| BCS | Branch on Carry Set |  |  |
| BEQ | Branch on Result Zero |  |  |
| BIT | Test Bits in Memory with Accumulator | ORA | "OR" Memory with Accumulator |
| BMI | Branch on Result Minus |  |  |
| BNE | Branch on Result not Zero |  |  |
| BPL | Branch on Result Plus | PHA | Push Accumulator on Stack |
| BRK | Force Break | PHP | Push Processor Status on Stack |
| BVC | Branch on Overflow Clear | PLA | Pull Accumulator from Stack |
| BVS | Branch on Overflow Set | PLP | Pull Processor Status from Stack |
| CLC | Clear Carry Flag | *RMB | Reset Memory Bit |
| CLD | Clear Decimal Mode | ROL | Rotate One Bit Left (Memory or |
| CLI | Clear Interrupt Disable Bit |  | Accumulator) |
| CLV | Clear Overflow Flag | ROR | Rotate One Bit Right (Memory or |
| CMP | Compare Memory and Accumulator |  | Accumulator) |
| CPX | Compare Memory and Index X | RTI | Return from Interrupt |
| CPY | Compare Memory and Index Y | RTS | Return from Subroutine |
| DEC | Decrement Memory by One | SBC | Subtract Memory from Accumulator with |
| DEX | Decrement Index $X$ by One |  | Borrow |
| DEY | Decrement Index Y by One | SEC | Set Carry Flag |
|  |  | SED | Set Decimal Mode |
|  |  | SEI | Set Interrupt Disable Status |
| EOR | "Exclusive-Or" Memory with | *SMB | Set Memory Bit |
|  | Accumulator | STA | Store Accumulator in Memory |
|  |  | STX | Store Index X in Memory |
|  |  | STY | Store Index Y in Memory |
| INC | Increment Memory by One |  |  |
| INX | Increment Index X by One |  |  |
| INY | Increment Index Y by One | TAX | Transfer Accumulator to Index X |
|  |  | TAY | Transfer Accumulator to Index Y |
|  |  | TSX | Transfer Stack Pointer to Index $X$ |
| JMP | Jump to New Location | TXA | Transfer Index X to Accumulator |
| JSR | Jump to New Location Saving Return | TXS | Transfer Index X to Stack Register |
|  | Address | TYA | Transter Index Y to Accumulator |



## A. 3 INSTRUCTION CODE MATRIX

| L | ${ }^{0}$ | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\Sigma$ | BRK Implied 17 | $\begin{gathered} \text { ORA } \\ \text { (IND, X) } \\ 2 \quad 6 \end{gathered}$ |  |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { ASL } \\ & \mathrm{ZP} \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { RMBO } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | PHP Implied 13 | $\begin{aligned} & \text { ORA } \\ & \text { IMM } \\ & 22 \end{aligned}$ | ASL Accum 12 |  |  | $\begin{aligned} & \text { ORA } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { ASL } \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{gathered} \text { BBRO } \\ \text { ZP } \\ 3 \quad 5^{* *} \end{gathered}$ | 0 |
| 1 | BPL <br> Relative <br> 2 2** | $\begin{aligned} & \text { ORA } \\ & \text { (IND), Y } \\ & 25^{*} \end{aligned}$ |  |  |  | $\begin{gathered} \hline \text { ORA } \\ \text { ZP, } X \\ 24 \\ \hline \end{gathered}$ | $\begin{gathered} \text { ASL } \\ \text { ZP, } X \\ 26 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{RMB1} \\ & \mathrm{ZP} \\ & 2 \quad 5 \\ & \hline \end{aligned}$ | CLC Implied 12 |  |  |  |  | ORA ABS, $X$ 3 4* |  | $\begin{gathered} \text { BBR1 } \\ \text { ZP } \\ 3 \quad 5^{\star *} \\ \hline \end{gathered}$ | 1 |
| 2 | JSR <br> Absolute <br> 3 | $\begin{gathered} \text { AND } \\ (\text { (ND, } X) \\ 2.6 \end{gathered}$ |  |  | $\begin{aligned} & \text { BIT } \\ & \mathrm{ZP} \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { AND } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{ROL} \\ & \mathrm{ZP} \\ & 2 \quad 5 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { RMB2 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | PLP Implied 14 | $\begin{aligned} & \hline \text { AND } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \hline \text { BIT } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \hline \text { AND } \\ & \text { ABS } \\ & 3 \quad 4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{ROL} \\ & \mathrm{ABS} \\ & 3 \quad 6 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { BBR2 } \\ \text { ZP } \\ 3 \quad 5^{* *} \\ \hline \end{gathered}$ | 2 |
| 3 | BMI <br> Relative <br> 2 2** | $\begin{gathered} \text { AND } \\ \text { (IND, Y) } \\ 25^{*} \end{gathered}$ |  |  |  | AND ZP, X 24 | $\begin{aligned} & \mathrm{ROL} \\ & \mathrm{ZP}, \mathrm{X} \\ & 26 \end{aligned}$ | $\begin{aligned} & \text { RMB3 } \\ & \mathrm{ZP} \\ & 2 \quad 5 \end{aligned}$ | $\begin{gathered} \text { SEC } \\ \text { Implied } \\ 12 \end{gathered}$ |  |  |  |  |  |  | $\begin{aligned} & \text { BBR3 } \\ & \text { ZP } 5^{* *} \end{aligned}$ | 3 |
| 4 | RTI <br> Implied <br> 16 | $\begin{gathered} \text { EOR } \\ \text { (IND, X) } \\ 266 \end{gathered}$ |  |  |  | $\begin{aligned} & \text { EOR } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { LSR } \\ & \text { ZP } \\ & 25 \end{aligned}$ | $\begin{aligned} & \text { RMB4 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | PHA Implied 13 | $\begin{aligned} & \text { EOR } \\ & \text { IMM } \\ & 22 \end{aligned}$ | LSR Accum 12 |  | JMP <br> ABS <br> 33 | $\begin{aligned} & \hline \text { EOR } \\ & \text { ABS } \\ & 3 \quad 4 \\ & \hline \end{aligned}$ | LSR ABS 36 | $\begin{array}{\|c\|} \hline \text { BBR4 } \\ \text { ZP } \\ 3 \mathrm{5} \end{array}$ | 4 |
| 5 | $\left.$BVC <br> Relative <br> 2 $2^{* *} \right\rvert\,$ | $\begin{aligned} & \text { EOR } \\ & \text { (IND), Y } \\ & 25^{*} \end{aligned}$ |  |  |  | $\begin{aligned} & \text { EOR } \\ & \text { ZP, } x \\ & 24 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { LSR } \\ & \text { ZP, } \mathrm{X} \\ & 26 \end{aligned}$ | $\begin{aligned} & \text { RMB5 } \\ & \text { ZP } \\ & 2 \quad 5 \\ & \hline \end{aligned}$ |  |  |  |  |  | $\begin{aligned} & \text { EOR } \\ & \text { ABS, } x \\ & 34^{*} \end{aligned}$ |  | $\begin{array}{\|c} \text { BBR5 } \\ \text { ZP } \\ 3 \quad 5^{* *} \end{array}$ | 5 |
| 6 | RTS Implied 16 | $\begin{gathered} \text { ADC } \\ \text { (IND, X) } \\ 266 \end{gathered}$ |  |  |  | $\begin{aligned} & \mathrm{ADC} \\ & \mathrm{ZP} \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { ROR } \\ & \text { ZP } \\ & 2 \quad 5 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { RMB6 } \\ \text { ZP } \\ 2 \quad 5 \end{gathered}$ | PLA Implied 14 | $\begin{aligned} & \hline \text { ADC } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ |  |  |  | $\begin{aligned} & \hline A D C \\ & A B S \\ & 3 \quad 4 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { ROR } \\ & \text { ABS } \\ & 3 \quad 6 \\ & \hline \end{aligned}$ | $\begin{gathered} \text { BBR6 } \\ \text { ZP } \\ 3 \quad 5 * * \end{gathered}$ | 6 |
| 7 | BVS Relative 2 2** | $\begin{gathered} \text { ADC } \\ \text { (IND, Y) } \\ 25^{*} \end{gathered}$ |  |  |  | ADC ZP, X <br> 24 | $\begin{aligned} & \text { ROR } \\ & \text { ZP, } \mathrm{X} \\ & 26 \end{aligned}$ | $\begin{aligned} & \text { RMB7 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ |  | $\begin{gathered} \text { ADC } \\ \text { ABS, } Y \\ 34^{*} \end{gathered}$ |  |  |  | $\begin{gathered} \text { ADC } \\ \text { ABS, } x \\ 34^{*} \end{gathered}$ |  | $\begin{aligned} & \text { BBR7 } \\ & \text { ZP }^{\text {2** }} \end{aligned}$ | 7 |
| 8 |  | $\begin{gathered} \text { STA } \\ \text { (IND, X) } \\ 266 \end{gathered}$ |  |  | $\begin{aligned} & \text { STY } \\ & \mathrm{ZP} \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { STA } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { STX } \\ & \text { ZP } \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { SMBO } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | DEY Implied 12 |  | TXA Implied 12 |  | $\begin{aligned} & \text { STY } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { STA } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { STX } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { BBSO } \\ & \mathrm{ZP}^{* *} \end{aligned}$ | 8 |
| 9 | BCC <br> Relative <br> 2 2** | $\begin{array}{\|c} \text { STA } \\ \text { (IND, Y) } \\ 2 \quad 6 \end{array}$ |  |  | $\begin{gathered} \text { STY } \\ \text { ZP, } \mathrm{X} \\ 24 \end{gathered}$ | $\begin{gathered} \text { STA } \\ \text { ZP, X } \\ 24 \\ \hline \end{gathered}$ | $\begin{gathered} \text { STX } \\ \text { ZP, Y } \\ 24 \end{gathered}$ | $\begin{aligned} & \text { SMB1 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | TYA Implied 12 |  <br> STA <br> ABS, $Y$ <br> 35 | TXS Implied 12 |  |  | $\begin{gathered} \text { STA } \\ \text { ABS, } x \\ 35 \end{gathered}$ |  | $\begin{aligned} & \text { BBS1 } \\ & \text { ZP } \\ & 3 \quad 5^{* *} \end{aligned}$ | 9 |
| A | $\begin{aligned} & \text { LDY } \\ & \text { IMM } \\ & 22 \end{aligned}$ | $\begin{gathered} \text { LDA } \\ (\text { IND, } \mathrm{X}) \\ 266 \end{gathered}$ | $\begin{aligned} & \hline \text { LDX } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & \text { LDY } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & \text { ZP } \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{array}{r} \text { LDX } \\ \text { ZP } \\ 2 \quad 3 \\ \hline \end{array}$ | $\begin{aligned} & \text { SMB2 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | TAY <br> Implied <br> 12 | $\begin{aligned} & \text { LDA } \\ & \text { IMM } \\ & 22 \end{aligned}$ | TAX Implied 12 |  | $\begin{aligned} & \text { LDY } \\ & \text { ABS } \end{aligned}$ $34$ | $\begin{aligned} & \text { LDA } \\ & \text { ABS } \end{aligned}$ $34$ | $\begin{aligned} & \text { LDX } \\ & \text { ABS } \end{aligned}$ $34$ | $\begin{aligned} & \text { BBS2 } \\ & 3 \text { ZP } \\ & 35^{* *} \end{aligned}$ | A |
| B | BCS <br> Relative <br> 2 2** | $\begin{gathered} \text { LDA } \\ \text { (IND), Y } \\ 25^{*} \end{gathered}$ |  |  | $\begin{aligned} & \text { LDY } \\ & \text { ZP, } \mathrm{X} \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { LDA } \\ & \text { ZP, } \mathrm{X} \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { LDX } \\ & \text { ZP, Y } \\ & 24 \end{aligned}$ | $\begin{aligned} & \text { SMB3 } \\ & Z P \\ & 2 \quad 5 \end{aligned}$ | CLV Implied 12 |  | TSX Implied 12 |  |  | $\begin{aligned} & \text { LDA } \\ & \text { ABS, } x \\ & 34^{*} \end{aligned}$ | $\begin{gathered} \text { LDX } \\ \text { ABS, } Y \\ 3 \quad 4^{*} \end{gathered}$ | $\begin{aligned} & \text { BBS3 } \\ & \text { ZP } \\ & 3 \text { 5** } \end{aligned}$ | B |
| C | $\begin{aligned} & \text { CPY } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & \text { (IND, X) } \\ & 266 \end{aligned}$ |  |  | $\begin{aligned} & \text { CPY } \\ & Z P \\ & 23 \end{aligned}$ | $\begin{aligned} & \text { CMP } \\ & 2 \mathrm{ZP} \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & 2 \mathrm{ZP} \\ & 2 \quad 5 \end{aligned}$ | $\begin{aligned} & \text { SMB4 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | INY Implied 12 | $\begin{aligned} & \text { CMP } \\ & \text { IMM } \\ & 22 \end{aligned}$ | $\begin{array}{\|c\|} \text { DEX } \\ \text { Implied } \end{array}$ $12$ |  | $\begin{aligned} & \text { CPY } \\ & \text { ABS } \end{aligned}$ $34$ | $\begin{aligned} & \text { CMP } \\ & \text { ABS } \\ & 34 \end{aligned}$ | $\begin{aligned} & \text { DEC } \\ & \text { ABS } \\ & 36 \end{aligned}$ | $\begin{aligned} & \text { BBS4 } \\ & 3^{\text {ZP }} 5^{* *} \end{aligned}$ | C |
| D | BNE <br> Relative <br> 2 $2^{* *}$. | $\begin{aligned} & \text { CMP } \\ & \text { (IND), Y } \\ & 25^{*} \end{aligned}$ |  |  |  | $\begin{gathered} \text { CMP } \\ \text { ZP, } \mathrm{X} \\ 2 \quad 4 \\ \hline \end{gathered}$ | $\begin{gathered} \text { DEC } \\ \text { ZP, } \mathrm{X} \\ 26 \end{gathered}$ | $\begin{aligned} & \text { SMB5 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ |  |  |  |  |  | $\begin{gathered} \text { CMP } \\ \text { ABS, } X \\ 34^{*} \end{gathered}$ |  | $\begin{aligned} & \text { BBS5 } \\ & 3^{\text {ZP }} 5^{* *} \end{aligned}$ | D |
| E | $\begin{aligned} & \text { CPX } \\ & \text { IMM } \\ & 22 \end{aligned}$ | $\begin{gathered} \text { SBC } \\ \text { (IND, X) } \\ 266 \end{gathered}$ |  |  | $\begin{aligned} & C P X \\ & Z P \\ & 2 \quad 3 \end{aligned}$ | $\begin{aligned} & \mathrm{SBC} \\ & \mathrm{ZP} \\ & 2 \quad 3 \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | $\begin{aligned} & \text { SMB6 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | INX Implied 12 | $\begin{aligned} & \text { SBC } \\ & \text { IMM } \\ & 2 \quad 2 \\ & \hline \end{aligned}$ |  |  | $\begin{aligned} & \text { CPX } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { SBC } \\ & \text { ABS } \\ & 3 \quad 4 \end{aligned}$ | $\begin{aligned} & \text { INC } \\ & \text { ABS } \\ & 3 \quad 6 \end{aligned}$ | $\begin{gathered} \text { BBS6 } \\ \text { ZP } \\ 35^{* *} \end{gathered}$ | E |
| F | $\left.$BEQ <br> Relative <br> 2 $2^{* *} \right\rvert\,$ | $\begin{gathered} \text { SBC } \\ \text { (IND), Y } \\ 25^{*} \end{gathered}$ |  |  |  | $\begin{gathered} \text { SBC } \\ \text { ZP, X } \\ 24 \end{gathered}$ | $\begin{gathered} \text { INC } \\ \text { ZP, } X \\ 26 \end{gathered}$ | $\begin{aligned} & \text { SMB7 } \\ & \text { ZP } \\ & 2 \quad 5 \end{aligned}$ | SED <br> Implied 12 | $\begin{array}{\|c\|} \hline \text { SBC } \\ \text { ABS, } Y \\ 3 \end{array} 4^{*} .$ |  |  |  | $\begin{aligned} & \text { SBC } \\ & \text { ABS, } X \\ & 34^{*} \end{aligned}$ | $\begin{gathered} \text { INC } \\ \text { ABS, } x \\ 37 \end{gathered}$ | $\begin{aligned} & \text { BBS7 } \\ & 3^{\text {ZP }} 5^{* *} \end{aligned}$ | F |
|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | A | B | C | D | E | F |  |
|  |  | 0 | $\frac{0}{\substack{\text { BRK } \\ \text { Implied } \\ 17}}$ |  | Code dressing truction | Mode ytes; | chine | cles |  |  |  |  | N if p N if b N if b | ge bound nch occu nch occu | dary is c urs to sa urs to diff | ossed me pa erent |  |

## APPENDIX B <br> KEY REGISTER SUMMARY

CPU Registers


Mode Control Register


Host Status Flag Register


| RS $\left(A_{0}\right)$ | READ | WRITE |
| :---: | :---: | :--- |
| 1 | HOST <br> STATUS FLAG | COMMAND <br> INPUT |
| 0 | DATA REG <br> OUTPUT | DATA REG <br> INPUT |

## APPENDIX C

## C. 1 MEMORY MAPS AND ADDRESS AND PIN ASSIGNMENTS



## C. 2 I/O AND INTERNAL REGISTER ADDRESSES

| ADDRESS | READ | WRITE |
| :---: | :---: | :---: |
| $\begin{array}{r} 001 \mathrm{~F} \\ 1 \mathrm{E} \\ 1 \mathrm{D} \\ 1 \mathrm{C} \end{array}$ | Host Status Fiag Register Input Data Register (IDR) | Host Status Flag Register Output Data Register (ODR) |
| $\begin{aligned} & 1 B \\ & 1 A \\ & 19 \\ & 18 \end{aligned}$ | Lower Counter <br> Lower Counter \& Clear Flag (IFR5) Upper Counter | Lower Latch <br> Upper Latch/Transfer Latch to Counter \& Clear Flag (IFR5) Upper Latch |
| $\begin{aligned} & 17 \\ & 16 \\ & 15 \\ & 14 \end{aligned}$ | Mode Control Register | Mode Control Register |
| $\begin{aligned} & 13 \\ & 12 \\ & 11 \\ & 10 \end{aligned}$ | Interrupt Enable Register Interrupt Flag Register Read "FF" | Interrupt Enable Register Clear Int Flag Bit |
| $\begin{aligned} & O F \\ & O E \\ & O D \\ & O C \end{aligned}$ | $\begin{aligned} & -- \\ & -- \\ & -- \end{aligned}$ |  |
| $\begin{aligned} & O B \\ & O A \\ & 09 \\ & 08 \end{aligned}$ |  | $\begin{aligned} & -- \\ & -- \\ & -- \end{aligned}$ |
| $\begin{aligned} & 07 \\ & 06 \\ & 05 \\ & 04 \end{aligned}$ | —— —— $— —$ |  |
| $\begin{aligned} & 03 \\ & 02 \\ & 01 \\ & 00 \end{aligned}$ | Port C <br> Port B <br> Port A | Port C Port B Port A |

## C. 3 MULTIPLE FUNCTION PIN ASSIGNMENTS

| PIN NUMBER  <br> R6541Q R6500/43 | I/O FUNCTION | ABBREVIATED PORT FUNCTION | MULTIPLEXED PORT FUNCTION |
| :---: | :---: | :---: | :---: |
| 31 | PC0 | AO | AO |
| 30 | PC 1 | A1 | A1 |
| 29 | PC2 | A2 | A2 |
| 28 | PC3 | A3 | A3 |
| 27 | PC4 | $\mathrm{R} / \overline{\mathrm{W}}$ | R/ $\bar{W}$ |
| 26 | PC5 | EMS | EMS |
| 25 | PC6/INT | PC6/INT | PC6/INT |
| 49 | PB0 | D0 | A4/D0 |
| 50 | PB1 | D1 | A5/D1 |
| 51 | PB2 | D2 | A6/D2 |
| 52 | PB3 | D3 | A7/D3 |
| 53 | PB4 | D4 | A8/D4 |
| 54 | PB5 | D5 | A9/D5 |
| 55 | PB6 | D6 | A10/D6 |
| 56 | PB7 | D7 | A11/D7 |

# APPENDIX D ELECTRICAL SPECIFICATIONS 

## Maximum Ratings

| RATING | SYMBOL | VALUE | UNIT |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{in}}$ | -0.3 to +7.0 | Vdc |
| Operating Temperature Range <br> Commercial | T | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $\mathrm{T}_{\text {sto }}$ | -65 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 ( $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 5 \% \mathrm{~V}_{\mathrm{ss}}=0$ )

| CHARACTERISTIC | SYMBOL | MIN | TYP | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipation (Outputs High) Commercial $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | $\mathrm{P}_{0}$ | - | 500 | - | mW |
| Input High Voltage (Normal Operating Levels) | $\mathrm{V}_{\text {IH }}$ | +2.0 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Input Low Voltage (Normal Operating Levels) | $\mathrm{V}_{1}$ | -0.3 | - | +0.8 | Vdc |
| Input Leakage Current $\mathrm{V}_{\mathrm{in}}=0 \text { to } 5.25 \mathrm{Vdc}$ | $\mathrm{I}_{\mathrm{IN}}$ | -10.0 |  | +10.0 | $\mu$ Adc |
| Input Low Current $\left(\mathrm{V}_{\mathrm{LL}}=0.4 \mathrm{Vdc}\right)$ |  |  | -1.0 | -1.6 | mAdc |
| Output High Voltage $\left(V_{\mathrm{cc}}=\min , I_{\text {Load }}=-100 \mu \mathrm{Adc}\right)$ | $\mathrm{V}_{\text {OH }}$ | +2.4 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Output High Voltage $\left(V_{c c}=\min \right)$ | $\mathrm{V}_{\text {смо }}$ | $\mathrm{V}_{\mathrm{cc}}-30 \%$ | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Output Low Voltage $\left(V_{\mathrm{cc}}=\mathrm{min}, \mathrm{I}_{\text {Load }}=1.6 \mathrm{mAdc}\right)$ | V oL | - | - | +0.4 | Vdc |
| Output High Current (Sourcing) $\left(\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{Vdc}\right)$ | $\mathrm{IOH}^{\text {I }}$ | -100 | - | - | $\mu \mathrm{Adc}$ |
| Output Low Current (Sinking) $\left(\mathrm{V}_{\mathrm{oL}}=0.4 \mathrm{Vdc}\right)$ | loi | 1.6 | - | - | mAdc |
| Darlington Current Drive, PE* $\left(\mathrm{V}_{\mathrm{OH}}=1.5 \mathrm{Vdc}\right)$ | $\mathrm{IOH}^{\text {H}}$ | -1.0 | - | - | mAdc |
| Output Low Current, PE* $\left(\mathrm{V}_{\mathrm{oL}}=0.4 \mathrm{Vdc}\right)$ | loL | 1.6 | - | - | mAdc |
| Input Capacitance $\left(\mathrm{V}_{\text {in }}-0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$ <br> $\mathrm{PA}, \mathrm{PB}, \mathrm{PC}, \mathrm{PF}^{*}, \mathrm{PG}^{*}$ | $\mathrm{C}_{\text {in }}$ | - | - | 10 | pF |
| Output Capacitance $\left(\mathrm{V}_{\text {in }}-0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right)$ | $\mathrm{C}_{\text {out }}$ | - | - | 10 | pF |
| I/O Port Resistance PAO-PA7, PC0-PC6 PFO-PF7, PG0-PG7 | $\mathrm{R}_{\mathrm{L}}$ | 3.0 | 6.0 | 11.5 | $K \Omega$ |

NOTE: Negative sign indicates outward current flow, positive indicates inward flow. $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 5 \%$ *R6500/42 only

## APPENDIX E TIMING REQUIREMENTS AND CHARACTERISTICS

## E. 1 GENERAL NOTES

1. $\mathrm{V}_{\mathrm{CC}} \quad 5 \mathrm{~V} \pm 5^{\circ}{ }_{0}, 0^{\circ} \mathrm{C} \leq \mathrm{T}_{\mathrm{A}} \leq 70^{\circ} \mathrm{C}$
2. A valid $V_{C C}-\overline{R E S}$ sequence is required before proper operation is achieved.
3. All timing reference levels are 0.8 V and 2.0 V , unless otherwise specified.
4. All time units are nanoseconds, unless otherwise specified.
5. All capacitive loading is 130 pF maximum, except as noted below:

$$
\begin{array}{ll}
\mathrm{PA}, \mathrm{~PB} & -50 \mathrm{pF} \text { maximum } \\
\mathrm{PB}, \mathrm{PC} \text { (I/O Modes Only) } & -50 \mathrm{pF} \text { maximum } \\
\text { PB, PC (ABB and Mux Mode) }-130 \mathrm{pF} \text { maximum }
\end{array}
$$

## E. 2 CLOCK TIMING

| Symbol | Parameter | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |
| $\mathrm{T}_{\mathrm{CYC}}$ | Cycle Time | 1000 | $10 \mu \mathrm{~s}$ | 500 | $10 \mu \mathrm{~s}$ |
| $\mathrm{T}_{\text {PW@O }}$ | CLKIN Input Clock Pulse Width | 475 | - | 240 | - |
| $\mathrm{T}_{\text {PW02 }}$ | Output Clock Pulse Width at Minimum $\mathrm{T}_{\mathrm{CYC}}$ | $\mathrm{T}_{\text {PWøO }}$ | $\begin{gathered} \mathrm{T}_{\text {PWoo }} \\ +25 \end{gathered}$ | $\mathrm{T}_{\text {PW@O }}$ | $\begin{gathered} T_{\text {Pwoo }} \\ +20 \end{gathered}$ |
| $T_{R}, T_{F}$ | Output Clock Rise, Fall Time | - | 25 | - | 15 |
| $\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}$ | Input Clock Rise, Fall Time | - | 10 | - | 10 |



## E. 3 ABBREVIATED MODE TIMING—PB AND PC

(MCR $5=1$, MCR $6=0$, MCR $7=1$ )

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $T_{\text {PCRS }}$ | (PC5) R/W Setup Time | - | 225 | - | 140 |
| $T_{\text {PCAS }}$ | (PC0-PC3) Address Setup Time | - | 225 | - | 140 |
| $T_{\text {PBSU }}$ | (PB) Data Setup Time | 50 | - | 35 | - |
| $T_{\text {PBHR }}$ | (PB) Data Read Hold Time | 10 | - | 10 | - |
| $T_{\text {pgiw }}$ | (PB) Data Write Hold Time | 30 | - | 30 | - |
| $T_{\text {PBDD }}$ | (PB) Data Output Delay | - | 175 | - | 150 |
| $T_{\text {PCHA }}$ | (PC0-PC3) Address Hold Time | 30 | - | 30 | - |
| $T_{\text {PCHR }}$ | (PC5) R/W Hold Time | 30 | - | 30 | - |
| $T_{\text {PCHV }}$ | (PC4) EMS Hold Time | 10 | - | 10 | - |
| TPCVP | (PC4) $\overline{E M S}$ Stabilization Time | 30 | - | 30 | - |
| Tesu | EMS Setup Time | - | 350 | - | 210 |
| NOTE 1: Values assume PC0-PC5 have the same capacitive load. |  |  |  |  |  |

## E.3.1 Abbreviated Mode Timing Diagram



## E. 4 MULTIPLEXED MODE TIMING-PB AND PC

$($ MCR $5=1$, MCR $6=1$, MCR $7=1)$

| SYMBOL | PARAMETER | $\mathbf{1}$ MHz |  | $\mathbf{2 ~ M H z ~}$ |  |
| :--- | :--- | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $T_{\text {PCRS }}$ | (PC5) R/W Setup Time | - | 225 | - | 140 |
| $T_{\text {PCAS }}$ | (PC0-PC3) Address Setup Time | - | 225 | - | 140 |
| $T_{\text {PBAS }}$ | (PB) Address Setup Time | - | 225 | - | 140 |
| $T_{\text {PBSU }}$ | (PB) Data Setup Time | 50 | - | 35 | - |
| $T_{\text {PBHR }}$ | (PB) Data Read Hold Time | 10 | - | 10 | - |
| $T_{\text {PBHW }}$ | (PB) Data Write Hold Time | 30 | - | 30 | - |
| $T_{\text {PBDD }}$ | (PB) Data Output Delay | - | 175 | - | 150 |
| $T_{\text {PCHA }}$ | (PC0-PC3) Address Hold Time | 30 | - | 30 | - |
| $T_{\text {PBHA }}$ | (PB) Address Hold Time | 0 | 100 | 0 | 80 |
| $T_{\text {PCHR }}$ | (PC5) R/W Hold Time | 30 | - | 30 | - |
| $T_{\text {PCHV }}$ | (PC4) EMS Hold Time | 10 | - | 10 | - |
| $T_{\text {PCVD }}{ }^{\text {(1) }}$ | (PC4) Address to EMS Delay Time | 30 | - | 30 | - |
| $T_{\text {PCVP }}$ | (PC4) EMS Stabilization Time | 30 | - | 30 | - |
| $T_{\text {ESU }}$ | EMS Setup Time | - | 350 | - | 210 |

NOTE 1: Values assume PC0-PC5 have the same capacitive load.

## E.4.1 Multiplex Mode Timing Diagram



## E. 5 I/O, EDGE DETECT AND COUNTER TIMING

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| $T_{\text {pow }}{ }^{(1)}$ <br> $\mathrm{T}_{\text {cmos }}{ }^{(1)}$ <br> $\mathrm{T}_{\text {Poow }}$ | Internal Write to Peripheral Data Valid <br> PA, PC TTL <br> PA, PC CMOS <br> PB | Z | $\begin{array}{r} 500 \\ 1000 \\ 175 \\ \hline \end{array}$ | - | $\begin{array}{r} 500 \\ 1000 \\ 150 \\ \hline \end{array}$ |
| $\begin{aligned} & T_{\text {Posu }} \\ & T_{\text {POSU }} \end{aligned}$ | Peripheral Data Setup Time PA, PC <br> PB | $\begin{array}{r} 200 \\ 50 \end{array}$ |  | $\begin{array}{r}200 \\ 50 \\ \hline\end{array}$ | - |
| $\left\lvert\, \begin{aligned} & T_{\text {PHA }} \\ & T_{\text {PHA }} \end{aligned}\right.$ | Peripheral Data Hold Time PA, PC PB | $\begin{aligned} & 75 \\ & 10 \end{aligned}$ | - | 75 10 | - |
| $\mathrm{T}_{\text {EPW }}$ | PA0-PA1 Edge Detect Pulse Width | Tcrc | - | $\mathrm{T}_{\mathrm{crc}}$ | - |
| $\begin{aligned} & T_{\text {cpw }} \\ & T_{c o}{ }^{(1)} \end{aligned}$ | Counter <br> PA2 Input Pulse Width PA2 Output Delay | $\mathrm{T}_{\mathrm{cyc}}$ | $\overline{500}$ | Trce | 500 |

NOTE 1: Maximum Load Capacitance: 50pF Passive Pull-Up Required

## E.5.1 I/O, Edge Detect, Counter.



## E. 6 MICROPROCESSOR TIMING (DO-D7, A0-A12, A15, SYNC, R/W)

| SYMBOL | PARAMETER | 1 MHz |  | 2 MHz |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIN | MAX | MIN | MAX |
| T ${ }_{\text {Rws }}$ | R/W Setup Time | - | 225 | - | 140 |
| $\mathrm{T}_{\text {ADS }}$ | A0-A12, A15 Setup Time | - | 150 | - | 75 |
| $\mathrm{T}_{\text {DSU }}$ | D0-D7 Data Setup Time | 50 | - | 35 | - |
| $T_{\text {HR }}$ | D0-D7 Read Hold Time | 10 | - | 10 | - |
| $\mathrm{T}_{\mathrm{HW}}$ | D0-D7 Write Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {MOS }}$ | D0-D7 Write Output Delay | - | 175 | - | 130 |
| $\mathrm{T}_{\text {SYM }}$ | SYNC Setup | - | 225 | - | 175 |
| $\mathrm{T}_{\mathrm{HA}}$ | A0-A12, A15 Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {HRW }}$ | R/W Hold Time | 30 | - | 30 | - |
| $\mathrm{T}_{\text {ACC }}$ | External Memory Access <br> Time $T_{A C C} \quad T_{c r c}-T_{f}-$ $T_{A O S}-T_{D S U}$ | - | $\mathrm{T}_{\mathrm{ACC}}$ | - | $\mathrm{T}_{\mathrm{ACC}}$ |
| $\mathrm{T}_{\text {SYH }}$ | SYNC Hold Time | 30 | - | 30 | - |

## E.6.1 Microprocessor Timing Diagram



## SECTION 4 MEMORY PRODUCTS

Page
Product Family Overview ..... 4-2
Masked ROMs
R2332A and R2332B 32K NMOS Static ROM ..... 4-3
R2364A 64K NMOS Static ROM ..... 4-7
R2364B 64K NMOS Static ROM ..... 4-11
R23C64 64K CMOS Static ROM ..... 4-15
R23128 128K NMOS Static ROM ..... 4-19
UV Erasable and One-Time PROMs
R27C64P 64K CMOS One-Time PROM ..... 4-23
R87C32 32K CMOS UV EPROM ..... 4-29
R87C64 64K CMOS UV EPROM ..... 4-35
EEROMs
R5213/2816 16K EEROM ..... 4-41
R52B33 64K Latched EEROM ..... 4-49
R2816A and R5516A 16K Latched EEPROM with Timer ..... 4-57
NVRAM
R2000 $64 \times 8$ Non-Volatile RAM ..... 4-65
EPROM Pinouts Guide ..... 4-71

## MEMORY PRODUCTS System ROM, Advanced CMOS and EEPROM

Multi-chip systems need memory. How much and what type is up to the designer. Some memory devices are high volume, low price products. Some are tougher to produce. Rockwell is as good as you can get at tough ROM, custom coded, made to order, 32K through 128K. So, when you're assembling a microprocessor based system, Rockwell can deliver it all, including ROM.

And, if you're working on a low power, high speed, system, Rockwell can supply CMOS ROM.

For systems needing low-power custom memory, we even offer CMOS UV EPROMs - ROM that can be electrically programmed and erased with ultraviolet light.

But Rockwell is also into some very new technology, with 5V EEPROMs. The new R5213 16K EEPROM has a

10 millisecond/byte erase/write time and unlimited read cycles. Each byte may be erased and written a minimum of 10,000 times, with a fast access time of less than 250 ns . And, there's more: the R2816A and R5516A, with on-chip timing and data latches. The R2816AH writes a byte in only 2 ms while the R5516A improves endurance to at least 1,000,000 write cycles/byte.

So, whatever your system need, Rockwell has the right ROM-NMOS, CMOS, UV EPROM and EEPROM.

Our multi- and single-chip microprocessor and microcomputers, 8 or 16 bit, are the most usable product line available today. And, to help make them even more usable, we also offer memory.

Rockwell Has The Right ROM For Your System

| Memory |  | Part No. | Product Description | Access Time (Nanoseconds) | Package |
| :---: | :---: | :---: | :---: | :---: | :---: |
| NMOS EEPROM | R2816A | $\begin{aligned} & -25 \\ & -3 \\ & -35 \end{aligned}$ | $16 \mathrm{~K}(2 \mathrm{~K} \times 8) 5 \mathrm{~V}$ Latched EEPROM with On-Board Timer <br> ( 10 ms Write Cycle)(2 ms Write Cycle ${ }^{3}$ ) <br> (10,000 Write Cycles/Byte) | $\begin{aligned} & -250 \\ & -300 \\ & -350 \end{aligned}$ | $\begin{aligned} & \text { 24-Pin } \\ & \text { CERDIP } \end{aligned}$ |
|  | R5213 | $\begin{aligned} & -25 \\ & -3 \\ & -35 \end{aligned}$ | $16 \mathrm{~K}(2 \mathrm{~K} \times 8) 5 \mathrm{~V}$ EEPROM | $\begin{aligned} & -250 \\ & -300 \\ & -350 \end{aligned}$ | 24-Pin CERDIP |
|  | R5516A | $\begin{aligned} & -25 \\ & -3 \\ & -35 \end{aligned}$ | $16 \mathrm{~K}(2 \mathrm{~K} \times 8) 5 \mathrm{~V}$ Latched EEPROM with On-Board Timer ( 10 ms Write Cycle) (1,000,000 Write Cycles/Byte) | $\begin{aligned} & -250 \\ & -300 \\ & -350 \end{aligned}$ | 24 Pin CERDIP |
|  | R52B33 | $\begin{aligned} & -2 \\ & -25 \\ & -3 \\ & -35 \\ & \hline \end{aligned}$ | $64 \mathrm{~K}(8 \mathrm{~K} \times 8) 5 \mathrm{~V}$ Latched EEPROM | $\begin{aligned} & -200 \\ & -250 \\ & -300 \\ & -350 \\ & \hline \end{aligned}$ | 24-Pin CERDIP |
| CMOS EPROM | R2716P | $\begin{aligned} & \hline-25 \\ & -350 \\ & \hline \end{aligned}$ | $64 \mathrm{~K}(8 \mathrm{~K} \times 8)$ One-Time PROM | $\begin{array}{r} -250 \\ -350 \\ \hline \end{array}$ | $28-\mathrm{Pin}$ <br> Plastic DIP |
|  | R87C32 | $\begin{aligned} & -35 \\ & -45 \\ & -55 \end{aligned}$ | $32 \mathrm{~K}(4 \mathrm{~K} \times 8) 5 \mathrm{~V}$ UV EPROM | $\begin{aligned} & -350 \\ & -450 \\ & -550 \end{aligned}$ | 24-Pin CERDIP |
|  | R87C64 | $\begin{aligned} & -2 \\ & -25 \\ & -35 \end{aligned}$ | $64 \mathrm{~K}(8 \mathrm{~K} \times 8) 5 \mathrm{~V}$ UV EPROM | $\begin{aligned} & -200 \\ & -250 \\ & -350 \end{aligned}$ | $28-P i n$ CERDIP |
| CMOS ROM | R23C64 | $\begin{aligned} & \text {-15P } \\ & -25 \mathrm{P},-25 \mathrm{PE} \\ & -3 \mathrm{P} \\ & -35 \mathrm{PE} \\ & \hline \end{aligned}$ | $64 \mathrm{~K}(8 \mathrm{~K} \times 8)$ Static ROM | $\begin{aligned} & -150 \\ & -250 \\ & -300 \\ & -350 \end{aligned}$ | $\begin{gathered} \text { 28-Pin } \\ \text { Plastic DIP1 } \end{gathered}$ |
| NMOS ROM | $\begin{gathered} \text { R2332A }^{2}-2 P \\ -25 P,-25 S P,-25 E P \\ -3 P,-3 S P,-3 E P \\ -P,-S P,-E P \end{gathered}$ |  | $32 \mathrm{~K}(4 \mathrm{~K} \times 8)$ Static ROM | $\begin{aligned} & -200 \\ & -250 \\ & -300 \\ & -450 \end{aligned}$ | 24-Pin <br> Plastic DIP ${ }^{1}$ |
|  | R2364A | $\begin{aligned} & -2 P \\ & -25 P \\ & -3 P,-3 S P,-3 E P \end{aligned}$ | $64 \mathrm{~K}(8 \mathrm{~K} \times 8)$ Static ROM | $\begin{aligned} & -200 \\ & -250 \\ & -300 \\ & \hline \end{aligned}$ | 24-Pin <br> Plastic DIP1 |
|  | R2364B | -3P, -3SP, -3EP | $64 \mathrm{~K}(8 \mathrm{~K} \times 8)$ Static ROM | -300 | $\begin{gathered} \text { 28-Pin } \\ \text { Plastic DIP1 } \end{gathered}$ |
|  | R23128 | $\begin{aligned} & \text {-25P, -25EP } \\ & -3 P,-3 E P \\ & \hline \end{aligned}$ | 128K (16K $\times 8$ ) Static ROM | $\begin{array}{r} -250 \\ -300 \\ \hline \end{array}$ | $\begin{gathered} \text { 28-Pin } \\ \text { Plastic DIP1 } \end{gathered}$ |
| NOTES:  LEGEND <br> 1. Also available in ceramic DIP. 3. R2816AH only. A $=$ T.I./Motorola JEDEC <br> 2. Also available in alternate 24-pin pinout (R2332B ). $S=$ Standby power |  |  |  | $E=E x t . T e m p .\left(-40^{\circ}\right.$ to $\left.85^{\circ} \mathrm{C}\right)$ |  |

## R2332A AND R2332B 32K ( $4 \mathrm{~K} \times 8$ ) STATIC ROM

## DESCRIPTION

The R2332A and R2332B ROMs are 32,768 -bit static ReadOnly Memories (ROMs), organized as 4,096 eight-bit bytes, that offer maximum access times of 200 to 450 nanoseconds, respectively. These ROMs are in industry-standard 24-pin, dual in-line packages, and are available in ceramic or low-cost plastic. These fully-static 32 K -bit ROMs are compatible with 8 -bit NMOS microprocessors, including the R6500 family of microprocessors.

All R2332A and R2332B ROMs operate totally asynchronously and require no clock input. These devices provide tri-state output buffers for memory expansion. These ROMs offer TTL input and output levels with a minimum noise immunity of 0.4 volts.
The mask-programmable chip enable input $(E / E)$ may be programmed to function as a chip select without power down standby mode or as a chip enable with power down standby mode. The active level of the enable input is also programmable.

## FEATURES

- $4,096 \times 8$ organization
- Access time: $200 \mathrm{~ns}, 250 \mathrm{~ns}, 300 \mathrm{~ns}$, and 450 ns (max.)
- Low power dissipation is 125 mW active, 37.5 mW standby
- Drives two TTL loads and 100 pF
- Single $+5 \mathrm{~V} \pm 10 \%$ power supply
- Totally static operation, no input clock required
- Completely TTL compatible
- Mask-programmable chip enable and chip select
- Tri-state outputs for memory expansion


## ORDERING INFORMATION




R2332A and R2332B Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | 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 |
| Output Voltage | $\mathrm{V}_{\text {OUT }}$ | -0.5 to +7.0 | Vdc |
| Temperature Under Bias <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | -10 to +80 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -65 to +95 |  |
| Power Dissipation | P | 1.0 | W |

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

DC CHARACTERISTICS $V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | Min | Typ | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | $V_{c c}$ | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.4 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=3.3 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 |  | 0.8 | V |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Load Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, 0 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant 5.5 \mathrm{~V}$ |
| $\mathrm{I}_{\text {L }}$ | Output Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, chip deselected, <br> $\mathrm{V}_{\text {OUT }}=+0.4 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| Icc | Power Supply Current, Active |  | 25 | 55 | mA |  |
| $I_{\text {SB }}$ | Power Supply Current, Standby ${ }^{1}$ |  | 7.5 | 16 | mA |  |
| $\mathrm{C}_{1}$ | Input Capacitance ${ }^{2}$ |  |  | 7 | 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}$, |
| $\mathrm{C}_{0}$ | Output Capacitance ${ }^{2}$ |  |  | 10 | pF |  |
| Notes: <br> 1. Applies only to chip enable with power down standby mode. <br> 2. This parameter is periodically sampled and is not $100 \%$ tested. |  |  |  |  |  |  |

AC CHARACTERISTICS $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | R2332-2 |  | R2332-25 |  | R2332-3 |  | R2332-45 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {avax }}$ | Address Valid to Address Don't Care | 200 |  | 250 |  | 300 |  | 450 |  | ns |
| $t_{\text {ELEH }}$ | Chip Enable Low to Chip Enable High ${ }^{2}$ | 200 |  | 250 |  | 300 |  | 450 |  | ns |
| $\mathrm{t}_{\text {AVQV }}$ | Address Valid to Output Valid ( $\mathrm{t}_{\text {ACC }}$ ) (Access) |  | 200 |  | 250 |  | 300 |  | 450 | ns |
| $t_{\text {ELaV }}$ | Chip Enable Low to Output Valid (Access) ${ }^{2}$ |  | 200 |  | 250 |  | 300 |  | 450 | ns |
| $\mathrm{t}_{\text {Avax }}$ | Address Valid to Output ( $\mathrm{t}_{\mathrm{OH}}$ ) Invalid | 10 |  | 10 |  | 10 |  | 10 |  | ns |
| $\mathrm{t}_{\text {ELQx }}$ | Chip Enable Low to Output ( $\mathrm{t}_{\mathrm{co}}$ ) Invalid | 10 |  | 10 |  | 10 |  | 10 |  | ns |
| $\mathrm{t}_{\text {EHQZ }}$ | Chip Enable High to Output High Z ( $\mathrm{t}_{\text {DF }}$ ) | 10 | $70^{4}$ | 10 | $70^{4}$ | 10 | $70^{4}$ | 10 | $70^{4}$ | ns |
| $\mathrm{t}_{\text {PU }}$ | Chip Selection to Power Up Time ${ }^{2}$ | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {PD }}$ | Chip Deselection to Power Down Time ${ }^{2}$ |  | 1004 |  | 1004 |  | 1004 |  | 1004 | ns |
| $\mathrm{t}_{\text {AVEL }}$ | Address Valid to Chip Enable Low | 0 |  | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {GLQV }}$ | Chip Select Low to Output Valid ${ }^{3}$ | 10 | $90^{4}$ | 10 | $90^{4}$ | 10 | $90^{4}$ | 10 | $90^{4}$ | ns |
| $\mathrm{t}_{\text {GHQZ }}$ | Chip Select High to Output High Z ${ }^{3}$ | 10 | $70^{4}$ | 10 | $70^{4}$ | 10 | $70^{4}$ | 10 | $70^{4}$ | ns |

## Notes:

1. Test Conditions:

Output Load: 2 TTL Loads and 100 pF ; Input Transition Time: 20 ns ; Timing Reference Levels: Input: 1.5V; Output: 0.8V, 2.0V.
2. Mask-programmed for chip enable with power down standby mode.
3. Mask-programmed for chip enable without power down standby mode.
4. Add 20 ns for extended temperature devices $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$.

TIMING DIAGRAMS
READ CYCLE TIMING 1


READ CYCLE TIMING 2


## TYPICAL CHARACTERISTICS

## SUPPLY CURRENT VS AMBIENT TEMPERATURE


$\mathbf{T}_{\mathrm{A}}$-Ambient Temperature- ${ }^{\circ} \mathbf{C}$

ACCESS TIME VS
AMBIENT TEMPERATURE


SUPPLY CURRENT VS SUPPLY VOLTAGE


## PACKAGE DIMENSIONS



## R2364A 64K ( $8 \mathrm{~K} \times 8$ ) STATIC ROM

## DESCRIPTION

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 industry-standard 24-pin, dual in-line packages, and are available in ceramic or low-cost plastic. These fully-static 64K-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 / E$ ) may be programmed to function as a chip select without power down standby mode or as a chip enable with power down standby mode. The active level of the enable input is also programmable.

## FEATURES

- $8,192 \times 8$ organization
- Access time: $200 \mathrm{~ns}, 250 \mathrm{~ns}$, and 300 ns (max.)
- Low power dissipation: 125 mW active, 37.5 mW standby
- Drives two TTL loads and 100 pf
- Single $+5 V \pm 10 \%$ power supply
- Totally static operation, no input clock required
- Completely TTL compatible
- Mask-programmable chip enable
- Tri-state outputs for memory expansion


## ORDERING INFORMATION




R2364A Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.5 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.5 to +7.0 | Vdc |
| Output Voltage | $\mathrm{V}_{\mathrm{OUT}}$ | -0.5 to +7.0 | Vdc |
| Temperature Under Bias <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | -10 to +80 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | P | 1.0 | W |

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

## DC CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | Min | Typ | Max | Units | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | $\mathrm{~V}_{\mathrm{CC}}$ | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.4 | V | $\mathrm{~V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=3.3 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.5 |  | 0.8 | V |  |
| $\mathrm{I}_{\mathrm{LI}}$ | Input Load Current |  |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}, 0 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{in}} \leqslant 5.5 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{LO}}$ | Output Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{Chip}$ Deselected, <br> $\mathrm{V}_{\mathrm{OUT}}=+0.4 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current, Active |  | 25 | 55 | mA | $\mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{SB}}$ | Power Supply Current, Standby ${ }^{1}$ |  | 7.5 | 16 | mA |  |
| $\mathrm{C}_{\mathrm{I}}$ | Input Capacitance ${ }^{2}$ |  |  | 7 | pF | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, chip deselected, pin <br> under test at $0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ <br> $\mathrm{f}=1 \mathrm{MHz}$ |

Notes:

1. Applies only to chip enable with power down standby mode.
2. This parameter is periodically sampled and is not $100 \%$ tested.

## AC CHARACTERISTICS

$V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | R2364A2 |  | R2364A25 |  | R2364A3 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $t_{\text {AVAX }}$ | Address Valid to Address Don't Care | 200 |  | 250 |  | 300 |  | ns |
| $t_{\text {ELEH }}$ | Chip Enable Low to Chip Enable High ${ }^{2}$ | 200 |  | 250 |  | 300 |  | ns |
| $\mathrm{t}_{\text {AVQV }}$ | Address Valid to Output Valid ( $\mathrm{t}_{\text {Acc }}$ ) (Access) |  | 200 |  | 250 |  | 300 | ns |
| $\mathrm{t}_{\text {ELQV }}$ | Chip Enable Low to Output Valid (Access) ${ }^{2}$ |  | 200 |  | 250 |  | 300 | ns |
| $\mathrm{t}_{\text {AVax }}$ | Address Valid to Output ( $\mathrm{t}_{\mathrm{OH}}$ ) Invalid | 10 |  | 10 | . | 10 |  | ns |
| $\mathrm{t}_{\text {ELQX }}$ | Chip Enable Low to Output ( $\mathrm{t}_{\mathrm{co}}$ ) Invalid | 10 |  | 10 |  | 10 |  | ns |
| $\mathrm{t}_{\text {EHQZ }}$ | Chip Enable High to Output High Z (t ${ }_{\text {DF }}$ ) | 10 | $70^{4}$ | 10 | $70^{4}$ | 10 | $70^{4}$ | ns |
| $t_{\text {PU }}$ | Chip Selection to Power Up Time ${ }^{2}$ | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {PD }}$ | Chip Deselection to Power Down Time ${ }^{2}$ |  | 1004 |  | 1004 |  | 1004 | ns |
| $t_{\text {AVEL }}$ | Address Valid to Chip Enable Low | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {GLQX }}$ | Chip Select Low to Output Invalid ${ }^{3}$ | 10 | $90^{4}$ | 10 | $90^{4}$ | 10 | $90^{4}$ | ns |
| $\mathrm{t}_{\text {GHQZ }}$ | Chip Select High to Output High Z | 10 | $70^{4}$ | 10 | $70^{4}$ | 10 | $70^{4}$ | ns |

## Notes:

1. Test Conditions:

Output Load: 2 TTL Loads and 100 pF ; Input Transition Time: 20 ns ; Timing Reference Levels: Input: 1.5 V , Output: 0.8 V , 2.0 V .
2. Mask-programmed for chip enable with power down standby mode.
3. Mask-programmed for chip enable without power down standby mode.
4. Add 20 ns for extended temperature devices $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$.

## TIMING DIAGRAMS

READ CYCLE TIMING 1 (E HELD LOW)


## TYPICAL CHARACTERISTICS

SUPPLY CURRENT VS AMBIENT TEMPERATURE


SUPPLY CURRENT VS SUPPLY VOLTAGE


ACCESS TIME VS AMBIENT TEMPERATURE


## PACKAGE DIMENSIONS



## R2364B <br> 64K ( $8 \mathrm{~K} \times 8$ ) STATIC ROM

## DESCRIPTION

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 64K-bit ROMs are compatible with all eight-bit N-channel microprocessors, including the R6500 family of microprocessors.
All three R2364B ROMs operate totally asynchronously, and require no clock input. Three mask-programmable chip select inputs allow up to eight 64 K 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 ( $\mathrm{E} / \overline{\mathrm{E}}$ ) may be programmed to function as a chip select without power down standby mode or as a chip enable with power down standby mode. The active level of the enable input is also programmable.

## FEATURES

- $8,192 \times 8$ organization
- Access time: $200 \mathrm{~ns}, 250 \mathrm{~ns}$ and 300 ns (max.)
- Low power dissipation: 125 mW active, 37.5 mW standby
- Drives two TTL loads and 100 pF
- Single $+5 \mathrm{~V} \pm 10 \%$ power supply
- Totally static operation, no input clock required
- Completely TTL compatible
- Three tri-state mask-programmable chip select inputs
- Mask-programmable chip enable
- Tri-state outputs for memory expansion


## ORDERING INFORMATION





## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.5 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.5 to +7.0 | Vdc |
| Output Voltage | $\mathrm{V}_{\mathrm{OUT}}$ | -0.5 to +7.0 | Vdc |
| Temperature Under Bias <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | -10 to +80 <br> -50 to +95 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | P | 1.0 | W |

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

## DC CHARACTERISTICS

$V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | Min | Typ | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{cc}}$ | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.4 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=3.3 \mathrm{~mA}$ |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{Cc}}$ | V |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.5 |  | 0.8 | V |  |
| $\mathrm{I}_{\mathrm{LI}}$ | 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}_{\mathrm{L}}$ | Output Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, chip deselected, <br> $\mathrm{V}_{\text {OUT }}=+0.4 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{cc}}$ | Power Supply Current, Active |  | 25 | 55 | mA | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$ |
| $\mathrm{I}_{\text {SB }}$ | Power Supply Current, Standby ${ }^{1}$ |  | 7.5 | 16 | mA |  |
| $\mathrm{C}_{1}$ | Input Capacitance ${ }^{2}$ |  |  | 7 | 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}$ |
| $\mathrm{C}_{0}$ | Output Capacitance ${ }^{2}$ |  |  | 10 | pF | $\mathrm{f}=1 \mathrm{MHz}$ |

Notes:

1. Applies only to chip enable with power down standby mode.
2. This parameter is periodically sampled and is not $100 \%$ tested.

## AC CHARACTERISTICS

$V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | R2364B2 |  | R2364B25 |  | R2364B3 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $t_{\text {AVAX }}$ | Address Valid to Address Don't Care | 200 |  | 250 |  | 300 |  | ns |
| $t_{\text {ELEH }}$ | Chip Enable Low to Chip Enable High ${ }^{2}$ | 200 |  | 250 |  | 300 |  | ns |
| $\mathrm{t}_{\text {AVQV }}$ | Address Valid to Output Valid ( $\mathrm{t}_{\text {ACC }}$ ) (Access) |  | 200 |  | 250 |  | 300 | ns |
| telav | Chip Enable Low to Output Valid (Access) ${ }^{2}$ |  | 200 |  | 250 |  | 300 | ns |
| $\mathrm{t}_{\text {AVQX }}$ | Address Valid to Output ( $\mathrm{tOH}^{\text {) }}$ Invalid | 10 |  | 10 |  | 10 |  | ns |
| $\mathrm{t}_{\text {ELQX }}$ | Chip Enable Low to Output ( $\mathrm{t}_{\mathrm{co}}$ ) Invalid | 10 |  | 10 |  | 10 |  | ns |
| $t_{\text {EHQZ }}$ | Chip Enable High to Output High Z (t ${ }_{\text {DF }}$ ) | 10 | $70^{4}$ | 10 | $70^{4}$ | 10 | $70^{4}$ | ns |
| $t_{\text {PU }}$ | Chip Selection to Power Up Time ${ }^{2}$ | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {PD }}$ | Chip Deselection to Power Down Time ${ }^{2}$ |  | 1004 |  | 1004 |  | 1004 | ns |
| $t_{\text {AVEL }}$ | Address Valid to Chip Enable Low | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {GLOV }}$ | Chip Select Low to Output Valid ${ }^{3}$ | 10 | $90^{4}$ | 10 | $90^{4}$ | 10 | $90^{4}$ | ns |
| $\mathrm{t}_{\text {GHQZ }}$ | Chip Select High to Output High Z | 10 | $70^{4}$ | 10 | $70^{4}$ | 10 | $70^{4}$ | ns |

## Notes:

1. Test Conditions:

Output Load: 2 TTL Loads and 100 pF ; Input Transition Time: 20 ns ; Timing Reference Levels: Input: 1.5 V ; Output: $0.8 \mathrm{~V}, 2.0 \mathrm{~V}$.
2. Mask programmed for chip enable with power down standby mode.
3. Mask programmed for chip enable without power down standby mode.
4. Add 20 ns for extended temperature devices $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$.
5. $\overline{\mathrm{G}}$ may be delayed up to $\mathrm{t}_{\text {Avov }}-\mathrm{t}_{\mathrm{Glov}}$ after the falling edge of $\overline{\mathrm{E}}$ without impact on $t_{\text {Avov. }}$. Data is available at the $Q$ outputs after a delay of $\mathrm{t}_{\mathrm{GLOv}}$ from the falling edge of $\overline{\mathrm{G}}$, provided that $\overline{\mathrm{E}}$ has been low $\left(V_{11}\right)$ and addresses have been valid for at least $t_{\text {Avov }}-t_{\text {GLOV }}$.
6. $\mathrm{t}_{G H O Z}$ and $\mathrm{t}_{\mathrm{EHQz}}$ are specified from $\overline{\mathrm{G}}$ or $\overline{\mathrm{E}}$, whichever occurs first.

TIMING DIAGRAMS


## TYPICAL CHARACTERISTICS

SUPPLY CURRENT VS
AMBIENT TEMPERATURE

$\mathrm{T}_{\mathrm{A}}$-Ambient Temperature- ${ }^{\circ} \mathrm{C}$

ACCESS TIME VS AMBIENT TEMPERATURE


SUPPLY CURRENT VS
SUPPLY VOLTAGE



## PRELIMINARY

## DESCRIPTION

The Rockwell R23C64 is an $8 \mathrm{~K} \times 8(65,536$ bits) CMOS static read-only-memory (ROM) housed in a 28 -pin JEDEC standard ( $B$ version) package. It is fabricated in CMOS technology to achieve high performance with extremely low power dissipation. This device is available with maximum access times of 150, 250, or 300 nanoseconds, optional extended temperature range, and packaged in ceramic or low-cost plastic.

The R23C64 is controlled via the chip enable ( $\bar{E}$ ) and the mask programmable chip selects ( $\mathrm{G} / \overline{\mathrm{G}} / \mathrm{N}, \mathrm{S} 1 / \overline{\mathrm{S} 1 / \mathrm{N}, \mathrm{S} 2 / \overline{\mathrm{S}} / \mathrm{N} \text { ). The } \text {. } 1 \text {. }}$ addresses are latched on the falling edge of $\bar{E}$, allowing the R23C64 to operate on multiplexed busses as well as nonmultiplexed buses. The chip selects control the output buffers, however, these buffers do not become active until valid data is present from the internal data latches. This prevents spurious, invalid outputs that increase power dissipation. When $\bar{E}$ is high, the output buffers are in the high impedance state and the address and chip select pins are ignored. $\bar{E}$ may also be held low indefinitely, keeping the address latched and the output buffers under chip select control.

## FEATURES

- $8,192 \times 8$ organization
- JEDEC approved pinout
- Extremely low power
-Active 10 mW (max.)
-Active (quiescent) $50 \mu \mathrm{~W}$
-Standby $50 \mu \mathrm{~W}$ (max.)
- Fast access times: $150 \mathrm{~ns}, 250 \mathrm{~ns}$ and 300 ns (max.)
- Mask programmable chip selects
- Latched addresses and (optional) latched chip selects
- Drive two TTL loads and 130 pF
- Single 5V $\pm 10 \%$ power supply
- Pin compatible with Rockwell R2364B NMOS ROMs and R87C64 and R2764 EPROMs


## ORDERING INFORMATION

| Part Number: R23C64 _ - - |  |
| :---: | :---: |
|  | LTemperature Range: $\begin{aligned} \text { No letter } & =0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\ E & =-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \end{aligned}$ <br> _Package: <br> C = Ceramic <br> $P=$ Plastic |
| Note: Submit ROM codes using Rockwell ROM Code Order Form, Order No. 2137. | $\begin{aligned} & \text { _Access Time (Max): } \\ & \begin{aligned} 15 & =150 \mathrm{~ns} \\ 25 & =250 \mathrm{~ns} \\ 3 & =300 \mathrm{~ns} \end{aligned} \end{aligned}$ |



R23C64 Block Diagram

*Mask-programmable option.
$N=$ No effect on selection logic, however, voltage greater than logic level shall not be applied.

ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :--- | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Output Voltage | $\mathrm{V}_{\text {OUT }}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Temperature Under Bias <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | -10 to +80 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | P | 1.0 | W |

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

## DC CHARACTERISTICS

$V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | Min | Typ | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{cc}}$ | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}+130 \mathrm{pF}$ |
| $V_{\text {OL }}$ | Output Low Voltage |  |  | 0.4 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}+130 \mathrm{pF}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.3 |  | 0.8 | $V$ |  |
| $I_{L I}$ | Input Load Current |  |  | $\pm 1$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, 0 \mathrm{~V} \leqslant \mathrm{~V}_{\mathrm{IN}} \leqslant 5.5 \mathrm{~V}$ |
| ILO | Output Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}$, chip deselected, <br> $\mathrm{V}_{\text {OUT }}=+0.4 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current, Active |  |  | $\begin{aligned} & 2 \\ & 1 \end{aligned}$ | $\begin{aligned} & \mathrm{mA} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{T}_{\mathrm{ELQV}}=150 \mathrm{~ns}^{1}, \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \\ & \mathrm{~T}_{\mathrm{ELQV}}=300 \mathrm{~ns}^{2}, \mathrm{~V}_{\mathrm{CC}}=5.5 \mathrm{~V} \end{aligned}$ |
| $I_{\text {SB }}$ | Power Supply Current, Standby |  |  | 10 | $\mu \mathrm{A}$ | $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{cc}}-0.5 \mathrm{~V}$; all other pins active |
| $\mathrm{C}_{1}$ | Input Capacitance (all but $\overline{\mathrm{E}}$ ) (E) |  | $\begin{array}{r} 5 \\ 10 \end{array}$ |  | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \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}$ |
| $\mathrm{C}_{0}$ | Output Capacitance ${ }^{3}$ |  | 10 |  | pF |  |
| Notes: <br> 1. $\mathrm{T}_{\text {ELEH }}=150 \mathrm{~ns}$, all pins active, no loads, $1 \mu \mathrm{sec}$ cycle time ( $\mathrm{T}_{\mathrm{ELEL}}=1 \mu \mathrm{~s}$ ). <br> 2. $\mathrm{T}_{\text {ELEH }}=300 \mathrm{~ns}$, all pins active, no loads, $2 \mu \mathrm{sec}$ cycle time ( $\mathrm{T}_{\text {ELEL }}=2 \mu \mathrm{~s}$ ). <br> 3. This parameter is periodically sampled and is not $100 \%$ tested. |  |  |  |  |  |  |

## AC CHARACTERISTICS

$V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

|  | Parameter | R23C64-15 |  | R23C64-25 |  | R23C64-3 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min | Max | Min | Max | Min | Max |  |
| $t_{\text {ELEL }}$ | Cycle Time | 220 |  | 365 |  | 465 |  | ns |
| $t_{\text {ELEH }}$ | Chip Enable Low to Chip Enable High | 150 |  | 250 |  | 300 |  | ns |
| $\mathrm{t}_{\text {EHEL }}$ | Chip Enable High to Chip Enable Low | 60 |  | 100 |  | 150 |  | ns |
| telqv | Chip Enable Low to Output Valid (Access) |  | 150 |  | 250 |  | 300 | ns |
| $t_{\text {AVEL }}$ | Address Setup Time | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {ELAX }}$ | Address Hold Time | 50 |  | 65 |  | 80 |  | ns |
| $t_{\text {GVQV }}$ | Chip Select Valid to Output Valid |  |  | 100 |  | 150 |  | ns |
| $\mathrm{t}_{\text {EHQZ }}{ }^{4}$ | Chip Enable High to Output High Z |  | 50 |  | 50 | 10 | 50 | ns |
| $\mathrm{t}_{\mathrm{GXQZ}}{ }^{4}$ | Chip Selects Invalid to Output High Z | 10 | 50 | 10 | 50 | 10 |  | ns |
| $\mathrm{t}_{\mathrm{F}}, \mathrm{t}_{\mathrm{R}}$ | Rise and Fall Times ${ }^{(2)}$ |  | 10 |  | 15 |  | 20 | ns |

## Notes:

1. Test Conditons: Output Load: 2 TTL Loads and 100 pF ; Input Transition Time: 20 ns ; Timing Reference Levels: Input: 1.5 V ; Output: $0.8 \mathrm{~V}, 2.0 \mathrm{~V}$.
2. Rise and Fall times stated are required for these high performance parameters only and may be relaxed to 100 ns for slower operation, e.g., 100 kHz operation.
3. $\bar{G}$ may be delayed up to $t_{A V Q V}-t_{G L Q v}$ after the falling edge of $\bar{E}$ without impact on $t_{A V Q V}$. Data is available at the $Q$ outputs after a delay of $t_{G L Q V}$ from the falling edge of $\bar{G}$, provided that $\bar{E}$ has been low $\left(V_{I L}\right)$ and addresses have been valid for at least $t_{A V Q V}-t_{G L Q V}$.
4. $\mathrm{t}_{\mathrm{EHQZ}}, \mathrm{t}_{\mathrm{GH} \mathrm{CZ}}$ are specified from $\overline{\mathrm{G}}$ or $\overline{\mathrm{E}}$ whichever occurs first.

## TIMING DIAGRAM




## R23128 128K (16K $\times 8$ ) STATIC ROM

## DESCRIPTION

The R23128-25 and R23128-3 are 131,072-bit static Read-Only Memories (ROMs), organized as 16,384 eight-bit bytes, that offer maximum access times of 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 128 K -bit ROMs are compatible with all N channel microprocessors.

The R23128 ROMs operate totally asynchronously, and require no clock input. Three mask-programmable chip select inputs allow up to eight 128 K ROMs to be OR-tied without external decoding. These devices provide tri-state output buffers for memory expansion. The R23128 ROMs offer TTL input and output levels with a minimum noise immunity of 0.4 volts.

The chip enable input ( $\overline{\mathrm{E}}$ ) functions as a chip enable with power down standby mode. When this line is high the chip is disabled and enters a low power standby state.

## FEATURES

- $16,384 \times 8$ organization bytes
- Access time: 250 ns and 300 ns (max.)
- Low typical power dissipation is 100 mW active, 20 mW standby
- Drives two TTL loads and 100 pF
- Single $+5 \mathrm{~V} \pm 10 \%$ power supply
- Totally static operation, no input clock required
- Completely TTL compatible
- Three mask-programmable chip select inputs
- Tri-state outputs for memory expansion


## ORDERING INFORMATION




C = Ceramic
$P=$ Plastic
emperature Range: $E=-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$

Not Sung Rock
ROM Code Order Fom
Order No. 2137 $3=300 \mathrm{~ns}$


*Mask-programmable option.
$N=$ no effect on selection/enable logic, however, voltage greater than logic levels shall not be applied.

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | 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 |
| Output Voltage | $\mathrm{V}_{\text {out }}$ | -0.5 to +7.0 | Vdc |
| Temperature under Bias <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ | -10 to +80 <br> -50 to +95 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\mathrm{STG}}$ | -65 to +150 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | 1.0 | W |

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

## DC CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | Min | Typ | Max | Units | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output HIGH Voltage | 2.4 |  | $\mathrm{V}_{\mathrm{Cc}}$ | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output LOW Voltage |  |  | 0.4 | V | $\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=3.3 \mathrm{~mA}$ |
| $\mathrm{V}_{1 \mathrm{H}}$ | Input HIGH Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{Cc}}$ | V |  |
| $\mathrm{V}_{\text {IL }}$ | Input LOW Voltage | -0.5 |  | 0.8 | V |  |
| $I_{L I}$ | 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}$ |
| ILO | Output Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \text { chip deselected } \\ & \mathrm{V}_{\text {out }}=+0.4 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{cc}} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC}}$ | Power Supply Current, Active |  | 20 | 55 | mA | $\mathrm{V}_{\mathrm{cc}}=5.5 \mathrm{~V}$ |
| $\mathrm{I}_{\text {SB }}$ | Power Supply Current, Standby |  | 7.5 | 16 | mA |  |
| C <br> $\mathrm{C}_{0}$ | Input Capacitance ${ }^{1}$ <br> Output Capacitance ${ }^{1}$ |  |  | $\begin{array}{r} 7 \\ 10 \end{array}$ | pF 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}$ $\mathrm{f}=1 \mathrm{MHz}$ |

Note:

1. This parameter is periodically sampled and is not $100 \%$ tested.

## AC CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | R23128-25 |  | R23128-3 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| $t_{\text {AVAX }}$ | Address Valid to Address Don't Care | 250 |  | 300 |  | ns |
| $t_{\text {ELEH }}$ | Chip Enable Low to Chip Enable High | 250 |  | 300 |  | ns |
| $\mathrm{t}_{\mathrm{AVQV}}$ | Address Valid to Output Valid ( $\mathrm{t}_{\text {ACC }}$ ) (Access) |  | 250 |  | 300 | ns |
| $t_{\text {ELQV }}$ | Chip Enable Low to Output Valid (Access) |  | 250 |  | 300 | ns |
| $\mathrm{t}_{\text {AVQX }}$ | Address Valid to Output ( $\mathrm{t}_{\mathrm{OH}}$ ) Invalid | 10 |  | 10 |  | ns |
| $\mathrm{t}_{\text {ELOX }}$ | Chip Enable Low to Output ( $\mathrm{t}_{\mathrm{co}}$ ) Invalid | 10 |  | 10 |  | ns |
| $\mathrm{t}_{\text {EHQZ }}$ | Chip Enable High to Output High Z ( $\mathrm{t}_{\mathrm{DF}}$ ) | 10 | 70 | 10 | 70 | ns |
| $t_{\text {PU }}$ | Chip Selection to Power Up Time | 0 |  | 0 |  | ns |
| $t_{\text {PD }}$ | Chip Deselection to Power Down Time |  | 100 |  | 100 | ns |
| $t_{\text {AVEL }}$ | Address Valid to Chip Enable Low | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\mathrm{GLQV}}$ | Chip Select Low to Output Valid | 10 | $90^{2}$ | 10 | $90^{2}$ | ns |
| $\mathrm{t}_{\text {GHQZ }}$ | Chip Select High to Output High Z | 10 | $70^{2}$ | 10 | $70^{2}$ | ns |
| Notes: <br> 1. Test Conditions: <br> 3. $\overline{\mathrm{G}}$ may be delayed up to $\mathrm{t}_{\mathrm{AVQV}}-\mathrm{t}_{\mathrm{GLQV}}$ after the falling edge of $\overline{\mathrm{E}}$ <br> Output load: 2 TTL loads and 100 pF <br> Input transition time: 20 ns delay of $t_{G L Q V}$ from the falling edge of $\bar{G}$, provided that $\bar{E}$ has been <br> Timing reference levels: Input: 1.5 V ; Output: $0.8 \mathrm{~V}, 2.0 \mathrm{~V}$ low $\left(\mathrm{V}_{\mathrm{IL}}\right)$ and addresses have been valid for at least $\mathrm{t}_{\mathrm{AVQV}}-\mathrm{t}_{\mathrm{GLQV}}$. <br> 2. Add 20 ns for extended temperature devices $\left(-40^{\circ} \mathrm{C}\right.$ to $\left.+85^{\circ} \mathrm{C}\right)$. <br> 4. $t_{G H Q Z}$ and $t_{E H Q Z}$ are specified from $\bar{G}$ or $\bar{E}$, whichever occurs first. |  |  |  |  |  |  |



## TYPICAL CHARACTERISTICS





# R27C64P <br> $64 \mathrm{~K}(8 \mathrm{~K} \times 8)$ CMOS ONE-TIME PROM 

## PRELIMINARY

## FEATURES

- $8,192 \times 8$ organization
- JEDEC approved pin-out
- Low Power
-Active 80 mW (max.)
-Standby $525 \mu \mathrm{~W}$ (max.)
- Access times: 250 ns and 350 ns (max.)
- Single 5V power supply
- Static operation, no clocks required
- One-time programmable
- TTL compatible inputs and tri-state outputs during both read and program mode
- Pin compatible with INTEL 2764A EPROM, Rockwell R87C64 EPROM and R23C64 and R2364B ROMs.


## ORDERING INFORMATION

R27C64P Block Diagram
Part Number: R27C64P $=$
Part Number: R27C64P $=$
L Access Time:
L Access Time:
$25=250 \mathrm{~ns}$
$25=250 \mathrm{~ns}$
$35=350 \mathrm{~ns}$
$35=350 \mathrm{~ns}$


## DESCRIPTION

The Rockwell R27C64P is an $8 \mathrm{~K} \times 8$ ( 65,536 bits) one-time programmable read-only-memory (PROM). It is manufactured using CMOS technology for low power dissipation in both active and standby operating modes. Access times of 250 ns and 350 ns is performance compatible with most 8 -bit and 16 -bit microprocessors.

Initially, all bits are in the "1" state. Data is programmed by applying 21 V to $V_{P P}$ a $T$ LL low to $\bar{E}$, and a 50 ms low pulse on $\bar{P}$ while the desired data is stable on Dq0-DQ7 lines and the address is stable on A0-A12 lines.

The R27C64P is ideal for low-cost permanent memory applications (program and/or data) in production runs requiring fast programming turn-around either at the factory, distributor/dealer or user's facility.


## R27C64P Pin Configuration:

| AO-A12 | ADDRESSES |
| :--- | :--- |
| $\overline{\mathbf{E}}$ | CHIP ENABLE |
| $\bar{G}$ | OUTPUT ENABLE |
| DQO-DQ7 | DATA INPUT/OUTPUT |
| $\bar{P}$ | PROGRAM ENABLE |

R27C64P Pin Names
Data Sheet Order No. MM18
March 1984

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{cc}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage <br> All, except Vpp during <br> Programming <br> Vpp during Programming | $\mathrm{V}_{\text {in }}$ | $\begin{aligned} & -0.3 \text { to } V_{c c}+0.3 \\ & -0.3 \text { to }+22.0 \end{aligned}$ | Vdc |
| Output Voltage | $\mathrm{V}_{\text {OUT }}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Temperature under Bias | $\mathrm{T}_{\mathrm{A}}$ | -10 to +80 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -40 to 125 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation (1) $25^{\circ}{ }^{\circ} \mathrm{C}$ | P | 1.0 | W |

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

## OPERATING CONDITIONS

| Parameter | Read Mode | Program Mode |
| :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ Supply Voltage | $5 \mathrm{~V} \pm 5 \%$ | $5 \mathrm{~V} \pm 5 \%$ |
| $\mathrm{~V}_{\mathrm{PP}}$ Supply Voltage |  | $21 \mathrm{~V} \pm 0.5 \mathrm{~V}$ |
| Temperature Range | 0 to $70^{\circ} \mathrm{C}$ | 0 to $70^{\circ} \mathrm{C}$ |

## DC OPERATING CHARACTERISTICS DURING READ

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

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage | - |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}+0.3$ | V |  |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $\mathrm{I}_{\mathrm{CC} 1}$ | $\mathrm{~V}_{\mathrm{CC}}$ Standby Current |  |  | 100 | $\mu \mathrm{~A}$ | $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{CC}}, \overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}, \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{CC} 2}$ | $\mathrm{~V}_{\mathrm{CC}}$ Active Current |  |  | 15 | mA | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{I}_{\mathrm{PP}}$ | $\mathrm{V}_{\mathrm{PP}}$ Current |  |  | 100 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}}$ max. |
| $\mathrm{I}_{\mathrm{IN}}$ | Input Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{O}}$ | Output Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{C}_{\mathrm{I}}$ | Input Capacitance ${ }^{2}$ |  |  | 7 | pF | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, chip deselected, pin under test <br> at $0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| $\mathrm{C}_{\mathrm{O}}$ | Output Capacitance ${ }^{2}$ |  |  |  | 10 | pF |
| $\mathrm{f}=1 \mathrm{MHz}$ |  |  |  |  |  |  |

## Notes:

1. Applies only to chip enable with power down standby mode.
2. This parameter is periodically sampled and is not $100 \%$ tested.

## DC OPERATING CHARACTERISTICS DURING PROGRAMMING

$V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=20^{\circ} \mathrm{C}$ to $30^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{PP}}=21.0 \mathrm{~V} \pm 0.5 \mathrm{~V}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}+0.3$ | V |  |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Active Current |  |  | 0.5 | mA |  |
| $\mathrm{I}_{\mathrm{PP}}$ | $\mathrm{V}_{\mathrm{PP}}$ Active Current |  | $\overline{\mathrm{F}}=\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IH}}$ |  |  |  |
| $\mathrm{I}_{\mathrm{IN}}$ | Input Leakage Current |  |  | 30 | mA |  |

## R27C64P <br> 64K (8K $\times 8$ ) CMOS ONE-TIME PROM

## PRELIMINARY

## FEATURES

- $8,192 \times 8$ organization
- JEDEC approved pin-out
- Low Power
-Active 80 mW (max.)
-Standby $525 \mu \mathrm{~W}$ (max.)
- Access times: 250 ns and 350 ns (max.)
- Single 5V power supply
- Static operation, no clocks required
- One-time programmable
- TTL compatible inputs and tri-state outputs during both read and program mode
- Pin compatible with INTEL 2764A EPROM, Rockwell R87C64 EPROM and R23C64 and R2364B ROMs.


## ORDERING INFORMATION



R27C64P Block Diagram

## DESCRIPTION

The Rockwell R27C64P is an $8 \mathrm{~K} \times 8(65,536$ bits) one-time programmable read-only-memory (PROM). It is manufactured using CMOS technology for low power dissipation in both active and standby operating modes. Access times of 250 ns and 350 ns is performance compatible with most 8 -bit and 16 -bit microprocessors.

Initially, all bits are in the "1" state. Data is programmed by applying 21 V to $V_{P P}$ a $T T L$ low to $\bar{E}$, and a 50 ms low pulse on $\overline{\mathbf{P}}$ while the desired data is stable on Dq0-DQ7 lines and the address is stable on A0-A12 lines.

The R27C64P is ideal for low-cost permanent memory applications (program and/or data) in production runs requiring fast programming turn-around either at the factory, distributor/dealer or user's facility.


R27C64P Pin Configuration

| A0-A12 | ADDRESSES |
| :--- | :--- |
| $\bar{E}$ | CHIP ENABLE |
| $\bar{G}$ | OUTPUT ENABLE |
| DQO-DQ7 | DATA INPUT/OUTPUT |
| $\bar{P}$ | PROGRAM ENABLE |

R27C64P Pin Names

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :---: | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\text {cc }}$ | -0.3 to +7.0 | Vdc |
| Input Voltage <br> All, except Vpp during Programming Vpp during Programming | $V_{\text {IN }}$ | $\begin{aligned} & -0.3 \text { to } V_{c c}+0.3 \\ & -0.3 \text { to }+22.0 \end{aligned}$ | Vdc |
| Output Voltage | $\mathrm{V}_{\text {OUT }}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Temperature under Bias | $\mathrm{T}_{\mathrm{A}}$ | -10 to +80 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -40 to 125 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation @ $25^{\circ} \mathrm{C}$ | P | - 1.0 | W |

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

## OPERATING CONDITIONS

| Parameter | Read Mode | Program Mode |
| :---: | :---: | :---: |
| $V_{\mathrm{CC}}$ Supply Voltage | $5 \mathrm{~V} \pm 5 \%$ | $5 \mathrm{~V} \pm 5 \%$ |
| $V_{\text {PP }}$ Supply Voltage |  | $21 \mathrm{~V} \pm 0.5 \mathrm{~V}$ |
| Temperature Range | 0 to $70^{\circ} \mathrm{C}$ | 0 to $70^{\circ} \mathrm{C}$ |

## DC OPERATING CHARACTERISTICS DURING READ

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

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | - |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{C C}+0.3$ | V | - .... |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $\mathrm{lcCl}_{1}$ | $\mathrm{V}_{\text {cc }}$ Standby Current |  |  | 100 | $\mu \mathrm{A}$ | $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{CC}}, \overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}, \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{ICC2}$ | $\mathrm{V}_{\mathrm{CC}}$ Active Current |  |  | 15 | mA | $\bar{E}=\bar{G}=V_{\mathrm{iL}}$ |
| $\mathrm{I}_{\text {Pp }}$ | $\mathrm{V}_{\text {PP }}$ Current |  |  | 100 | $\mu \mathrm{A}$ | $V_{P P}=V_{C C}$ max. |
| 1 N | Input Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=O \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| 10 | Output Leakage Current | , |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=O \mathrm{~V}$ to $\mathrm{V}_{\text {CC }}$ |
| $\mathrm{C}_{1}$ | Input Capacitance ${ }^{2}$ |  |  | 7 | pF | $\mathrm{V}_{C C}=5.0 \mathrm{~V}$, chip deselected, pin under test |
| $\mathrm{C}_{0}$ | Output Capacitance ${ }^{2}$ |  |  | 10 | pF | $\text { at } 0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ $f=1 \mathrm{MHz}$ |

Notes:

1. Applies only to chip enable with power down standby mode.
2. This parameter is periodically sampled and is not $100 \%$ tested.

## DC OPERATING CHARACTERISTICS DURING PROGRAMMING

$V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=20^{\circ} \mathrm{C}$ to $30^{\circ} \mathrm{C}, V_{P P}=21.0 \mathrm{~V} \pm 0.5 \mathrm{~V}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |  |
| $\mathrm{V}_{\mathrm{LL}}$ | Input Low Voltage | -0.1 |  | 0.8 | V | * |
| $\mathrm{I}_{\mathrm{CC}}$ | $V_{\text {cC }}$ Active Current |  |  | 0.5 | mA |  |
| Ipp. | $\mathrm{V}_{\mathrm{PP}}$ Active Current |  |  | 30 | mA | $V_{1 L}, \mathrm{G}=\mathrm{V}_{\mathrm{iH}}$ |
| $\mathrm{I}_{\mathrm{IN}}$ | Input Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |

## AC CHARACTERISTICS DURING READ

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

| Symbol | Parameter | R27C64P-25 |  |  | R27C64P-35 |  |  | Unit | Test Conditions ${ }^{(3)}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |  |
| $t_{\text {Avov }}$ | Address to Data Valid |  |  | 250 |  |  | 350 | ns | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=V_{\text {IL }}$ |
| telav | Chip Enable to Data Valid |  |  | 250 |  |  | 350 | ns | $\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{HL}}$ |
| $\mathrm{t}_{\text {GLov }}{ }^{1}$ | Output Enable to Data Valid | 10 |  | 100 | 10 |  | 120 | ns | $\overline{\mathrm{E}}=\mathrm{V}_{1 L}$ |
| $\mathrm{t}_{\mathrm{GHOZ}}{ }^{2}$ | Output Enable to High Impedance | 0 |  | 90 | 0 |  | 100 | ns | $\overline{\mathrm{E}}=\mathrm{V}_{1 L}$ |
| $\mathrm{t}_{\text {Axax }}$ | Address to Output Hold | 0 |  |  | 0 |  |  | ns | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{LL}}$ |
| $\mathrm{t}_{\text {EHQZ }}$ | Chip Enable to High Impedance | 0 |  | 90 | 0 |  | 100 | ns | $\overline{\mathrm{G}}=\mathrm{V}_{11}$ |

Notes:

1. $\bar{G}$ may be delayed up to $t_{A V Q V}$ - $t_{G L O V}$ after the falling edge of $\bar{E}$ without impact on $t_{A v a v}$. Data is available at the $D Q$ outputs after a delay of $t_{G L O V}$ from the falling edge of $\bar{G}$, provided that $\overline{\mathrm{E}}$ has been low $\left(\mathrm{V}_{\mathrm{IL}}\right)$ and addresses have been valid for at least $\mathrm{t}_{\mathrm{AVQV}}-\mathrm{t}_{\mathrm{GL}}$.
2. $\mathrm{t}_{\mathrm{GHOZ}}$ and $\mathrm{t}_{\mathrm{EHOZ}}$ are specified from $\overline{\mathrm{G}}$ or $\overline{\mathrm{E}}$, whichever occurs first.
3. Test Conditions:

Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$
Input Rise and Fall Times: $\leq 20$ ns
Input Pulse Levels: 0.45 V to 2.4 V
Timing Measurement Reference Level: Inputs 1 V and 2 V
Outputs 0.8 V and 2 V

READ TIMING DIAGRAM


## AC CHARACTERISTICS DURING PROGRAM

$V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=20^{\circ} \mathrm{C}$ to $30^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {AVPL }}$ | Address set-up time | 2 |  |  | $\mu \mathrm{S}$ |
| $t_{\text {dzGL }}$ | $\overline{\mathrm{G}}$ set-up time | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DVPL }}$ | Data set-up time | 2 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {ELPL }}$ | $\overline{\mathrm{E}}$ set-up time | 2 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {VHPL }}$ | $V_{\text {PP }}$ set-up time | 2 |  |  | $\mu \mathrm{S}$ |
| $t_{\text {PHDX }}$ | Data hold time | 2 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {GHAX }}$ | Address hold time | 0 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {GLQ }}$ | Output enable to data valid |  |  | 120 | ns |
| $\mathrm{t}_{\text {GHQ }}$ | Output disable to output high impedance | 0 |  | 100 | ns |
| $t_{\text {PLPH }}$ | $\overline{\mathrm{PE}}$ pulse width during programming | 45 | 50 | 55 | ms |

Notes:
Test Conditions:
Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$
Input Rise and Fall Times: $\leq 20 \mathrm{~ns}$
Input Puise Levels: 0.45 V to 2.4 V
Timing Measurement Reference Level: Inputs 1V and 2V
Outputs 0.8 V and 2 V

## PROGRAM TIMING DIAGRAM



## OPERATING MODES

The Rockwell R27C64P has five modes of operation (see table 1).

## Read Mode

The read mode is governed by two control pins, $\overline{\mathrm{E}}$ and $\overline{\mathrm{G}}$. In order to obtain data at the outputs, both $\bar{E}$ and $\bar{G}$ must be $V_{I L} . \overline{\bar{E}}$ is the power control and should be used for device selection. $\bar{G}$ is the output control and should be used to gate data to the output pins. Valid data will appear on the output pins after $T_{\text {AVQV }}$, $T_{E L Q V}$ or $T_{\text {GLQV }}$ times, depending on which is limiting.

## Standby Mode

The standby mode of the R27C64P reduces power dissipation. The R27C64P is placed in the standby mode by making $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{IH}}$. This is independent of $\overline{\mathrm{G}}$ and automatically puts the outputs in their high impedance (High-Z) state.

## Program Mode

The R27C64P is in the program mode when $\mathrm{V}_{\mathrm{PP}}$ is at 21 V with $\overline{\mathrm{E}}$ input at $\mathrm{V}_{\mathrm{IL}}$. The data to be programmed is applied to the data output pins. When the address controls and data are stable, a 50 msec program pulse is applied to the $\overline{\mathrm{P}}$ input.

## Program Verify Mode

A program verify should be performed on the programmed bits to determine that they were correctly programmed. The verify may be performed with $\mathrm{V}_{\mathrm{PP}}$ at 21 V . Data should be verified to $\mathrm{t}_{\mathrm{GLQV}}$ after the falling edge of $\overline{\mathrm{G}}$.

## Program Inhibit Mode

The program inhibit mode allows programming several R27C64P EPROMs simultaneously with different data for each by using $E$ to control which devices respond to the program pulse on $\bar{P}$.

Table 1. Mode Selection

| Mode ${ }^{\text {Pin }}$ | $\overline{\bar{E}} \underset{(20)}{ }$ | $\overline{\mathbf{G}}$ | $\begin{gathered} \overline{\mathbf{P}} \\ \mathbf{( 2 7 )} \end{gathered}$ | $\mathbf{V}_{\mathbf{P P}}$ <br> (1) | $\begin{aligned} & V_{c c} \\ & (28) \end{aligned}$ | $\begin{gathered} \text { DQ0-DQ7 } \\ (11-13,15-19) \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\text {iH }}$ | +5 | +5 | $Q_{\text {Out }}$ |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | No Effect | No Effect | +5 | +5 | High-Z |
| Program | $\mathrm{V}_{\text {IL }}$ | No Effect | $\mathrm{V}_{\text {IL }}$ | +21 | +5 | $\mathrm{D}_{\text {In }}$ |
| Program verify | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | +21 | +5 | $Q_{\text {OUt }}$ |
| Program inhibit | $\mathrm{V}_{\text {IH }}$ | No Effect | No Effect | +21 | +5 | High-Z |
| Program inhibit | No Effect | No Effect | $\mathrm{V}_{1 H}$ | +21 | +5 | High-Z |

## PACKAGE DIMENSIONS

## 28-PIN CERDIP



| DIM | MILLIMETERS |  | INCHES |  |
| :---: | ---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
| A | 36.32 | 37.34 | 1.430 | 1.470 |
| B | 12.95 | 13.46 | 0.510 | 0.530 |
| C | 3.68 | 4.19 | 0.145 | 0.165 |
| D | 0.41 | 0.51 | 0.016 | 0.020 |
| F | 1.27 | 1.52 | 0.050 |  |
| G | 2.54 BSC |  | 0.060 |  |
| J | 0.20 | 0.30 | 0.1008 |  |
| J | 0.20 | 0.30 | 0.008 | 0.012 |
| K | 3.18 | 4.19 | 0.125 | 0.165 |
| L | 16.13 | 17.41 | 0.635 | 0.685 |
| M | 15.24 | 15.75 | 0.600 | 0.620 |
| N | 0.89 | 1.14 | 0.035 | 0.045 |

NOTE: EITHER ROUND OR SQUARE UV WINDOW.

# R87C32 <br> 32K (4K x 8) CMOS UV EPROM 

## PRELIMINARY

## FEATURES

- $4096 \times 8$ organization
- JEDEC approved pin-out
- Low Power
-Active: 132 mW (max.)
-Standby: $525 \mu \mathrm{~W}$ (max.)
- Access times: $350 \mathrm{~ns}, 450$ ns and 550 ns (max.)
- Single 5V power supply
- Static operation, no clocks required
- Inputs and tri-state outputs TTL compatible during both read and program mode
- Pin compatible with INTEL 2732A EPROM and Rockwell R2332B ROM.

ORDERING INFORMATION


R87C32 Block Diagram

## DESCRIPTION

The Rockwell R87C32 is a $4 \mathrm{~K} \times 8(32,768$ bits) ultraviolet (UV) light erasable programmable read-only-memory (EPROM). It is manufactured using CMOS technology for low power dissipation in both active and standby operating modes. Single 5V operation allows simple circuit design in runtime environments.

Initially, all bits are in the " 1 " state. Programming is performed by applying 21 V to $\overline{\mathrm{G}} / \mathrm{Vpp}$ and a 50 ms low level pulse to $\overline{\mathrm{E}}$ while the desired data is stable on DQ0-DQ7 lines and the address is stable on A0-A11 lines. All bits may be erased to the " 1 " state by exposure to a UV light source through the transparent window on the top of the device package.

The R87C32 EPROM is ideal for system development or low volume production applications requiring non-volatile memory in either multiple chip or single chip microcomputers with extended bus configurations. The low power requirements especially support applications using the R65C00 CMOS Microcomputer device family.


R87C32 Pin Configuration

| AO-A11 | ADDRESSES |
| :--- | :--- |
| $\overline{\mathrm{E}}$ | CHIP ENABLE |
| $\overline{\mathrm{G}} / \mathrm{VPp}$ | OUTPUT ENABLE/PROGRAM |
| DQ0-DQ7 | DATA INPUTHOTPUT |

R87C32 Pin Names

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :--- | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage <br> All, except Vpp during <br> Programming <br> Vpp during Programming | $\mathrm{V}_{\mathrm{IN}}$ |  | Vdc |
| Output Voltage | $\mathrm{V}_{\mathrm{OUT}}$ | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ |  |
| Temperature under Bias | $\mathrm{T}_{\mathrm{A}}$ | -0.3 to +22.0 |  |
| Storage Temperature | $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |  |
| Power Dissipation $@ 25^{\circ} \mathrm{C}$ | P | -40 to 125 | ${ }^{\circ} \mathrm{C}$ |

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

## OPERATING CONDITIONS

| Parameter | Read Mode | Program Mode |
| :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ Supply Voltage | $5 \mathrm{~V} \pm 5 \%$ | $5 \mathrm{~V}_{ \pm} \pm \%$ |
| $\mathrm{~V}_{\mathrm{PP}}$ Supply Voltage |  | $21 \mathrm{~V} \pm 0.5 \mathrm{~V}$ |
| Temperature Range | 0 to $70^{\circ} \mathrm{C}$ | 0 to $70^{\circ} \mathrm{C}$ |

## DC OPERATING CHARACTERISTICS DURING READ

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage | - |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+0.3$ | V |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $\mathrm{I}_{\mathrm{CC} 1}$ | $\mathrm{V}_{\mathrm{CC}}$ Active Current TTL Level Address Inputs |  | 2 | 10 | mA | $\begin{aligned} & \bar{E}=\bar{G}=V_{\mathrm{IL}} \\ & V_{\mathrm{IN}}=V_{\mathrm{IH}} \text { or } V_{\mathrm{IL}} \\ & \text { Frequency }=1 \mathrm{MHz}, \mathrm{I} / \mathrm{O}=0 \mathrm{~mA} \end{aligned}$ |
|  | CMOS Level Address Inputs |  | 1 | 7 | mA | $\begin{aligned} & \bar{E}=\bar{G}=V_{1 L} \\ & V_{I N}=G N D \text { or } V_{C C} \\ & \text { Frequency }=1 \mathrm{MHz}, \mathrm{I} / \mathrm{O}=0 \mathrm{~mA} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC} 2}$ | $V_{C C}$ Standby Current TTL Level Chip Enable |  | 0.1 | 1 | mA | $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{HH}}$ |
|  | CMOS Level Chip Enable |  | 10 | 100 | $\mu \mathrm{A}$ | $\bar{E}=V_{C C}$ |
| $\mathrm{l}_{\text {pp }}$ | $\mathrm{V}_{\text {PP }}$ Supply Current |  |  | 30 | mA | $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{LL}}, \overline{\mathrm{G}} \mathrm{N}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{PP}}$ |
| $\mathrm{I}_{1}$ | Input Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{0}$ | Output Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=0 \mathrm{~V}$ to $\mathrm{V}_{\text {CC }}$ |
| $\mathrm{C}_{1}$ | Input Capacitance ${ }^{1}$ |  |  | 7 | pF | $\mathrm{V}_{\text {cc }}=5.0 \mathrm{~V}$, chip deselected, pin under test |
| $\mathrm{C}_{0}$ | Output Capacitance ${ }^{1}$ |  |  | 10 | pF | $\begin{aligned} & \text { at } 0 V, T_{A}= \\ & f=1 \mathrm{MHz} \end{aligned}$ |
| Notes: <br> 1. This parameter is periodically sampled and is not $100 \%$ tested. |  |  |  |  |  |  |

## DC OPERATING CHARACTERISTICS DURING PROGRAM

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=-20^{\circ} \mathrm{C}$ to $30^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{PP}}=21.0 \mathrm{~V} \pm 0.5 \mathrm{~V}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}$ | V |  |
| $\mathrm{V}_{\mathrm{IL}}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Active Current | - |  | 25 | mA | $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{G}}=21 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{PP}}$ | $\mathrm{V}_{\mathrm{PP}}$ Active Current | - |  | 30 | mA | $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{G}}=21 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{IN}}$ | Input Leakage Current |  |  | 10 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |

## AC CHARACTERISTICS DURING READ

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | R87C32-35 |  | R87C32-45 |  | R87C32-55 |  | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{t}_{\text {Avov }}$ | Address to Data Valid |  | 350 |  | 450 |  | 550 | ns | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}$ |
| telov | Chip Enable to Data Valid |  | 350 |  | 450 |  | 550 | ns | $\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{LL}}$ |
| $\mathrm{t}_{\mathrm{GLQ}}{ }^{2}$ | Output Enable to Data Valid |  | 120 |  | 120 |  | 120 | ns | $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{LL}}$ |
| $\mathrm{t}_{\mathrm{GHOZ}}{ }^{3}$ | Output Enable to High Impedance | 0 | 100 | 0 | 100 | 0 | 100 | ns | $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{IL}}$. |
| $\mathrm{t}_{\text {AXQX }}$ | Address to Output Hold | 0 |  | 0 |  | 0 |  | ns | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{LL}}$ |
| tehaz | Chip Enable to High Impedance | 0 | 100 | 0 | 100 | 0 | 100 | ns | $\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{iL}}$ |

Notes:

1. Test Conditions

Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$
Input Rise and Fall Times: $\leq 20 \mathrm{~ns}$
Input Pulse Levels: 0.45 V to 2.4 V
Timing Measurement Reference Level: Inputs 1 V and 2 V
Outputs 0.8 V and 2 V
2. $\bar{G}$ may be delayed up to $t_{A V Q V}-t_{G L Q v}$ after the falling edge of $\bar{E}$ without impact on $t_{\text {AvQv }}$. Data is available at the $D Q$ outputs after a delay of $\mathrm{t}_{\mathrm{GLQV}}$ from the falling edge of $\overline{\mathrm{G}}$, provided that $\overline{\mathrm{E}}$ has been low $\left(\mathrm{V}_{\mathrm{IL}}\right)$ and addresses have been valid for at least $\mathrm{t}_{\mathrm{AVQV}}-\mathrm{t}_{\mathrm{GL} \text { Qv }}$.
3. $\mathrm{t}_{\mathrm{GHOZ}}, \mathrm{t}_{\mathrm{EH} Q Z}$ are specified from $\overline{\mathrm{G}}$ or $\overline{\mathrm{E}}$, whichever occurs first.

## READ TIMING DIAGRAM



## AC CHARACTERISTICS DURING PROGRAM

$V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=20^{\circ} \mathrm{C}$ to $30^{\circ} \mathrm{C}$ (unless otherwise specified)


## PROGRAM TIMING DIAGRAM



## OPERATING MODES

The Rockwell R87C32 has five modes of operation (see table 1) and is pin compatible with Intel's 2732A.

## READ MODE

The read mode is governed by two control pins, $\overline{\mathrm{E}}$ and $\overline{\mathrm{G}}$. In order to obtain data at the outputs, both $\bar{E}$ and $\bar{G}$ must be $V_{\mathrm{IL}}$. $\overline{\mathrm{E}}$ is the power control and should be used for device selection. $\bar{G}$ is the output control and should be used to gate data to the output pins. Valid data will appear on the output pins after $\mathrm{T}_{\text {AVQV }}$, $T_{G L Q V}$ or $T_{\text {ELQV }}$ times, depending on which is limiting.

## STANDBY MODE

The standby mode of the R87C32 reduces power dissipation. The R87C32 is placed in the standby mode by making $\bar{E}=V_{I H}$. This is independent of $\overline{\mathcal{G}}$ and automatically puts the outputs in their high impedance (High-Z) state.

## PROGRAM MODE

The R87C32 is in the program mode when $\mathrm{G} N_{\mathrm{PP}}$ is at 21 V . The data to be programmed is applied to the data output pins. When the address controls and data are stable, a 50 msec program pulse is applied to the $\bar{E}$ input.

## PROGRAM VERIFY MODE

A program verify should be performed on the programmed bits to determine that they were correctly programmed. The verify may be performed with $\bar{G} / V_{\mathrm{PP}}$ and $\overline{\mathrm{E}}$ at $\underline{V}_{\mathrm{IL}}$. Data should be verified to $t_{\text {ELQV }}$ after the falling edge of $\overline{\mathrm{E}}$.

## PROGRAM INHIBIT MODE

The program inhibit mode allows programming several R87C32 EPROMs simultaneously with different data for each by using $\overline{\mathrm{E}}$ to control which devices respond to the program pulse on $\overline{\mathrm{E}}$.

Table 1. Mode Selection

| Pin <br> Mode | $\begin{gathered} \bar{E} \\ (18) \end{gathered}$ | G/VPP <br> (20) | $\begin{aligned} & V_{c c} \\ & (24) \end{aligned}$ | $\begin{gathered} \text { DQ0-DQ7 } \\ (9-11,13-17) \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{1 \mathrm{~L}}$ | $\mathrm{V}_{1 \mathrm{~L}}$ | +5 | $\mathrm{D}_{\text {OUT }}$ |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | No Effect | +5 | High-Z |
| Program | Puised $\mathrm{V}_{\mathrm{HH}}$ to $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{PP}}$ | +5 | $\mathrm{D}_{\text {in }}$ |
| Program verify | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{1 \mathrm{~L}}$ | +5 | $\mathrm{D}_{\text {OUt }}$ |
| Program inhibit | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{PP}}$ | +5 | High-Z |
| Note: No Effect = No effect on selection/enable logic, however, no voltage other than logic levels shall be applied. |  |  |  |  |

## ERASURE PROCEDURE

Initially, and after each erasure by ultraviolet light, all bits of the R87C32 are in the " 1 "' state. In Program Mode, " 0 "'s are selectively programmed into the desired bit locations. The only way to change a " 0 " to a " 1 " is by ultra-violet light erasure.

The recommended erasure procedure for the R87C32 is exposure to ultra-voilet light wahich has a wavelength of 2537 Angstroms.

The integrated dose for erasure should be a minimum of $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$. The erasure time with this dosage is 20 minutes using an ultraviolet lamp with a $12000 \mathrm{uW} / \mathrm{cm}^{2}$ power rating.

## Caution

The erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms. Sunlight and certain types of fluorescent lamps have wavelengths in the 3000-4000 Angstroms range.

## PACKAGE DIMENSIONS


dimensions in inches and (millimeters)

R87C64

## 0 Rockwell

# R87C64 <br> 64K (8K $\times 8$ ) CMOS UV EPROM 

## PRELIMINARY

## FEATURES

- $8,192 \times 8$ organization
- JEDEC approved pin-out
- Low Power
-Active 80 mW (max.)
-Standby $525 \mu \mathrm{~W}$ (max.)
- Access times: 250 ns and 350 ns (max.)
- Single 5V power supply
- Static operation, no clocks required
- TTL compatible inputs and tri-state outputs during both read and program mode
- Pin compatible with INTEL 2764A EPROM and Rockwell R23C64 and R2364B ROMs.

ORDERING INFORMATION


R87C64 Block Diagram

## DESCRIPTION

The Rockwell R87C64 is an $8 \mathrm{~K} \times 8(65,536$ bits) ultraviolet (UV) light erasable programmable read-only-memory (EPROM). It is manufactured using CMOS technology for low power dissipation in both active and standby operating modes.

Initially, and also after erasure, all bits are in the " 1 " state. Data is programmed by applying 21 V to $\mathrm{V}_{\mathrm{PP}}$ a TTL low to $\overline{\mathrm{E}}$, and a 50 ms low pulse on $\overline{\mathrm{P}}$ while the desired data is stable on DQ0-DQ7 lines and the address is stable on A0-A12 lines. All bits may be erased to the " 1 " state by exposure to a UV light source through the transparent window on the top of the device package.

The R87C64 EPROM is ideal for system development or production applications requiring non-volatile memory in either multiple chip or single chip microcomputers with extended bus configurations. The low power requirements especially support applications using the R65C00 CMOS Microcomputer device family.


R87C64 Pin Configuration

| A0-A12 | ADDRESSES |
| :--- | :--- |
| $\overline{\mathrm{E}}$ | CHIP ENABLE |
| $\overline{\mathrm{G}}$ | OUTPUT ENABLE |
| DQ0-DQ7 | DATA INPUT/OUTPUT |
| $\overline{\mathrm{P}}$ | PROGRAM ENABLE |

R87C64 Pin Names

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :--- | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | Vdc |
| Input Voltage <br> All, except Vpp during <br> Programming <br> Vpp during Programming | $\mathrm{V}_{\mathrm{IN}}$ |  | Vdc |
| Output Voltage |  | -0.3 to $\mathrm{V}_{\mathrm{CC}}+0.3$ |  |
| Temperature under Bias | $\mathrm{V}_{\text {OUT }}$ | -0.3 to +22.0 to $\mathrm{V}_{\mathrm{CC}}+0.3$ | Vdc |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -10 to +80 | ${ }^{\circ} \mathrm{C}$ |
| Power Dissipation @ $25^{\circ} \mathrm{C}$ | P | 1.0 |  |
| ${ }^{\circ} \mathrm{C}$ |  |  |  |

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

## OPERATING CONDITIONS

| Parameter | Read Mode | Program Mode |
| :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ Supply Voltage | $5 \mathrm{~V} \pm 5 \%$ | $5 \mathrm{~V} \pm 5 \%$ |
| $\mathrm{~V}_{\mathrm{PP}}$ Supply Voltage |  | $21 \mathrm{~V} \pm 0.5 \mathrm{~V}$ |
| Temperature Range | 0 to $70^{\circ} \mathrm{C}$ | 0 to $70^{\circ} \mathrm{C}$ |

## DC OPERATING CHARACTERISTICS DURING READ

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

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :--- | :--- | :---: | :---: | :---: | :---: | :--- |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  | - | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage | - |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |
| $\mathrm{~V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}+0.3$ | V |  |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $\mathrm{I}_{\mathrm{CC} 1}$ | $\mathrm{~V}_{\mathrm{CC}}$ Standby Current |  |  | 100 | $\mu \mathrm{~A}$ | $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{CC}}, \overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}, \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}$ or $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{CC} 2}$ | $\mathrm{~V}_{\mathrm{CC}}$ Active Current |  |  | 15 | mA | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{I}_{\mathrm{PP}}$ | $\mathrm{V}_{\mathrm{PP}}$ Current |  |  | 100 | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}} \cdot \mathrm{max}$. |
| $\mathrm{I}_{\mathrm{IN}}$ | Input Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{I}_{\mathrm{O}}$ | Output Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{~A}$ | $\mathrm{~V}_{\mathrm{OUT}}=0 \mathrm{~V}$ to $\mathrm{V}_{\mathrm{CC}}$ |
| $\mathrm{C}_{\mathrm{I}}$ | Input Capacitance ${ }^{2}$ |  |  | 7 | pF | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}, \mathrm{chip}$ deselected, pin under test <br> $\mathrm{at} 0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ <br> $\mathrm{f}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{O}}$ | Output Capacitance $^{2}$ |  |  |  | 10 | pF |

Notes:

1. Applies only to chip enable with power down standby mode.
2. This parameter is periodically sampled and is not $100 \%$ tested.

## DC OPERATING CHARACTERISTICS DURING PROGRAMMING

$V_{C C}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=20^{\circ} \mathrm{C}$ to $30^{\circ} \mathrm{C}, \mathrm{V}_{\mathrm{PP}}=21.0 \mathrm{~V} \pm 0.5 \mathrm{~V}$

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.0 |  | $\mathrm{~V}_{\mathrm{CC}}+0.3$ | V |  |
| $\mathrm{~V}_{\mathrm{IL}}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $\mathrm{I}_{\mathrm{CC}}$ | $\mathrm{V}_{\mathrm{CC}}$ Active Current |  |  | 0.5 | mA | $\overline{\mathrm{E}}=\overline{\mathrm{P}}=\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IH}}$ |
| $\mathrm{I}_{\mathrm{PP}}$ | $\mathrm{V}_{\mathrm{PP}}$ Active Current |  |  | 30 | mA |  |
| $\mathrm{I}_{\mathrm{IN}}$ | Input Leakage Current |  |  | 10 | $\mu \mathrm{~A}$ |  |

## AC CHARACTERISTICS DURING READ

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

| Symbol | Parameter | R87C64-25 |  |  | R87C64-35 |  |  | Unit | Test Conditions ${ }^{(3)}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |  |
| $t_{\text {Avav }}$ | Address to Data Valid |  |  | 250 |  |  | 350 | ns | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}$ |
| teLQv | Chip Enable to Data Valid |  |  | 250 |  |  | 350 | ns | $\overline{\mathrm{G}}=\mathrm{V}_{1 \mathrm{~L}}$ |
| $\mathrm{t}_{\text {GLav }}{ }^{1}$ | Output Enable to Data Valid | 10 |  | 100 | 10 |  | 120 | ns | $\overline{\mathrm{E}}=\mathrm{V}_{1 L}$ |
| $\mathrm{t}_{\text {GHaz }}{ }^{\text {a }}$ | Output Enable to High Impedance | 0 |  | 90 | 0 |  | 100 | ns | $\overline{\mathrm{E}}=\mathrm{V}_{1 \mathrm{~L}}$ |
| $\mathrm{t}_{\mathrm{Axax}}$ | Address to Output Hold | 0 |  |  | 0 |  |  | ns | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}$ |
| $\mathrm{t}_{\text {EHQZ }}$ | Chip Enable to High Impedance | 0 |  | 90 | 0 |  | 100 | ns | $\overline{\mathrm{G}}=\mathrm{V}_{\text {IL }}$ |

Notes:

1. $\bar{G}$ may be delayed up to $t_{A V Q V}-t_{G L O V}$ after the falling edge of $\bar{E}$ without impact on $t_{A V Q V}$. Data is available at the DQ outputs after a delay of $t_{G L Q V}$ from the falling edge of $G$, provided that $E$ has been low $\left(V_{I L}\right)$ and addresses have been valid for at least $t_{\text {AVQV }}-t_{G L Q V}$.
2. $t_{G H O Z}$ and $t_{E H O Z}$ are specified from $\bar{G}$ or $\bar{E}$, whichever occurs first.
3. Test Conditions:

Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$
Input Rise and Fall Times: $\leq 20 \mathrm{~ns}$
Input Pulse Levels: 0.45 V to 2.4 V
Timing Measurement Reference Level: Inputs 1V and 2V
Outputs 0.8 V and 2 V

## READ TIMING DIAGRAM



## AC CHARACTERISTICS DURING PROGRAM

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=20^{\circ} \mathrm{C}$ to $30^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {AVPL }}$ | Address set-up time | 2 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {DZGL }}$ | $\overline{\mathrm{G}}$ set-up time | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {DVPL }}$ | Data set-up time | 2 |  |  | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\text {ELPL }}$ | $\overline{\mathrm{E}}$ set-up time | 2 |  |  | $\mu \mathrm{s}$ |
| $t_{\text {VHPL }}$ | $V_{\text {PP }}$ set-up time | 2 |  |  | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\text {PHDX }}$ | Data hold time | 2 |  |  | $\mu \mathrm{S}$ |
| $t_{\text {GHAX }}$ | Address hold time | 0 |  |  | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {GLQV }}$ | Output enable to data valid |  |  | 120 | ns |
| $\mathrm{t}_{\text {GHQZ }}$ | Output disable to output high impedance | 0 | $\cdots$ | 100 | ns |
| $t_{\text {PLPH }}$ | $\overline{\mathrm{PE}}$ pulse width during programming | 45 | 50 | 55 | ms |

## Notes:

Test Conditions:
Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$
Input Rise and Fall Times: $\leq 20$ ns
Input Pulse Levels: 0.45 V to 2.4 V
Timing Measurement Reference Level: Inputs 1 V and 2 V

## PROGRAM TIMING DIAGRAM



## OPERATING MODES

The Rockwell R87C64 has five modes of operation (see table 1).

## Read Mode

The read mode is governed by two control pins, $\overline{\mathrm{E}}$ and $\overline{\mathrm{G}}$. In order to obtain data at the outputs, both $\bar{E}$ and $\bar{G}$ must be $V_{\mathrm{IL}}$. $\overline{\mathrm{E}}$ is the power control and should be used for device selection. $\bar{G}$ is the output control and should be used to gate data to the output pins. Valid data will appear on the output pins after $\mathrm{T}_{\text {AVQV }}$, $T_{\text {ELQV }}$ or $T_{G L Q V}$ times, depending on which is limiting.

## Standby Mode

The standby mode of the R87C64 reduces power dissipation. The R87C64 is placed in the standby mode by making $\bar{E}=V_{I H}$. This is independent of $\overline{\mathrm{G}}$ and automatically puts the outputs in their high impedance (High-Z) state.

## Program Mode

The R87C64 is in the program mode when $V_{P P}$ is at 21 V with $\bar{E}$ input at $V_{i L}$. The data to be programmed is applied to the data output pins. When the address controls and data are stable, a 50 msec program pulse is applied to the $\overline{\mathrm{P}}$ input.

## Program Verify Mode

A program verify should be performed on the programmed bits to determine that they were correctly programmed. The verify may be performed with $V_{P P}$ at 21 V . Data should be verified to $t_{\text {GLQV }}$ after the falling edge of $\bar{G}$.

## Program Inhibit Mode

The program inhibit mode allows programming several R87C64 EPROMs simultaneously with different data for each by using $E$ to control which devices respond to the program pulse on $\vec{P}$.

Table 1. Mode Selection

| Mode ${ }^{\text {Pin }}$ | $\begin{gathered} \bar{E} \\ \mathbf{( 2 0 )} \end{gathered}$ | $\overline{\mathbf{G}}$ | $\begin{gathered} \overline{\mathbf{P}} \\ \text { (27) } \end{gathered}$ | $\begin{aligned} & V_{P P} \\ & (1) \end{aligned}$ | $\begin{aligned} & V_{c c} \\ & (28) \end{aligned}$ | $\begin{gathered} \text { DQ0-DQ7 } \\ (11-13,15-19) \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Read | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{1 \mathrm{H}}$ | +5 | + 5 | Q out |
| Standby | $\mathrm{V}_{\mathrm{IH}}$ | No Effect | No Effect | +5 | +5 | High-Z |
| Program | $\mathrm{V}_{\text {IL }}$ | No Effect | $\mathrm{V}_{\text {iL }}$ | +21 | +5 | $\mathrm{D}_{\text {In }}$ |
| Program verify | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{1 L}$ | $\mathrm{V}_{\text {IH }}$ | +21 | +5 | $Q_{\text {OUT }}$ |
| Program inhibit | $\mathrm{V}_{\mathrm{IH}}$ | No Effect | No Effect | +21 | + 5 | High-Z |
| Program inhibit | No Effect | No Effect | $\mathrm{V}_{1 \mathrm{H}}$ | +21 | + 5 | High-Z |

## ERASURE PROCEDURE

Initially, and after each erasure by ultraviolet light, all bits of the R87C64 are in the " 1 " state. In Program Mode, " 0 "'s are selectively programmed into the desired bit locations. The only way to change a " 0 " to a " 1 " is by ultra-violet light erasure.

The recommended erasure procedure for the R87C64 is exposure to ultra-violet light which has a wavelength of 2537 Angstroms.

The integrated dose for erasure should be a minimum of $15 \mathrm{~W}-\mathrm{sec} / \mathrm{cm}^{2}$. The erasure time with this dosage is 20 minutes using an ultraviolet lamp with a $12000 \mathrm{uW} / \mathrm{cm}^{2}$ power rating.

## Caution

The erasure begins to occur when exposed to light with wavelengths shorter than approximately 4000 Angstroms. Sunlight and certain types of fluorescent lamps have wavelengths in the 3000-4000 Angstroms range.

## PACKAGE DIMENSIONS

## 28-PIN CERDIP



| DIM | MILLIMETERS |  | INCHES |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 36.32 | 37.34 | 1.430 | 1.470 |  |
| B | 12.95 | 13.46 | 0.510 | 0.530 |  |
| C | 3.68 | 4.19 | 0.145 | 0.165 |  |
| D | 0.41 | 0.51 | 0.016 | 0.020 |  |
| F | 1.27 | 1.52 | 0.050 | 0.060 |  |
| G | 2.54 |  | BSC | 0.100 BSC |  |
| J | 0.20 | 0.30 | 0.008 | 0.012 |  |
| J | 0.20 | 0.30 | 0.008 | 0.012 |  |
| K | 3.18 | 4.19 | 0.125 | 0.165 |  |
| L | 16.13 | 17.41 | 0.635 | 0.685 |  |
| M | 15.24 | 15.75 | 0.600 | 0.620 |  |
| N | 0.89 | 1.14 | 0.035 | 0.045 |  |

NOTE: EITHER ROUND OR SQUARE UV WINDOW.

## R5213/2816 16K $(2 K \times 8)$ ELECTRICALLY ERASABLE ROM

## PRELIMINARY

## FEATURES

- $2 \mathrm{~K} \times 8,2048 \times 8$ organization
- Single $5 \mathrm{~V} \pm 10 \%$ supply
- TTL or high voltage byte erase/byte write
- 9 ms or 1 ms byte erase/byte write
- 10,000 erase/write cycles per byte
- Chip clear
- Access time: 350 ns (max.)
- Infinite number of read cycles
- JEDEC Approved pinout
- Pin and 2816A EEPROMs compatible with Seeq 5213, Intel 2816


## ORDERING INFORMATION



## DESCRIPTION

The Rockwell R5213/2816 is a $2 \mathrm{~K} \times 8$ ( 16,384 bits), 5 V electrically erasable Read-Only Memory (EEROM). Data is electrically written either by a TTL pulse or a voltage between 15 V and 22V on the Write Enable pin. Once written-this requires less than 10 milliseconds-there is no limit to the number of read cycles. A byte erase as well as a chip clear mode is available. Each byte may be erased and written 10,000 times. The erasure time, in either a byte erase or chip clear mode, is less than 10 milliseconds.

The R5213 is ideal for applications requiring a nonvolatile memory with in-system write and erase capability. These features make possible dynamic reconfiguration, i.e., operating software is altered in real time. Possible applications are instrument/machine self calibration, programmable character generators, table look-up updates over telephone lines, and controlling automotive fuel/air ratio. Designing the R5213 into 8 - and 16 -bit microprocessor systems is also simplified since the typical access time is less than 250 ns , allowing zero wait state operation.


ABSOLUTE MAXIMUM RATINGS*

| Parameter | 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 |
| Output Voltage | $\mathrm{V}_{\text {OUT }}$ | -0.5 to +7.0 | Vdc |
| Temperature Under Bias | $\mathrm{T}_{\mathrm{A}}$ | -10 to +80 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\mathrm{STG}}$ | -65 to +100 | ${ }^{\circ} \mathrm{C}$ |
| W Level During Writing/ <br> Erasing | $\mathrm{V}_{\mathrm{W}}$ | -0.5 to +22.0 | Vdc |
| W Max. Duration at 22 V <br> During W/E Inhibit | $\mathrm{t}_{\mathrm{W}}$ | 24 | Hrs |

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

OPERATING CONDITIONS

| Parameter | All Modes |
| :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ Supply Voltage | $5 \mathrm{~V} \pm 10 \%$ |
| Temperature Range | 0 to $70^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

$V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | Min. | Typ. ${ }^{(2)}$ | Max. | Unit | Test Conditions ${ }^{(1)}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{IIN}^{\text {a }}$ | Input Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {CC }}$ Max. |
| 10 | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {CC }}$ Max. |
| IW | Write Enable Leakage Read Mode |  | 1.0 | 1.5 | mA | $\bar{W}=V_{1 H}$ |
|  | W/E Mode-TTL |  |  | -1.0 | mA | $\mathrm{W}=\mathrm{V}_{\mathrm{IL}}$ |
|  | W/E Mode-High Voltage |  |  | 1.5 | mA | $\bar{W}=22 \mathrm{~V}, \mathrm{E}=\mathrm{V}_{1 \mathrm{~L}}$ |
|  | W/E Inhibit Mode-High Voltage |  |  | 1.5 | mA | $\overline{\mathrm{W}}=22 \mathrm{~V}, \mathrm{E}=\mathrm{V}_{1 \mathrm{H}}$ |
|  | Chip Clear Mode-TTL |  |  | -1.0 | mA | $\bar{W}=V_{\text {IL }}$ |
|  | Chip Clear Mode-High Voltage |  |  | 1.5 | mA | $\bar{W}=22 \mathrm{~V}$ |
| ICCl | $\mathrm{V}_{\text {cc }}$ Standby Current |  | 15 | 30 | mA | $\vec{E}=\mathrm{V}_{\mathrm{H}}$ |
| $\mathrm{ICC2}$ | $\mathrm{V}_{\text {cc }}$ Active Current |  | 50 | 80 | mA | $\overline{\mathbf{E}}=\mathbf{G}=\mathrm{V}_{\text {IL }}$ |
| $\mathrm{V}_{1 \mathrm{~L}}$ (DC) | Input Low Voitage (DC) | -0.1 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IL }}(\mathrm{AC})$ | Input Low Voltage (AC) | -0.4 |  |  | V | Time $=10 \mathrm{~ns}$ |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | $v_{c c}+1$ | V |  |
| $\mathrm{V}_{\mathrm{w}}$ | $\overline{\mathrm{W}}$ Read Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}+1$ | V |  |
|  | $\bar{W}$ Write/Erase Voltage -TTL Mode | -0.1 |  | 0.8 | V |  |
|  | -High Voltage Mode | 15 | 21 | 22 | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{V}_{\mathrm{G}}$ | $\overline{\mathrm{G}}$ Chip Clear Voltage | 14 |  | 22 | V | $\mathrm{I}_{\mathrm{G}}=10 \mu \mathrm{~A}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 5 | 10 | pF | $\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V}$, chip deselected, pin |
| Cout | Output Capacitance ${ }^{(3)}$ |  |  | 10 | pF | $\begin{aligned} & \text { under test at } 0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}= \\ & 1 \mathrm{MHz} \end{aligned}$ |
| $\mathrm{c}_{\mathrm{v}_{\mathrm{cc}}}$ | $\mathrm{V}_{\text {cc }}$ Capacitance $^{(3)}$ |  |  | 500 | pF | $\overline{\mathrm{G}}=\overline{\mathrm{E}}=\mathrm{V}_{1 H}$ |
| $\mathrm{C}_{\mathrm{v}_{\mathrm{w}}}$ | $\mathrm{V}_{\text {W }}$ Capacitance ${ }^{(3)}$ |  |  | 10 | pF | $\overline{\mathrm{G}}=\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{IH}}$ |

## Notes:

1. Test Conditions: Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$; Input Rise and Fall Times: $\leqslant 20 \mathrm{~ns}$; Input Pulse Levels: 0.45 V to 2.4 V ; Timing

Measurement Reference Level: Inputs: 1 V and 2 V , Outputs: 0.8 V and 2 V
2. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$.
3. This parameter is periodically sampled and is not $100 \%$ tested.

## AC CHARACTERISTICS DURING READ

| Symbol | Parameter | R5213-25 ${ }^{(4)}$ |  |  | R5213-35 ${ }^{(4)}$ |  |  | Test Conditions ${ }^{(1)}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |
| $t_{\text {aVQV }}$ | Address to Data Valid | 10 | 200 | 250 |  | 300 | 350 | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{1 \mathrm{~L}}$ |
| $t_{\text {ELQV }}$ | Chip Enable to Data Valid | 10 | 200 | 250 |  | 300 | 350 | $\bar{G}=V_{1 L}$ |
| $t_{\text {GLQV }}$ | Output Enable to Data. Valid | 10 | 50 | 90 | 10 | 50 | 100 | $\bar{E}=V_{\text {IL }}$ |
| $\mathrm{t}_{\text {EHQZ }} \mathrm{t}_{\text {GHQZ }}{ }^{(2)}$ | Output Enable to High Impedance | 0 | 50 | 70 | 0 | 50 | 80 | $\bar{E}=V_{\text {IL }}$ |
| $\mathrm{t}_{\mathrm{AXQX}}{ }^{(3)}$ | Output Hold from Address, Chip Enable, or Output Enable, whichever Transition Occurred First | 0 | " |  | 0 |  |  | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}$ |

Notes:

1. Test Conditons: Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$; Input Rise and Fall Times: $\leq 20$ ns; Input Pulse Levels: 0.45 V to 2.4 V ; Timing Measurement Reference Level: Inputs: 1 V and 2 V , Outputs: 0.8 V and 2 V
2. $\bar{G}$ may be delayed up to $t_{A V Q V}-t_{G L O V}$ after the falling edge of $\bar{E}$ without impact on $t_{A V Q V}$. Data is available at the DQ outputs after a delay of $t_{\mathrm{GLQv}}$ from the falling edge of $\bar{G}$, provided that $\overline{\mathrm{E}}$ has been low $\left(\mathrm{V}_{\mathrm{IL}}\right)$ and addresses have been valid for at least $\mathrm{t}_{\mathrm{AVQV}} \mathrm{t}_{\mathrm{GLQV}}$.
3. $t_{E H Q Z}, t_{G H Q Z}$ is specified from $\bar{G}$ or $\bar{E}$ whichever occurs first.
4. All timing units in nanoseconds (ns).

## READ TIMING DIAGRAM



AC CHARACTERISTICS DURING WRITE/ERASE

| Symbol | Parameter | Min. ${ }^{(4)}$ | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $Q^{(1)}$ | Maximum Endurance | 10,000 |  |  | cycles/byte |
| $\mathrm{t}_{\text {AVWL }}$ | Address to $\bar{W}$ Set-Up Time | 150 |  |  | ns |
| teLwL | $\bar{E}$ to $\bar{W}$ Set-Up Time | 150 |  |  | ns |
| $t_{\text {DWWL }}$ | Data to $\bar{W}$ Set-Up Time | 0 |  |  | ns |
| $\mathrm{t}_{\text {whodx }}$ | Write Enable Pulse Width R5213 | 9 | 10 | 70 | ms |
|  | R5213H | 1 |  | 20 | ms |
| $\mathrm{t}_{\text {WHEH }}{ }^{(2)}$ | Write Recovery Time | 50 |  |  | ns |
| $\mathrm{t}_{\text {GHWL }}$ | $\overline{\mathrm{G}}$ Write/Erase Set-Up Time | 0 |  |  | ns |
| $\mathrm{t}_{\text {WHGX }}$ | $\overline{\mathrm{G}}$ Write/Erase Hold Time | 0 |  |  | ns |
| $\mathrm{t}_{\mathrm{PF}}{ }^{(3)}$ | $V_{\text {w }}$ Fall Time | 5 |  |  | ns. |

## Notes:

1. Maximum endurance, $Q$, is the number of write and erase cycles/byte.
2. $t_{\text {WHEH }}(\min )=50 \mathrm{~ns}$ when in the High Voltage W/E Mode only. When in the TTL W/E Mode, $t_{\text {WHEH }}(\mathrm{min})=700 \mathrm{~ns}$.
3. $t_{\text {pF }}$ applies only when in the High Voltage W/E Mode.
4. Test Conditions: Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$; Input Rise and Fall Times: $\leqslant 20 \mathrm{~ns}$; Input Pulse Levels: 0.45 V to 2.4 V ; Timing Measurement Reference Level: Inputs: 1 V and 2 V , Outputs: 0.8 V and 2 V

BYTE ERASE OR BYTE WRITE TIMING DIAGRAM


## CHIP ERASE TIMING



4

## DEVICE OPERATION

The Rockwell R5213/2816 has six modes of operation (see Table 1) and except for the chip clear mode it requires only TTL inputs to operate these modes.

To write a particular location of the R5213, that byte must first be erased. A memory location is erased by enabling the R5213 with Chip Enable at a TTL low, bringing Write Enable to a TTL low while Output Enable is a TTL high, and TTL highs (logical 1 's) are being presented to all the $I / O$ lines. The erase operation requires 9 ms . A write operation is the same as an erase except true data is presented to the I/O lines.

The R5213 is compatible to prior generation EEROMs which required a high voltage $\mathrm{V}_{\text {pp }}$ for writing and erasing. In the R5213 there is an internal dual level detection circuit which allows either a TTL low or $2: 1 \mathrm{~V} \mathrm{~V}_{\mathrm{Pp}}$ to be applied to $\overline{\mathrm{W}}$ to execute an erase or write operation. The R5213 specifies no restriction on the rising edge of $\mathrm{V}_{\mathrm{pp}}$.

For certain applications, the user may wish to erase the entire memory. A chip clear is performed in the same manner as a byte erase except that Output Enable is between 14 V and 22 V . All 2 K bytes are erased in less than 10 ms .

A characteristic of all EEROMs is that the total number of write and erase cycles is not unlimited. The R5213 has been designed for applications requiring up to 10,000 write and erase cycles per byte. The write and erase cycling characteristic is completely byte independent. Adjacent bytes are not affected during write/erase cycling.

After the device is written, data is read by applying a TTL high to $\bar{W}$, enabling the chip, and enabling the outputs. Data is available $t_{\text {Evov }}$ time after Chip Enable is applied or $t_{\text {Avav }}$ time from the addresses. System power may be reduced by placing the R5213 into a standby mode. Raising Chip Enable to a TTL high will reduce the active power by over $60 \%$.

## COMPATIBILITY

The R5213/2816 is $100 \%$ compatible with the Seeq 5213 and the Intel 2816A and, except for the $V_{G}$ (G Chip Erase Voltage), is also $100 \%$ backward compatible to the Intel 2816 which requires high voltage for byte erase/write.

Table 1. Mode Selection ( $\mathrm{V}_{\mathrm{cc}}=\mathbf{5 V} \pm 10 \%$ )
Table 1. Mode Selection

| Pin <br> Mode | $\begin{gathered} \stackrel{\rightharpoonup}{E} \\ \text { (18) } \end{gathered}$ | $\overline{\mathbf{G}}$ <br> (20) | $\overline{\mathbf{W}}\left(\mathbf{V}_{\mathrm{Pp}}\right)$ <br> (21) | $\begin{gathered} \text { DQO-DQ7 } \\ (9-11,13-17) \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
| Read ${ }^{(1)}$ | $V_{\text {IL }}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\text {IH }}$ | $\mathrm{D}_{\text {OUt }}$ |
| Standby ${ }^{(1)}$ | $\mathrm{V}_{\text {IH }}$ | No Effect | $\mathrm{V}_{\text {IH }}$ | High Z |
| Byte Erase ${ }^{(2)}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{D}_{\text {IN }}=\mathrm{V}_{\text {IH }}$ |
| Byte Write ${ }^{(2)}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | $V_{\text {IL }}$ | $\mathrm{D}_{\text {IN }}$ |
| Chip Clear ${ }^{(2)}$ | $V_{\text {IL }}$ | $V_{G}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{D}_{\text {IN }}=\mathrm{V}_{\text {IH }}$ |
| Write/Erase Inhibit | $\mathrm{V}_{1 \text { H }}$ | No Effect | No Effect | High Z |

## Note:

1. $\bar{W}$ may be from $V_{i H}$ to 6 V in the read and standby mode.
2. $\bar{W}$ may be at $\mathrm{V}_{\mathrm{IL}}$ (TTL W/E Mode) or from 15 V to 22 V (High Voltage W/E Mode) in the byte erase, byte write, or chip clear mode.
3. No Effect $=$ No effect on selection/enable logic, however, no voltage greater than logic levels shall be applied.

## POWER UP/DOWN CONSIDERATIONS

Care must be taken to prevent an unintentional write (or erase) cycle during power-up or power-down. These cycles can be prevented by applying a signal level of $V_{H H}$ to $\bar{W}$ (pin 21) whenever $\mathrm{V}_{c c}$ is greater than 2.75 volts. When $\mathrm{V}_{c c}$ is 2.75 volts or less, the device cannot perform a write (or erase) cycle.

Figure 1 shows a suggested circuit which can be used for powerup or power-down conditions. The power supply used for the 470 ohm pull-up resistor should be the same supply used for
the R5213 $\mathrm{V}_{\mathrm{cc}}$. When this $\mathrm{V}_{\mathrm{cc}}$ is outside the normal operating range ( 4.5 to 5.5 volts), the system power status signal (shown in Figure 1) should be low. Under these conditions, the open collector NAND gate and the 470 ohm resistor protect against an unintentional write (or erase).


Figure 1. Typical Power Monitor Circuit

## PACKAGE DIMENSIONS


dIMENSIONS IN INCHES AND (MILLIMETERS)

## FEATURES

- Input latches
- $8192 \times 8$ organization
- Single $5 \mathrm{~V} \pm 10 \%$ supply
- TTL byte erase/byte write
- 9 ms byte erase/byte write
- 10,000 erase/write cycles per byte
- Chip clear
- Fast access times: $200 \mathrm{~ns}, 250 \mathrm{~ns}, 300 \mathrm{~ns}$ and 350 ns (max.)
- Infinite number of read cycles
- JEDEC approved pinout
- Pin compatible With Seeq 52B33 EEPROM


## ORDERING INFORMATION

| Part Number: |
| :---: | :---: |
| R52B33 |
| Package: |
| CERDIP |

## DESCRIPTION

The Rockwell R52B33 is a 64 K ( $8192 \times 8$ bits) 5 volt electrically erasable read-only-memory (EEROM). The device operate on 5 volt TTL levels in the read, write and erase modes. The R52B33 also has a chip clear mode in which the entire memory is erased in a single erase cycle. The device performs chip clear with a TTL high level signal applied to $\bar{G}$ and a TTL low level applied to $\overline{\mathrm{CC}}$. The erasure time for both chip clear and byte erasure is under 10 ms .

Data, addresses, $\overline{\mathrm{E}}, \overline{\mathrm{CC}}$, and $\overline{\mathrm{G}}$ are latched on the leading edge of $\bar{W}$. The system controller needs only to maintain the $\bar{W}$ signal during the erase/write cycle after the latches are activated. Once written, which requires under 10 ms , there is no limit to the number of times that the data may be read. Each byte may be erased and written at least 10,000 times.

The R52B33 is ideal for applications requiring a nonvolatile memory with in-system write and erase capability. These features make possible dynamic reconfiguration, i.e., operating software is altered in real time. Possible applications are instrument/machine self calibration, programmable character generators, table look-up updates over telephone lines, and controlling automotive fuel/air ratio.


R52B33 Pin Configuration

| $A 0-A 12$ | ADDRESSES |
| :--- | :--- |
| $\overline{\mathrm{E}}$ | CHIP ENABLE |
| $\overline{\mathrm{G}}$ | OUTPUT ENABLE |
| $\overline{\mathrm{W}}$ | WRITE ENABLE |
| DQO-DQ7 | DATA INPUT (WRITE OR ERASE) <br> DATA OUTPUT (READ) |
| $\overline{\mathrm{CC}}$ | CHIP CLEAR |
| $\mathrm{N} / \mathrm{C}$ | NO CONNECT |

R52B33 Pin Names

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | 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 |
| Output Voltage | $\mathrm{V}_{\text {OUT }}$ | -0.5 to +7.0 | Vdc |
| Temperature Under Bias | $\mathrm{T}_{\mathrm{A}}$ | -10 to +80 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -65 to +100 | ${ }^{\circ} \mathrm{C}$ |

## OPERATING CONDITIONS

| Parameter | All Modes |
| :---: | :---: |
| $\mathrm{V}_{\text {cc }}$ Supply Voltage | $5 \mathrm{~V} \pm 10 \%$ |
| Temperature Range | 0 to $70^{\circ} \mathrm{C}$ |

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

## DC CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

| Symbol | Parameter | Min. | Typ. ${ }^{(2)}$ | Max. | Unit | Test Conditions ${ }^{(1)}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IN | Input Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $V_{\text {IN }}=V_{\text {CC }}$ Max. |
| 10 | Output Leakage Current |  |  | $\pm 10$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{V}_{\text {cc }}$ Max. |
| IWE | Write Enable Leakage Read Mode |  |  | 10 | $\mu \mathrm{A}$ | $\bar{W}=V_{1 H}$ |
|  | W/E Mode |  |  | 10 | $\mu \mathrm{A}$ | $\bar{W}=V_{\text {IL }}$ |
|  | Chip Erase Mode |  |  | 10 | $\mu \mathrm{A}$ | $\bar{W}=V_{\text {IL }}$ |
| $\mathrm{ICC1}$ | $\mathrm{V}_{\mathrm{cc}}$ Standby Current |  | 18 | 40 | mA | $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{IH}}$ |
| $\mathrm{ICC2}$ | $\mathrm{V}_{\text {cc }}$ Active Current |  | 60 | 110 | mA | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\text {IL }}$ |
| $\mathrm{V}_{\text {IL }}$ (DC) | Input Low Voltage (DC) | -0.1 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IL }}$ (AC) | Input Low Voltage (AC) | -0.4 |  |  | V | Time $=10 \mathrm{~ns}$ |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}+1$ | V |  |
| $\mathrm{V}_{\mathrm{w}}$ | W Read Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |  |
|  | W Write/Erase Voltage | -0.1 |  | 0.8 | V , |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  | 5 | 10 | pF | $\mathrm{V}_{C C}=5.0 \mathrm{~V}$, chip deselected, pin |
| $\mathrm{C}_{\text {OUt }}$ | Output Capacitance ${ }^{(3)}$ |  |  | 10 | pF | under test at $0 V, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=$ $1 \mathrm{MHz}$ |
| $\mathrm{C}_{\mathrm{v}_{\mathrm{cc}}}$ | $\mathrm{V}_{\text {cc }}$ Capacitance ${ }^{(3)}$ |  |  | 500 | pF | $\overline{\mathrm{G}}=\overline{\mathrm{E}}=\mathrm{V}_{1 H}$ |
| $\mathrm{C}_{\mathrm{V}_{\mathrm{w}}}$ | $\mathrm{V}_{\text {W }}$ Capacitance ${ }^{(3)}$ |  |  | 10 | pF | $\overline{\mathrm{G}}=\overline{\mathrm{E}}=\mathrm{V}_{1 H}$ |

Notes:

1. Test Conditions: Output Load: 1 TTL gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$; Input Rise and Fall Times: $\leqslant 20 \mathrm{~ns}$; Input Pulse Levels: 0.45 V to 2.4 V ; Timing Measurement Reference Level: Inputs: 1 V and 2 V , Outputs: 0.8 V and 2 V
2. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and nominal supply voltages
3. This parameter is periodically sampled and is not $100 \%$ tested.

## AC CHARACTERISTICS DURING READ

|  | Parameter | R52B33-20 |  | R52B33-25 |  | R52B33-30 |  | R52B33-35 |  | Unit | Test Conditions ${ }^{(1)}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Symbol |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |  |
| $\mathrm{t}_{\text {AVQV }}$ | Address to Data Valid |  | 200 |  | 250 |  | 300 |  | 350 | ns | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\text {IL }}$ |
| teLav | Chip Enable to Data Valid |  | 200 |  | 250 |  | 300 |  | 350 | ns | $\bar{G}=V_{1 L}$ |
| $\mathrm{t}_{\mathrm{GLQv}}{ }^{(2)}$ | Output Enable to Data Valid | 10 | 80 | 10 | 90 | 10 | 100 | 10 | 100 | ns | $\bar{E}=V_{1 L}$ |
| $\begin{aligned} & \mathrm{t}_{\mathrm{EHOZ}_{\prime}} \\ & \mathrm{t}_{\mathrm{GHOZ}^{(3)}}{ }^{(2)} \end{aligned}$ | Output Enable to High Impedance | 0 | 60 | 0 | 70 | 0 | 80 | 0 | 80 | ns | $\overline{\mathrm{E}}=\mathrm{V}_{\text {IL }}$ |
| $t_{\text {Axax }}$ | Output Hold from Address, Chip Enable, or Output Enable, whichever Transition Occurred First |  | 0 |  | 0 |  | 0 |  | 0 | ns | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}$ |

## Notes:

1. Test Conditons: Output Load: 1 TTL gate and $\mathrm{C}_{\mathrm{L}}=100 \mathrm{pF}$; Input Rise and Fall times: $\leq 20 \mathrm{~ns}$; Input Pulse Levels: 0.45 V to 2.4 V ; Timing Measurement Reference Level: Inputs: 1 V and 2 V , Outputs: 0.8 V and 2 V


2. $t_{E H Q Z}, t_{G H Q Z}$ is specified from $\bar{G}$ or $\bar{E}$ whichever occurs first.

## READ TIMING DIAGRAM



## AC CHARACTERISTICS DURING WRITE/ERASE

| Symbol | Parameter | R52B33-35 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Typ. | Max. |  |
| Q ${ }^{(1)}$ | Maximum Endurance | 10,000 |  |  | cycles/byte |
| $\mathrm{t}_{\text {AVWL }}$ | $\overline{\mathrm{E}}, \overline{\mathrm{G}}$ or Address Setup to $\bar{W}$ | 50 |  |  | ns |
| $\mathrm{t}_{\text {DVWL }}$ | Data Setup to $\bar{W}$ | 0 |  |  | ns |
| $\mathrm{t}_{\text {WLDx }}{ }^{(2)}$ | $\bar{W}$ to $\bar{E}, \overline{\mathrm{G}}$, Address or Data Change | 50 |  |  | ns |
| $t_{\text {WLWH }}$ | Write Enable, $\overline{\mathrm{W}}$, Pulse Width R52B33 | 9 | 10 | 70 | ms |
|  | R52B33H | 1 |  | 20 | ms |
| $t_{W R}{ }^{(3)}$ | $\bar{W}$ to Mode Change (Write Recovery Time) | 50 |  |  | ns |
| Notes: <br> 1. Maximum endurance, $Q$, is the number of write and erase cycles/byte. The endurance of the R52B33 is guaranteed to be at least 10,000 cycles/byte. <br> 2. After ${ }^{\text {WLDX }}$ hold time, from $\bar{W}$, the inputs $\bar{E}, \bar{G}$, Address and Data are latched and are "No Effect" until twR, Write Recovery Time, after the trailing edge of $\bar{W}$. <br> 3. The Write Recovery Time, $t_{W R}$, is the time after the trailing edge of $\bar{W}$ that the latches are open and able to accept the next mode set-up conditions. Reference Table 1 (page 6) for mode control conditions. |  |  |  |  |  |

## BYTE ERASE OR BYTE WRITE TIMING



## CHIP ERASE TIMING



## DEVICE OPERATION

The Rockwell R52B33 has six modes of operation (see Table 1). The control signals that determine these modes are TTL compatible.

The chip clear and byte erase time is 10 ms .

## READ

A read is accomplished by presenting the address of the desired byte to the Column and Row Address inputs with AO as the LSB. Once the address is stable, $\bar{E}$ is brought low in order to enable the chip ( $\bar{W}$ must be at a TTL high during the entire read cycle). The output drivers are made active by bringing $\bar{G}$ to a TTL low. Data is valid $\mathrm{t}_{\mathrm{ELO}}$ after $\overline{\mathrm{E}}$ or $\mathrm{t}_{\mathrm{GLOV}}$ after $\overline{\mathrm{G}}$ is low. The latches are transparent in the read mode.

## STANDBY

The power dissipation of the chip may be reduced by taking $\overline{\mathrm{E}}$ to a TTL high between operations. This lowers $P_{D}$ by over $60 \%$.

## BYTE ERASE/BYTE WRITE

Each byte of the memory may be individually erased or written with TTL level pulses. The two operations have the same timing and specifications since the byte erase is performed by writing all highs (HEX FF) to the selected byte. This restores the byte to its clear state of logical one. The byte erase is performed by presenting the device with $\bar{E}$ at a logical low and $\overline{\mathrm{G}}$ at a logical high after the address is stable. These controls must be stable for $t_{\text {AVWL }}$ before $\bar{W}$ is taken active. The data must be stable for
$t_{\text {DVWL. }}$ All of these control inputs together with the address and data lines are latched on the falling edge of $\bar{W}$. After $t_{\text {wLDx }}$ they may be removed and the next condition established while the byte is being erased or written. This effectively increases the write speed. After $t_{\text {WLwh }}, \bar{W}$ may be returned to the TTL high level and the next operation begun $t_{W_{R}}$ after the rising edge of the pulse.

## CHIP CLEAR

The chip clear is performed by taking $\overline{C C}$ and $\bar{E}$ to a TTL low level and $\overline{\mathrm{G}}$ to a TTL high voltage level. The order in which the controls are set does not matter, only that they are stable for $t_{\mathrm{AVWL}}$ before $\overline{\mathrm{W}}$ goes low. The I/O and the address inputs are No Effect. After the control and data inputs are stable, take $\bar{W}$ low. This latches all control and data inputs and, after $t_{\text {wLDX }}$ all inputs with the exception of $\bar{W}$ become No Effect. $\bar{W}$ must be maintained at a low level for the duration of the chip clear cycle and then return it to a high level. Another mode of operation may be started $t_{W R}$ after $\bar{W}$ is stable. The memory has now been returned to its clear state and contains all 1's.

## POWER UP/DOWN CONSIDERATIONS

Internal circuitry on all devices guard against inadvertent programming of bits during times when $\mathrm{V}_{\mathrm{CC}}$ is below the normal operating voltage. The device outputs will remain in high impedance and the write/erase circuitry disabled as long as $\bar{W}$ is kept at $V_{\mathrm{iL}}$. Normal operation, as outlined in Table 1, can begin only after $\bar{W}$ has been taken to $V_{1 H}$.

Table 1. Mode Selection $\left(\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 10 \%\right)$

|  | $\begin{gathered} \bar{E} \\ (20) \end{gathered}$ | $\overline{\mathbf{C C}}$ <br> (1) | $\bar{G}$ <br> (22) | $\begin{gathered} \bar{W} \\ (27) \end{gathered}$ | $\begin{gathered} \text { DQ0-DQ7 } \\ (11-13,15-19) \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Read ${ }^{(1)}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | $V_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | Dout |
| Standby ${ }^{(1)}$ | $\mathrm{V}_{\text {IH }}$ | No Effect | No Effect | No Effect | High Z |
| Byte Erase | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{D}_{\text {IN }}=\mathrm{V}_{1 H}$ |
| Byte Write | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{iH}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\text {IL }}$ | $\mathrm{D}_{\text {IN }}$ |
| Chip Clear | $\mathrm{V}_{\text {IL }}$ | $\mathrm{V}_{1 \mathrm{~L}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{1 \mathrm{~L}}$ | $\mathrm{D}_{\text {IN }}=\mathrm{V}_{1 \mathrm{H}}$ |
| Write/Erase Inhibit | $\mathrm{V}_{\mathrm{IH}}$ | No Effect | No Effect | No Effect | High Z |

## Note:

1. $\bar{W}$ may be from $V_{I H}$ to $6 V$ in the read and standby mode.
2. No Effect = No effect on selection/enable logic, however, no voltage greater than logic levels shall be applied.

## MICROPROCESSOR INTERFACE CIRCUIT EXAMPLE FOR BYTE WRITE/ERASE



NOTE:
ALL SIGNALS MUST SATISFY THE RELATIONSHIPS INDICATED SY THE TIMING DIAGRAMS SHOWN ON PAGES 3, 4 AND 5. EEROM SELECT IS DERIVED FROM THE CHIP SELECT SIGNALS OF ALL DEVICES FOR WHICH THIS CIRCUIT GATES
$\bar{W}$. THIS MAY ENTAIL A SIMPLE OR FUNCTION. IN CASE OF A SINGLE EEROM, THE TWO SIGNALS WOULD BE COMMON.

TYPICAL EEROM WRITE/ERASE ROUTINE


## PACKAGE DIMENSIONS

## 28-PIN CERDIP



| DIM | MILLIMETERS |  | INCHES |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 36.32 | 37.34 | 1.430 | 1.470 |  |
| B | 12.95 | 13.46 | 0.510 | 0.530 |  |
| C | 3.68 | 4.19 | 0.145 | 0.165 |  |
| D | 0.41 | 0.51 | 0.016 | 0.020 |  |
| F | 1.27 | 1.52 | 0.050 | 0.060 |  |
| G | 2.54 |  | BSC | 0.100 BSC |  |
| J | 0.20 | 0.30 | 0.008 | 0.012 |  |
| J | 0.20 | 0.30 | 0.008 | 0.012 |  |
| K | 3.18 | 4.19 | 0.125 | 0.165 |  |
| L | 16.13 | 17.41 | 0.635 | 0.685 |  |
| M | 15.24 | 15.75 | 0.600 | 0.620 |  |
| N | 0.89 | 1.14 | 0.035 | 0.045 |  |

## R2816A and R5516A $16 \mathrm{~K}(2 \mathrm{~K} \times 8)$ LATCHED EEPROM WITH TIMER

## FEATURES

- High endurance erase/write cycles
- 1,000,000 cycles per byte (R5516A)
- 10,000 cycles per byte (R2816A and R2816AH)
- 5 volt-only operation
- On-chip latches for direct microprocessor bus interface
- On-chip timer for self-completed byte erase and write
- Fast byte write cycle
- 2 ms write (R2816AH)
- 10 ms write (R2816A and R5516A)
- Fast access time: $250 \mathrm{~ns}, 300 \mathrm{~ns}, 350 \mathrm{~ns}$ (max.)
- TTL voltage level controlled modes
- Byte read
- Byte write with automatic byte erase
- Read/write inhibit
- Optional high voltage controlled modes
- Byte erase
- Byte write
- 9 ms chip clear
- Power up/down protection circuitry
- Low power operation
- 110 mA (max.) active current
- 40 mA (max.) standby current
- JEDEC approved 24-pin byte-wide pinout
- Direct replacement for $2 \mathrm{~K} \times 8$ EEPROMs
-21V 2816
- 5V 2816A and 5516A


## ORDERING INFORMATION

| Part Number: R2816A |
| :---: |
| R5516A |
| $\qquad$Access Time <br> 25 <br> 3 |
| $3=250 \mathrm{~ns}$ |
| $35=350 \mathrm{~ns}$ |
| Byte Write time |
| H $=2 \mathrm{~ms}$ (R2816AH only) |
| No letter $=10 \mathrm{~ms}$ |

## DESCRIPTION

The Rockwell R2816A and R5516A are 16K ( $2 \mathrm{~K} \times 8$ ) electrically erasable programmable read-only memory (EEPROM) devices with on-chip latches and write timer. EEPROMs allow non-volatile storage of data when power is off and in-circuit reading and writing of data when power is on.
The R2816A and R5516A both operate with TTL level signals and a 5 -volt power supply. The endurance, the number of times that a byte may be written to a particular location, is 1 million for the R5516A and 10 thousand for the R2816A. Once written, there is no limit to the number of times that the data may be read.

Both EEPROMs have an internal timer that automatically times out the write time. The on-chip timer, along with the latching of address and data lines, allows the EEPROM to complete write operation independently of the MPU. After executing a write


R2816A and R5516A Block Diagram
instruction to the EEPROM, the MPU is thus free to continue other computational tasks without delay or interruption required by earlier generation EEPROMs. The write operation is completed automatically, taking only 10 ms for the R2816A and R5516A, or only 2 ms for the faster R2816AH. A separate erase cycle is not required and the Write Enable $(\bar{W})$ pulse width requirement is only 150 ns (max.).

The R2816A EEPROM is the cost-effective choice for applications requiring infrequent updating of non-volatile data, i.e., no more than 10,000 updates/byte. The R5516A is ideal for designs employing frequent update of data.

| AO-A10 | ADDRESS |
| :---: | :--- |
| $\overline{\mathrm{E}}$ | CHIP ENABLE |
| $\overline{\mathrm{G}}$ | OUTPUT ENABLE |
| $\overline{\mathrm{W}}$ | WRITE ENABLE |
| DQ0 - DQ7 | DATA INPUT (WRITE OR ERASE) <br>  DATA OUTPUT (READ) |

R2816A and R5516A Pin Names

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.5 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.5 to +7.0 | Vdc |
| Output Voltage | $\mathrm{V}_{\mathrm{OUT}}$ | -0.5 to +7.0 | Vdc |
| Temperature Under Bias | $\mathrm{T}_{\mathrm{STG}}$ | -10 to +80 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\mathrm{STG}}$ | -65 to +100 | ${ }^{\circ} \mathrm{C}$ |
| $\overline{\mathrm{W}}$ Level in Optional <br> High Voltage Byte Erase/ <br> Write and Chip Clear Modes | $\mathrm{V}_{\mathrm{W}}$ | -0.5 to +22.5 | Vdc |
| $\overline{\mathrm{W}}$ or $\overline{\mathrm{G}}$ Max. Duration at 22 V | $\mathrm{t}_{\mathrm{W}}, \mathrm{t}_{\mathrm{G}}$ | 24 | Hrs |
| $\overline{\mathrm{G}}$ Level in Optional <br> HV Chip Clear Mode | $\mathrm{V}_{\mathrm{G}}$ | -0.5 to 22.5 | Vdc |



## R2816A and R5516A Pin Configuration

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

OPERATING CONDITIONS

| Parameter | All Modes |
| :---: | :---: |
| $\mathrm{V}_{\mathrm{CC}}$ Supply Voltage | $5 \mathrm{~V} \pm 10 \%$ |
| Temperature Range | 0 to $70^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise noted)

| Symbol | Parameter | Min. | Typ. ${ }^{2}$ | Max. | Unit | Test Conditions ${ }^{1}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IN | Input Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=5.5 \mathrm{~V}$ |
| lout | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5.5 \mathrm{~V}$ |
| $I_{\text {w }}$ | Write Enable Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\overline{\mathrm{W}}=\mathrm{V}_{\mathrm{W}}$ |
| $I_{G}$ | Output Enable Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{G}}$ |
| lcCl | $\mathrm{V}_{\mathrm{CC}}$ Standby Current |  | 18 | 40 | mA | $\overline{\bar{E}}=V_{1 H}, \overline{\mathrm{G}}=V_{\mathrm{IL}}$ <br> All I/O lines open, other inputs $=5.5 \mathrm{~V}$ |
| $\mathrm{ICC2}$ | $\mathrm{V}_{\mathrm{CC}}$ Active Current |  | 60 | 110 | mA | $\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{l}}$ <br> All I/O lines open, other inputs $=5.5 \mathrm{~V}$ |
| $\mathrm{V}_{1 \mathrm{~L}}$ | Input Low Voltage | -0.1 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{cc}}+1$ | V |  |
| $\mathrm{V}_{\mathrm{w}}$ | $\overline{\mathrm{W}}$ Input High Voltage in Optional HV Byte Erase/Write and HV Chip Clear Modes | 12 |  | 22 | V |  |
| $\mathrm{V}_{G}$ | $\overline{\mathrm{G}}$ Input High Voltage in Optional HV Chip Clear Mode | 12 |  | 22 | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.45 | V | $\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{IOH}=-400 \mu \mathrm{~A}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance ${ }^{3}$ |  |  | 7 | 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}, \mathrm{f}=1 \mathrm{MHz}$ |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance ${ }^{3}$ |  |  | 10 | pF |  |
| Notes: <br> 1. Test Conditions: Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$; Input Rise and Fall Times: $\leq 20 \mathrm{~ns}$; Input Pulse Levels: 0.45 V to 2.4 V ; Timing Measurement Reference Level: Inputs: 1 V and 2 V , Outputs: 0.8 V and 2 V <br> 2. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$. <br> 3. This parameter is periodically sampled and is not $100 \%$ tested. |  |  |  |  |  |  |

## EEPROM OPERATION

The Rockwell R2816A and R5516A EEPROMs have four modes of TTL level controlled operation (Table 1) and three optional high voltage level controlled modes (Table 2). The standby, byte read, byte write, and write/read inhibit modes are controlled by TTL levels on the Chip Enable ( $\overline{\mathrm{E}})$, Output Enable $(\overline{\mathrm{G}})$ and Write Enable ( $\bar{W}$ ) inputs. These modes support operations in costsensitive designs where minimal supporting circuitry is required.

The optional high voltage controlled modes allow R2816A/ R5516A operation in circuits designed for earlier generation EEPROMs. A high voltage ( $12-22 \mathrm{~V}$ ) on $\bar{W}$ supports separate byte erase and byte write operations required by prior EEPROM designs. The chip clear mode requires high voltage inputs on two control pins ( $\bar{W}$ and $\bar{G}$ ).

## TTL LEVEL CONTROLLED MODES

## BYTE READ

The byte read mode drives the data line outputs (DQ0-DQ7) with the contents of the EEPROM byte located by input address lines A0-A10. Read access time is 250 ns or less (R2816A-25/ R5516A-25).

A byte is read by stabilizing address lines A0-A10, applying a TTL low to $\bar{E}$ to enable the device, and applying TTL low to $\bar{G}$ to enable the data output drivers. Output data is valid on DQ0-DQ7 after $t_{\text {AVDV }}, \mathrm{t}_{\mathrm{ELDV}}$, or $\mathrm{t}_{\mathrm{QLDV}}$ time, whichever is limiting. $\bar{W}$ is held at TTL high throughout the cycle.

## STANDBY

The standby mode reduces R2816A/R5516A power dissipation by over 60\% (maximum ICC drops from 110 mA to 40 mA ).

A TTL high on $\bar{E}$ places the R2816A/R5516A in the standby mode regardless of the $\bar{G}$ or $\bar{W}$ input levels. The data output lines are in a high impedance state in this mode.

## BYTE WRITE

The TTL controlled byte write cycle performs both a byte erase (all bits are written to the 1 state) and a byte write (all bits are written to the input data line states) in the same write cycle. A separate, preceding byte erase cycle is not required.

Table 1. TTL Modes Selection

| Mode | Control Pins |  |  | $\begin{gathered} \text { I/O Data } \\ \text { Lines } \\ \text { (DQ0-DQ7) } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
|  | Chip Select (E) | Output Enable ( $\overline{\text { G }})$ | Write Enable (W) |  |
| Byte Read | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{D}_{\text {OUT }}$ |
| Standby | $V_{\text {IH }}$ | No Effect | No Effect | High Z |
| Byte Write | $\mathrm{V}_{12}$ | $\mathrm{V}_{\mathrm{IH}}$ |  |  |
| Write/Read Inhibit | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{1 \mathrm{H}}$ | $\mathrm{V}_{\text {IH }}$ | High Z |

Note: No Effect = No effect on logic selection, however, no voltage level other than TTL levels shall be applied.

Applying a TTL low to the $\bar{W}$ input of the selected EEPROM ( $\bar{E}$ low) with the outputs disabled ( $\overline{\mathrm{G}}$ high) initiates the byte write cycle. The address is latched on the falling edge of $\bar{W}$ (or $\bar{E}$, whichever occurs later) and the data is latched on the rising edge of $\bar{W}$ (or $\bar{E}$, whichever occurs first). The EEPROM uses the internal timer to automatically complete the byte erase and write operation without intervention from the MPU.

## WRITE OR READ INHIBIT

Applying a TTL low to $\bar{E}$ with both $\bar{G}$ and $\bar{W}$ held at TTL high enables the EEPROM but inhibits both reading from, and writing to, the device.

## OPTIONAL HIGH VOLTAGE CONTROLLED MODES

## HV BYTE ERASE OR BYTE WRITE

The high voltage byte erase or write mode operates the same as the TTL level controlled byte write mode with the following exceptions:

1. The active W voltage level is $12-22 \mathrm{~V}$ rather than TTL low.
2. A separate byte erase cycle must be performed with all data bits set to 1 (data lines are TTL high) prior to the byte write cycle.

## HV CHIP CLEAR

The chip clear mode erases all data in the R2816A/R5516A to the 1 state (TTL high) in 10 ms .

When the device is enabled, raising $\bar{W}$ and $\overline{\mathrm{G}}$ to a high voltage level (12-22V) initiates the chip clear mode. Dropping $\bar{W}$ below the high voltage minimum level terminates the mode. The data lines must be held at TTL high.

## POWER UP/DOWN WRITE PROTECTION

Internal circuitry protects the R2816A/R5516A against a false write during VCC power application or removal. This circuitry prevents writing under any of the following conditions:

1. VCC is less than 3 V .
2. A negative transition on $\bar{W}$ does not occur when VCC is between 3 V and 5 V .

Table 2. Optional High Voltage (HV) Modes Selection

|  | Control Pins |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Mode | Chip <br> Select <br> $(\overline{\mathrm{E}})$ | Output <br> Enable <br> $(\overline{\mathrm{G}})$ | Write <br> Enable <br> $(\overline{\mathrm{W}})$ |  |
| HV Byte Erase | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{W}}$ | $\mathrm{V}_{\mathrm{IH}}$ |
| HV Byte Write | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{IH}}$ | $\mathrm{V}_{\mathrm{W}}$ | $\mathrm{D}_{\mathrm{IN}}$ |
| HV Chip Clear | $\mathrm{V}_{\mathrm{IL}}$ | $\mathrm{V}_{\mathrm{G}}$ | $\mathrm{V}_{\mathrm{W}}$ | $\mathrm{V}_{\mathrm{IH}}$ |

## AC CHARACTERISTICS

$\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ (unless otherwise specified)

## BYTE READ

| Symbol | Parameter | Limits (ns) |  |  |  |  |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | $\begin{aligned} & \text { R5516A-25 } \\ & \text { R2816A-25 } \end{aligned}$ |  | $\begin{aligned} & \text { R5516A-3 } \\ & \text { R2816A-3 } \end{aligned}$ |  | R2816A-35 |  |  |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $t_{\text {AVAX }}$ | Read Cycle Time | 250 |  | 300 |  | 350 |  | ns |
| telov | Chip Enable ( $\overline{\mathbf{E}})$ Access Time ( $\mathrm{t}_{\text {CE }}$ ) |  | 250 |  | 300 |  | 350 | ns |
| $\mathrm{t}_{\text {avar }}$ | Address Access Time ( $\mathrm{t}_{\text {ACC }}$ ) |  | 250 |  | 300 |  | 350 | ns |
| t GLov | Output Enable ( $\overline{\mathrm{G}}$ ) Access Time ( $\mathrm{t}_{\mathrm{OE}}$ ) |  | 90 | , | 100 |  | 100 | ns |
| $\mathrm{t}_{\text {EHaz }}$ | $\overline{\mathbf{E}}$ to Output in High Z | 10 | 100 | 10 | 100 | 10 | 100 | ns |
| $\mathrm{t}_{\text {GHaz }}$ | $\overline{\mathrm{G}}$ to Output in High Z (t ${ }_{\text {DF }}$ ) | 10 | 100 | 10 | 100 | 10 | 100 | ns |
| $t_{\text {AXQX }}$ | Output Hold from Address Change ( $\mathrm{t}_{\mathrm{OH}}$ ) | 50 |  | 50 | - | 50 |  | ns |
| $\mathrm{t}_{\mathrm{pu}}$ | $\overline{\mathrm{E}}$ Low to Power-Up Time | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {PD }}$ | $\bar{E}$ High to Power Down Time |  | 50 |  | 50 |  | 50 | ns |

Notes:

1. Test Conditions: Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$; Input Rise and Fall Times: $\leq 20$ ns; Input Pulse Levels: 0.45 V to 2.4 V ; Timing Measurement Reference Level: Inputs: 1 V and 2 V , Outputs: 0.8 V and 2 V .
2. $\bar{G}$ low may be delayed up to $t_{G L Q v}$ after the falling edge of $\bar{E}$ without impact on $t_{A V Q V}$.
3. $t_{E H Q Z}$, and $t_{G H Q Z}$ are specified from $\bar{G}$ or $\bar{E}$ high whichever occurs first.

## BYTE READ WAVEFORMS



## BYTE WRITE TIMING

| Symbol | Parameter |  | $\begin{aligned} & \text { R5516A-25 } \\ & \text { R2816A-25 } \end{aligned}$ |  | $\begin{aligned} & \text { R5516A-3 } \\ & \text { R2816A-3 } \end{aligned}$ |  | R2816A-35 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Q | Maximum Endurance | R5516A | 1,000,000 |  | 1,000,000 |  | - |  | cycles/ bytes |
|  |  | R2816A, R2816AH | 10,000 |  | 10,000 |  | 10,000 |  |  |
| $t_{\text {wC }}$ | Write Cycle Time | R2816AH | 2 |  | 2 |  | - |  | ms |
|  |  | R5516A, R2816A | 10 |  | 10 |  | 10 |  |  |
| $\mathrm{t}_{\text {AVWL }}$ | Address Setup Time |  | 10 |  | 10 |  | 10 |  | ns |
| $t_{\text {WLAX }}$ | Address Hold Time |  | 50 |  | 70 |  | 70 |  | ns |
| $t_{\text {ELWL }}$ | Write Setup Time |  | 0 |  | 0 |  | 0 |  | ns |
| $t_{\text {WHEX }}$ | Write Hold Time |  | 0 |  | 0 |  | 0 |  | ns |
| $\mathrm{t}_{\text {GHWL }}$ | $\overline{\mathrm{G}}$ Setup Time |  | 10 |  | 10 |  | 10 |  | ns |
| $t_{\text {WHGX }}$ | $\overline{\mathrm{G}}$ Hold Time |  | 10 |  | 10 |  | 10 |  | ns |
| $t_{\text {WLWH }}$ | $\overline{\text { W Write Pulse Width }}{ }^{1}$ |  | 150 |  | 150 |  | 50 |  | ns |
| $\mathrm{t}_{\text {WHWX }}$ | Data Latch Time |  | 50 |  | 50 |  | 50 |  | ns |
| twLov | Data Valid Time ${ }^{2}$ |  |  | 1 |  | 1 |  | 1 | $\mu \mathrm{S}$ |
| tovwh | Data Setup Time |  | 20 |  | 50 |  | 50 |  | ns |
| $t_{\text {WHDX }}$ | Data Hold Time |  | 20 |  | 20 |  | 20 |  | ns |

## Notes:

1. $\overline{\mathrm{W}}$ is noise protected. Less than a 20 ns write pulse will not activate a write cycle.
2. Data must be valid within $1 \mu \mathrm{~s}$ maximum after the initiation of a write cycle.

## BYTE WRITE WAVEFORMS



DQ0-DQ7
HIGH $Z$
(DATA OUT)


HIGH VOLTAGE BYTE ERASE/WRITE TIMING

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {AVWV }}$ | Address Valid to $\bar{W}$ HV Setup Time ( $t_{\text {AS }}$ ) | 150 |  |  | ns |  |
| $t_{\text {ELWV }}$ | $\overline{\mathrm{E}}$ Low to $\overline{\mathrm{W}}$ HV Setup Time ( $\mathrm{t}_{\mathrm{CS}}$ ) | 150 | , |  | ns |  |
| $\mathrm{t}_{\text {GHWV }}$ | G High to $\bar{W}$ HV Setup Time | 0 |  |  | ns | $\overline{\mathrm{w}}=6 \mathrm{~V}$ |
| town | Data Valid to $\bar{W}$ HV Setup Time ( $\mathrm{t}_{\text {DS }}$ ) | 0 |  |  | ns |  |
| $t_{\text {wvwx }}$ | $\overline{\text { W }}$ HV Pulse Width | 9 | 10 | 70 | ms |  |
| ${ }_{\text {t }}^{\text {w }}$ | $\overline{\text { W }}$ Fall Time | 5 |  |  | $\mu \mathrm{S}$ | $\overline{\mathrm{w}}=6 \mathrm{~V}$ |
| ${ }_{\text {twhax }}$ | G Hold Time | 0 |  |  | ns |  |
| ${ }_{\text {WHHDX }}$ | Data Hold Time (tor) | 50 |  |  | ns | $\bar{W}=6 \mathrm{~V}$ |
| $t_{\text {WHEH }}$ | $\overline{\mathrm{W}}$ Recovery Time ( ${ }_{\text {wR }}$ ) | 50 |  |  | ns | $\overline{\mathrm{W}}=6 \mathrm{~V}$ |
| ${ }_{\text {WHHAX }}$ | Address Hold Time | 50 |  |  | ns | $\overline{\mathrm{W}}=6 \mathrm{~V}$ |

## HIGH VOLTAGE BYTE ERASE/WRITE WAVEFORMS



HIGH VOLTAGE CHIP CLEAR TIMING

| Symbol | Parameter | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| telwv | $\overline{\mathrm{E}}$ Low to $\overline{\mathrm{W}} \mathrm{HV}$ Setup Time ( $\mathrm{t}_{\mathrm{CS}}$ ) | 10 |  |  | ns |  |
| $\mathrm{t}_{\text {Guw }}$ | $\overline{\mathrm{G}}$ HV to $\overline{\mathrm{W}}$ HV Setup Time | 10 |  |  | ns |  |
| $t_{\text {DHWV }}$ | Data High to W HV Setup Time ( $\mathrm{t}_{\text {SS }}$ ) | 0 |  |  | ns |  |
| ${ }_{\text {twww }}$ | $\overline{\text { W }}$ HV Pulse Width | 9 | 10 | 70 | ms |  |
| $\mathrm{t}_{\text {WF }}$ | $\overline{\text { W }}$ Fall Time | 5 |  |  | $\mu \mathrm{S}$ | $\bar{W}=6 \mathrm{~V}$ |
| $\mathrm{t}_{\text {WHGX }}$ | $\overline{\mathrm{G}}$ Hold Time | 10 |  |  | ns | $\overline{\mathrm{W}}=6 \mathrm{~V}, \overline{\mathrm{G}}=12 \mathrm{~V}$ |
| $\mathrm{t}_{\text {WHDX }}$ | Data Hold Time ( $\mathrm{t}_{\mathrm{DH}}$ ) | 50 |  |  | ns | $\overline{\mathrm{w}}=6 \mathrm{~V}$ |
| $\mathrm{t}_{\text {WHEH }}$ | $\overline{\mathrm{W}}$ Recovery Time ( $\mathrm{twr}^{\text {a }}$ ) | 50 | ". |  | ns | $\overline{\mathrm{W}}=6 \mathrm{~V}$ |

## HIGH VOLTAGE CHIP CLEAR WAVEFORMS



## PACKAGE DIMENSIONS



DIMENSIONS IN INCHES AND

## R2000 <br> $64 \times 8$ NON-VOLATILE RAM

## Product Preview

## DESCRIPTION

The Rockwell R2000 Non-Volatile Random Access Memory (NVRAM) is a conventional $64 \times 8$ static random access memory (RAM) overlaid bit-for-bit with a $64 \times 8$ non-voltatile electrically eraseable programmable read only memory (EEPROM). The NVRAM combines the fast access read/write functions of static RAM with the permanent storage capability of EEPROM. STORE and RECALL commands, implemented as addresses to provide maximum user flexibility, initiate RAM to EEPROM and EEPROM to RAM data transfers. In response to the STORE command, the contents of the RAM are written into the EEPROM within 12 ms . In response to the RECALL command, the contents of the EEPROM are transferred to the RAM within $7.5 \mu \mathrm{~s}$. These commands require no additional control lines or external circuitry to support bus operation during power loss, thus greatly simplifying R2000 system design-in.

Three inputs can be variously strapped to cause the R2000's byte-wide parallel bus interface to operate in one of five different bus configurations. This enables the R2000 to operate with most industry standard microprocessors and single-chip microcomputers with extended buses.

R2000 applications include (1) saving of critical system data upon power failure, (2) permanent storage of instrument/machine selfrecalibration or transmitted parameters, (3) password storage, (4) replacement of DIP switches used for system configuration, and (5) automotive applications ranging from entry-codes to engine performance adjustments.

## FEATURES

- Byte-wide $64 \times 8$ organization
- Single 5 V power supply
- Low power dissipation
- 50 mA active current
- 10 mA STORE current
-25 mA standby current
- 10-Year data retention for each STORE
- Minimum 10,000 non-volatile STORE cycle endurance
- Microprocessor and microcontroller bus compatible
- Five strappable, directly compatible, bus interface configurations:
- R6500, R65C00, 6800 non-multiplexed bus
- Z80 non-multiplexed bus
- R65C00/21, 6801 multiplexed bus
- R6500/11, R6500/41 multiplexed bus
- 8051 multiplexed bus
- Software control of non-volatile functions
- Storage protection
- STORE and RECALL operation
- No additional control lines
- Only a single external capacitor required
- Fast static RAM access time:
- 125 ns (max.) for non-multiplexed bus
- 250 ns (max.) for multiplexed bus
- Reliable N -channel floating gate technology
- TTL compatible
- Self-timed STORE with power-down retention pin


R2000 Pin Configuration

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :--- | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +12.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\mathrm{IN}}$ | -0.3 to +12.0 | Vdc |
| Output Voltage | $\mathrm{V}_{\mathrm{OUT}}$ | -0.3 to +7.0 | Vdc |
| Temperature Under Bias | $\mathrm{T}_{\mathrm{A}}$ | -10 to +80 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -65 to +100 | $\circ^{\circ} \mathrm{C}$ |

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

## OPERATING CONDITIONS

| Parameter | All Modes |
| :---: | :---: |
| $V_{\text {CC }}$ Supply Voltage | $5 \mathrm{~V} \pm 5 \%$ |
| Temperature Range | 0 to $70^{\circ} \mathrm{C}$ |

## DC CHARACTERISTICS

( $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$, unless otherwise specified)

| Symbol | Parameter | Min. | Typ. ${ }^{2}$ | Max. | Unit | Test Conditions ${ }^{1}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}^{\mathrm{N}}$ | Input Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=\mathrm{GND} \text { to } 5.25 \mathrm{~V} \end{aligned}$ |
| lout | Output Leakage Current |  |  | 10 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=\mathrm{GND}$ to $\mathrm{V}_{\text {CC }}$ Max. |
| $\mathrm{I}_{\mathrm{RR}}$ | $\mathrm{V}_{\mathrm{RR}}$ Store Current |  |  | 10 | mA | $\begin{aligned} & \mathrm{V}_{\mathrm{RR}}=\mathrm{V}_{\mathrm{CC}}+0 \mathrm{~V},-0.25 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V} \end{aligned}$ |
| $\mathrm{I}_{\mathrm{CC} 1}$ | $\mathrm{V}_{\mathrm{CC}}$ Standby Current |  |  | 25 | mA | $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{H}}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{I}_{\mathrm{CC} 2}$ | $\mathrm{V}_{\mathrm{CC}}$ Active Current |  |  | 50 | mA | $\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{IL}}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ |
| $\mathrm{V}_{\text {RR }}$ | $\mathrm{V}_{\text {RR }}$ Supply Voltage | 4.0 |  | 5.25 | V | STORE Cycle, $\mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}$ |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.3 |  | 0.8 | V |  |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.0 |  | $\mathrm{V}_{\mathrm{CC}}+1$ | V |  |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage |  |  | 0.4 | V | $\mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 |  |  | V | $\mathrm{I}_{\mathrm{OH}}=-0.3 \mathrm{~mA}$ |
| $\mathrm{C}_{\text {IN }}$ | Input Capacitance |  |  | 5 | pF | $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$, chip deselected, pin under test at 0 V , |
| $\mathrm{C}_{\text {OUT }}$ | Output Capacitance ${ }^{3}$ |  |  | 150 | pF | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}$ |

## Notes:

1. Test Conditions: Output Load: 1 TTL gate and $C_{L}=100 \mathrm{pF}$; Input Rise and Fall Times: $\leq 20 \mathrm{~ns}$; Input Pulse Levels: 0.45 V to 2.4 V ;

Timing Measurement Reference Level: Inputs: 1 V and 2 V , Outputs: 0.8 V and 2 V .
2. Typical values are for $T_{A}=25^{\circ} \mathrm{C}$ and $\mathrm{V}_{C C}=5.0 \mathrm{~V}$.
3. This parameter is periodically sampled and is not $100 \%$ tested.
4. All units are direct current (DC) except capacitance.

## SIGNAL DESCRIPTION

A0-A5 -Address Lines. The six address inputs select memory locations in RAM and initiate the STORE and RECALL commands. In a non-multiplexed bus configuration, these lines are assigned to the A0-A5 pins. In a multiplexed bus configuration, some, or all, of the address inputs are shared with the D0-D5 data lines.

D0-D7-Data Lines. When $\overline{\mathrm{E}}$ is LOW, the eight bidirectional, three-state, data lines transfer data from the R2000 RAM to the data bus during a read operation, or from the data bus to the R2000 during a write operation. When $\bar{E}$ is HIGH, the data lines are in a high impedance state. In a multiplexed bus configuration, some of the data lines double as address lines.
$\bar{E}$-Chip Enable. $\bar{E}$ LOW input enables RAM read and write operation, as well as STORE and RECALL initiation. When $\bar{E}$ is HIGH, the R2000 is disabled and operates in a low-power standby mode. In the standby mode the R2000 consumes almost $50 \%$ less power than in the active mode. The data output lines are in a high impedance state during standby mode.

Ø2(WR)-Clock/(Write). This pin acts as either the Clock (ø2) or Write Enable (WR) input depending on bus interface configuration. When configured for an $6500 / 6800$ bus, $\varnothing 2$ clocks data in or out of the R2000 depending on the level of $R / \bar{W}$. When configured for an Z80/8051 bus, WR LOW (and RD HIGH) enables data to be written from the data lines into the R2000.
$\mathbf{R} / \overline{\mathbf{W}}(\overline{\mathrm{RD}})$-Read/Write (Read). This input pin serves as either Read/Write ( $\mathrm{R} / \overline{\mathrm{W}}$ ) or Read Enable ( $\overline{\mathrm{RD}}$ ) depending upon the bus interface configuration. When configured for an $6500 / 6800$ bus, R $\bar{W}$ HIGH enables data to be read from R2000 RAM to the data lines, whereas R $\bar{W}$ LOW enables data to be written from the data lines into the R2000. When configured for an Z80/8051 bus, $\overline{R D}$ LOW (and WR HIGH) enables data to be written from the R2000 RAM to the data bus.

NC(AS/ALE)-No Connect (Address Strobe/Address Latch Enable). This pin is used only with a multiplexed bus. A HIGH on this pin-AS for an R6500/* bus, or ALE for the 8051 busindicates that a valid address exists on the data/address lines.

MPX-Multiplex. The MPX, BC1 and BC2 inputs determine the bus interface configuration. MPX HIGH selects a multiplexed bus, whereas MPX LOW selects a non-multiplexed bus.

BC1, BC2-Bus Configuration 1 and 2. The BC1 and BC2 inputs, in conjunction with the MPX input, determine the bus interface configuration. Table 2 defines the specific bus selected by strapping each of these three inputs to either $\mathrm{V}_{\mathrm{CC}}$ or GND.
$\mathbf{V}_{\mathbf{R R}}$-STORE Power Supply. This power down retention pin is normally connected to an external $470 \mu \mathrm{~F}$ capacitor. The capacitor retains enough power to write the data from RAM into EEPROM when STORE is commanded upon loss of $V_{C C}$.
$V_{\text {cc }}$-Power. +5 Vdc .
GND-Ground. Ground.

## FUNCTIONAL DESCRIPTION

The major functions in the R2000 NVRAM are (1) the volatile static RAM with its associated address decode, sense and read circuitry, write control circuitry, and input receivers/output drivers; (2) the non-volatile EEPROM with its associated STORE and RECALL control circuit, and high voltage generator; and (3) the bus interface configuration logic. A block diagram of the R2000 NVRAM is shown in Figure 1.


Figure 1. R2000 Block Diagram

## RAM

The 64 bytes of volatile RAM are located at addresses 0 to $3 F$ (hexadecimal) as decoded from address lines A0-A5. Locations 0 and 1 in RAM are not accessible since addresses 0 and 1 correspond to the STORE and RECALL commands, respectively. The remaining bytes are available for general read/write access. Table 1 summarizes the memory map and the command operations.

During normal operation, the RAM operates at bus speed without affecting the contents of the EEPROM. RAM accesses are controlled by $\bar{E}, \emptyset 2(\overline{W R}), R / \bar{W}(\overline{R D})$, and (AS/ALE) inputs depending on the strapped bus configuration.

## EEPROM

The 64 bytes of non-volatile EEPROM shadow the static RAM cell-for-cell. Shadowing means that the RAM array is overlaid bit-fot-bit with the EEPROM array. The EEPROM operates in parallel with the static RAM during a STORE or RECALL thus providing immediate storage and retrieval. The first two bytes are not used because the corresponding addresses are used for the STORE and RECALL commands.

## STORE SECURITY KEY

The STORE and RECALL circuit controls the transfer of data between the RAM and the EEPROM. When a STORE command is received, i.e., address 0 is written with the value B5 (hexadecimal) on the data lines, data is copied from RAM to the EEPROM. The B5 value, called the STORE security key, is saved in an internal register during the STORE process. Once initiated, the STORE process completes under internal control and cannot be interrupted by an external signal. Access to the RAM from the data bus is inhibited during this time (indeterminate data will be output to the data bus if a read is attempted) and is re-enabled at the completion of the STORE. After STORE is complete-less than 12 ms after receipt of the STORE command-the B5 value is erased to prevent an inadvertent STORE from occurring due to an unintentional generation of address 0 . Internal R2000 circuitry also prevents alteration of EEPROM contents during $V_{C C}$ and $V_{R R}$ decay following power loss, and during $\mathrm{V}_{\mathrm{CC}}$ and $\mathrm{V}_{\mathrm{RR}}$ rise after power application.

When a RECALL command is received, i.e., any data is written to address 1, data in the EEPROM is copied to the RAM. The RECALL time takes less than $7.5 \mu \mathrm{~s}$.

Table 1. R2000 NVRAM Memory Map

| Address (Hex.) | Read/ Write | Data Value | Function |
| :---: | :---: | :---: | :---: |
| 00 | Write | B5 | STORE RAM to EEPROM. The RAM byte at this location is not accessible. The B5 data value is required to initiate the STORE sequence. |
|  | Read | - | No operation. |
| 01 | Write | Any | RECALL RAM from EEPROM. RAM data at this location is not accessible. |
|  | Read | - | No operation |
| 02-3F | Write | Any | Write data to RAM locations 02-3F. |
|  | Read | Any | Read data from RAM locations 02-3F. |

## STORE AND RECALL EXECUTION

Read and write instructions can be executed in the application program to STORE and RECALL data either during normal operation or upon detection of power loss or turn-on. If performed as a part of normal operation, the STORE and RECALL instructions can be executed either periodically or upon demand. If performed as a part of power on/off processing, the STORE instruction should be executed as part of the power loss detect interrupt handling routine, and the RECALL instruction executed as part of the power turn-on processing.

## $\mathbf{V}_{\text {RR }}$ CONNECTION

The $\mathrm{V}_{\mathrm{RR}}$ pin is normally connected to an external $470 \mu \mathrm{~F}$ (min.), 15 V capacitor. The capacitor, charged through internal circuitry to a value of $\mathrm{V}_{\mathrm{CC}}-0.25 \mathrm{~V}$, contains enough energy to complete a STORE operation upon loss of $\mathrm{V}_{\mathrm{CC}}$. An internal current limiting switch prevents a large inrush current to the capacitor upon power turn-on. An internal power switch connected to $\mathrm{V}_{\mathrm{CC}}$ opens during a STORE operation and when $\mathrm{V}_{\mathrm{CC}}$ drops below $V_{\text {RR }}$ to inhibit current drain from the capacitor into the $\mathrm{V}_{\mathrm{CC}}$ power grid.

If the $\mathrm{V}_{\mathrm{CC}}$ power grid has enough stored energy to support R2000 operation for at least 12 ms after the processor detects power loss and initiates a STORE, the $\mathrm{V}_{\mathrm{RR}}$ pin can be connected to $\forall_{C C}$ rather than the capacitor.

## SYSTEM CONNECTION

Figure 2 shows a typical system connection using an R6502 CPU, 4K x 8 static RAM, system decode logic, on an R2000 NVRAM.


Figure 2. Typical System Interface

## BUS CONFIGURATIONS

Strapping MPX, BC1, BC2 inputs high ( $\mathrm{V}_{\mathrm{CC}}$ or low (GND) configures the R2000 bus interface to operate with one of five different busses as specified in Table 2. Figure 3 shows the five possible configurations.

Table 2. Bus Configuration Strapping

| Pin Connections |  |  |  |
| :---: | :---: | :---: | :--- |
| MPX | BC2 | BC1 |  |
| LOW | LOW | LOW | R6500, R65C00, 6800 Non-multiplexed |
| LOW | LOW | HIGH | Z80 Non-multiplexed |
| HIGH | LOW | LOW | R65C00/21, 6801 Multiplexed |
| HIGH | HIGH | LOW | R6500/11, R6500/41 Multiplexed |
| HIGH | LOW | HIGH | $8085 / 8051$ Multiplexed |
| Note: Low $=$ GND, High $=V_{\text {CC }}$ |  |  |  |


|  |
| :---: |
|  |

Figure 3. Five Possible Strapping Configurations

## PACKAGE DIMENSIONS



DIMENSIONS IN INCHES AND (MILLIMETERS)

## EPROM PINOUTS GUIDE



## SECTION 5 INTELLIGENT DISPLAY CONTROLLERS

Page
Product Family Overview ..... 5-2
10937 Alphanumeric Display Controller ..... 5-3
10938 and 10939 Dot Matrix Display Controller ..... 5-11
10939, 10942 and 10943 Dot Matrix Display Controller ..... 5-20
10941 and 10939 Alphanumeric and Bargraph Display Controller ..... 5-32
10951 Bargraph and Numeric Display Controller ..... 5-41

# INTELLIGENT DISPLAY CONTROLLERS Cut Costs 30¢/digit, Replace Up To 11 TTL Devices, Interface With Any Host $\mu \mathrm{C}$ 

Rockwell display controllers drastically cut the cost and complexity of designing vacuum fluorescent (VF) displays into systems, can actually save up to 30 cents per digit. One 10937 can replace up to eleven TTL devices and can interface with any host microcomputer. VF Display manufacturers Futaba, NEC, and Noritake have all specified these controllers.
The 10937 is a single-chip alphanumeric display controller which directly drives 14 to 18 segment VF displays of up to 16 characters. It includes brightness and refresh controls and logic, its own RAM buffer, PLA segment decoder, and output driver.

The 10951 single-chip display controller is similar to the 10937 except the PLA segment decoder has been reprogrammed to drive a bar graph display and numerics.

If neither the 10937 nor the 10951 PLA segment codes satisfy the user's requirements, a custom code may be specified for the single-chip display controller.

The 10938 segment decoder/driver and the 10939 digit controller/driver operate as a set to drive dot matrix displays. A single set controls $5 \times 7$ dot matrix displays of up to 20 characters or cascaded to control up to

80 characters. Operating at 50V, the sets can drive VF displays and, with external drivers, LED, CCD, gas discharge and incandescent displays.
The 10941 can team with the 10939 to drive alphanumeric 14-18 segment VF displays of 20 to 40 characters and bar graphs. The 10942 and 10943 can team with the 10939 to drive 40 to 80 character $5 \times 12$ dot matrix displays.
The Rockwell display controllers are finding wide application in printers, photo copiers, typewriters, FAX machines and in various automotive and white goods uses. If the user has special requirements, a custom code may be specified for the segment decoder/driver device which can be packaged in a 40,28 , or 24 pin DIP according to the device type selected.

A new single-chip controller is under development which will be similar to the 10937/10951 devices except the user will have some control over the number of display outputs allocated as strobes or segments, the PLA will be doubled in size to allow 128 characters and the PLA may be bypassed to allow direct control of segments.

VACUUM FLUORESCENT CONTROLLER APPLICATIONS

| Display Type | Single Chip <br> Display <br> Controller <br> (See Part No.) | Multi-Chip Display Controller |  |
| :---: | :---: | :---: | :---: |
|  |  | Anode Driver Type (See Part No.) | Grid Driver (10939) |
| - 8 Char. 14-18 Seg. <br> - 10 Char. 14-18 Seg. <br> - 16 Char. 14-18 Seg. <br> - 20 Char. 14-18 Seg. <br> - 32 Char. 14-18 Seg. <br> - 40 Char. 14-18 Seg. | $\begin{aligned} & 1 \text { (10937) } \\ & 1 \text { (10937) } \\ & 1 \text { (10937) } \end{aligned}$ | $\begin{aligned} & 1(10941)^{*} \\ & 1(10941)^{*} \\ & 1(10941)^{*} \end{aligned}$ | $\begin{aligned} & 1 \\ & 2 \\ & 2 \end{aligned}$ |
| - 20 Char. $5 \times 7$ MTX <br> - 32 Char. $5 \times 7$ MTX <br> - 40 Char. $5 \times 7$ MTX <br> - 40 Char. $5 \times 12$ MTX <br> - 80 Char. $5 \times 7$ MTX <br> - 80 Char. $5 \times 12$ MTX |  | $1(10938)$ $1(10938)$ $1(10938)$ 1 EA $(10942)$ $(10943)$ $1(10938)$ 1 EA $(10942)$ $(10943)$ | $\begin{aligned} & 1 \\ & 2 \\ & 2 \\ & 2 \\ & 4 \\ & 4 \\ & 4 \end{aligned}$ |
| - Numeric + Bar Graph | 1 (10951) |  |  |

[^15]
## 10937

ALPHANUMERIC DISPLAY CONTROLLER

## PRELIMINARY

## DESCRIPTION

The 10937 Alphanumeric Display Controller, one of the Rockwell Intelligent Display Controller products, is a MOS/LSI general purpose display controller designed to interface to segmented displays (gas discharge, vacuum fluorescent, or LED).

The 10937 will drive displays with up to 16 characters with 14 or 16 segments plus a decimal point and comma tail. Segment decoding within the device provides for the ASCII character set (upper case only). No external drive circuitry is required for displays that operate on 10 ma of drive current up to 40 volts. A $16 \times 64$-bit segment decoder provides internal ASCII character set decoding for the display.

## FEATURES

- 16 character display driver with decimal point and comma tail
- 14 or 16 segment drivers
- Average data rate: 66 KHz
- Single character burst rate: 500 KHz
- TTL compatible
- Direct digit drive of 10 ma for 30,35 , and 40 volt displays
- Supports gas-discharge, vacuum fluorescent, or LED displays
- $64 \times 16$-bit PLA provides segment decoding for ASCII character set (all caps only)
- Serial data input for 8-bit display and control data words.
- 40-Pin DIP

ORDERING INFORMATION

| Part <br> Number | Package <br> Type | Drive <br> Voltage | Temperature <br> Range |
| :--- | :---: | :---: | :---: |
| $10937 \mathrm{P}-30$ | Plastic | 30 V | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| $10937 \mathrm{P}-35$ | Plastic | 35 V | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| $10937 \mathrm{P}-40$ | Plastic | 40 V | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| $10937 \mathrm{PE}-30$ | Plastic | 30 V | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| $10937 \mathrm{CE}-35$ | Plastic | 35 V | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| $10937 \mathrm{PE}-40$ | Plastic | 40 V | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |



10937 Block Diagram

## INTERFACE DESCRIPTION

## SPECIFICATIONS

## Maximum Ratings

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :--- | :--- | :--- | :--- | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{DD}}$ | +0.3 |  | -20 | V |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ |  | 40 | 100 | mW |
| Input Voltage | $\mathrm{V}_{\text {IN }}$ | +0.3 |  | -20 | V |
| Output Voltage | $\mathrm{V}_{\text {OUT }}$ | +0.3 |  | -40 | V |
| Operating Temperature |  |  |  |  |  |
| $\quad$ Commercial | $\mathrm{T}_{\mathrm{C}}$ | 0 |  | +70 | ${ }^{\circ} \mathrm{C}$ |
| $\quad$ Industrial | $\mathrm{T}_{\mathrm{I}}$ | -40 |  | +85 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 |  | +125 | ${ }^{\circ} \mathrm{C}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ |  |  | 5 | pf |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ |  |  | 10 | pf |



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 to this circuit.

All voltages are specified relative to $\mathrm{V}_{\mathrm{Ss}}$.

## D.C. Characteristics

| Parameter | Limits ( $\mathbf{V s s}_{\text {ss }}=0$ ) |  |  | Limits ( $\mathrm{V}_{\mathrm{ss}}=+5 \mathrm{~V}$ ) |  |  | Conditions | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |  |
| Supply Voltage ( $\mathrm{V}_{\mathrm{DD}}$ ) | -16.5 | -15.0 | -13.5 | -11.5 | -10.0 | -8.5 |  | V |
| Input DATA, SCLK, |  |  |  |  |  |  |  | V |
| Logic "1" | -1.0 |  | +0.3 | +4.0 |  | +5.3 |  | V |
| Logic "0" | $V_{D D}$ |  | -4.2 | $V_{D D}$ |  | +0.8 |  |  |
| Input POR |  |  |  |  |  |  |  |  |
| Logic "1" | -3.0 |  | +0.3 | +2.0 |  | +5.3 |  |  |
| Logic "0" | $V_{D D}$ |  | -10.0 | $V_{D D}$ |  | +5.0 |  |  |
| Output Digit and |  |  |  |  | ; |  |  |  |
| Segment Strobes |  |  |  |  |  |  |  |  |
| Driver On |  |  |  |  |  |  |  |  |
| Commercial |  |  | -1.5 |  | * | +3.5 | At 10 mA | v |
| Industrial |  |  | -1.7 |  |  | +3.3 |  | v |
| Driver Off 10937-30 |  |  | -30 |  |  | -25 | $\} \begin{aligned} & \text { Actual value } \\ & \text { determined by }\end{aligned}$ | v |
| Driver Off 10937-35 |  |  | -35 |  |  | -30 | $\} \begin{aligned} & \text { determined by } \\ & \text { external circuit }\end{aligned}$ | v |
| Driver Off 10937-40 |  |  | -40 |  |  | -35 | ) external circuit | V |
| Output Leakage |  |  | 10 |  |  | 10 | $\}$ Per driver at | $\mu \mathrm{A}$ |
| Input Leakage |  |  | 10 |  |  | 10 | driver off | $\mu \mathrm{A}$ |
| NOTES: All outputs require Pulldown Resistors. |  |  |  |  |  |  |  |  |

## A.C. Characteristics

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Internal Clock (1 Bit Time) | $\mathrm{T}_{\text {cyc }}$ |  |  |  |  |
| Commercial |  | 6.67 | 10.0 | 20.0 | $\mu \mathrm{s}$ |
| Industrial |  | 5.88 | 10.0 | 22.2 | $\mu \mathrm{s}$ |
| Segment or Digit Strobe Output | Tout | 200 |  |  | ns |
| SCLK Clock |  |  |  |  |  |
| On Time | $T_{\text {on }}$ | 1.0 |  | 20.0 | $\mu \mathrm{S}$ |
| Off Time | $\mathrm{T}_{\text {off }}$ | 1.0 |  |  | $\mu \mathrm{s}$ |
| Data Input Sample Time |  |  |  |  |  |
| Before SCLK Clock Off | $\mathrm{T}_{\text {boff }}$ | 200 |  |  | ns |
| After SCLK Clock Off | $\mathrm{T}_{\text {aoff }}$ | 100 |  |  | ns |

## SCLK and Serial Data Timing SCLK

## SCLK and Serial Data (Control Word) Examples

sCLK


DATA


LOAD DUTY CYCLE = 11
dATA


LOAD BUFFER POINTER = 11

DATA


LOAD DIGIT COUNTER $\mathbf{= 1 5}$

NOTE: Crosshatch = don't care


## Power-On Reset Voltage Limits



## FUNCTIONAL DESCRIPTION

The 10937 is a general purpose display controller for multiplexed, segmented displays with up to 16 character positions and 14 or 16 segments, plus decimal point and comma tail. No external drive circuitry is needed for displays requiring up to 10 ma of drive current up to 40 volts. All timing signals required to control the display are generated in the 10937 device without any refresh input from the host processor.

Input data is loaded into the Display Data Buffer via the Serial Data Input (Data) channel. Internal timing and control blocks synchronize the segment and digit output signals to provide the proper timing for the multiplexing operation. A $16 \times 64$-bit PLA is provided for segment decoding for the full ASCII character set (upper case only).

Input data is loaded into the 10937 ADC as a series of 8 -bit words with the most significant bit (MSB), bit 7, first. If bit 7 of any word loaded is a logical 1 (this bit is referred to as the control bit C), the loaded word is a control data word. If the C bit of any word is a logical 0 , the loaded word is a display data word. The following paragraphs describe the format and functions of these control and display data words.

## INPUT CONTROL DATA WORDS

When the C-Bit (bit 7) of the 8-bit input word is a logical 1, bits 5 and 6 are decoded into one of four control commands while data associated with the command are extracted from bits 0-4 (see Table 1). There are three control codes which perform the following display functions:

- Load the Display Data Buffer pointer,
- Load the Digit Counter,
- Load the Duty Cycle register.

A fourth control code is defined but is not intended as a user function (see note associated with Table 1). Table 1 lists the control codes and their functions.

## Load Buffer Pointer

The LOAD BUFFER POINTER code allows the Display Data Buffer pointer to be set to any digit position so that individual characters may be modified. The LOAD BUFFER PTR is loaded with a decimal equivalent value 2 less than the desired value (i.e., to point to character 6 of the display, a value of 4 is entered).

## Load Digit Counter

The LOAD DIGIT COUNTER code is normally used only during initialization routines to define the number of character positions to be controlled. This code maximizes the duty cycle for any display. If 16 characters are to be controlled, enter a value of 0 (zero). Otherwise, enter the value desired.

## Load Duty Cycle

The LOAD DUTY CYCLE code is used to turn the display on and off, to adjust display brightness, or to modify display timing for gas discharge displays. As shown in the block diagram, the time slot for each character is 32 clock cycles. The Segment and Digit Drivers for each character are on for a maximum of 31 cycles with a 1 cycle inter-digit off-time. The LOAD DUTY CYCLE code contains a 5 -bit numeric field which modifies the on-time for segment Driver Outputs from 0 to 31 cycles. A duty cycle of 0 puts both the segment and digit drivers into the off state.

## INPUT DISPLAY DATA WORDS

Display data words are loaded as 8-bit ASCII format codes. The 64 codes available (with the C-bit set to 0 to indicate a display data word) are shown in Table 2 with their corresponding ASCII characters.

Sixteen display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer is automatically incremented before each data word is stored in the Display Buffer except for decimal point and comma words. These do not cause the Buffer Pointer to increment and thus are always associated with the previous character entered. To select the next character position to be loaded out of the normal sequence, use the LOAD BUFFER POINTER command before entering the display data word. It is not necessary to use the LOAD BUFFER POINTER command to cycle back to position 1 when less than 16 character positions are being used (DIGIT COUNTER $=0$ ).

Table 1. Control Data Words

| 8-Bit Control Word |  | Function |
| :---: | :---: | :---: |
| C-Bit (Bit 7) | 7-Bit Code (Bits 6-0) |  |
| $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | 010NNNN ${ }^{(1)}$ 100NNNN ${ }^{(1)}$ 11 NNNNN $^{(2)}$ OONNNNN ${ }^{(3)}$ | LOAD BUFFER POINTER (Position of character to be changed) LOAD DIGIT COUNTER (Number of characters to be output) LOAD DUTY CYCLE (On/off and brightness control) TEST MODE ONLY (Not a user function) |
| Notes: 1. NNNN is a 4-bit binary value representing the digit number to be loaded <br> 2. NNNNN is a 5 -bit binary value representing the number of clock cycles each digit is on. |  | 3. This code is a device test function only. If executed it will lock the device in the test mode which can be removed only by performing a power-on reset. |



Figure 1. Display Scan Timing Diagram (Duty Cycle)

Table 2. Character Assignments for Display Data Words

| DATA WORD | CHARACTER | DATA WORD | CHARACTER | DATA WORD | CHARACTER | DATA WORD | CHARACTER |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $0 \times 000000$ | @ | 0x010000 | P | 0X100000 |  | 0X110000 | 0 |
| $0 \times 000001$ | A | $0 \times 010001$ | Q | $0 \times 100001$ | $!$ | $0 \times 110001$ | 1 |
| $0 \times 000010$ | B | $0 \times 010010$ | R | $0 \times 100010$ | " | $0 \times 110010$ | 2 |
| $0 \times 000011$ | C | $0 \times 010011$ | S | $0 \times 100011$ | \# | $0 \times 110011$ | 3 |
| $0 \times 000100$ | D | $0 \times 010100$ | T | 0x100100 | \$ | $0 \times 110100$ | 4 |
| $0 \times 000101$ | E | $0 \times 010101$ | U | 0X100101 | \% | $0 \times 110101$ | 5 |
| $0 \times 000110$ | F | $0 \times 010110$ | v | $0 \times 100110$ | \& | $0 \times 110110$ | 6 |
| $0 \times 000111$ | G | $0 \times 010111$ | w | $0 \times 100111$ | , | $0 \times 110111$ | 7 |
| 0x001000 | H | $0 \times 011000$ | X | 0X101000 | $($ | $0 \times 111000$ | 8 |
| $0 \times 001001$ | 1 | $0 \times 011001$ | Y | 0X101001 | ) | 0X111001 | 9 |
| $0 \times 001010$ | J | $0 \times 011010$ | z | 0X101010 | * | $0 \times 111010$ | : |
| $0 \times 001011$ | K | $0 \times 011011$ | [ | $0 \times 101011$ | + | $0 \times 111011$ | ; |
| $0 \times 001100$ | L | $0 \times 011100$ | 1 | 0x101100 |  | $0 \times 111100$ | $<$ |
| $0 \times 001101$ | M | $0 \times 011101$ | ] | $0 \times 101101$ | - | $0 \times 111101$ | $=$ |
| $0 \times 001110$ | N | $0 \times 011110$ | $\wedge$ | 0x101110 |  | 0X111110 | $>$ |
| $0 \times 001111$ | 0 | $0 \times 011111$ | - | $0 \times 101111$ | 1 | $0 \times 111111$ | ? |

## POWER-ON RESET (POR)

The Power-On Reset (POR) initializes the internal circuits of the 10937 ADC when power $\left(\mathrm{V}_{\mathrm{DD}}\right)$ is applied. The following conditions are established after a Power-On Reset:
a. The Digit Drivers (AD1-AD16) are in the off state (floating).
b. The Segment Drivers (SGA-SGP) are in the off state (floating). This includes PNT and Tail.
c. The cycle on-time for the LOAD DUTY CYCLE is set to 0 cycles.
d. The LOAD DIGIT COUNTER is set to 16 (a bit code value of 0 ).
e. The LOAD BUFFER POINTER is set to 15 to allow the first character to be entered into position 1.

## DIGIT DRIVERS (AD1-AD16)

The sixteen Digit Drivers (AD1-AD16) are used to select each of the display digits sequentially during a refresh scan. Display segments will be illuminated when both the Digit Drivers and Segment Drivers for a particular character are energized simultaneously. The timing characteristics of both the digits and segments are shown in Figure 1. See POR for the Power-On Reset state of these drivers.

## SEGMENT DRIVERS (SGA-SGP)

Sixteen (16) Segment Drivers are provided (SGA-SGP), plus the decimal point (PNT) and comma tail (TAIL). The segment outputs are internally decoded from the 8 -bit characters in the Display Data Buffer by means of a $64 \times 16$-bit PLA. The Segment Driver Allocations are shown in Figure 2. Data codes and their corresponding segment patterns are shown in Figure 3. Timing characteristics for the segment outputs are shown in Figure 1. See POR for the Power-On Reset state of these drivers.

## NOTE

For 14 -segment displays, SGA is used for the top segment and SGF is used for the bottom segment. SGB and SGE can be floated.

## TYPICAL SYSTEM HOOK-UP

Figure 4 shows the 10937 driven by a Host System as it would be connected to a V-F display. EK is determined by the V-F display specifications and RC is selected to provide proper biasing current for zeners. Pull down resistors RA and RG are determined by the interconnection capacitance between the 10937 and the display.


Figure 2. Segment Driver Allocations


NOTES: 1. Indicates characters that will not look the same as shown on a 14 segment display.
2. The LSD corresponds to the three least significant bits (0-2) and the MSD corresponds to the next three bits (3-5) in Table 2.

Figure 3. Display Segment Driver Character Patterns


Figure 4. Typical System Schematic

## 10938 AND 10939 DOT MATRIX DISPLAY CONTROLLER

## DESCRIPTION

The Rockwell 10938 and 10939 Dot Matrix Display Controller is a two-chip MOS/LSI general purpose display controller system designed to interface to dot matrix displays (gas discharge, vacuum-fluorescent or LED).

The two-chip set will drive displays with up to 35 anodes (dots) and up to 20 grids (characters) plus a cursor. The chips can be cascaded to drive larger displays of 80 characters or more with any number of segments. An internal PLA-type segment decoder provides character decoding and dot pattern generation for the full 96 -character ASCII set.

## ORDERING INFORMATION

| Part <br> Number | Package <br> Type | Temperature <br> Range |
| :--- | :---: | :---: |
| 10938 P | Plastic | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| 10938 PE | Plastic | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| 10939 P | Plastic | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| 10939 PE | Plastic | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

## FEATURES

- 20-character display driver cascadable to 80 or more characters
- Standard $5 \times 7$ character font. Custom fonts available by special order
- Separate cursor driver output
- Direct drive capability for vacuum-fluorescent displays
- $96 \times 35$ PLA provides segment decoding for full 96-character ASCll set
- Serial or parallel data input for 8 -bit display and control characters
- Brightness, refresh rate, and display mode controls
- 40-pin DIP


Block Diagram of 10938 and 10939

## INTERFACE DESCRIPTION

10938 Pin Functions

| Signal Name | Pin No. | Function |
| :--- | :---: | :--- |
| $V_{\text {SS }}$ | 2 | Power and signal ground |
| SG01-SG35 | $3-25,27-38$ | Segment driver outputs |
| SCLK-DIS | 39 | Serial data shift |
| DATA-LOAD | 40 | Serial data output/latch control |
| $V_{\text {DD }}$ | 1 | DC Power |
| $V_{G G}$ | 26 | Pull down driver voltage |


| $\mathrm{V}_{\mathrm{DO}}$ | 1 | 40 | DATA-LOAD |
| :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {ss }}$ | 2 | 39 | SCLK-DIS |
| SG35 | 3 | 38 | SG01 |
| SG34 | 44 | 37 | SG02 |
| SG33 | 5 | 36 | SG03 |
| SG32 | 6 | 35 | SG04 |
| SG31 | 7 | 34 | SG05 |
| SG30 | 88 | 33 | SG06 |
| SG29 | 9 | 32 | SG07 |
| SG28 | 10 | 31 | SG08 |
| SG27 | $\square 11$ | 30 | SG09 |
| SG26 | - 12 | 29 | SG10 |
| SG25 | 13 | 28 | SG11 |
| SG24 | -14 | 27 | SG12 |
| SG23 | -15 | 26 | $\mathrm{V}_{\mathrm{GG}}$ |
| SG22 | 16 | 25 | SG13 |
| SG21 | -17 | 24 | SG14 |
| SG20 | $\square 18$ | 23 | SG15 |
| SG19 | 19 | 22 | SG16 |
| SG18 | 20 | 21 | SG17 |

## SPECIFICATIONS

10939 Pin Functions

| Signal Name | Pin No. | Function |
| :--- | :---: | :--- |
| V $_{\text {SS }}$ | 36 | Power and signal ground |
| V $_{\text {DD }}$ | 37 | DC Power |
| CLOCK | 38 | Synchronization Clock |
| CURSOR | 14 | Cursor drive output |
| MASTER | 39 | Master/Slave Mode control |
| SIP | 3 | Sync Input |
| SOP | 2 | Sync Output |
| DO-D7 | $6-13$ | Serial or parallel data input |
| LD | 5 | Input data strobe |
| POR | 4 | Power-an reset |
| SCLK-DIS | 1 | Serial data shift clock |
| DATA-LOAD | 40 | Serial data output/latch control |
| STROO-STR19 | $15-34$ | Anode Drive Outputs |
| V $_{\text {GG }}$ | 35 | Pull down driver voltage |



## Maximum Ratings

| Parameters | Notes | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Operating Temperature <br> Commercial <br> Industrial <br> Storage Temperature | 1 | $\begin{aligned} & \mathrm{Tc} \\ & \mathrm{Ti} \end{aligned}$ | $\begin{gathered} 0 \\ -40 \\ -55 \end{gathered}$ |  | $\begin{aligned} & +70 \\ & +85 \\ & +125 \end{aligned}$ | $\begin{aligned} & { }^{\circ} \mathrm{C} \\ & { }^{\circ} \mathrm{C} \\ & { }^{\circ} \mathrm{C} \end{aligned}$ |
| Operating Voltage | 1 | $V_{\text {D }}$ | -22 | -20 | -18 | Volts |
| Operating Display Voltage | 1 | $V_{G G}$ | -50 |  | -30 | Volts |
| Power Dissipation (total) $I_{\text {load }}=0 \mathrm{~mA}$ per driver $I_{\text {load }}=2 \mathrm{~mA}$ per driver | 2 | PDO PDL |  | $\begin{array}{r} 40 \\ \quad 200 \end{array}$ | $\begin{aligned} & 100 \\ & 750 \end{aligned}$ | $\begin{aligned} & \mathrm{mW} \\ & \mathrm{~mW} \end{aligned}$ |
| Power Dissipation | 3 | PD |  | 200 | 400 | mW |

[^16]
## D.C. Characteristics

| Parameters | Notes | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ```Input D0-D7, LD, SIP Logic "1" Logic "0"``` | 3 | $\begin{aligned} & \mathrm{V}_{\mathrm{iH}} \\ & \mathrm{~V}_{\mathrm{it}} \end{aligned}$ | $\begin{gathered} -1.2 \\ \mathrm{~V}_{\mathrm{cc}} \end{gathered}$ |  | $\begin{aligned} & +0.3 \\ & -4.2 \end{aligned}$ | $\begin{aligned} & v \\ & v \end{aligned}$ |
| Input POR Logic "1" Logic " ${ }^{0}$ " | 3 | $\begin{aligned} & \mathrm{V}_{\text {IHPO }} \\ & \mathrm{V}_{\text {ILPO }} \end{aligned}$ | $\begin{gathered} -3.0 \\ V_{D D} \\ \hline \end{gathered}$ |  | $\begin{array}{r} +0.3 \\ -10.0 \\ \hline \end{array}$ | v |
| $\begin{aligned} & \text { Output SOP } \\ & \text { Logic "1" } \\ & \text { Logic " } 0^{\prime \prime} \end{aligned}$ | 3 | $\mathrm{V}_{\mathrm{OHSY}}$ $V_{\text {ousr }}$ | $\begin{gathered} -1.2 \\ V_{D D} \end{gathered}$ |  | $\begin{aligned} & +0.3 \\ & -4.2 \end{aligned}$ | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ |
| $\begin{aligned} & \text { Output Digits, Cursor, and Segments } \\ & \text { Logic "1" } \left.I_{\text {load }}=10 \mathrm{~mA}\right) \\ & \text { Logic " } 0^{\prime \prime}\left(\mathrm{I}_{\text {load }}=0 \mathrm{~mA}\right) \end{aligned}$ | 1 | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{ol}} \end{aligned}$ | $\begin{gathered} -1.5 \\ V_{G G} \end{gathered}$ | - | . $95 \mathrm{~V}_{G G}$ | v |

NOTES: 1. Designates characteristics for both 10938 and 10939.
2. Designates characteristics for 10938.
3. Designates characteristics for 10939.
A.C. Characteristics

| Parameter | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CLOCK Cycle Time Commercial Industrial | Toyc | $\begin{aligned} & 6.66 \\ & 5.88 \end{aligned}$ |  | $\begin{aligned} & 20.0 \\ & 22.2 \end{aligned}$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \end{aligned}$ |
| Display Outputs (STR00-STR19 and CURSOR) | $\begin{aligned} & T_{\text {stoff }} \\ & T_{\text {ston }} \\ & \hline \end{aligned}$ |  |  | $\begin{array}{r} 7.5^{*} \\ 1.54^{*} \end{array}$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \end{aligned}$ |
| SERIAL INTERFACE TIMING |  |  |  |  |  |
| Serial Clock (D1) On Time Off Time Cycle Time | $\begin{aligned} & \mathrm{T}_{\text {scon }} \\ & \mathrm{T}_{\text {scoff }} \\ & \mathrm{T}_{\text {sccyc }} \end{aligned}$ | $\begin{aligned} & 0.4 \\ & 0.4 \\ & 1.0 \end{aligned}$ |  | 20.0 | $\begin{aligned} & \mu \mathrm{S} \\ & \mu \mathrm{~S} \\ & \mu \mathrm{~S} \end{aligned}$ |
| Serial Data (DO) Set-up Time Hold Time | $\begin{aligned} & \mathrm{T}_{\text {ssetup }} \\ & \mathrm{T}_{\text {shold }} \end{aligned}$ | $\begin{aligned} & 400 \\ & 400 \end{aligned}$ |  |  | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ |
| Serial Clock to LD Time | $T_{\text {sl }}$ | 600 |  |  | ns |
| LD to Serial Clock | $\mathrm{T}_{\text {Is }}$ | 400 |  |  | ns |
| PARALLEL INTERFACE TIMING |  |  |  |  |  |
| Parallel Data (D0-D7) Set-up Time Hold Time | $\begin{aligned} & \mathrm{T}_{\text {psetup }} \\ & \mathrm{T}_{\text {phold }} \end{aligned}$ | $\begin{array}{r} 0 \\ 200 \end{array}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| Data Load (LD) |  |  |  |  |  |
| On Time Off Time | $T_{\text {idon }}$ | 250 |  |  | ns |
| Commercial |  | 40.0 |  |  | $\mu \mathrm{s}$ |
| Industrial |  | 44.5 |  |  | $\mu \mathrm{S}$ |
| Cycle Time | $T_{\text {Ideyc }}$ |  |  |  |  |
| Commercial |  | 60.0 |  |  | $\mu \mathrm{s}$ |
| Industrial |  | 66.7 |  |  | $\mu \mathrm{s}$ |

*40 pf. maximum load capacitance.

## SERIAL INTERFACE TIMING WAVEFORMS



## PARALLEL INTERFACE TIMING WAVEFORMS



## FUNCTIONAL DESCRIPTION

Once the display buffer has been loaded from the host processor, the 10938/10939 system generates all timing signals required to control the display.

Input data is loaded into the Display Data Buffer via the Serial or Parallel Data Input channel on the 10939. Internal timing and control logic synchronize the digit output signals with the Serial Data and Load signals to the 10938 to provide the proper timing for the multiplexing operation. A $96 \times 35$ bit PLA is provided for decoding the full 96 character ASCll set.

Input data is loaded into the 10939 as a series of 8 -bit words. If the Serial Mode is selected, Input Data lines D2-D7 should be tied down to $V_{D D}$ externally. Raising any one of these lines to the $\mathrm{V}_{\text {ss }}$ level automatically shifts the 10939 into the Parallel Mode. Input data may be Control or Display data. The following paragraphs describe the format and functions of these control and display data words.

## CONTROL DATA WORDS

Control data words are distinguished from Display Data words by the fact that they must be preceded by a Control Prefix word ( 00000001 or $01_{16}$ ). Control words and their functions are defined in Table 1.

Table 1. Control Word Assignments

| Hex Value | Function |
| :---: | :---: |
| 00 | Not used |
| 01 | Load 01 into Data Buffer |
| 02 | Not used |
| 03 | Not used |
| 04 | Not used |
| 05 | Set digit time to 16 cycles per grid |
| 06 | Set digit time to 32 cycles per grid |
| 07 | Set digit time to 64 cycles per grid |
| 08 | Enable Normal Display Mode (MSB in data words is ignored) |
| 09 | Enable Blank Mode (data words with MSB $=1$ will be blanked) |
| OA | Enable Inverse Mode (data words with MSB = 1 will be "inversed") |
| OB | Not used |
| OC | Not used |
| OD | Not used |
| OE | Start Display Refresh Cycle (use only once after reset) |
| OF | Not used |
| 10-3F | Not used |
| 40-7F | Load Duty Cycle Register with lower 6 bits (0-63) |
| 80-9F | Load Digit Counter ( $80=32,81=1,82=2$, etc.) |
| A0-BF | Not used |
| CO-DF | Load Buffer Pointer Register with lower 5 bits |
| E0-FF | Not used |

## Load Buffer Pointer

The Load Buffer Pointer code sets the Display Data Buffer pointer. The lower 5 bits of the code are loaded into the buffer pointer (see Table 2).

Table 2. Load Buffer Pointer Codes

| Code Value | Pointer Value | Characte Position |
| :---: | :---: | :---: |
| CO | 00 | 0 |
| C1 | 01 | 1 |
| C2 | 02 | 2 |
| C3 | 03 | 3 |
| C4 | 04 | 4 |
| C5 | 05 | 5 |
| C6 | 06 | 6 |
| C7 | 07 | 7 |
| C8 | 08 | 8 |
| C9 | 09 | 9 |
| CA | OA | 10 |
| CB | OB | 11 |
| CC | OC | 12 |
| CD | OD | 13 |
| CE | OE | 14 |
| CF | OF | 15 |
| D0 | 10 | 16 |
| D1 | 11 | 17 |
| D2 | 12 | 18 |
| D3 | 13 | 19) |
| D4 | 14 | 20 |
| D5 | 15 | 21 |
| D6 | 16 | 22 |
| D7 | 17 | 23 |
| D8 | 18 | 24 |
| D9 | 19 | 25 |
| DA | 1A | 26 |
| DB | 1B | 27 |
| DC | 1C | 28 |
| DD | 1D | 29 |
| DE | 1E | 30 |
| DF | 1F | 31 |

## Load Digit Counter

The Load Digit Counter defines the number of character positions (grids) to be controlled. This code is normally used only during initialization routines, but it may also be used in conjunction with the Load Duty Cycle control code to extend the range of brightness control (see Table 3).

## Load Duty Cycle

The Load Duty Cycle code is used to turn the display on and off, to adjust display brightness, or to modify display timing. The time slot for each character is 16,32 , or 64 cycles as selected by the Load Digit Time codes (see Table 3). The segment and digit drivers for each character are on for a maximum of 13,29 , or 61 cycles with a 3.0 cycle inter-digit off-time. The lower 6 bits of the Load Duty Cycle code are loaded into the Duty Cycle Register. Resultant duty cycles are shown in Table 4.

Table 3. Load Digit Counter Codes

| Code | Digit <br> Counter Value | No. of Grids <br> Controlled |
| :---: | :---: | :---: |
| 80 | 00 | 32 |
| 81 | 01 | 1 |
| 82 | 02 | 2 |
| 83 | 03 | 3 |
| 84 | 04 | 4 |
| 85 | 05 | 5 |
| 86 | 06 | 6 |
| 87 | 07 | 7 |
| 88 | 08 | 8 |
| 89 | 09 | 9 |
| 8 A | 0 A | 10 |
| 8 B | 0 B | 11 |
| 8 C | 0 C | 12 |
| 8 D | 0 D | 13 |
| 8 E | 0 E | 14 |
| 8 F | 0 F | 15 |
| 90 | 10 | 16 |
| 91 | 11 | 17 |
| 92 | 12 | 18 |
| 93 | 13 | 19 |
| 94 | 14 | 20 |
| 95 | 15 | 21 |
| 96 | 16 | 22 |
| 97 | 17 | 23 |
| 98 | 18 | 24 |
| 99 | 19 | 25 |
| 9 A | 1 A | 26 |
| 9 B | 1 B | 27 |
| 9 C | 1 C | 28 |
| 9 D | 1 D | 29 |
| 9 E | 1 E | 30 |
| 9 F | 1 F |  |
|  |  | 31 |

## Load Digit Time

The Load Digit Time codes set the total time for each character during the refresh cycle. Three values can be set using the three codes shown in Table 1. The default value set at power-on is 64 cycles per grid. For displays with 40 or more characters, or under conditions where the display can be subjected to quick movements during viewing (e.g. portable or vehicle-mounted applications), it may be necessary to increase the refresh rate by selecting 16 or 32 cycles per grid with the appropriate control code.

## Enable Display Mode

Each ASCII character is represented by the lower seven bits of the 8 -bit value loaded into the 10939. The eighth (most significant) bit is ignored in Normal display mode. If either Blank or Inverse mode is selected, however, a " 0 " in this bit selects Normal display mode, while a" 1 " selects either Blank or Inverse mode, depending on which mode is enabled. Three control codes are provided (see Table 1) to enable blank mode, enable inverse mode, or enable normal mode.

Table 4. Duty Cycle Control Codes

| Code | Digit Time $=16$ |  | Digit Time $=32$ |  | Digit Time $=64$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | On | Off | On | Off | On | Off |
| 40 | - | 16 | - | 32 | - | 64 |
| 41 | - | 16 | - | 32 | - | 64 |
| 42 | - | 16 | - | 32 | - | 64 |
| 43 | 1 | 15 | 1 | 31 | 1 | 63 |
| 44 | 2 | 14 | 2 | 30 | 2 | 62 |
| 45 | 3 | 13 | 3 | 29 | 3 | 61 |
| 46 | 4 | 12 | 4 | 28 | 4 | 60 |
| 47 | 5 | 11 | 5 | 27 | 5 | 59 |
| 48 | 6 | 10 | 6 | 26 |  | 58 |
| 49 | 7 | 9 | 7 | 25 | 7 | 57 |
| 4A | 8 | 8 | 8 | 24 | 8 | 56 |
| 4B | 9 | 7 | 9 | 23 | 9 | . 55 |
| 4 C | 10 | 6 | 10 | 22 | 10 | 54 |
| 4D | 11 | 5 | 11 | 21 | 11 | 53 |
| 4E | 12 | 4 | 12 | 20 | 12 | 52 |
| 4F | 13 | 3 | 13 | 19 | 13 | 51 |
| 50 | 13 | 3 | 14 | 18 | 14 | 50 |
| 51 | 13 | 3 | 15 | 17 | 15 | 49 |
| 52 | 13 | 3 | 16 | 16 | 16 | 48 |
| . | " | " | 17. | 15 | 17 | 47 |
| : | - | $\because$ | . | . | - | . |
|  | . | . |  | . |  | . |
| 5B | " | " | 25 | 7 | 25 | 39 |
| 5 C | " | " | 26 | 6 | 26 | 38 |
| 5D | " | " | 27 | 5 | 27 | 37 |
| 5E | " | " | 28 | 4 | 28 | 36 |
| 5 F | " | " | 29 | 3 | 29 | 35 |
| 60 | " | " | 29 | 3 | 30 | 34 |
| . | " | " | 29 | 3 | 31 | 33 |
| . | " | " | " | " | 32 | 32 |
| . | . | . | . | . | . | . |
| . | . | - | . | . | . | . |
| 7 C | " | " | " | " | 58 | 6 |
| 7 D | " | " | " | " | 59 | 5 |
| 7E | " | " | " | " | 60 |  |
| 7F | " | " | " | " | 61 | 3 |

In the Blank mode, any character with the MSB="1" will be blanked. In the Inverse mode, it will be displayed with all segment driver outputs inverted. On video displays, this is referred to as "Inverse Video" format. These controls allow individual characters or groups of characters to be blinked or blanked by simply changing the mode without changing the data in the Display Buffer.

## Start Refresh

At power on, the 10939 is held in an internal Halt mode. The normal display refresh sequence starts upon receipt of a Start Refresh control code. This is particularly useful for synchronizing systems using more than one 10939. Only the Master 10939 in a multi-chip system will recognize the Start Refresh code. The Master starts the Slave(s) at the appropriate time, using the SYNCO signal.

## INPUT DISPLAY DATA WORDS

Display data words are loaded as 8 －bit codes．The eighth （most significant）bit specifies normal（0）or blank／inverse（1） display mode，depending on the blank／inverse mode selec－ tion（see Control data words 09 and OA in Table 1）．Figure 1 shows the ASCII codes for the segment patterns for a bar－ graph display．

Twenty display data words must be entered to completely load the Display Data Buffer．The Buffer Pointer automati－ cally increments after each data word is stored in the buffer． To select the next character position to be loaded out of sequence，use the Load Buffer Pointer command．The Buffer Pointer will automatically reset to character position 0 when its value is equal to the Digit Counter programmed value．

## POWER－ON RESET

The Power－On Reset（POR）initializes the internal circuits of the 10939．This is normally accomplished when power（ $\mathrm{V}_{\mathrm{DD}}$ ） is applied．The following conditions are established by appli－ cation of POR：
a．The Grid Drivers（STR00－STR19）on the 10939 are in the off state．
b．The Anode Drivers（SG01－SG35）on the 10938 are in the off state．
c．The Duty Cycle is set to 0 ．
d．The Digit Counter is set to 32 ．
e．The Buffer Pointer is set to 0 ．
f．The Digit time is set to 64 ．
g．The Normal display mode is set．
h．DATA－LOAD is set to high impedance state．
i．SCLK－DIS is set to $V_{\text {OL }}$ to disable the segment drivers in the 10938.
j．SOP is set to $V_{\text {OL }}$ to disable the sync pulse．

## NOTES：

1．When the POR signal is removed，SCLK－DIS is set to the high impedance state．
2．During the initial rise time of $V_{D D}$ at power turn－on，the magnitude of $V_{G G}$ should not exceed the magnitude of $V_{D D}$ ．

## DIGIT DRIVERS（STR00－STR19）PLUS CURSOR

The 20 Digit Drivers select each of the display character positions sequentially during a refresh scan．Display seg－ ments will be illuminated when both the Digit Drivers and Segment Drivers for a particular character are energized simultaneously．The Cursor segment is generated by the 10939，but its timing characteristics are identical to the 16 segments generated by the 10938 ．

## SEGMENT DRIVERS（SG01－SG35）

Sixteen Segment Drivers are provided in the 10938．The output states for each ASCII character pattern and each bar－ graph pattern are internally decoded from the 8 －bit charac－ ters received from the 10939 by means of a $96 \times 16$－bit PLA． Data codes and the corresponding of the ASCII patterns are shown in Figure 1．Data codes and the corresponding bar－ graph patterns are shown in Figure 2.

| $L^{M}$ | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 |  | ${ }^{\prime \prime}{ }^{\prime \prime}$ | $\cdots$ | ${ }_{\square}^{\prime \cdots}$ | $\bullet$ | ！ |
| 1 |  | $\bullet$ | $\vdots_{\cdots}^{\cdots}$ | $\cdots$ | A $\quad .$. | ： |
| 2 | ： |  |  |  | 荋．．． | $\because$ |
| 3 | ： | $\cdots$ . . |  |  | ：$\quad \cdots$ | $\cdots \cdots$ |
| 4 | $\therefore \therefore$ $\therefore \square$ | $\therefore \therefore$ | －${ }^{\cdots}$ | $\cdots$ $\vdots$ | ：$\quad .$. |  |
| 5 | $\because$ $\therefore$ $\therefore$ | ：．．． $\cdots$ $\cdots$ | ：．．．． $\vdots$ $\vdots$ $\ldots$ | $\vdots \vdots$ | ：…： | $\vdots \vdots$ |
| 6 | $\because$ | 高 | ：．．．． $\vdots$ $\vdots$ | $\vdots \vdots$ | $\cdots$ | $\vdots \vdots$ |
| 7 | － | $\cdots$ | ¢ $\vdots$ $\vdots$ | $\vdots \vdots$ | ：$\quad \cdots$ | $\vdots \vdots$ |
| 8 | ${ }^{\bullet}$ | ：${ }^{\ldots}$ ： | 引 |  | $\vdots$ |  |
| 9 | $\vdots$ | $\cdots$ | $\because$ |  | $\because$ | $\because:$ |
| A | $\because$ | － |  |  | $\because$ | $\cdots$ $\therefore$ $\therefore$ |
| B | $\because \cdot$ | ： |  |  |  | $\vdots$ $\vdots$ $\therefore$ |
| c | $\therefore$ |  | $\vdots$ $\vdots$ |  | $\because$ | $\because$ |
| D | $\ldots$ | $\ldots$ | $\cdots$ |  | $\vdots \vdots$ | $\therefore$ |
| E |  | $\because$ | $\cdots$ | $\cdots$ | ：$\quad$ ！ | $\cdots$ |
| F | $\stackrel{\square}{ }$ | $\cdots$ | $\vdots$ | ！ | $\because$ | ：$: 7:$ ： |

The four least significant bits of the seven bit ASCII code are shown in hex notation down the left side of the table．The three most significant bits are shown across the top of the table．

Figure 1．Dot Matrix Patterns

| $R \mathrm{C}$ | 1 | 2 | 3 | 4 | 5 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | SG01 | SG02 | SG03 | SG04 | SG05 |
| 2 | SG06 | SG07 | SG08 | SG09 | SG10 |
| 3 | SG11 | SG12 | SG13 | SG14 | SG15 |
| 4 | SG16 | SG17 | SG18 | SG19 | SG20 |
| 5 | SG21 | SG22 | SG23 | SG24 | SG25 |
| 6 | SG26 | SG27 | SG28 | SG29 | SG30 |
| 7 | SG31 | SG32 | SG33 | SG34 | SG35 |

## TYPICAL SYSTEM HOOKUPS

Figure 3 shows a 10938 and a 10939 in a parallel interface with the host system driving a 20 character display. Figure 4 shows a 10938 and a 10939 in a serial interface with the host system driving a 20 character display. Figure 5 shows a 10938 and two 10939's interfaced parallel with the host system driving a 40 character display.

Figure 2. 5x 7 Dot Matrix Assignments


Figure 3. Typical Display System with Parallel Interface to Host System


Figure 4. Typical Display System with Serial Interface to Host System


Figure 5. Typical Display System with Parallel Interface to Host and Two 10939 Devices

## 10939, 10942, \& 10943 DOT MATRIX DISPLAY CONTROLLER

## DESCRIPTION

The Rockwell 10939, 10942, and 10943 Dot Matrix Display Controller is a three-chip MOS/LSI general purpose display controller system designed to interface to dot matrix displays (gas discharge, vacuum-fluorescent or LED).

The three-chip set will drive displays with up to 46 anodes (dots) and up to 20 grids (characters) plus a cursor. The chips can be cascaded to drive larger displays of up to 80 characters with any number of segments. An internal PLA-type segment decoder provides character decoding and dot pattern generation for the full 96 -character ASCII set.

## ORDERING INFORMATION

| Part <br> Number | Package <br> Type | Temperature <br> Range |
| :--- | :---: | :---: |
| 10939 P | Plastic | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| 10939 PE | Plastic | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| 10942 P | Plastic | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| 1042 CE | Plastic | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| 10943 P | Plastic | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| 10943 PE | Plastic | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

## FEATURES

- 20-character display driver cascadable to 80 characters
- Standard $5 \times 12$ character font. Custom fonts available by special order
- Separate cursor driver output
- Direct drive capability for vacuum-fluorescent displays
- Two $96 \times 23$ PLA's provide segment decoding for full 96 character ASCII set
- Serial or parallel data input for 8-bit display and control characters
- Brightness, refresh rate, and display mode controls
- 10939 provided in 40 -pin DIP
- 10942 and 10943 provided in 28 -pin DIP



## INTERFACE DESCRIPTION

| 10942 and 10943 Pin Functions |  |  |
| :--- | :---: | :--- |
| Signal Name | Pin No． | Function |
| $V_{\text {DD }}$ | 1 | DC Power |
| $V_{\text {SS }}$ | 2 | Power and signal ground |
| SG01－SG23 | $3-1719-26$ | Segment（Anode）driver outputs |
| $V_{\text {GG }}$ | 18 | Pull down driver voltage |
| SCLK－DIS | 27 | Serial data shift |
| DATA－LOAD | 28 | Serial data output／latch control |

10939 Pin Functions

| Signal Name | Pin No． | Function |
| :--- | :---: | :--- |
| V SS $^{\prime \mid}$ | 36 | Power and signal ground |
| V DD | 37 | DC Power |
| CLOCK | 38 | Synchronization Clock |
| CURSOR | 14 | Cursor drive output |
| MASTER | 39 | Master／Slave Mode control |
| SIP | 3 | Sync Input |
| SOP | 2 | Sync Output |
| DO－D7 | $6-13$ | Serial or paraliel data input |
| LD | 5 | Input data strobe |
| POR | 4 | Power－on reset |
| SCLK－DIS | 1 | Serial data shift clock |
| DATA－LOAD | 40 | Serial data output／latch control |
| STRO0－STR19 | $15-34$ | Anode Drive Outputs |
| VGG | 35 | Pull down driver voltage |


| $\mathrm{V}_{\mathrm{DD}} \mathrm{C} 1$ | 28.1 DATA－LOAD |
| :---: | :---: |
| $v_{s s} \mathrm{C} / 2$ | 27 －ISCLK－DIS |
| SG23－3 | 26 DSG01 |
| SG22－4 | 25 万SG02 |
| SG21－5 | 24 صsG03 |
| SG20－6 | 23 －SG04 |
| SG19 7 | 22 －SG05 |
| SG18－8 | 21 习SG06 |
| SG17－9 | 20 －SG07 |
| SG16－10 | 19 习SG08 |
| SG15 11 | $18.7 \mathrm{~V}_{\mathrm{GG}}$ |
| SG14－12 | 17 PSG09 |
| SG13－13 | 16 －SG10 |
| SG12－14 | 15 VSG11 |
| 10942 and 10943 <br> Pin Configurations |  |



## SPECIFICATIONS

Maximum Ratings

| Parameters | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Operating Temperature | $\mathrm{T}_{\mathrm{A}}$ |  |  |  |  |
| Commercial |  | 0 |  | +70 | ${ }^{\circ} \mathrm{C}$ |
| Industrial |  | -40 |  | ${ }^{\circ} \mathrm{C}$ |  |
| Storage Temperature | $\mathrm{T}_{\mathrm{S}}$ | -55 |  | ${ }^{\circ} \mathrm{C}$ |  |
| Operating Voltage | $\mathrm{V}_{\mathrm{DD}}$ | -22 | -20 | -18 | Volts |
| Operating Display Voltage | $\mathrm{V}_{\mathrm{GG}}$ | -50 |  | -30 | Volts |

D.C. Characteristics ( $\mathrm{V}_{\mathrm{DD}}=-18$ to $-22 \mathrm{Vdc}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}$, unless otherwise noted.)

| Parameter | Symbol | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 10942 \text { \& } 10943 \\ & \text { Output Segments } \\ & \text { Logic " } \left.1 \text { " ( } \text { LIOAD }^{2}=2 \mathrm{~mA}\right) \\ & \text { Logic " } 0 \text { " ( } \text { LLOAD }^{2}=0 \mathrm{~mA} \text { ) } \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{v}_{\mathrm{OL}} \end{aligned}$ | $\begin{gathered} -1.5 \\ V_{G G} \end{gathered}$ |  | $0.95 \mathrm{~V}_{\mathrm{GG}}$ |  |
| 10939 <br> Input D0-D7, LD, SIP <br> Logic "1" <br> Logic "0" <br> Input POR <br> Logic "1" <br> Logic "0" <br> Output SOP <br> Logic "1" <br> Logic "0" <br> Output Digits, Cursor Logic "1" ( $\left.l_{\text {load }}=10 \mathrm{~mA}\right)$ Logic " 0 " ( $\left.I_{\text {load }}=0 \mathrm{~mA}\right)$ | $V_{1 H}$ <br> $V_{\text {HPD }}$ <br> $V_{\text {ILPO }}$ <br> $V_{\text {OHSY }}$ <br> Volsy <br> $\mathrm{V}_{\mathrm{OH}}$ <br> $V_{\text {OL }}$ | $\begin{gathered} -1.2 \\ V_{D D} \\ -3.0 \\ V_{D D} \\ -1.2 \\ V_{D D} \\ -1.5 \\ V_{G G} \end{gathered}$ |  | $\begin{array}{r} +0.3 \\ -4.2 \\ +0.3 \\ -10.0 \\ \\ +0.3 \\ -4.2 \end{array}$ <br> $0.96 \mathrm{~V}_{\mathrm{GG}}$ | $\begin{aligned} & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \\ & v \end{aligned}$ |
| Note: $\mathrm{TA}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ (com | $+85^{\circ} \mathrm{C}$ (in | therw |  |  |  |

Operating Currents


Notes:

1. The 10942 and 10943 each have 35 internal driver outputs, 23 of which are brought out. $I_{\mathrm{GG}}$ is proportional to the number of drivers on. The values given are for all 35 drivers on. Divide $I_{\mathrm{GG}}$ shown by 35 to determine $\mathrm{I}_{\mathrm{GG}}$ for one driver.
2. The 10939 will never have more than two drivers on at any one time; one grid driver and the cursor. The values shown are for two drivers on with $100 \%$ duty cycle.
3. $I_{S S}=I_{D D}+I_{G G}+I_{D V R}\left(I_{D V R}=35 \times I_{\text {LOAD }}\right)$ Example: For 10939 and 10943 ( $T A=-40^{\circ} \mathrm{C}$ and $\mathrm{V}_{D D}=-22 \mathrm{~V}$ ):
$I_{\mathrm{SS}}=4.5+11.2+(35 \times 2.0)=85.7 \mathrm{~mA}$.
A.C. Characteristics

| Parameter | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CLOCK Cycle Time <br> Commercial Industrial <br> Display Outputs (STR00-STR19 and CURSOR) <br> - Data Load (LD) <br> On Time <br> Off Time <br> Commercial Industrial <br> Cycle Time Commercial Industrial | $T_{\text {cyc }}$ $T_{\text {stoff }}$ $T_{\text {ston }}$ $T_{\text {Idon }}$ $T_{\text {Idoff }}$ $T_{\text {ldcyc }}$ | 6.66 <br> 5.88 <br> 1.0 <br> 40.0 <br> 44.5 <br> 60.0 <br> 66.7 |  | $\begin{gathered} 20.0 \\ 22.2 \\ 7.5^{*} \\ 1.54^{*} \end{gathered}$ | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| SERIAL INTERFACE TIMING <br> Serial Clock (D1) <br> On Time <br> Off Time Cycle Time <br> Serial Data (DO) <br> Set-up Time Hold Time <br> Serial Clock to LD Time <br> LD to Serial Clock | $\mathrm{T}_{\text {scon }}$ <br> $T_{\text {scoff }}$ <br> $T_{\text {sccyc }}$ <br> $\mathrm{T}_{\text {ssetup }}$ <br> $\mathrm{T}_{\text {shold }}$ <br> $\mathrm{T}_{\mathrm{s} \mid}$ <br> $\mathrm{T}_{\text {Is }}$ | $\begin{aligned} & 1.0 \\ & 1.0 \\ & 2.0 \\ & 400 \\ & 400 \\ & 1.0 \\ & 1.0 \end{aligned}$ |  | 20.0 | $\begin{aligned} & \mu \mathrm{s} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \\ & \\ & \mathrm{~ns} \\ & \mathrm{~ns} \\ & \mathrm{~ns} \\ & \mu \mathrm{~s} \\ & \mu \mathrm{~s} \end{aligned}$ |
| PARALLEL INTERFACE TIMING <br> Parallel Data (D0-D7) <br> Set-up Time <br> Hold Time | $T_{\text {psetup }}$ <br> $T_{\text {phold }}$ | $\begin{array}{r} 0 \\ 200 \end{array}$ |  |  | ns ns |

*40 pf. maximum load capacitance.

## SERIAL INTERFACE TIMING WAVEFORMS



## PARALLEL INTERFACE TIMING WAVEFORMS



## FUNCTIONAL DESCRIPTION

Once the display buffer has been loaded from the host processor, the 10939, 10942, and 10943 system generates all timing signals required to control the display.

Input data is loaded into the Display Data Buffer via the Serial or Parallel Data Input channel on the 10939. Internal timing and control logic synchronize the digit output signals with the Serial Data and Load signals to the 10942/10943 to provide the proper timing for the multiplexing operation. Two $92 \times 23$ bit PLA's, one in the 10942 and the other in the 10943, decode the full 96 character ASCII set.

Input data is loaded into the 10939 as a series of 8 -bit words. If the Serial Mode is selected, Input Data lines D2-D7 should be tied down to $V_{D D}$ externally. Raising any one of these lines to the $\mathrm{V}_{\text {Ss }}$ level automatically shifts the 10939 into the Parallel Mode. Input data may be Control or Display data. The following paragraphs describe the format and functions of these control and display data words.

## CONTROL DATA WORDS

Control data words are distinguished from Display Data words by the fact that they must be preceded by a Control Prefix word (0000 0001 or $01_{16}$ ). Control words and their functions are defined in Table 1.

Table 1. Control Word Assignments

| Hex Value | Function |
| :---: | :---: |
| 00 | Not used |
| 01 | Load 01 into Data Buffer |
| 02 | Not used |
| 03 | Not used |
| 04 | Not used |
| 05 | Load Digit Time to 16 cycles per grid |
| 06 | Load Digit Time to 32 cycles per grid |
| 07 | Load Digit Time to 64 cycles per grid |
| 08 | Enable Normal Display Mode (MSB in data words is ignored) |
| 09 | Enable Blank Mode (data words with MSB $=1$ will be blanked) |
| OA | Enable Inverse Mode (data words with MSB = 1 will be "inversed") |
| OB | Not used |
| OC | Not used |
| OD | Not used |
| OE | Start Display Refresh Cycle (use only once after reset) |
| OF | Not used |
| 10-3F | Not used |
| 40-7F | Load Duty Cycle Register |
| 80-9F | Load Digit Counter ( $80=32,81=1,82=2$, etc.) |
| AO-BF | Not used |
| CO-DF | Load Buffer Pointer Register with lower 5 bits |
| E0-FF | Not used |

## Load Buffer Pointer

The Load Buffer Pointer code sets the Display Data Buffer pointer. The lower 5 bits of the code are loaded into the buffer pointer (see Table 2).

Table 2. Load Buffer Pointer Codes

| Code <br> Value | Pointer <br> Value | Character <br> Position |
| :---: | :---: | :---: |
| C0 | 00 | 0 |
| C1 | 01 | 1 |
| C2 | 02 | 2 |
| C3 | 03 | 3 |
| C5 | 04 | 4 |
| C6 | 05 | 5 |
| C7 | 06 | 6 |
| C8 | 07 | 7 |
| C9 | 08 | 8 |
| CA | 09 | 9 |
| CB | $0 A$ | 10 |
| CC | $0 B$ | 11 |
| CD | $0 C$ | 12 |
| CE | $0 D$ | 13 |
| CF | $0 E$ | 14 |
| D0 | $0 F$ | 15 |
| D1 | 10 | 16 |
| D2 | 11 | 17 |
| D3 | 12 | 18 |
| D4 | 13 | 19 |
| D5 | 14 | 20 |
| D6 | 15 | 21 |
| D7 | 16 | 22 |
| D8 | 17 | 23 |
| D9 | 18 | 24 |
| DA | 19 | 25 |
| DB | $1 A$ | 26 |
| DC | $1 B$ | 27 |
| DD | $1 C$ | -28 |
| DE | $1 D$ | 29 |
| DF | $1 E$ | 30 |
| Note: Do not use character positions $20-31$. |  |  |

## Load Digit Counter

The Load Digit Counter defines the number of character positions (grids) to be controlled. This code is normally used only during initialization routines, but it may also be used in conjunction with the Load Duty Cycle control code to extend the range of brightness control (see Table 3).

## Load Duty Cycle

The Load Duty Cycle code is used to turn the display on and off, to adjust display brightness, or to modify display timing. The time slot for each character is 16,32 , or 64 cycles as selected by the Load Digit Time codes (see Table 1). The segment and digit drivers for each character are on for a maximum of 13,29 , or 61 cycles with a 3.0 cycle inter-digit off-time. The lower 6 bits of the Load Duty Cycle code are loaded into the Duty Cycle Register. Resultant duty cycles are shown in Table 4.

Table 3. Load Digit Counter Codes

| Code | Digit Counter Value | No. of Grids Controlled |
| :---: | :---: | :---: |
| 80 | 00 | 32 |
| 81 | 01 | 1 |
| 82 | 02 | 2 |
| 83 | 03 | 3 |
| 84 | 04 | 4 |
| 85 | 05 | 5 |
| 86 | 06 | 6 |
| 87 | 07 | 7 |
| 88 | 08 | 8 |
| 89 | 09 | 9 |
| 8A | OA | 10 |
| 8B | OB | 11 |
| 8 C | OC | 12 |
| 8D | OD | 13 |
| 8 E | OE | 14 |
| 8 F | OF | 15 |
| 90 | 10 | 16 |
| 91 | 11 | 17 |
| 92 | 12 | 18 |
| 93 | 13 | 19 |
| 94 | 14 | 20 |
| 95 | 15 | 21. |
| 96 | 16 | 22 |
| 97 | 17 | 23 |
| 98 | 18 | 24 |
| 99 | 19 | 25 |
| 9A | 1A | 26 |
| 9B | 1 B | 27 |
| 9 C | 1 C | 28 |
| 9D | 1D | 29 |
| 9E | 1E | 30 |
| 9F | 1F | 31 |

## Load Digit Time

The Load Digit Time codes set the total time for each character during the refresh cycle. Three values can be set using the three codes shown in Table 1. The default value set at power-on is 64 cycles per grid. For displays with 40 or more characters, or under conditions where the display can be subjected to quick movements during viewing (e.g. portable or vehicle-mounted applications), it may be necessary to increase the refresh rate by selecting 16 or 32 cycles per grid with the appropriate control code.

## Enable Display Mode

Each ASCII character is represented by the lower seven bits of the 8 -bit value loaded into the 10939. The eighth (most significant) bit is used to turn the cursor on in Normal display mode. If either Blank or Inverse mode is selected, however, a " 0 " in this bit selects Normal display mode, while a " 1 " selects either Blank or Inverse mode, depending on which mode is enabled. Three control codes are provided (see Table 1) to enable blank mode, enable inverse mode, or enable normal mode.

Table 4. Duty Cycle Control Codes

| Code | Digit Time $=16$ |  | Digit Time $=32$ |  | Digit Time $=64$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | On | Off | On | Off | On | Off |
| 40 | - | 16 | - | 32 | - | 64 |
| 41 | - | 16 | - | 32 | - | 64 |
| 42 | - | 16 | - | 32 | - | 64 |
| 43 | 1 | 15 | 1 | 31 | 1 | 63 |
| 44 | 2 | 14 | 2 | 30 | 2 | 62 |
| 45 | 3 | 13 | 3 | 29 | 3 | 61 |
| 46 | 4 | 12 | 4 | 28 | 4 | 60 |
| 47 | 5 | 11 | 5 | 27 | 5 | 59 |
| 48 | 6 | 10 | 6 | 26 | 6 | 58 |
| 49 | 7 | 9 | 7 | 25 | 7 | 57 |
| 4A | 8 | 8 | 8 | 24 | 8 | 56 |
| 4B | 9 | 7 | 9 | 23 | 9 | 55 |
| 4 C | 10 | 6 | 10 | 22 | 10 | 54 |
| 4D | 11 | 5 | 11 | 21 | 11 | 53 |
| 4E | 12 | 4 | 12 | 20 | 12 | 52 |
| 4F | 13 | 3 | 13 | 19 | 13 | 51 |
| 50 | 13 | 3 | 14 | 18 | 14 | 50 |
| 51 | 13 | 3 | 15 | 17 | 15 | 49 |
| 52 | 13 | 3 | 16 | 16 | 16 | 48 |
| . | " | " | 17 | 15 | 17 | 47 |
| - | . | . | - | - | . | . |
| - | - | $\cdot$ | - | - | - | - |
| 5B | " | " | 25 | 7 | 25 | 39 |
| 5C | " | " | 26 | 6 | 26 | 38 |
| 5D | " | " | 27 | 5 | 27 | 37 |
| 5E | " | " | 28 | 4 | 28 | 36 |
| 5 F | " | " | 29 | 3 | 29 | 35 |
| 60 | " | " | 29 | 3 | 30 | 34 |
|  | " | " | 29 | 3 | 31 | 33 |
| . | " | " | " | " | 32 | 32 |
| - | $\cdots$ | - | . | - | . | - |
| $\cdot$ | - | - | - | $\cdot$ | - | $\cdot$ |
| 7 C | " | " | " | " | 58 | 6 |
| 7D | " | " | " | " | 59 | 5 |
| 7 E | " | " | " | " | 60 | 4 |
| 7F | " | " | " | " | 61 | 3 |

In the Blank mode, any character with the $M S B=$ " 1 " will be blanked. In the Inverse mode, it will be displayed with all segment driver outputs inverted. On video displays, this is referred to as "Inverse Video" format. These controls allow individual characters or groups of characters to be blinked or blanked by simply changing the mode without changing the data in the Display Buffer.

## Start Refresh

At power on, the 10939 is held in an internal Halt mode. The normal display refresh sequence starts upon receipt of a Start Refresh control code. This is particularly useful for synchronizing systems using more than one 10939. Only the Master 10939 is a multi-chip system will recognize the Start Refresh code. The Master starts the Slave(s) at the appropriate time, using the SYNCO signal.

## INPUT DISPLAY DATA WORDS

Display data words are loaded as 8 -bit codes. The eighth (most significant) bit (bit 7) is a dual purpose bit. This bit specifies normal (0) or blank/inverse (1) display mode, depending on the blank/inverse mode selection (see control data words 09 and 0 A in Table 1). Bit 7 also controls the cursor output from the 10939; on (1) or off (0). Note, however, that this bit always controls the cursor no matter what display mode is selected.

Twenty display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer automatically increments after each data word is stored in the buffer. To select the next character position to be loaded out of sequence, use the Load Buffer Pointer command. The Buffer Pointer will automatically reset to character position 0 when its value is equal to the Digit Counter programmed value.

## DIGIT DRIVERS (STR00-STR19) PLUS CURSOR

The 20 Digit Drivers select each of the display character positions sequentially during a refresh scan. Display segments will be illuminated when both the Digit Drivers and Segment Drivers for a particular character are energized simultaneously. The Cursor segment is generated by the 10939, but its timing characteristics are identical to the 46 segment outputs generated by the 10942 and the 10943.

## SEGMENT DRIVERS (SG01-SG23)

46 Segment Drivers are provided by the 10942 and the 10943. The output states for each ASCII character pattern are internally decoded from the 8 -bit characters received from the 10939 by means of two $96 \times 23$-bit PLA's, one in the 10942 and the other in the 10943. Data codes and the corresponding ASCII patterns are shown in Figure 1.

## POWER-ON RESET

The Power-On Reset (POR) initializes the internal circuits of the 10939. This is normally accomplished when power ( $\mathrm{V}_{\mathrm{DD}}$ ) is applied. The following conditions are established by application of POR:
a. The Grid Drivers (STR00-STR19) on the 10939 are in the off state.
b. The Anode Drivers, SG01-SG23 on the 10942 and SG01SG23 on the 10943, are in the off state.
c. The Duty Cycle is set to 0 .
d. The Digit Counter is set to 32.
e. The Buffer Pointer is set to 0 .
f. The Digit time is set to 64 .
g. The Normal display mode is set.
h. DATA-LOAD is set to high impedance state.
i. SCLK-DIS is set to $V_{\text {OL }}$ to disable the segment drivers in the 10942 and 10943.
j. SOP is set to $V_{O L}$ to disable the sync pulse.

NOTES:

1. When the POR signal is removed, SCLK-DIS is set to the high impedance state.
2. During the initial rise time of $V_{D D}$ at power turn-on, the magnitude of $\mathrm{V}_{\mathrm{GG}}$ should not exceed the magnitude of $\mathrm{V}_{\mathrm{DD}}$.

| SEGMENTS DRIVEN BY 10942 | ROW COL | 1 | 2 | 3 | 4 | 5 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 1 | SG01 | SG02 | SG03 | SG04 | SG05 |
|  | 2 | SG06 | SG07 | SG08 | SG09 | SG10 |
|  | 3 | SG11 | SG12 | SG13 | SG14 | SG15 |
|  | 4 | SG16 | SG17 | SG18 | SG19 | SG20 |
|  | 5 | SG21 | SG22 | SG23 | SG01 | SG02 |
|  | 6 | SG03 | SG04 | SG05 | SG06 | SG07 |
| SEGMENTS DRIVEN BY 10943 | 7 | SG08 | SG09 | SG10 | SG11 | SG12 |
|  | 8 | SG13 | X | X | SG14 | SG15 |
|  | 9 | SG16 | $\mathbf{X}$ | $\mathbf{x}$ | SG17 | SG18 |
|  | 10 | SG19 | SG20 | SG21 | SG22 | SG23 |
|  | 11 | X | X | X | X | X |
|  | 12 TIE THESE FIVE TOGETHER ${ }^{(1)}$ |  |  |  |  |  |
|  | Note: <br> 1. DRIVEN BY CURSOR LINE OF 10939. |  |  |  |  |  |

Figure 2. $5 \times 12$ Dot Matrix Assignments

| $M S_{B} s_{B}$ | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X010 | \＃\＃ |  | 邑 | REB HEB $\#$ | 世胃 |  |  |  |
| X011 |  |  | \＃ | \＃ |  | B \＃ $\#$ $\#$ |  | 曲 |
| X100 | 㝵 | \＃ |  |  |  | \＃\＃ |  |  |
| X101 |  |  |  | 弗 | 母 \＃ |  | \＃ |  |
| X110 | 呦 | \＃\＃ |  | \＃\＃ \＃ \＃ | \＃ | \＃\＃ | \＃里 |  |
| X111 | \＃ \＃ \＃ |  | $\square$ | \＃\＃ | 母 |  | \＃ | \＃ |

Figure 1．Dot Matrix Patterns

| $M S_{B}^{L} S_{B}$ | 1000 | 1001 | 1010 | 1011 | 1100 | 1101 | 1110 | 1111 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X010 |  |  |  | \＃\＃ | \＃\＃ | \＃ | \＃\＃ | \＃ |
| X011 |  |  |  | 㬰 | \＃\＃ | \＃\＃ |  |  |
| X100 |  |  |  |  | \＃ |  |  |  |
| X101 |  |  | \＃\＃ | 井 | 井 |  | 世胃 | \＃\＃ |
| X110 |  |  | \＃ |  |  |  |  |  |
| X111 |  |  | \＃月 | \＃\＃ | \＃月 | \＃ | 曲 | \＃ |

Figure 1．Dot Matrix Patterns（Cont．）

## TYPICAL SYSTEM HOOKUPS

Figure 3 shows a 10939, 10942, and a 10943 in a parallel interface with the host system driving a 20 -character display. Figure 4 shows a 10939, 10942, and a 10943 in a serial interface with the host system driving a 20 -character display. Figure 5 shows two 10939's, a 10942, and a 10943 interfaced parallel with the host system driving a 40-character display.



Figure 4. Typical Display System with Serial Interface to Host System


Figure 5. Typical Display System with Parallel Interface to Host and Two 10939 Devices

# 10941 AND 10939 ALPHANUMERIC AND BARGRAPH DISPLAY CONTROLLER 

## DESCRIPTION

The Rockwell 10939 and 10941 Alphanumeric and Bargraph Display Controller is a two-chip MOS/LSI general purpose display controller system designed to interface with bargraph and segmented displays (gas discharge, vacuum-fluorescent or LED).

The two-chip set will drive up to 20 segments and up to 20 grids (characters) plus a cursor. The chips can be cascaded to drive larger displays of 80 characters or more. Segment decoding for ASCII characters or the bargraph patterns is accomplished through an internal PLA.

ORDERING INFORMATION

| Part <br> Number | Package <br> Type | Temperature <br> Range |
| :--- | :---: | :---: |
| 10941 P | Plastic | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| 10941 PE | Plastic | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |
| 10939 P | Plastic | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| 10939 PE | Plastic | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

## FEATURES

- 20-character display driver cascadable to 80 or more characters
- Direct drive capability for vacuum-fluorescent displays
- $96 \times 16$ PLA provides segment decoding for ASCII characters (all caps only) and bargraph patterns
- Serial or parallel data input for 8-bit display and control characters
- Brightness, refresh rate, and display mode controls
- Separate cursor driver output
- 10939 comes in 40-pin DIP
- 10941 comes in 24-pin DIP


Block Diagram of 10941 and 10939

## INTERFACE DESCRIPTION

10941 Pin Functions

| Signal Name | Pin No. | Function |
| :--- | :---: | :--- |
| V SS | 2 | Power and signal ground |
| SG01-SG16 | $6-15,17-22$ | Segment driver outputs |
| SCLK-DIS | 23 | Serial data shift |
| DATA-LOAD | 24 | Serial data output/latch control |
| V $_{\text {DD }}$ | 1 | DC Power |
| V $_{G G}$ | 16 | Pull down driver voltage |



10941 Pin Configuration

## SPECIFICATIONS

10939 Pin Functions

| Signal Name | Pin No. | Function |
| :--- | :---: | :--- |
| $V_{\text {SS }}$ | 36 | Power and signal ground |
| V $_{\text {DD }}$ | 37 | DC Power |
| CLOCK | 38 | Synchronization Clock |
| CURSOR | 14 | Cursor drive output |
| MASTER | 39 | Master/Slave Mode control |
| SIP | 3 | Sync Input |
| SOP | 2 | Sync Output |
| D0-D7 | $6-13$ | Serial or parallel data input |
| LD | 5 | Input data strobe |
| POR | 4 | Power-on reset |
| SCLK-DIS | 1 | Serial data shift clock |
| DATA-LOAD | 40 | Srial data output/latch control |
| STR00-STR19 | $15-34$ | Anode Drive Outputs |
| V $_{\text {GG }}$ | 35 | Pull down driver voltage |



10939 Pin Configuration

Maximum Ratings

| Parameters | Notes | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Operating Temperature Commercial Industrial Storage Temperature | 1 | $\begin{aligned} & \mathrm{Tc} \\ & \mathrm{Ti} \end{aligned}$ | $\begin{gathered} 0 \\ -40 \\ -55 \end{gathered}$ |  | $\begin{aligned} & +70 \\ & +85 \\ & +125 \end{aligned}$ | $\begin{aligned} & { }^{\circ} \mathrm{C} \\ & { }^{\circ} \mathrm{C} \\ & { }^{\circ} \mathrm{C} \end{aligned}$ |
| Operating Voltage | 1 | $V_{D D}$ | -22 | -20 | -18 | Volts |
| Operating Display Voltage | 1 | $V_{\text {GG }}$ | -50 |  | -30 | Volts |
| Power Dissipation (total) $I_{\text {load }}=0 \mathrm{~mA}$ per driver $\mathrm{I}_{\text {load }}=2 \mathrm{~mA}$ per driver | 2 | $\begin{aligned} & \text { PDO } \\ & \text { PDL } \end{aligned}$ |  | $\begin{array}{r} 40 \\ 200 \end{array}$ | $\begin{aligned} & 100 \\ & 750 \end{aligned}$ | $\begin{aligned} & \mathrm{mW} \\ & \mathrm{~mW} \end{aligned}$ |
| Power Dissipation | 3 | PD |  | 200 | 400 | mW |

NOTES: 1. Designates characteristics for both 10941 and 10939.
2. Designates characteristics for 10941.
3. Designates characteristics for 10939.
D.C. Characteristics

| Parameter | Notes | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { Input DO-D7, LD, SIP } \\ & \text { Logic "1" } \\ & \text { Logic " } 0 \text { " } \end{aligned}$ | 3 | $\begin{aligned} & V_{\mathrm{IH}} \\ & \mathrm{~V}_{\mathrm{IL}} \end{aligned}$ | $\begin{gathered} -1.2 \\ \mathrm{~V}_{\mathrm{DD}} \end{gathered}$ |  | $\begin{aligned} & +0.3 \\ & -4.2 \end{aligned}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{v} \end{aligned}$ |
| Input POR Logic "1" Logic " $\mathrm{O}^{\prime}$ | 3 | $\begin{aligned} & V_{\text {IHPO }} \\ & V_{\text {ILPO }} \end{aligned}$ | $\begin{gathered} -3.0 \\ V_{D D} \end{gathered}$ |  | $\begin{aligned} & +0.3 \\ & -10.0 \end{aligned}$ | $\begin{aligned} & \text { V } \\ & \text { V } \end{aligned}$ |
| $\begin{aligned} & \text { Output SOP } \\ & \text { Logic " } 1 \text { " } \\ & \text { Logic " } 0 \text { " } \\ & \hline \end{aligned}$ | 3 | $\begin{aligned} & \mathrm{V}_{\mathrm{OHSY}} \\ & \mathrm{~V}_{\mathrm{OLSY}} \end{aligned}$ | $\begin{gathered} -1.2 \\ V_{D D} \end{gathered}$ |  | $\begin{array}{r} +0.3 \\ -4.2 \\ \hline \end{array}$ | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ |
| Output Digits, Cursor, and Segments <br> Logic "1" ( $l_{\text {load }}=10 \mathrm{~mA}$ ) <br> Logic " $0^{\prime \prime}$ (lioad $\left.=0 \mathrm{~mA}\right)$ | 1 | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}} \\ & \mathrm{~V}_{\mathrm{OL}} \end{aligned}$ | $\begin{gathered} -1.5 \\ V_{G G} \end{gathered}$ |  | . $95 \mathrm{~V}_{\mathrm{GG}}$ | $\begin{aligned} & \mathrm{V} \\ & \mathrm{v} \end{aligned}$ |
| NOTES: 1. Designates characteristics for both 10941 and 10939. <br> 2. Designates characteristics for 10941. <br> 3. Designates characteristics for 10939. |  |  |  |  |  |  |

## A.C. Characteristics

| Parameter | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| CLOCK Cycle Time Commercial Industrial | $\mathrm{T}_{\text {cyc }}$ | $\begin{aligned} & 6.66 \\ & 5.88 \end{aligned}$ |  | 20.0 22.2 | ${ }_{\mu \mathrm{S}} \mathrm{S}$ |
| Display Outputs (STR00-STR19 and CURSOR) | $\begin{aligned} & \mathrm{T}_{\text {stoff }} \\ & \mathrm{T}_{\text {ston }} \end{aligned}$ |  |  | $\begin{array}{r} 7.5^{*} \\ 1.54^{*} \\ \hline \end{array}$ | $\begin{aligned} & \mu \mathrm{S} \\ & \mu \mathrm{~s} \\ & \hline \end{aligned}$ |
| SERIAL INTERFACE TIMING |  |  |  |  |  |
| Serial Clock (D1) On Time Off Time Cycle Time | $\mathrm{T}_{\text {scon }}$ <br> $\mathrm{T}_{\text {scoff }}$ <br> $\mathrm{T}_{\text {sccyc }}$ | $\begin{aligned} & 0.4 \\ & 0.4 \\ & 1.0 \end{aligned}$ |  | 20.0 | $\begin{aligned} & \mu \mathrm{S} \\ & \mu \mathrm{~S} \\ & \mu \mathrm{~S} \end{aligned}$ |
| Serial Data (DO) Set-up Time Hold Time | $\begin{aligned} & \mathrm{T}_{\text {ssetup }} \\ & \mathrm{T}_{\text {shold }} \end{aligned}$ | $\begin{aligned} & 400 \\ & 400 \end{aligned}$ |  |  | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| Serial Clock to LD Time | $\mathrm{T}_{\text {sl }}$ | 600 |  |  | ns |
| LD to Serial Clock | $\mathrm{T}_{\text {Is }}$ | 400 |  |  | ns |
| PARALLEL INTERFACE TIMING |  |  |  |  |  |
| Parallel Data (D0-D7) |  |  |  |  |  |
| Set-up Time | $\mathrm{T}_{\text {psetup }}$ | 0 |  |  | ns |
| Hold Time | $\mathrm{T}_{\text {phold }}$ | 200 |  |  | ns |
| Data Load (LD) |  |  |  |  |  |
| On Time | $T_{\text {Idon }}$ | 250 |  |  | ns |
| Off Time | $\mathrm{T}_{\text {ldaff }}$ |  |  |  |  |
| Commercial |  | 40.0 |  |  | $\mu \mathrm{s}$ |
| Industrial |  | 44.5 |  |  | $\mu \mathrm{S}$ |
| Cycle Time | $T_{\text {ldeyc }}$ |  |  |  |  |
| Commercial |  | 60.0 |  |  | $\mu \mathrm{S}$ |
| Industrial |  | 66.7 |  |  | $\mu \mathrm{s}$ |
| * 40 pf. maximum load capacitance. |  |  |  |  |  |

SERIAL INTERFACE TIMING WAVEFORMS


PARALLEL INTERFACE TIMING WAVEFORMS


## FUNCTIONAL DESCRIPTION

Once the display buffer has been loaded from the host processor, the 10941/10939 system generates all timing signals required to control the display.

Input data is loaded into the Display Data Buffer via the Serial or Parallel Data Input channel on the 10939. Internal timing and control logic synchronize the digit output signals with the Serial Data and Load signals to the 10941 to provide the proper timing for the multiplexing operation. A $96 \times 35$ bit PLA is provided for decoding the full 96 character ASCII set.

Input data is loaded into the 10939 as a series of 8 -bit words. If the Serial Mode is selected, Input Data lines D2-D7 should be tied down to $V_{D D}$ externally. Raising any one of these lines to the $\mathrm{V}_{\mathrm{ss}}$ level automatically shifts the 10939 into the Parallel Mode. Input data may be Control or Display data. The following paragraphs describe the format and functions of these control and display data words.

## CONTROL DATA WORDS

Control data words are distinguished from Display Data words by the fact that they must be preceded by a Control Prefix word ( 00000001 or $01_{16}$ ). Control words and their functions are defined in Table 1.

Table 1. Control Word Assignments

| Hex Value | Function |
| :---: | :---: |
| 00 | Not used |
| 01 | Load 01 into Data Buffer |
| 02 | Not used |
| 03 | Not used |
| 04 | Not used |
| 05 | Set digit time to 16 cycles per grid |
| 06 | Set digit time to 32 cycles per grid |
| 07 | Set digit time to 64 cycles per grid |
| 08 | Enable Normal Display Mode (MSB in data words is ignored) |
| 09 | Enable Blank Mode (data words with MSB $=1$ will be blanked) |
| OA | Enable Inverse Mode (data words with MSB = 1 will be "inversed") |
| OB | Not used |
| OC | Not used |
| OD | Not used |
| OE | Start Display Refresh Cycle (use only once after reset) |
| OF | Not used |
| 10-3F | Not used |
| 40-7F | Load Duty Cycle Register with lower 6 bits (0-63) |
| 80-9F | Load Digit Counter ( $80=32,81=1,82=2$, etc.) |
| A0-BF | Not used |
| C0-DF | Load Buffer Pointer Register with lower 5 bits |
| E0-FF | Not used |

## Load Buffer Pointer

The Load Buffer Pointer code sets the Display Data Buffer pointer. The lower 5 bits of the code are loaded into the buffer pointer (see Table 2).

Table 2. Load Buffer Pointer Codes
$\left.\begin{array}{|c|c|c|}\hline \begin{array}{c}\text { Code } \\ \text { Value }\end{array} & \begin{array}{c}\text { Pointer } \\ \text { Value }\end{array} & \begin{array}{c}\text { Character } \\ \text { Position }\end{array} \\ \hline \text { C0 } & 00 & 0 \\ \text { C1 } & 01 & 1 \\ \text { C2 } & 02 & 2 \\ \text { C3 } & 03 & 3 \\ \text { C4 } & 04 & 4 \\ \text { C5 } & 05 & 5 \\ \text { C6 } & 06 & 6 \\ \text { C7 } & 07 & 7 \\ \text { C8 } & 08 & 8 \\ \text { C9 } & 09 & 9 \\ \text { CA } & 0 A & 10 \\ \text { CB } & 0 B & 11 \\ \text { CC } & 0 \text { C } & 12 \\ \text { CD } & 0 D & 13 \\ \text { CE } & 0 E & 14 \\ \text { CF } & 0 F & 15 \\ \text { D0 } & 10 & 16 \\ \text { D1 } & 11 & 17 \\ \text { D2 } & 12 & 18 \\ \text { D3 } & 13 & 19 \\ \text { D4 } & 14 & 20 \\ \text { D5 } & 15 & 21 \\ \text { D6 } & 16 & 22 \\ \text { D7 } & 17 & 23 \\ \text { D8 } & 18 & 24 \\ \text { D9 } & 19 & 25 \\ \text { DA } & 1 A & 26 \\ \text { DB } & 1 B & 27 \\ \text { DC } & 1 C & 28 \\ \text { DD } & 1 D & 29 \\ \text { DE } & 1 E & 30 \\ \text { DF } & 1 F & 31\end{array}\right\}$

## Load Digit Counter

The Load Digit Counter defines the number of character positions (grids) to be controlled. This code is normally used only during initialization routines, but it may also be used in conjunction with the Load Duty Cycle control code to extend the range of brightness control (see Table 3).

## Load Duty Cycle

The Load Duty Cycle code is used to turn the display on and off, to adjust display brightness, or to modify display timing. The time slot for each character is 16,32 , or 64 cycles as selected by the Load Digit Time codes (see Table 3). The segment and digit drivers for each character are on for a maximum of 13,29 , or 61 cycles with a 3.0 cycle inter-digit off-time. The lower 6 bits of the Load Duty Cycle code are loaded into the Duty Cycle Register. Resultant duty cycles are shown in Table 4.

Table 3. Load Digit Counter Codes

| Code | Digit <br> Counter Value | No. of Grids <br> Controlled |
| :---: | :---: | :---: |
| 80 | 00 | 32 |
| 81 | 01 | 1 |
| 82 | 02 | 2 |
| 83 | 03 | 3 |
| 84 | 04 | 4 |
| 85 | 05 | 5 |
| 86 | 06 | 6 |
| 87 | 07 | 7 |
| 88 | 08 | 8 |
| 89 | 09 | 9 |
| 8 A | 0 A | 10 |
| 8 B | 0 B | 11 |
| 8 C | 0 C | 12 |
| 8 D | 0 D | 13 |
| 8 E | 0 E | 14 |
| 8 F | 0 F | 15 |
| 90 | 10 | 16 |
| 91 | 11 | 17 |
| 92 | 12 | 18 |
| 93 | 13 | 19 |
| 94 | 14 | 20 |
| 95 | 15 | 21 |
| 96 | 16 | 22 |
| 97 | 17 | 23 |
| 98 | 18 | 24 |
| 99 | 19 | 25 |
| 9 A | 1 A | 26 |
| 9 B | 1 B | 27 |
| 9 C | 1 C | 28 |
| 9 D | 1 D | 29 |
| 9 E | 1 E | 30 |
| 9 F | 1 F | 31 |
|  |  |  |

## Load Digit Time

The Load Digit Time codes set the total time for each character during the refresh cycle. Three values can be set using the three codes shown in Table 1. The default value set at power-on is 64 cycles per grid. For displays with 40 or more characters, or under conditions where the display can be subjected to quick movements during viewing (e.g. portable or vehicle-mounted applications), it may be necessary to increase the refresh rate by selecting 16 or 32 cycles per grid with the appropriate control code.

## Enable Display Mode

Each ASCII character is represented by the lower seven bits of the 8 -bit value loaded into the 10939. The eighth (most significant) bit is ignored in Normal display mode. If either Blank or Inverse mode is selected, however, a " 0 " in this bit selects Normal display mode, while a "1" selects either Blank or Inverse mode, depending on which mode is enabled. Three control codes are provided (see Table 1) to enable blank mode, enable inverse mode, or enable normal mode.

Table 4. Duty Cycle Control Codes

| Code | Digit Time $=16$ |  | Digit Time $=32$ |  | Digit Time $=64$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | On | Off | On | Off | On | Off |
| 40 | - | 16 | - | 32 | - | 64 |
| 41 | - | 16 | - | 32 | - | 64 |
| 42 | - | 16 | - | 32 | - | 64 |
| 43 | 1 | 15 | 1 | 31 | 1 | 63 |
| 44 | 2 | 14 | 2 | 30 | 2 | 62 |
| 45 | 3 | 13 | 3 | 29 | 3 | 61 |
| 46 | 4 | 12 | 4 | 28 | 4 | 60 |
| 47 | 5 | 11 | 5 | 27 | 5 | 59 |
| 48 | 6 | 10 | 6 | 26 | 6 | 58 |
| 49 | 7 | 9 | 7 | 25 | 7 | 57 |
| 4A | 8 | 8 | 8 | 24 | 8 | 56 |
| 4B | 9 | 7 | 9 | 23 | 9 | 55 |
| 4C | 10 | 6 | 10 | 22 | 10 | 54 |
| 4D | 11 | 5 | 11 | 21 | 11 | 53 |
| 4E | 12 | 4 | 12 | 20 | 12 | 52 |
| 4F | 13 | 3 | 13 | 19 | 13 | 51 |
| 50 | 13 | 3 | 14 | 18 | 14 | 50 |
| 51 | 13 | 3 | 15 | 17 | 15 | 49 |
| 52 | 13 | 3 | 16 | 16 | 16 | 48 |
| . | " | " | 17 | 15 | 17 | 47 |
| . | - | - | - | . | . | . |
| - | - | - | . | - | - | . |
| B | " | ; |  |  |  | 3 |
| 5B | " | " | 25 | 7 | 25 | 39 |
| 5C | " | " | 26 | 6 | 26 | 38 |
| 5D | " | " | 27 | 5 | 27 | 37 |
| 5E | " | " | 28 | 4 | 28 | 36 |
| 5F | " | " | 29 | 3 | 29. | 35 |
| 60 | " | " | 29 | 3 | 30 | 34 |
| . | " | " | 29 | 3 | 31 | 33 |
| . | " | " | " | " | 32 | 32 |
| . | - | . | - | . | . | . |
| . | - | . | . | . | - | . |
| 7 C | " | " | " | " | 58 | 6 |
| 7 D | " | " | " | " | 59 | 6 |
| 7 E | " | " | " | " | 60 | 5 |
| 7F | " | " | " | " | 61 | 3 |

In the Blank mode, any character with the MSB="1" will be blanked. In the Inverse mode, it will be displayed with all segment driver outputs inverted. On video displays, this is referred to as "Inverse Video" format. These controls allow individual characters or groups of characters to be blinked or blanked by simply changing the mode without changing the data in the Display Buffer.

## Start Refresh

At power on, the 10939 is held in an internal Halt mode. The normal display refresh sequence starts upon receipt of a Start Refresh control code. This is particularly useful for synchronizing systems using more than one 10939. Only the Master 10939 in a multi-chip system will recognize the Start Refresh code. The Master starts the Slave(s) at the appropriate time, using the SYNCO signal.

## INPUT DISPLAY DATA WORDS

Display data words are loaded as 8 -bit codes. The eighth (most significant) bit specifies normal (0) or blank/inverse (1) display mode, depending on the blank/inverse mode selection (see Control data words 09 and OA in Table 1). Figure 1 shows the ASCII codes for the segment patterns for a bargraph display.

Twenty display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer automatically increments after each data word is stored in the buffer. To select the next character position to be loaded out of sequence, use the Load Buffer Pointer command. The Buffer Pointer will automatically reset to character position 0 when its value is equal to the Digit Counter programmed value.

## POWER-ON RESET

The Power-On Reset (POR) initializes the internal circuits of the 10939. This is normally accomplished when power ( $\mathrm{V}_{\mathrm{DD}}$ ) is applied. The following conditions are established by application of POR:
a. The Grid Drivers (STR00-STR19) on the 10939 are in the off state.
b., The Segment Drivers (SG01-SG16) on the 10941 are in the off state.
c. The Duty Cycle is set to 0 .
d. The Digit Counter is set to 32.
e. The Buffer Pointer is set to 0 .
f. The Digit time is set to 64 .
g. The Normal display mode is set.
$h$. DATA-LOAD is set to high impedance state.
i. SCLK-DIS is set to $\mathrm{V}_{\mathrm{OL}}$ to disable the segment drivers in the 10941.
j. SOP is set to $V_{O L}$ to disable the sync puise.

## NOTES:

1. When the POR signal is removed, SCLK-DIS is set to the high impedance state.
2. During the initial rise time of $\mathrm{V}_{\mathrm{DD}}$ at power turn-on, the magnitude of $V_{G G}$ should not exceed the magnitude of $V_{D D}$.

## DIGIT DRIVERS (STROO-STR19) PLUS CURSOR

The 20 Digit Drivers select each of the display character positions sequentially during a refresh scan. Display segments will be illuminated when both the Digit Drivers and Segment Drivers for a particular character are energized simultaneously. The Cursor segment is generated by the 10939, but its timing characteristics are identical to the 16 segments generated by the 10941.

## SEGMENT DRIVERS (SG01-SG16)

Sixteen Segment Drivers are provided in the 10941. The output states for each ASCII character pattern and each bargraph pattern are internally decoded from the 8 -bit characters received from the 10939 by means of a $96 \times 16$-bit PLA. Data codes and the corresponding of the ASCII patterns are shown in Figure 1. Data codes and the corresponding bargraph patterns are shown in Figure 2.


Figure 1. 10941 14-Segment Display Patterns

| Input Code |  |  |  |  |  |  |  |  |  | Segment Patterns (1=On) |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7 | 6 | 5 | 54 | 4 | 3 | 2 | 1 | 0 |  | A | B | C | D | E | F | G | H | 1 | J | K | L | M | N | 0 | P |
| 0 | 1 |  |  | 0 | 0 | 0 | 0 |  |  | 1 |  |  |  |  | - |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 10 | 0 | 0 | 0 | 0 | 1 |  |  | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 10 | 0 | 0 | 0 | 1 |  |  |  |  | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 10 | 0 | 0 | 0 | 1 | 1 |  |  |  |  | 1 |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 10 | 0 | 0 | 1 | 0 | 0 |  |  |  |  |  | 1 |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 10 | 0 | 0 | 1 | 0 |  |  |  |  |  |  |  | 1 |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 10 | 0 | 0 | 1 | 1 | 0 |  |  |  |  |  |  |  | 1 |  |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 10 | 0 | . 0 | 1 | 1 | 1 |  |  |  |  |  |  |  |  | 1 |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 10 | 0 | 1 | 0 | 0 | 0 |  |  |  |  |  |  |  |  |  | 1 |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 10 | 0 | 1 | 0 | 0 | 1 |  |  |  |  |  |  |  |  |  |  | 1 |  |  |  |  |  |  |
| 0 | 1 | 1 | 1 | 0 | 1 | 0 | 1 |  |  |  |  |  |  |  |  |  |  |  |  | 1 |  |  |  |  |  |
| 0 | 1 | 1 | 10 | 0 | 1 | 0 | 1 | 1 |  |  |  |  |  |  |  |  |  |  |  |  | 1 |  |  |  |  |
| 0 | 1 | 1 | 10 | 0 | 1 | 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 |  |  |  |
| 0 | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 |  |  |
| 0 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 |  |
| 0 | 1 |  | 1 | 0 | 1 | 1 | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 |
| 0 | 1 |  | 1 | 1 | 0 | 0 | 0 | 0 |  | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 |  | 1 | 1 | 0 | 0 | 0 |  |  | 1 | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 |  | 0 | 1 | 1 | 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 |  | 1 | 1 | 0 | 1 | 0 |  | 0 | 1 | 1 | 1 | 1 | 1 |  |  |  |  |  |  |  |  |  |  |  |
| 0 | 1 |  | 1 | 1 | 0 | 1 | 0 |  | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |  | - |  |  |  |  |  |
| 0 | 1 |  | 1 | 1 | 0 | 1 | 1 |  | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | - |  |  |  |  |  |  |  |  |
| 0 | 1 |  | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |  |  |  |  |  |
| 0 | 1 |  | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | : 1 | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |  |  |  |  |
| 0 | 1 |  | 1 | 1 | 1 | 0 | 0 |  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |  |  |  |
| 0 | 1 |  | 1 | 1 | 1 | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1. | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |  |  |
| 0 | 1 |  | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  | . |  |  |
| 0 | 1 |  | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  |  |  |
| 0 | 1 |  | 1 | 1 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1. | 1 | 1 | 1 |  |  |
| 0 | 1 |  | 1 | 1 | 1 | 1 | 1 | 1 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |  |
| 0 | 1 |  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

Figure 2. 10941 Bargraph PLA Codes

## TYPICAL SYSTEM HOOKUPS

Figure 3 shows a 10941 and a 10939 in a parallel interface with the host system driving a 20 character display. Figure 4 shows a 10941 and a 10939 in a serial interface with the
host system driving a 20 character display. Figure 5 shows a 10941 and two 10939's interfaced parallel with the host system driving a 40 character display.


Figure 3. Typical Display System with Parallel Interface to Host System


Figure 4. Typical Display System with Serial Interface to Host System


Figure 5. Typical Display System with Parallel Interface to Host and Two 10939 Devices

## 10951

## BARGRAPH \& NUMERIC DISPLAY CONTROLLER

## Preliminary

## DESCRIPTION

The Rockwell 10951 Bargraph \& Numeric Display Controller (referred to as the 10951) is a LSI general purpose display controller designed to interface to segmented displays (gas discharge, vacuum fluorescent, or LED).

The 10951 will drive 16 -segment bargraph or seven-segment plus comma and decimal numeric displays with up to 16 display positions. The controller accepts command and data input words on a clocked serial input line. Commands control the on/off duty cycle, starting character position and number of characters to display. Encoded data words display bargraph position (single segment or increasing bar length), numbers, comma, decimal and selected upper and lower case letters. No external drive circuitry is required for displays that operate on 10 ma of drive current up to 40 volts. A $64 \times 16$-bit segment decoder provides internal ASCII character set decoding for the display.

## ORDERING INFORMATION

| Part <br> Number | Package <br> Type | Drive <br> Voltage | Temperature <br> Range |
| :--- | :---: | :---: | :---: |
| 10951 P-50 | Plastic | 50 V | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ |
| 10951 PE-50 | Plastic | 50 V | $-40^{\circ} \mathrm{C}$ to $+85^{\circ} \mathrm{C}$ |

## FEATURES

- 16 segment drivers plus decimal point and comma tail drivers
- 16 digit drivers
- Average data rate: 66 kHz
- Single character burst rate: 500 kHz
- TTL compatible
- Direct digit drive of 10 ma for 30,35 , and 40 volt displays
- Supports gas-discharge, vacuum fluorescent, or LED displays
- Serial data input for 8-bit display and control data words
- $64 \times 16$-bit PLA provides data decoding driving
-Any 1 of 16 bargraph segments
-1 to 16 bargraph segments
-Ten seven-segment numeric characters (0-9)
-Comma and decimal
-Eight upper and lower case seven-segment characters
- Command functions
-On/off duty cycle
-Character position
-Number of characters
- 40-Pin DIP



## INTERFACE DESCRIPTION

10951 Pin Functions

| Signal Name | Pin No. | Function |
| :--- | :---: | :--- |
| VSS | 1 | Power and signal ground |
| AD16-AD1 | $2-17$ | Digits 16 through 1 driver outputs |
| VDD | 18 | DC power connection |
| A | 19 | A clock used only for device testing |
| POR | 20 | Power-on reset input |
| DATA | 21 | Serial data input |
| SCLK | 22 | Serial data clock input |
| SGA-SGP | $23-38$ | Segments A through P driver outputs |
| TAIL | 39 | Comma tail driver output |
| PNT | 40 | Decimal point driver output |

## SPECIFICATIONS

## Maximum Ratings

| Parameter | Symbol | Min | Typ | Max | Unit |
| :--- | :---: | :---: | :---: | :---: | :--- |
| Supply Voltage | $\mathrm{V}_{\mathrm{DD}}$ | +0.3 |  | -20 | V |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ |  | 40 | 100 | mW |
| Input Voltage | $\mathrm{V}_{\text {IN }}$ | +0.3 |  | -20 | V |
| Output Voltage | $\mathrm{V}_{\text {OUT }}$ | +0.3 |  | -40 | V |
| Operating Temperature |  |  |  |  |  |
| Commercial | $\mathrm{T}_{\mathrm{C}}$ | 0 |  | +70 | ${ }^{\circ} \mathrm{C}$ |
| $\quad$ Industrial | $\mathrm{T}_{\mathrm{I}}$ | -40 |  | +85 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 |  | +125 | ${ }^{\circ} \mathrm{C}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ |  |  | 5 | pf |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ |  |  | 10 | pf |



## 10951 Pin Configuration

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 to this circuit.

All voltages are specified relative to $V_{\text {SS }}$.

## DC Characteristics

| Parameter | Limits ( $\mathrm{V}_{\text {ss }}=0$ ) |  |  | Limits ( $\mathrm{V}_{\text {ss }}=+5 \mathrm{~V}$ ) |  |  | Conditions | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Min. | Typ. | Max. | Min. | Typ. | Max. |  |  |
| Supply Voltage (VD) | -16.5 | -15.0 | -13.5 | -11.5 | -10.0 | -8.5 |  | V |
| Input DATA, SCLK, |  |  |  |  |  |  |  | $v$ |
| Logic "1" | -1.0 |  | +0.3 | +4.0 |  | +5.3 |  | V |
| Logic "0" | $V_{\text {DD }}$ |  | -4.2 | $V_{D D}$ |  | +0.8 |  |  |
| Input POR |  |  |  |  |  |  |  |  |
| Logic "1" | -3.0 |  | +0.3 | +2.0 |  | +5.3 |  |  |
| Logic "0" | $V_{D D}$ |  | -10.0 | $V_{D D}$ |  | -5.0 |  |  |
|  |  |  |  |  |  |  |  |  |
| Segment Strobes |  |  |  |  |  |  |  |  |
| Driver On |  |  |  |  |  |  |  |  |
| Commercial |  |  | -1.5 |  |  | +3.5 | At 10 mA | v |
| Industrial |  |  |  |  |  | +3.3 | $\{$ Actual value | v |
| Driver Off 10951-50 |  |  | -50 |  |  | -45 | Actual value determined by external circuit | v |
| Output Leakage |  |  | 10 |  |  | 10 | ) Per driver at | $\mu \mathrm{A}$ |
| Input Leakage |  |  | 10 |  |  | 10 | $\}_{\text {driver off }}$ | $\mu \mathrm{A}$ |
| NOTES: All outputs require Pulldown Resistors. |  |  |  |  |  |  |  |  |

AC Characteristics

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Internal Clock (1 Bit Time) | $\mathrm{T}_{\text {cyc }}$ |  |  |  |  |
| Commercial |  | 6.67 | 10.0 | 20.0 | $\mu \mathrm{s}$ |
| Industrial |  | 5.88 | 10.0 | 22.2 | $\mu \mathrm{s}$ |
| Segment or Digit Strobe Output | $\mathrm{T}_{\text {out }}$ | 200 |  |  | ns |
| SCLK Clock |  |  |  |  |  |
| On Time | $\mathrm{T}_{\text {on }}$ | 1.0 |  | 20.0 | $\mu \mathrm{S}$ |
| Off Time | $\mathrm{T}_{\text {off }}$ | 1.0 |  |  | $\mu \mathrm{s}$ |
| Data Input Sample Time |  |  |  |  |  |
| Before SCLK Clock Off | $T_{\text {boff }}$ | 200 |  |  | ns |
| After SCLK Clock Off | $\mathrm{T}_{\text {aoff }}$ | 100 |  |  | ns |

SCLK and Serial Data Timing


## SCLK and Serial Data (Control Word) Examples



NOTE: Crosshatch = don't care
Data Word LSB/MSB Timing


Power-On Reset Voltage Limits

NOTE: $\mathbf{V}_{\text {ss }}$ referenced to 0 V


## FUNCTIONAL DESCRIPTION

The 10951 receives commands and data on a serial input line clocked externally by a separate clock input line. The controller decodes the commands from control data words, decodes the data words in accordance with an internal $64 \times 16$ bit programmable logic array (PLA) and turns on and off segment and digit output drivers. The segment output patterns are controlled by the decoded data words while the digit output and segment output timing are controlled by the decoded control words. All timing signals required to control the display are generated in the 10951 device without any refresh input from the host processor.
Input data is loaded into the Display Data Buffer via the Serial Data Input (Data) channel. Internal timing and control blocks synchronize the segment and digit output signals to provide the proper timing for the multiplexing operation. The $16 \times 64$ PLA decodes 8 -bit data words to drive the 16 segment, comma and decimal point drivers. The decoded data words will drive 16 segments to display bargraph patterns (single segment and multiple segment for increasing length displays) or seven-segment patterns to display numbers, selected upper and lower case letters, comma and decimal point.

Input data is loaded into the 10951 as a series of 8 -bit words with the most significant bit (MSB), bit 7 . If bit 7 of any word loaded is a logical 1 (this bit is referred to as the control bit C), the loaded word is a control data word. If the C bit of any word is a logical 0 , the loaded word is a display data word. The following paragraphs describe the format and functions of these control and display data words.

## INPUT CONTROL DATA WORDS

When the C-Bit (bit 7 ) of the 8 -bit input word is a logical 1 , bits 5 and 6 are decoded into one of four control commands while data associated with the command are extracted from bits 0-4. There are three control codes which perform the following display functions:

- Load the Display Data Buffer pointer,
- Load the Digit Counter,
- Load the Duty Cycle register.

A fourth control code is defined but is not intended as a user function (see note associated with Table 1). Table 1 lists the control codes and their functions.

## Load Buffer Pointer

The LOAD BUFFER POINTER code allows the Display Data Buffer pointer to be set to any digit position so that individual characters may be modified. The LOAD BUFFER PTR is loaded with a decimal equivalent value 2 less than the desired value (i.e., to point to character 6 of the display, a value of 4 is entered).

## Load Digit Counter

The LOAD DIGIT COUNTER code is normally used only during initialization routines to define the number of character positions to be controlled. This code maximizes the duty cycle for any display. If 16 characters are to be controlled, enter a value of 0 (zero). Otherwise, enter the value desired.

## Load Duty Cycle

The LOAD DUTY CYCLE code is used to turn the display on and off, to adjust display brightness, or to modify display timing for gas discharge displays. As shown in the block diagram, the time slot for each character is 32 clock cycles. The Segment and Digit Drivers for each character are on for a maximum of 31 cycles with a 1 cycle inter-digit off-time. The LOAD DUTY CYCLE code contains a 5 -bit numeric field which modifies the on-time for segment Driver Outputs from 0 to 31 cycles. A duty cycle of 0 puts both the segment and digit drivers into the off state. Figure 1 shows the timing characteristics for the segment outputs.

## POWER-ON RESET (POR)

The Power-On Reset (POR) initializes the internal circuits of the 10951 when power $\left(V_{D D}\right)$ is applied. The following conditions are established after a Power-On Reset:
a. The Digit Drivers (AD1-AD16) are in the off state (floating).
b. The Segment Drivers (SGA-SGP) are in the off state (floating). This includes PNT and TAIL.
c. The cycle on-time for the LOAD DUTY CYCLE is set to 0 cycles.
d. The LOAD DIGIT COUNTER is set to 16 (a bit code value of 0 ).
e. The LOAD BUFFER POINTER is set to 15 to allow the first character to be entered into position 1.

Table 1. Control Data Words

| 8-Bit Control Word |  | Function |
| :---: | :---: | :---: |
| C-Bit | 7-Bit Code |  |
| $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | O10NNNN ${ }^{(1)}$ <br> 100NNNN ${ }^{(1)}$ <br> 11NNNNN ${ }^{(2)}$ <br> OONNNNN ${ }^{(3)}$ | LOAD BUFFER POINTER (Position of character to be changed) LOAD DIGIT COUNTER (Number of characters to be output) LOAD DUTY CYCLE (On/off and brightness control) TEST MODE ONLY (Not a user function) |
| NOTE: 1. NNNN is a 4 -bit binary value representing the digit number to be loaded <br> 2. NNNNN is a 5 -bit binary value representing the number of clock cycles each digit is on. |  | 3. This code is a device test function only. If executed it will lock the device in the test mode which can be removed only by performing a power-on reset. |



Figure 1. Display Scan Timing Diagram (Duty Cycle)

## INPUT DISPLAY DATA WORDS

Display data words are loaded as 8 -bit format codes. There are 64 codes available (with the C-bit set to 0 to indicate a display data word).

Sixteen display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer is automatically incremented before each data word is stored in the Display Buffer except for decimal point and comma words. The decimal point and comma words do not cause the Buffer Pointer to increment and thus are always associated with the previous character entered. To select the next character position to be loaded out of the normal sequence, use the LOAD BUFFER POINTER command before entering the display data word. It is not necessary to use the LOAD BUFFER POINTER command to cycle back to position 1 when less than 16 character positions are being used (DIGIT COUNTER $\neq 0$ ).

## DIGIT DRIVERS (AD1-AD16)

The sixteen Digit Drivers (AD1-AD16) are used to select each of the display digits sequentially during a refresh scan. Display segments will be illuminated when both the Digit


Figure 2. Segment Allocation

Drivers and Segment Drivers for a particular character are energized simultaneously. The timing characteristics of both the digits and segments are shown in Figure 1. See POR for the Power-On Reset state of these drivers.

## SEGMENT DRIVERS (SGA-SGP)

Sixteen (16) Segment Drivers are provided (SGA-SGP), plus the decimal point (PNT) and comma tail (TAIL). The segment, PNT and TAIL outputs are internally decoded from the 8 -bit characters in the Display Data Buffer by means of a 64 $\times 16$-bit PLA. The allocations for the 16 -segment bargraph display and the seven-segment alphanumeric character plus comma and decimal point are shown in Figure 2. The input codes associated with seven-segment alphanumeric, comma and decimal point display are shown in Figure 3. The complete set of 8-bit codes for the bargraph and alphanumeric display is shown in Table 2. Note that only segment drivers SGA-SGG are used to drive the seven-segment characters. Segment drivers SGH-SGP may be used for other purposes as decoded in accordance with Table 2. Timing characteristics for the segment outputs are shown in Figure 1. See POR for the Power-On Reset state of these drivers.

| $\begin{aligned} & \text { INPUT } \\ & \text { CODE } \\ & \text { (BITS 2-0) } \end{aligned}$ | INPUT CODE (BITS 7-3) |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
|  | 0X100 | 0X101 | 0X110 | $0 \times 111$ |
| 000 | 1 | - | 1 | $\square$ |
| 001 | 1 |  | $1$ | $\square$ |
| 010 | - |  | - | $\square$ |
| 011 | $\square$ |  | - |  |
| 100 | 1 | , | 1 |  |
| 101 | $\square$ |  |  | -1 |
| 110 | $\square$ | - |  | $\square$ |
| 111 | 7 |  | $\square$ | - |

Figure 3. 7-Segment Patterns

Table 2. 10951 Data Codes


## NOTES:

* Sets comma and decimal outputs for last character entered.
** Sets decimal output for last character entered.


## TYPICAL SYSTEM HOOK-UP

Figure 4 shows the 10951 driven by a Host System as it would be connected to a V-F display. $\mathrm{E}_{\mathrm{K}}$ is determined by the V-F display specifications and $R_{C}$ is selected to provide proper biasing
current for zeners. Pull down resistors $R_{A}$ and $R_{G}$ are determined by the interconnection capacitance between the 10951 and the display.


Figure 4. Typical System Schematic

## SECTION 6 MICROCOMPUTER DEVELOPMENT SYSTEMS

Page
Product Family Overview ..... 6-2
Rockwell Design Center (RDC)
RDC-1001 and RDC-1002 RDC System ..... 6-3
RDC-1XX and RDC-3XX RDC R6500/* Personality Set ..... 6-9
RDC-502 and RDC-504 R6502-R65C02 Personality Set ..... 6-13
RDC-2000 R6500 Cross Assembler for Intel Development System ..... 6-17
System 65 Development System (Optional Modules)
M65-1XX and M65-2XX System 65 R6500/* Personality Set ..... 6-19
M65-001, M65-002, and M65-003 User 65 Module ..... 6-23
M65-031 and M65-032 16K Static RAM Module ..... 6-28
M65-040 PROM Programmer Module ..... 6-31
M65-045 PROM/ROM Module ..... 6-39
M65-060 Extender Card ..... 6-43
M65-071 Design Prototyping Module ..... 6-44
M65-660 Macro Assembler and Linking Loader ..... 6-46
Software Preparation System
SPS-200 Software Preparation System Peripheral Connector Module ..... 6-48

## MICROCOMPUTER DEVELOPMENT SYSTEMS Low Cost, Flexible Systems Work With Multiple $\mu$ Cs

To support product development, Rockwell offers a range of microcomputer development systems, each extremely economical when compared on a cost/performance basis with competitive development systems.

The Rockwell AIM 65 microcomputer described in Section 7 functions as an extremely low cost, expandable, development system when used with the Rockwell Software Preparation System kit. The Rockwell Design Center (RDC) is an excellent, low cost, disk based development system, allowing concurrent development of up to four target R6500 and R6500/* systems.
The RDC is an easy to use, powerful development system for multi-chip and one-chip R6500 systems. A full line of support modules, macro assembler, link editor and high level PL/65 language are also available. R6500/* personality modules, additional RAM and a PROM programmer help add versatility.

The RDC supports the growing trend to using single-chip microcomputers as slaves with multi- or single-chip microprocessor systems. The advantages of slaves include both cost and technical savings, such as eliminating some complex timing relationships. With the RDC, up to four different microprocessor personality modules can be performing in-circuit-emulation under control of the system. The RDC mainframe is constructed modularly, using the proven RM Eurocard design, so it can be expanded readily, as needed. The terminal unit includes CRT, disk drives, and keyboard. Up to 1.28 Mbytes can be addressed on the two 96 TPI, double sided, double density, $51 / 4$-inch disk drives.

The RDC allows designers to economically and efficiently develop multiple microcomputer systems, regardless of the microcomputer device involved. Personality sets and target RAM modules are available for all R6500 and R6500/* configurations.


Rockwell Design Center Development System

# RDC-1001/2 ROCKWELL DESIGN CENTER (RDC) 

## INTRODUCTION

The Rockwell Design Center (RDC) is a development system vertically integrated to support the entire R6500 family of microprocessors and microcomputers. The RDC allows emulation, development, and software debugging of up to four separate microprocessors and microcomputers concurrently, even if the four devices are different members of the R6500 family. The RDC is a disk-based system with two 96 TPI, double-sided, double-density $51 / 4$-inch floppy disk drives that provide a storage capacity of up to 1.3 M bytes of data (formatted).

A unique bus structure provides a separate system bus and four target busses which can operate at different speeds (up to 4 MHz ). Construction of the RDC is modular based on the proven RM 65 design using both single- and double-sized Eurocards and highly reliable DIN 41612 pin and socket connectors. The double Eurocards allow use of both the system bus and a target bus which can operate at different speeds.

Featuring Softkey function keys, the RDC eliminates the need for an operator to learn extra key strokes and command structures. A command line of operating modes is displayed across the bottom of the CRT screen so that the user need only push the corresponding function key to command the RDC to enter the mode of operation desired.

## FEATURES

## Hardware

- Modular construction based on proven RM 65 architecture
- Highly reliable, standard DIN 41612 pin and socket connectors
- Non-glare 12-inch CRT, green phosphor
- Detachable full ASCII intelligent keyboard
- Dual 96 TPI, double-sided, double-density $51 / 4$-inch floppy disk drives
- Separate system bus and four independent target busses
- Two serial ports-one for RDC terminal interface-one for host system download
- Two parallel ports-one for RDC terminal interface-one for external printer
- 64K byte RAM system memory
- Internal self-test panel for system troubleshooting
- Three separate CPUs for keyboard, CRT, and system control
- Designed for built-in PROM programmer option

For users who already have an Intel ISIS II with mass storage program management, an R6500 cross-assembler is available. This.allows the RDC to function as a satellite, providing a powerful debug system. The RDC is also capable of receiving files from the Rockwell SYSTEM 65 Microcomputer.

When used with the R6500/* Microcomputer or R6502-R65C02 Microprocessor Personality Sets, the RDC is a powerful emulation system for the complete family of Rockwell R6500/* onechip microcomputers or NMOS R6502 and CMOS R65C02 families of microprocessors. The multiple target bus structure of the RDC allows the user to emulate four devices concurrently, and at different speeds.


## Rockwell Design Center System

## Functional

- Self-contained, disk-based operating system
- Softkey function access to menu-driven operational modes
- Text Editor
- R6500 Macro Assembler/Linking Leader
- SYSGEN configurable to user environment
- Automatic power-up initialization of system and configurations
- Separate system and target memory map
- 4 target simultaneous emulation
- Real-time in-circuit emulation, up to 4 MHz
- Five hardware breakpoints per target, 32-bits wide with "don't care'' bits
- Inside or outside window breakpoint with 1 byte resolution
- Configurable as a satellite for an Intel ISIS II host system or Rockwell SYSTEM 65
- Self-test software


## PRODUCT OVERVIEW

The RDC consists of three assemblies; the mainframe, a CRT terminal with floppy disk drives and a full ASCII keyboard. The mainframe contains the following components:

- The system bus and target/user busses
- Power supply and system cooling fans
- Two 32K Dynamic RAM modules for system memory
- Single Board Computer (SBC) module
- Floppy Disk Controller (FDC) module
- Asynchronous Communications Interface Adapter (ACIA) module with 2 channels for keyboard interface and user RS-232C
- Multi-function Peripheral Interface (MPI) module with two ports for interface to the CRT terminal and to a printer
- 24-pin and 28 -pin PROM sockets for optional PROM Programmer module

The terminal assembly consists of a non-glare 12 -inch, green phosphor CRT, a video display controller module, and two $51 / 4-$ inch floppy disk drives. The keyboard is intelligent for full ASCII operation.

## FUNCTIONAL DESCRIPTION

## Major Components and Interfaces

The block diagram shows the architecture of the RDC system and identifies the relationship between the system bus and the target busses. Although the block diagram shows only one Target Interface, it represents the architecture of each of the four target busses. The terminal keyboard interfaces with the RDC system through one of the RS-232C ports (J3 connected to the ACIA module). The CRT interfaces with the RDC system through a parallel port (J3 connected to the MPI module). The disk drives interface to the RDC system through a separate port (J2 connected to the FDC module). All other control functions of the RDC system interface directly through the RDC system bus. Note that the Personality Set PMC module interfaces the RDC system bus to the target bus.

## Bus Structure

The RDC system operates through a multiple bus structure-a system bus and four target busses. The system bus contains 21 card slots to accommodate single Eurocard modules or


RDC System Block Diagram
double Eurocard modules. Double Eurocard modules plugged into the system bus are common to the system bus and the target bus. Double Eurocard modules (such as the R6500/* Personality Set PMC module) are used for microcomputer emulation support. Single Eurocard module connectors on the system bus are used to interface with RDC microcomputer system modules such as the 32 K RAM(2), SBC, FDC, ACIA, and MPI.

The four target busses are segmented so that four separate emulations can be controlled by the system concurrently. Three of the target busses have four card slots each. Three of these slots will accept double Eurocard modules, and the fourth will accept a single Eurocard module. The double card slots are intended for a Personality Module Controller (PMC) module and future growth up to two Analyzer modules. The single card slot is
intended for plugging in a target (emulation) RAM module ( 8 K $\times 8$ or $64 \mathrm{~K} \times 8$ depending upon the microcomputer to be emulated). These three target busses are color coded (blue, red, and yellow) on the RDC card cage for easy identification of the division of the target bus segments. The fourth target bus consists of nine Euroconnectors, four of which will accept double Eurocard modules and five of which will accept single Eurocard modules.

A typical single target emulation configuration will consist of an R6500/* or R6502-R65C02 Personality Set (comprising a PMC module, Personality Pod, and Emulator Interface) and a target RAM module, as a minimum. Since up to four fully configured emulation systems can be supported concurrently, the RDC could be configured with any combination of four R6500/* or R6502-R65C02 Personality Sets, and four target RAM modules in addition to the RDC system control modules.


## Operating Modes

The RDC bootstrap ROM is initiated whenever the system is powered-up. The bootstrap program then loads the SYSGEN data and system program from the system disk drive. When the bootstrap is completed the CRT displays a Softkey menu for the function keys on the keyboard. It is this menu that prompts the user to select the mode of operation required. The Softkey prompts displayed at this time are:

## SATELLITE LOCAL <br> SYSGEN <br> HELP

These Softkey prompts represent the primary modes of operation for the RDC system. When the function key corresponding to the CRT prompt location is pressed, one of the following modes is selected:

SATELLITE-This mode provides the menus available for interfacing the RDC as a satellite to the host system (Intel ISIS II)

LOCAL -This mode provides the menus available to the user from within the RDC without requiring host resources.

SYSGEN - This mode allows the user to modify the diskettestored system parameters on either a permanent (until another power-up condition) or a temporary basis.

HELP -This mode displays information which briefly describes the operational mode options available in SATELLITE, LOCAL and SYSGEN modes. All Softkey menus include a HELP which is always located on the CRT screen directly over the far right hand function key on the keyboard.

Each Softkey prompt, when selected by the function key, invokes a new set of Softkey prompts which further define the tasks to be performed by the mode. As an example, if the LOCAL prompt is selected, a new Softkey prompt menu displays:
UTILITY, DEBUG

HELP
If UTILITY is selected from this prompt, a new menu displays:
DISK FILE EXEC HELP

Selecting DISK invokes a new menu which asks:

```
COPY BACKUP FORMAT DIR INIT HELP
```

This hierarchy continues until all parameters of the tasks of the mode selected have been established. At any time during the mode selection process the user has the option of calling back the previous set of Softkey menu prompts by simply pushing the - (minus) key.

The illustration shows the depth to which the command line prompts guide the user through selecting the desired mode of operation.

| Mode | Command Line Prompts. |
| :---: | :---: |
| SATELLITE $\longrightarrow$ DOWNLOAD (ISIS II or SYSTEM 65 PROTOCOL) • HELP |  |
| LOCAL |  |
| SYSGEN |  |
| HELP | MODE COMMAND LIST EXPLANATIONS |

Command Line Hierarchy (Typical)

## INTERFACE

Interface between the RDC system control modules and the port connectors on the back panel are made through ribbon cables. The ribbon cables are permanently attached to the port connectors. The terminal interfaces to the RDC system through two cables with mating connectors on each end that are keyed for proper installation. The RDC Cable Interface figure shows how
these cables are routed in the system. The Self-Test Panel interface ribbon cable is attached to the test panel and has a connector on the other end that mates to the SBC module I/O connector. The optional PROM programmer module connects to the two PROM sockets through a single ribbon cable.


NOTE: (1) Ribbon cables are physically attached to RDC Mainframe other end that mate to the modules.

RDC Mainframe Internal/External Ribbon Cable Connections

## SPECIFICATIONS

| Parameter | RDC Mainframe | RDC Terminal |  |
| :---: | :---: | :---: | :---: |
|  |  | CRT/FDD | Keyboard |
| Dimensions Height Width Depth | 11 in. ( 27.94 cm ) $20 \mathrm{in} .(50.80 \mathrm{~cm})$ 18 in. $(45.72 \mathrm{~cm})$ | 14 in. ( 35.56 cm ) 20 in . $(50.80 \mathrm{~cm})$ $16 \mathrm{in} .(40.64 \mathrm{~cm})$ | 3 in. $\quad(7.62 \mathrm{~cm})$ $20 \mathrm{in} .(50.80 \mathrm{~cm})$ 8 in. ( 20.32 cm ) |
| Weight | 40 lbs . $(18 \mathrm{Kg})$ | 42 lbs . 19 Kg ) | $6 \mathrm{lbs} .(2.7 \mathrm{Kg})$ |
| Electrical AC Input Voltage <br> AC Frequency Fuse Requirement | 105 to 125 (RDC-1001) <br> 210 to 250 (RDC-1002) <br> 47 to 63 Hz <br> 3 A slo-blo (RDC-1001) <br> 1.5 A slo-blo (RDC-1002) | 105 to 125 (RDC-1001) 210 to 250 (RDC-1002) 47 to 63 Hz 3 A slo-blo (RDC-1001) 1.5 A slo-blo (RDC-1002) |  |
| Environmental Temperature With/Disk Media Humidity | $59^{\circ} \mathrm{F}$ to $104^{\circ} \mathrm{F}\left(15^{\circ} \mathrm{C}\right.$ to $\left.40^{\circ} \mathrm{C}\right)$ operating $-4^{\circ} \mathrm{F}$ to $140^{\circ} \mathrm{F}\left(-20^{\circ} \mathrm{C}\right.$ to $\left.60^{\circ} \mathrm{C}\right)$ shipping $-4^{\circ} \mathrm{F}$ to $122^{\circ} \mathrm{F}\left(-20^{\circ} \mathrm{C}\right.$ to $\left.50^{\circ} \mathrm{C}\right)$ storage $20 \%$ to $80 \%$ non-condensing operating* $1 \%$ to $95 \%$ non-condensing shipping $1 \%$ to $95 \%$ non-condensing storage |  |  |
| NOTE: *Disk media maximum wet bulb temperature $84.9{ }^{\circ} \mathrm{F}\left(29.4{ }^{\circ} \mathrm{C}\right)$ |  |  |  |

## ORDERING INFORMATION

| Part Number | Description |
| :---: | :---: |
| RDC-1001 | RDC System (100 Vac)(1) |
| RDC-1002 | RDC System (220 Vac) ${ }^{(1)}$ |
| RDC-1010 | 32K System RAM Module |
| RDC-1011 | 8K Target RAM Module |
| RDC-1012 | 64K Target RAM Module |
| RDC-1030 | PROM Programmer Module |
| RDC-2000 | R6500 Cross Assembler for Intel ISIS II |
| Order Number ${ }^{(2)}$ | Document Title |
| RDC06 | RDC R6500/* Personality Set Data Sheet |
| RDC11 | RDC R6502-R65C02 Personality Set |
|  | Data Sheet |
| RDC12 | RDC PROM Programmer Data Sheet |
| RM08 | ACIA Module Data Sheet |
| RM10 | SBC Module Data Sheet |
| RM15 | FDC Module Data Sheet |
| RM24 | MPI Module Data Sheet |
| RM11 | 32K Dynamic RAM Module Data Sheet |
| Notes: <br> (1) Both system configurations are shipped with the following components: <br> - RDC Mainframe <br> - RDC Terminal with 12" CRT and Dual 51/4" Floppy Disk Drives and detached Keyboard <br> - Six System Control modules-ACIA, FDC, SBC, MPI, and two 32K DRAM <br> - All Required Interface Cables <br> - Software Package (Utilities, Text Editor, Macro Assembler) <br> - Documentation Package <br> (2) Documents provide further information about the RDC system. |  |
|  |  |
|  |  |

## PERSONALITY SETS

Personality Sets are available for the RDC that allow emulation, development, and software debugging of the complete family of R6500/* Microcomputers and R6502-R65C02 Microprocessors. The microcomputers and microprocessors supported by these Personality Sets are:

| R6500/11P | 13P | P | - R6511Q |
| :---: | :---: | :---: | :---: |
| R6500/12P | - R6500/41P | - R6500/43P | R65C02 |
| - R6541Q | - R6501Q | - R6502 | R6503 |
| R65C102 | - R65C112 | - R6506 | - R6507 |
| - R6504 | - R6505 | - R6514 | - R6515 |
| R6512 | - R6513 | R6500/1P |  |

For complete information on ordering any particular Personality Set or groups of Personality Sets, refer to the RDC R6500/* Personality Set Data Sheet, Order Number RDC06, or RDC R6502-R65C02 Personality Set Data Sheet, Order Number RDC11.

# RDC-1XX AND RDC-3XX ROCKWELL DESIGN CENTER R6500/* PERSONALITY SET 

## INTRODUCTION

The RDC R6500/* Personality Set is a Rockwell Design Center (RDC) option that allows the RDC user to develop, debug and verify programs intended for use by any R6500 one-chip microcomputer system. The R6500/* offers the user a high performance development system specifically designed for emulation of a microcomputer system. This RDC option supports in-circuit emulation for the entire R6500 family of one-chip microcomputers.

The basic R6500/* Personality Set includes a Personality Module Controller (PMC), two Personality Emulator Pod Modules, a Device Adapter, an In-Circuit Emulation Probe assembly, an interconnect cable set, and the required software and support documentation.

The R6500/* Personality Set provides the RDC with a dual CPU capability. This added feature permits the RDC CPU to maintain control, even while the R6500/* is executing a program, thus providing the user with complete control over the development process.

The R6500/* Personality Set can be expanded to include four separate emulation systems which can be run concurrently on the RDC.

## FEATURES

- Disk based macro assembler and debug monitor
- Provides 8K RAM in system (optional)
- Supports 65K address range in target environment
- Five hardware breakpoints with SYNC outputs
- User defined external break signal
- Single step through interrupts
- Supports four simultaneous target developments
- No zero page address conflicts
- Power down capability
- RAM write protection
- User or system supplied power and clock
- Real-time in-circuit emulation
- Menu-driven Softkey command selection


RDC R6500/* Personality Set


System Interconnection

## RUN MODE/CONTROLLED EXECUTION COMMAND SUMMARY

The R6500/* Personality Set is designed to allow the R6500/* to execute independent of the RDC. Thus, while the R650n/* is executing code, the RDC CPU is still in operation. This allows certain functions to be performed by the RDC CPU without disturbing the execution of the R6500/*.

## RUN MODE COMMANDS

The R6500/* debug monitor allows certain commands to be performed while the R6500/* is in the Run mode. The Run Mode commands are highlighted as follows:

| Description |
| :---: |
| RUN MODE COMMANDS |
| Issue Reset |
| Examine or Modify Hardware Breakpoint |
| Exit Run Mode |
| Return to RDC Operating System |
| Select a New PMC Module |
| Enable/Disable the System Pointer |
| Halt/Resume Run |

## CONTROLLED EXECUTION MODE COMMANDS

The Controlled Execution Mode commands are divided into five groups, as follows:

| Description |
| :---: |
| COMMANDS TO DISPLAY MEMORY OR REGISTERS |
| Display or alter sixteen selected memory locations |
| Display or alter next sixteen memory locations |
| Display or alter previous sixteen memory locations |
| Examine/modify RAM and I/O one byte at a time |
| Dump memory in Hex and ASCII format |
| Invoke disassembler |
| Display or alter register contents |
| COMMANDS TO SET PROGRAM BREAKPOINTS |
| Set or reset software breakpoint addresses |
| Enable or disable single step mode |
| Set or modify hardware breakpoint |

## Description

COMMANDS TO TRACE PROGRAM FLOW
Toggle instruction trace on or off
Toggle register printout on or off Show register form for printout Show last nine instruction addresses
DISK FUNCTIONS
Special disk functions
Display disk directory
Delete file
MISCELLANEOUS COMMANDS
Write protect memory blocks
Load object code
Start execution of user's program
Dump memory
Issue RESET
Verify object code against memory Return control to RDC Operating System Initialize the current board
Enable/disable printer
Allow single step through interrupts

## CONFIGURATIONS

The RDC Personality Sets for the R6500/* Microcomputers, shown in the chart below, include one Personality Module Controller (PMC), two Personality Emulator Pod Modules, a Device Adapter, an In-Circuit Emulation Probe assembly, an interconnect cable set, and the required software and support documentation. The RDC Personality Sets are available either bundled with an 8K Target RAM (the 100 series part numbers in the table below) or unbundled without the 8 K Target RAM (the 300 series part numbers below).

R6500/* Personality Sets

| Part Number | Description |
| :---: | :---: |
| RDC-101 or -301 | R6500/11P Personality Set, 1 MHz |
| RDC-102 or -302 | R6500/11AP Personality Set, 2 MHz |
| RDC-111 or -311 | R6500/12Q Personality Set, 1 MHz |
| RDC-112 or -312 | R6500/12AQ Personality Set, 2 MHz |
| RDC-121 or -321 | R6500/13Q Personality Set, 1 MHz |
| RDC-122 or -322 | R6500/13AQ Personality Set, 2 MHz |
| RDC-131 or -331 | R6500/41P Personality Set, 1 MHz |
| RDC-132 or -332 | R6500/41AP Personality Set, 2 MHz |
| RDC-141 or -341 | R6500/42Q Personality Set, 1 MHz |
| RDC-142 or -342 | R6500/42AQ Personality Set, 2 MHz |
| RDC-151 or -351 | R6500/43Q Personality Set, 1 MHz |
| RDC-152 or -352 | R6500/43AQ Personality Set, 2 MHz |
| RDC-161 or -361 | R6500/1P Personality Set, 1 MHz |
| RDC-162 or -362 | R6500/1AP Personality Set, 2 MHz |



## DEVICE ADAPTERS

The Adapter/Emulator Devices are used to reconfigure RDC1XX Personality Sets for use with other R6500/* Microcomputers. They replace the Adapter/Emulator Devices in the Personality Emulator Pod Module and contain the desired emulator device.

| Part Number | Description |
| :---: | :--- |
| RDC-211 | Adapter/Emulator Device <br> (R6511Q) for R6500/11/12/13, 1 MHz <br> Adapter/Emulator Device <br> (R6511AQ) for R6500/11/12/13, 2 MHz <br> Adapter/Emulator Device |
| RDC-221 | (R6541AQ) for R6500/41/42/43, 1 MHz <br> Adapter/Emulator Device <br> (R6541AQ) for R6500/41/42/43, 2 MHz <br> RDC-222 <br> Adapter/Emulator Device <br> (R6500/1EC) for R6500/1, 1 MHz <br> RDC-231 <br> Adapter/Emulator Device <br> (R6500/1EAC) for R6500/1, 2 MHz |

## IN-CIRCUIT EMULATION PROBES

The in-Circuit Emulation Probe assemblies used to reconfigure the RDC-1XX Personality Sets for use with other R6500/* Microcomputers are shown in the chart below.

| Part Number | Description |
| :---: | :---: |
| RDC-200 | 40-Pin Probe and cable for R6500/11P. Prerequisite, RDC-211 or -212 |
| RDC-201 | 64-Pin Probe and cables for R6500/12Q. Prerequisite, RDC-211 or -212 |
| RDC-202 | 64-Pin Probe and cables for R6500/13Q. Prerequisite, RDC-211 or -212 |
| RDC-203 | 40 -Pin Probe and cable for R6500/41P. Prerequisite, RDC-221 or -222 |
| RDC-204 | 64 -Pin Probe and cables for R6500/42Q. Prerequisite, RDC-221 or -222 |
| RDC-205 | 64 -Pin Probe and cables for R6500/43Q. Prerequisite, RDC-221 or -222 |
| RDC-206 | 40-Pin Probe and cable for R6500/1P. Prerequisite, RDC-231 or -232 |

## RDC-502 AND RDC-504 ROCKWELL DESIGN CENTER R6502-R65C02 PERSONALITY SET

## INTRODUCTION

The RDC R6502-R65C02 Personality Set is a Rockwell Design Center (RDC) option that allows the RDC user to develop, debug and verify programs intended for use by any R6500 one-chip microprocessor system. The R6502-R65C02 offers the user a high performance development system specifically designed for emulation of a microprocessor system. This RDC option supports in-circuit emulation for the entire R6500 and R65C00 family of one-chip microprocessors.

The basic R6502-R65C02 Personality Set includes a Personality Module Controller (PMC), two Personality Emulator Pod Modules, five emulator devices (R6502, R6512, R65C02, R65C102, and R65C112), two prototype-to-pod interface cables, an RDC interconnect cable set, and the required software and support documentation.

The R6502-R65C02 Personality Set provides the RDC with a dual CPU capability. This added feature permits the RDC CPU to maintain control, even while the microprocessor is executing a program, thus providing the user with complete control over the development process.

The R6502-R65C02 Personality Set can be expanded to include four separate emulation systems which can be run concurrently on the RDC.

## FEATURES

- Disk based macro assembler and debug monitor
- Provides 8 K or 64K RAM in system (optional)
- Supports 65 K address range in target environment
- Five hardware breakpoints with SYNC outputs
- User defined external break signal
- Single step through interrupts
- Supports four simultaneous target developments
- No zero page address conflicts
- Power down capability
- RAM write protection
- User or system supplied power and clock
- Real-time in-circuit emulation
- Menu-driven Softkey command selection


RDC R6502-R65C02 Personality Set


System Interconnection

## RUN MODE/CONTROLLED EXECUTION COMMAND SUMMARY

The R6502-R65C02 Personality Set is designed to allow R650X, R651X or R65XXX devices to execute independent of the RDC. Thus, while the emulator is executing code, the RDC CPU is still in operation. This allows certain functions to be performed by the RDC CPU without disturbing the execution of the emulator device.

## RUN MODE COMMANDS

The R6502-R65C02 debug monitor allows certain commands to be performed while the emulator is in the Run mode. The Run Mode commands are highlighted as follows:

| Description |
| :---: |
| RUN MODE COMMANDS |
| Issue Reset |
| Examine or Modify Hardware Breakpoint |
| Exit Run Mode |
| Return to RDC Operating System |
| Select a New PMC Module |
| Enable/Disable the System Pointer |
| Halt/Resume Run |

## CONTROLLED EXECUTION MODE COMMANDS

The Controlled Execution Mode commands are divided into five groups, as follows:

## Description

COMMANDS TO DISPLAY MEMORY OR REGISTERS Display or alter sixteen selected memory locations Display or alter next sixteen memory locations Display or alter previous sixteen memory locations Examine/modify RAM and IIO one byte at a time Dump memory in Hex and ASCII format Invoke disassembler Display or alter register contents

COMMANDS TO SET PROGRAM BREAKPOINTS
Set or reset software breakpoint addresses Enable or disable single step mode Set or modify hardware breakpoint

| Description |
| :---: |
| COMMANDS TO TRACE PROGRAM FLOW |
| Toggle instruction trace on or off |
| Toggle register printout on or off |
| Show register form for printout |
| Show last nine instruction addresses |
| DISK FUNCTIONS |
| Special disk functions |
| Display disk directory |
| Delete file |
| MISCELLANEOUS COMMANDS |
| Write protect memory blocks |
| Load object code |
| Start execution of user's program |
| Issue RESET |
| Verify object code against memory |
| Return control to RDC Operating System |
| Initialize the current board |
| Enable/disable printer |
| Allow single step through interrupts |

## CONFIGURATIONS

The RDC Personality Sets for the R6502-R65C02 Microprocessors, shown in the chart below, includes one Personality Module Controller (PMC), two Personality Emulator Pod Modules, one Emulator Device set, an interconnect cable set, and the required software and support documentation.

## R6502-R65C02 Personality Sets and Memory

| Part Number | Description |
| :---: | :---: |
| RDC-502 | R6502-R65C02 Personality Set, $1-2 \mathrm{MHz}$ |
| RDC-504 | R6502-R65C02 Personality Set, 4 MHz |
|  |  |
| RDC-1011 | 8K RAM Target Memory, $1-2 \mathrm{MHz}$ only |
| RDC-1012 | 64K RAM Target Memory, $1-4 \mathrm{MHz}$ |
|  |  |



Typical R6502-R65C02 Personality Set Hardware Components

## R6502-R65C02 Personality Set Component List

| QUANTITY | ITEM | DESCRIPTION |
| :---: | :---: | :---: |
| 1 <br> 1 <br> 1 <br> 2 <br> 2 | PMC Module <br> Emulator Pod Module Assembly <br> Emulator Package <br> PMC to Pod Interface Ribbon Cables (Long Length) <br> Prototype-to-Pod Interface Cables (Medium Length) | Controller module that plugs into the RDC Mainframe. <br> Pod that contains EPM-1 and EPM-2, a short ribbon cable, a six-wire power cable, and the R6502 Emulator Device. <br> Package contains the R6512, R65C02, R65C102 and R65C112 Emulator devices and 5 jumper headers for the 28-pin processors. <br> One cable with 60-pin connector on each end with one cable with a 50-pin connector on each end. <br> One of two possible configurations: <br> a. One ribbon cable with 40 -pin connectors on each end. Used for emulating, the R6502, R6512, R65C02, R65C102 or R65C112. <br> b. One cable with a 28 -pin connector on each end. Used for emulating the R6503, R6504, R6505, R6506, R6507, R6513, R6514 or R6515. |

# RDC-2000 R6500 CROSS ASSEMBLER FOR INTEL DEVELOPMENT SYSTEM 

## CROSS ASSEMBLY

The R6500 Cross Assembler provides the user with the capability of developing assembly language programs on the Intel Development System and downloading these programs to the Rockwell Design Center (RDC) for debugging and in-circuit operation.

The process of translating microprocessor instructions for a computer program written in symbolic form to executable machine instructions is called an assembly, and the computer program that performs this translation is called an assembler. Assemblers that run on a host computer different from the target computer that the generated machine code is to operate in are called cross assemblers. One assembly language statement usually translates into a single processor instruction. Each statement consists of a label (if required), a mnemonic operation code, an operand (if required), an arithmetic operator (if required) and an optional comment. Constants comprising one or more bytes of memory are generated from data statements while one or more bytes of memory are assigned to variables. This cross assembler is a symbolic assembler that allows the programmer to represent memory locations and numeric values with names or symbols.

## PRODUCT OVERVIEW

The R6500 Cross Assembler for the Intel Development System allows users who have access to such a system and are accustomed to its text editor (ISIS CREDIT) to enter and edit source code, assemble the program and save both the source and object code on floppy disk. The object code can then be loaded into a Rockwell Design Center (RDC) for program debugging and in-circuit validation using an R6500, R6500/* or R65C00 Personality Set. Up to four personality sets can be installed in one RDC Main Frame to maximize the utility of one Intel Development System and RDC. The object code can also be programmed into PROM/ROM for execution by an R6500 NMOS or R65C00 CMOS microprocessor or masked in R6500/* NMOS one-chip microcomputer ROM for execution.

The disk-based R6500 cross assembler is a two-pass symbolic assembler which produces absolute 6500 object code. It performs symbol (1-6 characters) definition, syntax checking, assembly/symbol table listings and cross reference generation for effective program development. Assembler operation is automatic once started.

The assembler outputs to the console the pass it is currently performing and a dot for every 16 lines of source code assembled. This enables viewing of the assembly process and observation of detected errors. List (.LST), object (.OBJ), and symbol (.SYM) files are automatically generated with the source name assigned as the header and the particular extension added.

## FEATURES

- Intel Development System Host
- Supports Rockwell's 8-bit CPU devices:
-R6500 NMOS microprocessor family
-R6500/* NMOS microcomputer family
-R65C00 CMOS microprocessor family
- Symbolic notation-operands and labels
- Interactive assembler operation
- Operator selected object code output devices
—Display/printer
-Printer
—Floppy Disk
—Download to RDC
- Operator selected assembly/error listing output
—Display/Printer
—Printer
-Floppy Disk
- Assembler directives
- Symbolic cross-reference
- Communications support-downloading of object code


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RDC-2000 | R6500 Cross Assembler for Intel Development <br> System Disk (8" ISIS II compatible disk) |
| Order No. | Description |
| RDC02 | R6500 Cross Assembler for Intel Development <br> System User's Manual (included with RDC-2000) |

## SYSTEM REQUIREMENTS

The Intel Development System must provide 64K bytes of memory and the Dual-Density Drive option to support the R6500 Cross Assembler. 32 K bytes are then available for application source code. The other 32 K bytes contain the ISIS system (14K) and the cross assembler (18K).

## Assembler Directives

| Assembly Listing Control |  |  |  |
| :---: | :--- | :--- | :--- |
| ITLL | Title | WIDTH | Line Length |
| .PAGE | Page | SKIP | Skip |
| LINE | Page Length |  |  |

Source File Control
END End of Assembly
.MOD Assembly Type

## Data Storage

.BYTE WORD .DBYTE .SBYTE

Equate
$=\quad$ Assign value to symbol

## Error Codes

## Pass 1

1 OPERAND VALUE IS INVALID OR GT HEX FFFF
2 OPERAND VALUE IS GREATER THAN HEX FFFF
3 INCORRECT ADDRESSING MODE
4 SYMBOL NOT PREVIOUSLY DEFINED
5 NO OPERAND
6 ASCII STRING NOT PROPERLY ENCLOSED
7 MISSING .END STATEMENT
8 UNDEFINED ASSEMBLER DIRECTIVE
9 IMPROPER EQUATE FORMAT
10 UNRECOGNIZABLE ASTERISK DEFINITION
1 INDIRECT ADDRESSING OFF OF ZERO PAGE
12 INCORRECT FORM OF INDIRECT ADDRESSING, MISSING $Y$
13 INCORRECT FORM OF INDEX ADDRESSING, MISSING $X$
14 OPERAND MUST BE ON ZERO PAGE (00-SFF)
15 ILLEGAL INSTRUCTION FOR THIS ASSEMBLER

Pass 2
1 .MOD DIRECTIVE MUST BE FIRST LINE ON LISTING
2 INCORRECT FORMAT OF INDEX ADDRESSING, MISSING $X$ OR Y
3 MISSING RIGHT PARENTHESIS
4 LABEL LONGER THAN 6 CHARACTERS
5 LABEL IS DEFINED MORE THAN ONCE
6 RELATIVE BRANCH IS OUT OF RANGE
7 ILLEGAL OR MISSING OPCODE
8 OPERAND LABEL IS DEFINED MORE THAN ONCE 9. SYMBOL TABLE FULL

10 MISSING LABEL FOR EQUATE
11 OPERAND LABEL GREATER THAN 6 CHARACTERS LONG
12. MOD VALUE IS INCORRECT FOR THIS ASSEMBLER

13 OPERAND NOT BETWEEN 0-7
14 SYMBOL HAS ILLEGAL CHARACTER OR IS GREATER THAN ZIJFFF

| Operators |  |
| :---: | :---: |
| Prefix Character | Base |
| (none) | 10 (Decimal) |
| $\$$ | 16 (Hexadecimal) |
| $@$ | 8 (Octal) |
| $\%$ | 2 (Binary) |
|  |  |


| Constants (Prefix) |  |
| :---: | :--- |
| Operator | Operation <br> + <br> - |
| $<$ | Addition <br> Subraction <br> High-Byte Selection <br> Low-Byte Selection |

## M65-1XX AND M65-2XX SYSTEM 65 R6500/* PERSONALITY SET

## INTRODUCTION

The Rockwell R6500/* Personality Set is a System 65 Development System option that allows the System 65 user to develop, debug and verify special programs intended for use by any R6500 one-chip microcomputer system. The R6500/* offers the user a high performance development system specifically designed for emulation of a microcomputer system. This System 65 option supports in-circuit emulation for the entire R6500 family of one-chip microcomputers.

The basic R6500/* Personality Set includes a Personality Module Controller (PMC), two Personality Emulator Pod Modules, a Device Adapter, an In-Circuit Emulation Probe assembly, an interconnect cable set, and the required software and support docurnentation.

The R6500/* Personality Set provides the System 65 with a dual CPU capability. This added feature permits the System 65 CPU to maintain control, even while the R6500/* is executing a program, thus providing the user with complete control over the development process.

The R6500/* Personality Set can be expanded to include four separate emulation systems which can be run concurrently on the System 65 Development System.

## FEATURES

- Disk based macro assembler and debug monitor
- Provides 8K RAM in system
- Supports 65 K address range in target environment
- Two hardware breakpoints with SYNC outputs
- User defined external break signal
- Single step through interrupts
- Supports four simultaneous target developments
- No zero page address conflicts
- Power down capability
- RAM write protection
- User or system supplied power and clock
- Real-time in-circuit emulation


## RUN MODE/CONTROLLED EXECUTION MODE COMMANDS

The R6500/* Personality Set is designed to allow the R6500/* to execute independent of the System 65. Thus, while the R6500/* is executing code, the System 65 CPU is still in operation. This allows certain functions to be performed by the System 65 CPU without disturbing the execution of the R6500/*. Tables 1 and 2 list the commands for the Run Mode and Controlled Execution Mode respectively. The R6500/* debug monitor allows certain commands to be performed while the R6500/* is in the Run mode.


System 65 R6500/* Personality Set

Table 1. Run Mode Commands

| Command | Description |
| :---: | :--- |
| I | Issue reset |
| C | Examine or modify hardware breakpoint |
| Q | Exit run mode |
| ESC | Return to.System 65 monitor |
| F | Select a new PMC board |
|  | Give board number/emulator model |
| $\$$ | Enable/disable the system pointer |
| CSPACE $>$ | Halt/resume run |

Table 2. Controlled Execution Mode Commands

| Command | Description |
| :---: | :---: |
| Commands to Display Memory or Registers |  |
| M | Display sixteen selected memory locat |
| <SPACE> | Display next sixteen memory locations |
|  | Display previous sixteen memory locat |
|  | Examine/modify RAM and I/O one byte |
| U | Dump memory in Hex and ASCII forma |
|  | Invoke disassembler |
| R | Display register contents |
| Commands to Alter Memory or Registers |  |
| 1 | Alter memory location |
|  | Alter program counter |
| A | Alter accumulator |
| X | Alter X register |
| Y | Alter Y register |
| P | Alter processor status |
| S | Alter stack pointer |
| Commands to Set Program Breakpoints |  |
| B | Set or reset software breakpoint add |
| 4 | Enable or disable single step mode |
| ? | Show all software breakpoint addresse |
| \# | Clear all software breakpoints |
| c | Set or modify hardware breakpoint |
| Commands to Trace Program Flow |  |
| Z | Toggle instruction trace on or off |
| V | Toggle register printout on or off |
| $J$ | Show register form for printout |
| H | Show last nine instruction addresses |

Disk Functions

| 1 | Special disk functions |
| :--- | :--- |
| 2 | Display disk directory |
| 3 | Delete file |

## Miscellaneous Commands

| W | Write project memory blocks |
| :--- | :--- |
| L | Load object code |
| G | Start execution of user's program |
| D | Dump memory |
| I | Issue RESET |
| K | Verify object code against memory |
| Q | Return control to System 65 |
| 7 | Reinitialize R6500/1 Monitor either from |
|  | System 65 or R6500/1 Monitor |
| 8 | Reenter R6500/1 Monitor from System 65 |
| E | Enter the Text Editor |
| T | Reenter the Text Editor |
| N | Invoke the Assembler |
| F | Select a new PMC board |
| O | Initialize the current board |
| S | Enable/disable printer |
|  | Give board number/emulator model |
| ESC | Stop on-going process |
| + | Allow single step through interrupts |

## ORDERING INFORMATION

R6500/* Personality Module Sets

| Part Number | Description |
| :---: | :---: |
| M65-101 | R6500/11P Personality Set, 1 MHz |
| M65-102 | R6500/11AP Personality Set, 2 MHz |
| M65-111 | R6500/12Q Personality Set, 1 MHz |
| M65-112 | R6500/12AQ Personality Set, 2 MHz |
| M65-121 | R6500/13Q Personality Set, 1 MHz |
| M65-122 | R6500/13AQ Personality Set, 2 MHz |
| M65-131 | R6500/41P Personality Set, 1 MHz |
| M65-132 | R6500/41AP Personality Set, 2 MHz |
| M65-141 | R6500/42Q Personality Set, 1 MHz |
| M65-142 | R6500/42AQ Personality Set, 2 MHz |
| M65-151 | R6500/43Q Personality Set, 1 MHz |
| M65-152 | R6500/43AQ Personality Set, 2 MHz |
| M65-161 | R6500/1P Personality Set, 1 MHz |
| M65-162 | R6500/1AP Personality Set, 2 MHz |

Adapter/Emulator Devices ${ }^{(1)}$

| Part Number | Description |
| :---: | :--- |
| M65-211 | Adapter/Emulator Device <br> (R6511Q) for R6500/11/12/13, 1 MHz <br> M65-212 |
| Adapter/Emulator Device <br> (R6511AQ) for R6500/11/12/13, 2 MHz |  |
| M65-221 | Adapter/Emulator Device <br> (R6541Q) for R6500/41/42/43, 1 MHz |
| M65-222 | Adapter/Emulator Device <br> (R6541AQ) for R6500/41/42/43, 2 MHz |
| M65-231 | Adapter/Emulator Device <br> (R6500/1EC) for R6500/1, 1 MHz |
| M65-232 | Adapter/Emulator Device <br> (R6500/1EAC) for R6500/1,2 MHz |

Note:

1. Used to reconfigure M65-1XX Personality Sets for use with other R6500/* Microcomputers. Replaces Adapter/Emulator Device in Personality Emulator Pod Module.

In-Circuit Emulation Probes ${ }^{(1)}$

| Part Number | Description |
| :---: | :---: |
| M65-200 | 40 Pin Probe and cable for R6500/11P. Prerequisite, M65-211 or 212 |
| M65-201 | 64 Pin Probe and cables for R6500/12Q. Prerequisite, M65-211 or 212 |
| M65-202 | 64 Pin Probe and cables for R6500/13Q. Prerequisite, M65-211 or 212 |
| M65-203 | 40 Pin Probe and cable for R6500/41P. Prerequisite, M65-221 or 222 |
| M65-204 | 64 Pin Probe and cables for R6500/42Q. Prerequisite, M65-221 or 222 |
| M65-205 | 64 Pin Probe and cables for R6500/43Q. Prerequisite, M65-221 or 222 |
| M65-206 | 40 Pin Probe and cable for R6500/1P. Prerequisite, M65-231 or 232 |
| Note: <br> 1. Used to rec other R6500 | ure M65-1XX Personality Sets for use with icrocomputers. |




## ADDITIONAL PROBES AND ADAPTERS

## SELECTION GUIDE

If you already have a System 65 Personality Set for a member of the R6500/* family you need not purchase a complete new set to support another member of the family. The following matrix shows the minimum probes and adapters that need to
be purchased to reconfigure your set for another R6500/* device. Select the device now being supported in the FROM row, find the device you wish to support in the TO column. The P/N's in the intersection will reconfigure your Personality Set.


# M65-001, -002, -003 USER 65 MODULES 

## OVERVIEW

The USER 65 Module permits users developing R6500-based products to extend the full power of System 65 Development System into 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. M65-003 configuration is without the controller.

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 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 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 Y1 (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.


USER 65 Host Module Functional Block Diagram


M65-001 USER 65 Module
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.

The Host Module also contains the RS-232C and TTY baud rate generator circuitry. Crystal Y2 ( 1.8432 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. Each 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 $R / \bar{W}$ signal to form a READ signal and a WRITE signal, which are used in the USER 65 Buffer Module.

The address lines and control lines $\varnothing 1, \not \varnothing_{2}, \overline{\mathrm{DMA}}$, 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 (A1-A4).

The Control lines S.O., RDY, $\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}, \overline{\mathrm{IRQ}}$ 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{D M A}$ 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 Order No. D39.

## 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.
The address lines, SYNC and $R / \bar{W}$ lines are buffered with I.C.'s 8 T97 (Z1-Z3). The control lines RDY, $\overline{R E S}, \overline{N M I}, \overline{\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 $\varnothing 1$ and $\varnothing 2$ clocks are buffered by 8 T 97 (Z5). To use an external clock, jumper $N$ must be installed. To use $\varnothing 1$, jumper $M$ must be installed. 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 $\mathrm{Z8}$.

Table 1. USER 65 Host Board to Buffer Board Interface Signals

| CONNECTOR J1 |  | CONNECTOR J2 |  |
| :---: | :---: | :---: | :---: |
| PIN | SIGNAL | PIN | SIGNAL |
| 1 | A0 | 1 | EXT. CLOCK |
| 3 | A1 | 3 | $\phi_{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 | $\overline{\mathrm{D} 6}$ |
| 15 | A7 | 15 | $\overline{\text { D5 }}$ |
| 17 | A8 | 17 | D4 |
| 19 | A9 | 19 | D3 |
| 21 | A10 | 21 | $\overline{\mathrm{D} 2}$ |
| 23 | A11 | 23 | D1 |
| 25 | A12 | 25 | DO |
| 27 | A13 | 27 | +5V |
| 29 | A14 | 29 | $+5 \mathrm{~V}$ |
| 31 | A15 | 31 | +5V |
| 33 | SYNC | 33 | +5V |
| 35 | R/W | 35 | +5V |
| 37 | RDY | 37 | +5V |
| 39 | RESET | 39 | +5V |
| 41 | $\overline{\mathrm{NMI}}$ |  | $\theta$ |
| 43 | $\overline{\mathrm{IRQ}}$ |  |  |
| 45 | S0 |  |  |
| Note: | mbered p | necte | und. |



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 28pin types of cables are provided.

## INSTALLATION

## USER 65 HOST MODULE

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 1.
5. Plug the USER 65 Host Module into any convenient slot in the System 65 chasis.
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).


Figure 1. 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: |

8. Set switches S1 and S2 on the RAM Module per Tables 3 and 4 to enable/disable and to select the address range of the internal System 65 RAM.

## NOTE

If external RAM adddresses 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.

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- \$BFFF |
| Up | Down | Down | \$C000- \$DFFF |
| Down | Down | Down | \$E000 - \$FFFF |
| Note: "Up" is toward the top edge of the module |  |  |  |

## USER 65 BUFFER MODULE

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

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 System 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 R/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 cabels. The 40 -pin socket (J3) should be used for either of the 40-pin CPU's, R6502 or R6512. The cable labeled PS00-D603001 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 J 3 or the 28 -pin cable to plug J 4 or J 5 , 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

| User Equipment CPU | Buffer Module Socket | Cable To User Equipment | Jumper | Signal | User's CPU Pin |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 86502 | J3 | PSOO-D603-001 | $\begin{aligned} & R \\ & M \\ & N^{*} \end{aligned}$ | R/W $\varnothing 1$ (OUT) $\varnothing 0$ (IN) | $\begin{array}{r} 34 \\ 3 \\ 37 \end{array}$ |
| R6503 | J4 | PS00-D605-001 | $\begin{aligned} & \hline \mathrm{P} \\ & \mathrm{~B} \\ & \mathrm{D} \\ & \mathrm{E} \\ & \mathrm{~F} \\ & \mathrm{~A} \\ & \mathrm{~N}^{*} \end{aligned}$ | $\begin{aligned} & \frac{\mathrm{R} / \mathrm{W}}{\mathrm{RES}} \\ & \text { VSS } \\ & \mathrm{IRQ} \\ & \hline \text { NM1 } \\ & \varnothing 2 \text { (OUT) } \\ & \varnothing 0 \text { (IN) } \end{aligned}$ | $\begin{array}{r} 26 \\ 1 \\ 2 \\ 3 \\ 4 \\ 28 \\ 27 \end{array}$ |
| R6504 | J5 | PS00-D605-001 | $\begin{aligned} & \hline \mathrm{P} \\ & \mathrm{~B} \\ & \mathrm{D} \\ & \mathrm{E} \\ & \mathrm{~A} \\ & \mathbf{N}^{*} \\ & \hline \end{aligned}$ | R/W RES VSS RQ $\not \subset 2$ (OUT) $\varnothing 0$ (IN) | $\begin{array}{r} 26 \\ 1 \\ 2 \\ 3 \\ 28 \\ 27 \\ \hline \end{array}$ |
| R6506 | 14 | PS00-D605-004 | $\begin{array}{l\|l\|} \hline P \\ B \\ D \\ K \\ S \\ A \\ N^{*} \\ \hline \end{array}$ | R/W <br> RES <br> VSS <br> RDY <br> $\overline{\mathrm{IRO}}$ <br> $\varnothing 2$ (OUT) <br> $\varnothing 0$ (IN) | $\begin{array}{r} \hline 26 \\ 1 \\ 2 \\ 3 \\ 4 \\ 28 \\ 27 \\ \hline \end{array}$ |
| R6506 | J4 $\square$ | PS00-D605-001 | $\begin{aligned} & \hline P \\ & B \\ & D \\ & \mathrm{~L} \\ & \mathrm{~S} \\ & \mathrm{~A} \\ & \mathrm{M} \\ & \mathrm{~N}^{*} \\ & \hline \end{aligned}$ | R/W <br> RES <br> VSS <br> $\varnothing 1$ (OUT) <br> $R O$ <br> $\emptyset 2$ (OUT) <br> $\varnothing 1$ (OUT) <br> $\varnothing 0$ (IN) | $\begin{array}{r} 26 \\ 1 \\ 2 \\ 3 \\ 4 \\ 28 \\ 3 \\ 27 \\ \hline \end{array}$ |
| R6507 | J5 | PS00-D605-001 | $\begin{aligned} & \hline \mathrm{P} \\ & \mathrm{~B} \\ & \mathrm{D} \\ & \mathrm{~K} \\ & \mathrm{~A} \\ & \mathrm{~N}^{*} \end{aligned}$ | R/W RES VSS RDY $\emptyset 2$ (IUT) $\emptyset 0$ (IN) R | $\begin{array}{r} 26 \\ 1 \\ 2 \\ 3 \\ 28 \\ 27 \\ \hline \end{array}$ |
| R6512 | J3 | PS00-D603-001 | $\begin{aligned} & \mathbf{R}_{N^{*}} \end{aligned}$ | $\begin{aligned} & R / W \\ & \not \varnothing_{2}(I N) \end{aligned}$ | $34$ |
| R6513 | J4 | PSO0-D604-001 | $\begin{aligned} & P \\ & \mathrm{C} \\ & \mathrm{E} \\ & \mathrm{~F} \\ & \mathrm{~T} \\ & \mathrm{~N}^{*} \end{aligned}$ | R/W <br> VSS <br> IRO <br> NMI <br> RES <br> $\varnothing 2$ (IN) | $\begin{array}{r} \hline 26 \\ 1 \\ 3 \\ 4 \\ 28 \\ 27 \end{array}$ |
| R6514 | J5 | PS00-D604-001 | $\begin{aligned} & \hline \mathrm{P} \\ & \mathrm{C} \\ & \mathrm{E} \\ & \mathrm{~T} \\ & \mathrm{~N}^{*} \end{aligned}$ | R/W VSS IRQ RES $\varnothing 2$ (IN) | $\begin{array}{r} 26 \\ 1 \\ 3 \\ 28 \\ 27 \end{array}$ |
| R6515 | J4 | PS00-D604-001 | $\begin{aligned} & \hline \mathrm{P} \\ & \mathrm{C} \\ & \mathrm{~J} \\ & \mathrm{~L} \\ & \mathrm{~S} \\ & \mathrm{~T} \\ & \mathrm{~N}^{*} \end{aligned}$ | R/W VSS <br> RDY <br> $\overline{\text { IRQ }}$ <br> $\overline{R E S}$ <br> Ø2 (IN) | $\begin{array}{r} 26 \\ 1 \\ 2 \\ 4 \\ 4 \\ 28 \\ 27 \end{array}$ |

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

## TYPICAL APPLICATION

A typical application for the USER 65 module is illustrated. 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 module is installed in the CPU socket instead of a CPU. The user must provide page $0(\$ 0000-\$ 00 F F)$ and page $1(\$ 0100-\$ 01 F F)$ 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 chasis. 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 module 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 $\$$ C000-\$FFFF; these addresses cannot be used by the programmer.


USER 65 Module Hook-up

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Common Specifications Operating Frequency. Operating Temperature. Power Requirements | $\begin{aligned} & 1 \mathrm{MHz} \text { or } 2 \mathrm{MHz} \\ & 0^{\circ} \text { to } 70^{\circ} \mathrm{C} \\ & +5 \mathrm{Vdc} \pm 5 \% @ 1.5 \mathrm{~A} \end{aligned}$ |
| Host Module Specifications <br> Module Dimensions. <br> Edge Contacts: <br> Edge Contact Signals: | 9.75 in. wide $\times 7.50 \mathrm{in}$. high 86 pins on 0.156 in. centers System 65 compatible |
| Buffer Module Specifications <br> Module Dimensions: <br> Cable Lengths: <br> To System 65 <br> To User Equipment | 4.125 in. wide $\times 7.375$ in. high <br> 60 in . <br> 12 in . |

## M65-031 AND M65-032 16K STATIC RAM MODULES

## OVERVIEW

The 16 K Static RAM Module contains $16 \mathrm{~K}(16,384)$ bytes of Random Access Memory (RAM), implemented with 32 R2114 $1024 \times 4$ Static RAM devices and is available in either 1 MHz (M65-031) or $2 \mathrm{MHz}(\mathrm{M} 65-032)$ version. Also included are address decoding and selection, write protection and data buffering circuitry.

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 independently write-protected via special lines.

The Static RAM Module is directly compatible with the Rockwell 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 in 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 independent 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


M65-031 16K Static RAM Module

## FUNCTIONAL DESCRIPTION

The edge connector pin assignments for the RAM Module are compatible with the Motherboard pin assignments given in Section 4 of the System 65 User's Manual (Document No. 29650 N35; Order No. 206).

The RAM Module's 16 K bytes of read/write memory are provided 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 connector. The data signals are inverted to make them compatible with the system 65 Data Bus ( $\overline{\mathrm{D} 0}-\overline{\mathrm{D} 7}$ ).

Module Switches S1 and S2 provide independent 8K 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 $52-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 Z10 and Z21. The Comparator outputs enable or disable 1-of-8 Decoder devices Z9 and Z20 to provide the input chip select signals to the two 8 K RAM sections.

Write protection is controlled by seven Write Protect lines, WP1WP7, one line for each 8 K section of memory (the lowest 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 8 K 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 Z35 and Z36 to select one of the seven Write Protect lines. The selected line controls the RAM Write Control signals, Z34-6 and Z344-8.


## INSTALLATION

Use the following procedure 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 power 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 S2one 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 F F$ ) 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 $\$ C 000-\$ F F F F$ are used by
the System 65 Monitor Board, and must not be enabled in RAM Modules.
4. Insert the RAM Module(s) into any vacant slot(s) in the System 65 chassis.
5. Install System 65 top cover.
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) <br> Down (On) |
| RAM Enabled (Selected) |  |

Table 2. RAM Address Range Select Switch Settings

| Switch S1/S2 Position |  |  | 8 K 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-\$BFFF |
| 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 \mathrm{~ns}(\mathrm{P} / \mathrm{N} \mathrm{M65-031)}$ |
|  | $250 \mathrm{~ns}(\mathrm{~F} / \mathrm{N} \mathrm{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 -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 $\quad 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 | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Inputs $(\overline{\mathrm{DO}}-\overline{\mathrm{D7}})$, AO-A15, WP1-WP7, $\varnothing 2, \mathrm{R} \overline{\mathrm{W}}$ <br> Input Low Voltage <br> Input High Voltage |  |  |  |  |  |
| Outputs $(\overline{\mathrm{DO}}-\overline{\mathrm{D7} 7})$ | $\mathrm{V}_{\mathrm{IL}}$ |  | 0.8 | V | $\mathrm{I}_{\mathrm{IL}}=400 \mu \mathrm{a}$ |
| Output Low Voltage | 2.0 | $\mathrm{~V}_{\mathrm{CC}}$ | V | $\mathrm{I}_{\mathrm{IH}}=40 \mu \mathrm{a}$ |  |
| Output High Voltage | $\mathrm{V}_{\mathrm{OL}}$ |  |  |  |  |

## 0 Rockwell

# M65-040 <br> PROM PROGRAMMER MODULE 

## OVERVIEW

The M65-040 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 development system 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

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. 29650N35).

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.


M65-040 PROM Programming Module

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, Z12 and Z13, to provide a logical inversion and a single TTL load to the System 65 bus signals. The two R6520 PIAs, Z5 and Z8, are used to store the address, data and control information for the PROM device. The address, Read/Write (R/W), and $\varnothing 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 $\$ \mathrm{CO} 01 \mathrm{C}-\$ \mathrm{C} 01 \mathrm{~F}$.

The PROM device receives address lines A0-A9 and data lines D0-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 fom the +5 -volt power through a DC-DC converter, Z 6 , and an adjustable voltage, regulator, Z 1 . 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.

Table 1. System 65 PROM Socket Interface Summary

| PROM <br> Socket <br> Pin <br> Number | PROM Device Type |  |  |  |  |  |  | ```Connector J1 Pin Number``` |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 2704 | $\begin{aligned} & \text { Intel } \\ & 2708 \end{aligned}$ | Intel 2758 | Intel <br> 2716 | $\begin{gathered} \text { T.I. } \\ 2716 \end{gathered}$ | T.I. 2516 | $\begin{aligned} & \text { T.1. } \\ & 2532 \end{aligned}$ |  |
| 1 | A7 | A7 | A7 | A7 | A7 | A7 | A7 | 21 |
| 2 | A6 | A6 | A6 | A6 | A6 | A6 | A6 | 19 |
| 3 | A5 | AS | A5 | A5 | A5 | A6 | A5 | 17 |
| 4 | A4 | A4 | 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 | A1 | A1 | A1 | 26 |
| 8 | AO | AO | AO | AO | AO | AO | AO | 24 |
| 9 | DO | DO | Do | Do | 01 | Q1 | 01 | 22 |
| 10 | D1 | D1 | D1 | D1 | 02 | 02 | Q2 | 20 |
| 11 | D2 | D2 | D2 | D2 | 03 | 03 | 03 | 18 |
| 12 | GND | GND | GND | GND | vss | vSs | Vss | 16 |
| 13 | D3 | D3 | D3 | D3 | 04 | 04 | 04 | 10 |
| 14 | D4 | D4 | D4 | D4 | 05 | 05 | 05 | 8 |
| 15 | D5 | D5 | D5 | D5 | 06 | 06 | Q6 | 6 |
| 16 | D6 | D6 | D6 | D6 | 07 | 07 | 07 | 2 |
| 17 | D7 | D7 | D7 | D7 | 08 | 08 | 08 | 4 |
| 18 | PGM | PGM | $\overline{C E / P G M}$ | CE/PGM | CS/PGM | PD/PGM | A11 | 13 |
| 19 | VDD | VDD | GND | A 10 | VDD | A10 | A10 | 11 |
| 20 | CSNE | CSTNE | $\overline{\mathrm{OE}}$ | $\overline{O E}$ | A10 | $\overline{\text { CS }}$ | PD/PGM | 9 |
| 21. | VBB | VBB | VPP | VPP | VBB | VPP | VPP | 7 |
| 22 | GND | A9 | A9 | A9 | A9 | A9 | A9 | 5 |
| 23 | A8 | A8 | A8 | A8 | A8 | A8 | A8 | 3 |
| 24 | VCC | VCC | vcc | Vcc | VCC(PE) | Vcc | Vcc | 1 |


Note: All examples were prepared
using SYSTEM 65 Operating
System Version 3

## MODULE INSTALLATION

Install the PROM Programmer Module as follows:

1. Turn System 65 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 connector 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 may 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 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 (avoiding 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 I/O 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 ${ }^{\star}$ 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 \mathrm{~A})$ and page 1 ( $\$ 0100-\$ 01 \mathrm{FF}$ ).

## 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 (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 $(=)$ 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.

Following illustration 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.

```
CLYOFFSET=90190 IN=F FILE=PROM*F DISK=1
DONE
CSOM PRGGRIMMER FOR 1 MHZ SYSTEM (VER E)
ENTER 2704, 2768, 2758, 2716, 2516,2532
=2716
TMS 2716 FROM?
=N
**********************
DEVICE TIPE=
OEVIC
************************
ENTER FROM COMMAND: VERIFY(V), FROGRAM(F),READ(R),OR CHECK(C)
OR MEMORY COMMAND: VERIFY(F), LORQUL), DUMF(D), MEM FILL(M), INVERT\I)
```

Power-Up and Loading 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 F F)$.
2. Cannot overlap the PROM Programmer routine for file name PROM* ${ }^{\star}$ (\$0200-\$0FFF).
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-ones 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 use 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.


Program Function Example

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

## 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 ENTER 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 $1 / 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.

```
<5>
```

```
ENTER 2794, 2708, 2758, 2716, 2516, 2532
```

ENTER 2794, 2708, 2758, 2716, 2516, 2532
=2716
=2716
TMS 2716 PRON?
TMS 2716 PRON?
=N
=N
**********************
**********************
**********************
DEVICE TYPE=
DEVICE TYPE=
DEVIC
DEVIC
ENTER PROM COMMAND: VERIFY(V),PROGRAM(P),RERD(R),OR CHECK(C)
ENTER PROM COMMAND: VERIFY(V),PROGRAM(P),RERD(R),OR CHECK(C)
OR MEMORY COMMAND: VERIFY(F),LOAD(L),DUMP (D), MEM FILLL (M), INUERT (I)
OR MEMORY COMMAND: VERIFY(F),LOAD(L),DUMP (D), MEM FILLL (M), INUERT (I)
=Y \
=Y \
ERROR LIST
ERROR LIST
OUT=L
OUT=L
ENTER FIRST RDORESS
ENTER FIRST RDORESS
-1900
-1900
ENTER LAST ADDRESS
ENTER LAST ADDRESS
=17FF
=17FF
ERROR
ERROR
RDDR PROM RAM
RDDR PROM RAM
lll
lll
17FF CG 15
17FF CG 15
DONE
DONE
*************
*************
DEVICE TYPE=
DEVICE TYPE=
2716
2716
ENTER PROM COMMMND: VERIFY(V),PROGRAM(P),RERD (R),OR CHECK(C)
ENTER PROM COMMMND: VERIFY(V),PROGRAM(P),RERD (R),OR CHECK(C)
OR MEMORY COMMMAND: VERIFYY(F), LORDSL),OUMMP(D), MEM FILLSM), IMVERT\I)

```
OR MEMORY COMMMAND: VERIFYY(F), LORDSL),OUMMP(D), MEM FILLSM), IMVERT\I)
```


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

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.


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

```
<5>
<5>
ENTER 27,04, 2708, 2758, 2716, 2516, 2532
=2716
=N
************************
DEVICE TYPE=
2716
ENTER PROM COMMAND: VERIFY(V),PROGRAM(P),READ(R),OR CHECK<C)
OR MEMORY COMMAND: VERIFY(F), LOAD (L), DUMP (D), MEM FILL (M), INVERT (I)
=C
CHECK FIRST RDDRESS
CNTER
ENTER LAST ADDRESS
PROM NOT INITIALIZED
DONE
*************
2716
ENTER PROM COMMAND: VERIFY(V), PROGRAM(P),RERD(R),OR CHECK(C)
ENT,
```

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$ | 0 | $\$ 1000$ |
| $\$ 1000$ | $\$ 2000$ | $\$ 3000$ |
| $\$ 7000$ | $\$ A 000$ | $\$ 1000$ |
| $\$ E 000$ | $\$ 2000$ | $\$ 1000$ |

```
\S\ PRM PROGRRMMER FOR 1 MHZ SYSTEM (VER E)
ENTER 2704,2708, 2758, 2716,2516,2532
=2716
TMS 2716 PROM?
=N
********************
DEVICE TYPE=
2716
ENTER PROM COMMRND: VERIFY(V),PROGRAM(P),RERD(R),OR CHECK (C)
OR MEMORY COMMAND: VERIFY(F),LOAD(L),DUMP (D), MEM FILL (M), INVERT (I)
=L
OFFSET=D000 IN=F FILE=AIMBRS DISK=2
************************
DEVICE TYPE=
2716
ENTER PROM COMMRND: VERIFY(V),PROGRAM(P), RERD(R),OR CHECK(C)
OR MEMORY COMMAND: VERIFY(F),LORD(L), OUMP (D),MEM FILL (M),INVERT(I)
```


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


## 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 file 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.g.:


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

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.

```
PROM PROGRRMMER FOR 1 MHZ SYSTEM (VER E)
```

PROM PROGRRMMER FOR 1 MHZ SYSTEM (VER E)
ENTER 2704, 2708, 2758, 2716, 2516, 2532
ENTER 2704, 2708, 2758, 2716, 2516, 2532
=2716
=2716
TMS 2716 PROM?
TMS 2716 PROM?
TMS
TMS
**************************
**************************
O716
O716
**********************
**********************
ENTER PROM COMMAND: VERIFY(V),PROGRAM(P),RERD(R),OR CHECK(C)
ENTER PROM COMMAND: VERIFY(V),PROGRAM(P),RERD(R),OR CHECK(C)
OR MEMORY COMMAND: VERIFY(F),LORD(L),DUMP (D), MEM FILL (M), INVERT (I)
OR MEMORY COMMAND: VERIFY(F),LORD(L),DUMP (D), MEM FILL (M), INVERT (I)
MNR
MNR
MEM FILL=00
MEM FILL=00
FROM=1000 TO=13FF
FROM=1000 TO=13FF
************************
************************
DEVICE TYPE=
DEVICE TYPE=
2716
2716
ENTER PROM COMMAND: VERIFY(V),PROGRAM(P),READ(R),OR CHECK(C)
ENTER PROM COMMAND: VERIFY(V),PROGRAM(P),READ(R),OR CHECK(C)
OR MEMORY COMMAND: VERIFY(F),LORD (L),DUMP(D),MEM FILL(M), INVERT(\I)

```
OR MEMORY COMMAND: VERIFY(F),LORD (L),DUMP(D),MEM FILL(M), INVERT(\I)
```


## Memory Fill Function Example

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

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.

| PROM PROGRAMMER FOR 1 MHZ SYSTEM (VER E) <br> ENTER 2704, 2708, 2758, 2716, 2516, 2532 $2716$ <br> TMS 2716 PROM? <br> $=\mathrm{N}$ <br> ********************** <br> DEVICE TYPE= <br> 2716 <br> ********************* <br> ENTER PROM COMMAND: VERIFY(V),PROGRAM(P),READ $(R)$, $O R$ CHECK ( $C$ ) <br> OR MEMORY COMMAND: VERIFY(F), LORD (L) , DUMP (D), MEM FILL (M), INVERT (I) $=1$ <br> INVERT BITS=FF <br> FROM=1000 TO=13FF <br>  <br> DEVICE TYPE= <br> 2716 <br> ENTER PROM COMMRND: VERIFY( $Y$ ), PROGRAM ( $P$ ), READ (R), OR CHECK (C) <br> OR MEMORY COMMAND: VERIFY $\langle F\rangle$, LOAD $\langle L\rangle$, OUMP (D) , MEM FILL $\langle M\rangle$, INVERT $\langle I\rangle$ |
| :---: |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |
|  |  |

Invert Bits Function Example

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| PROM Devices Supported | 2704, 2708, 2758, Intel 2716 and Texas Instruments 2716 |
| Programming Time (approximately) | $\begin{aligned} & 2704-100 \mathrm{sec} . \\ & 2708-200 \mathrm{sec} . \\ & 2758-60 \mathrm{sec} . \\ & \text { Intel } 2716-120 \mathrm{sec} . \\ & \text { T.I. } 2716-400 \mathrm{sec} . \\ & 2516-120 \mathrm{sec} . \\ & 2532-240 \mathrm{sec} . \\ & \hline \end{aligned}$ |
| Interface | System 65 compatible |
| 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}$ to $+70^{\circ} \mathrm{C}$ |
| Power Requirements | $\begin{aligned} & +5 \mathrm{Vdc} \pm 5 \% @ 750 \mathrm{ma} \text { (fused at } 2 \mathrm{amps} \text { ) } \\ & +12 \mathrm{Vdc} \pm 5 \% @ 50 \mathrm{ma} \text { (fused at } 1 / 2 \mathrm{amp} \text { ) } \\ & -12 \mathrm{Vdc} \pm 5 \% @ 50 \mathrm{ma} \text {. } \end{aligned}$ |
| Fuse Description | F1-AGC $1 / 2 \mathrm{~A}-250 \mathrm{~V}$ (Bussman) F2-AGC 2A-250V (Bussman) |

## M65-045 PROM/ROM MODULE

## OVERVIEW

The M65-045 PROM/ROM Module permits system read only memory to be increased by up to 16 K bytes. The module provides 1624 -pin DIP sockets for accepting industry-standard 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 4K-byte sections. Each 4K-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 $4 K$-byte address space
- Single +5 V supply


M65-045 PROM/ROM Module

## FUNCTIONAL DESCRIPTION

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. 29650N35, Order No. 206).

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{D} 7}$ ) 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, S 3 through S 6 , which must be set to the desired hexadecimal value ( $0-F$ ). For example, if Switch S 3 is set to C , the base address for Sockets $\mathrm{Z4}, \mathrm{Z5}, \mathrm{Z} 6$ and $\mathrm{Z7}$ is $\$ \mathrm{C} 000$ (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, \mathrm{CS} 2=0$ and CS1 $=1$ will work only in Socket $Z 22$ (see Table 4) and with a selected base address value of $2,6, \mathrm{~A}$ or E.

The PROM/ROM Module must also be jumper-configured 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


Table 2. Switch Settings for 2716 PROM Operation

| Base Address (A15, A14, A13, A12) | Address A11 | Socket | Enable/Disable Switch |
| :---: | :---: | :---: | :---: |
| S3 (0-F) | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \mathrm{Z5} \\ & \mathrm{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} & \mathrm{S} 2-2 \\ & \text { S2-4 } \end{aligned}$ |
| S6 (0-F) | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \mathrm{Z24} \\ & \mathrm{Z29} \end{aligned}$ | $\begin{array}{r} S 2-6 \\ \mathrm{~S} 2-8 \end{array}$ |

Note: For 2716 PROMs, add Jumpers 4, 6, 8, 11 and 12.

Table 3. Switch Settings for 2708 or 2758 PROM Operations

| Base Address (A15, A14, A13, A12) | 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} & \text { Z4 } \\ & \text { Z5 } \\ & \text { Z6 } \\ & \text { Z7 } \end{aligned}$ | $\begin{aligned} & \text { S1-1 } \\ & \text { S1-2 } \\ & \text { S1-3 } \\ & \text { S1-4 } \end{aligned}$ |
| S4 (0-F) | $\begin{aligned} & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { Z10 } \\ & \text { Z11 } \\ & \text { Z13 } \\ & \text { Z14 } \end{aligned}$ | $\begin{aligned} & \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} & \mathrm{Z} 17 \\ & \text { Z18 } \\ & \text { Z21 } \\ & \text { Z22 } \end{aligned}$ | $\begin{aligned} & \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} & \text { S2-5 } \\ & \text { S2-6 } \\ & \text { S2-7 } \\ & \text { S2-8 } \end{aligned}$ |

Note: 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 C59-C62. 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


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 |
| :---: | :---: | :---: | :---: |

Note: *Assumes S1=A12 and S2=A13. For 2332 ROMs, add Jumpers 2, 5, 6 and 9.

## INSTALLATION

Install PROM/ROM Modules in the System 65 chassis or, with appropriate changes, in an Auxiliary Card Cage 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. Set the switches on the PROM/ROM Module per Tables 2 through 5 . The base memory address are assigned by four hexadecimal switches, S 3 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

| Parameter | Value |
| :--- | :--- |
| Memory Capacity | 16 K bytes |
| Word Length | 8 bits |
| Interface | System 65 compatible |
| Module Components | 162424 pin DIP sockets |
| Module Dimensions | 9.75 in. wide $\times 6.00$ 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 \mathrm{Vdc}+5 \%$ @ 500 ma. with no |
|  | devices installed |

LOGIC LEVELS $T_{A}=0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}, \mathrm{v}_{\mathrm{CC}}=+5 \mathrm{~V}+5 \%$

| Characteristic | Symbol | Min | Max | Unit | Condition |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \text { Inputs }(\overline{D O}-\overline{D 7}, A 0-A 15, \\ & \phi 2, R / \bar{W}) \end{aligned}$ |  |  |  |  |  |
| Input Low Voltage | $V_{\text {IL }}$ |  | 0.8 | v | $I_{1 L}=400 \mu \mathrm{a}$ |
| Input High Voltage | $V_{\text {IH }}$ | 2.0 | ${ }^{\text {cc }}$ | v | $\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$ | $\mathrm{I}_{\mathrm{OL}}=48 \mathrm{ma}$ |
| Output High Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | $v_{\text {cc }}$ | $v$ | $\mathrm{I}_{\mathrm{OH}}=10 \mathrm{ma}$ |

## M65-060 EXTENDER CARD

## OVERVIEW

The M65-060 Extender Card provides 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 standard 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 Motherboard are given in Section 4 of the System 65 User's Manual (Document No. 29650N35).

## SPECIFICATIONS

| Parameter | Value |
| :--- | :--- |
| Edge Contacts | 86 pins on 0.156 -in. centers |
| Edge Connector | 86 pins on 0.156 -in. centers |
| Extender Card Dimensions | 9.75 in. wide $\times 9.00$ in. high <br> $\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 System 65 chassis.
5. Insert the desired circuit module into the plug on top of the Extender Card.
6. Turn System 65 power on.


M65-060 Extender Card

## M65-071 DESIGN PROTOTYPING MODULE

## OVERVIEW

The M65-071 Design Prototyping Module 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 platedthrough holes that permit wire-wrap 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 86pin edge connector are identical to the Motherboard pin assignments given in Section 4 of the System 65 User's Manual (Document No. 29650N35; Order No. 206).


M65-071 Design Prototyping Module

## INSTALLATION

Install a Design Prototyping Module in the System 65 or, with appropriate changes, in an Auxiliary Card Cage 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. 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

| Parameter | Value |
| :--- | :--- |
| Component Mounting Area |  |
| $\quad$ Number of Component Rows | 14 |
| Number of Hole Rows |  |
| Vertical Hole Spacing |  |
| Horizontal Hole Spacing | 35 |
|  | 46 holes on 0.1-in. centers <br> 35 holes on either 0.3-in. <br> or 0.1 -in. centers |
| Flat Ribbon Connector Mounting <br> Area <br> Number of Pins <br> Per Connector |  |
| Module Dimensions | 170 |
| Edge Connector | 7.50 in. high $\times 9.75$ in. wide |
| 00.062 in. thick |  |

# M65-660 <br> SYSTEM 65 MACRO ASSEMBLER \& LINKING LOADER 

## DESCRIPTION

The System 65 Macro Assembler and Linking loader is a diskbased computer program that generates computer program absolute machine code or relocatable object code and links relocatable object code into absolute machine code. The assembler/loader operates on the System 65 Development System and generates code for execution by any central processing unit (CPU) in the Rockwell R6500 NMOS microprocessor, R6500/* NMOS one-chip microcomputer and R65C00 CMOS microprocessor device families.

## MACRO ASSEMBLER

The macro assembler translates CPU instructions and data statements written in symbolic form (the source program), into absolute or relocatable code. Instructions, consisting of a label (if included), a mnemonic operation code, an operand (if required) and an arithmetic operator (if included), are assembled one-at-a-time into one- to three-byte machine instructions (with absolute or relocatable address information). Constants comprising one or more bytes of memory are generated from data statements while one or more bytes of memory are assigned to variables. The macro capability allows sequences of instructions to be pre-defined for in-line code inclusion by specifying only the macro name. Conditional assembly allows portions of instruction sequences or macros to be included in (or excluded from) in-line code. The combination of the macro and conditional assembly capability speeds program development by eliminating duplicate coding efforts for similar processing tasks and increases program flexibility and reliability by allowing one source program to generate different computer programs based on specified control parameters.

## LINKING LOADER

The linking loader combines independently assembled modules of absolute and/or relocatable object code into a single executable object file. This allows a large program to be developed in manageable size modules by separate software designers and integrated by the linking process. This also allows program changes to be made to one module without affecting any of the other modules-a key requirement in many program validation and certification procedures.

Small programs can still be assembled into absolute executable code without using the linking loader, however, to simplify development.

The assembler/loader operates in conjunction with the ROMresident System 65 Debug Monitor/Text Editor (OS 3.1).

## MACRO ASSEMBLER FEATURES

- Supports three CPU families
—R6500 NMOS microprocessor
-R6500/* NMOS microcomputer
—R65C00 CMOS microprocessor
- Flexible object code generation
-Absolute code (executable)
—Relocatable code (linkable)
- Macro definition includes
—Multiple parameters
-Other macros
-CPU instructions
-Assembler directives
- Macro call includes
-Macro name
—Argument list
- Condition assembly
-IF condition
-ELSE complementary condition
- 12 conditional operators
- Symbol cross reference table
-Lists defined and used symbols
-Listed in alphanumeric order


## LINKING LOADER FEATURES

- Resolves inter-module symbol linkage
- Assigns absolute addresses
- Generates absolute executable code
- Produces reports
-Load map of module locations
-Symbolic debug table
-Symbol table
- Interactive or command file setup

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| M65-660-3 | Macro Assembler and Linking Loader ${ }^{(1)}$ |
| Order No. | Description |
| 249 | Macro Assembler and Linking Loader User's <br> Manual $^{(2)}$ |
| Notes: <br> 1. Requires System 65 OS 3.1 ROMs <br> 2. Included with M65-660-3. |  |

Assembler Directives

| Assembly Listing | Control |
| :---: | :---: |
| .TTL | Title |
| .SBTTL | Subtitle |
| .PAG | Page |
| .SKI | Skip |
| .ERR | Error |

## Source File Control

| .END | End of Assembly |
| :--- | :--- |
| FILE | Next File |
| INCL | Include |

## Data Storage

.BYTE
WORD
.DBYTE
.SBYTE

## Equate

=
Assign value to symbol

## Conditional

.IF

Condition
ELSE Complementary condition
EIF End of conditional

Macro .MACRO
ENDM
.MEXIT
NARG

Option Control
.OPT

| .OPT | Option |
| :--- | :--- |
|  | LIST/NOLIST |
|  | GEN/NOGEN |
|  | ERR/NOERR |
|  | SYM/NOSYM |
|  | CREF/NOCREF |
|  | ABS |
|  | REL |
|  | MEM |

TOC/NOTOC
OBJ/NOOBJ
MD/NOMD
ME/NOME
CC/NOCC
PLEN
LLEN
FF/NOFF
CLS
Radix 2, 8, 10, or 16

## Relocation/Linking

.DEF Internal definition
REF External reference
.ZREF Zero page reference
.PSECT Program section
.IDENT Module identification

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

## Linking Loader Directives

| ERR | Errors destination | ORG | Origin |
| :--- | :--- | :--- | :--- |
| OBJ | Object code generation | ORDER | Section order |
| MAP | Load map generation | DEF | Symbol definition |
| CALS | Symbol table location | LOAD | Load code specification |
| SYM | Global symbol table | END | Command file end |
| DEBUG | Debug symbol table |  |  |

## 0 Rockwell

## SPS-200 SOFTWARE PREPARATION SYSTEM (SPS) PERIPHERAL CONNECTOR MODULE

## INTRODUCTION

The optional SPS Peripheral Connector Module (PCM) (Part No. SPS-200), which connects directly to the AIM 65 Microcomputer Master Module connector, provides the Software Preparation System (SPS) with a complete set of external I/O interfaces. These I/O interfaces support external printers, serial devices, audio cassette 20 mA current loop and parallel I/O devices such as the RM 65 board family.

The external printer interface routes and buffers (TTL levels) the printer signals to a Centronics compatible 34-pin connector for printer support.

The RS-232 interface operates at the $\pm 5 \mathrm{~V}$ level. No handshaking signals are provided, but selectable handshake signals have been wired for static levels. Feed throughs are provided to cut and jumper these signals. Data Set/Data Terminal operation is selected using a jumper pair.

The 20 mA current loop interface routes four 20 mA current loop signals from the AIM 65 Master Module connector (J1) to a dedicated Molex connector to provide current loop I/O support.

The audio cassette recorder interface signals are routed to two mini-phone ( 3.5 mm ) jacks for audio cassette support. The remote control lines are controled by reed relays and routed to two sub-mini-phone ( 2.5 mm ) jacks.

The parallel I/O connector interface supports the 40-pin signals routed to the interface by the AIM 65 Master Module User

VIA (Z22). The parallel interface connector is compatible with many of the RM 65 modules, e.g.; single Board Computer (SBC) and Multi-function Peripheral Interface (MPI), and with the AIM 65/40 Microcomputer connector, e.g., User Parallel I/O, Display Interface and Printer Interface.

## FEATURES

- 34-pin connector for Centronics compatible printer support
- RS-232 connector for serial interface support
- Molex connector for 20 mA current loop support
- 3.5 mm mini-phone jack connectors for audio cassette support
- 2.5 mm sub-mini-phone jack connectors for remote tape control
- 40-pin parallel I/O connector, compatible with the RM 65 module family


## REFERENCE DOCUMENTS

The following documents contain information regarding set-up and operation of SPS-200.

| Order No. | Title |
| :---: | :---: |
| 2167 | R6500 Software Preparation System (SPS) |
|  | User's Manual |
| 209 | AIM 65 Microcomputer User's Guide |



SPS-200 Peripheral Connector Module

## EXTERNAL PRINTER INTERFACE

SPS Module Printer Connector

| Pin | Signal | Pin | Signal |
| :---: | :--- | :--- | :--- |
| 1 | STROBE | 13 | Data 6 |
| 2 | Ground | 14 | Ground |
| 3 | Data 1 | 15 | Data 7 |
| 4 | Ground | 16 | Ground |
| 5 | Data 2 | 17 | Data 8 |
| 6 | Ground | 18 | Ground |
| 7 | Data 3 | 19 | ACK |
| 8 | Ground | 20 | Ground |
| 9 | Data 4 | 21 | Not Used |
| 10 | Ground | 22 | Ground |
| 11 | Data 5 | 23 to 34 | Not Used |
| 12 | Ground |  |  |



Interface Module Connector


## Printer Interface Cable (User Supplied)

Centronics Type Connector Pin Assignment

| Pin | Signal | Pin | Signal |
| :--- | :--- | :--- | :--- |
| $\mathrm{J}-1$ | STROBE | $\mathrm{J}-8$ | Data 7 |
| $\mathrm{J}-2$ | Data 1 | $\mathrm{J}-9$ | Data 8 |
| $\mathrm{J}-3$ | Data 2 | $\mathrm{J}-10$ | ACK |
| $\mathrm{J}-4$ | Data 3 | $\mathrm{J}-11$ to -17 | Not Used |
| $\mathrm{J}-5$ | Data 4 | $\mathrm{J}-19$ to -29 | Ground |
| $\mathrm{J}-6$ | Data 5 | $\mathrm{J}-30$ to -35 | Not Used |
| $\mathrm{J}-7$ | Data 6 | $\mathrm{J}-18$ and $\mathrm{J}-36$ | Not Connected |



External Printer Connector

## RS-232 INTERFACE

RS-232 Connector Pin Assignments

| Pin | Signal Mnemonic | Signal Name | Input/Output |  |
| :---: | :---: | :---: | :---: | :---: |
|  |  |  | Data Set | Data Term |
| 1 | GND | Chassis Ground |  |  |
| 2 | TD | Transmit Data | 1 | 0 |
| 3 | $\overline{\mathrm{RD}}$ | Receive Data | 0 | 1 |
| 5 | CTS | Clear to Send ${ }^{11}$ | +5V Always | +5V Always |
| 6 | DSR | Data Set Ready ${ }^{1}$ | +5V Always | +5V Always |
| 7 | GND | Signal Ground |  |  |
| 8 9 $9-25$ | DCD | Data Carrier Detected ${ }^{1}$ Not Used | +5V Always | +5V Always |

${ }^{1}$ This can be cut for a No Connect option


RS-232 Connector Pin Locations

## 20 mA CURRENT LOOP INTERFACE

20 mA Current Loop Connector Pin Assignments

| Pin | Signal Mnemonic | Signal Name |
| :--- | :--- | :--- |
| 1 | TTY KYBD | TTY Keyboard |
| 2 | TTY KYBD RETURN (+) | TTY Keyboard Return (+) |
| 3 | TTY PTR | TTY Printer |
| 4 | TTY PTR RETURN (+) | TTY Printer Return (+) |



TO TTY KEYBOARD TO TTY PRINTER

CURRENT LOOP MOLEX NO. 08-50-0114 PINS CONNECTOR INSIDE NO. 22-01-2041 HOUSING (SIDE VIEW)

## PARALLEL I/O CONNECTOR INTERFACE

Parallel I/O Connector Pin Assignments

| Pin | Mnemonic | Signal Name | Input/Output |
| :---: | :---: | :---: | :---: |
| 1* | CB2 | Port B, Control No. ${ }^{11}$ | $1 / \mathrm{O}$ |
| 2 |  | No Connect |  |
| 3* | CB1 | Port B, Control No. 1 | $1 / 0$ |
| 5* | PB7 | Port B, Bit 7 | $1 / 0$ |
| 7* | PB6 | Port B, Bit 6 | $1 / 0$ |
| 9* | PB5 | Port B, Bit 5 | $1 / 0$ |
| 11* | PB4 | Port B, Bit 4 | $1 / 0$ |
| 13* | PB3 | Port B, Bit 3 | $1 / 0$ |
| 15* | PB2 | Port B, Bit 2 | $1 / 0$ |
| 17** | PB1 | Port B, Bit 1 | $1 / 0$ |
| 19* | PB0 | Port B, Bit 0 | $1 / 0$ |
| 21 | PA7 | Port A, Bit 7 | $1 / 0$ |
| 23 | PA6 | Port A, Bit 6 | $1 / 0$ |
| 25 | PA5 | Port A, Bit 5 | $1 / 0$ |
| 27 | PA4 | Port A, Bit 4 | $1 / 0$ |
| 29 | PA3 | Port A, Bit 3 | $1 / 0$ |
| 31 | PA2 | Port A, Bit 2 | $1 / 0$ |
| 33 | PA1 | Port A, Bit 1 | $1 / 0$ |
| 35 | PAO | Port A, Bit 0 | $1 / 0$ |
| 37 | CA2 | Port A, Control No. 2 | $1 / 0$ |
| 39 | CA1 | Port A, Control No. 1 | $1 / 0$ |
| 40 |  | No Connect |  |
| Note: Even Numbered pins connected to GND. |  |  |  |
| *These signals are used by the Printer Interface. <br> 1 This can be cut/jumpered to +5 V . |  |  |  |


| 2 | 40 | CABLE CONNECTOR: |
| :---: | :---: | :---: |
|  |  | (OR EQUIVALENT) |
|  |  | REAR PANEL CONNECTOR: <br> (3M) 3324-0000 |
| 1 | 39 |  |

Parallel I/O Connector Pin Locations

DATA SET/DATA TERMINAL SETUP


## AUDIO CASSETTE RECORDER INTERFACE



Audio Cassette Recorder Interface


#### Abstract

\section*{WARNING}

This equipment generates, uses and can radiate radio frequency energy and if not installed and used in accordance with the instructions manual, may cause interference to radio communications. It has been tested and found to comply with the limits for a Class A computing device pursuant to Subpart J of Part 15 of FCC Rules, which are designed to provide reasonable protection against such interference when operated in a commercial environment. Operation of this equipment in a residential area is likely to cause interference in which case the user at his own expense will be required to take whatever measures may be required to correct the interference.


INFORMATION TO USER: If this equipment does cause interference to radio or television reception which can be determined by turning the equipment on and off, the user is encouraged to try to correct the interference by one or more of the following measures:

- reorient the receiving antenna
- relocate the computer with respect to the receiver
- move the computer with respect to the receiver
- plug the computer into a different outlet so that the computer and receiver are on different circuits

If necessary, the user should consult the dealer or an experienced radio/television technician for additional suggestions. The user may find the following booklet prepared by the Federal Communications Commission helpful:

## "How to Identify and Resolve Radio and TV Interference Problems:

This booklet is available from the U.S. Government Printing Office, Washington, D.C. 20402, Stock Number 004-000-0345-4.


Figure 1. Peripheral Connector Module Schematic


## SECTION 7 AIM 65 MICROCOMPUTER FAMILY

Page
Product Family Overview ..... 7-2
A65-100 and A65-400 AIM 65 Microcomputer ..... 7-3
A65-0500 AIM 65 Microcomputer System ..... 7-10
A65-002 and A65-006 AIM 65 Microcomputer Enclosure ..... 7-12
A65-003 Service Test Board ..... 7-14
A65-004-03 Power Supply and Cable ..... 7-16
A65-010 Assembler ROM ..... 7-18
A65-020 BASIC Interpreter ROMs ..... 7-20
A65-024 BASIC Compiler ..... 7-22
A65-030 PL/65 Compiler ROMs ..... 7-24
A65-040 Math Package ROM ..... 7-26
A65-050 FORTH ROMs ..... 7-28
A65-052 FORTH Target Compiler ..... 7-33
A65-060 Instant Pascal ROMs ..... 7-38
A65-090 Disk Operating System (DOS 1.0) ROM ..... 7-41
A65-901 PROM Programmer and CO-ED Module ..... 7-42
A65-905 Memory Cartridge ..... 7-46

## AIM 65 MICROCOMPUTER FAMILY Professional, Hard Working, Low Cost, Blue Collar Microcomputer

For low cost prototypes or low to medium volume production, Rockwell offers an extended family of board level "blue collar" products, easy to design-in and implement. All are built around the R6502 CPU and R6500 peripherals so that applcations using the modules can be readily redesigned into devices as volume warrants. And, all of the board products are available with a wide range of languages-Microsoft BASIC, FORTH, PL/65, assembly, instant Pascal-for optimum system solutions.
The AIM 65 (R6500 based Advanced Interactive Microcomputer) is an under $\$ 500$ microcomputer, complete with keyboard, display and hard copy printer. It has extensive options, many interfaces and expansion capabilities. If you're planning on computerizing a product, AIM 65 is designed to do the job. If you're interested in designing a system around the R6500 family of devices,

AIM 65 is also a mini-development system at the price of most evaluation boards. And, AIM 65 comes with complete documentation, making it simple to use. Since it is a "best seller'' widely used in universities and industry, a large library of commercially available texts and manuals has developed, making it even easier to use.
In addition to bare board blue-collar versions, the AIM 65 is available in an enclosure, complete with power supply, for use as a desk top computer. Additional memory cartridges are available to plug onto the desk top AIM 65 providing additional languages or memory. These can let AIM 65 function as a test instrument, analyzer or controller.
Whatever your application, for a learning tool, evaluation system or industrial controller, a blue collar AIM 65 Microcomputer is an economical solution.
*AIM 65 Microcomputer is a trademark of the Rockwell International Corp.


# A65-100 AND A65-400 AIM 65 MICROCOMPUTER 

## PRODUCT OVERVIEW

The AIM 65 microcomputer is a complete, assembled microcomputer system featuring a 20 -column thermal printer, a $20-$ character alphanumeric display, and a full-size terminal style keyboard. On-board memory sockets accept up to 20 K bytes of PROM/ROM and 4K bytes of static RAM. A user R6522 Versatile Interface Adapter (VIA) dedicates 16 parallel I/O data lines and four handshaking control lines to application usage. The address, data, and control lines are also accessible for off-board memory, peripheral and I/O expansion. An 8K-byte ROM-resident debug monitor and text editor provides immediate interactive operation upon power turn-on.

With its self-contained printer and display, the AIM 65 mi crocomputer is ideal for educational and industrial desk-top applications. The on-board printer, unique to single-board microcomputers in its class, make the AIM 65 microcomputer a natural for any control and monitor application requiring hard copy output-such as equipment performance monitoring, data logging, test and evaluation, specialized data acquisition and reduction, laboratory measurements and analysis, and untold others.

The interactive monitor simplifies computer program checkout with single step functions which trace instruction execution and register contents as well as stop execution at specified breakpoint addresses. Memory and registers can be examined and altered to set up controlled execution conditions and to allow detailed analysis of program performance. The text editor allows computer program assembly and high level language instructions and data to be easily entered and edited at the source code level.


A65-400 AIM 65 Microcomputer

## FEATURES

- Single Board Computer with on-board RAM, ROM, and I/O
—Powerful and Popular 6502 CPU
- Up to 4K bytes of 2114 Static RAM
-Up to 20K bytes of 2532 PROM or R2332 ROM
-User-Dedicated Application Parallel I/O Interface
-Low-Cost Audio Cassette Recorder Interface with 2 Recorder Remote Control Lines
- 20 mA Current Loop Serial Interface
-Expansion Bus Interface
- 20-Column Thermal Printer
-64 Character ASCII Format
- 120 Lines per Minute
$-5 \times 7$ Dot Matrix Character Font
- 20-Character Display
-64-Character ASCII Format
-16-Segment Font
-High Contrast Monolithic Characters
- Full-Size 54-key Terminal Style Keyboard
-26 Alphabetic, 10 Numeric, and 22 Special Characters
-9 Control Functions and 3 User-Defined Functions
- ROM-Resident Interactive Debug Monitor
-Monitor-Generated Prompts and Single Keystroke Commands
-Single-Step Execution with Tracing and Breakpoints
-Memory and Register Examine and Alter
-Mnemonic Instruction Entry and Disassembly
- Text Editor
-Line Oriented Commands (Read, Insert, Delete, List)
-Character String Find and Change
- Parallel Application Interface
-R6522 Versatile Interface Adapter (VIA)
-Two 8-bit Parallel Bidirectional Data Ports
-Two 2-bit Handshake Control Ports
-Two Programmable 16-bit Counter/Timers
-8-bit Serial Interface
- Optional ROM-Based Languages
-4K Symbolic Assembler
-8K BASIC Interpreter
-8K PL/65 Compiler
-8K FORTH Compiler/Interpreter
-20K Pascal Compiler/Interpreter (16K Bytes Off-Board)


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :--- |
| A65-100 | AIM 65 with 1K RAM |
| A65-400 | AIM 65 with 4K RAM |
| A65-415 | AIM 65 with 4K RAM \& BASIC Interpreter ROMs |
| A65-420 | AIM 65 with 4K RAM, BASIC Interpreter ROMs |
|  | \& Assembler ROM |
| A65-450 | AIM 65 with 4K RAM \& FORTH ROMs |
| Order No. | Description |
| 209 | AIM 65 Microcomputer User's Guide ${ }^{(1)}$ |
| 209 L | AIM 65 Monitor Listing |
| 217 | AIM 65 Reference Card |
| 219 | AIM 65 Schematic (Wall Chart) ${ }^{(1)}$ |
| 201 | R6500 Hardware Manual |
| 202 | R6500 Programming Manual ${ }^{(1)}$ |
| 200 | R6500 Programming Reference Card ${ }^{(1)}$ |
| 221 | AIM 65 BASIC Language Reference Manual ${ }^{(2)}$ |
| 233 | AIM 65 BASIC Reference Card |
| 265 | AIM 65 FORTH User's Manual |
| 283 | AIM 65 FORTH Reference Card ${ }^{(3)}$ |
| Notes: |  |
| 1. |  |
| 2. | Included with all models. |
| 3. | Included with A65-0415 and A65-0420. |

## FUNCTIONAL DESCRIPTION

The AIM 65 microcomputer consists of a Master Module (which includes the central processing and control circuitry, decoders, memory, //O and printer control circuitry), an attached Display Module and a separate Keyboard Module. A thermal printer is mounted directly on the Master Module while the Display Module is mounted on angle brackets which are fastened to the Master Module.

## Central Processing and Control

The R6502 8-bit microprocessor, the central processing unit (CPU) of the AIM 65 microcomputer, provides the overall control and monitoring of all AIM 65 operations. The R6502 communicates with other AIM 65 elements on three separate buses. A 16-bit address bus allows the CPU to directly address 65,536 memory locations. An 8 -bit bidirectional data bus carries data from the CPU to/from memory and interface devices. The control bus carries various timing and control signals between the CPU and interfacing peripherals, devices, and off-board elements.

The CPU operates at 1 MHz , which is derived from a 4 MHz crystal-controlled oscillator. The $\emptyset 2$ system clock and read/write control signals are generated by the CPU, and are buffered and routed to other devices on-board and to the expansion connector.

A decoder circuit provides chip select signals to the on-board PROM/ROM and RAM sockets and to the l/O devices. 4K-byte chip selects are sent to the PROM/ROM sockets (\$BXXX\$FXXX) while 1 K -byte select signals are routed to the RAM sockets ( $\$ 00 X X-\$ X C X X$ ). On-board I/O is also decoded to 1 K byte selects (\$A0XX-\$ACXX).

A pushbutton switch initiates RESET to the on-board devices and to interfacing equipment through the expansion connector. Installed terminal posts allow connection to a remote RESET switch. The STEP/RUN switch selects program execution in either the single-step mode or the run mode. In single-step mode, execution of all instructions in the address range 0 $\$ 9 F F F$ can be traced or can be stopped at any of four specified breakpoints. The $K B / T T Y$ switch selects operation using the AIM 65 keyboard and display or using a, teletypewriter attached to the 20 mA current loop interface.

## Memory

Two $1024 \times 42114$ static RAM devices are required for each 1 K -byte of installed RAM. Both 1 K and 4 K versions are available. The 1 K version may be expanded on-board in 1 K increments up to 4K using the spare RAM sockets.

Five PROM/ROM sockets accept installation of the 4 K -byte R2332 ROM, 2532 PROM, or smaller devices with compatible pinouts, e.g., 2K-byte 2516 PROM. The AIM 65 microcomputer comes with two R2332 ROMs containing the Debug Monitor/ Text Editor installed at addresses $\$$ E000-\$FFFF.

## I/O

The 16 bidirectional data lines and 4 handshake control lines of the user-dedicated R6522 VIA are routed directly to the application connector. The high current capacity of the VIA's eight "B" port lines can directly drive many industry-standard devices, such as solid state relays. One of the lines can be used as either a serial input or output line.
The audio recorder interface connects to one or two low-cost audio cassette recorders. Two remote control lines can control two separate recorders independently during read and write operations using the AIM 65 blocked audio recording format.

## Peripherals

The printer prints on heat-sensitive roll paper by means of ten thermal elements, mounted on a movable head, each of which can print two $5 \times 7$ matrix dot characters. The printed characters are formed by dot patterns stored in the AIM 65 Monitor/Editor ROMs. A motor-driven platen advances the paper after each row of horizontal dots is printed. The motor and thermal element driver voltages are derived from an external +24 V power supply. The printing is controlled by subroutines resident in the Monitor/ Editor ROMs.

The AIM 65 display consists of five four-digit 16 -segment alphanumeric displays and an R6520 Peripheral Interface Adapter (PIA) mounted on the Display Module which connects to the Master Module through two short solid-conductor ribbon cables. Each display quad contains internal memory, decoder, and driver circuitry. The display quads interface with the Master Module through the PIA. Data may be sent to the display using Monitor ROM subroutines.

The Keyboard Module connects to the Master Module by a removable 16 -conductor flat ribbon cable. The interface is through an R6532 RAM, I/O, and Timer (RIOT) device which supports the Monitor with the RAM and timer. The key matrix is strobed by eight lines output through the RIOT with the matrix returns routed back through eight R6532 input lines.

## OPTIONS

Optional hardware and accessory items are available which expand the functionality of the AIM 65 Microcomputer. The microcomputer can be easily installed in an attractive, professional, injection molded plastic enclosure for desk-top applications. Plug-in memory cartridges (A65-905 series) connect to the AIM 65 enclosure to expand memory in configurations of RAM and/or PROM/ROM. System expansion via RM 65 modules adds memory, input/output and peripheral (e.g., floppy disk and CRT display interface) functions to the on-board AIM 65 resources. Three different adapters/buffer modules connect the AIM 65 Expansion Connector to either one RM 65 module or to one of the multi-slot RM 65 motherboards. PROM programming can be performed using either the AIM 65 PROM Programmer or the RM 65 PROM Programmer Module (RM652901). The latter module has the advantage of being able to be used with other RM 65 modules connected to the system, e.g., RM 65 FDC module with AIM 65 DOS 1.0 (A65-090) firmware, to simplify source and object code handling.
Optional ROM-based languages support computer program development in both R6500 assembly language and high level languages. BASIC (by Microsoft) is the most popular microcomputer language used for computation and low speed control applications. FORTH is a highly efficient language in terms of memory utilization and execution speed-and also greatly shortens program development time. PL/65 provides structured control statements and compiles to 6500 assembly language to serve as an efficient system implementation language. The AIM 65 Pascal is a unique implementation of a substantial subset of standard Pascal which features interactive statement entry and execution with debug features at the source statement level.

OPTION ORDERING INFORMATION

| Part No. | Description |
| :---: | :---: |
| Accessories and Hardware |  |
| A65-002 | AIM 65 Enclosure |
| A65-003 | AIM 65 Service Test Board |
| A65-004 | AIM 65 Power Supply \& Cable |
| A65-006 | AIM 65 Enclosure and Power Supply |
| A65-901 | AIM 65 PROM Programmer |
| A65-905 | AIM 65 Memory Cartridge |
| RM65-7101E | RM 65 Single Card Adapter for AIM 65 |
| RM65-7104E | RM 65 Adapter/Buffer Module for AIM 65 |
| RM65-7116E | RM 65 Cable Driver \& Buffer Module for AIM 65 |
| Firmware |  |
| A65-010 | AIM 65 Assembler ROM |
| A65-020 | AIM 65 BASIC Interpreter ROMs |
| A65-030 | AIM 65 PL/65 Compiler ROMs |
| A65-040 | AIM 65 Math Package ROM |
| A65-050 | AIM 65 FORTH Interpreter System ROMs |
| A65-060 | AIM 65 Instant Pascal ROMs |
| A65-090 | AIM Disk Operating System Version 1.0 (DOS 1.0) ROM ${ }^{(1)}$ |
| Software |  |
| A65-024 | AIM 65 BASIC Compiler ${ }^{(1,2,3)}$ |
| A65-052 | AIM 65 FORTH Compiler ${ }^{(1,2,2,3,4)}$ |
| Notes: <br> 1. Requires RM 65 Floppy Disk Controller (FDC) module. (RM65-5101NE). <br> 2. Requires AIM 65 DOS 1.0 ROM (A65-090). <br> 3. Provided on $51 / 4^{\prime \prime}$ double-density disk. <br> 4. Requires AIM 65 FORTH Interpreter ROMs (A65-050). |  |
|  |  |
|  |  |
|  |  |
|  |  |


| Expansion Connector Pin Assignments |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Top (Component Side) |  |  |  | Bottom (Solder Side) |  |  |  |
| Signal Mnemonic | Signal Name | Input/ Output | Pin | Pin | Signal Mnemonic | Signal Name | Input/ Output |
| SYNC | SYNC | 0 | 1 | A | A0 | Address Bit 0 | 0 |
| RDY | Ready | 1 | 2 | B | A1 | Address Bit 1 | 0 |
| $\square 1$ | Phase 1 Clock | 0 | 3 | c | A2 | Address Bit 2 | 0 |
| IRQ | Interrupt Request | 1 | 4 | D | A3 | Address Bit 3 | 0 |
| S.o. | Set Overflow | 1 | 5 | E | A4 | Address Bit 4 | 0 |
| NMI | Non-Maskable Interrupt | 1 | 6 | F | A5 | Address Bit 5 | 0 |
| RES | Reset | 1 | 7 | H | A6 | Address Bit 6 | 0 |
| D7 | Data Bit 7 | 1/0 | 8 | J | A7 | Address Bit 7 | 0 |
| D6 | Data Bit 6 | 1/0 | 9 | $K$ | A8 | Address Bit 8 | 0 |
| D5 | Data Bit 5 | 1/0 | 10 | L | A9 | Address Bit 9 | 0 |
| D4 | Data Bit 4 | 1/0 | 11 | M | A 10 | Address Bit 10 | 0 |
| D3 | Data Bit 3 | 1/0 | 12 | N | A11 | Address Bit 11 | 0 |
| D2 | Data Bit 2 | 1/0 | 13 | P | A 12 | Address Bit 12 | 0 |
| D1 | Data Bit 1 | 1/0 | 14 | R | A13 | Address Bit 13 | 0 |
| D0 | Data Bit 0 | 1/0 | 15 | S | A14 | Address Bit 14 | 0 |
| -12V | *-12 Vdc | - | 16 | T | A 15 | Address Bit 15 | - |
| +12V | * +12 Vdc | 0 | 17 | U | SYS $\square_{2}$ | System Phase 2 Clock | 0 |
| CS8 | Chip Select 8 | 0 | 18 | $v$ | SYS R/W | System Read/Write | 0 |
| CS9 | Chip Select 9 | 0 | 19 | w | $\overline{R / \bar{W}}$ | Read/Write "Not" | 0 |
| $\overline{C S A}$ | Chip Select A | 0 | 20 | $\times$ | TEST | Test | 0 |
| $+5 \mathrm{~V}$ | $+5 \mathrm{Vdc}$ | 0 | 21 | Y | $\bar{\square}$ | Phase 2 Clock "Not"' | 0 |
| GND | Ground |  | 22 | $z$ | RAM R $\bar{N}$ | RAM Read/Write | 0 |

Note: *Not used on AIM 65.

Application Connector Pin Assignments

| Top (Component Side) |  |  |  |  | Bottom (Solder Side) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Signal Mnemonic | Signal Name | Type | 1/0 | Pin | Pin | Signal Mnemonic | Signal Name | Type | 1/0 |
| GND | Ground |  |  | 1 | A | $+5 \mathrm{~V}$ | $+5 \mathrm{~V}$ | Power | 0 |
| PA3 | Port A Data Bit 3 | NMOS | 1/O | 2 | B |  | NC |  |  |
| PA2 | Port A Data Bit 2 | NMOS | 1/0 | 3 | C | 02 | CPU Phase 2 Clock | NMOS | 0 |
| PA1 | Port A Data Bit 1 | NMOS | 1/0 | 4 | D | $\mathrm{R} / \bar{W}$ | CPU Read/Write | NMOS |  |
| PA4 | Port A Data Bit 4 | NMOS | 1/0 | 5 | E | TAPE 1B RTN | Tape 1B Remote Control Return |  | 1/0 |
| PA5 | Port A Data Bit 5 | NMOS | 1/0 | 6 | F | TAPE 1B | Tape 18 Remote Control |  | 1/0 |
| PA6 | Port A Data Bit 6 | NMOS | 1/0 | 7 | H | TAPE 2B RTN | Tape 2B Remote Control Return |  | 1/0 |
| PA7 | Port A Data Bit 7 | NMOS | 1/0 | 8 | $J$ | TAPE 2B | Tape 2B Remote Control |  | 1/0 |
| PBO | Port B-Data Bit 0 | NMOS | 1/0 | 9 | K |  | NC |  |  |
| PB1 | Port B Data Bit 1 | NMOS | 1/0 | 10 | L | AUDIO IN | Audio Input Low |  | 1 |
| PB2 | Port B Data Bit 2 | NMOS | 1/0 | 11 | M | AUDIO OUT LO | Audio Output Low Level |  | 0 |
| PB3 | Port B Data Bit 3 | NMOS | 1/0 | 12 | N | +12V | $+12 \mathrm{Vdc}$ | Power | 0 |
| PB4 | Port B Data Bit 4 | NMOS | 1/0 | 13 | P | AUDIO OUT HIGH | Audio Output High Level |  | 0 |
| PA0 | Port A Data Bit 0 | NMOS | 1/0 | 14 | R | TTY KYBD RTN (+) | TTY Keyboard Return | $20 \mathrm{~mA} \mathrm{( }+$ ) |  |
| PB7 | Port B Data Bit 7 | NMOS | 1/0 | 15 | S | TTY PWR RTN (+) | TTY Power Return | $20 \mathrm{~mA}(+)$ |  |
| PB5 | Port B Data Bit 5 | NMOS | 1/0 | 16 | T | TTY KYBD | TTY Keyboard (Data In) | $20 \mathrm{~mA}(-)$ | 1 |
| PB6 | Port B Data Bit6 | NMOS | 1/0 | 17 | U | TTY PWR | TTY Power (Data Out) | 20 mA (-) | 0 |
| CB1 | Port B Control Bit 1 | NMOS | 1/0 | 18 | V | TAPE 2A | Tape 2A Remote Control. | $\therefore \quad 2$ | $1 / 0$ |
| CB2 | Port B Control Bit 2 | NMOS | 1/0 | 19 | W | TAPE 1A | Tape 1A Remote Control | 5 | 1/0 |
| CA1 | Port A Control Bit 1 | NMOS | 1 | 20 | $x$ |  | NC |  |  |
| CA2 | Port A Control Bit 2 | NMOS | 1/0 | 21 | Y | SERIALIN | Serial Input |  | 1 |
| -12V | -12 Vdc* | Power | 0 | 22 | $z$ | $+24 \mathrm{~V}$ | +24 Vdc** | Power | 0 |
| Notes: *Pin 22 jumpered to -12 V through jumper. <br> **Pin $Z$ jumpered to $+24 V$ through jumper. |  |  |  |  |  |  |  |  |  |

## SPECIFICATIONS



## ELECTRICAL CHARACTERISTICS


${ }^{* *}+24 \mathrm{~V}$ peak current specified as worst case with printer dury cycle of $75 \%$. For most cases, a +24 V 2 A power supply is sufficient.



AIM 65 Microcomputer Block Diagram

## MONITOR COMMANDS

## Major Function Entry

(RESET Button)-Enter and Initialize Monitor
ESC - Reenter Monitor
E - Enter and Initialize Text Editor
T - Reenter Text Editor
N - Jump to D000
5 - Jump to B000
6 - Jump to B003

## 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
/ - 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 peripheral I/O device
D - Dump object code to peripheral I/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
1 - Insert line into text buffer
K - Delete current line of text
(SPACE) - Display current line of text
L - List lines of text to peripheral I/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


## A65-0500 <br> AIM 65 MICROCOMPUTER SYSTEM

## DESCRIPTION

The AIM 65 " 500 " Series Microcomputer System offers the popular AIM 65 Microcomputer, power supply, interconnect wiring, switches, and attractive injection molded enclosure-all fully connected, assembled, and ready for operation. Four models, pre-configured with varying combinations of ROM-based languages, support many different educational, scientific, or industrial applications. The stylistic, low profile, compact enclosure with fine textured, nonreflective brown finish complements classroom, industrial, office or laboratory environments.

All models include a full-size terminal-style keyboard and 20character alphanumeric display for interactive operator communications and a 20 -column printer for hard copy records of computed results of programs and/or data. Serial interface and control lines are provided for audio cassette storage of programs and data files. The microcomputer memory features 4 K bytes of RAM and 8 K bytes of ROM-resident interactive debug monitor and text editor in addition to the available languages. Most important may be the flexibility afforded by the userdedicated I/O port that interfaces to application sensors, actuators or peripherals. Built-in I/O features include two 8-bit parallel handshake and one serial bidirectional data ports. Two 16-bit timer/controllers are available for time measurement or event counting. Finally, the microcomputer bus is accessible at a connector for external expansion with the AIM 65 memory cartridge system (A65-905-XX), AIM 65 PROM programmer (A65-901) or a selection of RM 65 modules such as floppy disk or CRT controllers.


## FEATURES

- R6502 CPU-based single board computer
- 20-character 16 -segment display
- 20-column thermal printer
- Full-size 54-key terminal-style keyboard
- ROM-resident Debug Monitor/Text Editor
- Parallel application connection
- Expansion bus connection
- Includes power supply, switches and wiring
- Sturdy aluminum base
- Low-profile injection molded ABS top cover
- Enclosed, plug-in memory cartridge option for desk-top expansion
- RM 65 peripheral, input/output and memory module expansion interface
- Fully assembled, tested and warranted.


## ORDERING INFORMATION

| Part No. | Description |
| :---: | :---: |
| A65-0500 | AIM 65 Microcomputer System with 4K RAM and 12K PROM/ROM capacity |
| A65-0515 | AIM 65 Microcomputer System with 4K RAM, 8K BASIC Interpreter ROMs and 4K PROM/ROM capacity |
| A65-0520 | AIM 65 Microcomputer System with 4K RAM, 8K BASIC Interpreter ROMs and 4K Assembler ROM |
| A65-0550 | AIM 65 Microcomputer System with 4K RAM, 8K FORTH ROMs and 4K PROM/ROM capacity |
| Order No. | Description |
| 209 | AIM 65 Microcomputer User's Guide ${ }^{(1)}$ |
| 209 L | AIM 65 Monitor Listing ${ }^{(1)}$ |
| 217 | AIM 65 Reference Card ${ }^{(1)}$ |
| 200 | R6500 Programming Reference Card ${ }^{(1)}$ |
| 201 | R6500 Hardware Manual ${ }^{(1)}$ |
| 202 | R6500 Programming Manual ${ }^{(1)}$ |
| 221 | AIM 65 BASIC Language Reference Manual ${ }^{(2)}$ |
| 233 | AIM 65 BASIC Reference Card ${ }^{(2)}$ |
| 265 | AIM 65 FORTH User's Manual ${ }^{(3)}$ |
| 283 | AIM 65 FORTH Reference Card ${ }^{(3)}$ |
| Notes: |  |
| 1. Included with all models. |  |
| 2. Included with A65-0515 and A65-0520. |  |
| 3. Include | A65-0550. |

AIM 65 Microcomputer System

## SPECIFICATIONS

| Characteristics | Values |
| :---: | :---: |
| Dimensions |  |
| Width | $13.0 \mathrm{in}.(330 \mathrm{~mm})$ |
| Depth | 15.5 in. ( 395 mm ) |
| Height | 3.9 in . ( 100 mm ) |
| Weight | $11 \mathrm{lb} .(5 \mathrm{~kg})$ |
| Environment |  |
| Operating Temperature | $0^{\circ}$ to $50^{\circ} \mathrm{C}$ |
| Storage Temperature | $0^{\circ}$ to $70^{\circ} \mathrm{C}$ |
| Relative Humidity | 0\% to 85\% (without condensation) |
| Power |  |
| Input voltage | $115 \mathrm{Vac} \pm 10 \%, 47-63 \mathrm{~Hz}^{(1)}$ |
| Fuse | $115 \mathrm{Vac}, 1 \mathrm{~A}$ |
| Power cord | 6 f., 3-conductor cord (125 VAC, 13A rating) with molded vinyl grounding plug (NEMA 5-15P) Class B |
| Power supply output | 5 VDC (3.0A max.) |
|  | 24 VDC ( 0.5 ave., 2.5 A peak) |
| Interface Connector ${ }^{(2)}$ |  |
| $J 1$ (Application) and | 44-pin edge connector ( 0.156 in. centers) |
| J3 (Expansion) | Mates with Viking 2VH22/1AND5 or equivalent |
| Notes: |  |
| 1. Power supply transformer input connections can be changed for $230 \mathrm{Vac} \pm 10 \%$ input voltage. |  |
|  |  |

## A65-002, A65-006 AIM 65 MICROCOMPUTER ENCLOSURE

## PRODUCT OVERVIEW

The AIM 65 Microcomputer Enclosure is an attractive, professional housing for the Rockwell AIM 65 Microcomputer. Featuring low-profile stylistic design, fine-textured, non-reflective finish and handsome brown color, the enclosure makes the AIM 65 Microcomputer a pleasing addition to the office, laboratory, classroom and light industrial environment. The $13 \times 15.5 \times$ 3.9 inches enclosure occupies minimal desk-top space.

The enclosure consists of a sturdy aluminum base and a durable injection-molded top cover. The base includes mounting provisions for the power supply, line cord, power switch and circuit breaker. The cover is UL approved flame-retardant ABS material with metal threaded inserts for firm attachment to the base.

Offered with or without an internal power supply, the enclosure comes with a rocker-type power on/off switch, a pushbutton reset switch, a 6 -foot, 115 Vac line cord with 3 -prong plug, a fuse holder and fuse, and internal wiring for easy assembly to the AIM 65 Microcomputer.

The filtered power supply provides +5 V (regulated) at 3 A and +24 V (regulated) at .5 A (average) $/ 2.5 \mathrm{~A}$ (peak). Prewired DC power lines terminated with lugs connect directly to the AIM 65 Microcomputer power terminal strip. The AIM 65 Microcomputer system passes the FCC Class B radio frequency interference requirements for personal computers when used with the A65006 Enclosure and power supply.

An external paper holder and paper feed guide allows easy printer paper replacement without top cover removal. A clear plastic tear bar with a straight knife edge is permanently attached to the top cover for convenient paper tear-off. Rear openings permit access to the application and expansion connectors. A remote Reset switch installed on the top cover is pre-wired to slip-on terminals to mate with external Reset switch posts on the AIM 65 Master Module. Removeable plugs allow access to the RUN/STEP and TTY/KB switches on the AIM 65 Master Module.

## FEATURES

- Attractive, low-profile styling
- Compact and Portable
- Sturdy aluminum base with integral accessory mounting brackets
- Durable injection-molded ABS top cover
-Access holes to Application and Expansion connectors
-External RESET push-button switch
-Pluggable access holes to STEP/RUN and TTY/KB switches
-Clear plastic printer paper tear bar
- All necessary accessories
-Rocker-style power on/off switch
-Fuse holder
- Line Cord
-All assembly hardware included
- Optional $+5 \mathrm{~V}+24 \mathrm{~V}$ internal power supply operates from 115/ 230Vac @ $50 / 60 \mathrm{~Hz}$



## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| A65-002 | AIM 65 Enclosure (without Power Supply) |
| A65-006 | AIM 65 Enclosure and Power Supply |

## SPECIFICATIONS

| Characteristic | Value | Characteristic | Value |
| :---: | :---: | :---: | :---: |
| Dimensions Depth Width Height | 12.9 in ( 328 mm ) 15.5 in ( 394 mm ) $3 / 8.9$ in ( 99 mm ) | Accessories (cont.) Power Cord Type Plug | 3-wire/18-gauge US 3-prong (NEMA 5-15P) |
| Weight without Power Supply with Power Supply Shipping Weight without Power Supply with Power Supply | $\begin{gathered} 5 \mathrm{lb} .0 \text { oz. }(2.24 \mathrm{~kg}) \\ 9 \mathrm{lb} .6 \mathrm{oz} \cdot(4.20 \mathrm{~kg}) \\ 6 \mathrm{lb} .8 \text { oz. }(2.9 \mathrm{~kg}) \\ 10 \mathrm{lb} .14 \mathrm{oz} .(4.87 \mathrm{~kg}) \end{gathered}$ | Length Rating | $\begin{aligned} & 6 \text { feet } \\ & 125 \mathrm{~V} / 13 \mathrm{~A} \end{aligned}$ |
|  |  | Power Supply AC Input | $\begin{aligned} & 115 / 230 \mathrm{Vac} \pm 10 \%, \\ & 47-63 \mathrm{~Hz} \end{aligned}$ <br> (Derate output current |
| Construction Base Material Mounting Brackets | Sheet Aluminum with Chem-film finish Integral | DC Output 1 Voltage | Adjustable $+5 \mathrm{Vdc} \pm 5 \%$ (regulated) |
| Cover |  | Current | 3.0A |
| Material | Flame-retardant ABS plastic | Overvolage Prolection | 2 |
| Forming | Injection Molded | DC Output 2 |  |
| Color | Dark Brown | Voltage | Adjustable +24 Vdc (regulated) |
| Finish | Non-Reflective, fine textured | Current | 0.54 (average)/2.5A (peak) |
| Accessories Fuse | $\begin{aligned} & 115 \text { Vac @ 1A } \\ & 230 \text { Vac @ 0.5A } \\ & \text { Rocker-style } \\ & \text { Square Push-button } \end{aligned}$ | Short Circuit Protection | Automatic current limitfoldback |
|  |  | Temperature Rating | $0^{\circ}$ to $50^{\circ} \mathrm{C}$ full rated output (Derated linearly) to $40 \% @ 70^{\circ} \mathrm{C}$ |
| Reset Switch |  | UL Recognized |  |

## A65-003 <br> AIM 65 SERVICE TEST BOARD

## DESCRIPTION

The AIM 65 Service Test Board, in conjunction with the AIM 65 Microcomputer and AIM 65 Debug Monitor ROMs, performs a complete functional test of the microcomputer. This test board provides a convenient way to test the AIM 65 microcomputer either after repair or during periodic inspection and preventative maintenance. The module connects directly to the AIM 65 Microcomputer Application and Expansion connectors. Power is supplied from the AIM 65 Microcomputer eliminating additional power connection requirements.

The ROM-based test program can be initiated immediately after microcomputer power turn-on. Menu type command prompts simplify test selection. Five separate commands allow test level selection appropriate to the test objective. ALL TESTS selection performs nine separate tests consecutively to check all microcomputer circuits as well as the application and expansion interfaces. Once initiated, operation is automatic with operator response required only to type keys to test the keyboard and to advance testing after printer adjustment. SINGLE TEST mode allows a specific test to be performed-this is especially useful when testing a particular device or circuit. CONTINUOUS TEST performs a repetitive test of the microcomputer without operator intervention-thus supporting burn-in operation and test after component replacement. R6532 and 2114 RAM can be selectively checked with the R6532 RAM and 2114 RAM tests, respectively.

Test commands and results are displayed and printed. The printout provides hardcopy test results for easy inclusion in equipment maintenance records. Adjustment of potentiometers controlling printer speed, printer dot intensity and audio tape circuit gain enables proper and consistent settings. An LED provides visual indication of proper audio circuit gain adjustment. Mechanical adjustment of printer gear alignment is also supported.

## FEATURES

- Performs complete functional test
- No external equipment required
- Provides hardcopy test results
- ROM-based 4 K -byte test program for immediate operation
- Performs five tests upon command
-ALL TESTS
-SINGLE TEST
-CONTINUOUS TEST
—R6532 RAM TEST
-2114 RAM TEST
- Tests nine separate functions in ALL TEST mode or upon SINGLE TEST command
-Chip select logic
-ROM checksum
—R6532 and 2114 RAM
- User R6522 VIA
—System R6522 VIA
—Display
-Printer
—Switch
—Keyboard
- Isolates most failures to component level
- Supports calibration of variable adjustments
-Audio tape circuit gain
—Printer speed
—Print intensity
-Printer dot alignment
- Audio tape circuit gain adjustment LED indicator
- Easy installation-connects directly to AIM 65 Application and Expansion connectors
- No external power required


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| A65-003 | AIM 65 Service Test Board |
| Order No. | Description |
| 2117 | AIM 65 Self-Test Module User's Manual <br> (Included with A65-003) |



A65-003 AIM 65 Service Test Module

## A65-004-03 <br> AIM 65 POWER SUPPLY AND CABLE

## DESCRIPTION

The AIM 65 Power Supply and Cable is a compact open frame DC power supply with output cable for connection to an AIM 65 Microcomputer. The power supply fits compactly inside the AIM 65 Enclosure (A65-002) to provide a complete table top microcomputer system. The $+5 \mathrm{~V} / 3 \mathrm{~A}$ output provides plenty of power for full on-board PROM/ROM and RAM expansion. The $+24 \mathrm{~V} / 1.5 \mathrm{~A}$ output supplies power for the AIM 65 microcomputer printer.

Slip-on terminals on the AC input terminal strip simplify connection to a wide range of input power: 110/1.15/215/230 Vac at $47-63 \mathrm{~Hz}$. The 3 -wire DC output cable, factory connected to the power supply output terminals, can be readily connected to the AIM 65 input power terminals.

Both outputs are current limited to prevent damage to the power supply if the outputs are overloaded or accidentally shorted together. Full power is provided from $0^{\circ}$ to $50^{\circ} \mathrm{C}$.

## FEATURES

- Dual AC input voltage
-110 or 115 Vac @ 47-63 Hz or
-215 or 230 Vac@ 47-63 Hz
- Two DC output voltages
-+5 V for AIM 65 Microcomputer logic
-+24 V for AlM 65 Microcomputer printer
- Slip-on input connection
- Compact size - fits in AIM 65 Enclosure
- Meets FCC Class B RFI requirements for personal computers when connected to the AIM 65 Microcomputer
- DC output cable included


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| A65-004-03 | Power Supply and Cable |



A65-004-03 Power Supply

## SPECIFICATIONS

| Parameter | Value | Parameter | Value |
| :---: | :---: | :---: | :---: |
| AC Input | 115/230 Vac $\pm 10 \%, 47-63 \mathrm{~Hz}$ | Dimensions |  |
|  | (Derate output current $10 \%$ for 50 | A | $6.31 \mathrm{in} .(160.3 \mathrm{~mm})$ |
|  | Hz operation) | B | $4.50 \mathrm{in} .(114.3 \mathrm{~mm})$ |
|  |  | C | $3.78 \mathrm{in} .(96.0 \mathrm{~mm})$ |
| DC Output 1 |  | D | $1.62 \mathrm{in} .(41.3 \mathrm{~mm})$ |
| Voltage | Adjustable $+5 \mathrm{Vdc} \pm 5 \%$ (regulated) | E | 0.45 in . $(11.4 \mathrm{~mm}$ ) |
| Current | 3.0A | F | $1.10 \mathrm{in} .(27.9 \mathrm{~mm})$ |
| Overvoltage Protection | $6.2 \pm 0.4 \mathrm{Vdc}$ | G | $2.12 \mathrm{in} .(53.8 \mathrm{~mm})$ |
|  |  | H | 0.95 in. (24.1 mm) |
| DC Output 2 |  | 1 | $1.24 \mathrm{in} .(31.5 \mathrm{~mm})$ |
| Voltage | Adjustable +24 Vdc (regulated) | J | 3.62 in . (91.9 mm) |
| Current | 0.5A (average)/2.5A (peak) | K | 1.20 in ( 30.5 mm ) |
|  |  | L | 8-32 THD (3) |
| Short Circuit Protection | Automatic current limit/foldback | Output Cable |  |
| Temperature Rating | $0^{\circ} \mathrm{C}$ to $50^{\circ} \mathrm{C}$ full rated output (Derated | Type | 3-wire jacketed with internal balun |
|  | linearly to $40 \%$ @ $70^{\circ} \mathrm{C}$ ) | Load Termination Routed Outputs | Spade lugs $+5 \mathrm{~V},+24 \mathrm{~V} \text { and } \mathrm{COM}$ |



AC INPUT TERMINAL DC OUTPUT TERMINAL*


## A65-010 AIM 65 ASSEMBLER ROM

## ASSEMBLY LANGUAGE

An assembler translates microprocessor instructions and data statements written in symbolic form (the source program) into machine executable code (the object program). The AIM 65 Assembler translates one instruction, consisting of a label (if required), a mnemonic operation code, an qperand (if required) and arithmetic operator (if required) into a machine instruction consisting of from one to three bytes of memory. Constants comprising one or more bytes of memory are generated from data statements while one or more bytes of memory are assigned to variables. The assembler operates in two passes. Pass 1 checks for syntax errors and assigns values to symbols in a symbol table. Pass 2 generates the actual machine code and outputs the assembly listing which lists the source code and the corresponding machine code.

The source code is usually entered using the AIM 65 Text Editor then assembled to generate the machine code for program execution and debugging. Program changes to the source program can easily be edited then the program reassembled to generate the new machine code thus eliminating the need for the programmer to code and recode the program in machine code-a time consuming and laborious process.

## PRODUCT OVERVIEW

The AIM 65 Assembler is a 4 K -byte ROM-resident, two-pass symbolic assembler that plugs into socket Z24 on the AIM 65 Microcomputer Master Module and operates in conjunction with the AIM 65 Debug Monitor/Text Editor ROMs. The assembler translates computer program instructions written in standard assembly language for the 6502 microprocessor into machine code that will operate in any 6502 or 65XX CPU. Operating options are selected interactively by the operator upon assembly command. These options specify source code device, object code device, symbol table location, full assembly or errors only output listing and output listing device. Memory to memory assembly is supported for rapid program generation. Compatibility with the RM 65 Floppy Disc Controller (FDC) module (RM65-5101NE) and AIM 65 DOS 1.0 ROM (A65-090) allows source code to be input from one or more files on floppy disk and object code to be output to a floppy disk file to assemble very large programs and to permanently save source and object code.

## FEATURES

- AIM 65 Microcomputer host
- 6502 machine code generation
- ROM-resident for immediate operation
- Symbolic linkage-operands and labels
- Interactive assembler operation setup
- Operator selected input device
-Memory (text buffer)
-Audio tape
—TTY
-User defined
- Operator selected object code output device
-Memory (RAM)
-Audio tape
-TTY
—Display/printer
-Printer
-User-defined
- Operator selected assembly/error listing output device
—Display/printer
—Printer
—User-defined
- Assembler directives
- AIM 65 DOS 1.0 compatible


## MEMORY MAP

| Address (Hex) | Contents |
| :---: | :---: |
| \$D000-\$DFFF | Assembler Program |
| \$0-\$AC | Assembler Variables |

## ORDERING INFORMATION

| Part No. | Description |
| :---: | :---: |
| A65-010 | AIM 65 Assembler ROM |
| Order No. | Description |
| 209 | AIM 65 User's Guide <br> (includes AIM 65 Assembler <br> User's Instructions) |

## R6502 CPU INSTRUCTIONS

| Mnemonic | Instruction | Mnemonic | Instruction |
| :---: | :---: | :---: | :---: |
| ADC | Add Memory to Accumulator with Carry | LDA | Load Accumulator with Memory |
| AND | AND Memory with Accumulator | LDX | Load Index X with Memory |
| ASL. | Shift Left One Bit (Memory or Accurnulator) | LDY | Load Index $Y$ with Memory |
| BCC | Branch on Carry Clear | LSR | Shitt Right One Bit (Memory or Accumulator) |
| BCS | Branch on Carry Set | NOP | No Operation |
| BEQ | Branch on Result Zero | ORA | OR Memory with Accumulator |
| BIT | Test Bits in Memory with Accumulator |  | On Memory with Accumulat |
| BMI | Branch on Result Minus | PHA | Push Accumulator on Stack |
| BNE | Branch on Result Not Zero | PHP | Push Processor Status on Stack |
| BPL | Branch on Result Plus | PLA | Pull Accumulator from Stack |
| BRK | Force Break | PLP | Pull Processor Status from Stack |
| BVC | Branch on Overflow Clear | ROL | Rotate One Bit Left (Memory or Accumulator) |
| BVS | Branch on Overflow Set | ROR | Rotate One Bit Right (Memory or Accumulator) |
| CLC | Clear Carry Flag | RTI | Return from Interrupt |
| CLD | Clear Decimal Mode | RTS | Return from Subroutine |
| CLI | Clear Interrupt Disable Bit | SBC | Subtract Memory from Accumulator with Borrow |
| CLV | Clear Overflow Flag | SEC | Set Carry Flag |
| CMP | Compare Memory and Accumulator | SED | Set Decimal Mode |
| CPX | Compare Memory and Index $X$ | SEI | Set Interrupt Disable Status |
| CPY | Compare Memory and Index $Y$ | STA | Store Accumulator in Memory |
| DEC | Decrement Memory by One | STX | Store Index $\mathbf{X}$ in Memory |
| DEX | Decrement Index $X$ by One | STY | Store Index Y in Memory |
| DEY | Decrement Index Y by One | TAX | Transfer Accumulator to Index $X$ |
| EOR | Exclusive-OR Mernory with Accumulator | TAY | Transfer Accumulator to Index $Y$ |
| INC | Increment Memory by One | TSX | Transfer Stack Pointer to Index $X$ |
| INX | Increment Index $X$ by One | TXA | Transter Index $X$ to Accumulator |
| INY | Increment Index $Y$ by One | TYA | Transter Index $X$ to Stack Pointer Transfer Index $Y$ to Accumulator |
| $\begin{aligned} & \text { JMP } \\ & \text { JSR } \end{aligned}$ | Jump to New Location Jump to New Location Saving Return Address |  |  |

## AIM 65 ASSEMBLER DIRECTIVES

| Command | Function | Command |
| :--- | :--- | :--- |
| F | Equate | Function |
| .BYTE | Byte constant | LIS/NOL |

# A65-020 <br> AIM 65 BASIC INTERPRETER ROMS 

## BASIC LANGUAGE

BASIC is a simple but powerful computer program language. Originally developed at Dartmouth University, BASIC has gained universal acceptance and is commonly used world-wide in schools, industry, and science.

The heart of BASIC is a set of easily learned English words which are used as commands. Complex and powerful statements can be constructed by adding operands and operators to the commands. Equations involving complex formulas and multiple variables can easily be solved. Internal floating point arithmetic handles a wide range of numeric values ( $2.93873588 \mathrm{E}-39$ to $1.70141183 \mathrm{E}+38$ ) and provides nine-digit accuracy to most calculations. In addition to addition, subtraction, multiplication and division, a full set of transcendental functions support trigonometric, exponential, square, square root, polynomial and logarithmic operations.

## PRODUCT OVERVIEW

The AIM 65 BASIC Interpreter, consisting of input formatter, lister, floating point functions, interpreter and input/output functions, is contained in two 4 K -byte ROMs that plug into sockets Z25 and Z26 on the AIM 65 Microcomputer Master Module. AIM 65 BASIC operates in one of two modes, development and runtime. In the development mode, BASIC statements are entered and executed as either direct or indirect commands. Direct commands are executed upon entry to provide immediate results, however, the statements are not stored for subsequent execution. Indirect commands are entered along with an associated line number and are executed upon RUN command entry. The AIM 65 microcomputer peripherals, i.e., the keyboard, 20 -character single line display and 20 column printer, are used in the development mode to enter statements, to list entered indirect statements and to display/print execution results. The AIM 65 Debug Monitor/Text Editor ROMs must be resident in both the run-time and the development mode.

In the run-time mode, BASIC begins execution of the application program (i.e., previously entered indirect statements) without entering the BASIC command level. A short user-provided driver program initializes BASIC upon entry from the AIM 65 Monitor command level via key depression or execution command (or upon power turn-on or RESET if the RESET vector points to the application program).

The AIM 65 BASIC Interpreter ROMs, when installed in the AIM 65 Microcomputer, support development and checkout of an application program written in BASIC that is to be installed in an RM 65 Single Board Computer (SBC) module for run-time operation. The developed program, located in PROM or loaded from mass storage, will run with RM 65 Run-Time BASIC ROM
installed in the RM 65 SBC module. In this configuration, all RM 65 input/output operations must be user-provided and can be tested using the AIM 65 Microcomputer prior to being installed in the RM 65 environment.

## LANGUAGE FEATURES

- BASIC is easy to learn
- Microsoft BASIC is universally accepted
- BASIC is widely used
- Supports simple and complex statements
- Floating point arithmetic functions
-Add, subtract, multiply, divide
-Trigonometric (sine, cosine, tangent, arctangent)
-Exponential, square, square root
—Natural logarithm
- String variables and arrays
- Integer variables
- Subroutine calls
- Conditional expressions
- User function


## INTERPRETER FEATURES

- AIM 65 Microcomputer host
- ROM resident for immediate operation
- Operates in development and run-time modes
- Fast execution (reference Microsoft 6502 BASIC interpretation)
- Develops programs for execution in AIM 65 Microcomputer with AIM 65 BASIC installed or in RM 65 Single Board Computer (SBC) module based system with RM 65 Run-Time BASIC installed
- Executes application program from RAM or PROM


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :--- |
| A65-020 | AIM 65 BASIC ROMs |
| RM65-0122 | RM 65 Run-Time BASIC ROM |
| Order No. | Description |
| 221 | AIM 65 BASIC Language Reference Manual(1) |
| 233 | AIM 65 BASIC Reference Card(1) |
| 810 | RM 65 Run-Time BASIC User's Manual(2) |
| Notes: |  |
| 1. Included with A65-020. |  |
| 2. Included with RM65-0122. |  |

MEMORY MAP

| Address (Hex) | Contents |
| :--- | :---: |
| $\$ B 000-\$ C F F F$ | AIM 65 BASIC Program |
| $\$ 200-\$ 20 F$ | AIM 65 BASIC Variables |
| $\$ 0-\$ D 6$ | AIM 65 BASIC Variables |

## PROM PROGRAMMING

The application program is easily programmed into a PROM for operation in an OEM or end-user environment using the AIM 65 Microcomputer connected to either an RM 66 PROM Programmer module (RM65-2901E) or an AIM 65 PROM Programmer and CO-ED Module (A65-901).

## BASIC STATEMENTS



## A65-024 <br> AIM 65 BASIC COMPILER

## BASIC LANGUAGE

BASIC is a simple but powerful computer program language. Originally developed at Dartmouth University, BASIC has gained universal acceptance and is commonly used world-wide in schools, industry, and science.

The heart of BASIC is a set of easily learned English words which are used as commands. Complex and powerful statements can be constructed by adding operands and operators to the commands. Equations involving complex formulas and multiple variables can easily be solved. Internal floating point arithmetic handles a wide range of numeric values ( $2.93873588 \mathrm{E}-39$ to $1.70141183 \mathrm{E}+38$ ) and provides nine-digit accuracy to most calculations. In addition to addition, subtraction, multiplication and division, a full set of transcendental functions support trigonometric, exponential, square, square root, polynomial and logarithmic operations.

## PRODUCT OVERVIEW

The AIM 65 BASIC Compiler, consisting of the BASIC compiler and BASIC run-time library, is contained on an AIM 65 diskette. The BASIC Compiler, in conjunction with the BASIC run-time library, compiles a program written in the BASIC language into a 6500 assembly language source file and an optimized runtime library file. The BASIC source code file is made up of indirect BASIC commands and statements. The two output files, assembly source file and optimized run-time file, are then assembled using the AIM 65 Assembler to create a BASIC object code file for execution.

The AIM 65 Text Editor can be used to create and edit the application program source code. The AIM 65 peripherals, i.e., keyboard, 20-character single-line display and 20 -column printer, are used to enter and list BASIC statements and to display/print execution results.

The disk-based compiler operates on the AIM 65 Microcomputer in conjunction with the RM65 Floppy Disk Controller (FDC) module and the AIM 65 DOS 1.0. The AIM 65 Assembler (Part No. A65-010) is required to support the BASIC Compiler on the AIM 65 Microcomputer.

## LANGUAGE FEATURES

- BASIC is easy to learn
- Microsoft BASIC is universally accepted
- BASIC is widely used
- Supports simple and complex statements
- Floating point arithmetic functions
-Add, subtract, multiply, divide
-Trigonometric (sine, cosine, tangent, arctangent)
- Exponential, square, square root
—Natural logarithm
- String variables and arrays
- Integer variables
- Subroutine calls
- Conditional expressions
- User function


## COMPILER FEATURES

- Aim 65 Microcomputer host
- Generates standalone object code
- Compiles to 6500 assembly language easing optimization
- Fast execution
- Develops programs for execution in AIM 65 Microcomputer without AIM 65 BASIC installed or in RM 65 Single Board Computer (SBC) module based system without RM 65 RunTime BASIC installed
- Executes application program from RAM or PROM


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| A65-024 | AIM 65 BASIC Compiler |
| Order No. | Description |
| 2159 | AIM 65 BASIC Compiler User's Manual ${ }^{(1)}$ |
| 233 | AIM 65 BASIC Reference Card ${ }^{(1)}$ |
| Note: <br> 1. Included with A65-024. |  |

## MEMORY MAP

| Address (Hex) | Contents |
| :--- | :---: |
| $\$ 1000-\$ 3 C 00$ | AIM 65 BASIC Compiler |
| $\$ 0-\$ F F$ | AIM 65 BASIC Variables |

## PROM PROGRAMMING

The application program is easily programmed into a PROM for operation in an OEM or end-user environment using the AIM 65 Microcomputer connected to either an RM 65 PROM Programmer module (RM65-2901E) or an AIM. 65 PROM Programmer and CO-ED Module (A65-901).

## BASIC STATEMENTS



## A65-030 <br> AIM 65 PL/65 COMPILER ROMS

## PL/65 LANGUAGE

PL/65 is a high level language developed for the R6500 family of microprocessors. Resembling PL/I and Algol in general form, PL/65 combines high level language attributes with the power and flexibility of assembly language for efficient generation of time-critical and system implementation software. High level constructs speed program development and eliminate machine coding errors by the use of compiler generated algorithms. All language features are aimed at improving the productivity of the systems programmer by simplifying the writing of computer programs normally written in assembly language.

## PRODUCT OVERVIEW

The AIM 65 PL/65 Compiler is contained in two 4K-byte ROMs that plug into sockets Z25 and Z26 on the AIM 65 Microcomputer Master Module. The compiler operates in conjunction with the AIM 65 Debug Monitor/Text Editor ROMs. Source code written in PL/65 is compiled into assembly language instructions rather than 6502 CPU machine code to allow program enhancement at the assembly level, if needed, and to avoid symbol manipulation in the compiler. Drop down capability allows assembly language to be incorporated in-line in the source code, however. The generated assembly language may then be assembled on the AIM 65 Microcomputer using the AIM 65 Assembler ROM.

Compatibility with the RM 65 Floppy Disk Controller (FDC) module and AIM 65 DOS 1.0 firmware allows efficient mass storage and file handling of source code written in PL/65, the PL/65 compiler generated assembly language and the assembled machine code-especially for large programs. The compiler inputs source code from the AIM 65 Text Editor, audio tape, TTY or user-defined devices and outputs assembly code to display/printer, memory, audio tape, TTY or user defined devices. The floppy disk interface is implemented through the user-defined functions via DOS 1.0 firmware.

PL/65 compilers have also been implemented on the AIM 65/40 Microcomputer and the System 65 Development system to allow programs written in PL/65 to be transported between these systems. AIM 65 and AIM 65/40 PL/65 is a subset of the System 65 PL/65.

## FEATURES

- AIM 65 Microcomputer host and target
- ROM resident for immediate operation
- Resembles PLII and Algol
- Increases program productivity and efficiency
- Improves program reliability
- Reduces programming errors
- Drops down to assembly language by block or single instruction for optimal code efficiency
- Includes control structures for conditional branching and iterative looping
- Supports structured programming and self-documentation
- Encourages modular program design
- Compatible with RM 65 FDC module and AIM 65 DOS 1.0.


## MEMORY MAP

| Address (Hex) | Contents |
| :--- | :--- |
| $\$$ B000-\$CFFF | PL/65 Compiler Program |
| $\$ 0200-\$ 049 F$ | PL/65 Compiler Variables (Compilation Only) |
| $\$ 0-\$ 4$ | PL/65 Compiler Variables (Compilation and <br> Runtime) |

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| A65-030 | AIM 65 PL/65 Compiler ROMs |
| A65-010 | AIM 65 Assembler ROM ${ }^{(2)}$ |
| Order No. | Description |
| 257 | AIM 65 PL65 Compiler User's Manual(1) |
| NOTES: <br> 1. Included with A65-030. <br> 2. User's instructions included in AIM 65 User's Guide <br> (Order No. 209). |  |

## PL/65 LANGUAGE STATEMENTS

| Specification | Block | Imperative |
| :---: | :---: | :---: |
| ENTRY | BEGIN | SHIFT |
| EXIT | DO | ROTATE |
| TFILE | ASSEMBLY CODE |  |
| DFILE | INC |  |
| Conditional Execution | Declaration | INCW |
| IF-THEN-ELSE | DECLARE | DEC |
|  | DEFINE | DECW |
| Branching | DATA | UTACK |
| GOTO | Ussignment |  |
| CALL | Direct Single Byte Move |  |
| RETURN | Indirect Single Byte Move | Looping |
| RTI | Direct Multiple Byte Move | FOR-TO-BY |
| BREAK |  | WHILE |
| HALT |  | Miscellaneous |
|  |  | Comment |
|  |  | Tab |

## A65-040 <br> AIM 65 MATH PACKAGE ROM

## FLOATING POINT ARITHMETIC

Floating point arithmetic is often desired to perform mathematical operations in calculation intensive applications such as scientific computation, industrial data acquisition and reduction, process control, and laboratory measurements. In the AIM 65 Math Package, a number is represented in floating point form as an unsigned exponent, a normalized mantissa and an arithmetic sign. The magnitude of the number is equal to two raised to the exponent power times the fractional mantissa, where the exponent may range from -127 to +127 . The mantissa is a $32-$ bit number normalized such that the most significant bit (MSB) is always equal to " 1 ". Operating on floating point numbers alleviates programming difficulty and additional development time usually associated with fixed point scaling and minimizes uncertainties when performing calculations involving both very large and very small numbers. Numbers in magnitude from $2.93873588 \mathrm{E}-39$ to $1.70141183 \mathrm{E}+38$ can be handled in the AIM 65 Math Package. In addition, nine digit accuracy is provided in most calculations.

## PRODUCT OVERVIEW

The AIM 65 Math Package contains a full complement of floating point arithmetic, conversion, trigonometric, utility and other transcendental functions as user callable subroutines in a 4 K -byte ROM. Programmed in 6502 machine language for fast execution, these functions support calculation intensive applications. These functions are host computer independent and may be installed in any 6502 CPU based microcomputer supporting the memory map requirements. The math package is located at \$D000-SDFFF to allow direct installation in an AIM 65 Microcomputer, an RM 65 Single Board Computer (SBC) module or in an RM 65 PROM/ROM module.

In addition to the machine language interface, direct linkage to AIM 65 FORTH and RM 65 Run-Time FORTH provides floating point processing in the FORTH language. When installed in an AIM 65 Microcomputer with AIM 65 FORTH also installed, the floating point words can be automatically linked to the FORTH vocabulary during FORTH initialization. Application programs written in FORTH can thus be both developed and executed on the AIM 65 Microcomputer. For OEM or end user installation in an RM 65 system with user-provided input/output functions, such programs can be developed on an AIM 65 Microcomputer then transferred to an RM 65 SBC based system with RM 65 Run-Time FORTH installed for execution in the RM 65 environment.

## FEATURES

- Floating point arithmetic
-Addition and subtraction
-Multiplication and division
- Integer arithmetic
-Multiplication
-Division
- Comparison ( $<,=,>$ )
- Trigonometric
-Sine and cosine
-Tangent and arctangent
- Conversion
-Degrees to radians
—Radians to degrees
- Polynomials
-Consecutive power
—Odd power
- Logarithmic
-Natural log
-Common log
- Square root, power, exponential
- Absolute value, integer and floating point sign, greatest integer
- 6502 CPU machine instruction linkage
- Host computer independent
- AIM 65 FORTH and RM 65 Run-time FORTH compatible
- 4K-byte ROM based
- Nine digit accuracy
- Wide range ( $2.93873588 \mathrm{E}-39$ to $1.70141183 \mathrm{E}+38$ )


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :--- |
| A65-040 | AIM 65 Math Package ROM |
| A65-050 | AIM 65 FORTH ROMs |
| RM65-0152 | RM 65 Run-Time FORTH ROMs |
| Order No. | Description |
| 2118 | AIM 65 Math Package User's Manual(1) |
| 265 | AIM 65 FORTH User's Manual(2) |
| 812 | RM 65 Run-Time FORTH User's Manual ${ }^{(3)}$ |
| Notes: |  |
| 1. Included with A65-040. |  |
| 2. Included with A65-050. |  |
| 3. Included with RM65-0152. |  |

## MEMORY MAP

| Address (Hex) | Contents |
| :--- | :--- |
| $\$ D 000-\$ D F F F$ | AIM 65 Math Package Program |
| $\$ A B-\$ C 4$ | AIM 65 Math Package Variables |
| $\$ 25 C-\$ 27 E$ | AIM 65 Math Package Variables |

## MATH PACKAGE FUNCTIONS

| Assembly <br> Language Label | FORTH Word | Function | Assembly <br> Language Label | FORTH Word | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INIT |  | Initialize Math Package | SIN | SIN | Sine |
| FADDT | F+ | Floating Point Add | COS | COS | Cosine |
| FADD |  | Floating Point Add (Memory) | TAN | TAN | Tangent |
| FSUBT | F- | Floating Point Subtract | ARCTAN | ARCTAN | Arc Tangent |
| FSUB |  | Floating Point Subtract (Memory) | DEGRE | DEGREES | Convert Radians to Degrees |
| FMULTT | $\mathrm{F}^{*}$ | Floating Point Multiply | RADS | RADIANS | Convert Degrees to Radians |
| FMULT |  | Floating Point Multiply (Memory) | POLYX | POLYODD | Odd Exponent Polynomial |
| FDIVT | F/ | Floating Point Divide | POLY | POLY | Consecutive Exponent Polynomial |
| FDIV |  | Floating Point Divide (Memory) | MOVFM | $M>F$ | Move Number from Memory to FAC |
| IMULT |  | Integer Multiply | MOVMF | $\mathrm{F}>\mathrm{M}$ | Move Number from FAC to Memory |
| IDIVID |  | Integer Divide | MOVFA |  | Move Number from ARG to FAC |
| FTOD |  | Convert Floating Point to Integer | MOVAF |  | Move Number from FAC to ARG |
| DTOF |  | Convert Integer to Floating Point | CONUPK | $M>A$ | Move Number from Memory to ARG |
| NEGFAC |  | Negate Floating Point Number |  | $S>A$ | Move Number from Stack to ARG |
| ABS | FABS | Absolute Value of Floating Point Number |  | $S>F$ $F>S$ | Move Number from Stack to FAC Move Number from FAC to Stack |
| INT | INT | Truncate Floating Point Number | FIN | FIN | Convert ASCll to Floating Point |
| SGN | SGN | Sign of FAC to FAC | FOUT | FOUT | Convert Floating Point to ASCII |
| SIGN | FSIGN | Sign of FAC to ARG | MINLN | MIN-WIDTH | FOUT Minimum Field Width Variable |
| FCOMP | FCOMP | Compare Floating Point Number | DECLN | DEC-LENGTH | FOUT No. of Places to the Right of the |
| SQR | SQR | Square Root |  |  | Decimal Point Variable |
| FPWRT | $\uparrow$ | Raise to a Power |  |  |  |
| EXP | EXP | Exponential |  |  |  |
| LOG10 | LOG | Common Log |  |  |  |
| LOG | LN | Natural Log |  |  |  |

## A65-050 <br> AIM 65 FORTH ROMS

## FORTH LANGUAGE

FORTH is a unique programming language well suited to a variety of applications. Because it was originally developed for real-time control applications, FORTH is ideal for machine and process control, energy managements, data acquisition, automatic testing, robotics and other applications where assembly language was previously the only possible language choice.

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. FORTH has a built in 6502 macro assembler, and lets you drop into assembly language at almost any point in your program, without perarate 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.

## FEATURES

- AIM 65 Microcomputer host and target
- ROM resident for immediate operation
- Application oriented
- Extensible language
- Over 200 pre-defined functions
- Interactive compilation
- Reverse polish notation
- Compact memory usage
- Fast execution
- Easy debugging
- Stack implementation
- 16-bit words
- Built-in structured macro assembler
- Shortens software development time


## PRODUCT OVERVIEW

AIM 65 FORTH, consisting of primitives, interpreter, macro assembler and input/output functions, is contained in two 4 K byte ROMs that plug into the AIM 65 Microcomputer Master Module sockets Z25 and Z26. FORTH functions are linked to AIM 65 Debug Monitor and Text Editor ROMs providing access to the AIM 65 peripherals (keyboard, single-line display and 20 column printer) as well as user-defined input/output functions. Both interactive and batch modes of operation are supported. Interactive operation interprets FORTH words upon entry for immediate execution and debugging or for compilation. In the batch mode, FORTH words can be entered into the Text Buffer then input to FORTH for interpretation. The batch mode allows an application program to be easily edited using Text Editor commands. Application programs written in FORTH can thus be developed, as well as executed for checkout or production operation, on the AIM 65 Microcomputer.

AIM 65 FORTH ROMs, when installed in an AIM 65 Microcomputer, can also be used to develop and checkout an application program written in FORTH that is to be installed in an RM 65 Single Board Computer (SBC) module for runtime operation. The developed program will run with RM 65 Run-Time FORTH ROMs installed in the RM 65 SBC module. In this configuration, all RM 65 input/output operations must be user-provided and can be tested using the AIM 65 Microcomputer as the host computer prior to being installed in the RM 65 environment.

## ORDERING INFORMATION

| Part No. | Description |
| :--- | :--- |
| A65-050 | AIM 65 FORTH ROMs |
| A65-040 | AIM 65 Math Package ROM |
| RM65-0152 | RM 65 Run-Time FORTH ROM |
| Order No. | Zescription |
| 265 | AIM 65 FORTH User's Manual ${ }^{(1)}$ |
| 283 | AIM 65 FORTH Reference Card ${ }^{(1,}$, 2) |
| 2118 | AIM 65 Math Package User's Manual ${ }^{(2)}$ |
| 812 | RM 65 Run-Time FORTH User's Manual ${ }^{(3)}$ |
| NOTES: |  |
| 1. Included with A65-050. |  |
| 2. Included with A65-040. |  |
| 3. Included with RM65-0152. |  |

## 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 features 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 (RPM), the notation that is used in Hewlett-Packard scientific calculators. Using a data stack is an extremely efficient way of passing variables 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/bottomup" 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 submodules. 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.

## FLOATING POINT FUNCTIONS

AIM 65 FORTH contains both a single- (16-bit) and double-(32-bit) precision integer arithmetic capability. In AIM 65 applications where floating point arithmetic is desired, the AIM 65 Math Package may be used in conjunction with the FORTH ROMs. These floating point functions may be called using FORTH words included in the math package ROM. When this ROM is installed in socket Z24 on the AIM 65 Microcomputer, the floating point math words can be automatically linked to the FORTH dictionary during FORTH initialization. The AIM 65 Math Package ROM can also be installed in either an RM 65 SBC or PROM/ROM module.

## MEMORY MAP

| Address (Hex) | Contents |
| :--- | :--- |
| $\$ D 000-\$ D F F F$ | Math Package Program |
| $\$ 3000-\$ C F F F$ | FORTH Program |
| $\$ 280-\$ 2 F F$ | Terminal Input Buffer |
| $\$ 25 C-\$ 27 F$ | Math Package Variables |
| $\$ 200-\$ 257$ | FORTH User Variables |
| $\$ A B-\$ C 4$ | Math Package Variables |
| $\$ 10-\$ A A$ | FORTH Variables |

## FORTH WORDS

STACK MANIPULATION

DUP
2DUP
DROP
2DROP
SWAP
OVER
ROT

- DUP
$>R$
R $>$
R
PICK
SP@
RP@
BOUNDS
.S


## DEFINING WORDS

| :<name> | Begin colon definition of <name>. |
| :---: | :---: |
| ; | End colon definition. |
| VARIABLE <namd> | Create a variable <name> with initial value n ; returns address when executed. |
| CONSTANT < name> | Create a constant <name> with value $n$; returns value when executed. |
| CODE <name> | Begin definition of assembly-language primitive operation <name>. |
| ;CODE | Used to create a new defining word, with execution-time "code routine" for this data type in assembly. |
| <BUILDS . . . DOES> | Used to create a new defining word, with execution-time routine for this data type in higher-level FORTH. |
| USER | Create a user variable. |

MEMORY
@
C@
Cl
?
$+!$
CMOVE
FILL
ERASE
BLANKS
TOGGLE
Duplicate top of stack.
Duplicate top two stack items.
Delete top of stack.
Delete top two stack items.
Exchange top two stack items.
Copy second item to top.
Rotate third item on top.
Duplicate only if non-zero
Move top item to return stack.
Retrieve item from return stack.
Copy top of return stack onto stack.
Copy the nth item to top.
Return address of stack position
Return address of return stack pointer.
Convert "address count" to "endaddress start-address."
Print contents of stack.

Begin colon definition of <name>. End colon definition. Create a variable <name> with initial value n ; returns address when executed.
n ; returns value when executed.
Begin definition of assembly-language primitive operation <name>. Used to create a new defining word, this data type in assembly. dit data type in higher-level FORTH.
Create a user variable.

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 n 3 bytes starting at address n 1 to area starting at address n2.
Put byte n3 into n 2 bytes starting at address n 1 .
Fill n2 bytes in memory with zeroes, beginning at address $n 1$.
Fill n2 bytes in memory with blanks, beginning at address n 1 .
Mask memory with bit pattern.

## NUMERIC REPRESENTATION

| DECIMAL | Set decimal base. |
| :--- | :--- |
| HEX | Set hexadecimal base. |
| BASE | Set number base. |
| DIGIT | Convert ASCII to binary. |
| 0 | The number zero. |
| 1 | The number one. |
| 2 | The number two. |
| 3 | The number three. |

## FORTH WORDS (CONT'D)

## ARITHMETIC AND LOGICAL

$\stackrel{+}{\mathrm{D}}+$
D+ Add double-precision numbers.
$-\quad$ Subtract ( $n 1$ - $n$ )
Multiply.
Divide ( $n 1 / n 2$ ).
Modulo (i.e., remainder from division).
MOD
/MOD
-/MOD
$\cdot /$
U.

U/
$\mathrm{M}^{*}$
M/
M/MOD

MAX
MIN
$+-$
ABS
DABS
NEGATE
DNEGATE
$S->D$
$1+$
$2+$
$1-$
$2-$
AND
OR
XOR
XOR
COMPARISON OPERATORS
$<$
$>$
$=$
$0<$
$0=$
$\mathrm{U}<$
NOT

## MISCELLANEOUS AND SYSTEM

| (<comment>) | Begin comment (terminate by right <br> parentheses on same line). |
| :--- | :--- |
| CFA | Alter PFA to CFA. |
| NFA | Alter PFA to NFA. |
| PFA | Alter NFA to PFA. |
| LFA | Alter PFA to LFA. |
| LIMIT | Top of memory. |
| QUIT | Clear return stack and return to |
|  | terminal. |

## CONTROL STRUCTURES

| DO . . . LOOP | Se |
| :---: | :---: |
| DO . . . +LOOP | Like DO . . . LOOP, but adds stack value to index. |
| 1 | Place current index value on stack. |
| LEAVE | Terminate loop at next LOOP or +LOOP. |
| BEGIN . . . UNTIL | Loop back to BEGIN until true at UNTIL. |
| BEGIN . . . WHILE <br> . . . REPEAT | Loop while true at WHILE, REPEAT loops unconditionally to BEGIN. |
| BEGIN . . AGAIN | Unconditional loop. |
| IF... THEN | If top of stack true, execute following clause THEN continue; otherwise continue at THEN. |
| IF . . ELSE . . . THEN | If top of stack true, execute ELSE clause THEN continue; otherwise execute following clause, THEN continue. |
| END | Alias for UNTIL. |
| ENDIF | Alias for THEN. |


| COMPILER-TEXT INTERPRETER |  |
| :--- | :--- |
| [COMPILE] | Force compilation of IMMEDIATE word. <br> Compile following <name> into <br> dictionary. |
| COMPILE | Compilie a number into a literal. <br> LITERAL |
| Comperile a double-precision number into |  |
| a literal. |  |
| EXECUTE | Execute the definition on top of stack. <br> Suspend compilation, enter execution. |
|  | Resume compilation. |

DICTIONARY CONTROL

CREATE
FORGE
HERE
allot
TASK

- FIND

DP
C,
PAD
IMMEDIATE
INTERPRET
LATEST
LIT
CLIT
LITERAL
SMUDGE
STATE

Create a dictionary header.
FORGET all definitions from <name> on.
Returns address of next unused byte in the dictionary
Leave a gap of $n$ bytes in the dictionary.
A dictionary marker.
Find the address of <name> in the dictionary.
Search dictionary for <name>.
User variable containing the dictionary pointer.
Store byte into dictionary.
Compile a number into the dictionary
Pointer to temporary buffer.
Force execution when compiling.
The Text Interpreter executes or compiles.
Leave name field address (NFA) of top word in CURRENT.
Place 16 -bit literal on the stack.
Place byte literal on the stack.
Compile a 16 -bit literal.
Toggle name SMUDGE bit.
User variable containing compilation state.


## FORTH WORDS (CONT'D)

| PRIMITIVES |  |
| :--- | :--- |
| OBRANCH | Run-time conditional branch. |
| BRANCH | Run-time unconditional branch. |
| ENCLOSE | Text scanning primitive used by wORD. |
| RO | Location of Return Stack. |
| SO | Location of Parameter Stack. |
| RP! | Initialize Return Stack. |
| SP! | nitialize Parameter Stack. |
| NEXT | The FORTH virtual machine. |
|  |  |
|  |  |
|  |  |

## MATH PACKAGE FORTH WORDS (A65-040)*

## FLOATING POINT ARITHMETIC

F+ Adds two floating point pumbers.
F- Subtracts one floating point number from another floating point number.
F* Multiplies two floating point numbers.
F/ Divides one floating point number by another floating point number.

## UTILITY, SIGN AND COMPARISONS

FABS | Takes the absolute value of a floating |
| :---: |
| point number. |
| Truncates a floating point number to an |
| integer. |
| Converts the sign of a floating point |
| number to a floating point number. |
| Gets a value corresponding to the sign |
| of a floating point number. |
| Compares the value of a compacted |
| number in memory to a floating point |
| number. |

FSIGN
POLYNOMIAL
POLY
POLYODD

EXPONENTIAL AND LOGARITHMIC
SQR Takes the square root of a floating point number.
$>\quad$ Raises one floating point number to the power of another floating point number.
EXP Raises the transcendental number e to the power of a floating point number.
LOG
Computes the logarithm to the base 10
(i.e., common log) of a floating point number.
LN
Computes the logarithm to the base e (i.e., natural log) of a floating point number.

| FLOATING POINT ARITHMETIC |  |
| :--- | :--- |
| F- | Adds two floating point pumbers. |
| F- | Subtracts one floating point number <br> from another floating point number. |
| F* $^{*}$ | Multiplies two floating point numbers. |
| F/ | Divides one floating point number by |
|  | another floating point number. |

*Requires AIM 65 FORTH or RM 65 FORTH be resident.

## SECURITY

!CSP
?COMP
?CSP
?ERROR
?EXEC
?PAIRS
?STACK
ABORT
ERROR
MESSAGE
WARNING
FENCE
WIDTH

Store stack position in check stack pointer.
Error if not compiling.
Check stack position.
Output error message.
Not executing error.
Conditional not paired error.
Stack out of bounds error.
Error; operation terminates.
Execute error notification and restart system.
Displays message.
Pointer to message routine.
Prevents forgetting below this point.
Controls significant characters of <name>.

## USER VARIABLE

MIN-WIDTH . Specifies the minimum field width to be output.
DEC-LENGTH
Specifies the number of places to the right of the decimal point to be output.

## ASCII/FLOATING POINT CONVERSIONS

FIN Converts a number in memory from ASCII to floating point format.
FOUT Converts a number from floating point to ASCII.

## FORMAT CONVERSION AND DATA MOVING

| $M>F$ | Unpacks the compacted number in <br> memory to floating point. <br> Packs the floating point number to <br> compacted format and stores the <br> result in memory. |
| :--- | :--- |
| F $>$ M | mems the floating point number in |
| memory. |  |
| Converts an integer to floating point |  |
| format. |  |
| Converts an integer to floating point |  |
| format. |  |

## TRIGONOMETRIC AND UNITS CONVERSION

Calculates the sine of a floating point number (in radians).
Calculates the cosine of a floating point number (in radians).
Calculates the tangent of a floating point number (in radians).
Calculates the arc tangent of a floating point number.
Converts a floating point number from radians to degrees.
Converts a floating point number from degrees to radians.

## A65-052 <br> AIM 65 FORTH TARGET COMPILER

## FORTH LANGUAGE

FORTH is a unique programming language well suited to a variety of applications. 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 input/output intensive applications where assembly language was previously considered to be the only possible language choice.

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. FORTH allows programmers 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.

## FORTH TARGET COMPILER

The FORTH Target Compiler generates object code from application programs written in FORTH. The object code is a compiled composite of the user's application vocabulary and those portions of the Target Compiler nucleus necessary to support the application vocabulary. The disk-based FORTH Target Compiler operates on the AIM 65 Microcomputer in conjunction with the AIM 65 FORTH Interpreter ROMs, the RM 65 Floppy Disk Controller (FDC) module and the AIM 65 DOS 1.0 firmware.

The compiled object code, located at a user-specified origin with optional auto-start vectors, will execute in any 6502 CPU-based microcomputer system supporting the runtime nucleus memory map requirements. Application programs can also be developed to run on AIM 65 or RM 65 SBC module-based systems with supporting RM 65 memory and input/output modules, e.g., Analog Input/Output, IEEE-488 Interface, and Multi-function Peripheral Interface Linkage to RM 65 Floppy Disk Controller, CRT Controller, and IEEE-488 module as well as the AIM 65 Math Package, firmware can also be included for expanded application systems.

## FEATURES

- Fully compatible with FORTH programs developed with AIM 65 or AIM 65/40 FORTH Interpreter ROMs
- Disk-based compiler operation with vocabulary overlays for
-Text Editing
-Disk Interfacing
-Serial Input/Output
-Compiling
-Special Utilities
- Easy compiler operation
-Load screen direction
-Compile tracing (mapping)
-Compiles to RAM and/or disk
- Includes 6502 Macro Assembler with
-Forward references
-Symbolic labels
-Relative branches
- Efficient object code generation
-ROMable object code
-Standalone operation
-Minimum runtime nucleus
-Optimized FORTH compiled vocabulary
-AIM 65 autostart capability
-User-specified origin
- Flexible target computer installation
-System independent (runs on any 6502 CPU-based system with minimal runtime memory map requirements)

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| AIM 65-052 | AIM 65 FORTH Target Compiler |
| AIM 65-050 | AIM 65 FORTH Interpreter ROMs ${ }^{(1)}$ |
| AIM 65-090 | AIM 65 DOS 1.0 ROM ${ }^{(1,2)}$ |
| AIM 65-040 | AIM 65/40 Math Package ROM ${ }^{(6)}$ |
| Order No. | Description |
| 2105 | AIM 65 and AIM 65/40 FORTH Target |
|  | Compiler User's Manual(3) |
| 265 | AIM 65 FORTH User's Manual(4) |
| 2118 | AIM 65 Math Package User's Manual(5) |
| Notes: |  |
| (1) Required for FORTH Target Compiler operation. |  |
| (2) Requires RM65-5101NE FDC module. |  |
| (3) Included with A65-052. |  |
| (4) Included with A65-050. |  |
| (5) Included with A65-040. |  |
| (6) Optional. |  |

## 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 the dictionary words to define each new word. Once the new word has been defined it is added to the system dictionary and 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.

FORTH is a stack-oriented language, and is programmed in Reverse Polish Notation (RPN), the notation that is used in Hewlett-Packard scientific calculators. A data stack is an extremely efficient way of passing variables back and forth between operations and eliminates the need to tie up memory locations with variable tables.

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 submodules. When the lowest levels of sub-modules have been defined, FORTH coding begins at those levels, working back up toward the top of the program, in pyramid fashion. Each sub-module is a standalone component of the program, and can be debugged without having the complete program in the system. The interactive nature of FORTH supports this time efficient development technique.

In most time-critical applications, at least part of the program must be written in assembly languages. FORTH has a built-in 6502 macro assembler, and allows assembly language coding at almost any point in your program, without separate assembly and load steps or special 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.

The application program is developed, debugged and integrated with the user interface using the ROM-based FORTH Interpreter. After program validation, the application is compiled into stand-alone object code with only required portions of the Target Nucleus. The compiled byte count will generally be less than the separate application/interpreter byte count.

## FORTH TARGET COMPILER OPERATION

The disk-based, two-pass, FORTH Target Compiler compiles object code in one of two modes: BIG.COMPILE or QUICK.COMPILE. The QUICK.COMPILE mode compiles the entire object code directly to RAM then saves the compiled code on disk. The BIG.COMPILE mode compiles to 1 K -byte buffer areas in RAM. When the buffer is full, the buffer contents are transferred to disk then compilation continues. The BIG.COMPILE mode optimizes object code RAM requirements although it compiles slower than the QUICK.COMPILE mode.

Operation of the compiler is directed by one or more LOAD SCREENS. This technique provides the user with complete control of compiler variables, origin statements, cold start vectors and utility routines. The LOAD-SCREEN(s) then specify which user screens to compile and in what order.

## FLOATING POINT OPERATION

The FORTH Target Compiler provides both single-precision (16-bit) and double-precision (32-bit) single integer arithmetic functions. If floating point arithmetic is desired, code words can easily be defined within the application program to link to external floating point subroutines. The AIM 65 Math Package ROM, located at address $\$ 8000-\$ 8 F F F$, can be installed in the application system. Alternatively, user-defined floating point functions may be linked to or even provided within the code definitions.

## SYSTEM REQUIREMENTS

The AIM $65{ }^{\circ}$ FORTH Target Compiler operates in an AIM 65 Microcomputer in conjunction with an RM 6532 K Dynamic RAM module and an RM 65 FDC module with an AIM 65 DOS 1.0 ROM installed on the FDC module. The following table lists two configurations of AIM 65/40 and RM 65 hardware and firmware which may be used. Other configurations can be easily composed depending on the user's development and application requirements.
$\left.\begin{array}{|l|c|c|}\hline & \begin{array}{c}\text { Host Computer }\end{array} \\ \hline \begin{array}{c}\text { Required } \\ \text { Peripherals } \\ \text { Firmware }\end{array} & \begin{array}{c}\text { A65-450 } \\ \text { AIM 65 Microcomputer } \\ \text { with 4K RAM } \\ \text { and FORTH ROMs }\end{array} & \begin{array}{c}\text { A65-550 } \\ \text { AIM 65 Microcomputer } \\ \text { System with 4K RAM } \\ \text { and FORTH ROMs }\end{array} \\ \hline \text { RM65-7104E RM 65 Adapter/Buffer for AIM 65, or } \\ \text { RM65-7116E RM 65 Cable Adapter/Buffer for AIM 65 }\end{array}\right\}$

FORTH WORDS (Continued)
EDITOR VOCABULARY OVERLAY

## BUFFERS

INSERT-BUF
FIND-BUF $\quad$ An 80-byte buffer beginning at PAD +160 .

## LINE ORIENTED COMMANDS:

K

M
u

X
>LINE\#
(DELETE)
(HOLD)
(KILL)
(PUT)
?

1LINE

LINE On current screen, returns the RAM address of the beginning of the line\#.

NEW Beginning at line\#, clears each line and allows a NEW line to be typed in. Input is terminated by a null line entry (CR CR). Clears remaining lines on the current screen.

Copies text into the INSERT-BUF and the current line until the delimiter (CR) is encountered.

Beginning at the current cursor address, deletes text unTILL the end of the matching text string is encountered. The text is held in FIND-BUF.

Moves cursor to beginning of line\# in current screen. Shows the line.
Swaps the contents of the INSERT-BUF and FIND-BUF.

Replaces INSERT-BUF and line\# in block\# with current referenced line.

Copies text into the INSERT-BUF and the line on the current screen under the cursor.

Copies the current line into INSERT-BUF. Then deletes the line and scrolls the screen up. The last line becomes a blank.

Returns the current cursor line \#.
Referring to the current cursor position, deletes n preceding characters and calls UPDATE.

Copies the referenced line number into INSERT-BUF and UPDATE.

Blanks line\# and UPDATE.
Replaces the current line with contents of INSERT-BUF.

Prints the current line with the cursor at current cursor position and the line number at the end of the line.

Searches the current line after cursor position for a match to contents of FIND-BUF. Repositions cursor to it if a match is found and sets $f=1$. If no match is found, sets $f=0$ and positions the cursor to the next line.

## STRING ORIENTED COMMANDS

D

F

1
MATCH
(F)
\#LAG Returns the address of the character following the cursor and then counts to the line end.
\#LEAD
Returns the address of the character preceding the cursor and the count to the beginning of the line.

## SCREEN COMMANDS

B
Moves to last block.
L
Lists current screen.
Moves to next block.
TOP
Moves cursor to the top line of the text.
WIPE
Clears the entire screen.

## MISCELLANEOUS COMMANDS

BUF-MOVE Move non-null contents of PAD to ADDR.
E

R Replaces string identified by FIND-BUFF with TEXT.

Beginning at current screen and continuing through screen \#n, searches for a string match to TEXT and displays matches.

## CURSOR COMMANDS

R\# Returns the cursor position ( n ).
\#LOCATE

TEXT

USE
WHERE
$\gg \quad$ Add's n to cursor position and displays line.
Returns byte position of cursor and line number.

Takes text from input stream until DLIMiter character is encountered ( 65 characters maximum). Moves text to PAD and fills to 65 characters with blanks (\$20).

Displays CHAR as the cursor.
Displays where an error in LOADing occurred. Also shows context and current.

## FORTH WORDS

## GENERAL PURPOSE VOCABULARY

The following FORTH words are provided in addition to those provided in the A65-050 FORTH Interpreter ROMs (refer to Data Sheet Order No. D87).


## FORTH WORDS (Continued)

## TARGET COMPILER VOCABULARY OVERLAY

## LISTS

| SYMBOLS | Defines names in the object code. |
| :--- | :--- |
| LOCALS | Defines words at compile time only. |
| MAGICS | Immediate words. |
| SWITCHES \& FLAG WORDS (directives active during compile) |  |

ON
OFF
MAPPING
GAG
AUTO.FORWARD

Changes switch state to ON .
Changes switch state to OFF.
Prints or displays the name and CFA of each WORD when created.

Suppresses most non-fatal error messages.
AUTO.FORWARD
Automatic forward reference for undefined words.

NUMERIC
ROMABLE
CONTROL WORDS

| FORWARD | Forces forward reterence of the name immediately following. |
| :---: | :---: |
| WIDE | Name field length (headerless code). |
| SET | Changes the value of FORTH user constants. |
| WINDOW.LO WINDOW.HI | Defines the Target address space boundaries. |
| destination | Defines the target buffer block number. |
| $\left.\begin{array}{l} \text { RAM.LO } \\ \text { RAM.HI } \end{array}\right\}$ | Identifies nucleus RAM boundaries. Extends from RAM.LO for USER.SIZE bytes. |
| USER.SIZE | Number of bytes reserved beginning at RAM.LO. RAM between RAM.LO + USER.SIZE and RAM.HI is used for work buffers (PAD, etc.) when ROMABLE flag is set. |
| ORIGIN | Compiler's target dictionary. |
| FAST.COMPILE | Target space will be RAM only, based on WINDOW.LO and WINDOW.HI. |
| BIG.COMPILE | Target space maybe virtual data space on disk. |
| CLEAR.TARGET | Fills the target area with zeros. |

READY START

## DEFINING WORDS

LABEL

VARIABLE If ROMABLE is true, VARIABLE becomes a USER variable, otherwise variable is identical to ROM-based FORTH.

Sets aside bytes in RAM area (like ALLOT).
Equivalent to ROM command HERE. Returns current RAM address.

Relative branch opcodes for assembly operation.

Compiles a double number in line.
Compiles CLIT of following ASCII character.
Immediate word to separate <BUILDS DOES $>$ into TARGET NUCLEUS and Target Compiler.

Identical to CODE but also sets a pointer for LOCATE.

Informs the compiler where the execution time CODE is located.

Similar to SMUDGE.
Sets the SMUDGE bit on the last target word.

## A65-060 AIM 65 INSTANT PASCAL ROMS

## PASCAL LANGUAGE

Pascal is a powerful high-level computer programming language originally designed for educational purposes. Developed by Niklaus Wirth of the ETH Technical Institute of Zurich in 1971, Pascal has gained acceptance worldwide as the standard language to teach computer programming. The rich variety of Pascal language features allows a wide range of data structures to be specified and complex algorithms to be implemented. Programming in Pascal using structured programming techniques produces programs that are easy to write, understand and maintain. The widespread teaching of the language coupled with the increased productivity of the programmer and the improved reliability of compiler generated code is causing Pascal to be increasingly adopted in industrial and scientific applications as well as in the classroom.

## PRODUCT OVERVIEW

AIM 65 Instant Pascal ${ }^{\top M}$ is a unique implementation of the Pascal language which combines the immediacy of ROM-based software, interactive source code entry and debug facilities, onboard AIM 65 printer and display peripherals and low-cost expansion memory, to provide a complete Pascal education, development and application system. The language is a major subset of Standard Pascal (defined by K. Jensen and N. Wirth in their book, "Pascal User Manual and Report") incorporating all of the simple and structured statements, and the most widely used simple and structured data types. Extensions to the language permit direct control in Pascal of the AIM 65 Microcomputer memory-mapped $I / O$ and allow interfacing to machinelanguage programs developed with the AIM 65 Assembler.

Instant Pascal incorporates facilities to write and debug programs entirely at the source language level. These facilities include source-level editor, breakpoint, and trace-plus immediate source statement execution for examination and modification of data. Source statements are translated immediately upon entry into an intermediate language which is interpretively executed.

The 20K-byte AIM 65 Instant Pascal software comes in a fiveROM set. One ROM plugs into AIM 65 Master Module socket Z24 while the other four ROMs plug into an RM 65 16K-byte PROM/ROM (RM65-3216E) module.

[^17]
## FEATURES

- AIM 65 Microcomputer host and target
- Substantial subset of Standard Pascal (Jensen and Wirth)
- ROM resident for immediate operation
- Direct control of memory mapped I/O
- Machine language interface linkage
- Source code editor
-Position text pointer
-Find character string
-List, delete, insert statement
—View statement
- 

Flexible program control
-Check syntax for coding errors without executing program
-Execute one statement to allow examination and modification of data
-Execute entire program

- Source level debugging facilities
—Breakpoint
-Assignment trace lists values as they are changed
-Statement trace lists statements as they are executed
- Device Source I/O
-Input source code from specified device
-Output source code to specified device


## MEMORY MAP

| Address (Hex) | Contents |
| :--- | :--- |
| $\$$ SB000-\$BFFF | Pascal Program |
| $\$ 4000-\$ 7 F F F$ | Pascal Program |
| $\$$ FFCD-\$FFF | Translator input area (default value) |
| \$ED2-\$FC2 | Translator output area (default value) |
| $\$ 300$ up | Execution stack (default value) |
| \$FC-\$FF | Pascal Variables |
| $\$ 06-\$ B 4$ | Pascal Variables |

## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| A65-060 | AIM 65 Instant Pascal ROMs |
| Order No. | Description |
| 279 | AIM 65 Instant Pascal User's Manual* |
| Note: <br> *Included with A65-060. |  |

## NSTANT PASCAL EXTENSIONS TO STANDARD PASCAL

-Variables, both simple and structured, may be given absolute memory addresses. This permits Pascal programming of memorymapped I/O and linkage to machine-language subroutines.
-The OTHERWISE: default clause is implemented in the CASE statement. Identifiers may have any length; the entire identifier is significant.
-Data of type STRING may have lengths which vary dynamically up to the declared maximum length. The type S:STRING[C] is implemented as S:ARRAY[O . . C] OF CHAR, where S[0] is the value of the dynamic length. ( $C$ is a constant less than 256.)
-The predefined procedure BREAK causes interruption of program execution, if it is enabled.
-The predefined procedure SUBR(ENTRANCE) calls the machine-language subroutine whose entrance address is the declared address of the absolute variable ENTRANCE. The variant SUBR(ENTRANCE, DATA) places the address of the Pascal variable DATA in page 0 before giving control to the subroutine.
-The predefined functions FUNC(ENTRANCE) and FUNC(ENTRANCE, DATA) are the same as SUBR; in addition they return a CHARtype value which the subroutine leaves in $A$.

## STANDARD PASCAL FEATURES NOT IMPLEMENTED IN INSTANT PASCAL

-Files and their associated predefined procedures and variables (GET, PUT, RESET, REWRITE, EOLN, EOF) are not implemented. The predefined procedures READ, READLN, WRITE, WRITELN are implemented to interface with all character-serial devices available to the AIM 65 Monitor, including user-defined devices. The following types may be read and written: char, integer, reat, Boolean ( Y or N on input), variable-length string.
-Set expressions are not implemented. One-byte sets (with up to eight elements) and the relational operator $\mathbb{N}$ are implemented; these permit Pascal-level testing of I/O device status.
-Records are implemented, but record variants are not.
-Dynamic storage allocation and the pointer type are not implemented.
-The directive FORWARD is not implemented.
-The constant definition identifier=identifier; is not implemented.
-Ambiguity between field and variable names at the same block level is not supported. Other Pascal visibility rules are fully supported.
-Packing of data is not done below the byte level. The word-symbol PACKED is accepted but ignored, and the predefined procedures PACK and UNPACK are not implemented.
-Procedural and functional parameters to procedures and functions are not implemented.
-GOTO may not jump outside its own block.
-The 60 -character input line of the AIM 65 limits the length of certain constructs, in particular simple statements, procedure/function headings, and enumerated type lists, which may not be extended during input from one line to the next.

## OPERATION OF INSTANT PASCAL

All operations in the Instant Pascal system are controlled by a set of single-letter commands. The system generally performs one of the following six major operations.

1. Source input from keyboard or input device.
2. Source output to printer or output device.
3. Program editing: positioning the text unit pointer or deleting text units.
4. Syntax checking a program. This operation is called automatically at the first call to execute a program after any change. It may also be called explicitly.
5. Executing a program.
6. Executing a single statement entered by the user.

All commands are preceded by the Instant Pascal prompt "+<." The numeric parameter $n$ in some of the commands has either a decimal value or one of the following two default values: "."=forever; CR=1.

## MEMORY EXPANSION CONSIDERATIONS

About 1.5 bytes per character of source code is required td store an application program written in Pascal in memory due to the translation process. For minimum applications requiring less than 3.2 K bytes of on-board user RAM, the PROM/ROM module can be connected to the AIM 65 Expansion Con nector using an RM 65 Single Card Adapter. For large applications, connection of an RM 65 multi-siot card cage through an RM 65 Adapter/Buffer module is recommended One or more RM 65 RAM modules can then be added as required. Up to 15.2 K bytes of contiguous RAM can be dedicated to the application program.

## INSTANT PASCAL OPERATION COMMANDS

## Text Unit Pointer Movement

| $+<T>$ | Position to top text unit. |
| :--- | :--- |
| $+<B>$ | Position to bottom text unit. |
| $+<U>/ n$ | Position up $n$ text units. |
| $+<D>/ n$ | Position down $n$ text units. |
| $+<F>$ string | Find the line containing the argument string. |

## Source Text Editing

```
+<K>/n
+<l>
+<>space
+<V>
```

Delete $n$ text units.
Insert one line of source.
List current text unit.
View a neighborhood of five text units centered at the current one.

## Device Source I/O

$+<\mathrm{R}>\mathrm{IN}=$ device
$+\langle L>/$ nOUT $=$ device

Read lines of source until empty line.
List n text units to the specified device.

## Toggles

$+\langle S\rangle \quad$ Toggle statement trace.
$+<A>\quad$ Toggle assignment trace.
$+\langle E\rangle \quad$ Toggle enabling of the BREAK procedure.

## Program Control

$+<C>$
Check program syntax.
Execute program. Starts at beginning of program unless a break is in progress. Break-in-progress status may be cancelled with the C command or by changing the program.
Execute and trace until the start of the next statement and return with break-in-progress status set. Immediately execute the statement. Identifier visibility is defined by the position of the text unit pointer in the program.

## Miscellaneous

$+<$ W $>$
$+<N>$
$+<\mathrm{M}>\quad$ Report number of free memory bytes.
$+<\mathbf{Z}\rangle \quad$ Cold start.

# A65-090 AIM 65 DISK OPERATING SYSTEM VERSION 1.0 (DOS 1.0) ROM 

## DISK OPERATING SYSTEM

A disk operating system (DOS) provides a standard interface between the user and one or more floppy disk drives, floppy disk control (FDC) hardware and executive-level software. The DOS, implemented in software, allows program and data files to be opened, closed, read and written under operator or program control. In an interactive environment, commands are usually initiated by the operator from the keyboard in response to userfriendly prompts displayed by the system.

## PRODUCT OVERVIEW

The AIM 65 Disk Operating System Version 1.0 (DOS 1.0) provides disk and file management functions for the AIM 65 Microcomputer in conjunction with an RM 65 Floppy Disk Controller (FDC) module. With this configuration, mass sforage files can be easily manipulated when connected to one to four $5^{1 / 4 \prime}$ or $8^{\prime \prime}$ floppy disk drives. DOS 1.0 functions, contained on a 4 K -byte ROM that plugs into the FDC module, are available immediately upon computer power turn-on without waiting for separate loading of a disk-based DOS into RAM.

DOS 1.0 functions are operator commandable through interactive AIM 65 Debug Monitor/Text Editor operation as well as language (assembler; compiler and/or interpreter) operation. Text and program source code may be written to, and read from, disk with the Editor List and Read commands, respectively. Binary data and program object code may be written to, and loaded from, disk using the Debug Monitor Dump and Load commands, respectively. Files containing source and object code for application programs written in AIM 65 Assembler, BASIC, FORTH, PL/65 and Instant Pascal languages are therefore supported. In addition, utility functions format a disk, list the contents of the disk directory, delete a file, recover a file and backup a disk upon command. The DOS functions may also be called under program control by the application program into order to read and write data files.

Disk read or write errors, both at the DOS and FDC hardware level, are reported upon detection. User-alterable variables allow changing of default values to application unique values.

Disks formatted by AIM 65 DOS 1.0 are compatible with AIM 65/40 DOS 1.0 and AIM 65/40 BDOS 1.0. Files written by any of these DOS programs may therefore be read by either microcomputer.

## FEATURES

- AIM 65 Microcomputer compatible
- ROM resident for immediate operation
- Installs on-board RM 65 Floppy Disk Controller (FDC) module
- Provides mass storage of programs and data
- Compatible with AIM 65 high level language and Assembler ROMs
- Disk oriented commands (format, list, backup)
- File oriented commands (list, delete, recover)
- Input/Output commands
-Read and write text and object code
-Automatic file open and close
- User-alterable variables
-Utility function and error handling vectors (before and after DOS functions)
- Input/output vectors
- l/O buffer vectors
- Extensive error detection and reporting


## MEMORY MAP

| Address (Hex) | Contents |
| :--- | :--- |
| $\$ 8800-\$ 8 F F F$ | RM 65 FDC Module I/O |
| $\$ 8000-\$ 8 E F F$ | DOS 1.0 Program |
| $\$ 600-\$ 7 F F$ | DOS 1.0 VO Buffer (default location) |
| $\$ 500-\$ 563$ | DOS 1.0 Variables |
| $\$ 4 A 0-\$ 4 F A$ | DOS 1.0 Variables |
| $\$ D 7-\$ D E$ | DOS 1.0 Variables |


| Part No. | Description |
| :--- | :---: |
| A65-090 AIM 65 DOS 1.0 ROM <br> RM65-5101NE RM 65 FDC Module (without ROM <br> containing primitive subroutines  <br> (2) $)$  |  |
| Order No. | Description |
| 802 | RM 65 FDC Module User's Manual ${ }^{(1)}$ |
| Notes: |  |
| 1. Describes user's instructions for AIM 65 DOS 1.0. Included |  |
| with A65-090 and RM65-5101NE. |  |
| 2. The DOS 1.0 ROM includes primitive subroutines in addition |  |
| to DOS functions. |  |

## 0 Rockwell

## A65-901 AIM 65 PROM PROGRAMMER AND CO-ED MODULE

## PRODUCT OVERVIEW

The A65-901 PROM Programmer and CO-ED Module is one of the hardware options available for the AIM 65 Microcomputer family.

The A65-901 PROM Programmer and CO-ED Module programs 1 K -, 2 K -, and 4 K -byte PROMs that can be installed in the AIM 65 microcomputer or in a RM 65 16K PROM/ROM Module. The PROM Programmer provides check, program, verify and read functions.

The utility of the Module is enhanced through the included 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 A65-901 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 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 4K-byte PROM when used with a 4K RAM version of AIM 65
- Zero insertion force (ZIF) socket for PROM being programmed
- On-board DC/DC Converter allows +5 V -only operation
- Fully assembled, tested and warranted


A65-901 PROM Programmer and CO-ED Module

## 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 F F$ 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, PIA 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.



| PROM Programmer Commands |  |  |
| :---: | :---: | :--- |
| Category | Command | Function |
| ENTRY/EXIT | F1 | ENTER PROM PROGRAMMER |
|  | F2 | RE-ENTER PROM PROGRAMMER |
|  | ESCAPE TO MONITOR |  |
| BASE ADDRESS | B | PROM BASE ADDRESS |
|  | O | RAM BASE ADDRESS |
| PROM | C | CHECK PROM |
|  | P | PROGRAM PROM |
|  | $V$ | VERIFY PROM |
|  | READ PROM |  |
| MEMORY | R | LOAD MEMORY |
|  |  | V |
|  |  | VERIFY MEMORY |
|  |  | D |

CO-ED Commands


## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions Width Length Height | $4.4 \mathrm{in} .(111 \mathrm{~mm})$ <br> $6.3 \mathrm{in} .(160 \mathrm{~mm})$ <br> $0.75 \mathrm{in} .(19 \mathrm{~mm})$ |
| Weight | 5.3 ox. (150 g) |
| Environment <br> Operating Temperature <br> Storage Temperature Relative Humidity | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ <br> $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ <br> $0 \%$ to $85 \%$ (without condensation) |
| Power Requirements With DC/DC Converter Without DC/DC Converter | $\begin{aligned} & +5 \mathrm{~V} \pm 5 \%, 1.1 \mathrm{~A}(5.5 \mathrm{~W})-\text { Maximum } \\ & +5 \mathrm{~V} \pm 5 \%, 0.75 \mathrm{~A}(3.75 \mathrm{~W})-\text { Maximum } \\ & +30 \mathrm{~V} \pm 5 \%, 0.04 \mathrm{~A}(1.2 \mathrm{~W})-\text { Maximum } \end{aligned}$ |
| Mernory Map User RAM I/O ROM | $\begin{aligned} & \$ 1000-\$ 13 F F \\ & \$ 8800-\$ 8 F F F \\ & \$ 9000-\$ 9 F F F \end{aligned}$ |

## A65-905 <br> AIM 65 MEMORY CARTRIDGE

## PRODUCT OVERVIEW

The A65-905 Memory Cartridge is one of the hardware options available for the AIM 65 Microcomputer family.

Many applications of AIM 65 microcomputers, particularly in test equipment, instrumentation, monitors, analyzers or controllers, require that the resident application software or fixed parametric data be changed periodically. This may occur because the item under test or being controlled has been changed, or parameter values have been revised. For OEM installations, the change may be required to customize the system for different customers.

The AIM 65 Memory Cartridge system is an economical and convenient method for expanding the memory of an AIM 65 microcomputer. The cartridges are designed for use with the Rockwell packaged 500 Series of desktop microcomputers, but may also be used with any AIM 65 board-level microcomputer. A Buffer Module connects to the AIM 65 Master Module, buffers the expansion bus signals, and provides a covered host receptacle for a Memory Cartridge. In addition to expanded RAM and provisions for user application PROM firmware, a variety of preconfigured AIM 65 high level languages, assembler and math package routines are available in plug-in Memory Cartridge form. These language cartridges permit the user to program different applications in different languages. Unpopulated RAM and PROM/ROM cartridges are also available for complete user flexibility.

The Buffer Module fits under the AIM 65 Master Module and fastens securely to the Rockwell AIM 65 Enclosure. Rugged injection molded plastic covers for both the Buffer Module and the Memory Cartridge complement the AIM 65 Enclosure in color, texture and sturdiness. A Memory Cartridge plugs vertically into the Buffer Module immediately behind the microcomputer enclosure to require a minimum of area in desktop applications. A recessed label area on the Memory Cartridge cover allows configuration information to be neatly added in an area visible to the operator. Address decoding required by the different cartridges is accomplished automatically without user intervention.

A 16K Battery Backed CMOS RAM Cartridge retains program and data in memory when the AIM 65 Microcomputer power is turned off. Critical information can thus be preserved during AC power transients or outages and during normal turn-off cycles.

## FEATURES

- Preconfigured Memory Cartridges
-AIM 65 high level languages and support firmware
-Up to 16 K bytes additional RAM (volatile or non-volatile)
-Up to 32K byte additional PROM/ROM
-Combination RAM and PROM/ROM
- Permanent Buffer Module installation
- Convenient Memory Cartridge plug-in installation
- Use with any AIM 65500 Series Desktop Microcomputer
- Compatible with A65-006 enclosure and power supply
- Cartridges are fully assembled, tested and warranted


## ORDERING INFORMATION

| Part No. | Description |
| :---: | :---: |
| A65-905-00 | Buffer Module |
| A65-905-01 | BASIC Interpreter, Assembler, 8K CMOS RAM \& 4K User PROM Socket |
| A65-905-02 | PL/65 Compiler, Assembler, 8K CMOS RAM \& 4K User PROM Socket |
| A65-905-03 | FORTH, Math Package, 8K CMOS RAM \& 4K User PROM Socket |
| A65-905-04 | Instant PASCAL \& 6K CMOS RAM |
| A65-905-05 | 32K PROM/ROM (1) |
| A65-905-06 | 16K CMOS RAM |
| A65-905-07 | 16K CMOS RAM (unpopulated) |
| A65-905-08 | 8K CMOS RAM \& 16K PROM/ROM (1) |
| A65-905-09 | 16K Battery Backed CMOS RAM |



AIM 65 Desktop Microcomputer with Memory Cartridge

## FUNCTIONAL DESCRIPTION

## BUFFER MODULE

The Buffer Module interfaces the AIM 65 Expansion Connector to a Memory Cartridge as illustrated. Non-inverting circuits buffer the data and address lines. Data direction is controlled by the BR/W signal. During a write operation, data from the AIM 65 Master Module is directed towards the cartridge. During a read operation, data from the cartridge is directed towards the AIM 65 Master Module. The RAM R/W signal is routed through the Buffer Module to the cartridge interface to control the Memory Cartridge device read/write operation.

Address decoding is accomplished by a factory programmed $256 \times 4$ PROM which drives a 3 -to-8 decoder. An interlock signal (PE) ensures the PROM is enabled only when a cartridge is installed. Three address straps within the cartridge (S1, S2, and S3) identify the cartridge type installed by selecting the appropriate address decoding section in the PROM. The five most significant buffered address lines address one of the 32 bytes within the selected section. A valid address for the installed cartridge results in a low level signal on the most significant PROM output pin. This signal in turn enables both the 3 -to- 8 decoder and the data transceiver. The remaining three PROM outputs (O1, O2, and O 3 ) provide the selection input to the
decoder and drive the appropriate decoder output to the low state. The eight decoder outputs form the eight active low chip select signals for the cartridge.

PROM timing is controlled by a delay circuit implemented with a mono-stable multivibrator. This circuit delays the turn-on of the address decode PROM to prevent bus contentions at the beginning of each cycle.

Power for the Buffer Module is derived from the AIM 65 power supply through the Expansion Connector. Power for the cartridge is routed through the Buffer Module.

## MEMORY CARTRIDGE

The Memory Cartridge has eight 24 -pin sockets which can accept 2 K RAMs, 4 K PROMs or 4 K ROMs. In models -01 , $-02,-03,-05$, and -08 , sockets are available for user supplied PROMs. In model -07, sockets are provided for user supplied RAMs.

Variations in socket functions are accomplished by routing selected signals through factory installed jumpers. The eight sockets are arranged into three groups as illustrated in the block diagram. All sockets in each group are configured to accept the same memory device type.


## INSTALLATION

## BUFFER MODULE

1. Before installing the Buffer Module, turn off power to the AIM 65 Microcomputer.
2. Align the Buffer Module Connector J1 pin 1 with the AIM 65 Expansion Connector J3 pin 1.
3. Carefully slide the Buffer Module under the AIM 65 Master Module, plugging the Buffer Module onto the Expansion Connector. Press in firmly on the end of the module assembly until all pins are securely seated.
4. If your AIM 65 Microcomputer is installed in an AIM 65 Enclosure, fasten the Buffer Module Assembly bottom plate to the base plate of the enclosure using the screws provided with the Buffer Module.

## MEMORY CARTRIDGE BATTERY INSTALLATION (A65-905-09 only)

1. The battery is NOT factory installed. Install the battery by sliding it into the holder plus side (+) up.
2. There is no on/off switch for the battery. Remove the battery to prevent draining the battery when the cartridge is not powered.
3. The battery will last six months in battery back-up mode. Therefore, replace the battery after six months of use. The replacement battery should be either a GE or Sanyo CR2032.
4. A potentiometer in the cartridge sets the voltage threshold level at which the cartridge switches from $\mathrm{V}_{\mathrm{CC}}$ mode to battery back-up mode. The factory set levels are approximately +4.5 Vdc for battery back-up and +4.7 Vdc for $\mathrm{V}_{\mathrm{Cc}}$ power. Adjust this potentiometer while monitoring the voltage on pin 4 of $\mathrm{Z9}$ to raise or lower these levels. When pin 4 goes high (about +5 Vdc ), the cartridge is in battery back-up.

## MEMORY CARTRIDGE

1. Before installing or removing a Memory Cartridge, turn off power to the AIM 65 Microcomputer.
2. To install the cartridge, align the cartridge with the label side towards the microcomputer and plug the cartridge into the Buffer Module receptacle (the cartridge is keyed to prevent improper insertion). Press down firmly on the top of the cartridge until all pins are securely seated.



Notes:
(1) Master Module only.
(2) These blocks are addressed on the AIM 65 Master Module in addition to the cartridges. Components must be removed from AIM 65 Master Module sockets Z24, Z25, and Z26 prior to installing the memory cartridge model -01, -02, or -03. Component must be removed from AIM 65 Master Module socket Z26 prior to installing cartridge module -04.

Memory Cartridge Component Summary

| Socket | Cartridge Model No. (A65-905-XX) |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | -01 | -02 | -03 | -04 | -05 | -06 | -07 | -08 | -09 |
| Function | BASIC | PL/65 | FORTH | PASCAL | PROM/ROM | RAM | User RAM | RAM and PROM/ROM | Battery Backed RAM |
| Z1 | RAM | RAM | RAM | RAM | PROM | RAM | RAM | RAM | RAM |
| Z2 | RAM | RAM | RAM | RAM | PROM | RAM | RAM | RAM | RAM |
| Z3 | RAM | RAM | RAM | RAM | PROM | RAM | RAM | RAM | RAM |
| Z4 | RAM | RAM | RAM | R32P2-11 <br> ROM | PROM | RAM | RAM | RAM | RAM |
| Z5 | $\begin{gathered} (1) \\ \text { PROM } \end{gathered}$ | (1) PROM | (1) <br> PROM | R32P3-11 ROM | PROM | RAM | RAM | PROM | RAM |
| Z6 | $\begin{aligned} & \text { R3226-11 } \\ & \text { ROM } \end{aligned}$ | $\begin{gathered} \text { R3299-11 } \\ \text { ROM } \end{gathered}$ | R32J1-11 ROM | $\begin{gathered} \text { R32P4-11 } \\ \text { ROM } \end{gathered}$ | PROM | RAM | RAM | PROM | RAM |
| Z7 | $\begin{gathered} \text { R3225-11 } \\ \text { ROM } \end{gathered}$ | $\begin{aligned} & \text { R3298-21 } \\ & \text { ROM } \end{aligned}$ | $\begin{aligned} & \text { R32J2-11 } \\ & \text { ROM } \end{aligned}$ | R32P5-11 ROM | PROM | RAM | RAM | PROM | RAM |
| Z8 | $\begin{aligned} & \text { R3224-11 } \\ & \text { ROM } \end{aligned}$ | $\begin{gathered} \text { R3224-11 } \\ \text { ROM } \end{gathered}$ | $\begin{aligned} & \text { R32L3-11 } \\ & \text { ROM } \end{aligned}$ | R32P6-11 ROM | PROM | RAM | RAM | PROM | RAM |

Notes:

1. All PROM is user provided TI2532 or equivalent.
2. All RAM is Toshiba TC5516AP, Toshiba TC5516APL or Suwa Seikosha SRM2018C.

Buffer Module to AIM 65 Expansion Connector Pin Assignments

| Top (Component Side) |  |  |  | Bottom (Solder Side) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | $\begin{aligned} & \text { Input/ } \\ & \text { Output** } \end{aligned}$ | Pin | Signal Mnemonic | Signal Name | Input/ Output** |
| 1 | SYNC | *SYNC |  | A | AO | Address Bit 0 | 1 |
| 2 | RDY | *Ready |  | B | A1 | Address Bit 1 | 1 |
| 3 | $\varnothing_{1}$ | *Phase 1 Clock |  | C | A2 | Address Bit 2 | 1 |
| 4 | $\overline{\mathrm{IRO}}$ | *Interrupt Request |  | D | A3 | Address Bit 3 | 1 |
| 5 | S.O. | *Set Overflow |  | E | A4 | Address Bit 4 | 1 |
| 6 | NMI | *Non-Maskable Interrupt |  | F | A5 | Address Bit 5 | 1 |
| 7 | RES | *Reset |  | H | A6 | Address Bit 6 | 1 |
| 8 | D7 | Data Bit 7 | 1/0 | J | A7 | Address Bit 7 | 1 |
| 9 | D6 | Data Bit 6 | 1/0 | K | A8 | Address Bit 8 | 1 |
| 10 | D5 | Data Bit 5 | 1/0 | L | A9 | Address Bit 9 | 1 |
| 11 | D4 | Data Bit 4 | 1/O | M | A10 | Address Bit 10 | 1 |
| 12 | D3 | Data Bit 3 | //O | N | A11 | Address Bit 11 | 1 |
| 13 | D2 | Data Bit 2 | //O | P | A12 | Address Bit 12 | 1 |
| 14 | D1 | Data Bit 1 | 1/0 | R | A13 | Address Bit 13 | 1 |
| 15 | D0 | Data Bit 0 | 1/0 | S | A14 | Address Bit 14 | 1 |
| 16 | -12V | *-12 Vdc |  | T | A15 | Address Bit 15 | 1 |
| 17. | +12V | * +12 Vdc |  | U | SYS $\emptyset 2$ | System Phase 2 Clock |  |
| 18 | CS8 | *Chip Select 8 |  | v | SYS R/W | *System Read/Write : |  |
| 19 | $\overline{\mathrm{CS} 9}$ | *Chip Select 9 |  | W | $\overline{\mathrm{R}} \bar{W}$ | Read/Write "Not" | 1 |
| 20 | $\overline{\text { CSA }}$ | *Chip Select A |  | X | TEST | *Test |  |
| 21 | $+5 \mathrm{~V}$ | $+5 \mathrm{Vdc}$ |  | Y | $\phi 2$ | Phase 2 Clock "Not" | 1 |
| 22 | GND | Ground |  | z | RAM R/W | RAM Read/Write | 1 |
| Note: <br> * $=$ Not used on this module. <br> ** $=$ With respect to the Buffer Module. |  |  |  |  |  |  |  |

Memory Cartridge to Buffer Module Connector Pin Assignments

| Front (Label Side) |  |  |  |  | Rear |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | $\begin{gathered} \text { Input/ } \\ \text { Output** } \end{gathered}$ | Pin | Signal Mnemonic | Signal Name | Input/ Output** |
| 2 | BA3 | Address Bit 3 | 1 | 1 | BA2 | Address Bit 2 | 1 |
| 4 | BA1 | Address Bit 1 | 1 | 3 | BAO | Address Bit 0 | 1 |
| 6 | BA7 | Address Bit 7 | 1 | 5 | BA6 | Address Bit 6 | 1 |
| 8 | BA4 | Address Bit 4 | 1 | 7 | BA5 | Address Bit 5 | 1 |
| 10 | BA15 | Address Bit 15 | 1 | 9 |  | Not Used |  |
| 12 | BA14 | Address Bit 14 | 1 | 11 | $\overline{\text { PE }}$ | PROM Enable | 0 |
| 14 | BA12 | Address Bit 12 | 1 | 13 | BA13 | Address Bit 13 | 1 |
| 16 | BA9 | Address Bit 9 | 1 | 15 | BA8 | Address Bit 8 | 1 |
| 18 | BA11 | Address Bit 11 | 1 | 17 | BA10 | Address Bit 10 | 1 |
| 20 | BD1 | Data Bit 1 | 1/0 | 19 | BDO | Data Bit 0 | 1/0 |
| 22 | BD3 | Data Bit 3 | 1/0 | 21 | BD2 | Data Bit 2 | I/O |
| 24 | BD5 | Data Bit 5 | 1/O | 23 | BD4 | Data Bit 4 | 1/0 |
| 26 | BD7 | Data Bit 7 | 1/0 | 25 | BD6 | Data Bit 6 | 1/O |
| 28 | CS2 | Chip Select 2 | 1 | 27 | CS1 | Chip Select 1 | 1 |
| 30 | CS4 | Chip Select 4 | 1 | 29 | CS3 | Chip Select 3 | 1 |
| 32 | CS6 | Chip Select 6 | 1 | 31 | CS5 | Chip Select 5 | 1 |
| 34 | CS8 | Chip Select 8 | 1 | 33 | $\overline{\mathrm{CS7}}$ | Chip Select 7 | 1 |
| 36 | RAM R/W | RAM Read/Write | 1 | 35 | S3 | Address Strap 3 | 0 |
| 38 | S2 | Address Strap 2 | 0 | 37 | S1 | Address Strap 1. | 0 |
| 40 |  | Not Used |  | 39 |  | Not Used |  |
| 42 | +5V | +5 Vdc |  | 41 | +5V | $+5 \mathrm{Vdc}$ |  |
| 44 | GND | Ground |  | 43 | GND | Ground |  |
| Note: <br> **With respect to Memory Cartridge. |  |  |  |  |  |  |  |

## SPECIFICATIONS

| Parameter | Value |  |  |
| :---: | :---: | :---: | :---: |
|  | Memory Cartridge |  | Buffer Module |
| Dimensions Width Length Height | 5.25 4.85 0.88 | $33 \mathrm{~mm})$ ( 23 mm ) ( 22 mm ) | 4.75 in. ( 121 mm ) 4.69 in. (119 mm) <br> 1.48 in . $(38 \mathrm{~mm}$ ) |
| Power | $\begin{aligned} & -01,-02,-03 \\ & -04 \\ & -05 \\ & -06,-07,-09 \\ & -08 \end{aligned}$ | $\pm 5 \%$ <br> 550 ma-Typical <br> 550 ma-Typical <br> 870 ma-Typical <br> 380 ma -Typical <br> 620 ma-Typical | $\begin{gathered} +5 \mathrm{~V} \pm 5 \% \\ 250 \mathrm{ma}-\text { Typical } \end{gathered}$ |
| Environment <br> Operating Temperature Storage Temperature <br> Relative Humidity | $0^{\circ} \mathrm{C}$ to $50^{\circ} \mathrm{C}$ <br> $-40^{\circ} \mathrm{C}$ to $85^{\circ}$ <br> $-20^{\circ} \mathrm{C}$ to $50^{\circ}$ <br> 0\% to $85 \%$ | cept A65-905-09) 5-905-09)* condensation) | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ $-40^{\circ} \mathrm{C} \text { to } 85^{\circ} \mathrm{C}$ <br> $0 \%$ to $85 \%$ (without condensation) |
| Interface Connections AIM 65 Expansion Connector <br> Buffer Module to Cartridge | $\begin{array}{r} 44 \text { pir } \\ (0.1 \end{array}$ | connector centers) | 44 pin-edge receptacle ( 0.156 in. centers) <br> 44 pin-edge receptacle ( 0.100 in . centers) |
| Note: * $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ if the battery is not present. |  |  |  |

## SECTION 8 AIM 65/40 MICROCOMPUTER FAMILY

Page
Product Family Overview ..... 8-2
A65/40-8X15 Series 8000 Microcomputer System ..... 8-3
A65/40-2000, A65/40-3000, A65/40-4000 and A65/40-5000 AIM 65/40 Microcomputer ..... 8-10
A65/40-1000 Single Board Computer ..... 8-22
A65/40-0004 Power Supply and Cable ..... 8-30
A65/40-0200 and A65/40-0210 Standard and Extended Keyboards ..... 8-32
A65/40-0400 40-Character Display ..... 8-36
A65/40-0600 Graphics Printer ..... 8-43
A65/40-0800 Video Display Controller Module ..... 8-49
A65/40-7010 Assembler ROM ..... 8-56
A65/40-7012 Macro Assembler and Linking Loader ..... 8-58
A65/40-7020 BASIC Interpreter ROMs ..... 8-59
A65/40-7024 BASIC Compiler ..... 8-61
A65/40-7040 Math Package ROM ..... 8-63
A65/40-7050 FORTH ROMs ..... 8-65
A65/40-7052 FORTH Target Compiler ..... 8-70
A65/40-7090 Disk Operating System Version 1.0 (DOS 1.0) ROM ..... 8-75
A65/40-7092 Bootstrap Disk Operating System Version 1.0 Upgrade Kit ..... 8-76

## AIM 65/40 MICROCOMPUTER FAMILY Modular Microcomputer Family With Wide OEM, Control Capabilities

The AIM 65/40 modular microcomputer system allows functional steps up from the AIM 65 microcomputer in hard working blue collar applications, at very competitive prices. It also offers an extremely wide range of languages, controller options and an operating system for even greater application flexibility.

The four basic modules of an AIM 65/40 include an R6502 based single board computer, an intelligent printer with 40 column alphanumerics and graphics capabilities, a 40 -character intelligent alphanumeric VF display, and a full ASCII keyboard. It may be purchased as a complete set for end users or as separate modules for OEM users. The printer and display modules may be mounted remotely from the single board computer.

Language ROMs include BASIC interpreter and compiler, FORTH firmware and compiler. An assembler ROM, debug monitor and text editor ROMs, math package ROM add to the versatility. There are even disk operating systems.


AIM 65/40 MICROCOMPUTER BOARD-LEVEL VERSION

A video controller module can be pre-configured onto the AIM 65/40 or can be used stand alone with other microprocessor based systems. It gives the AIM 65/40 the ability to command screen formatting, text handling and screen editing, plus full graphics drawing and data display functions. When pre-configured, the AIM 65/40 comes with an extended keyboard that includes cursor movement controls and a numeric keypad.

For desk top use, the AIM 65/40 comes in an attractive enclosure, including power supply and an expansion card cage which can accept any RM 65 Eurocard module. With its built-in features and expansion capabilities, the desk top AIM 65/40 can be any type of microcomputer system you might need.

In the blue collar family, the AIM 65/40 microcomputer provides more power, greater flexibility, for more applications.


## 0 Rockwell

## A65/40-8X15 AIM 65/40 SERIES 8000 MICROCOMPUTER SYSTEM

## OVERVIEW

The AIM 65/40 Series 8000 Microcomputer System is a powerful, 8-bit R6502 CPU based microcomputer with a complete complement of RAM, ROM and I/O capacity-packaged in an attractive professional desk-top enclosure and ready for use in a wide range of OEM and end-user applications. Four models offer either a built-in 40-character single line display or an 80character $\times 25$ line video display controller with each display model available with an internal graphics printer or a Centronics type printer interface.

ROM-based disk operating system, input/output functions, debug monitor, text editor, R6500 assembler, and BASIC interpreter provide both standalone software development capability and run-time environment. Application programs developed and/or executed on a Series 8000 microcomputer can meet requirements for low cost, high performance applications such as data acquisition and logging, instrumentation, medical analysis, environmental monitor, scientific calculation, and automatic test equipment in office, laboratory, or light industrial environments.


A65/40-8515 Microcomputer System

## FEATURES

- Integrated, complete and expandable microcomputer system
-AIM 65/40 single board microcomputer with all its features and populated with 48 K bytes RAM and 24 K bytes ROM
-AIM 65/40 extended keyboard with 57-key main keyboard, 15-key numeric and cursor control keyboard, 8 function keys and separate RESET and ATTN keys
-RM 65 card cage with two available slots for user expansion
-RM 65 floppy disk controller for interfacing with up to four $51 / 4^{\prime \prime}$ double-density floppy disk drives
-Internal power supply with user expansion capacity
- Four models to choose from
-Optional single line display or video display controller (VDC)
-Optional graphics printer or Centronics printer interface
- Fully contained in attractive, professional enclosure
-Attractive, stylized two-piece design
-Strong, injection molded ABS plastic construction
-Complementary two-tone color (sand with brown trim)
-Swing-open top for easy access to internal components
-Separate floating keyboard assembly
- Hardware and software expansion options
-RM 65 input/output, controller and memory modules
-Disk- and ROM-based language assemblers, compilers and/or interpreters
- ROM-resident firmware for immediate operation
—Bootstrap disk operating system (BDOS 1.0)
-User accessible I/O subroutines
—Debug monitor/text editor
—R6500 assembler
-8K BASIC interpreter

ORDERING INFORMATION

| Part No: | Description |
| :---: | :--- |
| A65/40-8215 | AIM 65/40 with VDC, Extended Keyboard, 48K <br> RAM, BASIC Interpreter, Assembler, BDOS 1.0, <br>  <br> FDC \& 2 Expansion Slots |
| A65/40-8315 | Same as A65/40-8215 with Graphics Printer <br> A65/40-8415 <br>  <br>  <br>  <br> AIM 65/40 with 40-Character Display, Extended <br> Keyboard, 48K RAM, BASIC Interpreter, <br> Assembler, BDOS 1.0, FDC \& 2 Expansion Slots |
| A65/40-8515 | Same as A65/40-8415 with Graphics Printer |

## HARDWARE DESCRIPTION

The AIM 65/40 Series 8000 Microcomputer System is fully packaged in a two-unit injection-molded ABS plastic enclosure. The Main Unit houses the Single Board Computer (SBC) module, power supply, RM 65 4-Slot Card Cage and adapter, Single Line Display or Video Display Controller (VDC) module, Graphics Printer or Centronics Printer Interface adapter; and interconnect cabling. The hinged front panel swings forward revealing internal components thus allowing convenient switch setting and PROM/ ROM installation for custom applications. The rear section is easily removed to access the RM 65 Card Cage for installation of RM 65 expansion modules. Cables from external peripherals and equipment connect directly to connectors mounted on the back panel.

The detached Keyboard Unit houses the AIM 65/40 Extended Keyboard and is connected to the Main Unit by a retractable cable for flexible positioning on the work surface.

## SBC Module

The SBC module contains an R6502 CPU, a 1 MHz clock circuit, on-board device decoders, interrupt request priority circuit, reset conditioning, 32K bytes PROM/ROM sockets and 48K bytes RAM. 24K bytes of ROM are installed with two 4 K -byte sockets available for user PROM/ROM installation. All on-board memory may be enabled in 4 K -byte blocks, yielding an optimal mix of on-board/off-board memory and V/O to be addressed. The RAM may also be write-protected in 8K-byte segments. Dual bank addressing allows an additional 56K bytes of memory or I/O to be accessed off-board.

## Video Display Controller (Models -8215 and -8315)

The Video Display Controller (VDC) interfaces the SBC module to a CRT monitor by generating a composite video output signal which is routed to a BNC connector on the back panel. Controlled by a separate microprocessor, built-in commands in
either text or graphics mode provide flexible text handling and screen editing as well as full graphics line drawing and display functions.

In the text mode, a screen format of 80 characters $\times 24$ lines is automatically selected. A $40 \times 24$ format is also available and other formats are user programmable. Eight pages of text are available in the $80 \times 24$ format with automatic page sizing for other formats. A 4K-byte character generator ROM contains bit patterns for 256 different characters in a $7 \times 10$ dot matrix field. Standard characters include upper- and lower-case alphabetics, numerals (including subscripts and superscripts), math and Greek symbols, common European letters, and semigraphic characters.

The full graphics mode incorporates bit mapping of $280 \times 224$ pixels, which is compatible with the Graphics Printer. Line drawing commands move a pen and draw or erase lines using either relative or absolute position reference. Data byte capability allows individual dots to be controlled using a 40 bytes per dot line format (seven dots per byte).

## Graphics Printer (Models -8315 and -8515)

The Graphics Printer is a dot matrix thermal printer with two modes operation: text and graphics. In the text mode, up to 40 characters per line can be printed using $7 \times 8$ dot matrix characters. 256 pre-defined upper and lower case letters, numbers including superscripts and subscripts, math symbols, and common European and Greek letters are included in the controller ROM. Text is printed at a fast 240 lines per minute. In the graphics mode, all 280 horizontal dots in a row are individually controlled, and any number of rows may be printed.

The printer includes a dedicated microprocessor-based controller which operates the printer motor and thermal head timing and control functions independently from the SBC module thus relieving the SBC module from time consuming peripheral control functions.


A65/40-8515 Microcomputer System-Front Cover Open


AIM 65/40 Series 8000 Microcomputer System Block Diagram

Parallel Application Connector (J1) Pin Assignments

| Pin | Signal | 1/0 | Type | Pin | Signal | Type |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | CB2 | 1/0 | NMOS | 2 | NC/+5V* | Power |
| 3 | CB1 | 1/0 | NMOS | 4 | GND | Power |
| 5 | PB7 | 1/0 | NMOS | 6 | GND | Power |
| 7 | PB6 | 1/0 | NMOS | 8 | GND | Power |
| 9 | PB5 | 1/0 | NMOS | 10 | GND | Power |
| 11 | PB4 | 1/0 | NMOS | 12 | GND | Power |
| 13 | PB3 | 1/0 | NMOS | 14 | GND | Power |
| 15 | PB2 | 1/0 | NMOS | 16 | GND | Power |
| 17 | PB1 | 1/0 | NMOS | 18 | GND | Power |
| 19 | PBO | 1/O | NMOS | 20 | GND | Power |
| 21 | PA7 | 1/0 | NMOS | 22. | GND | Power |
| 23 | PA6 | 1/0 | NMOS | 24 | GND | Power |
| 25 | PA5 | 1/0 | NMOS | 26 | GND | Power |
| 27 | PA4 | 1/0 | NMOS | 28 | GND | Power |
| 29 | PA3 | 1/0 | NMOS | 30 | GND | Power |
| 31 | PA2 | 1/0 | NMOS | 32 | GND | Power |
| 33 | PA1 | 1/0 | NMOS | 34 | GND | Power |
| 35 | PAO | 1/0 | NMOS | 36 | GND | Power |
| 37 | CA2 | 1/0 | NMOS | 38 | GND | Power |
| 39 | CA1 | 1 | NMOS | 40 | NC/+5V* | Power |

Serial RS-232C Application Connector (J2) Pin Assignments

| Pin | Signal | I/O | Type | Pin | Signal | I/O | Type |
| ---: | :--- | ---: | :---: | :---: | :--- | :---: | :---: |
| 1 | GND |  | Power | 2 | TD | O | RS-232C |
| 3 | RD | I | RS-232C | 4 | RTS | I/O | RS-232C |
| 5 | CTS | I/O | RS-232C | 6 | DSR | //O | RS-232C |
| 7 | GND |  | Power | 8 | DCD | I/O | RS-232C |
| 9 | NC |  |  | 10 | NC |  | RS-232C |
| 11 | NC |  |  | 12 | NC |  |  |
| 13 | NC |  |  | 14 | NC |  |  |
| 15 | NC |  |  | 16 | NC |  |  |
| 17 | NC |  |  | 18 | NC |  |  |
| 19 | NC |  |  | 20 | DTR | //O |  |
| 21 | NC |  |  | 22 | NC |  | RS-232C |
| 23 | NC |  |  | 24 | NC |  |  |
| 25 | NC |  |  | 26 | NC |  |  |

Audio/20 mA Current Loop Connector (J3) Pin Assignments

| Pin | Signal | I/O | Type | Pin | Signal | Type |
| ---: | :--- | :---: | :--- | :---: | :---: | :---: |
| 1 | TTY RTS | 1 | TTY | 2 | GND | Power |
| 3 | TTY TD | O | TTY | 4 | GND | Power |
| 5 | TTY RD | 1 | TTY | 6 | GND | Power |
| 7 | TTY RTN |  | Power | 8 | GND | Power |
| 9 | AUDIO OUT | 1 | TTL | 10 | GND | Power |
| 11 | AUDIO IN | O | TTL | 12 | GND | Power |
| 13 | CTRL 2 RTN | O | Relay | 14 | GND | Power |
| 15 | CTRL 2 | 1 | Relay | 16 | GND | Power |
| 17 | CTRL 1 RTN | O | Relay | 18 | GND | Power |
| 19 | CTRL 1 | 1 | Relay | 20 | GND | Power |

Printer Connector (J7) Pin Assignments

| Pin | Signal | I/O | Pin | Signal | I/0 |
| :---: | :---: | :---: | :---: | :--- | :---: |
| 1 | STROBE | 0 | 6 | DATA 5 | 0 |
| 2 | DATA 1 | 0 | 7 | DATA 6 | 0 |
| 3 | DATA 2 | 0 | 8 | DATA 7 | 0 |
| 4 | DATA 3 | 0 | 10 | $\overline{\text { ACK }}$ | 1 |
| 5 | DATA 4 | 0 | $9,11-18$ | NC |  |
|  |  |  | $19-2$ | GND |  |

## Centronics Printer Interface (Models -8215 and -8415)

The Centronics Printer Interface connector adapter buffers the external printer output signals from the SBC module and routes the signals to the Printer connector on the back panel.

## 40-Character Display (Models -8415 and -8515)

The 40-Character Display includes a vacuum fluorescent display and a dedicated microprocessor-based controller. The vacuum fluorescent display is a single sealed unit containing 40 separately controllable digits. Each digit is composed of a 16segment font which illuminates a full set of upper case alphabetics, numerics, and special characters. In the semi-graphics mode, the 16 segments for each digit are individually controlled. In addition, each digit includes a separate decimal point. When energized, the digits form bright, crisp characters in a bluegreen color.

## Extended Keyboard

The Extended Keyboard contains a 57-key full-size terminal style alphanumeric keyboard with locking SHIFT key, a 15-key numeric and cursor control keyboard, eight function keys, and separate RESET and ATTN keys.

## SOFTWARE DESCRIPTION

Standard ROM-based software in the Series 8000 Microcomputer System provides either immediate development capability in BASIC and R6500 assembly language or automatic application program startup in a run-time environment. Program initiation can be performed either in a PROM/ROM-based application program or in RAM after an automatically initiated load of the application program from floppy disk. The ROMs installed in each Series 8000 systems are:

- AIM 65/40 VO ROM
- AIM 65/40 Bootstrap Disk Operating System Version 1.0 (BDOS 1.0)
- AIM 65/40 Debug Monitor/Text Editor
- AIM 65/40 BASIC Interpreter
- AIM 65/40 Assembler


## I/O ROM

The I/O ROM includes preprogrammed auto-start initialization, interrupt, input/output and utility functions which support userdefined programs as well as Series 8000 standard firmware and optional firmware/software. Auto-start initialization jumps to predetermined PROM/ROM addresses during RESET processing. The application program can assume direct control of the system for continued operation, or it can just initialize required functions, then return control back to the I/O ROM for continued auto-start of other functions. VO drivers directly support intelligent display and printer peripherals. Other drivers support the RS-232C/ 20MA interfaces and the audio cassette ports, and control the on-board speakers.

## BDOS 1.0

The BDOS 1.0 ROM provides disk and file management functions as well as automatic loading of a bootstrap loader from
disk for load and go program execution. BDOS functions open, close, read and write program and data files under operator or program control. User-friendly prompts, displayed at the Debug Monitor, Text Editor, BASIC, and Assembler command level messages, simplify operator initiation and monitoring of disk and file operations. Disk-oriented functions include format a disk and list the directory for all files on the disk. File-oriented functions include list, delete and recover a named file.

When the BASIC ROMs are installed, the microcomputer automatically initializes to the BASIC command level unless overridden by an application program auto-start sequence. Easy entry to the Debug Monitor and Text Editor command levels allow machine level debugging, assembler selection and text entry/editing.

## Debug Monitor/Text Editor ROMs

The Debug Monitor/Text Editor includes a wide selection of functions to simplify computer program entry and checkout. Text can be easily entered, edited, saved and retrieved using either line- or screen-oriented commands in the Text Editor. A character cursor can be positioned left, right, up, or down to aid character insertion, addition, and deletion. Automatic and selective character string change capability makes block changes as desired. Multiple text buffers can easily be maintained for separate program and data files.

The Debug Monitor controls program execution in single step and run modes and allows convenient examination and altering of memory and registers. Single step mode disassembles instructions and traces register contents upon command for detail examination of program operation. Symbol level debugging reduces dependence on absolute addresses and simplifies program checkout. Command string capability allows command sequences to be chained and easily repeated.

## BASIC ROMs

The 8K Microsoft-developed BASIC Interpreter implements an industry standard high level language which is simple but powerful and is commonly used in industry, science and schools.

BASIC operates in one of two modes, development and runtime. In the development mode, BASIC statements are entered and executed as either direct or indirect commands. Direct commands are executed upon entry to provide immediate results, however, the statements are not stored for subsequent execution. Indirect commands are entered along with an associated line number and are executed upon RUN command entry or application program auto-start initialization. Indirect statements can also be loaded into the Text Editor for entry into BASIC to simplify program editing. The microcomputer peripherals, i.e., keyboard, 40 -character single line display/video display and printer, are used in the development mode to enter statements, to list entered indirect statements and to display/print execution results.

## Assembler ROM

The assembler translates computer program instructions written in R6500 assembly language for the 6502 microprocessor into machine code that will operate either in the Series 8000 Microcomputer System or in any 65XX CPU-based microcomputer. Operating options are selected interactively by the operator
upon assembly command. These options specity source code device, object code device, symbol table location, full assembly or errors only output listing and output listing device. A repeat command invokes the assembly according to previously commanded options for rapid setup during program debugging; editing and reassembly. Memory to memory assembly is supported to speed program generation.

MEMORY MAP

## SOFTWARE OPTIONS

| Part No. | Description |
| :---: | :--- |
| Disk-Based ${ }^{(1)}$ |  |
| A65/40-7012 | AIM 65/40 Macro Assembler and Linking Loader |
| A65-40/7024 | AIM 65/40 BASIC Compiler |
| A65/40-7052 | AIM 65/40 FORTH Compiler |
| ROM-Based |  |
| A65/40-7040 | AIM 65/40 Math Package ROM |
| A65/40-7050 | AIM 65/40 FORTH ROMs |

Note: Provided a $5 \frac{1}{4}$-inch double-density floppy disk compatible with AIM 65/40 BDOS 1.0.

## SPECIFICATIONS

| Parameter | Value | Parameter | Value |
| :---: | :---: | :---: | :---: |
| Dimensions |  | Electrical (cont.) |  |
| Main Enclosure |  | J3 (Audio/20 mA Current Loop) | 20-pin mass terminated connector (3M\#3421-7020 or equivalent) |
| Width | $17.00 \mathrm{in}.(43.2 \mathrm{~cm})$ |  |  |
| Length Height | $\begin{aligned} & 7.75 \mathrm{in} .(19.7 \mathrm{~cm}) \\ & 2.26 \mathrm{in} .(5.8 \mathrm{~cm}) \end{aligned}$ | J 4 (Composite Video) | RCA BNC type (Allied \#60BB or equivalent) |
| Keyboard Enclosure |  | J5 (Floppy Disk Drive) | 34-pin mass terminated connector <br> (3M \#3414-6034 or equivalent) |
| Width Length Height | 17.00 in . ( 43.2 cm ) $17.68 \mathrm{in} .(44.9 \mathrm{~cm})$ 6.00 in . $(15.2 \mathrm{~cm})$ | J7 (Printer) | 36-pin mass terminated connector 3M\#3366-1001 or equivaient |
| Environment |  | Power Connector | 3-Prong Recessed Grounding Plug |
| Operating Temperature |  |  | (NEMA 5-15P) |
| With Printer Without Printer | $0^{\circ} \mathrm{C}$ to $50^{\circ} \mathrm{C}$ $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | Power Cord Type |  |
| Storage Temperature |  | Type Length | Detachable, 3-Conductor 6 Feet |
| With Printer | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | Rating | $125 \mathrm{Vac}, 15 \mathrm{~A}$ Service |
| Without Printer | $-25^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ | Line End | Molded Vinyl Grounding Plug |
| Relative Humidity | 0\% to 85\% (without condensation) | Microcomputer End | Molded Vinyl Grounding Receptacle |
| Electrical |  | AC Power Requirement |  |
| Interface Connectors (Back Panel) |  | Input Voltage Fuse | $115 \mathrm{Vac} \pm 10 \%, 47-63 \mathrm{~Hz}$ $230 \mathrm{Vac}, 3 \mathrm{~A}$, Slo-Blo |
| $J 1$ (Parallel Application) | 40-pin mass terminated connector (3M\#3417-7040 or equivalent) |  |  |
| J2 (Serial RS-232C Application) | 25 -pin Delta connector 3M\#3482-1000 or equivalent) |  |  |



# A65/40-2000, -3000, -4000 and -5000 AIM 65/40 MICROCOMPUTER 

## OVERVIEW

The AIM 65/40 microcomputer integrates the AIM $65 / 40 \mathrm{mod}-$ ular components-Single Board Computer (SBC), 40-Character Display or Video Display Controller (VDC) module, Graphics Printer, and a Standard or Extended Keyboard-into a complete self-contained system including an application-oriented I/O ROM and a ROM resident operator-oriented Debug Monitor/ Text Editor. The display and printer modules are mounted onto the SBC while the keyboard is detached-all peripherals are connected through removable 40 -conductor ribbon cables. The peripherals can easily be relocated to other positions to satisfy unique installation requirements.

In its integrated form, a desk-top installation of the AIM 65/40 microcomputer system can perform a wide range of specialized data acquisition, data reduction, control, and monitor functions in either OEM or end-user configurations. As a development tool, the system can support software developed in either assembly or high level language for operation in AIM 65/40 or RM 65 based microcomputers at a fraction of the cost of other systems.

As an advanced generation of the popular AIM 65 microcomputer, the separate AIM 65/40 assemblies provide increased processing throughput, improved keyboard, display and printer modules, and expanded application interfaces. The 6502 CPUbased AIM 65 Single Board Computer, with a full address complement of memory capacity on-board, extremely flexible I/O, and interrupt driven I/O handlers in firmware, is the heart of the AIM 65/40 microcomputer system. The AIM 65 Graphics Printer, with its separate microcomputer controller, prints 40 columns of characters using a complete set of upper and lower case alphabetic, numeric, semi-graphic, and special characters in the text mode at 240 lines per minute, and also provides a full graphics mode of 280 dots by $n$ rows. The AIM 65/40-Character Display, with its own microprocessor-based controller, features an easy-to-read fluorescent display, and provides a full complement of alphanumeric and special characters as well as internal editing, scrolling, and blinking functions. The terminal-style AIM 65 Standard Keyboard contains a full-size main keyboard plus a separate row of eight dedicated function keys and isolated RESET and ATTN keys.

The system comes with a 4 K -byte I/O ROM and an 8 K -byte interactive debug monitor and text editor. Optional assembler and common high level language compilers/interpreters improve programmer productivity, increase program reliability, and simplify program maintenance. ROM-based firmware includes a disk operating system, symbolic assembler, universally accepted BASIC interpreter, and a highly efficient FORTH system with resident compiler, interpreter, and macro assembler. Optional disk-based software includes a macro assembler, BASIC compiler and FORTH target compiler.

FEATURES<br>- Single Board Computer with extensive memory and I/O<br>-6502 CPU<br>- 131K addressing, in Two 65K-byte banks<br>-Up to 48 K -bytes of on-board RAM, with write-protect<br>-Up to 32K-bytes of on-board PROM or ROM<br>-User-Prioritized Interrupts, up to six levels<br>-User-Dedicated parallel I/O interface<br>-User-Dedicated RS-232C serial interface<br>-Audio cassette/TTY ( 20 mA current) interface<br>-RM 65 bus expansion interface<br>- Graphics Printer<br>-Text mode provides upper/lower case alphanumerics, Math, and Special Characters at 240 lines/minute<br>-Full graphics mode provides 280-dot resolution<br>-Quiet, reliable thermal operation<br>- 40-Character Display<br>-Full upper case alphanumeric and special characters<br>-Bright, crisp vacuum fluorescent display<br>-Display, edit, auto-scroll, and character blinking functions<br>- Full-Size Terminal-Style Standard Keyboard<br>-57 keys, including locking ALL CAPS key<br>-Eight user function keys, plus ATTN and RESET<br>- 1<br>I/O ROM<br>-Auto-start initialization<br>- Interrupt-driven peripheral I/O handling<br>-RAM vectored I/O with expansion hooks<br>-General purpose I/O and utility subroutines<br>- ROM-Resident Interactive Debug Monitor<br>-Accepts instructions in mnemonic form<br>-Machine level debug functions<br>-Command file for automatic command execution<br>- ROM-Resident Text Editor<br>-Line and screen oriented commands<br>-Read, list, insert, delete functions<br>-Cursor control functions<br>- Automatic and manual block change functions<br>- Extensive Documentation<br>- Comprehensive user's manual<br>—//O ROM and Monitor/Editor assembly listings<br>-Programming and hardware manual<br>-Summary booklet and wall schematic



A65/40-5000 AIM 65/40 Microcomputer
ORDERING INFORMATION

| Mlcrocomputers |  |
| :---: | :---: |
| Part No. | Description |
| A65/40-2000 | AIM 65/40 SBC with 32K RAM, Monitor |
|  | ROMs, Extended Keyboard, and VDC |
|  | Module |
| A65/40-3000 | AlM 65/40 SBC with 32K RAM, Monitor |
|  |  |
|  | Graphics Printer |
| A65/40-4000 | AIM 65/40 SBC with 32K RAM Monitor ROMs, |
|  | Standard Keyboard and 40 Char. Display |
| A65/40-5000 | AIM 65/40 with 32K RAM Monitor ROMs, |
|  | Standard Keyboard, 40 Char. Display and |
|  | Graphics Printer |
|  |  |

Firmware Options

| Part No. | Description |
| :--- | :--- |
| A65/40-7010 | AIM 65/40 Assembler ROM |
| A65/40-7020 | AIM 65/40 BASIC Interpreter ROMs |
| A65/40-7040 | AIM 65/40 Math Package ROM |
| A65/40-7050 | AIM 65/40 FORTH ROMs |
| A65/40-7090 | AIM 65/40 Disk Operating System Version 1.0 |
| A65/40-7092 | (DOS 1.0) ROM |
|  | AIM 65/40 Bootstrap Disk Operating System |
|  | Version 1.0 (BDOS 1.0) ROM |

Software Options (51/4" Disks)

| Part No. | Description |
| :---: | :---: |
| A65/40-7012 | AIM 65/40 Macro Assembler and Linking Loader ${ }^{(1)}$ |
| A65/40-7024 | AIM 65/40 BASIC Compiler Disk ${ }^{(2)}$ |
| A65/40-7052 | AIM 65/40 FORTH Target Compiler ${ }^{(2)}$ |
| Notes: <br> 1. Requires RM 65 FDC Module (RM65-5101E) and A65/40-7092 BDOS 1.0 ROM. <br> 2. Requires RM 65 FDC Module (RM65-5101E) and either A65/40-7090 DOS 1.0 or A65/40-7092 BDOS 1.0 ROM. |  |
|  |  |
|  |  |

## FUNCTIONAL DESCRIPTION

## SINGLE BOARD COMPUTER (SBC) MODULE

The A65/40-1000 SBC Module contains an R6502 CPU, a 1 MHz clock circuit, on-board device decoders, interrupt request priority circuit, reset conditioning, and both PROM/ROM and RAM memory. On-board sockets accept up to 65 K bytes of read-only and read/write memory. Up to 32K bytes of PROM/ ROM and up to 48 K bytes of RAM may be installed. All on-board memory may be enabled in 4K-byte blocks, yielding an optimal mix of on-board/off-board memory and $\mathrm{I} / \mathrm{O}$ to be addressed. The RAM may also be write-protected in 8 K -byte segments. Dual bank addressing allows an additional 56 K bytes of memory or I/O to be accessed off-board.

The SBC module is connected by removable cables to the 40Character Display and the Graphics Printer over identical Centronics type parallel handshaking interfaces. The SBC is also connected to the Standard Keyboard through a removable interface cable. These peripheral ports may be also used as general purpose bi-directional data ports with parallel, serial, interrupt, and timer capabilities controlled by user programming of two onboard R6522 Versatile Interface Adapter (VIA) devices.

A separate user-dedicated R6522 VIA interfaces with the Parallel I/O Connector. The high current drive capacity of the VIA's eight " $B$ " port lines can directly drive many industry-standard devices, such as solid state relays. The RS-232C connector provides an interface that allows the SBC to function as a data set or data terminal. An Audio/TTY Connector interfaces to one or two audio cassette recorders and to a 20 mA current loop serial interface.

An Expansion Connector extends the system bus to Rockwell RM 65 bus compatible memory, I/O, or peripheral controller modules. Up to six levels of interrupt priority may be assigned to on-board and off-board peripherals.

## STANDARD KEYBOARD

The A65/40-0200 Standard Keyboard is a full-size terminal style alphanumeric keyboard containing 66 momentary contact single pole single throw (SPST) keys and one locking SPST key. The keyboard has a complement of 63 momentary contact keys in an $8 \times 9$ matrix with nine positions unused. An ALL CAPS locking key is also in this matrix. Nine strobe and eight return lines are used to determine which key is pressed. Three momentary contact keys-RESET, ATTN, and PAPER FEED are outside of the keyboard matrix. These key switches have dedicated returns.

## EXTENDED KEYBOARD

The A65/40-0210 Extended Keyboard has the added features of an industry standard numeric keyboard and cursor control keys.


## GRAPHICS PRINTER

The A65/40-0600 Graphics Printer includes a dot matrix thermal printer mechanism, a microcomputer controller, thermal head drivers, and motor/strobe timing circuitry.

The printer mechanism includes a thermal head, platen, motor drive linkage, and associated wiring. There are 40 thermal elements on the thermal head, each of which spans seven dot fields; each element is a discrete point which rides against heat sensitive paper. Control logic turns on the thermal head drivers to heat the sensitized paper when a dot is to be printed. During a print cycle, the thermal head moves horizontally across the paper; when an entire row of dots has been printed, the printer motor advances the platen by one horizontal row of dots.

The printer controller includes an R6504 CPU, 4K-byte ROM, RAM, I/O, timer, clock, and reset circuitry. The ROM contains both the CPU instructions and the individual character bit patterns. The controller performs printer motor and thermal head timing and control functions to enable the printer to operate independently from the SBC module.

Data and control commands are transmitted to the printer over the Centronics type parallel handshake interface. An internal buffer accepts up to 80 bytes for printing. The controller automatically prints the first $407 \times 8$ dot-matrix characters in the text mode or after receiving a row of 280 dots in the graphics mode. The paper can also be advanced with a paper feed command, or manually using the paper feed switch.

## 40-CHARACTER DISPLAY

The A65/40-0400 40-Character Display contains a vacuum fluorescent display, a microprocessor-based controller, a 2 K -byte character font/program ROM, character and segment drivers, and a $D C / D C$ power converter. The vacuum fluorescent display is a single sealed unit containing 40 separately controllable digits. Each digit is composed of a 16 -segment font which allows a full set of upper case alphabetics, numerics, and special characters to be displayed. In the semi-graphics mode, the 16 segments of each digit are individually controlled. In addition, each digit includes a separate decimal point. When energized, the digits form bright, crisp characters in a blue-green color.

## VIDEO DISPLAY CONTROLLER (VDC) MODULE

The A65/40-0800 Video Display Controller (VDC) module interfaces the AIM 65/40 microcomputer to either a CRT monitor or TV receiver. The module connects to the AIM 65/40 SBC module display connector (J5) and interfaces to the display through either the composite video output or the separate HSYNC, VSYNC, and VIDEO output TTL compatible signals. With its integral microcomputer controller, built-in commands provide selectable and programmable screen formatting, flexible text handling and editing, and full graphics drawing and data display functions. In the text mode, preprogrammed formats of 80 characters $\times 24$ lines or 40 characters $\times 24$ lines are selectable. Other formats are user programmable. The full graphics mode incorporates bit mapping of $280 \times 224$ pixels, which is compatible with the Graphics Printer.

## I/O ROM

The I/O ROM includes preprogrammed auto-start initialization, interrupt, input/output and utility functions which support userdefined programs as well as AIM 65/40 optional firmware/software. Auto-start initialization jumps to predetermined PROM/ ROM addresses during RESET processing. The application program can assume direct control of the system for continued operation, or it can just initialize required functions, then return control back to the I/O ROM for continued auto-start of other functions.

I/O drivers directly support AIM 65/40 intelligent display and printer peripherals. Other drivers support the RS-232C/TTY interfaces, the audio cassette ports and control the on-board speaker.

## DEBUG MONITOR/TEXT EDITOR

The Debug Monitor/Text Editor includes a wide selection of functions to simplify computer program entry and checkout. Text can be easily entered, edited, saved, and retrieved using either line or screen oriented commands in the Text Editor. A character cursor can be positioned left, right, up, or down to aid character insertion, addition, and deletion. Automatic and selective character string change capability makes block changes as desired. Multiple text buffers can easily be maintained for separate program and data files.

The Debug Monitor controls program execution in single step and run modes and allows convenient examination and altering of memory and registers. Single step operation àllows instruction and register trace for detail examination of executed instructions. Symbol level debugging reduces dependence on absolute addresses and simplifies program checkout.

## DEBUG MONITOR COMMANDS

## Monitor Control Commands

| CTRL RESET | Enter and Initialize Monitor (Cold Reset) |
| :--- | :--- |
| RESET | Enter Monitor (Warm Reset) |
| ATTN | Non-Maskable Interrupt |
| ESC | Escape to Monitor Command Level |
| E | Initialize Text Buffer and Enter Text Editor |
| C | Recover Text Buffer and Enter Text Editor |
| T | Reenter Text Editor |
| F1-F8 | Enter Function 1 - Function 8 |
| + | Repeat Last Command |
| $\&$ | Execute Command String |
| O | Toggle Memory Bank |
| CTRL Z | Direct Peripheral Control |
| CTRL Z CTRL Z | SBC Module RAM Self Test |
| CTRL C | Clear Display And Home Cursor |
| CTRL N | Home Cursor |

## Display/Alter Registers

| R | Display Register Contents |
| :--- | :--- |
| A | Display/Atter Accumulator |
| P | Display/Atter Processor Status |
| S | Display/Ater Stack Pointer |
| X | Display/Alter $\times$ Register |
| Y | Display/Alter Y Register |
| $*$ | Display/Alter Program Counter |


| Display/Alter Memory |  |
| :--- | :--- |
| M | Display Selected Memory Contents |
| SPACE | Display Higher Memory Locations |
|  | Display Lower Memory Locations |
|  | Alter Current Memory Contents |

## Enter/Disassemble Instructions

| I | Enter Mnemonic Instruction |
| :--- | :--- |
| K | Disassemble Memory |
| ; | Enter Symbolic Address |

## Execution/Trace

| G | Execute Program |
| :--- | :--- |
| Z | Toggle Instruction Trace |
| J | Display Register Heading |
| H | Display Jump and Branch History |
| V | Toggle Symbol Table On/Off |

## Breakpoint Manipulation

| $?$ | Display Breakpoints |
| :--- | :--- |
| $\#$ | Clear Breakpoints |
| 4 | Toggle Breakpoint Enable On/Off |
| B | Set Breakpoint |

## Load/Dump Memory

| L | Load Memory |
| :--- | ---: |
| D | Dump Memory |
| F | Verify Memory |

Peripheral Control

| CTRL P | Toggle Auto-Print On/Off |
| :---: | :---: |
| PRINT | Print Display Contents |
| 1 | Toggle Recorder 1 Control On/Off |
| 2 | Toggle Recorder 2 Control On/Off |
| 3 | Verify Tape Checksum |
| Screen Oriented Commands |  |
| F1 (or CTRL Q) | Home Cursor on Line |
| F2 (or CTRL R) | Clear Line to Right |
| F3 (or CTRL S) | Toggle Insert Mode On/Off |
| F4 (or CTRL T) | Delete Character Under Cursor |
| F5 (or CTRL U). | Move Cursor Left (Left Arrow) |
| F6 (or CTRL V) | Move Cursor Right (Right Arrow) |
| F7 (or CTRL W) | Move Line/Cursor Down (Down Arrow) |
| F8 (or CTRL X) | Move Line/Cursor Up (Up Arrow) |
| CTRL A | Add (Insert) a Line |
| CTRL B | Break a Line |
| CTRL D | Delete a Line |

## TEXT EDITOR COMMANDS

## Editor Control Commands

| S | Enter Screen Edit Mode |
| :--- | :--- |
| Q | Quit Editor and Enter Monitor |
| ESC | Return to Editor Command Level |
| + | Repeat Last Command |
| CTRL C | Clear Display and Home Cursor |
| CTRL N | Home Cursor |

## Line Oriented Commands

| L | List Multiple Lines |
| :--- | :--- |
| R | Read Multiple Lines |
| I | Insert One Line |
| O | Overlay Current Line |
| K | Delete Multiple Lines |
| (SPACE) | Display Current Line |
| $?$ | Display Current and Last Line Addresses |
| G | Go to Line Number |
| U | Go up Multiple Lines |
| D | Go down Multiple Lines |
| T | Go to Top Line |
| B | Go to Bottom Line |
| F7 (or CTRL W) | Go Down One Line |
| F8 (or CTRL X) | Go Up One Line |



Notes:
(1) AIM 65/40 System peripheral VO addresses are assigned to FF80-FFDF.
(2) User available during application program operation if the debug and text editor functions are not used.
(3) User available if the optional language and the RM 65 expansion module ROMs are not used.
(4) Requires RM65-5101E Floppy Disk Controller (FDC) module.
(5) 56 K bytes of RAM ( 0 - \$DFFF) is available for disk-based assemblericompilers and user programs. VO ROM and BDOS 1.0 ROM require 8 K bytes (\$E000-SFFFF).

SBC Module Connector J1 (Parallel Application) Pin Assignments

| Pin | Signal | 1/0 | Type | Pin | Signal | Type |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | CB2 | IO | NMOS | 2 | $\mathrm{NC} /+5 \mathrm{~V}^{*}$ | Power |
| 3 | CB1 | $1 / 0$ | NMOS | 4 | GND | Power |
| 5 | PB7 | 1/0 | NMOS | 6 | GND | Power |
| 7 | PB6 | $1 / \mathrm{O}$ | NMOS | 8 | GND | Power |
| 9 | PB5 | I/O | NMOS | 10 | GND | Power |
| 11 | PB4 | I/O | NMOS | 12 | GND | Power |
| 13 | PB3. | $1 / 0$ | NMOS | 14 | GND | Power |
| 15 | PB2 | 1/0 | NMOS | 16 | GND | Power |
| 17 | PB1 | $1 / 0$ | NMOS | 18 | GND | Power |
| 19 | PB0 | I/O | NMOS | 20 | GND | Power |
| 21 | PA7 | 1/O | NMOS | 22 | GND | Power |
| 23 | PA6 | $1 / 0$ | NMOS | 24 | GND | Power |
| 25 | PA5 | $1 / 0$ | NMOS | 26 | GND | Power |
| 27 | PA4 | $1 / 0$ | NMOS | 28 | GND | Power |
| 29 | PA3 | IO | NMOS | 30 | GND | Power |
| 31 | PA2 | 1/0 | NMOS | 32 | GND | Power |
| 33 | PA1. | 1/O | NMOS | 34 | GND | Power |
| 35 | PAO | I/O | NMOS | 36 | GND | Power |
| 37 | CA2 | 1/0 | NMOS | 38 | GND | Power |
| 39 | CA1. | I | NMOS | 40 | $\mathrm{NC} /+5 \mathrm{~V}^{*}$ | Power |

SBC Module Connector J2
(Serial Application) Pin Assignment

| Pin | Signal | I/O | Type | Pin | Signal | I/O | Type |
| ---: | :--- | :--- | :--- | ---: | :--- | :--- | :---: |
| 1 | GND |  | Power | 2 | TD | O | RS-232C |
| 3 | $\overline{\text { RD }}$ | 1 | RS-232C | 4 | RTS | I/O | RS-232C |
| 5 | CTS | I/O | RS-232C | 6 | DSR | I/O | RS-232C |
| 7 | GND |  | Power | 8 | DCD | I/O | RS-232C |
| 9 | NC |  |  | 10 | NC |  |  |
| 11 | NC |  |  | 12 | NC |  |  |
| 13 | NC |  |  | 14 | NC |  |  |
| 15 | NC |  |  | 16 | NC |  |  |
| 17 | NC |  |  | 18 | NC |  |  |
| 19 | NC |  |  | 20 | DTR | I/O | RS-232C |
| 21 | NC |  |  | 22 | NC |  |  |
| 23 | NC |  |  | 24 | NC |  |  |
| 25 | NC |  |  | 26 | NC |  |  |

SBC Module Connector J3
(Audio/TTY) Pin Assignments

| Pin | Signal | I/O | Type | Pin | Signal | Type |
| ---: | :--- | :---: | :--- | :---: | :---: | :---: |
| 1 | TTY RTS | I | TTY | 2 | GND | Power |
| 3 | TTY TD | O | TTY | 4 | GND | Power |
| 5 | TTY RD | I | TTY | 6 | GND | Power |
| 7 | TTY RTN |  | Power | 8 | GND | Power |
| 9 | AUDIO OUT | I | TTL | 10 | GND | Power |
| 11 | AUDIO IN | O | TTL | 12 | GND | Power |
| 13 | CTRL 2 RTN | O | Relay | 14 | GND | Power |
| 15 | CTRL 2 | 1 | Relay | 16 | GND | Power |
| 17 | CTRL 1 RTN | O | Relay | 18 | GND | Power |
| 19 | CTRL 1 | 1 | Relay | 20 | GND | Power |

SBC Module Connector J4 (RM 65 Bus) Pin Assignments


SBC Module Connector J5 (Printer) Pin Assignments

| Pin | R6522 |  | Printer |  | Type | Pin | Signal | Type |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Signal | 1/0 | Signal | $1 / 0$ |  |  |  |  |
| 1 (1) | $+5 \mathrm{~V}$ | 0 | +5V | 0 | Power | 2 | GND | Power |
| 3 | NC |  | NC |  | - | 4 | - GND | Power |
| 5 | NC |  | NC |  | - | 6 | GND | Power |
| 7. | NC | \% | NC |  | - | 8 | GND | Power |
| 9 | NC |  | NC |  | - | 10 | - GND | Power |
| 11 | NC |  | NC |  | - | 12 | - GND | Power |
| 13 | NC |  | NC |  | - | 14 | GND | Power |
| 15 | PAPER FEED (2) |  | PAPER FEED (2) |  | TTL | 16 | GND | Power |
| 17 | RES | 0 | RES | 0 | TTL | 18 | GND | Power |
| 19 | PB1 | 1/0 | STROBE | 0 | NMOS | 20 | GND | Power |
| 21 | PA7 | $1 / 0$ | Data 7 | 0 | NMOS | 22 | GND | Power |
| 23 | PA6 | 1/0 | Data 6 | 0 | NMOS | 24 | GND | Power |
| 25 | PA5 | I/O | Data 5 | 0 | NMOS | 26 | GND | Power |
| 27 | PA4 | $1 / 0$ | Data 4 | 0 | NMOS | 28 | GND | Power |
| 29 | PA3 | 10 | Data 3 | 0 | NMOS | 30 | GND | Power |
| 31 | PA2 | 1/0 | Data 2 | 0 | NMOS | 32 | GND | Power |
| 33 | PA1 | 1/0 | Data 1 | 0 | NMOS | 34 | GND | Power |
| 35 | PAO | 1/0 |  | 0 | NMOS |  | GND | Power |
| 37 |  |  | $\mathrm{NC}$ |  | - | 38 | GND | Power |
| 39 | CA2 | 1/0 | $\overline{\text { ACK }}$ | 1 | NMOS | 40 (1) | $+5 \mathrm{~V}$ | Power |
| otes: | aximum +5 V curren onnected to J7-39 th | jnum | not exceed 200 mA |  |  |  |  |  |

SBC Module Connector J6 (Display) Pin Assignments

| Pin | R6522 |  | Printer |  | Type | Pin | Signal | Type |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Signal | 1/0 | Signal | 1/0 |  |  |  |  |
| . 1 (1) | +5V |  | $+5 \mathrm{~V}$ |  | Power | 2 | GND | Power |
| $\checkmark 3$ | NC |  | NC |  | - | 4 | GND | Power |
| 5 | NC |  | NC |  | - | 6 | GND | Power |
| 7 | NC |  | NC |  | - | 8 | GND | Power |
| 9 | NC |  | NC |  | - | 10 | GND | Power |
| 11 | NC |  | NC |  | - | 12 | GND | Power |
| 13 | NC |  | NC |  | - | 14 | GND | Power |
| 15 | PAPER FEED (2) |  | PAPER FEED (2) | 0 | TTL | 16 | GND | Power |
| 17 | RES |  | RES | 0 | TTL | 18 | GND | Power |
| 19 | PB0 | 1/0 | STROBE | 0 | NMOS | 20 | GND | Power |
| 21 | PA7 | 1/0 | Data 7 | 0 | NMOS | 22 | GND | Power |
| 23 | PA6 | 1/0 | Data 6 | 0 | NMOS | 24 | GND | Power |
| 25 | PA5 | I/O | Data 5 | 0 | NMOS | 26 | GND | Power |
| 27 | PA4 | 1/0 | Data 4 | 0 | NMOS | 28 | GND | Power |
| 29 | РА3 | 1/0 | Data 3 | 0 | NMOS | 30 | GND | Power |
| 31. | PA2 | 1/0 | Data 2 | 0 | NMOS | 32 | GND | Power |
| 33 | PA1 | 1/0 | Data 1 | 0 | NMOS | 34 | GND | Power |
| 35 | PAO | 1/0 | Data 0 | 0 | NMOS | 36 | GND | Power |
| 37 |  |  | NC |  | - | 38 | GND | Power |
| 39 | CB2 | 1/0 | $\overline{\text { ACK }}$ | 1 | NMOS | 40 | $+5 \mathrm{~V}$ | Power |

Notes: (1) Maximum +5 V current through J6 should not exceed 200 mA per pin.
(2) Connected to J7-39 through jumper W3.

SBC Module Connector J7 (Keyboard) Pin Assignments

| Pin | R6522 |  | Keyboard |  | Type | Pln | Signal | Type |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Signal | 1/0 | Signal | 1/0 |  |  |  |  |
| 1 (2) | CB2 | 1/0 | RES | 1 | TTL | 2 (1) | $\mathrm{NC} /+5 \mathrm{~V}$ | Power |
| 3 (3) | CB1 | 1/0 | ATTN | 1 | TTL | 4 | GND | Power |
| 5 | PB7 | 1/0 | MSB7 | 0 | NMOS | 6 | GND | Power |
| 7 | PB6 | 10 | MSB6 | 0 | NMOS | 8 | GND | Power |
| 9 | PB5 | vo | MSB5 | 0 | NMOS | 10 | GND | Power |
| 11 | PB4 | 1/0 | MSB4 | 0 | NMOS | 12 | GND | Power |
| 13 | PB3 | 1/0 | MSB3 | 0 | NMOS | 14 | GND | Power |
| 15 | PB2 | vo | MSB2 | 0 | NMOS | 16 | GND | Power |
| 17 | PB1 | vo | MSB1 | 0 | NMOS | 18 | GND | Power |
| 19 | PBO | vo | MSBO | 0 | NMOS | 20 | GND. | Power |
| 21 | PA7 | 1/0 | MRT7 |  | NMOS | 22 | GND | Power |
| 23 | PA6 | vo | MRT6 | 1 | NMOS | 24 | GND | Power |
| 25 | PA5 | $1 / 0$ | MRT5 | 1 | NMOS | 26 | GND | Power |
| 27 | PA4 | 1/0 | MRT4 | 1 | NMOS | 28 | GND | Power |
| 29 | PA3 | l/O | MRT3 | 1 | NMOS | 30 | GND | Power |
| 31 | PA2 | $1 / 0$ | MRT2 | 1 | NMOS | 32 | GND | Power |
| 33 | PA1 | 1/0 | MRT1 | 1 | NMOS | 34 | GND | Power |
| 35 | PAO | 1/0 | MRTO | 1 | NMOS | 36 | GND | Power |
| 37 | CA2 | 1/0 | MSB8 | 1 | NMOS | 38 | GND | Power |
| 39 (4) | CA1 | 1 | PAPER FEED | 1 | NMOS | 40 (1) | $\mathrm{NC} /+5 \mathrm{~V}$ | Power |

Notes: (1) Pins 2 and 40 can be optionally jumpered to +5 V (maximum current through each pin should not exceed 200 mA ).
(2) Pin 1 can be optionally jumpered to the RESET circuit or to CB2.
(3) Pin 3 can be optionally jumpered to the $\overline{\text { NMI }}$ circuit or to CB1.
(4) Pin 39 can be optionally jumpered as PAPER FEED or to CA1.

NMOS INTERFACE (Input Voltage $=\mathbf{+ 5 . 0} \mathrm{V}, \mathrm{TA}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.4 | 5.0 | V |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.3 | +0.4 | $v$ |
| $\mathrm{I}_{\mathrm{H}}$ | Input High Current $\left(V_{I H}=2.4 \mathrm{~V}\right)$ | -100 | -300 | $\mu \mathrm{A}$ |
| ILI | Input Low Current $\left(V_{I L}=0.4 A\right)$ | -1.0 | -1.6 | mA |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage ( LLOAD $\leqslant-100 A$ ) | 2.4 | 5.0 | v |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage ( $\mathrm{L}_{\text {LOAD }} \leqslant-3 \mathrm{~mA}$ ) | - | 0.4 | v |
| $\mathrm{IOH}^{\text {O}}$ | Output High Current (Sourcing) $\left(\mathrm{V}_{\mathrm{OH}} \geqslant 2.4 \mathrm{~V}\right)$ <br> ( $\mathrm{V}_{\mathrm{OH}} \geqslant 1.5 \mathrm{~V}$, VIA PB0-PB7 only) | $\begin{aligned} & -100 \\ & -1.0 \end{aligned}$ | 二 | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \end{aligned}$ |
| loL | Output Low Current (Sinking) $\left(\mathrm{V}_{\mathrm{OL}} \leqslant 0.4 \mathrm{~V}\right)$ | 1.6 | - | mA |
| $\begin{array}{ll} \hline \text { TTL } & \text { - Industry standard LS TTL. } \\ \text { OC TTL - Industry standard Open Collector LS TTL. } \end{array}$ |  | 3S TTL - Industry standard Tri-State LS TTL. <br> TP TTL — Industry standard Totem Pole LS TTL. |  |  |

## SPECIFICATIONS



## REFERENCE DOCUMENTS

The following product literature is available for further product information.

| Order Number | Document Title |
| :---: | :---: |
| D74 | A65/40-0200, A65/40-0210 Standard and Extended Keyboard Data Sheet |
| D76 | A65/40-0400 40-Character Display Data Sheet |
| D75 | A65/40-0600 Graphic Printer Data Sheet |
| D86 | A65/40-0800 Video Display Controller Module Data Sheet |
| D77 | A65/40-1000 Single Board Computer Module Data Sheet |
| D123 | A65/40-7010 Assembler ROM |
| D128 | A65/40-7012 Macro Assembler and Linking Loader |
| D120 | A65/40-7020 BASIC Interpreter ROMs |
| D118 | A65/40-7024 BASIC Compiler |
| D130 | A65/40-7040 Math Package ROMs |
| D122 | A65/40-7050 FORTH ROMs |
| D119 | A65/40-7052 FORTH Target Compiler |
| D116 | A65/40-7090 Disk Operating System Version 1.0 ROM |
| D129 | A65/40-7092 Bootstrap Disk Operating System Version 1.0 ROM |

## A65/40-1000 AIM 65/40 SINGLE BOARD COMPUTER

## OVERVIEW

The A65/40-1000 Single Board Computer (SBC) is one of the hardware options available for the AIM 65/40. Microcomputer family.

The SBC is an extremely flexible and adaptable microcomputer on a single board. Memory sockets accept up to 65 K bytes of read-only and read/write memory on the board. Three installed peripheral ribbon cable connectors, as well as three user dedicated application edge connectors, provide extensive and versatile parallel and serial interfaces for use in industrial, scientific and educational installations. The RM 65 Bus compatible expansion connector allows additional memory, I/O, peripheral controller and application modules to be easily connected.

Up to 32 K bytes of PROM/ROM and up to 48 K bytes of RAM may be installed on-board. All on-board memory may be enabled in 4K-byte blocks, yielding an optimal mix of on-board/offboard memory and $\mathrm{I} / \mathrm{O}$ to be addressed. The RAM may also be write-protected in 8 K -byte segments. Dual bank addressing allows an additional 56K bytes of memory or I/O to be accessed off-board.

The display and printer interfaces connect through interface cables to the A65/40-0400 40-Character Display and the A65/40-0600 Graphics Printer over identical Centronics type parallel handshaking interfaces. The keyboard interface connects to the A65/40-0200 Standard Keyboard through an interface cable. These peripheral ports may be used as general purpose bidirectional data ports with parallel, serial, interrupt and timer capabilities controlled by user programming of two onboard R6522 Versatile Interface Adapter (VIA) devices.

In addition, a separate user-dedicated R6522 VIA interfaces with the Parallel Application connector. The high current drive capacity of the VIA's eight " $B$ " port lines can directly drive many industry-standard devices, such as solid state relays. The RS-232C Connector provides an interface that allows the SBC to function as a data set or data terminal. An Audio/TTY Connector can be used to attach one or two audio cassette recorders, for program or data storage, and a 20 mA current loop teletypewriter.

The A65/40-1000 SBC comes with a 4K-byte I/O ROM installed. Preprogrammed auto-start initialization, interrupt, input/output and utility functions support user-defined programs as well as AIM 65/40 optional firmware/software. Auto-start initialization jumps to predetermined PROM/ROM addresses during RESET processing. The application program can assume direct control of the SBC for continued operation, or it can just initialize required functions, then return control back to the I/O ROM for continued auto-start of other functions. I/O drivers directly support AIM 65/40 intelligent display and printer peripherals.

## FEATURES

- Popular and Powerful 6502 CPU
- Extensive On-Board Memory
-Up to 48K bytes of RAM, with write-protect
-up to 32 K bytes of PROM or ROM
- Extended and Flexible Addressing
- 131 K addressing, in two 65K-byte banks
-Dedicated or shared bank addressing
-On-board/off-board memory select
- User-Prioritized Interrupts-Up to six levels
- Installed I/O Driver ROM
-Interrupt driven AIM 65/40 peripheral I/O handlers
-User program auto-start initialization
-Utility subroutines and user I/O driver linkage
- Two System Display/Printer Connectors
-Centronics type parallel handshake
-AIM 65/40 40-character display compatible
-AIM 65/40 graphics printer compatible
- Full-Size Keyboard Interface
-General purpose parallel interface
-AIM 65/40 keyboard compatible
- Parallel Application Interface
-R6522 Versatile Interface Adapter (VIA)
-Two 8-bit parallel bidirectional data ports
-Two 2-bit handshake control ports
-Two programmable 16-bit counter/timers
-8-bit serial interface
- RS-232C Serial Application Interface
-R6551 Asynchronous Communications Interface Adapter (ACIA) with programmable data rate to 19,200 baud
-Configurable as data set or data terminal
- 20 mA Current Loop Serial Interface
- Interface to Low Cost Audio Cassette Recorders
-Remote on/off control through on-board relays
-AIM 65 format compatible
- On-Board Piezo-Electric Speaker
- Programmable tone and duration
- +5 V Operation


## FUNCTIONAL DESCRIPTION

## CENTRAL PROCESSING AND CONTROL

The A65/40-1000 SBC contains a central processing unit (CPU), decoders, read/write memory, read-only memory, peripheral interface devices, application interface circuits, expansion bus drivers and support circuitry-all connected together by an internal system bus.

The R6502 CPU, with its advanced pipeline architecture and 13 addressing modes for fast execution and memory efficiency, performs the central processing. A 1 MHz system operating frequency is derived from a clock circuit employing a 16 MHz reference crystal.

The RESET conditioning circuit shapes the RESET signal received from the on-board RESET switch or the Keyboard Connector and generates the system reset ( $\overline{\mathrm{RES}}$ ) for the CPU, onboard I/O devices, the off-board peripherals and the expansion bus. It also generates the $\overline{\mathrm{RES}}$ signal at power turn-on.

The Single Step circuit, enabled under software control, allows CPU monitored single instruction execution through user programs located below \$A000. When enabled, a Non-Maskable Interrupt (NMI) is generated upon execution of each instruction to allow an interrupt subroutine to perform debug functions, such as disassembly of the instruction and display of register contents.

The Interrupt Request Priority circuitry prioritizes individual interrupt requests ( $\overline{\mathrm{RQ}}$ ) from six sources-the System R6522 VIA, the Keyboard R6522 VIA, the Application R6522 VIA, the Application R6551 ACIA, the RM 65 Bus, and the on-board RAM Write Protect circuitry-into a system $\overline{\mathrm{RQ}}$. Each $\overline{\mathrm{RQ}}$ can be assigned any priority relative to the others by wiring the Interrupt Request Priority Header. The Interrupt Request Priority Mask inhibits generation of the System $\overline{\mathrm{RQ}}$ to the CPU for individual interrupt requests assigned below a software selected priority level.

The On-board Device Decoder generates device select signals for all on-board RAM, ROM or I/O access. The PROM/ROM and RAM select switches allow independent on-board/off-board selection of each 4 K -byte block.

Programmable Bank Addressing creates two 65K-byte banks, for an effective addressing range of 131 K bytes with the RM 65 Bus Expansion Connector. The upper 4 K bytes containing the VO ROM, and the lower 4 K bytes containing the R6502 stack RAM, are always common to both Bank 0 and Bank 1. An additional 20K bytes of PROM/ROM may be assigned common to both banks, or dedicated to Bank 0, on 4 K -byte boundaries with the Bank Selection jumpers. The remaining PROM/ROM and RAM is dedicated to Bank 0.

## MEMORY

Eight 24-pin PROM/ROM sockets allow installation of up to 32 K bytes of PROM/ROM. PROM/ROM size jumpers set up the sockets to accept 8 K - or 4 K -byte devices. The on-board RAM can be expanded up to 48 K bytes using industry standard 16 K $\times 1$ dynamic RAM devices in 24 16-pin sockets.

The RAM Refresh and Timing Control circuitry controls address and data timing for RAM memory access, and provides transparent refreshing of the dynamic RAM devices. Write protect switches allow the RAM to be selected for read-only access, with independent protection of 8 K byte sections (except for the lowest 8 K which contains page 0 and page 1). An attempted write into any protected RAM location will generate a write protect interrupt request ( $\overline{\mathrm{RQ}}$ ).

## I/O HARDWARE

Two system R6522 VIA devices support three peripheral portsdisplay, printer and keyboard. Common I/O data lines and separate control lines are routed from the System VIA to the Display and Printer Connectors. Both common or unique data can easily be transferred through the System VIA to the interfacing peripherals since the handshaking control lines are separately handled. The System VIA also controls data transferred to and from audio cassette recorders as well as on-board relays to remotely turn the recorders on and off. Each VIA provides two 16-bit timer/counters and an 8-bit serial shift register.

A separate R6522 VIA interfaces with the Keyboard Connector and the on-board speaker amplifier. Nine keyboard strobe lines are output from the keyboard VIA to the keyboard and another eight return lines are input. The eight return lines are also or'ed together and connected to the VIA to cause a keyboard $\overline{\mathrm{RQ}}$ when a key is depressed.

The third R6522 VIA is dedicated to user functions. All 16 data and 4 control lines are routed directly to the Parallel Application Connector. The Application VIA provides two 8 -bit bidirectional data ports with handshake control and allows the data direction of each port bit to be individually assigned. One of the data lines may be configured as a serial line to an 8 -bit shift register with three input and four output modes. Two independent 16 -bit timer/counters in the R6522 with four modes in Timer 1 and three modes in Timer 2 support numerous internal and external timing and clock functions. Two data ports associated with the timers allow various input/output functions to be programmed such as rectangular wave form generation and sampling.

In addition to the parallel interfaces, a user dedicated serial interface is provided in both RS-232C and 20 mA forms. An R6551 Asynchronous Communication Interface Adapter (ACIA) device connects to RS-232C and 20 mA current loop interface circuits. On-board jumpers configure the R6551 ACIA to operate as either a data set or a data terminal. The R6551 ACIA, with its internal data rate generator, may be programmed to one of the 16 rates (from 50 to 19,200 baud). Additional program control of word length ( $5,6,7$ or 8 bits), number of stop bits ( $1,11 / 2$ or 2 ) and parity (odd, even or none) is also provided.

The RS-232C Interface circuit converts the TTL level signals to RS-232C voltage levels and routes the signals to the RS-232C Connector. The TTY Interface circuit converts TTL level signals to 20 mA current signals and routes the signals to the Audio/ TTY Connector. The TTY receive data and transmit data lines operate in parallel with the RS-232C lines.

Line driver and tri-state circuitry interface with the on-board address, data and control lines to interface with the Expansion Connector. Both the address lines and data lines are inverted
to be compatible with the Rockwell RM 65 Bus. Data and control lines are connected to the Bus Control line from the Expansion Connector so they can be disconnected from the bus during offboard DMA operations.

## INTERFACE CONNECTORS

The two identical 40-pin Display and Printer connectors allow display and printer functions to be easily interchanged, or duplicated if two displays or two printers are connected. These connectors are directly compatible with the A65/40-0400 40Character Display and the A65/40-0600 Graphics Printer-or they may be connected to other Centronics type interface compatible equipment. +5 V is routed to the connectors for use by the interfacing peripherals. The display and printer connectors are mounted vertically on the front half of the SBC to conveniently connect to the printer and display interface cables.

The 40-pin Keyboard Connector connects the 17 I/O lines from the Keyboard VIA to the keyboard interface cable. Keyboard RESET and Non-Maskable Interrupt ( $\overline{\mathrm{NMI} \text { ) lines are routed from }}$ the connector to the Reset Conditioning and Single Step circuits respectively. The Paper Feed signal from the keyboard may be routed directly to the display and printer connectors, or to the Keyboard VIA. Mounted horizontally on the front of the SBC, the connector allows easy connection to an interfacing cable from the A65/40 Keyboard, or from any other compatible equipment.

The application, audio/TTY and expansion bus signals are routed to four edge connectors. The pins on each connector are spaced at standard 0.100 inch separation for direct connection to mass terminated cable connectors. Mounting holes are also provided to allow installation of other connectors.

The 40-pin Parallel Application Connector connects to $\mathrm{I} / \mathrm{O}$ lines routed directly to the Application R6522 VIA. In addition, +5 V can be supplied to the interfacing equipment through an onboard jumper.

The 26-pin RS-232C Connector connects to lines from the RS232C Interface circuitry. A standard 25-pin D-type connector can be installed. The 20 -pin Audio/TTY Connector interfaces with audio data and control lines from the Audio Cassette Interface circuitry and 20 mA current loop lines from the TTY Interface circuitry.

The 72-pin Expansion Connector interfaces to lines from the RM 65 Bus interface. An RM 65-AIM 65/40 Buffer Module, P/N RM65-7140(E) can be connected to the Expansion Connector to interface with a Rockwell RM 65 card cage/motherboard.

## VOLTAGE CONVERTER

The DC-DC Voltage Converter generates all required on-board voltages from the +5 volt supply. The +12 V and -12 V are used by the RS-232C Interface Circuit, while +12 V and -5 V are required by the dynamic RAMs.

NMOS Interface (Input Voltage $=+5.0 \mathrm{~V}, \mathrm{TA}=\mathbf{2 5}{ }^{\circ} \mathrm{C}$ )



Notes: (1) AIM 65/40 System peripheral I/O addresses are assigned to FF80-FFDF.
(2) User avallable during application program operation if the debug and text editor functions are not used.
(3) User avallable if the optional language and the RM 65 expansion module ROMs are not used.

Connector J1 (Parallel Application) Pin Assignments

| Pin | Signal | 1/0 | Type | Pin | Signal | Type |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | CB2 | VO | NMOS | 2 | $\mathrm{NC} /+5 \mathrm{~V}^{*}$ | Power |
| 3 | CB1 | 1/O | NMOS | 4 | GND | Power |
| 5 | PB7 | I/O | NMOS | 6 | GND | Power |
| 7 | PB6 | VO | NMOS | 8 | GND | Power |
| 9 | PB5 | VO | NMOS | 10 | GND | Power |
| 11 | PB4 | I/O | NMOS | 12 | GND | Power |
| 13 | PB3 | 1/0 | NMOS | 14 | GND | Power |
| 15 | PB2 | 1/0 | NMOS | 16 | GND | Power |
| 17 | PB1 | 1/0 | NMOS | 18 | GND | Power |
| 19 | PB0 | 1/0 | NMOS | 20 | GND | Power |
| 21 | PA7 | 1/0 | NMOS | 22 | GND | Power |
| 23 | PA6 | 1/O | NMOS | 24 | . GND | Power |
| 25 | PA5 | 1/0 | NMOS | 26 | GND | Power |
| 27 | PA4 | 1/O | NMOS | 28 | GND | Power |
| 29 | PA3 | $1 / 0$ | NMOS | 30 | GND | Power |
| 31 | PA2 | 1/0 | NMOS | 32 | GND | Power |
| 33 | PA1 | 1/0 | NMOS | 34 | GND | Power |
| 35 | PAO | I/O | NMOS | 36 | GND | Power |
| 37 | CA2 | 1/0 | NMOS | 38 | GND | Power |
| 39 | CA1 | 1 | NMOS | 40 | $\mathrm{NC} /+5 \mathrm{~V}^{*}$ | Power |

Note: *Pins 2 and 40 can be optionally jumpered to +5 V (maximum current through each pin should not exceed 200 mA ).

Connector J2 (Serial Application) Pin Assignments

| Pin | Signal | I/O | Type | Pin | Signal | I/O | Type |
| :---: | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | GND |  | Power | 2 | TD | O | RS-232C |
| 3 | RD | I | RS-232C | 4 | RTS | I/O | RS-232C |
| 5 | CTS | I/O | RS-232C | 6 | DSR | I/O | RS-232C |
| 7 | GND |  | Power | 8 | DCD | I/O | RS-232C |
| 9 | NC |  |  | 10 | NC |  |  |
| 11 | NC |  |  | 12 | NC |  |  |
| 13 | NC |  |  | 14 | NC |  |  |
| 15 | NC |  |  | 16 | NC |  |  |
| 17 | NC |  |  | 18 | NC |  |  |
| 19 | NC |  |  | 20 | DTR | $1 / O$ | RS-232C |
| 21 | NC |  |  | 22 | NC |  |  |
| 23 | NC |  |  | 24 | NC |  |  |
| 25 | NC |  |  | 26 | NC |  |  |

Connector J3 (Audio/TTY) Pin Assignments

| Pln | Signal | I/O | Type | Pin | Signal | Type |
| ---: | :--- | :---: | :--- | :---: | :---: | :---: |
| 1 | TTY RTS | I | TTY | 2 | GND | Power |
| 3 | TTY TD | 0 | TTY | 4 | GND | Power |
| 5 | TTY RD | 1 | TTY | 6 | GND | Power |
| 7 | TTY RTN |  | Power | 8 | GND | Power |
| 9 | AUDIO OUT | 1 | TTL | 10 | GND | Power |
| 11 | AUDIO IN | 0 | TTL | 12 | GND | Power |
| 13 | CTRL 2 RTN | 0 | Relay | 14 | GND | Power |
| 15 | CTRL 2 | 1 | Relay | 16 | GND | Power |
| 17 | CTRL 1 RTN | 0 | Relay | 18 | GND | Power |
| 19 | CTRL 1 | 1 | Relay | 20 | GND | Power |

Connector J4 (RM 65 Bus) Pin Assignments

| Bottom (Solder Side) |  |  |  |  | Top (Component Side) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | 1/0 | Type | Pin | Signal Mnemonic | Signal Name | 1/0 | Type |
| Wa |  | Not Connected |  | - | Wc |  | Not Connected |  | - |
| Xa | $+5 \mathrm{~V}$ | +5 Vdc Line (See Note) |  | Power | Xc | $+5 \mathrm{~V}$ | +5 Vdc (See Note) |  | Power |
| 1a | GND | Ground |  | Power | 1 c | $+5 \mathrm{~V}$ | +5 Vdc |  | Power |
| 2 a | BADR/ | Buffered Bank Address | 0 | 3S TTL | 2 c | BA15/ | Buffered Address Bit 15 | 0 | 3S TTL |
| 3 a | GND | Ground |  | Power | 3 c | BA14/ | Buffered Address Bit 14 | 0 | 35 TTL |
| 4a | BA13/ | Buffered Address Bit 13 | 0 | 35 TTL | 4 c | BA12/ | Buffered Address Bit 12 | 0 | 3S TTL |
| 5 a | BA11/ | Buffered Address Bit 11 | 0 | 3S TTL | 5 c | GND | Ground |  | 35 TTL |
| 6 a | BA10/ | Buffered Address Bit 10 | 0 | 3S TTL | 6 c | BA9/ | Buffered Address Bit 9 | 0 | 3 STTL |
| 7 a | BA8/ | Buffered Address Bit 8 | 0 | 3S TTL | 7 c | BA7/ | Buffered Address Bit 7 | 0 | 35 TTL |
| 8 a | GND | Ground |  | Power | 8 C | BA6/ | Buffered Address Bit 6 | 0 | 3S TTL |
| 9 a | BA5/ | Buffered Address Bit 5 | 0 | 3S TTL | 9 c | BA4/ | Buffered Address Bit 4 | 0 | 3S TTL |
| 10a | BA3/ | Buffered Address Bit 3 | 0 | 3S TTL | 10c | GND | Ground |  | Power |
| 11a | BA2/ | Buffered Address Bit 2 | 0 | 3S TTL | 11c | BA1/ | Buffered Address Bit 1 | 0 | 3S TTL |
| 12a | BAO/ | Buffered Address Bit 0 | 0 | 3S TTL | 12c | B $\square_{1}$ | Buffered Phase 1 Clock | 0 | TP TTL |
| 13a | GND | Ground |  | Power | 13c | BSYNC | Buffered Sync |  | 35 TTL |
| 14a | BSO | Buffered Set Overflow | 1 | OC TTL | 14c | BDRQ1/ | *Buffered DMA Request 1 |  |  |
| 15a | BRDY | Buffered Ready | 1 | OC TTL | 15c | GND | Ground |  | Power |
| 16a |  | *User Spare 1 |  |  | 16c | -12 V/-V | *-12 Vdc/-V |  |  |
| 17a | +12 V/+V. | * $+12 \mathrm{Vdc} /+\mathrm{V}$ |  |  | 17c |  | *User Spare 2 |  |  |
| 18a | GND | Ground Line |  | Power | 18c. | BFLT/ | Buffered Bus Float | 1 | OC TTL |
| 19a | BDMT/ | *Buffered DMA Terminate |  |  | 19c | Вф0 | *Buffered External Phase 0 Clock |  |  |
| 20a |  | * User Spare 3 |  |  | 20c | GND | Ground |  | Power |
| 21a | $\mathrm{BR} / \mathrm{W} /$ | Buffered Read/Write "Not" | 0 | 3S TTL | 21c | BDRQ2/ | *Buffered DMA Request 2 |  |  |
| 22a |  | *System Spare |  |  | 22 c | $B R / \bar{W}$ | Buffered Read/Write | 0 | 35 TTL |
| 23a | GND | Ground |  | Power | 23 c | BACT/ | Buffered Bus Active | 1 | OC TTL |
| 24a | BIRQ/ | Buffered Interrupt Request | 1 | OC TTL | 24 c | BNMI/ | Buffered Non-Maskable Interrupt | 1 | OC TTL |
| 25a | Bø2. | Buffered Phase 2 "Not" Clock | 0 | 3 STTL | 25c | GND | Ground |  | Power |
| 26a | Bø2 | Buffered Phase 2 Clock | 0 | 3 STTL | 26 c | BRES/ | Buffered Reset | 0 | OC TTL |
| 27a | BD71 | Buffered Data Bit 7 | 1/O | 3S TTL | 27c | BD6/ | Buffered Data Bit 6 | I/O | 3S TTL |
| 28a | GND | Ground |  | Power | 28c | BD5/ | Buffered Data Bit 5 | VO | 3 STTL |
| 29a | BD4/ | Buffered Data Bit 4 | 1/O | 3S TTL | 29c | BD3/ | Buffered Data Bit 3 | I/O | 3S TTL |
| 30a | BD2/ | Buffered Data Bit 2 | 1/O | 3S TTL | 30c | GND | Ground |  | Power |
| 31a | BD1/ | Buffered Data Bit 1 | 1/O | 3s TTL | 31c | BD0/ | Buffered Data Bit 0 | I/O | 3S TTL |
| 32a | $+5 \mathrm{~V}$ | +5 Vdc |  | Power | 32 c | GND | Ground |  | Power |
| Ya Za | $+5 \mathrm{~V}$ | +5 Vdc (See Note) Not Connected |  | Power | $\begin{aligned} & \mathrm{Yc} \\ & \mathrm{Zc} \end{aligned}$ | $+5 \mathrm{~V}$ | +5 Vdc (See Note) <br> Not Connected |  | Power |
| Note: *Not used on the SBC. Signal name reflects RM 65 Bus reserved function. |  |  |  |  |  |  |  |  |  |

Connector J5 (Printer) Pin Assignments

| Pin | R6522 |  | Printer |  | Type | Pin | Signal | Type |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Signal | 1/0 | Signal | 1/0 |  |  |  |  |
| 1 (1) | +5V | 0 | $+5 \mathrm{~V}$ | 0 | Power | 2 | GND | Power |
| 3 | NC |  | NC |  | - | 4 | GND | Power |
| 5 | NC |  | NC |  | - | 6 | GND | Power |
| 7 | NC |  | NC |  | - | 8 | GND | Power |
| 9 | NC |  | NC |  | - | 10 | GND | Power |
| 11 | NC |  | NC |  | - | 12 | GND | Power |
| 13 | NC |  | NC |  | - | 14 | GND | Power |
| 15 | PAPERFEED (2) |  | PAPERFEED (2) |  | TTL | 16 | GND | Power |
| 17 | RES | 0 | RES | 0 | TTL | 18 | GND | Power |
| 19 | PB1 | I/O | STROBE | 0 | NMOS | 20 | GND | Power |
| 21 | PA7 | I/O | Data 7 | 0 | NMOS | 22 | GND | Power |
| 23 | PA6 | I/O | Data 6 | 0 | NMOS | 24 | GND | Power |
| 25 | PA5 | I/O | Data 5 | 0 | NMOS | 26 | GND | Power |
| 27 | PA4 | I/O | Data 4 | 0 | NMOS | 28 | GND | Power |
| 29 | PA3 | VO | Data 3 | 0 | NMOS | 30 | GND | Power |
| 31 | PA2 | I/O | Data 2 | 0 | NMOS | 32 | GND | Power |
| 33 | PA1 | 1/0 | Data 1 | 0 | NMOS | 34 | GND | Power |
| 35 | PAO | I/O | Data 0 | 0 | NMOS | 36 | GND | Power |
| 37 |  |  | NC |  | - | 38 | GND | Power |
| 39 | CA2 | V/O | $\overline{\text { ACK }}$ | 1 | NMOS | 40(1) | $+5 \mathrm{~V}$ | Power |

Notes: (1) Maximum +5 V current through J 5 should not exceed 200 mA per pin. (2) Connected to J7-39 through jumper W3.

Connector J6 (Display) Pin Assignments

| Pin | R6522 |  | Display |  | Type | Pin | Signal | Type |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Signal | I/O | Signal | 1/0 |  |  |  |  |
| 1 (1) | $+5 \mathrm{~V}$ |  | $+5 \mathrm{~V}$ |  | Power | 2 | GND | Power |
| 3 | NC |  | NC |  | - | 4 | GND | Power |
| 5 | NC |  | NC |  | - | 6 | GND | Power |
| 7 | NC |  | NC |  | - | 8 | GND | Power |
| 9 | NC |  | NC |  | - | 10 | GND | Power |
| 11 | NC |  | NC |  | - | 12 | GND | Power |
| 13 | NC |  | NC |  | - | 14 | GND | Power |
| 15 | PAPERFEED (2) |  | PAPERFEED (2) | 0 | TTL | 16 | GND | Power |
| 17 | RES |  | RES | 0 | TTL | 18 | GND | Power |
| 19 | PB0 | I/O | STROBE | 0 | NMOS | 20 | GND | Power |
| 21 | PA7 | I/O | Data 7 | 0 | NMOS | 22 | GND | Power |
| 23 | PA6 | VO | Data 6 | 0 | NMOS | 24 | GND | Power |
| 25 | PA5 | Vo | Data 5 | 0 | NMOS | 26 | GND | Power |
| 27 | PA4 | I/O | Data 4 | 0 | NMOS | 28 | GND | Power |
| 29 | PA3 | /10 | Data 3 | 0 | NMOS | 30 | GND | Power |
| 31 | PA2 | $1 / 0$ | Data 2 | 0 | NMOS | 32 | GND | Power |
| 33 | PA1 | Vo | Data 1 | 0 | NMOS | 34 | GND | Power |
| 35 | PAO | I/O | Data 0 | 0 | NMOS | 36 | GND | Power |
| 37 |  |  | NC |  | - | 38 | GND | Power |
| 39 | CB2 | /O | $\overline{\text { ACK }}$ | 1 | NMOS | 40 | $+5 \mathrm{~V}$ | Power |
| Notes: (1) Maximum +5V current through J6 should not exceed 200 mA per pin. (2) Connected to J7-39 through jumper W3. |  |  |  |  |  |  |  |  |

## Connector J7 (Keyboard) Pin Assignments

| Pin | R6522 |  | Keyboard |  | Type | Pin | Signal | Type |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Slgnal | 1/0 | Signal | 1/0 |  |  |  |  |
| 1 (2) | CB2 | 1/0 | RES | 1 | TTL | 2 (1) | $\mathrm{NC} /+5 \mathrm{~V}$ | Power |
| 3 (3) | CB1 | 1/0 | $\overline{\text { ATTN }}$ | 1 | TTL | 4 | GND | Power |
| 5 | PB7 | 1/0 | MSB7 | 0 | NMOS | 6 | GND | Power |
| 7 | PB6 | 1/0 | MSB6 | 0 | NMOS | 8 | GND | Power |
| 9 | PB5 | 1/0 | MSB5 | 0 | NMOS | 10 | GND | Power |
| 11 | PB4 | 1/0 | MSB4 | 0 | NMOS | 12 | GND | Power |
| 13 | PB3 | 1/0 | MSB3 | 0 | NMOS | 14 | GND | Power |
| 15 | PB2 | 1/0 | MSB2 | 0 | NMOS | 16 | GND | Power |
| 17 | PB1. | $1 / 0$ | MSB1 | 0 | NMOS | 18 | GND | Power |
| 19 . | PB0 | 1/0 | MSBO | 0 | NMOS | 20 | GND | Power |
| 21 | PA7 | 1/0 | MRT7 | 1 | NMOS | 22 | GND | Power |
| 23 | PA6 | 1/0 | MRT6 | 1 | NMOS | 24 | GND | Power |
| 25 | PA5 | 1/0 | MRT5 | 1 | NMOS | 26 | GND | Power |
| 27 | PA4 | 1/0 | MRT4 | 1 | NMOS | 28 | GND | Power |
| 29 | PA3 | 1/0 | MRT3 | 1 | NMOS | 30 | GND | Power |
| 31. | PA2 | $1 / 0$ | MRT2 | 1 | NMOS | 32 | GND | Power |
| 33 | PA1 | $1 / 0$ | MRT1 | 1 | NMOS | 34 | GND | Power |
| 35 | PAO | 1/0 | MRTO | 1 | NMOS | 36 | GND | Power |
| 37 | CA2 | 1/O | MSB8 | 1 | NMOS | 38 | GND | Power |
| 39 | CA1 | 1 | PAPERFEED | 1 | NMOS | 40 (1) | $\mathrm{NC} /+5 \mathrm{~V}$ | Power |

Notes: (1) Pins 2 and 40 can be optionally jumpered to $+5 V$ (maximum current through each pin should not exceed 200 mA ).
(2) Pin 1 can be optionally jumpered to the RESET circuit or to CB2.
(3) Pin 3 can be optionally jumpered to the $\overline{N M T}$ circuit or to CB1.
(4) Pin 39 can be optionally jumpered as PAPERFEED or to CA1.

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions Width Length Height | 11.85 in. (301 mm) $12.5 \mathrm{in} . \quad(318 \mathrm{~mm})$ $0.75 \quad(19 \mathrm{~mm})$ |
| Weight | $1.0 \mathrm{lb} .(373 \mathrm{~g})$ |
| Environment Operating Temperature Storage Temperature Relative Humidity | $\begin{aligned} & 0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & -25^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ & 0 \% \text { to } 85 \% \text { (without condensation) } \end{aligned}$ |
| Power Requirements | $+5 \mathrm{~V}=5 \%$ Regulated; 2.5A (typical); 3.5A (max.) |
| Power Connector | 2 Post Terminal Block |
| Interface Connector <br> J1 (Parallel Application) <br> J2 (Serial Application) <br> J3 (Audio/TTY) <br> J4 (RM 65 Expansion) <br> J7 (Keyboard) <br> J5 (Printer) and <br> J6 (Keyboard) | 40-pin edge connector ( 0.100 in. centers). Pre-drilled holes for installation of 40 -pin 3M \#3432-1002, or equivalent, mass terminated connector. <br> 26 -pin edge connector ( 0.100 in . centers). Pre-drilled holes for installation of 25 -pin AMP \#206584-1, or equivalent, mass terminated connector. <br> 20 -pin edge connector ( 0.100 in. centers). Pre-drilled holes for installation of 20-pin 3M \#3492-1002 or equivalent, mass terminated connector. <br> 72-pin edge connector ( 0.100 in. centers). Pre-drilled holes for installation of a 64-pin DIN 41612 <br> Euroconnector or 72 -pin TI H42-51-11-36, or equivalent, connector to directly mate to one Rockwell RM 65 module. <br> 40-pin 3M \#3495-1002, or equivalent. Mates with 3M: \#3418-0000T, or equivalent, ribbon cable connector. <br> 40-pin 3M \#3495-2002, or equivalent. Mates with 3M \#3418-0000T, or equivalent, ribbon cable connector. |

Note: Power requirements are specified for 8 PROM/ROM devices ( 32 K bytes) 0.6 A (typical) and 1.2A (maximum), and for 16 RAM devices ( 32 K bytes) with total 0.9 A and 1.7 A (maximum) total, installed.


A65/40-1000 Single Board Computer (SBC) Diagram

## 0 Rockwell

## A65/40-0004 AIM 65/40 POWER SUPPLY AND CABLE

## DESCRIPTION

The AIM 65/40 Power Supply and Cable is an open frame DC power supply with output cable for connection to an AIM 65/40 Microcomputer. The power supply provides sufficient power for full on-board RAM and PROM/ROM expansion as well as offboard RM 65 expansion modules, e.g., RM 65 Floppy Disk Controller (FDC) module (RM65-5101E) and RM 65 Multifunction Peripheral Interface (MPI) module (RM65-5223E). The $+24 \mathrm{~V} /$ 4A output supplies power to the AIM 65/40 Graphics Printer. The $\pm 12 \mathrm{~V}$ and -5 V outputs are not used by the AIM 65/40 Microcomputer, but are available for expansion module use.

AC power connects to an input terminal strip. A jumper on the power supply can be positioned for either 115 or 230 Vac input. An input fuse (5A for 115 Vac or 3 A for 230 Vac ) provides line protection. The 3-wire DC output cable, factory connected to the power supply output terminals, allows direct connection to the AIM 65/40 input power terminals.

All outputs are current limited to prevent damage to the power supply if the outputs are overloaded or accidentally shorted together. Full power output is provided from $0^{\circ}$ to $50^{\circ} \mathrm{C}$.

## FEATURES

- Dual AC input voltage -115 Vac@ 47-63 Hz or - 230 Vac @ 47-63 Hz
- Five DC output voltages
- +5V for AIM 65/40 Microcomputer logic
$-+24 V$ for AIM 65/40 Graphics Printer
$-+12 \mathrm{~V},-12 \mathrm{~V}$ and -5 V for expansion modules
- Fused input
- $75 \%$ minimum efficiency
- All outputs current limited
- No 60 Hz EMI
- Meets FCC/VDE RFI requirements
- Soft start-Minimizes input current surge at turn-on
- No turn on or turn off overshoot
- DC output cable included

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| A65/40-0004 | AIM 65/40 Power Supply and Cable |



A65/40-0004 Power Supply

## SPECIFICATIONS

| Parameter | Value | Parameter | Value |
| :---: | :---: | :---: | :---: |
| AC Input <br> DC Output <br> Total Output Power <br> $+5 \mathrm{Vdc}$ <br> +24 Vdc <br> +12 Vdc <br> -12 Vdc <br> $-5 \mathrm{Vdc}$ <br> Output Accuracy* <br> +5 V output <br> Other outputs <br> Static Regulation Line <br> Load +5 V output Other outputs <br> Ripple and Noise <br> Temperature Coefficients <br> Overshoot <br> Overioad Protection <br> Overvoltage Protection <br> Brownout Protection | $\begin{aligned} & 115 / 230 \mathrm{Vac} \pm 10 \%, 47-63 \mathrm{~Hz} \\ & 150 \mathrm{~W} \text { max. } \\ & 20.0 \mathrm{~A} \text { max. } \\ & \text { 4.0A ave. max., 8.0A peak } \\ & 1.5 \mathrm{~A} \text { max. } \\ & 1.0 \mathrm{~A} \text { max. } \\ & 0.5 \mathrm{~A} \text { max. } \\ & \text { Adjustable } \pm 5 \% \\ & \pm 5 \% \text { max. } \\ & \pm 1 \% \text { all output } \\ & 20 \% \text { to } 100 \% \text { max. rated load } \\ & \pm 1 \% \text { max. } \\ & \pm 3 \% \text { max. } \\ & 0.2 \% \text { RMS } \\ & 0.02 \% /{ }^{\circ} \mathrm{C} \end{aligned}$ <br> No turn on or turn off overshoot <br> Current limit protection on all outputs <br> All outputs protected against power supply induced overvoltage. <br> Holds full rated regulation to 85/170 Vac | Hold Up Time <br> Temperature Range <br> Dimensions <br> A <br> B <br> C <br> D <br> E <br> F <br> G <br> H <br> J <br> K <br> $L$ <br> M <br> N <br> Output Cable Length <br> Type Gauge Termination Routed Outputs | 16 ms min . at nominal line input with full load output <br> $0^{\circ} \mathrm{C}$ to $50^{\circ} \mathrm{C}$ full rating, derated $2 \%$ per ${ }^{\circ} \mathrm{C}$ linearly from $50^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$. <br> 10.50 in . $\mathbf{( 2 6 6 . 7 \mathrm { mm } \text { ) } ) ~}$ <br> 5.00 in. ( 127.0 mm ) <br> $2.50 \mathrm{in} .(63.5 \mathrm{~mm})$ <br> 3.90 in . $(99.0 \mathrm{~mm}$ ) <br> $0.30 \mathrm{in} .(7.6 \mathrm{~mm})$ <br> 8.90 in . $(226.0 \mathrm{~mm})$ <br> 0.38 in. ( 9.6 mm ) <br> 1.62 in . ( 41.1 mm ) <br> 0.25 in. ( 6.4 mm ) <br> 10.00 in . $(254.0 \mathrm{~mm})$ <br> 12.5 in. ( 317.5 mm ) <br> 8-32 THD. (4) <br> 0.156 in . ( 3.96 mm ) DIA. (4) <br> 12 in . $\mathbf{3 0 4 . 8 \mathrm { mm } \text { ) } ) ~}$ <br> 3-wire jacketed with internal balun <br> 20 AWG <br> Tinned leads $+5 \mathrm{~V},+24 \mathrm{~V} \text { and COM }$ |
| Note: <br> *Referenced to nominal input voltage at $60 \%$ load on all outputs with +5 V output set to +5.00 V . |  |  |  |



## A65/40-0200 AND A65/40-0210 AIM 65/40 STANDARD AND EXTENDED KEYBOARDS

## OVERVIEW

The A65/40-0200 and A65/40-0210 keyboard subassemblies are one of the hardware options available for the AIM 65/40 Microcomputer family.

The A65/40-0200 Standard Keyboard is a full-size ASCII keyboard. The 57 main keys provide the complete set of 128 ASCII printable and control characters. Eight separate function keys, located above the main keyboard, support user-defined processes. Separate ATTN and RESET keys allow user-defined interrupt processing and computer initialization. An industry standard, NMOS parallel interface can be used to connect the keyboard to a Rockwell AIM 65/40 Single-Board Computer (SBC), Rockwell RM 65 board-level products, or to other computers.

The A65/40-0210 Extended Keyboard has all of the above features, plus an industry standard numeric keyboard and cursor control key

## FEATURES

- Full-size, terminal-style keyboard
- 64 keys within an $8 \times 9$ matrix support the ASCII character set:
-Alphanumerics
-Punctuation
-Special symbols
-PRINT
-Eight special functions
-Locking ALL CAPS
- Separate RESET, ATTN, and PAPER FEED keys
- Extended keyboard has 15 additional keys; 10 numeric, decimal point and 4 cursor control keys
- No active components ensures long life
- Keyboard interface connector compatible with AIM 65/40 SBC or RM 65 Parallel Application connectors


A65/40-0200 Standard Keyboard


A65/40-0210 Extended Keyboard

## FUNCTIONAL DESCRIPTION

The AIM 65/40 Keyboard assembly is a terminal-style alphanumeric keyboard which interfaces to a host computer through a parallel interface. The keyboard contains 66 momentary contact single pole single throw (SPST) keys and one locking SPST key.

The keyboard has a complement of 63 momentary contact keys in an $8 \times 9$ matrix; with nine positions unused. An ALL CAPS locking key is also in this matrix. To decode keys within the matrix, the AIM 65/40 software places a logic 0 on one of the nine strobe lines of the matrix. By reading the eight return lines, any key(s) down on that strobe row can be distinguished. Repeating this process for each of the nine strobe rows gives
an image of the entire keyboard matrix. Three momentary contact keys-RESET, ATTN, and PAPER FEED are outside of the keyboard matrix.

All keyboard strobe and return lines are brought out to a $40-\mathrm{pin}$ keyboard interface connector, which allows direct connection to an AIM 65/40 SBC or any RM 65 modules with the parallel peripheral connector.

The added keys on the Extended Keyboard control 15 additional momentary contact SPST switches, which are included in the $8 \times 9$ switch matrix. The 11 numeric and decimal switches are connected in parallel with their counterparts on the main keyboard. The four cursor control switches are added positions in the matrix which are not included in the Standard Keyboard.


Keyboard Functional Block Diagram
Connector P1 (System Interface) Pin Assignments

| Pin | Signal | Pin | Signal |
| :---: | :---: | :---: | :---: |
| 40 | RES | 39 | NC |
| 38 | ATTN | 37 | GND (1) |
| 36 | MSB7 | 35 | GND (1) |
| 34 | MSB6 | 33 | GND (1) |
| 32 | MSB5 | 31 | GND (1) |
| 30 | MSB4 | 29 | GND (1) |
| 28 | MSB3 | 27 | GND (1) |
| 26 | MSB2 | 25 | GND (1) |
| 24 | MSB1 | 23 | GND (1) |
| 22 | MSBO | 21 | GND (1) |
| 20 | MRT7 | 19 | GND (1) |
| 18 | MRT6 | 17 | GND (1) |
| 16 | MRT5 | 15 | GND (1) |
| 14 | MRT4 | 13 | GND (1) |
| 12 | MRT3 | 11 | GND (1) |
| 10 | MRT2 | 9 | GND (1) |
| 8 | MRT1 | 7 | RES RET |
| 6 | MRTO | 5 | ATTN RET |
| 4 | MSB8 | 3 | PAPER FEED RET |
| 2 | PAPER FEED | 1 | NC |

Notes:
(1) Odd-numbered pins 9 through 37 are connected together on the keyboard and should be connected to GND on the interfacing equipment.
(2) The pin number assignments are reversed from the AIM $65 / 40$ SBC, to provide a one-to-one signal routing through a 40 -conductor ribbon cable.


Keyboard Schematic
SPECIFICATIONS

| Parameter | Value |  |
| :---: | :---: | :---: |
| Dimensions | Standard | Extended |
| Width | 11.85 in . (301 mm) | 15.35 in . ( 390 mm ) |
| Length | 5.25 in. ( 133 mm ) | $5.25 \mathrm{in} .(133 \mathrm{~mm})$ |
| Height | 1.25 in . ( 32 mm ) | $1.25 \mathrm{in} .(32 \mathrm{~mm}$ ) |
| Weight | 1 lb .8 oz . | 1 lb .12 oz. |
| Environment |  |  |
| Operating Temperature | $0^{\circ} \mathrm{C}$ to $50^{\circ} \mathrm{C}$ |  |
| Storage Temperature Relative Humidity | $-40^{\circ} \mathrm{C}$ to $55^{\circ} \mathrm{C}$ $0 \%$ to $95 \%$ (withou |  |
| Interface Connector | 40-pin 3M \#3495-10 <br> \#3418-0000T, or eq | with 3M |



Keyboard Dimensions

# A65/40-0400 AIM 65/40 40-CHARACTER DISPLAY 

## OVERVIEW

The A65/40-0400 40-Character Display is one of the hardware options available for the AIM 65/40 Microcomputer family.

The 40-Character Alphanumeric Display is a free-standing subassembly consisting of a vacuum fluorescent display and a microprocessor based controller. With its integral controller, operation is completely automatic-including display refresh. Connecting to a host computer over parallel interface with Cen-tronics-compatible protocol, command and data are transferred in a handshaking manner.

The sealed vacuum fluorescent display includes 40 bright, crisp, 16 -segment digits. The blue-green characters are easily readable in almost any working environment-from office to factory.

Firmware functions in the controller augment basic communication and display updating with a variety of editing functions and display enhancements to increase its usability. The full $40-$ characters, coupled with programmable eye-catching techniques, such as variable rate character blinking and auto-scrolling, allow meaningful and important messages to be displayed, detected and understood-in factory, office, laboratory and classroom applications.

Installation in a wide variety of racks, cabinets, enclosures, and front panels is easy due to its straightforward construction and standard interface. The display can be connected directly to the Rockwell A65/40-1000 Single Board Computer (SBC), to Rockwell RM 65-1000E SBC module or RM65-5222E GPIO and Timer module, or other compatible equipment, through an interconnecting cable.

## FEATURES

- Intelligent controller
-Independent operation
-Centronics type handshake interface
-Separate character font/program ROM
- 40-character display
-Vacuum fluorescent
-Easy-to-read 16-segment digits
-Clear, bright blue-green color
-Fast response
-Long life
- 196 characters
-Upper case alphabetics with lower case notation
—Numbers
-Math symbols
-Special characters
- Variable display parameters
-Auto-scroll rate
—Character blinking
-Character blink rate
-Cursor blink rate
- Internal editing functions
—80-character line buffer
- Insert/delete character
-Right/left cursor control
-Transmit edited line to host
- Display self-test
- +5 V operation


A65/40-0400 40-Character Display

## FUNCTIONAL DESCRIPTION

The 40-Character Display contains a vacuum fluorescent display, a microprocessor based controller, clock, a 2K-byte character font/program ROM, character and segment drivers, and a DC/DC power converter.

The vacuum fluorescent display is a single sealed unit containing 40 separately controllable digits. Each digit is composed of a 16 -segment font which allows a full set of upper case alphabetics, numerics, and special characters to be displayed. In the semi-graphics mode, the 16 segments of each digit are individually controlled. In addition, each digit includes a separate decimal point. When energized, the digits form blue-green color characters. The unit comes with a smoked, neutral filter lens cover the display, but other custom lens filters can be used to change the display color to meet unique installation requirements.

The display controller includes an R6504 CPU, RAM, I/O, timer, clock and reset circuitry. The 2K byte ROM contains both the CPU controller instructions and the individual character segment patterns. This ROM can be replaced by another PROM or ROM
to provide a custom character set. The controller performs all communications interfacing, display refreshing, and control functions-enabling the display to operate independently from the host computer.

All data and control commands are transmitted to the display over the Centronics-type parallel handshake interface. An internal buffer allows up to 80 characters to be received by the display; the display scrolls after the 40th character is received. There are character editing commands such as insert and delete, as well as transmit buffer, which sends an edited line back to the host computer. There are also display enhancement features such as auto-scroll which allows the display buffer to be continuously circulated, at a selected rate, and blinking characters.

The two-post terminal block provides +5 V for the controller and for the on-board DC/DC Converter, which generates the additional voltages required by the fluorescent display. The +5 V can, alternatively, be routed through the interface connector.

Display Control Commands

| Hex Code | Control Character | Description | Hex Code | Control Character | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | CTRL @ | * | 10 | CTRL P | Pass Through Next Character |
| 01 | CTRL A | Clear Line | 11 | CTRL Q |  |
| 02 | CTRL B | Clear to End of Line | 12 | CTRL R |  |
| 03 | CTRL C | Clear Line | 13 | CTRL S | Toggle Insert Character Mode |
| 04 | CTRL D | Clear to End of Line | 14 | CTRL T | Delete One Character |
| 05 | CTRLE | Clear Line | 15 | CTRL U |  |
| 06 | CTRL F | Clear to End of Line | 16 | CTRL V | * |
| 07 | CTRL G | * ${ }^{\text {a }}$ | 17 | CTRL W | Display Cursor |
| 08 | CTRL H | Backspace ( $\leftarrow$ ) | 18 | CTRL X | Blank Cursor |
| 09 | CTRLI | Horizontal Tab $\rightarrow$ ) | 19 | CTRL Y | Warm Reset |
| 0 A | CTRL J | Warm Reset | 1A | CTRL Z | Cold Reset |
| OB | CTRLK | Warm Reset | 1 B | CTRL [ | Escape Command (ESC) |
| ${ }^{0} \mathrm{C}$ | CTRLL | Warm Reset | 1 C | CTRL\} | - |
| OD | CTRL M | (Home on Line) | 1D | CTRL ] | * |
| OE | CTRL N | (Home on Line) | 1E | CTRL $\wedge$ | * |
| OF | CTRL 0 | Carriage Return (Home on Line) | 1F | CTRL - | * |

[^18]

40-Character Display Block Diagram

Display Escape Commands

| Hex Code | Character Sequence | Function |
| :--- | :--- | :--- |
| 1B 41 | ESC A | Auto-Scroll Display |
| 1B 45. | ESC E x y | Set Environment (1) |
| 1B 47 | ESC G | Enter Graphics Mode |
| 1B 49 | ESC I | Select/Deselect Display (toggle) |
| 1B 54 | Perform Self-Test |  |
| 1B 58 4C | ESC X L | Transmit Line |
| 1B 3D | ESC $=\times y$ | Position Cursor (2) |
| 1B 58 | ESC W | Set Window Position |
| ESC X | Transmit Display Line |  |

Notes:
(1) Set Environment Sequence:

| Hex Code |
| :--- |
| 41 XX |
| 42 YY ZZ |
| 43 YY ZZ |
| 52 XX |
| 53 XX |


| Character Sequence |
| :---: |
| $A$ (Attribute) |
| B (On) (Off) |
| C (On) (Off) |
| R (Rate) |
| S (Character) |

## Function

Set Bit-7 Attributes
Set Blinking Character Rate
Set Blinking Cursor Rate
Set Auto-Scroll Rate
Set the Cursor Character
(2) The Position Cursor sequence requires two additional characters. The first $(\mathrm{y})$ is ignored. The second $(\mathrm{x})$ becomes the new cursor position.

Connector J1 (Interface) Pin Assignments


Data Transfer Timing Characteristics

| Symbol | Parameter | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| T ${ }_{\text {dsu }}$ | Data Set-Up Time | 0 | - | - | $\mu \mathrm{S}$ |
| T ${ }_{\text {d }}$ | Data Hold Time | 25 | - | - | $\mu \mathrm{s}$ |
| Ts | Strobe Pulse Width Time | 50 | - | - | ns |
| Tp | Processing Time | - | 500 | - | $\mu \mathrm{S}$ |
| $\mathrm{T}_{\text {A }}$ | Acknowledge Width | - | 5 | - | $\mu \mathrm{S}$ |
| $\mathrm{T}_{\text {SB }}$ | Strobe-to-Busy Time | - | 14 | 25 | ns |
| $T_{\text {AB }}$ | Acknowledge-to-Busy Time | - | 20 | 40 | ns |
| Note: $\mathrm{t}_{\mathrm{r},} \mathrm{t}_{\mathrm{f}}=10$ to 30 ns |  |  |  |  |  |



Data Transfer Waveforms

## SPECIFICATIONS



NMOS Interface (Input Voltage $=+5.0 \mathrm{~V}, \mathrm{TA}=25^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | Input High Voltage | 2.4 | 5.0 | V |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.3 | +0.4 | $v$ |
| $\mathrm{I}_{\mathrm{IH}}$ | Input High Current | -100 | -300 | $\mu \mathrm{A}$ |
|  | ( $\mathrm{V}_{\text {IH }}=2.4 \mathrm{~V}$ ) |  |  |  |
| $1 / 1$ | Input Low Current $\left(V_{I L}=0.4 A\right)$ | -1.0 | -1.6 | mA |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 2.4 | 5.0 | V |
|  | $\left(I_{\text {LOAD }} \leqslant-100 A\right)$ |  |  |  |
| VoL | Output Low Voltage | - | 0.4 | v |
|  | $\left(l_{\text {LOAD }} \leqslant-3 \mathrm{~mA}\right)$ |  |  |  |
| $\mathrm{IOH}^{\text {d }}$ | Output High Current (Sourcing) $\left(\mathrm{V}_{\mathrm{OH}} \geqslant 2.4 \mathrm{~V}\right)$ | -100 | - | $\mu \mathrm{A}$ |
| IoL | Output Low Current (Sinking) $\left(\mathrm{V}_{\mathrm{OL}} \leqslant 0.4 \mathrm{~V}\right)$ | 1.6 | - | mA |



Character Display

## A65/40-0600 AIM 65/40 GRAPHICS PRINTER

## OVERVIEW

The A65/40-0600 Graphics Printer is one of the hardware options available for the AIM 65/40 Microcomputer Family.

The Graphics Printer is a microprocessor-controlled dot matrix thermal printer, with a 4 K byte character font/program ROM, and a paper feed switch. In the test mode, up to 40 characters can be printed using $7 \times 8$ dot matrix characters. In the graphics mode, all 280 horizontal dot positions on a row are individually controlled, and any number of rows may be printed.

The printer mechanism includes a thermal head, platen, motor, drive linkage and associated wiring. There are 40 thermal elements on the thermal head, each of which spans seven dot fields. Each element is a discrete point which rides against heat sensitive paper. During a print cycle, the thermal head moves horizontally across the paper. Control logic turns on the thermal head drivers to heat the sensitized paper when a dot is to be printed. When an entire row of dots has been printed, the printer motor advances the platen by one horizontal row of dots.

The printer controller includes an R6504 CPU, RAM, I/O, timer, clock and reset circuitry. The 4 K byte ROM contains both the CPU instructions and the individual character bit patterns. The ROM is socketed, and can be replaced by a user-supplied PROM or ROM, to provide a custom character set. The con-


A65/40-0600 Graphics Printer
troller performs printer motor and thermal head timing and control functions, to enable the printer to operate independently from the host computer. Further, the controller handles the communications interface, and processes the commands and data to be printed.

Data and control commands are transmitted to the printer over the Centronics type parallel handshake interface. An internal buffer accepts up to 80 characters for printing. The controller automatically prints the first 40 characters in the text mode or after receiving each row of 280 dots in the graphics mode. The paper can also be advanced with a paper feed command, or manually, using the paper feed switch.

A three-post terminal block connects to $+5 \mathrm{~V},+24 \mathrm{~V}$ and GND. The +5 V supplies the control circuitry while the +24 V powers the motor and thermal head drivers. On-board potentiometers allow motor speed and dot print intensity to be manually adjusted.

## FEATURES

- Intelligent controller
-Independent operation
-User command flexibility
-Centronics type handshake interface
-Separate character font/program ROM
- 40-column text/semi-graphics
-256 character set
-     - Upper and lower case alphabetics
-Numbers including superscripts and subscripts
-Math symbols
-European and Greek characters
- Full graphics capability
- $\mathbf{2 8 0}$ dot $\times n$
-Individual dot control
-Print complex wave forms and digitized photographs
- Fast-240 lines per minute
- Quiet, thermal operation
- User alterable dot timing
- Printer self-test
- Requires only +5 V and +24 V

Printer Control Commands


Printer Escape Commands

| Hex Code | Character Sequence | Function |
| :---: | :---: | :---: |
| 1B 3D | $E S C=y x$ | Position Cursor (1) |
| 1B 45 | ESC E x | Set Environment (2) |
| 1B 47 | ESC G | Enter Graphics Mode |
| 1B 53 | ESC S | Transmit Character Definition |
| 1B 54 | ESC T | Perform Self-Test |
| Notes: <br> (1) The Position Cursor sequence requires two additional characters. The first (y) is ignored. The second ( $x$ ) becomes the new cursor position. |  |  |
|  |  |  |
| (2) Set Environment Sequence: |  |  |
| Hex Code | Character Sequence | Function |
| 41 XX | A (Attribute) | Set Bit 7 Attributes |
| 47 XX | G (Length) | Set Gap Between Pages |
| 50 XX | P (Length) | Set Page Length |
| 54 XX | T (Time) | Set Dot Print Time |

## Data Transfer Timing

| Symbol | Parameter | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| TpSU | Data Set-up Time | 0 | - | - | $\mu \mathrm{S}$ |
| TDH | Data Hold Time | 25 | - | - | $\mu \mathrm{s}$ |
| $\mathrm{T}_{\mathrm{s}}$ | Strobe Pulse Width Time | 50 | - | - | ns |
| Tp | Processing Time (non-printing) | 0.13 | 0.15 | 12 | ms |
| $T_{P}$ | Processing Time (printing) | 0.25 | - | 0.5 | S |
| $\mathrm{T}_{\text {A }}$ | Acknowledge Puilse Width Time | - | 5 | - | $\mu \mathrm{s}$ |
| $T_{\text {SB }}$ | Strobe-to-Busy Time | - | 14 | 25 | ns |
| $\mathrm{T}_{\text {AB }}$ | Acknowledge-to-Busy Time | - | 20 | 40 | ns |



0

Data Transfer Waveforms

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions Width Length Height | 7.6 in. (193 mm) 6.3 in. ( 160 mm ) 3.0 in . $(77 \mathrm{~mm})$ |
| Weight | $1.0 \mathrm{lb} .(0.45 \mathrm{~kg})$ |
| Environment Operating Temperature Storage Temperature Relative Humidity | ```0% C to 50 0 0% to 85% (without condensation)``` |
| Power Requirements | $+5 \mathrm{~V} \pm 5 \%$ Regulated, 0.3 A (typical); 0.4 A (max.); 0.4 (peak) <br> $+24 \mathrm{~V}(+3.6 \mathrm{~V},-2.6 \mathrm{~V}$ ) Unregulated, 2.5A (typical); 4.0A (max.); 6.3* (peak) |
| Interface Connector <br> Power Connector | 40-pin 3M\#3495-1002, or equivalent, receptacle. Mates with 3M \#3418-0000T, or equivalent, ribbon cable connector. <br> 3-post terminal block |

Connector J4 (System Interface) Pin Assignments


NMOS Interface (Input Voltage $=\mathbf{+ 5 . 0 V}$, TA $=\mathbf{2 5}{ }^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{IH}}$ | Input High Voltage | 2.4 | 5.0 | V |
| $\mathrm{V}_{\text {IL }}$ | Input Low Voltage | -0.3 | +0.4 | V |
| $\mathrm{I}_{\mathrm{H}}$ | Input High Current $\left(V_{I H}=2.4 V\right)$ | -100 | -300 | $\mu \mathrm{A}$ |
| $1 / 2$ | Input Low Current $\left(V_{\mathrm{IL}}=0.4 \mathrm{~A}\right)$ | -1.0 | -1.6 | mA |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage ( $\mathrm{L}_{\text {LOAD }} \leqslant-100 \mathrm{~A}$ ) | 2.4 | 5.0 | V |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage $\left(l_{\text {LOAD }} \leqslant-3 \mathrm{~mA}\right)$ | - | 0.4 | V |
| $\mathrm{IOH}^{\text {O}}$ | Output High Current (Sourcing) $\left(\mathrm{V}_{\mathrm{OH}} \geqslant 2.4 \mathrm{~V}\right)$ | -100 | - | $\mu \mathrm{A}$ |
| 1 OL | Output Low Current (Sinking) $\left(\mathrm{V}_{\mathrm{OL}} \leqslant 0.4 \mathrm{~V}\right)$ | 1.6 | - | mA |

FAt Bx
FDrt = GEAE
TEST GDUNT $=0 \mathrm{~B}$


| 6 |  |
| :---: | :---: |
| 1 |  |
| 2 |  |
| 3 |  |
| 4 | EiETEEFGHISKLTMD |
| 5 |  |
| $E$ |  |
| 7 |  |
| 8 |  |
| 5 |  |
| A |  |
| - |  |
| E |  |
| [ |  |
| $E$ |  |
| F |  |




世 W


# AIM 65/40-0800 VIDEO DISPLAY CONTROLLER (VDC) MODULE 

## OVERVIEW

The A65/40-0800 Video Display Controller (VDC) module interfaces the A65/40-1000 Rockwell AIM 65/40 Single Board Computer, RM65-1000 Single Board Computer or RM65-5223 MultiFunction Peripheral Interface module, or any other host computer with an industry compatible Centronics-type parallel interface, to a CRT monitor or TV receiver. The VDC module outputs an NTSC compatible composite video on one connector and separate HSYNC, VSYNC and VIDEO signals at TTL levels on another connector for convenient CRT interfacing.

With its integral microcomputer controller, built-in commands provide selectable and programmable screen formatting, flexible text handling and editing, and full graphics drawing and data display functions. These CRT-oriented functions extend the use of the AIM 65/40 microcomputer into new man-machine applications in the factory, office, laboratory and classroom.

In the text mode, preprogrammed formats of 80 characters $\times$ 24 lines or 40 characters $\times 24$ lines are selectable. Other formats are user programmable. Eight pages of text are available (in the $80 \times 24$ format) with automatic page sizing for other formats. The 4 K -byte character generator ROM contains bit patterns for 256 different characters in a $7 \times 10$ dot matrix field. Standard characters include upper- and lower-case alphabetics, numerals (including subscripts and superscripts), math and Greek symbols, common European letters, and semigraphic characters.

The full graphics mode incorporates bit mapping of $280 \times 224$ pixels, which is compatible with the Rockwell AIM 65/40 Graphics Printer (A65/40-0600). Line drawing commands move a pen and draw or erase lines using either relative or absolute position reference. Data byte capability allows individual dots to be controlled using a 40 bytes per dot line format (seven dots per byte). In addition, the entire screen display data can be transmitted to the host computer.


## FEATURES

- Independent Intelligent Controller
-6502 CPU Based
-Centronics-type Parallel Handshake Interface
-4K-byte Program ROM
-4K-byte Character ROM
-16K-bytes of Refresh RAM
- Flexible Text Mode Operation
-Selectable 80 or 40 Columns $\times 24$ Lines
-Other Screen Formats Programmable
-Multiple Text Pages
-Cursor Movement and Positioning
-Character and Line Editing
-Line, Page, and Buffer Control
-Inverse Video on a Character Basis
- 256 Character ROM
-Upper- and Lower-case Alphabetics
-Numerals Including Subscripts and Superscripts
-Math Symbols
-European and Greek Letters
-Semigraphic Symbols
- Full Graphics Mode
$-280 \times 224$ Pixels Resolution
-Line Drawing Functions
- Individual Bit Map Control
-Transmit Screen to Host
- Two Video Output Formats
-Separate VIDEO, HSYNC and VSYNC TTL Signals
-NTSC or European Compatible Composite VIDEO Signal
- Self-Test
- +5 V Operation


## SELF-TEST

A self-test function tests the microcomputer RAM, calculates and displays the program ROM check-sum, and displays all the characters generated by the Character Generator ROM.

A65/40-0800 VDC Module

## FUNCTIONAL DESCRIPTION

The A65/40-0800 VDC module consists of four major sections:

- Microcomputer Section
- CRT Section
- Oscillator
- DC/DC Power Converter

The microcomputer section consists of a R6502 Central Processing Unit (CPU), R6532 RAM, Input/Output and Timer (RIOT), a 4K-byte R2332 program ROM, address decoder, reset timer and associated support circuitry. The CPU also has major interfaces with the R6545-1 CRT Controller (CRTC) and the refresh RAM (through address multiplexers) in the CRT section. Internal data, address and control bus lines interconnect these devices within the VDC module.

The CPU controls the transfer of data received from the host computer on data lines D0-D7 through the RIOT onto internal data bus lines. If the data is a command, the CPU performs the associated processing and sends appropriate commands to the R6545-1 CRTC. Display data is passed from the CPU onto the refresh RAM for subsequent display as text or graphics.

The 4K-byte Program ROM contains the CPU program instructions which implement the control and escape commands. This ROM can be replaced with a compatible 4 K - or 8 K -byte $\mathrm{PROM} /$ ROM device for custom applications.

The R6532 RIOT supplies the RAM and I/O required for CPU control. Eight of the 16 V/O port lines interface the data I/O lines while two lines service the STROBE and $\overline{\text { ACK signals at the }}$ connector J1 interface. Five other lines (80/40 characters/line, normal/inverse video, display mode, blanking and DISPLAY ENABLE) interface with the CRT section.

The CRT section consists of the R6545-1 CRTC and other logic to generate, combine and output the video signal. The R65451 CRTC provides the interface between the CPU and the rest of the CRT section. The CRTC generates refresh RAM addresses and character generator row addresses to allow text or graphics data to be accessed from the refresh RAM for converting to video format.

The CRTC operation is controlled by the contents of 16 internal registers which specify such screen format characteristics as the number of total and displayed horizontal characters, horizontal sync position, VSYNC and HSYNC pulse widths, number of total and displayed vertical rows, and the number of scan lines per character. In addition, the cursor position address and the display start address in the refresh RAM are programmable as are the cursor character start and stop scan lines.

Eight $411616 \mathrm{~K} \times 1$ dynamic RAM devices comprise the 16 K byte refresh RAM. This RAM is accessed by both the CPU and the CRTC through address multiplexers. Separate address lines from the CPU and from the CRTC are connected to the multiplexers which in turn output the RAM address lines to access the refresh RAM. An additional 16K $\times 1$ RAM device stores the normal/inverse status for each text character.

During the display trace, the CRT addresses the refresh RAM to output the text characters or graphics data on the RAM data output lines. DATA is retrieved from the RAM at the 1.714 MHz clock rate during 80 column text mode and at 0.857 MHz in the 40 column text mode and in the graphics mode. The data from the RAM is latched for text or graphics output.

In the text mode, the ASCII character codes on the latched refresh RAM data output lines form the character address to the character generator ROM. During text display, the bit patterns corresponding the ASCII characters are output on ROM data lines to the text parallel-to-serial converter which then shifts the data out serially to the video combining circuit.

In the graphics mode, each byte in the refresh RAM contains a dot pattern rather than a character ASCII code. The bit patterns on the latched refresh RAM output data are loaded directly into the graphics parallel-to-serial converter which then shifts the data out serially to the video combining circuit.

The selected text or graphics serial data is combined with the CURSOR signal, the BLANK signal and the character INVERSE signal.

This merged video signal is then converted to TTL level and routed to connector J3 as the separate video signal. The VSYNC and HSYNC outputs from the CRTC are routed through drivers to the same connector.

The driven VSYNC and HSYNC signals are nor'ed to produce the combined SYNC signal. The SYNC signal is then combined with the merged video signal, converted to NTSC format and routed to connector J2 as the composite video signal. Trimmer potentiometers allow adjustment of the contrast and brightness levels.

The VDC module operates on +5 V provided either from the host computer through connector J 1 or from a terminal block (TB1) connection. +12 V and -5 V are generated on-board by a $\mathrm{DC} /$ DC power converter. Optional connections on TB1 also allow +12 V and -5 V to be provided externally.


A65/40-0800 VDC Module Block Diagram

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Outside Dimensions <br> Width <br> Height* <br> Depth* <br> Component Height <br> Lead Protrusion | $\begin{array}{cc} 11.85 \mathrm{in} . & (301 \mathrm{~mm}) \\ 4.9 \mathrm{in} . & (124 \mathrm{~mm}) \\ 0.6 \mathrm{in} . & (14 \mathrm{~mm}) \\ 0.4 \mathrm{in} . & (10 \mathrm{~mm}) \\ 0.1 \mathrm{in} . & (2.5 \mathrm{~mm}) \\ \hline \end{array}$ |
| Weight | $9.5 \mathrm{oz} . \quad(270 \mathrm{~g})$ |
| Environment <br> Operating Temperature <br> Storage Temperature <br> Relative Humidity | $\begin{aligned} & 0^{\circ} \mathrm{C} \text { to } 70^{\circ} \mathrm{C} \\ & -55^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C} \\ & 0 \% \text { to } 85 \% \text { (without condensation) } \end{aligned}$ |
| Power Requirements <br> Internally Generated +12 V and -5 V <br> Externally Supplied +12 V and -5 V | $\begin{aligned} & +5 \mathrm{~V} \pm 5 \% \text { Regulated-0.85 A (typical); 1.5A (max.) } \\ & +5 \mathrm{~V} \pm 5 \% \text { Regulated-0.5 } \mathrm{A} \text { (typical); } 1.2 \mathrm{~A} \text { (max.) } \\ & +12 \mathrm{~V} \pm 5 \% \text { Regulated- } 200 \mathrm{~mA} \text { (typical); } 315 \mathrm{~mA} \text { (max.) } \\ & -5 \mathrm{~V} \pm 5 \% \text { Regulated-1.4 } \mathrm{mA} \text { (typical); } 1.8 \mathrm{~mA} \text { (max.) } \end{aligned}$ |
| Interface Connection <br> Host Computer <br> Separate Video <br> Composite Video <br> Power Connector | 40-pin 3M \#3495-1002, or equivalent, connector. Mates with 3M \#3417-6040, or equivalent, ribbon cable connector <br> 6 -pin right angle connector. Mates with AMP 87159-6, or equivalent, connector (supplied with module) <br> Single conductor screw-on right angle coaxial connector. Mates with Sealectro 50-024-0000, or equivalent, connector (supplied with module) <br> Four-post terminal block ( $+5 \mathrm{~V},+12 \mathrm{~V},-5 \mathrm{~V}$, and GND) |
| *Dimensions do not include mounting br |  |

NMOS Interface (Input Voltage $=+5.0 \mathrm{~V}, \mathrm{TA}=25^{\circ} \mathrm{C}$ )

| Symbol | Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {th }}$ | Input High Voitage | 2.4 | 5.0 | V |
| $V_{\text {IL }}$ | Input Low Voitage | -0.3 | +0.4 | V |
| $\mathrm{I}_{\mathrm{H}}$ | Input High Current $\left(\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}\right)$ | 100 | 300 | $\mu \mathrm{A}$ |
| I/L | Input Low Current $\left(V_{I L}=0.4 \mathrm{~V}\right)$ | -1.0 | -1.6 | mA |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage $(\text { I LOAD } \leqslant-100 \mu \mathrm{~A})$ | 2.4 | 5.0 | V |
|  | ( 1 LOAD $\leqslant-3 \mathrm{~mA}$ ) | 1.5 | 5.0 | V |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage $(I \operatorname{LOAD} \leq 1.6 \mathrm{~mA})$ | 0 | 0.4 | v |
| $\mathrm{IOH}^{\text {O}}$ | Output High Current (Sourcing) $\left(\mathrm{V}_{\mathrm{OH}} \geqslant 2.4 \mathrm{~V}\right)$ | -100 | -1000 | $\mu \mathrm{A}$ |
| 10 L | Output Low Current (Sinking) $\left(V_{\mathrm{OL}} \leqslant 0.4 \mathrm{~V}\right)$ | 1.6 | - | mA |

Connector J 1 (Interface) Pin Assignments


Connector J2 (Composite Video) Pin Assignments

| Pin | Signal | I/O | Type |
| :---: | :--- | :---: | :---: |
| Center <br> Shield | Composite Video <br> GND | 0 | NTSC |

Connector J3 (Separate Video) Pin Assignments

| Pin | Signal | I/O | Type |
| :---: | :--- | :---: | :---: |
| 1 | Video | 0 | TTL |
| 2 | GND | - | - |
| 3 | VSYNC | 0 | TTL |
| 4 | GND | - | - |
| 5 | HSYNC | 0 | TTL |
| 6 | GND | - | - |

Data Transfer Timing Characteristics

| Symbol | Parameter | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| T ${ }_{\text {dSU }}$ | Data Set-Up Time | 0 | - | - | $\mu \mathrm{s}$ |
| T ${ }_{\text {DH }}$ | Data Hold Time | 25 | - | - | $\mu \mathrm{s}$ |
| $\mathrm{T}_{\text {s }}$ | Strobe Pulse Width Time | 50 | - | - | ns |
| Tp | Processing Time | 0.1 | - | 500 | ms |
| $\mathrm{T}_{\text {A }}$ | Acknowledge Width | - | 5 | - | $\mu \mathrm{s}$ |
| $\mathrm{T}_{\text {SB }}$ | Strobe-to-Busy Time | - | 14 | 25 | ns |
| $\mathrm{T}_{\text {AB }}$ | Acknowledge-to-Busy Time | - | 20 | 40 | ns |

Note: $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}=10$ to 30 ns


Data Transfer Waveforms

Video Display Control Commands

| Hex Code | Control Character | Description | Hex <br> Code | Control Character | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | CTRL@ | * | 10 | CTRL P | Pass Through Next Character |
| 01 | CTRLA | Clear Line | 11 | CTRL Q | Next Page |
| 02 | CTRL B | Clear to End of Line | 12 | CTRL R | Previous Page |
| 03 | CTRL C | Clear Page | 13 | CTRL S | Toggle Insert Character Mode |
| 04 | CTRL D | Clear to End of Page | 14 | CTRL T | Delete One Character |
| 05 | CTRL E | Clear Buffer | 15 | CTRL U | Insert One Line |
| 06 | CTRL F | Clear to End of Buffer | 16 | CTRL V | Delete One Line |
| 07 | CTRL G |  | 17 | CTRL W | Display Cursor |
| 08 | CTRL H | Cursor Left (Backspace) | 18 | CTRL X | Blank Cursor |
| 09 | CTRL ! | Cursor Right (Horizontal Tab) | 19 | CTRL Y | Cold Reset |
| OA | CTRL J | Cursor Down (Line Feed) | 1 A | CTRL Z | Warm Reset |
| OB | CTRL K | Cursor Up (Vertical Tab) | 1B | CTRL [ | Escape Command (ESC) |
| ${ }^{O C}$ | CTRL L | Next Page (Form Feed) | 1 C | CTRL | Cursor Down (Line Feed) |
| OD | CTRL M | Home on Line (Carriage Return) | 1D | CTRL ] | Home Cursor on Last Line |
| OE | CTRL N | Home on Page | 1E | CTRLA | Cursor Up (Vertical Tab) |
| OF | CTRL O | Home on Buffer | 1F | CTRL - |  |

Video Display Escape Commands


Video Display Graphics Commands



Character Set

## A65/40-7010 AIM 65/40 ASSEMBLER ROM

## ASSEMBLY LANGUAGE

An assembler translates microprocessor instructions and data statements written in symbolic form (the source program) into machine executable code (the object program). The AIM 65/40 Assembler translates one instruction, consisting of a label (if required), a mnemonic operation code, an operand (if required) and arithmetic operator (if required) into a machine instruction consisting of from one to three bytes of memory. Constants comprising one or more bytes of memory are generated from data statements while one or more bytes of memory are assigned to variables. The assembler operates in two passes. Pass 1 checks for syntax errors and assigns values to symbols in a symbol table. Pass 2 generates the actual machine code and outputs the assembly listing which lists the source code and the corresponding machine code.

The source code, is usually entered and edited using the AIM 65/40 Text Editor then assembled to generate the machine code for program execution and debugging. Program changes to the source program can easily be edited then the program reassembled to generate the new machine code thus eliminating the need for the programmer to code and recode the program in machine code-a time consuming and laborious process.

## PRODUCT OVERVIEW

The AIM 65/40 Assembler is a 4 K -byte ROM-resident, two-pass symbolic assembler that plugs into socket Z64 on the AIM 65/40 Microcomputer Single Board Computer (SBC) module and operates in conjunction with the AIM 65/40 I/O ROM and the AIM 65/40 Debug Monitor/Text Editor ROMs. The assembler translates computer program instructions written in standard assembly language for the 6502 microprocessor into machine code that will operate in any 6502 or 65XX CPU. Operating options are selected interactively by the operator upon assembly command. These options specify source code device, object code device, symbol table location, full assembly or errors only output listing and output listing device. A repeat command invokes the assembly according to previously commanded options for rapid setup during program debugging, editing and reassembly. Memory to memory assembly is supported to speed program generation. Compatibility with the RM 65 Floppy Disk Controller (FDC) module (RM65-5101NE) and AIM 65/40 DOS 1.0 (A65/40-7090) and AIM 65/40 BDOS 1.0 (A65/40-7092) allows source code to be input from one or more files on a floppy disk and object code to be output to a floppy disk file to assemble very large programs and to permanently save source and object code.

## FEATURES

- AIM 65/40 Microcomputer host
- 6502 machine code generation
- ROM-resident for immediate operation
- Symbolic linkage-operands and labels
- Interactive assembler operation setup
- Operator selected input device
-Memory (text buffer in RAM)
-Floppy disk
-Audio tape
-Serial
- User defined (interactive and non-interactive)
- Operator selected object code output device
-Memory (RAM)
-Floppy disk
—Audio tape
-Serial
-User-defined (interactive and non-interactive)
—Display/printer
-Printer
- Operator selected assembly/error listing output device
-Display/printer
-Printer
- Serial
-User-defined (interactive and non-interactive)
- Assembler directives
- AIM 65/40 DOS 1.0 and BDOS 1.0 compatible


## MEMORY MAP

| Address (Hex) | Contents |
| :---: | :---: |
| $\$ 9000-\$ 9 F F F$ | Assembler Program |
| $\$ 0-\$ D 6$ | Assembler Variables |

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| A65/40-7010 | AIM 65/40 Assembler ROM |
| Order No. | Description |
| 297 | AIM 65/40 Assembler User's Manual ${ }^{(1)}$ |
| Note: <br> (1) Included with A65/40-7010. |  |

R6502 CPU INSTRUCTIONS

| Mnemonic | Instruction | Mnemónic | Instruction |
| :---: | :---: | :---: | :---: |
| ADC | Add Memory to Accumulator with Carry | LDA | Load Accumulator with Memory |
| AND | AND Memory with Accumulator | LDX | Load Index X with Memory |
| ASL | Shift Left One Bit (Memory or Accumulator) | LDY | Load Index $Y$ with Memory |
| BCC | Branch on Carry Clear | LSR | Shift Right One Bit (Memory or Accumulator) |
| BCS | Branch on Carry Set | NOP | No Operation |
| BEQ | Branch on Result Zero | ORA | OR Memory with Accumulator |
| BMI | Branch on Result Minus | PHA | Push Accumulator on Stack |
| BNE | Branch on Result Not Zero | PHP | Push Processor Status on Stack |
| BPL | Branch on Result Plus | PLA | Pull Accumulator from Stack |
| BRK | Force Break | PLP | Pull Processor Status from Stack |
| BVC | Branch on Overifow Clear | ROL | Rotate One Bit Left (Memory or Accumulator) |
| BVS | Branch on Overflow Set | ROR | Rotate One Bit Right (Memory or Accumulator) |
| CLC | Clear Carry Flag | RTI | Return from Interrupt |
| CLD | Clear Decimal Mode | RTS | Return from Subroutine |
| CLI | Clear Interrupt Disable Bit | SBC |  |
| CLV | Clear Overflow Flag | SEC | Set Carry Flag |
| CMP | Compare Memory and Accumulator Compare Memory and Index X | SED | Set Decimal Mode |
| CPX | Compare Memory and Index $X$ Compare Memory and Index $Y$ | SEI | Set Interrupt Disable Status |
|  |  | STA | Store Accumulator in Memory |
| DEC | Decrement Memory by One | STX | Store Index X in Memory |
| DEX | Decrement Index X by One | STY | Store Index Y in Memory |
| DEY | Decrement Index Y by One | TAX | Transfer Accumulator to Index $X$ |
| EOR | Exclusive-OR Memory with Accumulator | TAY | Transfer Accumulator to Index $Y$ |
| INC | Increment Memory by One | TSX | Transfer Stack Pointer to Index $X$ |
| INX | Increment Index $X$ by One | TXA | Transfer Index $X$ to Accumulator |
| INY | Increment Index Y by One | TXS | Transfer Index $X$ to Stack Pointer |
| $\begin{aligned} & \text { JMP } \\ & \text { JSR } \end{aligned}$ | Jump to New Location Jump to New Location Saving Return Address |  |  |

AIM 65/40 ASSEMBLER DIRECTIVES

| Command | Function | Command | Function |
| :--- | :--- | :--- | :--- |
| . | Equate | OPT | Listing control option |
| .YYE | Byte constant | LIS/NOL | Assembly listing generation |
| WORD | Word constant | GEN/NOG | Object code question |
| .DBYTE | Double-byte constant | ERR/NOE | Error listing generation |
| .PAG | Page heading | FILE | Source code file linkage |
| .SKIP | Skip line(s) | END | Last statement/first source code file linkage |

# A65/40-7012 AIM 65/40 MACRO ASSEMBLER \& LINKING LOADER 

## DESCRIPTION

The AIM 65/40 Macro Assembler and Linking loader is a diskbased computer program that generates computer program absolute machine code or relocatable object code and links relocatable object code into absolute machine code. The assembler/loader operates on the AIM 65/40 Microcomputer and generates code for execution by any central processing unit (CPU) in the Rockwell R6500 NMOS microprocessor, R6500/* NMOS one-chip microcomputer and R65C00 CMOS microprocessor device families.

## MACRO ASSEMBLER

The macro assembler translates CPU instructions and data statements written in symbolic form (the source program), into absolute or relocatable code. Instructions, consisting of a label (if included), a mnemonic operation code, an operand (if required) and an arithmetic operator (if included), are assembled one-at-a-time into one- to three-byte machine instructions (with absolute or relocatable address information). Constants comprising one or more bytes of memory are generated from data statements while one or more bytes of memory are assigned to variables. The macro capability allows sequences of instructions, to be pre-defined for in-line code inclusion by specifying only the macro name. Conditional assembly allows portions of instruction sequences or macros to be included in (or excluded from) in-line code. The combination of the macro and conditional assembly capability speeds program development by eliminating duplicate coding efforts for similar processing tasks and increases program flexibility and reliability by allowing one source program to generate different computer programs based on specified control parameters.

## LINKING LOADER

The linking loader combines independently assembled modules of absolute and/or relocatable object code into a single executable object file. This allows a large program to be developed in manageable size modules and integrated by the linking process. This also allows program changes to be made to one module without affecting any of the other modules-a key requirement in many program validation and certification procedures.

Small programs can still be assembled into absolute executable code without using the linking loader, however, to simplify development.

The assembler/loader operates in conjunction with the AIM 65/40 BDOS 1.0 Upgrade Kit (A65/40-7092).

## MACRO ASSEMBLER FEATURES

- Supports three CPU families
-R6500 NMOS Microprocessor
-R6500/* NMOS Microcomputer
-R65C00 CMOS Microprocessor
- Flexible code generation
-Absolute executable code
-Relocatable linkable code
- Macro definition includes
-Multiple parameters
-Other macros
—Assembler
- Macro call includes
-Macro name
-Argument list
- Condition assembly
-IF condition
-ELSE complementary condition
- 12 conditional operators
- Symbol cross reference tale
-Lists defined and used symbols
-Alphanumeric order


## LINKING LOADER FEATURES

- Resolves inter-module symbol linkage
- Assigns absolute addresses
- Generates absolute executable code
- Produces reports
-Load map of module locations
-Symbolic debug table
-Symbol table
- Interactive or command file setup

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| A65/40-7012 | AIM 65/40 Macro Assembler and Linking Loader ${ }^{(1)}$ |
| Order No. | Description |
| 2153 | AIM 65/40 Macro Assembler and Linking Loader <br> User Manual(2) |
| Notes: <br> 1. Requires RM 65 Floppy Disk Controller (FDC) module <br> (RM65-5101NE) and AIM 65/40 BDOS 1.0 Upgrade Kit <br> (A65/40-7092). <br> 2. Included with A65/40-7012. |  |

## A65/40-7020 <br> AIM 65/40 BASIC INTERPRETER ROMS

## BASIC LANGUAGE

BASIC is a simple but powerful computer program language. Originally developed at Dartmouth University, BASIC has gained universal acceptance and is commonly used world-wide in schools, industry, and science.

The heart of BASIC is a set of easily learned English words which are used as commands. Complex and powerful statements can be constructed by adding operands and operators to the commands. Equations involving complex formulas and multiple variables can easily be solved. Internal floating point arithmetic handles a wide range of numeric values ( $2.93873588 \mathrm{E}-39$ to $1.70141183 \mathrm{E}+38$ ) and provides nine-digit accuracy to most calculations. In addition to addition, subtraction, multiplication and division, a full set of transcendental functions support trigonometric, exponential, square, square root, polynomial and logarithmic operations.

## PRODUCT OVERVIEW

The AIM 65/40 BASIC Interpreter, consisting of input formatter, lister, floating point functions, interpreter and input/output functions, is contained in two 4 K -byte ROMs that plug into sockets Z70 and Z71 on the AIM 65/40 Microcomputer Single Board Computer (SBC) Module. AIM 65/40 BASIC operates in one of two modes, development and run-time. In the development mode, BASIC statements are entered and executed as either direct or indirect commands. Direct commands are executed upon entry to provide immediate results, however, the statements are not stored for subsequent execution. Indirect commands are entered along with an associated line number and are executed upon RUN command entry. The AIM 65/40 Text Editor can be conveniently used to load indirect statements into the Text Buffer for entry into BASIC to simplify program editing. The AIM 65/40 microcomputer peripherals, i.e., keyboard, 40character single line display/video display controller module and graphics printer, are used in the development mode to enter statements, to list entered indirect statements and to display/ print execution results.

In the run-time mode, BASIC begins execution of the application program (i.e., previously entered indirect statements) without entering the BASIC command level. The AIM 65/40 peripherals are not required in their mode unless used in the application. The AIM 65/40 VO ROM must be resident (but not the Debug Monitor/Text Editor ROMs) for run-time support. A short userprovided driver program initializes BASIC upon power turn-on or RESET via the AIM 65/40 VO ROM auto-start linkage.

## LANGUAGE FEATURES

- BASIC is easy to learn
- Microsoft BASIC is universally accepted
- BASIC is widely used
- Supports simple and complex statements
- Floating point arithmetic functions
-Add, subtract, multiply, divide
-Trigonometric (sine, cosine, tangent, arctangent)
-Exponential, square, square root
-Natural logarithm
- String variables and arrays
- Integer variables
- Subroutine calls
- Conditional expressions
- User function


## INTERPRETER FEATURES

- AIM 65/40 Microcomputer or RM 65 Single Board Computer (SBC) module host
- ROM resident for immediate operation
- Operates in development and run-time modes
- Fast execution (reference Microsoft 6502 BASIC interpretation)
- Executes application program from RAM or PROM
- Develops programs for execution in either AIM 65 Microcomputer or in RM 65 SBC module based system with AIM 65/40 BASIC ROMs installed.

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| A65/40-7020 | AIM 65/40 BASIC ROMs |
| Order No. | Description |
| 299 | AIM 65/40 BASIC User's Manual* |
| 2100 | AIM 65/40 BASIC Reference Card* |
| NOTES: <br> "Included with A65/40-7020. |  |

## AIM 65/40 BASIC Interpreter ROMs

## MEMORY MAP

| Address (Hex) | Contents |
| :--- | :--- |
| \$C000-\$DFFF | AIM 65/40 BASIC Program |
| $\$ 700-\$ 7 D 6$ | AIM 65/40 BASIC Variables and Vectors |
| $\$ 0-\$ 6 D$ | AIM 65/40 BASIC Variables |

## PROGRAMMING

The application program can easily be programmed into a PROM for operation in an OEM or end-user environment using an RM 65 PROM Programmer module (RM65-2901E) connected to an AIM 65/40 Microcomputer.

The AIM 65/40 BASIC Interpreter ROMs can also be used in an RM 65 environment in either development or run-time mode. When installed in an RM 65 SBC module based system along with the RM 65 VO ROM, AIM 65/40 peripherals can be used to support development as well as run-time operation.

## AIM 65/40 BASIC STATEMENTS



## A65/40-7024 <br> AIM 65/40 BASIC COMPILER

## BASIC LANGUAGE

BASIC is a simple but powerful computer program language. Originally developed at Dartmouth University, BASIC has gained universal acceptance and is commonly used world-wide in schools, industry, and science.

The heart of BASIC is a set of easily learned English words which are used as commands. Complex and powerful statements can be constructed by adding operands and operators to the commands. Equations involving complex formulas and multiple variables can easily be solved. Internal floating point arithmetic handles a wide range of numeric values ( $2.93873588 \mathrm{E}-39$ to $1.70141183 \mathrm{E}+38$ ) and provides nine-digit accuracy to most calculations. In addition to addition, subtraction, multiplication and division, a full set of transcendental functions support trigonometric, exponential, square, square root, polynomial and logarithmic operations.

## PRODUCT OVERVIEW

The AIM 65/40 BASIC Compiler, consisting of the BASIC Compiler and BASIC run-time library, is contained on an AIM 65/40 diskette. The BASIC Compiler, in conjunction with the BASIC run-time library, compiles a program written in the BASIC language into a 6500 assembly language source file and an optimized run-time library file. The BASIC source code file is made up of indirect BASIC commands and statements. The two output files, assembly source file and optimized run-time file, are then assembled using the AIM 65/40 assembler to create a BASIC object code file for execution.

The AIM 65/40 Text Editor can be used to create and edit the application program source code. The AIM 65/40 peripherals, i.e., keyboard, 40 -character single line display/video display controller module and graphic printer, are used to enter and list BASIC statements and to display/print execution results.

The disk-based compiler operates on the AIM 65/40 Microcomputer in conjunction with the RM65 Floppy Disk Controller (FDC) module and the AIM 65/40 DOS 1.0 or BDOS 1.0 firmware. The AIM 65/40 Assembler (Part No. A65/40-7010) or the AIM 65/40 Macro Assembler (Part No. A65/40-7012) option is required to support the BASIC Compiler on the AIM 65/40 Microcomputer. The AIM 65/40 I/O ROM must be resident for BASIC I/O support during application program execution, i.e., to run the program after compilation and assembly.

## LANGUAGE FEATURES

- BASIC is easy to learn
- Microsoft BASIC is universally accepted
- BASIC is widely used
- Supports simple and complex statements
- Floating point arithmetic functions
- Add, subtract, multiply, divide
-Trigonometric (sine, cosine, tangent, arctangent)
- Exponential, square, square root
—Natural logarithm
- String variables and arrays
- Integer variables
- Subroutine calls
- Conditional expressions
- User function


## COMPILER FEATURES

- AIM 65/40 Microcomputer or RM 65 Single Board Computer (SBC) module host
- Generates standalone code
- Compiles to 6500 assembly language easing optimization
- Fast execution
- Executes application program from RAM or PROM
- Develops programs for execution in either AIM 65 Microcomputer or in RM 65 SBC module based system without AIM 65/40 BASIC ROMs installed.

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| A65/40-7024 | AIM 65/40 BASIC Compiler |
| Order No. | Description |
| 2160 | AIM 65/40 BASIC User's Manual* |
| 2100 | AIM 65/40 BASIC Reference Card* |
| Note: <br> *Included with A65/40-7024. |  |

## MEMORY MAP

| Address (Hex) | Contents |
| :--- | :---: |
| $\$ 1000-\$ 3 C 00$ | AIM 65/40 BASIC Compiler |
| $\$ 0-\$ 100$ | AIM 65/40 BASIC Variables |

## AIM 65/40 BASIC STATEMENTS

## PROGRAMMING

The application program can easily be programmed into a PROM for operation in an OEM or end-user environment using an RM 65 PROM Programmer module (RM65-2901E) connected to an AIM 65/40 Microcomputer.

When used in an RM 65 SBC module based system along with the RM 65 I/O ROM, AIM 65/40 peripherals can be used to support the BASIC Compiler operation.


## A65/40-7040 <br> AIM 65/40 MATH PACKAGE ROM

## FLOATING POINT ARITHMETIC

Floating point arithmetic is often desired to perform mathematical operations in calculation intensive applications such as scientific computation, industrial data acquisition and reduction, process control, and laboratory measurements. In the AIM 65/ 40 Math Package, a number is represented in floating point form as an unsigned exponent, a normalized mantissa and an arithmetic sign. The magnitude of the number is equal to two raised to the exponent power times the fractional mantissa, where the exponent may range from -127 to +127 . The mantissa is a 32bit number normalized such that the most significant bit (MSB) is always equal to " 1 ". Operating on floating point numbers alleviates programming difficulty and additional development time usually associated with fixed point scaling and minimizes uncertainties when performing calculations involving both very large and very small numbers. Numbers in magnitude from $2.93873588 \mathrm{E}-39$ to $1.70141183 \mathrm{E}+38$ can be handled in the AIM 65/40 Math Package. In addition, nine digit accuracy is provided in most calculations.

## PRODUCT OVERVIEW

The AIM 65/40 Math Package contains a full complement of floating point arithmetic, conversion, trigonometric, utility and other transcendental functions as user-callable subroutines in a 4 K -byte ROM. Programmed in 6502 machine language for fast execution, these functions support calculation intensive applications. These functions are host computer independent and may be installed in any 6502 CPU based microcomputer supporting the memory map requirements. The math package is located at $\$ 8000-\$ 8 F F F$ to allow direct installation in an AIM 65/40 Microcomputer, an RM 65 Single Board Computer (SBC) module or in an RM 65 PROM/ROM module.

In addition to the machine language interface, direct linkage to AIM 65/40 FORTH provides floating point processing in the FORTH language. When installed in an AIM 65/40 Microcomputer with AIM 65/40 FORTH also installed, the floating point words can be automatically linked to the FORTH vocabulary during FORTH initialization. Application programs written in FORTH can thus be both developed and executed on the AIM 65/40 Microcomputer. For OEM or end user installation in an RM 65 system with user-provided input/output functions, such programs can be developed on an AIM 65/40 Microcomputer then transferred to an RM 65 SBC based system with AIM $65 / 40$ FORTH installed for execution in the RM 65 environment.

## FEATURES

- Floating point arithmetic
-Addition and subtraction
-Multiplication and division
- Integer arithmetic
-Multiplication
-Division
- Comparison ( $<,=,>$ )
- Trigonometric
-Sine and cosine
-Tangent and arctangent
- Conversion
-Degrees to radians
—Radians to degrees
- Polynomials
-Consecutive power
-Odd power
- Logarithmic
-Natural log
-Common log
- Square root, power, exponential
- Absolute value, integer and floating point sign, greatest integer
- 6502 CPU machine instruction linkage
- Host computer independent
- AIM 65/40 FORTH compatible
- 4K-byte ROM based
- Nine digit accuracy
- Wide range ( $2.93873588 \mathrm{E}-39$ to $1.70141183 \mathrm{E}+38$ )


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| A65/40-7040 | AIM 65/40 Math Package ROM |
| A65/40-7050 | AIM 65/40 FORTH ROMs |
| Order No. | Description |
| 2113 | AIM 65/40 Math Package User's Manual( ${ }^{(1)}$ |
| 2103 | AIM 65/40 FORTH User's Manual( |

## MEMORY MAP

| Address(Hex) | Contents |
| :--- | :--- |
| $\$ 8000-\$ 8 F F F$ | AIM 65/40 Math Package Program |
| $\$$ AB- $\$ 4$ | AIM $65 / 40$ Math Package Variables |
| $\$ 110-\$ 132$ | AIM 65/40 Math Package Variables |

## MATH PACKAGE FUNCTIONS

| Assembly <br> Language Label | FORTH <br> Word | Function | Assembly <br> Language <br> Label | FORTH <br> Word | Function |
| :---: | :---: | :---: | :---: | :---: | :---: |
| INIT |  | Initialize Math Package | SIN | SIN | Sine |
| FADDT | F+ | Floating Point Add | COS | COS | Cosine |
| FADD |  | Floating Point Add (Memory) | TAN | TAN | Tangent |
| FSUBT | F- | Floating Point Subtract | ARCTAN | ARCTAN | Arc Tangent |
| FSUB |  | Floating Point Subtract (Memory) | DEGRE | DEGREES | Convert Radians to Degrees |
| FMULTT | $F^{*}$ | Floating Point Multiply | RADS | RADIANS | Convert Degrees to Radians |
| FMULT |  | Floating Point Multiply (Memory) | POLYX | POLYODD | Odd Exponent Polynomial |
| FDIVT | F/ | Floating Point Divide | POLY | POLY | Consecutive Exponent Polynomial |
| FDIV |  | Floating Point Divide (Memory) | MOVFM | $M>F$. | Move Number from Memory to FAC |
| IMULT |  | Integer Multiply | MOVMF | $F>M$ | Move Number from FAC to Memory |
| IDIVID |  | Integer Divide | MOVFA | 8 - \% | Move Number from ARG to FAC |
| FTOD |  | Convert Floating Point to Integer | MOVAF |  | Move Number from FAC to ARG |
| DTOF |  | Convert Integer to Floating Point | CONUPK | $M>A$ | Move Number from Memory to ARG |
| NEGFAC |  | Negate Floating Point Number |  | $S>A$ | Move Number from Stack to ARG |
| ABS | FABS | Absolute Value of Floating Point Number |  | $S>F$ | Move Number from Stack to FAC |
| INT | INT | Truncate Floating Point Number |  | $F>S$ | Move Number from FAC to Stack |
| SGN | SGN | Sign of FAC to FAC | FIN | FIN | Convert ASCII to Floating Point |
| SIGN | FSIGN | Sign of FAC to ARG | FOUT | FOUT | Convert Floating Point to ASCII |
| FCOMP | FCOMP | Compare Floating Point Number | MINLN | MIN-WIDTH | FOUT Minimum Field Width Variable |
| SQR | SQR | Square Root | DECLN | DEC-LENGTH | FOUT No. of Places to the Right of the Dec- |
| FPWRT | $\uparrow$ | Raise to a Power |  |  | imal Point Variable |
| EXP | EXP | Exponential |  |  |  |
| LOG10 | LOG | Common Log |  |  | $\cdots \cdots$ |
| LOG | LN | Natural Log |  |  |  |

## A65/40-7050 AIM 65/40 FORTH ROMS

## FORTH LANGUAGE

FORTH is a unique programming language well suited to a variety of applications. Because it was originally developed for real-time control applications, FORTH is ideal for machine and process control, energy managements, data acquisition, automatic testing, robotics and other applications where assembly language was previously the only possible language choice.

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. FORTH has a built in 6502 macro assembler, and lets you drop into assembly language at almost any point in your program, without perarate 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.

## FEATURES

- AIM 65/40 Microcomputer host and target
- RM 65 SBC module based system compatible
- ROM resident for immediate operation
- Application oriented
- Extensible language
- Over 200 pre-defined functions
- Interactive compilation
- Reverse polish notation
- Compact memory usage
- Fast execution
- Easy debugging
- Stack implementation
- 16-bit words
- Built-in structured macro assembler
- Shortens software development time


## PRODUCT OVERVIEW

The AIM $65 / 40$ FORTH system, consisting of primitives, interpreter, macro assembler and input/output functions, is contained in two 4K-byte ROMs. These ROMs plug into sockets Z70 and Z71 on the AIM 65/40 Microcomputer Single Board Computer (SBC) module. Linkage to the AIM 65/40 I/O ROM interfaces FORTH to the AIM 65/40 peripherals (keyboard, single-line display/video display controller and graphics printer) and to user-defined functions. Interface with the AIM 65/40 Debug Monitor and Text Editor ROMs supports machine level debugging and editing of application programs written in FORTH. Both interactive and batch modes of operation are supported. Interaction operation allows FORTH words to be compiled and/ or executed as they are entered for immediate debugging and operation. In the batch mode, FORTH words can be entered into the Text Buffer then input to FORTH to be compiled and/or executed. Batch mode allows an application program to be easily edited using Text Editor line- and screen-oriented commands.

The AIM 65/40 FORTH ROMs can also be installed in an RM 65 Single Board Computer (SBC) module based system for either development or runtime operation. This is especially attractive in OEM or end-user applications requiring a compact RM 65 modular computer assembly. The RM 65 I/O ROM, when also installed in this configuration, supports FORTH input/output operation with AIM 65/40 peripherals connected to RM 65 input/output modules. Vectored input/output functions support user-defined interface functions, as well, in an RM 65 installation.

## ORDERING INFORMATION

| Part No. | Description |
| :--- | :--- |
| A65/40-7050 | AIM 65/40 FORTH ROMs |
| A65/40-7040 | AIM 65/40 Math Package ROM |
| Order No. | Description |
| 2103 | AIM 65/40 FORTH User's Manual(1) |
| 2104 | AIM 65/40 FORTH Reference Card(1) |
| 2113 | AIM 65/40 Math Package User's Manual(2) |
| NOTES: |  |
| 1. Included with A65/40-7050. |  |
| 2. Included with A65/40-7040. |  |

## 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 features 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 (RPM), the notation that is used in Hewlett-Packard scientific calculators. Using a data stack is an extremely efficient way of passing variables 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/bottomup" 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 submodules. 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.

## FLOATING POINT FUNCTIONS

AIM 65/40 FORTH contains both a single- (16-bit) and double-(32-bit) precision integer arithmetic capability. In AIM 65/40 or RM 65 applications where floating point arithmetic is desired, the AIM 65/40 Math Package may be used in conjunction with the FORTH ROMs. These floating point functions may be called using FORTH words included in the math package ROM. When this ROM is installed in socket Z63 on the AIM 65/40 SBC Module, the floating point math words can be automatically linked to the FORTH dictionary during FORTH initialization. The AIM 65/40 Math Package can also be installed in either an RM 65 SBC module based system for operation in the RM 65 environment.

## MEMORY MAP

| Address (Hex) | Contents |
| :--- | :--- |
| $\$ C 000-\$ D F F F$ | FORTH Program |
| $\$ 8000-\$ 8 F F F$ | Math Package Program |
| $\$ 780-\$ 7 F F$ | Terminal Input Buffer |
| $\$ 760-\$ 77 F$ | User Variables |
| $\$ 700-\$ 75 \mathrm{~F}$ | FORTH User Variables |
| $\$ A B-\$ C 4$ | Math Package Variables |
| $\$ 10-\$ A 8$ | FORTH Variables |

## FORTH WORDS

## STACK MANIPULATION

DUP
2DUP
DROP
2DROP
SWAP
OVER
ROT

- DUP
$>R$
R $>$
R
PICK
SP@
RP@
BOUNDS
.S

DEFINING WORDS
$\left.\begin{array}{ll}\text { :<name> } & \begin{array}{l}\text { Begin colon definition of <name> } \\ \text { End colon definition. }\end{array} \\ \text { VARIABLE <namd> } \\ \text { Create a variable <name> with initial } \\ \text { value n; returns address when } \\ \text { executed. }\end{array}\right\}$

## MEMORY

CMOVE
FILL
ERASE
BLANKS
TOGGLE
Duplicate top of stack. Duplicate top two stack items.
Delete top of stack.
Delete top two stack items.
Exchange top two stack items.
Copy second item to top.
Rotate third item on top.
Duplicate only if non-zero
Move top item to return stack.
Retrieve item from return stack.
Copy top of return stack onto stack.
Copy the nth item to top.
Return address of stack position
Return address of return stack pointer.
Convert "address count" to "end-
address start-address."
Print contents of stack. End colon definition.
reate a variable <name> with initial executed.
eate a constant <name> with value n ; returns value when executed. primitive operation <name>. sed to create a new defining word, with execution-time "code routine" for this data type in assembly. with execution time routine for this data type in higher-level FORTH.
Create a user variable.

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 $n 3$ bytes starting at address $n 1$ to area starting at address n2.
Put byte n 3 into n 2 bytes starting at address $n 1$.
Fill n2 bytes in memory with zeroes, beginning at address $n 1$.
Fill n2 bytes in memory with blanks, beginning at address $n 1$.
Mask memory with bit pattern.

## NUMERIC REPRESENTATION

| DECIMAL | Set decimal base. |
| :--- | :--- |
| HEX | Set hexadecimal base. |
| BASE | Set number base. |
| DIGIT | Convert ASCll to binary. |
| 0 | The number zero. |
| 1 | The number one. |
| 2 | The number two. |
| 3 | The number three. |
| 4 | The number four. |

## FORTH WORDS (CONT'D)

ARITHMETIC AND LOGICAL

| + | Add. |
| :---: | :---: |
| D+ | Add double-precision numbers. |
| - | Subtract ( n 1 - n 2 ) |
| - | Multiply. |
| 1 | Divide ( $\mathrm{n} 1 / \mathrm{n} 2$ ). |
| MOD | Modulo (i.e., remainder from division). |
| /MOD | Divide, giving remainder and quotient. |
| ./MOD | Multiply, then divide ( $n 1 \cdot n 2 / n 3$ ), with double intermediate. |
| $\cdot 1$ | Like -/MOD, but give quotient only. |
| U. | Unsigned multiply leaving double product. |
| U/ | Unsigned divide. |
| M* | Signed multiplication leaving double product. |
| M/ | Signed remainder and quotient from double dividend. |
| M/MOD | Unsigned divide leaving double quotient and remainder from double dividend and single divisor. |
| MAX | Maximum. |
| MIN | Minimum. |
| + - | Set sign. |
| D+- | Set sign of double-precision number. |
| ABS | Absolute value. |
| DABS | Absolute value of double-precision number. |
| NEGATE | Change sign. |
| DNEGATE | Change sign of double-precision number. |
| S->D | Sign extend to double-precision number. |
| $1+$ | Increment value on top of stack by 1. |
| $2+$ | Increment value on top of stack by 2. |
| 1 | Decrement value on top of stack by 1. |
| $2-$ | Decrement value on top of stack by 2. |
| AND | Logical AND (bitwise). |
| OR | Logical OR (bitwise) |
| XOR | Logical exclusive OR (bitwise). |

## COMPARISON OPERATORS

$<$
$>$
$=$
$0<$
$0=$
$\mathrm{U}<$
NOT

True if n 1 less than n 2 .
True if n 1 greater than n 2 .
True if top two numbers are equal.
True if top number negative.
True if top number zero.
True if u1 less than u2.
Same as $0=$.

## MISCELLANEOUS AND SYSTEM

(<comment>) Begin comment (terminate by right
CFA
NFA
PFA
LFA
LIMIT
QUIT
parentheses on same line).
Alter PFA to CFA.
Alter PFA to NFA.
Alter NFA to PFA.
Alter PFA to LFA.
Top of memory.
Clear return stack and return to terminal.

## CONTROL STRUCTURES

| DO . . . LOOP | Set up loop, given index range. |
| :---: | :---: |
| DO ... + + ${ }^{\text {LOOP }}$ | Like DO . . . LOOP, but adds stack value to index. |
| 1 | Place current index value on stack. |
| LEAVE | Terminate loop at next LOOP or +LOOP. |
| BEGIN . . . UNTIL | Loop back to BEGIN until true at UNTIL. |
| BEGIN . . . WHILE ... REPEAT | Loop while true at WHILE, REPEAT loops unconditionally to BEGIN. |
| BEGIN . . AGAIN | Unconditional loop. |
| IF... THEN | If top of stack true, execute following clause THEN continue; otherwise continue at THEN. |
| IF ... ELSE ... THEN | If top of stack true, execute ELSE clause THEN continue; otherwise execute following clause, THEN continue. |
| END | Alias for UNTIL. |
| ENDIF | Alias for THEN. |

## COMPILER-TEXT INTERPRETER

| [COMPILE] | Force compilation of IMMEDIATE word. <br> COMPILE |
| :--- | :--- |
| Compile following <name> into <br> dictionary. |  |
| CITERAL |  |
| CLITERAL | Compile a number into a literal. <br> Compile a double-precision number into <br> a literal. |
| EXECUTE | Execute the definition on top of stack. <br> Suspend compilation, enter execution. |
| [ | Resume compilation. |

DICTIONARY CONTROL
CREATE
FORGET
HERE
ALLOT
TASK

- FIND

DP

C,

PAD
IMMEDIATE
INTERPRET
LATEST
LIT
CLIT
LITERAL
SMUDGE
STATE

## FORTH WORDS (CONT'D)

| U?IN | User variable for ?IN. |
| :---: | :---: |
| U?OUT | User variable for ?OUT. |
| U?TERMINAL | User variable for ?TERMINAL. |
| U-CR | User variable for -CR |
| UABORT | User variable for ABORT. |
| UB/BUF | User variable for $B / B U F$. |
| UB/SCR | User variable for B/SCR. |
| UC/L | User variable for C/L. |
| UCLOSE | User variable for CLOSE. |
| UCR | User variable for CR. |
| UEMIT | User variable for EMIT. |
| UFIRST | User variable for FIRST. |
| UKEY | User variable for KEY. |
| ULIMIT | User variable for LIMIT. |
| MONITOR \& CASSETTE I/O |  |
| COLD | AIM 65/40 FORTH cold start. |
| MON | Exit to AIM 65/40 Monitor. |
| CLOSE | Close tape file. |
| ? N | Set to active input device (AID). |
| ?OUT | Set to active output device (AOD). |
| GET | Input a character from the AID. |
| PUT | Output a character to the AOD. |
| READ | Input n2 characters from AID to address $n 1$. |
| WRITE | Output n2 characters to AOD at address n 1 . |
| SOURCE | Compile from the AID. |
| FINIS | Terminate complete from SOURCE. |
| INPUT-OUTPUT |  |
| - CR | Output CR to printer only. |
| CR | Carriage return. |
| SPACE | Type one space. |
| SPACES | Type $n$ spaces. |
| CLRLINE | Output a CTRL B. |
|  | Print text string (terminated by "). |
| DUMP | Dump n2 words starting at address. |
| TYPE | Type string of n1 characters starting at address n2. |
| ?TERMINAL | True if terminal break request present. |
| KEY | Read key, put ASCll value on stack. |
| EMIT | Output ASCII value from stack. |
| EXPECT | Read $n 1$ characters from input to address n2. |
| WORD | Read one word from input stream, until delimiter. |
| IN | User variable contained within TIB. |
| BAUD | Set BAUD rate. (See Note 1) |
| BL | Output a SPACE character. |
| C/L | Nümber of characters/line. |
| TIB | Pointer to terminal input buffer start address. |
| QUERY | Input text from terminal. |
| ID. | Print <name> from name \# field address (nfa). |
| HANG | Wait for keystroke. |
| OUTPUT FORMATTING |  |
| NUMBER | Convert string at address to doubleprecision number. |
| <\# | Start output string. |

OUTPUT FORMATTING (CONT'D)
\#
\#S
SIGN
\# $>$
HOLD
HDL

- TRAILING
.LINE
COUNT


## .R

D.
D.R

DPL

VOCABULARIES
$\left.\begin{array}{ll}\text { CONTEXT } & \begin{array}{c}\text { Returns address of pointer to } \\ \text { CONTEXT vocabulary. } \\ \text { Returns address of pointer to }\end{array} \\ \text { CURRENT } & \text { CURRENT vocabulary. } \\ \text { Main FORTH vocabulary. }\end{array}\right\}$

## FORTH WORDS (CONT'D)

PRIMITIVES
OBRANCH
BRANCH
ENCLOSE
R0
SO
RP!
SP!
NEXT

Run-time conditional branch. Run-time unconditional branch. Text scanning primitive used by WORD. Location of Return Stack.
Location of Parameter Stack.
Initialize Return Stack.
Initialize Parameter Stack.
The FORTH virtual machine.

SECURITY
!CSP
?COMP
?CSP
?ERROR
? EXEC
?PAIRS
?STACK
ABORT
ERROR
MESSAGE
WARNING
FENCE
WIDTH

Store stack position in check stack pointer.
Error if not compiling.
Check stack position.
Output error message.
Not executing error.
Conditional not paired error.
Stack out of bounds error.
Error; operation terminates.
Execute error notification and restart system.
Displays message.
Pointer to message routine.
Prevents forgetting below this point.
Controls significant characters of <name>.

## MATH PACKAGE FORTH WORDS (A65/40-7040)*

## FLOATING POINT ARITHMETIC

F+ Adds two floating point numbers.
F- Subtracts one floating point number from another floating point number. $\mathrm{F}^{*} \quad$ Multiplies two floating point numbers. F/ Divides one floating point number by another floating point number.

UTILITY, SIGN AND COMPARISONS
FABS
Takes the absolute value of a floating point number.
INT Truncates a floating point number to an integer.
SGN
Converts the sign of a floating point number to a floating point number.
FSIGN Gets a value corresponding to the sign of a floating point number.
Compares the value of a compacted number in memory to a floating point number.

## POLYNOMIAL

POLY
POLYODD

> Evaluates a polynomial with consecutive exponents.
> Evaluates a polynomial with odd exponents.

EXPONENTIAL AND LOGARITHMIC
SQR Takes the square root of a floating point number.
Raises one floating point number to the power of another floating point number.

LN
Raises the transcendental number $\theta$ to the power of a floating point number.
Computes the logarithm to the base 10 (i.e., common log) of a floating point number.
Computes the logarithm to the base e (i.e., natural log) of a floating point number.

## USER VARIABLE

MIN-WIDTH
Specifies the minimum field width to be output.
DEC-LENGTH
Specifies the number of places to the right of the decimal point to be output.

## ASCII/FLOATING POINT CONVERSIONS

FIN
FOUT

FORMAT CONVERSION AND DATA MOVING

| M $>F$ | Unpacks the compacted number in <br> memory to floating point. <br> Packs the floating point number to <br> compacted format and stores the <br> result in memory. |
| :--- | :--- |
| F>M | Unpacks the floating point number in <br> memory. <br> Converts an integer to floating point <br> format. <br> Converts an integer to floating point <br> format. <br> Converts a number from floating point <br> to an integer. |
| S>A |  |

## TRIGONOMETRIC AND UNITS CONVERSION

SIN
cos
TAN
ARCTAN
degrees
RADIANS

Converts a number in memory from ASCII to floating point format.
Converts a number from floating point to ASCII.
memory to floating point.
Packs the floating point number to compacted format and stores the

Unpacks the floating point number in memory.
Converts an integer to floating point
Converts an integer to floating point
Converts a number from floating point to an integer.

Calculates the sine of a floating point number (in radians).
Calculates the cosine of a floating point number (in radians).
Calculates the tangent of a floating point number (in radians).
Calculates the arc tangent of a floating point number.
Converts a floating point number from radians to degrees.
Converts a floating point number from degrees to radians.

[^19]
# A65/40-7052 <br> AIM 65/40 FORTH TARGET COMPILER 

## FORTH LANGUAGE

FORTH is a unique programming language well suited to a variety of applications. 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 input/output intensive applications where assembly language was previously considered to be the only possible language choice.

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. FORTH allows programmers 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.

## FORTH TARGET COMPILER

The FORTH Target Compiler generates object code from application programs written in FORTH. The object code is a compiled composite of the user's application vocabulary and those portions of the Target Compiler nucleus necessary to support the application vocabulary. The disk-based FORTH Target Compiler operates on the AIM 65/40 Microcomputer in conjunction with the AIM 65/40 FORTH Interpreter ROMs, the RM 65 Floppy Disk Controller (FDC) module and the AIM 65/40 BDOS 1.0 Upgrade Kit.

The compiled object code, located at a user-specified origin with optional auto-start vectors, will execute in any 6502 CPU-based microcomputer system supporting the runtime nucleus memory map requirements. Application programs can also be developed to run on AIM 65/40 or RM 65 SBC module-based systems with supporting RM 65 memory and input/output modules, e.g., Analog Input/Output, IEEE-488 Interface, and Multi-function Peripheral Interface. Linkage to RM 65 Floppy Disk Controller, CRT Controller, and IEEE-488 module, as well as the AIM 65/ 40 VO and Math Package, firmware can also be included for expanded application systems.

## FEATURES

- Fully compatible with FORTH programs developed with AIM 65 or AIM 65/40 FORTH Interpreter ROMS
- Disk-based compiler operation with vocabulary overlays for -Text Editing
—Disk Interfacing
-Serial Input/Output
-Compiling
-Special Utilities
- Easy compiler operation
-Load screen direction
-Compile tracing (mapping)
-Compiles to RAM and/or disk
- Includes 6502 Macro Assembler with
-Forward references
-Symbolic labels
-Relative branches
- Efficient object code generation
-ROMable object code
-Standalone operation
-Minimum runtime nucleus
-Optimized FORTH compiled vocabulary
-User-specified origin
- Flexible target computer installation
-System independent (runs on any 6502 CPU-based system with minimal runtime memory map requirements) or
-AIM 65/40 or RM 65 //O ROM autostart capability


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| AIM 65/40-7052 | AIM 65/40 FORTH Target Compiler |
| AIM 65/40-7050 | AIM 65/40 FORTH Interpreter ROMs ${ }^{(1)}$ |
| AIM 65/40-7092 | AIM 65/40 BDOS 1.0 Upgrade Kit $^{(1,2)}$ |
| AIM 65/40-7040 | AIM 65/40 Math Package ROM ${ }^{(6)}$ |
| Order No. | Description |
| 2105 | AIM 65 and AIM 65/40 FORTH Target |
|  | Compiler User's Manual(3) |
| 2103 | AIM 65/40 FORTH User's Manual(4) |
| 2113 | AIM 65/40 Math Package User's Manual(5) |
| Notes: |  |
| (1) Required for FORTH Target Compiler operation. |  |
| (2) Requires RM65-5101NE FDC module. |  |
| (3) Included with A65/40-7052. |  |
| (4) Included with A65/40-7050. |  |
| (5) Included with A65/40-7040. |  |
| (6) Optional |  |

## 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 the dictionary words to define each new word. Once the new word has been defined it is added to the system dictionary and 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.

FORTH is a stack-oriented language, and is programmed in Reverse Polish Notation (RPN), the notation that is used in Hewlett-Packard scientific calculators. A data stack is an extremely efficient way of passing variables back and forth between operations and eliminates the need to tie up memory locations with variable tables.

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, FORTH coding begins with 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 debugged without having the complete program in the system. The interactive nature of FORTH supports this time efficient development technique.

In most time-critical applications, at least part of the program must be written in assembly languages. FORTH has a built-in 6502 macro assembler, and allows assembly language coding at almost any point in your program, without separate assembly and load steps or special 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.

The application program is developed, debugged and integrated with the user interface using the ROM-based FORTH Interpreter. After program validation, the application is compiled into stand-alone object code with only required portions of the Target

Nucleus. The compiled byte count will generally be less than the separate application/interpreter byte count.

## FORTH TARGET COMPILER OPERATION

The disk-based, two-pass, FORTH Target Compiler compiles object code in one of two modes: BIG.COMPILE or QUICK. COMPILE. The QUICK.COMPILE mode compiles the entire object code directly to RAM then saves the compiled code on disk. The BIG.COMPILE mode compiles to 1 K -byte buffer areas in RAM. When the buffer is full, the buffer contents are transferred to disk then compilation continues. The BIG.COMPILE mode optimizes object code RAM requirements although it compiles slower than the QUICK.COMPILE mode.

Operation of the compiler is directed by one or more LOAD SCREENS. This technique provides the user with complete control of compiler variables, origin statements, cold start vectors and utility routines. The LOAD-SCREEN(s) then specify which user screens to compile and in what order.

## FLOATING POINT OPERATION

The FORTH Target Compiler provides both single-precision (16-bit) and double-precision (32-bit) single integer arithmetic functions. If floating point arithmetic is desired, code words can easily be defined within the application program to link to external floating point subroutines. The AIM 65/40 Math Package ROM, located at address $\$ 8000-\$ 8 F F F$ can be installed in the application system. Alternatively, user-defined floating point functions may be linked to or even provided within the code definitions.

## SYSTEM REQUIREMENTS

The AIM 65/40 FORTH Target Compiler operates in an AIM 65/40 Microcomputer with 32K bytes RAM in conjunction with an RM 65 FDC module with an AIM $65 / 40$ DOS 1.0 or BDOS 1.0 ROM installed on the FDC module. The following table lists two configurations of AIM 65/40 and RM 65 hardware and firmware which may be used. Other configurations can be easily composed depending on the user's development and application requirements.

| Required <br> Peripherals/ <br> Firmware |  | Host Computer |  |
| :---: | :---: | :---: | :---: |
|  |  | AIM 65/40-2000 (AIM 65/40 SBC Module with 32K RAM, Monitor ROMS, Extended Keyboard, and VDC Module) | A65/40-8315 (AIM 65/40 Microcomputer System -Series 8000) |
| RM65-7141E | RM 65 Cable Adapter \& Buffer Module for AIM 65/40 | X |  |
| RM65-7004E | RM 65 4-Slot Card Cage | X |  |
| RM65-5101NE | RM 65 Floppy Disk Controller (FDC) Module (Without ROM) | X | X |
| A65/40-7090 | AIM 65/40 DOS 1.0 ROM, or | X | X |
| A65/40-7092 | AIM 65/40 BDOS 1.0 Upgrade Kit | X | X |
| A65-40-7040 | AIM 65/40 Math Package ROM | optional | optional |
| A65/40-7050 | AIM 65/40 FORTH ROMs | X | X |
|  | Floppy Disk Drives (2) | X | x |
|  | CRT Monitor | X | X |

## FORTH WORDS

## GENERAL PURPOSE VOCABULARY

The following FORTH words are provided in addition to those provided in the A65/40-7050 FORTH Interpreter ROMs (refer to Data Sheet No. D122).

| ABORT" | Prints TEXT if a run-time error occurs. | 2OVER | Double-precision OVER. |
| :---: | :---: | :---: | :---: |
| ASCII | During compile time, places a CLIT and the literal value of CHAR in the dictionary. In immediate mode, returns the ASCII value on the stack. | 2SWAP | Double-precision SWAP. <br> Execution only. Creates a constant NAME with value $n$. |
| COMBINE | Combines low byte of $I$ and high byte of $h$ to form n . | -TEXT | Compares strings at ADDR1 and ADDR2 for $n$ bytes. Returns $f=1$ if same. |
| COMPILING | Activates the Compiler Vocabulary Overlay. | ?DEF | IF NAME is defined, returns $f=1$. |
| DISKING | Activates the Disk Vocabulary Overlay. | ?RANGE | Returns $\mathrm{f}=1$ if $\mathrm{n} 2<\mathrm{n} 1<\mathrm{n} 3$ for signed numbers. |
| EDITOR | Activates the Editor Overlay. | ?URANGE | Returns $\mathrm{f}=1$ if $\mathrm{u} 2<\mathrm{u} 1<\mathrm{u} 3$ for unsigned |
| EXTERNAL | Execution only. NFA of next word to be defined. |  | numbers. |
| FALSE | Returns a false flag. |  |  |
| H. | Prints n as an unsigned hexadecimal value. |  |  |
| HI | Returns the high byte of $n$. |  |  |
| IFEND | Marks a place. | DISK VO | ULARY OVERLAY |
| iftrue | Compiles the following input if $f=1$, otherwise skips. | BACKUP | Copies all of drive 0 to drive 1. |
| INTERNAL | Returns the NFA of the latest word defined. | BLOCKS | Copies block b1 through b1 $+n$ to block b2 through b2+n. |
| LO | Returns the low byte of n . | COPY | Copies block b1 to block b2. |
| LOADER | Creates word NAME that loads screen no. n . | DOWN | Beginning at block $b$ and continuing for $n$ blocks, copies from drive 1 to drive 0 . |
| MODULE | Execution only. Places NFA1 into LFA of NFA2. | MASSACRE SCREENS | Clears n blocks beginning at block b , DRO. <br> Copies screens S1 through S1+n to screens S2 through S2+n. |
| OFF | Stores a 0 in ADDR. | SLATE | WRITES blanks (\$20) to block b relative to |
| ON | Stores a 1 in ADDR. |  | DRIVE 0. |
| ROLL | Rotates the nth number to the top of the stack. | SWEEP | READS blocks $b$ through $b+n$ searching for disk errors. |
| ROOM | $n=$ RAM space left. | UP | Beginning at block b, copies $n$ blocks from |
| SET | Places value $n$ in variable or constant NAME. |  |  |
| SPLIT | Returns low and high byte of $n$. | VERIFY | Compares blocks beginning at b1 to those beginning at b 2 for n blocks and displays |
| THRU | Performs sequential LOAD's beginning at screen no. n and continuing through screen no. n. | VOLUME | errors. <br> Returns the block number of the block 0 of drive 2 relative to drive 0. |
| TRUE | Returns a true flag. | ?WRONG | If $\mathrm{b} 1=\mathrm{b} 2$, then sets $\mathrm{f}=1$, else sets $\mathrm{f}=0$. |
| U. | Outputs n as a double-precision number. |  |  |
| UNRAVEL | Back traces the return stack. |  |  |
| Y/N? | Asks the question YES? or NO?, depending on $f_{1}=1$ or 0 . Returns $f_{2}$ as true or false depending on input match to $f_{1}$. |  |  |
| 2ROT | Rotates double-precision numbers $d_{1}$, $d_{2}, d_{3}$. |  |  |
| 2* | Returns $\mathrm{d}_{3}=\mathrm{d}_{1}{ }^{*} \mathrm{~d}_{2}$. |  |  |

## FORTH WORDS (Continued)

EDITOR VOCABULARY OVERLAY

| BUFFERS |  | STRING ORIENTED COMMANDS: |  |
| :---: | :---: | :---: | :---: |
| INSERT-BUF | An 80-byte buffer beginning at PAD +80 . | D | Finds the text, deletes it and shows the line. |
| FIND-BUF | An 80 -byte bufier beginning at PAD +160. |  |  |
|  |  | F | Finds the text, positions the cursor at the end of the text string and shows the line. |
| K | Swaps the contents of the INSERT-BUF and FIND-BUF. | 1 | Inserts the contents of INSERT-BUF into line at cursor position. |
| LINE | On current screen, returns the RAM address of the beginning of the line\#. | MATCH | Searches the memory space beginning at ADDR2 for CNT2 for a match of the data |
| M | Replaces INSERT-BUF and line\# in block\# with current referenced line. |  | beginning at ADDR1 for CNT1. If no match is found, sets $\mathfrak{f}=1$ and ADDR3=ADDR1 + CNT1. If a match is found, sets $f=0$ and |
| NEW | Beginning at line\#, clears each line and allows a NEW line to be typed in. Input is | (F) | ADDR3=address of the next byte after the matching string. |
|  | terminated by a null line entry (CR CR). Clears remaining lines on the current screen. |  | Locates the text in the buffer (a subpart of the F command). |
| P | Copies text into the INSERT-BUF and the current line until the delimiter (CR) is encountered. | \#LAG | Returns the address of the character following the cursor and then counts to the end of the line. |
| TILL | Beginning at the current cursor address, deletes text unTILL the end of the matching text string is encountered. The text is held in FIND-BUF. | \#LEAD | Returns the address of the character preceding the cursor and the count to the beginning of the line. |
|  |  | SCREEN COMMANDS |  |
| T | Moves cursor to beginning of line\# in current screen. Shows the line. | B | Moves to last block. |
|  |  | L | Lists current screen. |
| U | Copies text into the INSERT-BUF and the line on the current screen under the cursor. | $N$ | Moves to next block. |
| X | Then deletes the line and scrolls the screen up. The last line becomes a blank. | TOP | Moves cursor to the top line of the text. |
|  |  | WIPE | Clears the entire screen. |
| >LINE\# | Returns the current cursor line\#. | MISCELLANEOUS COMMANDS |  |
| (DELETE) | Referring to the current cursor position, deletes $n$ preceding characters and calls UPDATE. | BUF-MOVE | Move non-null contents of PAD to ADDR. |
|  |  | E | Erases the string in front of the cursor for a length equal to the string in FIND-BUFF. |
| (HOLD) | Copies the referenced line number into INSERT-BUF and UPDATE. | R | Replaces string identified by FIND-BUFF with TEXT. |
| (KILL) | Blanks line\# and UPDATE. | S | Beginning at current screen and continuing through screen \#n, searches for a string match to TEXT and displays match occurrences. |
| (PUT) | Replaces the current line with contents of INSERT-BUF. |  |  |
| ? | Prints the current line with the cursor at current cursor position and the line number at the end of the line. | CURSOR COMMANDS |  |
|  |  | R\# | Returns the cursor position ( n ). |
| 1LINE | Searches the current line after cursor position for a match to contents of FINDBUF. Repositions cursor to it if a match is found and sets $f=1$. If no match is found, sets $f=0$ and positions the cursor to the next line. | \#LOCATE | Returns byte position of cursor and line number. |
|  |  | >> | Adds n to cursor position and displays the line. |

## FORTH WORDS (Continued)



# A65/40-7090 AIM 65/40 DISK OPERATING SYSTEM VERSION 1.0 (DOS 1.0) ROM 

## DISK OPERATING SYSTEM

A disk operating system (DOS) provides a standard interface between the user and one or more floppy disk drives, floppy disk control (FDC) hardware and executive level software. The DOS, implemented in software, allows program and data files to be opened, closed, read and written under operator or program control. In an interactive environment, commands are usually initiated by the operator from the keyboard in response to user friendly prompts displayed by the system.

## PRODUCT OVERVIEW

The AIM 65/40 Disk Operating System Version 1.0 (DOS 1.0) provides disk and file management functions for the AIM 65/40 Microcomputer in conjunction with an RM 65 Floppy Disk Controller (FDC) module. With this configuration, mass storage files can be easily manipulated when connected to one to four $51 / 4^{\prime \prime}$ or $8^{\prime \prime}$ floppy disk drives. DOS 1.0 functions, contained on a 4 K -byte ROM that plugs into the FDC module, are available immediately upon computer power turn-on without waiting for separate loading of a disk-based DOS into RAM.

DOS 1.0 functions are operator commandable through interactive AIM 65/40 Debug Monitor/Text Editor operation as well as language (assembler, compiler and/or interpreter) operation. Text and program source code may be written to, and read from, disk with the Editor List and Read commands, respectively. Binary data and program object code may be written to, and loaded from, disk using the Debug Monitor Dump and Load commands, respectively. Files containing source and object code for application programs written in AIM 65/40 Assembler, BASIC, and FORTH languages are therefore supported. In addition, utility functions format a disk, list the contents of the disk directory, delete a file, recover a file and backup a disk upon command. The DOS functions may also be called under program control by the application program into order to read and write data files.

Disk read or write errors, both at the DOS and FDC hardware level, are reported upon detection. User-alterable variables allow changing of default values to application unique values.

Disks formatted by AIM 65/40 DOS 1.0 are compatible with AIM 65 DOS 1.0 and AIM 65/40 BDOS 1.0, Files written by any of these DOS programs may therefore be read by either microcomputer.

## FEATURES

- AIM 65/40 Microcomputer compatible
- ROM resident for immediate operation
- Installs on-board RM 65 Floppy Disk Controller (FDC) module
- Provides mass storage of programs and data
- Compatible with AIM 65 high level language and Assembler ROMs
- Disk oriented commands (format, list, backup)
- File oriented commands (list, delete, recover)
- Input/Output commands
-Read and write text and object code
-Automatic file open and close
- User-alterable variables
-Utility function and error handling vectors (before and after DOS functions)
-Error handling vectors (before and after DOS functions)
-Input/output vectors
- Extensive error detection and reporting


## MEMORY MAP

| Address (Hex) | Contents |
| :--- | :--- |
| $\$ 8 F 00-\$ 8 F F F$ | RM 65 FDC Module I/O |
| $\$ 8000-\$ 8 E F F$ | DOS 1.0 Program |
| $\$ 3 E 00-\$ 3 F F F$ | DOS 1.0 VO Buffer (default location) |
| $\$ \$ 00-\$ 563$ | DOS 1.0 Variables |
| $\$ 4 A 0-\$ 4 F A$ | DOS 1.0 Variables |
| $\$ D 7-\$ D E$ | DOS 1.0 Variables |

ORDERING INFORMATION

| Part No. | Description |
| :---: | :---: |
| $\begin{aligned} & \text { A65/40-7090 } \\ & \text { RM65-5101NE } \end{aligned}$ | AIM 65/40 DOS 1.0 ROM RM 65 FDC Module (without ROM containing primitive subroutines ${ }^{(2)}$ ) |
| Order No. | Description |
| 802 | RM 65 FDC Module User's Manual(1) |
| NOTES: <br> 1. Describes user's instructions for AIM 65/40 DOS 1.0. Included with A65/40-7090 and RM65-5101NE. <br> 2. The DOS 1.0 ROM includes primitive subroutines in addition to DOS functions. |  |

## A65/40-7092 AIM 65/40 BOOTSTRAP DISK OPERATING SYSTEM VERSION 1.0 UPGRADE KIT

## DISK OPERATING SYSTEM

A disk operating system (DOS) provides a standard interface between the user and one or more floppy disk drives, floppy disk control (FDC) hardware and executive level software. The DOS, implemented in software, allows program and data files to be opened, closed, read and written under operator or program control. In an interactive environment, commands are usually initiated by the operator from the keyboard in response to user friendly prompts displayed by the system.

## PRODUCT OVERVIEW

The AIM 65/40 Bootstrap Disk Operating System Version 1.0 (BDOS 1.0) provides disk and file management functions for the AIM 65/40 Microcomputer in conjunction with an RM 65 Floppy Disk Controller (FDC) module. With this configuration, mass storage files can be easily manipulated when connected to one to four $514^{\prime \prime}$ or $8^{\prime \prime}$ floppy disk drives. BDOS 1.0 functions, contained on a 4 K -byte ROM that plugs into the FDC module, are available immediately upon computer power turn-on without waiting for separate loading of a disk-based DOS into RAM.

The AIM $65 / 40$ BDOS 1.0 provides a bootstrap and autostart capability in addition to the same functions as AIM 65/40 DOS 1.0 (A65/40-7090). It is also located higher in memory than AIM $65 / 40$ DOS 1.0 to allocate RAM at \$8XXX to disk-resident system or application software. If neither AIM 65/40 Debug Monitor nor BASIC Interpreter ROMs are installed, a bootstrap function can be read from the disk and executed to load and autostart an application program. The BASIC or Debug Monitor command level will be entered if the AIM 65/40 BASIC or Debug Monitor ROMs are installed (BASIC overrides the Debug Monitor) unless overridden by an application autostart via the AIM 65/40 //O ROM. AIM 65 BDOS 1.0 does not contain DMA routines, however, indirect vectors are provided for user addition.

Disks formatted by AIM 65/40 BDOS 1.0 are compatible with AIM 65 DOS 1.0 and AIM 65/40 DOS 1.0. Files written by any of these DOS programs may therefore be read by either microcomputer.

The upgrade kit includes:
For installation on RM 65 FDC Module
AIM 65/40 BDOS 1.0 ROM
FDC Module addressing PLA (495R23-003)
For installation on the AIM65/40 SBC Module
AIM 65/40 I/O ROM V1.1 (R32T3-14)
AIM 65/40 Monitor/Editor ROMs V1.1
(R32U5-13 and R32U6-13)

## FEATURES

- AIM 65/40 Microcomputer compatible
- ROM resident for immediate operation
- Installs on-board RM 65 Floppy Disk Controller (FDC) module
- Provides mass storage of programs and data
- Compatible with AIM 65 high level language and Assembler ROMs
- Disk oriented commands (format, list, backup)
- File oriented commands (list, delete, recover)
- Input/Output commands
-Read and write text and object code
-Automatic file open and close
- User-alterable variables
-Utility function and error handling vectors (before and after DOS functions)
- Input/output vectors
- I/O buffer vectors
- Extensive error detection and reporting


## MEMORY MAP

| Address (Hex) | Contents |
| :--- | :--- |
| \$E000-\$EFFF | DOS 1.0 Program |
| TOP OF RAM | DOS 1.0 //O Buffer |
| \$500-\$563 | DOS 1.0 Variables |
| \$4A0-\$4FA | DOS 1.0 Variables |
| \$D7-\$DE | DOS 1.0 Variables |

## ORDERING INFORMATION

| Part No. | Description |
| :---: | :---: |
| A65/40-7092 <br> RM65-5101NE | AIM 65/40 BDOS 1.0 Upgrade Kit RM 65 FDC Module (without ROM containing primitive subroutines ${ }^{(1)}$ ) |
| Order No. | Description |
| 2152 | AIM 65/40 BDOS, 1.0 User's Manual ${ }^{(2)}$ |
| 288 | AIM 65 Monitor/Editor Program Listing |
| 280 | AlM 65/40 System User's Manual |
| 262 | AIM 65/40 I/O ROM Program Listing |
| Notes: <br> 1. BDOS 1.0 ROM in upgrade kit includes primitive subroutines in addition to DOS functions. <br> 2. Included with A65/40-7092 |  |
|  |  |

## SECTION 9 RM 65 MICROCOMPUTER MODULE FAMILY

Page
Product Family Overview ..... 9-2
RM65-1000E Single Board Computer (SBC) Module ..... 9-3
RM65-0110 I/O ROM ..... 9-7
RM65-0122 Run-Time BASIC INTERPRETER ROM ..... 9-8
RM65-0152 Run-Time FORTH ROM ..... 9-10
RM65-2901E PROM Programmer Module ..... 9-15
RM65-3108E 8K Static RAM Module ..... 9-21
RM65-3132E 32K Dynamic RAM Module ..... 9-25
RM65-3216E 16K PROM/ROM Module ..... 9-29
RM65-3264NE Univeral Memory Module ..... 9-33
RM65-5101E Floppy Disk Controller (FDC) Module ..... 9-37
RM65-5102E CRT Controller (CRTC) Module ..... 9-43
RM65-5104E Direct Memory Access Controller Module ..... 9-49
RM65-5222E General Purpose Input/Output (GPIO) and Timer Module ..... 9-54
RM65-5223E Multi-Function Peripheral Interface (MPI) Module ..... 9-58
RM65-5302E and RM65-5303E Analog Input Module and Analog Input/Output Module ..... 9-63
RM65-5451E Asynchronous Communications Interface Adapter (ACIA) Module ..... 9-69
RM65-7004E and RM65-7004NE 4-Slot Piggyback Module Stack and Motherboard ..... 9-73
RM65-7008E and RM65-7008NE 8-Slot Card Cage and Motherboard ..... 9-78
RM65-7016E and RM65-7016NE 16-Slot Card Cage and Motherboard ..... 9-83
RM65-7101E Single Card Adapter Module for AIM 65 ..... 9-88
RM65-7102E IEEE-488 Bus Interface Module ..... 9-94
RM65-7104E Adapter/Buffer Module for AIM 65 ..... 9-99
RM65-7116E RM65 Cable Driver Adapter/Buffer Module for AIM 65 ..... 9-105
RM65-7141E Adapter Cable and Buffer Module for AIM 65/40 ..... 9-111
RM65-7201E Design Prototyping Module ..... 9-116
RM65-7211E Extender Module ..... 9-120

# RM 65 MICROCOMPUTER MODULE FAMILY Standard Boards Cut Design Costs, Offer Flexibility 

RM 65 microcomputer modules offer a simple solution to designing hard working blue coilar microcomputer systems. You start with an R6502 based single board Eurocard-sized computer. Then you add functions, exactly as required, with additional Eurocards. Program your system in either FORTH or BASIC, control essentially any peripherals the system may need. There's no more optimum way to quickly and economically put together prototype and small to medium run systems.

The RM 65 family includes a single board computer, memory, general purpose I/O, intelligent peripheral controllers and accessory modules. Silicon software supports the family with BASIC, FORTH and peripheral drivers. Plus, the family includes card cages, buffers, adapters, cabling, extender module, everything needed for complete system implementation.

The RM 65 microcomputer modules are all Eurocard sized, $100 \mathrm{~mm} \times 160 \mathrm{~mm}$. Memory modules include 8 K static RAM, 32K dynamic RAM, 16K PROM/ROM and a PROM programmer. ROMs include I/O, BASIC and FORTH. There is an IEEE-488 module, general purpose I/O and timer module, ACIA module, and a multifunction peripheral controller module.
An analog input/output module allows an RM 65 system to interface with thermocouples, strain gages, pressure sensors and similar analog devices. Floppy disk and CRT controller modules allow RM 65 systems to drive displays and removable memory. A direct memory access controller allows RM 65 systems to have high data transfer rates when needed.

Since the RM 65 blue collar family is designed around the R6500 family, systems can be readily redesigned into R6500 devices as volume or application warrant. RM 65 lets you design custom systems with standard boards, buying only what you need, when you need it.


## RM 65 MICROCOMPUTER MODULES

The RM65-1000E Single Board Computer Module is one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Modules are 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.

RM 65 Microcomputer Modules use a motherboard interconnect concept and accept 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 AIM 65 and AIM 65/40 Microcomputers for product development and for a broad variety of portable or desk-top microcomputer applications.

## PRODUCT OVERVIEW

The RM65-1000E Single Board Computer (SBC) Module 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 module 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 65K 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 counter-timers 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.

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-1000E | Single Board Computer (SBC) Module |
| Order No. | Description |
| 809 | Single Board Computer (SBC) Module User's <br> Manual (included with RM655-1000E) |

## FEATURES

- Compact size-about $4^{\prime \prime} \times 61 / 2^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Pin and socket bus connection
- On-board R6502 CPU
- 2K of 2114 static RAM
- Two sockets for up to 16K 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 65 K byte memory banks
- Jumpers allow selection of the following
$-2 K$, 4 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


RM65-1000E Single Board Computer (SBC) Module

## FUNCTIONAL DESCRIPTION

The Clock Circuit uses a crystal-controlled oscillator to provide a stable $1-\mathrm{MHz}$ clock reference. A jumper selects between the internal 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 65K) 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 \mathrm{~K}, 4 \mathrm{~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 K \times 4$ RAM devices to provide on-board read/write memory.

The R6522 Versatile Interface Adapter (VIA) provides inputoutput capability to the SBC Module. The VIA provides two 8bit 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 ( $\varnothing 0$ ), Ready and Bus Fioat input lines are buffered coming from the RM 65 bus into the SBC Module. The DMA Terminate, Reset and Phase 1 Clock ( $\varnothing 1$ ) 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.


RM 65 Bus Pin Assignments

| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | Pin | Signal Mnemonic | Signal Name |
| 1 a | GND | Ground | 10 | +5V | $+5 \mathrm{Vdc}$ |
| 2a | BADR/ | Buffered Bank Address | 2 c | BA15/ | Buffered Address Bit 15 |
| 3 a | GND | Ground | 3 c | BA14/ | Buffered Address Bit 14 |
| 4a | BA13/ | Buffered Address Bit 13 | 4 c | BA12/ | Buffered Address Bit 12 |
| 5 a | BA11/ | Buffered Address Bit 11 | 5 c | GND | Ground |
| 6 a | BA10/ | Buffered Address Bit 10 | 6 c | BA9/ | Buffered Address Bit 9 |
| 7 a | BA8/ | Buffered Address Bit 8 | 7 c | BA7/ | Buffered Address Bit 7 |
| 8 a | GND | Ground | 8 c | BA6/ | Buffered Address Bit 6 |
| 9 a | BA5/ | Buffered Address Bit 5 | 9 c | BA4/ | Buffered Address Bit 4 |
| 10a | BA3/ | Buffered Address Bit 3 | 10 c | GND | Ground |
| 11a | BA2/ | Buffered Address Bit 2 | 11 c | BA1/ | Buffered Address Bit 1 |
| 12a | BAO/ | Buffered Address Bit 0 | 12 c | B61 | Buffered Phase 1 Clock |
| 13a | GND | Ground | 13 c | BSYNC | Buffered Sync |
| 14a | BSO | Buffered Set Overflow | 14 c | BDRQ1/ | *Buffered DMA Request 1 |
| 15a | BRDY | Buffered Ready | 15 c | GND | Ground |
| 16a |  | * User Spare 1 | 16 c | $-12 \mathrm{~V} /-\mathrm{V}$ | *-12 Vdc/-V |
| 17a | $+12 \mathrm{~V} /+\mathrm{V}$ | *+12 Vdc/+V | 17 c |  | *User Spare 2 |
| 18a | GND | Ground line | 18 c | BFLT/ | Buffered Bus Float |
| 19a | BDMT/ | Buffered DMA Terminate | 190 | Вф0 | Buffered External Phase 0 Clock |
| 20a |  | * User Spare 3 | 20c | GND | Ground |
| 21a | $\mathrm{BR} / \overline{\mathrm{W}} /$ | Buffered Read/Write "Not" | 21 c | BDRQ2/ | *Buffered DMA Request 2 |
| 22a |  | *System Spare | 22 c | $B R / \bar{W}$ | Buffered Read/Write |
| 23a | GND | Ground | 23c | BACT/ | *Buffered Bus Active |
| 24a | BIRQ/ | Buffered Interrupt Request | 24c | BNMI/ | Buffered Non-Maskable Interrupt |
| 25a | B $\varnothing 2 /$ | Buffered Phase 2 "Not" Clock | 25 c | GND | Ground |
| 26a | B¢2 | Buffered Phase 2 Clock | 26c | BRES/ | Buffered Reset |
| 27a | BD7/ | Buffered Data Bit 7 | 27c | BD6/ | Buffered Data Bit 6 |
| 28a | GND | Ground | 28 c | BD5/ | Buffered Data Bit 5 |
| 29a | BD4/ | Buffered Data Bit 4 | 290. | BD3/ | Buffered Data Bit 3 |
| 30a | BD2/ | Buffered Data Bit 2 | 30c | GND | Ground |
| 31a | BD1/ | Buffered Data Bit 1 | 31 c | BDO/ | Buffered Data Bit 0 |
| 32a | +5V | $+5 \mathrm{Vdc}$ | 32 c | GND | Ground |

Note:
Not used on this module.


RM 65 SBC Module Dimensional Outline

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions (See Notes) <br> Width <br> Length <br> Height | 3.9 in . 100 mm ) <br> $6.3 \mathrm{in} .(160 \mathrm{~mm})$ <br> 0.56 in . $(14 \mathrm{~mm})$ |
| Weight | 5.6 oz . (160 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} \end{aligned}$ <br> $0 \%$ to $85 \%$ (without condensation) |
| Electrical Power Requirements | $\begin{array}{r} +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}$ |
| Interface <br> RM 65 Bus Interface <br> /O Connector <br> RESET Switch Connector | 64-pin plug ( 0.100 in . centers) per DIN 41612 (Row B not installed) <br> 40-pin 3M mass termination ( 0.100 in . centers) <br> 2 vertical pins ( $0: 3 \mathrm{in}$. high) on 0.200 in. center |

## Notes:

1. 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. Length does not include extensions beyond the edge of the module due to connectors or the module ejector.
3. Dimensions conform to DIN 41612.

# RM65-0110 <br> RM 65 INPUT/OUTPUT (I/O) ROM 

## INPUT/OUTPUT FUNCTIONS

The input/output (I/O) functions in a microcomputer performs interface processing between an application program and peripheral devices, e.g. display, printer and keyboard. These functions are usually implemented as closed subroutines that may be called by the application program or as part of an operating system that operates on passed parameters. The I/O functions normally issue operating commands to the peripherals, monitor status from the peripherals and transfer data to and from the peripherals. Data formatting and message protocol stripping is also usually performed. In addition, general purpose utility functions supporting I/O operations are often provided.

## PRODUCT OVERVIEW

The RM 65 /O ROM contains initialization, interrupt and I/O processing functions to interface AIM 65/40 peripherals to an RM 65 Single Board Computer (SBC) based microcomputer system. The processing and entry points, in most cases, are identical to the AIM 65/40 /O ROM, to enable an application program developed on the AIM 65/40 Microcomputer to be easily transferred to the RM 65 environment for final validation and production operation. Source code entry, editing, compilation and/or assembly, and debugging can be performed on the AIM 65/40 Microcomputer with its extensive development aids using the AIM 65/40 Debug Monitor/Text Editor and the desired language. The AIM 65/40 peripherals connected to the AIM 65/ 40 SBC module can support development as well as application checkout in this configuration.
In a minimum RM 65 module installation consisting of only the RM 65 SBC module (RM65-1000E), the 4K-byte RM 65 I/O ROM in one SBC module socket supports an application program in the other SBC module socket for user-defined I/O over the SBC module parallel $1 / 0$ port. The addition of one RM 65 Multifunction Peripheral Interface (MPI) module (RM65-5223E) allows interface to an AIM 65/40 Keyboard and either the AIM 65/40 40-Character Display or AIM 65/40 Video Display Controller in one configuration, or the AIM 65/40 Graphics Printer and a user-defined interface in the other configuration. Installation of two RM 65 MPI modules supports both configurations.

## MEMORY MAP

| Address (Hex) | Contents |
| :---: | :---: |
| \$FFFA-\$FFFF | NMI, RES and IRQ Vectors |
| \$F000-\$FFF9 | I/O ROM Program |
| \$1000-\$1FFF | System I/O |
| \$200-\$49F | V/O ROM Vectors, Constants and Variable |
| \$FO-\$FF | I/O ROM Variables |

## FEATURES

- RM 65 SBC module compatible
- AIM 65/40 VO ROM interface compatible
- ROM resident for immediate operation
- Supports AIM 65/40 Peripherals
—40-Character Display (A65/40-0400)
-Video Display Controller Module (A65/40-0800)
-Graphics Printers (A65/40-0600)
-Standard Keyboard (A65/40-0200)
-Expanded Keyboard (A65/40-0210)
- Interrupt Handlers
-Interrupt Request (IRQ) with before and after user linkage
-Non-Maskable Interrupt (NMI) with before and after user linkage
—Reset (RES)
-Break instruction linkage
- Initialization Functions
-Cold and warm start variable initialization
-Autostart linkage to application programs
- Provide input/output handlers for
-Keyboard (system terminal) input
-Display/printer (system terminal) output
- Memory input/output
-Floppy disk (RM65-5101E)
- Printer output
-Interactive user-defined input/output
-Non-interactive user-defined input/output
-Null output
- User-alterable variables
-Input/output vectors
-Interrupt vectors
ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-0110 | RM 65 VO ROM |
| Order No. | Description |
| 821 | RM 65 VO ROM User's Manual ${ }^{*}$ |
| Note: <br> "Included with |  |

## RM 65-0122 <br> RM 65 RUN-TIME BASIC INTERPRETER ROM

## BASIC LANGUAGE

BASIC is a simple but powerful computer program language. Originally developed at Dartmouth University, BASIC has gained universal acceptance and is commonly used world-wide in schools, industry, and science.

The heart of BASIC is a set of easily learned English words which are used as commands. Complex and powerful statements can be constructed by adding operands and operators to the commands. Equations involving complex formulas and multiple variables can easily be solved. Internal floating point arithmetic handles a wide range of numeric values ( $2.93873588 \mathrm{E}-39$ to $1.70141183 \mathrm{E}+38$ ) and provides nine-digit accuracy to most calculations. In addition to addition, subtraction, multiplication and division, a full set of transcendental functions support trigonometric, exponential, square, square root, polynomial and logarithmic operations.

## PRODUCT OVERVIEW

RM 65 Run-Time BASIC, consisting of input formatter, lister, interpreter, floating point functions and input/output linkage, is contained in an 8K-byte ROM that plugs into an RM65-1000 Single Board Computer (SBC) or RM65-3216 PROM/ROM module for development or run-time operation in the RM 65 environment. This run-time package allows an application program written in BASIC to be developed on an AIM 65 Microcomputer using its on-board peripherals (keyboard, single line display and printer) and ROM resident Debug Monitor and Text Editor and then transferred to the RM 65 module for run-time operation.

All input/output functions for use with RM 65 Run-Time BASIC are user-provided and link to the application program through one or more of the 10 I/O vectors provided in the run-time ROM. BASIC words such as LOAD, SAVE, PRINT, INPUT, READ and GET link through these vectors to the $1 / O$ functions.

The RM 65 Run-Time BASIC can be used in the development mode by user-provided AIM 65 equivalent input/output functions. In fact, the RM 65 Run-Time BASIC ROM can be installed on an RM 65 PROM/ROM module, the module connected to an AIM 65 Microcomputer, the I/O vectors loaded to point to AIM 65 Monitor ROM functions, then development and/or final program validation performed on the AIM 65 Microcomputer before transferring the application program object code to PROM/ROM.

## LANGUAGE FEATURES

- BASIC is easy to learn
- Microsoft BASIC is universally accepted
- BASIC is widely used
- Supports simple and complex statements
- Floating point arithmetic functions
—Add, subtract, multiply, divide
-Trigonometric (sine, cosine, tangent, arctangent)
-Exponential, square, square root
- Natural logarithm
- String variables and arrays
- Integer variables
- Subroutine calls
- Conditional expressions
- User function


## INTERPRETER FEATURES

- RM 65 Single Board Computer (SBC) module host and/or target
- ROM resident for immediate operation
- Compatible with indirect statements entered on AIM 65 Microcomputer with AIM 65 BASIC
- I/O vectors link to user-provided peripheral drivers


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-0122 RM 65 Run-time BASIC ROM <br> A65-020  | AIM 65 BASIC ROMs |
| Order No. | Description |
| 810 | RM 65 Run-time BASIC User's Manual ${ }^{(1)}$ |
| 221 | AIM 65 BASIC User's Manual |
| Notes: |  |
| 1. |  |
| Included with RM65-0122. <br> 2. Included with A65-020. |  |

MEMORY MAP

| Address (Hex) | Contents |
| :--- | :--- |
| $\$ B 000-\$ C F F F$ | BASIC Program |
| $\$ 248-\$ 2 D C$ | BASIC Input/Output Buffers |
| $\$ 218 \$ 247$ | BASIC Variables |
| $\$ 200-\$ 217$ | BASIC I/O Vectors |
|  | BASIC Variables |

## PROM PROGRAMMING

The application program object code can be programmed into a PROM for operation in an OEM or end-user environment using an AIM 65 PROM Programmer \& CO-ED module (A65-901) or an RM 65 PROM Programmer module (RM652901E) connected to the AIM 65 Microcomputer.

## STATEMENTS



# RM65-0152 <br> RM 65 RUN-TIME FORTH ROM 

## FORTH LANGUAGE

FORTH is a unique programming language well suited to a variety of applications. Because it was originally developed for real-time control applications, FORTH is ideal for machine and process control, energy management, data acquisition, automatic testing, robotics and other applications where assembly language was previously the only possible language choice.

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

## FEATURES

- RM 65 SBC module compatible
- ROM resident for immediate operation
- Application oriented
- Extensible language
- Over 200 pre-defined functions
- Interactive compilation
- Reverse polish notation
- Compact memory usage
- Fast execution
- Easy debugging
- Stack implementation
- 16-bit words
- Built-in structured macro assembler
- Shortens software development time
- AIM 65 FORTH compatible


## PRODUCT OVERVIEW

RM 65 Run-Time FORTH, consisting of primitives, interpreter, macro assembler and input/output linkage, is contained in an 8K-byte ROM that plugs into an RM65-1000E Single Board Computer (SBC) or RM65-3216E PROM/ROM module for development or run-time operation in the RM 65 environment. This run-time package allows an application program written in FORTH to be developed on an AIM 65 Microcomputer with its on-board peripherals (keyboard, single line display and printer) and ROM-resident Debug Monitor and Text Editor and then transferred to the RM 65 module for run-time operation. The application program object code can be programmed into a PROM using an A65-901 AIM 65 PROM Programmer \& CO-ED module or an RM65-2901E PROM Programmer module.

All input/output functions for use with RM 65 Run-Time FORTH are user-provided and link to the application program through one or more of the $11 \mathrm{I} / \mathrm{O}$ vectors provided in the run-time ROM. FORTH words such as KEY, EXPECT, EMIT, GET, READ, and ?IN link through these vectors to the I/O functions.

The RM 65 Run-Time FORTH can be used in the development mode by user-provided AIM 65 equivalent input/output functions. In fact, the RM 65 Run-Time FORTH ROM can be installed on an RM 65 PROM/ROM module, the module connected to an AIM 65 Microcomputer, the I/O vectors loaded to point to AIM 65 Monitor ROM functions, then development and/or final program validation performed on the AIM 65 Microcomputer before transferring the application program object code to PROM/ROM.

## ORDERING INFORMATION

| Part No. | Description |
| :--- | :--- |
| RM65-0152 | RM 65 Run-Time FORTH ROM |
| A65-050 | AIM 65 FORTH ROMs |
| A65-040 | AIM 65 Math Package ROM |
| Order No. | Description |
| 812 | RM 65 Run-Time FORTH User's Manual ${ }^{(1)}$ |
| 265 | AIM 65 FORTH User's Manual(2) |
| 2118 | AIM 65 Math Package User's Manual ${ }^{(3)}$ |
| Notes: |  |
| 1. Included with RM65-0152 |  |
| 2. Included with A65-050. |  |
| 3. Included with A65-040. |  |

## 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 features 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 (RPM), the notation that is used in Hewlett-Packard scientific calculators. Using a data stack is an extremely efficient way of passing variables 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/bottomup" 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 submodules. 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.

## FLOATING POINT FUNCTIONS

The RM 65 Run-Time FORTH ROM contains both a single-(16-bit) and double- (32-bit) precision integer arithmetic capability. In RM 65 applications where floating point arithmetic is desired, the AIM 65 Math Package ROM may be used in conjunction with the run-time FORTH ROM. The application program can be developed on an AIM 65 Microcomputer with both AIM 65 FORTH and AIM 65 Math Package ROMs installed. A math package ROM must then be installed in the RM 65 SBC or PROM/ROM module for run-time operation of the application program along with the RM 65 Run-Time FORTH ROM.

## MEMORY MAP

| Address (Hex) | Description |
| :--- | :--- |
| $\$ D 000-\$ D F F F$ | Math Package Program |
| $\$$ B000-\$CFFF | FORTH Program |
| $\$ 300-\$ 31 E$ | IO Vectors |
| $\$ 280-\$ 2 F F$ | Terminal Input Buffer |
| $\$ 25 C-\$ 27 F$ | Math Package Variables |
| $\$ 200-\$ 257$ | FORTH User Variables |
| $\$ A B-\$ C 4$ | Math Package Variables |
| $\$ 10-\$ A A$ | FORTH Variables |

## FORTH WORDS

## STACK MANIPULATION

DUP
2DUP
DROP
2DROP
SWAP
OVER
ROT

- DUP
$>R$
$R>$
R
PICK
SP@
RP@
BOUNDS
.S

DEFINING WORDS

```
:<name>
```

VARIABLE <name>

CONSTANT <name>

CODE <name>
;CODE
<BUILDS . . . DOES $>$

USER

## MEMORY

@

TOGGLE

Duplicate top of stack.
Duplicate top two stack items.
Delete top of stack.
Delete top two stack items.
Exchange top two stack items.
Copy second item to top.
Rotate third item on top.
Duplicate only if non-zero
Move top item to return stack.
Retrieve item from return stack.
Copy top of return stack onto stack.
Copy the nth item to top.
Return address of stack position
Return address of return stack pointer.
Convert "address count" to "endaddress start-address."
Print contents of stack.

Begin colon definition of <name>. End colon definition.
Create a variable <name> with initial value n ; returns address when executed.
Create a constant <name> with value $n$; returns value when executed.
Begin definition of assembly-language primitive operation <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 user variable.

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 n 3 bytes starting at address n 1 to area starting at address n 2 .
Put byte n3 into n2 bytes starting at address n 1 .
Fill n2 bytes in memory with zeroes, beginning at address n 1 .
Fill n2 bytes in memory with blanks, beginning at address n 1 .
Mask memory with bit pattern.

## NUMERIC REPRESENTATION

| DECIMAL | Set decimal base. |
| :--- | :--- |
| HEX | Set hexadecimal base. |
| BASE | Set number base. |
| DIGIT | Convert ASCII to binary. |
| 0 | The number zero. |
| 1 | The number one. |
| 2 | The number two. |
| 3 | The number three. |

## FORTH WORDS (CONT'D)

ARITHMETIC AND LOGICAL

| + | Add. |
| :---: | :---: |
| D+ | Add double-precision numbers. |
| - | Subtract ( n 1 - n 2 ) |
| - | Muitiply. |
| 1 | Divide ( $\mathrm{n} 1 / \mathrm{n} 2$ ). |
| MOD | Modulo (i.e., remainder from division). |
| /MOD | Divide, giving remainder and quotient. |
| ./MOD | Multiply, then divide ( $\mathrm{n} 1 \cdot \mathrm{n} 2 / \mathrm{n} 3$ ), with double intermediate. |
| $\cdot /$ | Like //MOD, but give quotient only. |
| U. | Unsigned multiply leaving double product. |
| U/ | Unsigned divide. |
| M* | Signed multiplication leaving double product. |
| M/ | Signed remainder and quotient from double dividend. |
| M/MOD | Unsigned divide leaving double quotient and remainder from double dividend and single divisor. |
| MAX | Maximum. |
| MIN | Minimum. |
| + - | Set sign. |
| D+ - | Set sign of double-precision number. |
| ABS | Absolute value. |
| DABS | Absolute value of double-precision number. |
| NEGATE | Change sign. |
| DNEGATE | Change sign of double-precision number. |
| $S->D$ | Sign extend to double-precision number. |
| $1+$ | Increment value on top of stack by 1 . |
| $2+$ | Increment value on top of stack by 2. |
| 1 - | Decrement value on top of stack by 1 . |
| $2-$ | Decrement value on top of stack by 2. |
| AND | Logical AND (bitwise). |
| OR | Logical OR (bitwise) |
| XOR | Logical exclusive OR (bitwise). |

## COMPARISON OPERATORS

$<\quad$ True if $n 1$ less than n2.
$>\quad$ True if n 1 greater than n 2.
$=\quad$ True if top two numbers are equal.
$0<\quad$ True if top number negative.
$0=\quad$ True if top number zero.
$\mathrm{U}<\quad$ True if u1 less than u2.
NOT
Same as $0=$.

## MISCELLANEOUS AND SYSTEM

(<comment>)

## CFA

NFA
PFA
LFA
LIMIT
QUIT

Begin comment (terminate by right parentheses on same line).
Alter PFA to CFA.
Alter PFA to NFA.
Alter NFA to PFA.
Alter PFA to LFA.
Top of memory.
Clear return stack and return to terminal.

CONTROL STRUCTURES

| DO ... LOOP | Set up loop, given index range. |
| :---: | :---: |
| DO . . + + LOOP | Like DO . . . LOOP, but adds stack value to index. |
| 1 | Place current index value on stack. |
| LEAVE | Terminate loop at next LOOP or +LOOP. |
| BEGIN . . . UNTIL | Loop back to BEGIN until true at UNTIL. |
| BEGIN . . . WHILE <br> ... REPEAT | Loop while true at WHILE, REPEAT loops unconditionally to BEGIN. |
| BEGIN .. AGAIN | Unconditional loop. |
| IF . . . THEN | If top of stack true, execute following clause THEN continue; otherwise continue at THEN. |
| IF . . . ELSE . . THEN | If top of stack true, execute ELSE clause THEN continue, otherwise execute following clause, THEN continue. |
| END | Alias for UNTIL. |
| ENDIF | Alias for THEN. |
| COMPILER-TEXT INTERPRETER |  |
| [COMPILE] | Force compilation of IMMEDIATE word. |
| COMPILE | Compile following <name> into dictionary. |
| LITERAL | Compile a number into a literal. |
| DLITERAL | Compile a double-precision number into a literal. |
| EXECUTE | Execute the definition on top of stack. |
| [ | 'Suspend compilation, enter execution. |
| ] | Resume compilation. |

DICTIONARY CONTROL

| CREATE | Create a dictionary header. <br> FORGET all definitions from $<$ name> <br> on. |
| :--- | :--- |
| FORGET |  |$\quad$| Returns address of next unused byte in |
| :--- |
| the dictionary. |
| Leave a gap of $n$ |

## FORTH WORDS (CONT'D)

| USER VARIABLES (See Note 1) |  | OUTPUT FORMATTING (CONT'D) |  |
| :---: | :---: | :---: | :---: |
| U?TERMINAL | User variable for ?TERMINAL. (See Note 2.) | \# | Convert next digit of double-precision number and add character to output |
| UABORT | User variable for ABORT. |  | string. |
| UB/BUF | User variable for B/BUF. | \#S | Convert all significant digits of double- |
| UB/SCR | User variable for B/SCR. |  | precision number to output string. |
| UC/L | User variable for C/L. | SIGN | Insert sign of n into output string. |
| UEMIT | User variable for EMIT. | \#> | Terminate output string (ready for |
| UFIRST | User variable for FIRST. |  | TYPE). |
| UKEY | User variable for KEY. | HOLD | Insert ASCII character into output |
| ULIMIT | User variable for LIMIT. |  | string. |
|  |  | HDL | Hold pointer, user variable. |
| MONITOR \& CASSETTE I/O (See Note 1) |  | - TRAILING | Suppress trailing blanks. |
| COLD | AIM 65 FORTH cold start. (See Note 2.) | .LINE COUNT | Display line of text from mass storage. Change length of byte string to type form. |
| MON | Exit to AIM 65 Monitor. (See Note 2.) |  | Print number on top of stack. |
| CHAIN | Chain tape file. | .R | Print number n 1 right justified n2 |
| CLOSE | Close tape file. |  | places. |
| ? IN | Set to active input device (AID). | D. | Print double-precision number n2 n2. |
| ? OUT | Set to active output device (AOD). | D.R | Print double-precision number n2 n 1 |
| GET | Input a character from the AID. |  | right justified n 3 places. |
| PUT | Output a character to the AOD. | DPL | Number of digits to the right of decimal |
| READ | Input n2 characters from AID to address n 1 . |  | point. |
| WRITE | Output n2 characters to AOD at address n 1 . | VOCABULARIES |  |
|  |  | CONTEXT | Returns address of pointer to |
| SOURCE | Compile from the AID. |  | CONTEXT vocabulary. |
| FINIS | Terminate complete from SOURCE. | CURRENT | Returns address of pointer to CURRENT vocabulary. |
| INPUT-OUTPUT (See Note 1). |  | FORTH | Main FORTH vocabulary. |
|  |  | ASSEMBLER | Assembler vocabulary. |
| - CR | Output CR to printer only. | DEFINITIONS | Set CURRENT vocabulary to |
| CR | Carriage return. |  | CONTEXT. |
| SPACE | Type one space. | VOCABULARY <name> | Create new vocabulary. |
| SPACES | Type $n$ spaces. | VLIST | Print names of all words in CONTEXT |
| CLRLINE | Output a CTRL B. |  | vocabulary. |
|  | Print text string (terminated by "). | VOC-LINK | Most recently defined vocabulary. |
| $\begin{aligned} & \text { DUMP } \\ & \text { TYPE } \end{aligned}$ | Dump n2 words starting at address. | VIRTUAL STORAGE |  |
|  | Type string of n 1 characters stariing at address n 2 . | LOAD | Load mass storage screen (compile or execute). |
| PTERMINAL | True if terminal break request present. | BLOCK | execute). <br> Read mass storage block to memory |
| KEY | Read key, put ASCII value on stack. | BLOCK | Read mass storage block to memory address. |
| EXPECT | Read n 1 characters from input to address n2. | B/BUF | System constant giving mass storage block size in bytes. |
| WORD | Read one word from input stream, until delimiter. | BLK | System variable containing current block number. |
| IN | User variable contained within TIB. |  |  |
| baud | Set BAUD rate. | SCR | System variable containing current |
| BL | Output a SPACE character. |  | screen number. |
| C/L | Number of characters/line. | UPDATE FLUSH | Mark last buffer accessed as updated. |
| TIB | Pointer to terminal input buffer start address. | FLUSH | Write all updated buffers to mass storage. |
| QUERY | input text from terminal. | EMPTY-BUFFERS | Erase all buffers. |
| ID. | Print <name> from name \# field address (nta) | $\begin{aligned} & \text { +BUF } \\ & \text { BUFFER } \end{aligned}$ | Increment buffer address. Fetch next memory buffer. |
| HANG | Wait for keystroke. | RW | User read write linkage. |
| OUTPUT FORMATTING (See Note 1) |  | USE | Variable containing address of next buffer. |
| NUMBER | Convert string at address to doubleprecision number. | PREV | Variable containing address of latest buffer. |
|  |  |  | Leaves address of first block buffer. |
| <\# | Start output string. | OFFSET | User variable block offset to mass storage. |
| NOTES: 1. Rea | r-provided V/O function. |  | Interpret next screen. |
|  | 65 Monitor ROM be installed. | ; S | Stop interpretation. |

OUTPUT FORMATTING (CONT'D)

## FORTH WORDS (CONT'D)

| Primitives |  | SECURITY |
| :---: | :---: | :---: |
| OBRANCH | Run-time conditional branch. | !CSP |
| BRANCH | Run-time unconditional branch. |  |
| ENCLOSE | Text scanning primitive used by WORD. | ?COMP |
| RO | Location of Return Stack. | ?CSP |
| SO | Location of Parameter Stack. | ?ERROR |
| RP! | Initialize Return Stack. | ?EXEC |
| SP! | Initialize Parameter Stack. | ?PAIRS |
| NEXT | The FORTH virtual machine. | ?STACK |
|  |  | ABORT |
|  |  | ERROR |
|  |  | MESSAGE |
|  |  | WARNING |
|  |  | FENCE |
|  |  | WIDTH |

Store stack position in check stack pointer.
Error if not compiling.
Check stack position.
Output error message.
Not executing error.
Conditional not paired error.
Stack out of bounds error.
Error; operation terminates.
Execute error notification and restart system.
Displays message.
Pointer to message routine.
Prevents forgetting below this point.
Controls significant characters of <name>.

## MATH PACKAGE FORTH WORDS (A65-040)*

## FLOATING POINT ARITHMETIC <br> F+ Adds two floating point numbers. F- Subtracts one floating point number from another floating point number. <br> $\mathrm{F}^{*} \quad$ Multiplies two floating point numbers. <br> F/ Divides one floating point number by another floating point number.

| UTILITY, SIGN AND COMPARISONS |  | FIN |
| :---: | :---: | :---: |
| FABS | Takes the absolute value of a floating point number. | FOUT |
| INT | Truncates a floating point number to an integer. |  |
| SGN | Converts the sign of a floating point number to a floating point number. | FORMA $M>F$ |
| FSIGN | Gets a value corresponding to the sign of a floating point number. | $M>F$ $F>M$ |
| FCOMP | Compares the value of a compacted number in memory to a floating point number. | $\mathrm{M}>\mathrm{A}$ |
| POLYNOMIAL |  | S>A |
| POLY | Evaluates a polynomial with consecutive exponents. | S $>\mathrm{F}$ |
| POLYODD | Evaluates a polynomial with odd exponents. | F>S |

## EXPONENTIAL AND LOGARITHMIC

Takes the square root of a floating point number.
$>\quad$ Raises one floating point number to the power of another floating point number.
EXP
LOG

LN
Raises the transcendental number e to the power of a floating point number.
Computes the logarithm to the base 10 (i.e., common log) of a floating point number.
Computes the logarithm to the base e (i.e., natural $\log$ ) of a floating point number.

MIN-WIDTH

USER VARIABLE

DEC-LENGTH
Specifies the minimum field width to be output.
Specifies the number of places to the right of the decimal point to be output.

## ASCII/FLOATING POINT CONVERSIONS

Converts a number in memory from ASCII to floating point format.
Converts a number from floating point to ASCII.

## FORMAT CONVERSION AND DATA MOVING

## TRIGONOMETRIC AND UNITS CONVERSION

Unpacks the compacted number in memory to floating point.
Packs the floating point number to compacted format and stores the result in memory.
Unpacks the floating point number in memory.
Converts an integer to floating point format.
Converts an integer to floating point format.
Converts a number from floating point to an integer.

Calculates the sine of a floating point number (in radians).
Calculates the cosine of a floating point number (in radians).
Calculates the tangent of a floating point number (in radians).
Calculates the arc tangent of a floating point number.
Converts a floating point number from radians to degrees.
Converts a floating point number from degrees to radians.

[^20]
## RM65-2901E RM 65 PROM PROGRAMMER MODULE

## RM 65 MICROCOMPUTER MODULES

RM 65 Microcomputer Module products are 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.

RM 65 Module products use a motherboard interconnect concept in which any card can be inserted in any slot. The 64 -line RM 65 Bus offers memory addressing up to 128 K bytes, provides high immunity to electrical noise and includes growth provisions for user functions. A selection of card cages allows packaging flexibility. RM 65 products may also be used with Rockwell AIM 65 and AIM 65/40 Microcomputers for product development and for a broad variety of portable or desktop microcomputer applications.

## PRODUCT OVERVIEW

The RM 65 PROM Programmer module in conjunction with an AIM 65 or AIM 65/40 Microcomputer; programs industry standard 1 K -, 2 K -, 4 K - and 8 K -byte EPROMs (ultra-violet light erasable prograrnmable read-only memories) and 2K-byte EEROMs (electrically erasable programmable read-only memories). The module consists of an RM 65 module and a PROM socket module connected together by a 24 -inch ribbon cable. A 28 -pin Zero Insertion Force (ZIF) socket mounted on the PROM socket module allows installation of a 28 -pin or 24 -pin PROM. The PROM socket module may be installed in various desk-top enclosure or front panel arrangements for development, enduser or OEM installation.

## FEATURES

- RM 65 bus compatible
- Compact size RM 65 module-about $100 \mathrm{~mm} \times 160 \mathrm{~mm}$ ( $4 \mathrm{in} . \times 61 / 4 \mathrm{in}$.)
- Separate PROM socket module with
-28-pin Zero Insertion Force (ZIF) socket
-Mounting holes for enclosure or panel installation
-Connecting 24 -inch cable to RM 65 module
- Programs 1K-byte to 8K-byte UV EPROMs
—1K-byte: 2508, 2758
—2K-byte: 2516, 2716
-4K-byte: 2532, 2732, 2732A
—8K-byte: 2564, 2764, 68764
- Erases and programs 2K-byte EEROMs
—2K-byte: R5213/2816, 5213, 2816, 48016
- On-board 8 K -byte ROM contains programming functions compatible with both
-AIM 65 Microcomputer Monitor
-AIM 65/40 Microcomputer I/O and Monitor
- Easy-to-use interactive commands
—PROM interface (check, program, read, verify)
-RAM preparation (fill and invert)
-Utility functions (command and PROM type menu, PROM type selection, toggle verify mode, etc.)
- Verify during or after programming
- +5 V only operation (on-board DC/DC converter)
- Fully assembled and tested with one year warranty


RM65-2901E PROM Programmer Module

## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-2901E | PROM Programmer Module |
| Order No. | Description |
| 820 | PROM Programmer Module User's Manual ${ }^{\star}$ |
| Note: <br> $\star$ Included with RM65-2901E. |  |

## FUNCTIONAL DESCRIPTION

## RM 65 Module

The Data Transceivers invert and transfer 8-bits of parallel data between the PROM Programmer module and the RM 65 data bus when enabled by the Chip Select Decoder. The read/write line from the RM 65 bus determines the direction of data flow. During a write operation, data is transferred from the bus to the module; during a read operation, data is transferred from the module to the RM 65 bus.

The Control Signal Buffers invert and transfer the phase 2, read/ write, bank address and reset signals from the RM 65 bus to the module. The bus active signal is also driven to the RM 65 bus when data is being transferred between the RM 65 bus and the module.

Address Signal Buffers invert and transfer signals from 13 address lines from the RM 65 bus to the module.

The Chip Select Decoder, in conjunction with Base Address Select, Bank Select and Bank Select Enable switches and the ROM Range Select jumper decodes the address from the RM 65 bus and generates enable signals to other major on-board circuits. When the address matches the I/O Base Address switch positions, one of two Octal Latches, the on-board R6522 Versatile Interface Adapter (VIA), the Digital-to-Analog Converter (DAC) and/or the Data Bus Transfers are enabled. When the address matches the ROM Base Address switch positions and ROM Range Selection jumper position, the on-board program ROM is enabled along with the Data Bus Transceivers.

Bank Select and Bank Select Enable switches assign the module to one or two 65K-byte memory banks. The Bank Select Enable switch assigns the module to be active in common memory (both Bank 0 and 1) or in the bank selected by the Bank Select switch (either Bank 0 or 1).

There are eight Base Address switches; four switches assign the on-board ROM base address to a 4K-byte boundary and five assign the I/O base address to a page ( 256 bytes) within the ROM base address.

The ROM Range Select jumper indicates that no ROM, a 4 K byte ROM or an 8K-byte ROM, is installed on-board.

An 8K-byte ROM containing the PROM Programmer computer program instructions is installed on the module. One-half of the ROM contains programming functions, memory mapped at \$7100-\$7FFF, which operate in conjunction with the AIM 65 Monitor firmware. The other half of the ROM is memory mapped at \$D100-\$DFFF and contains programming functions compatible with the AIM 65/40 V/O and Monitor ROMs. A jumper selects which 4K-bytes (upper or lower), or if the entire 8 K -bytes, of the ROM socket are to be addressed.

The R6522 VIA transfers 8 -bit data between the RM 65 data bus and the PROM data lines and controls programming voltage levels. During PROM programming, the VIA transfers data from the Data Transceivers for writing into the PROM and during a PROM read, verify or check function, the VIA reads data from the PROM. During PROM programming, the VIA issues control signals to the Power Multiplexer, the Misplaced PROM Detector, and the Vpp Rise/Fall Time Controller.

The Programmable Voltage Regulator, consisting of the 8 -bit DAC, a Vpp Rise/Fall Time Controller, a DC/DC Converter and an Analog Buffer, generates the Vpp programming voltage. The DAC outputs a voltage proportional to Vpp for the selected PROM type as controlled by 8 -bit data received from the RM 65 data bus. The DAC output voltage is amplified to the full Vpp level, mixed with the rise or fall time control signal, clamped to minimum Vpp level, and output to the Analog. Buffer. The +5 to +32 V DC/DC Converter provides the high voltage used in the second stage of amplification. The Analog Buffer amplifies the Vpp current for use by the Power Multiplexer.

The Power Multiplexer selects the proper voltage level to output to the PROM during a programming or read operation as controlled by signals from the VIA and Octal Latch A. The output voltage is selected from TTL high, TTL low, Vcc and the Vpp output from the Analog Buffer. The correct voltage is selected by VIA output control lines.

The Misplaced PROM Detector determines if a 24-pin PROM has been offset by one or two pin positions when installed in the 28-pin ZIF socket on the PROM module. The detected state is input to the VIA and sampled by the programming firmware to prevent application of programming voltage to a misplaced PROM.

The two Octal Latches, A and B, transfer addresses from the Address Buffers to the PROM during PROM access operations. The levels of three programming voltages output by the Power Multiplexer to the PROM are also controlled by Octal Latch A.

## PROM Socket Module and Interface Cable

A 28-pin Zero Insertion Force (ZIF) socket is mounted on a 3 -inch $\times 3$-inch PROM socket module and connected to the RM 65 module by a 24 -inch ribbon cable. The socket module has mounting holes and may be installed in any orientation. The 28pin ZIF socket allows installation of 24-pin PROMs as well as 28-pin PROMs.

## PROM PROGRAM COMMANDS

Computer program routines to operate the PROM Programmer module are provided in an 8 K -byte ROM installed on the RM 65 module. One of the two versions of the resident firmware is jumper selectable upon installation to operate with either the AIM 65 or the AIM 65/40 I/O and Monitor firmware. Easy-to-use interactive commands perform PROM interface functions (check, program, read and verify), RAM preparation functions (fill and invert) and utility functions (e.g., command and PROM type menus, toggle verification mode, and change PROM type). Many Monitor commands are directly linked to the PROM Programmer command level for ease of operation.

PROM Programmer commands are invoked from a command enty level mode similar to the AIM 65 and 65/40 Debug Monitor operation. Initial entry and re-entry functions from the Debug Monitor provide operator initialization flexibility. The commands listed below can then be selected by single keystrokes. Subprompts displayed upon command selection request entry of information pertinent to the specific function. Once initiated, each function operates automatically until successful completion or upon termination due to a detected error.

PROM PROGRAMMER FUNCTIONS

| Command | Function |
| :---: | :--- |
| C | Check PROM |
| P | Program PROM |
| R | Read PROM |
| V | Verify PROM |
| S | Check Memory |
| A | Alter Memory |
| I | Invert Memory |
| $?$ | Display Menu |
| E | Erase EEROM |
| N | Change PROM Type |
| T | Toggle Verify Mode |
| X | Exit |
| L | Load with Offset |
| D | Dump with Offset |

The RM 65 Floppy Disk Controller (FDC) Module and DOS 1.0 functions may also be used in conjunction with the PROM Programmer to simplify file handling during PROM programming or read operations.


PROM Socket Pin Assignment


RM 65 Bus Pin Assignments

|  | Bottom (Solder Side) |  | Top (Component Side) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Signal Mnemonic | Signal Name | Pin | Pin | Signal Mnemonic | Signal Name |
| GND | Ground | 1a | 1 c | $+5 \mathrm{~V}$ | $+5 \mathrm{Vdc}$ |
| BADR/ | Buffered Bank Address | 2a | 2 c | 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 |
| BA10/ | Buffered Address Bit 10 | 6a | 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 | 11c | BA1/ | Buffered Address Bit 1 |
| BAO/ | Buffered Address Bit 0 | 12a | 12c | B $\square_{1}$ | *Buffered Phase 1 Clock |
| GND | Ground | 13a. | 13 c | BSYNC | *Buffered Sync |
| BSO | *Buffered Set Overflow | 14a | 14c | BDRQ1/ | *Buffered DMA Request 1 |
| BRDY | *Buffered Ready | 15a | 15 c | GND | Ground |
|  | *User Spare 1 | 16a | 16c | -12V/-V | *-12 Vdc/-V |
| +12V/+V | *+12 Vdc | 17a | 17c |  | *User Spare 2 |
| GND | Ground | 18a | 18c | 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" | 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 |
| B $\mathbf{D}^{1}$ | Buffered Phase 2 "Not" Clock | 25a | 25c | GND | Ground |
| Bф2 | *Buffered Phase 2 Clock | 26a | 26c | BRES/ | Buffered Reset |
| BD71 | Buffered Data Bit 7 | 27a | 27 c | 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 | 31 c | BDO/ | Buffered Data Bit 0 |
| +5V | +5 Vdc | 32a | 32c | GND | Ground |

## SPECIFICATIONS

| Characteristics | Values |
| :---: | :---: |
| Dimensions <br> PROM Programmer Module Width <br> Length <br> Height ${ }^{(1)}$ <br> Weight ${ }^{(3)}$ <br> PROM Socket Module Length Height ${ }^{(2)}$ Weight (with cable) ${ }^{(3)}$ PROM Programmer Cable Length | $\begin{aligned} & 100 \mathrm{~mm}(3.94 \mathrm{in} .) \\ & 167 \mathrm{~mm}(6.58 \mathrm{in} .) \\ & 14 \mathrm{~mm}(0.56 \mathrm{in} .) \\ & 184 \mathrm{~g} \quad(6.5 \mathrm{oz} .) \\ & 76 \mathrm{~mm}(3.0 \mathrm{in} .) \\ & 35 \mathrm{~mm}(1.38 \mathrm{in.}) \\ & 99 \mathrm{~g} \quad(3.5 \mathrm{oz} .) \\ & 610 \mathrm{~mm}(24 \mathrm{in} .) \end{aligned}$ |
| Environment Operating Temperature Storage Temperature Relative Humidity | $\begin{aligned} & 0^{\circ} \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 | $+5 \mathrm{~V} \pm 5 \%$ at 1.1 A typical <br> 2.0 A maximum (average) <br> 2.9 A maximum (peak) |
| Connectors/Sockets RM 65 Bus Connector (P1) Socket Module Cable Connector (J1) PROM Socket | 64-pin plug per DIN 41612 (Rows a and b with c not installed) 40-pin plug ( 0.100 in . centers) per DIN 41612, mates with 3417-7040 (3M) or equivalent 28-pin, 213R27-010 or equivalent |

Notes:

1. Height value includes the maximum values for component height above the board surface ( 0.4 in .), printed circuit board thickness ( 0.062 in.), and pin extension through the bottom of the module ( 0.1 in .).
2. Height value includes height of Zero Insertion Force Socket lever and cable connector plug thickness.
3. Total weight of PROM Programmer Module (including PROM Programmer Cable with attached PROM Socket Module) 284 g ( 10 oz .).



RM65-2901E PROM Programmer Module

## RM65-3108E RM 65 8K STATIC RAM MODULE

## RM 65 MICROCOMPUTER MODULES

The RM65-3108E 8K Static RAM Module is one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Module products are 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.

RM 65 module products use a motherboard interconnect concept and accept 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 selection of card cages provides packaging flexibility. RM 65 products may also be used with Rockwell AIM 65 and AIM 65/40 Microcomputers for product development and for a broad variety of portable or desktop microcomputer applications.

## PRODUCT OVERVIEW

The RM65-3108E 8K Static RAM Module contains 8192 8-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.

## FEATURES

- Compact size-about $4^{\prime \prime} \times 61 / 4^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Pin and socket bus connectors
- RM 65 Bus compatible
- Buffered address, data and control lines
- Two separately addressable 4 K byte sections
- 16 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.

ORDERING INFORMATION

| Part No. | Description |
| :--- | :--- |
| RM65-3108E | 8K Static RAM Module <br> RM65-3108NE <br> 8K Static RAM Module (without RAM <br> devices installed) |
| Order No. | Description |
| 805 | 8K Static RAM Module User's Manual <br> (included with RM65-3108E and <br> RM65-3108NE) |



RM65-3108E 8K Static RAM Module

## FUNCTIONAL DESCRIPTION

8K bytes of static 2114 RAM are divided into two separately. addressable 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 4K RAM Section (1 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 Control circuit, the Base Address Decoders, and the PROM/ ROM size jumpers as well as address lines A11 and A'10 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.


| RM 65 Bus Pin Assignments |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bottom (Solder Side) |  |  |  | Top (Component Side) |  |  |  |
| Pin | Signal Mnemonic | Signal Name | Input/ Output | Pin | Signal Mnemonic | Signal Name | Input/ Output |
| 1 a | GND | Ground |  | 15 | $+5 \mathrm{~V}$ | +5 Vdc |  |
| 2 a | BADR | Buffered Bank Address | 1 | 2 c | BA15/ | Buffered Address Bit 15 | 1 |
| 3 a | GND | Ground |  | 3c | BA14/ | Buffered Address Bit 14 | 1 |
| 4a | BA13/ | Buffered Address Bit 13 | 1 | 4 c | BA12/ | Buffered Address Bit 12 | 1 |
| 5a | BA11/ | Buffered Address Bit 11 | 1 | 5 c | GND | Ground |  |
| 6 a | BA10/ | Buffered Address Bit 10 | 1 | 6 c | BA9/ | Buffered Address Bit 9 | 1 |
| 7a | BA8/ | Buffered Address Bit 8 | 1 | 7 c | BA7/ | Buffered Address Bit 7 | 1 |
| 8 a | GND | Ground |  | 8 c | BA6/ | Buffered Address Bit 6 | 1 |
| 9 a | BA5/ | Buffered Address Bit 5 | 1 | 9 c | BA4/ | Buffered Address Bit 4 | 1 |
| 10a | BA3/ | Buffered Address Bit 3 | 1 | 10c | GND | Ground |  |
| 11a | BA2/ | Buffered Address Bit 2 | 1 | 119 | BA1/ | Buffered Address Bit 1 | 1 |
| 12a | BAO/ | Buffered Address Bit 0 | 1 | 12c | B ${ }^{\text {d }} 1$ | *Buffered Phase 1 Clock |  |
| 13a | GND | Ground |  | 13c | BSYNC | *Buffered Sync |  |
| 14a | BSO | *Buffered Set Overflow |  | 14c | BDRQ1/ | *Buffered DMA Request 1 |  |
| 15a | BRDY | *Buffered Ready |  | 15c | GND | Ground |  |
| 16a |  | *User Spare 1 |  | 16c | -12V/-V | *-12 Vdc/-V |  |
| 17a | +12V/ +V | *+12 Vdc/+V |  | 17c |  | *User Spare 2 |  |
| 18a | GND | Ground Line |  | 18c | BFLT/ | *Buffered Bus Float |  |
| 19a | BDMT/ | *Buffered DMA Terminate |  | 19c | вфо | *Buffered External Phase 0 Clock |  |
| 20a |  | *User Spare 3 |  | 20c | GND | ${ }^{*}$ Ground |  |
| 21a | $\mathrm{BR} / \overline{\mathrm{W}} /$ | Buffered Read/Write "Not" | 1 | 21c | BDRQ2/ | *Buffered DMA Request 2 |  |
| 22a |  | *System Spare |  | 22c | BR/W | Buffered Read/Write | 1 |
| 23a | GND | Ground |  | 23c | BACT/ | Buffered Bus Active | 0 |
| 24a | BIRQ/ | *Buffered Interrupt Request |  | 24 c | BNMI/ | *Buffered Non-Maskable Interrupt |  |
| 25a | B $\chi^{2 /}$ | Buffered Phase 2 "Not" Clock | 1 | 25c | GND | Ground |  |
| 26a | B ${ }^{\text {2 }}$ | *Buffered Phase 2 Clock |  | 26c | BRES/ | *Buffered Reset |  |
| 27a | BD7/ | Buffered Data Bit 7 | 1/0 | 27 c | BD6/ | Buffered Data Bit 6 | 1/0 |
| 28a | GND | Ground |  | 28c | BD5/ | Buffered Data Bit 5 | $1 / 0$ |
| 29a | BD4/ | Buffered Data Bit 4 | 1/0 | 29c | BD3/ | Buffered Data Bit 3 | /10 |
| 30a | BD2/ | Buffered Data Bit 2 | 1/0 | 30c | GND | Ground |  |
| 31a | BD1/ | Buffered Data Bit 1 | 1/0 | 31c | BDO/ | Buffered Data Bit 0 | 1/0 |
| 32a | +5V | +5 Vdc |  | 32c | GND | Ground |  |



## Module Dimensions

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions (See Notes) <br> Width <br> Length <br> Height | $\begin{aligned} & 3.9 \mathrm{in} .(100 \mathrm{~mm}) \\ & 6.3 \mathrm{in} .(160 \mathrm{~mm}) \\ & 0.56 \mathrm{in} .(14 \mathrm{~mm}) \end{aligned}$ |
| Weight | $5.3 \mathrm{oz}.(145 \mathrm{~g})$ |
| Environment <br> 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} \end{aligned}$ <br> $0 \%$ to $85 \%$ (Without condensation) |
| Power Requirements | $\begin{array}{r} +5 \mathrm{Vdc} \pm 5 \% @ 1.0 \mathrm{~A}(5.0 \mathrm{~W}) \text {-Typical } \\ \text { 1.9A }(9.5 \mathrm{~W}) \text {-Maximum } \end{array}$ |
| Access Time | 450 ns -Maximum |
| RM 65 Bus Interface | 64-pin plug ( 0.100 in. centers) per DIN 41612 (Row b not installed) |

Notes:

1. 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. Length does not include the added extension due to the module ejector.
3. Dimensions conform to DIN 41612.

## RM65-3132E RM 65 32K DYNAMIC RAM MODULE

## RM 65 MICROCOMPUTER MODULES

The RM65-3132E 32K Dynamic RAM Module is one of the hardware options available for the RM 65 Microcomputer Module Family.

RM 65 Microcomputer Module products are 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.

RM 65 module products use a motherboard interconnect concept and accept 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 AIM 65 and AIM 65/40 Microcomputers 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 65K 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 65K bank. The independent addressing of blocks provide flexibility 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 completely transparent to the RM 65 Bus, thus providing low power performance at no loss of bus speed.

## FEATURES

- Compact size-about $4^{\prime \prime} \times 61 / 4^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Pin and socket bus connection
- RM 65 bus compatible
- Buffered data, address, and control lines
- Internal Refresh controller is completely transparent to the RM 65 bus
- On-board switch allows write protection
- Base Address Header allows each 4K 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

| Part No. | Description |
| :--- | :--- |
| RM65-3132E | 32K Dynamic RAM Module <br> RM65-3132NE <br> 32K Dynamic RAM Module (without RAM <br> devices installed) |
| Order No. | Description |
| 808 | 32K Dynamic RAM Module User's Manual <br> (included with RM65-3132E and <br> RM65-3132NE) |



RM65-3132E 32K Dynamic RAM Module

## 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 65K memory bank or dis-
abled. 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.


| RM 65 Bus Pin Assignments |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| Pin | Signal Mnemonic | Signal Name | Pin | Signal Mnemonic | Signal Name |
| 1a | GND | Ground | 1 c | +5V | +5 Vdc |
| 2a | BADR/ | Buffered Bank Address | 2 c | BA15/ | Buffered Address Bit 15 |
| 3 a | GND | Ground | 3 c | BA14/ | Buffered Address Bit 14 |
| 4 a | BA13/ | Buffered Address Bit 13 | 4 c | BA12/ | Buffered Address Bit 12 |
| 5 a | BA11/ | Buffered Address Bit 11 | 5 c | GND | Ground |
| 6 a | BA10/ | Buffered Address Bit 10 | 6 c | BA9/ | Buffered Address Bit 9 |
| 7 a | BA8/ | Buffered Address Bit 8 | 7 c | BA7/ | Buffered Address Bit 7 |
| 8 a | GND | Ground | 8 c | BA6/ | Buffered Address Bit 6 |
| 9 a | BA5/ | Buffered Address Bit 5 | 9c | BA4/ | Buffered Address Bit 4 |
| 10a | BA3/ | Buffered Address Bit 3 | 10c | GND | Ground |
| 11a | BA2/ | Buffered Address Bit 2 | 11c | BA1/ | Buffered Address Bit 1 |
| 12a | BAO/ | Buffered Address Bit 0 | 12c | B ${ }_{1} 1$ | *Buffered Phase 1 Clock |
| 13a | GND | Ground | 13c | BSYNC | *Buffered Sync |
| 14a | BSO | *Buffered Set Overflow | 14 c | BDRQ1/ | *Buffered DMA Request 1 |
| 15a | BRDY | *Buffered Ready | 15c | GND | Ground |
| 16a |  | *User Spare 1 | 16c | -12V/-V | *-12 Vdc/-V |
| 17a | $+12 \mathrm{~V} /+\mathrm{V}$ | +12 Vdc/+V | 17 c |  | *User Spare 2 |
| 18a | GND | Ground Line | 18c | BFLT/ | *Buffered Bus Float |
| 19a | BDMT/ | *Buffered DMA Terminate | 190 | Bф0 | *Buffered External Phase 0 Clock |
| 20a |  | *User Spare 3 | 20c | GND | Ground |
| 21a | $\mathrm{BR} / \overline{\mathrm{W}} /$ | Buffered Read/Write "Not" | 21c | BDRQ2/ | *Buffered DMA Request 2 |
| 22a |  | *System Spare | 22 c | BR/W | Buffered Read/Write |
| 23a | GND | Ground | 23 c | BACT/ | Buffered Bus Active |
| 24a | BIRQ/ | *Buffered Interrupt Request | 24 c | BNM// | *Buffered Non-Maskable Interrupt |
| 25a | B $¢ 2 /$ | Buffered Phase 2 "Not" Clock | 25 c | GND | Ground |
| 26a | B $\quad 2$ | *Buffered Phase 2 Clock | 26c | BRES/ | *Buffered Reset |
| 27a | BD7/ | Buffered Data Bit 7 | 27 c | BD6/ | Buffered Data Bit 6 |
| 28a | GND | Ground | 28c | BD5/ | Buffered Data Bit 5 |
| 29a | BD4/ | Buffered Data Bit 4 | 29c | BD3/ | Buffered Data Bit 3 |
| 30a | BD2/ | Buffered Data Bit 2 | 30c | GND | Ground |
| 31a | BD1/ | Buffered Data Bit 1 | 31 c | BDO/ | Buffered Data Bit 0 |
| 32a | $+5 \mathrm{~V}$ | $+5 \mathrm{Vdc}$ | 32c | GND | Ground |



## SPECIFICATIONS



## RM65-3216E RM 65 16K PROM/ROM MODULE

## RM 65 MICROCOMPUTER MODULES

The RM65-3216E 16K PROM/ROM Module is one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Module products are 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.

RM 65 module products use a motherboard interconnect concept and accept 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 AIM 65 and AIM 65/40 Microcomputers for product development and for a broad variety of portable or desktop microcomputer applications.

## FEATURES

- Compact size—about $4^{\prime \prime} \times 61 / 4^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Pin and socket bus connection
- 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
- +5 V 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.

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-3216E | 16K PROM/ROM Module |
| Order No. | Description |
| 806 | 16K PROM/ROM Module User's Manual <br> (included with RM65-3216E) |



## 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 4K 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

| 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 |
| GND | Ground |  | 1 a | 1 c | +5V | $+5 \mathrm{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 |
| BA8/ | Buffered Address Bit 8 | 1 | 7 a | 78 | BA7/ | Buffered Address Bit 7 | 1 |
| GND | Ground |  | 8 a | 8 c | BA6/ | Buffered Address Bit 6 | 1 |
| BA5/ | Buffered Address Bit 5 | 1 | 9 a | 9 c | BA4/ | Buffered Address Bit 4 | 1 |
| BA3/ | Buffered Address Bit 3 | 1 | 10a | 10c | GND | Ground |  |
| BA2/ | Buffered Address Bit 2 | 1 | 11a | 11c | BA1/ | Buffered Address Bit 1 | 1 |
| BAO/ | Buffered Address Bit 0 | 1 | 12a | 12 c | B ${ }_{1} 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 | -12V/-V | *-12 Vdc/-V |  |
| +12V/+V | *+12 Vdc/ / V ${ }^{\text {Ground }}$ |  | 17a | 17c |  | * User Spare 2 |  |
| GND | Ground Line |  | 18a | 18c | BFLT/ | *Buffered Bus Float |  |
| BDMT/ | *Buffered DMA Terminate |  | 19a | 190 | Bф0 | *Buffered External Phase 0 Clock |  |
|  | * User Spare 3 |  | 20a | 20c | GND | Ground |  |
| $B R / \bar{W} /$ | *Buffered Read/Write "Not" <br> *System Spare | 1 | 21a | 21c 22 c | BDRQ2/ BR/W | *Buffered DMA Request 2 Buffered Read/Write |  |
| GND | Ground |  | 23a | 23 c | BACT/ | Buffered Bus Active | 0 |
| BIRQ/ | *Buffered Interrupt Request |  | 24a | 24c | BNMI/ | *Buffered Non-Maskable Interrupt |  |
| Bø2/ | *Buffered Phase 2 "Not" Clock |  | 25a | 25c | GND | Ground |  |
| Bø2 | *Buffered Phase 2 Clock |  | 26a | 26c | BRES/ | *Buffered Reset |  |
| BD7/ | Buffered Data Bit 7 | 0 | 27a | 27 c | BD6/ | Buffered Data Bit 6 | 0 |
| GND | Ground |  | 28a | 28c | BD5/ | Buffered Data Bit 5 | 0 |
| BD4/ | Buffered Data Bit 4. | 0 | 29a | 290 | BD3/ | Buffered Data Bit 3 | 0 |
| BD2/ | Buffered Data Bit 2 | 0 | 30a | 30c | GND | Ground |  |
| BD1/ | Buffered Data Bit 1 <br> Not Connected (See Note) | 0 | $\begin{array}{r} \text { 31a } \\ \mathrm{Za} \end{array}$ | 31 c Zc | BDO/ | Buffered Data Bit 0 <br> Not Connected (See Note) | 0 |
| Note: <br> *Not used on the 16K PROM/ROM module. |  |  |  |  |  |  |  |

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions (1, 2, 3) Width Length Height | 3.9 in. ( 100 mm ) 6.3 in . $(160 \mathrm{~mm}$ ) 0.56 in . $(14 \mathrm{~mm})$ |
| Weight | 5.0 oz. (140 g) |
| Environment <br> 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 w/o PROM/ROM Devices | $\begin{array}{r} +5 \mathrm{Vdc} \pm 5 \% 0.17 \mathrm{~A}(0.85 \mathrm{~W})-\text { Typical } \\ 0.27 \mathrm{~A}(1.35 \mathrm{~W})-\text { Maximum } \end{array}$ |
| Access Time | 450 nanoseconds (max) |
| RM 65 Bus Interface Edge Connector Version Eurocard Version | 72-pin edge connector ( 0.100 in. centers) <br> 64 -pin plug ( 0.100 in. centers) per DIN 41612 (Row b not installed) |
| Notes: <br> 1. Height includes the maximum values thickness ( 0.062 in.), and pin extensio <br> 2. Length does not include the added ext <br> 3. Dimensions conform to DIN 41612. | ht above the board surface ( 0.4 in . for populated modules), printed circuit board of the module ( 0.1 in .). <br> odule ejector. |



Module Dimensions

## RM65-3264NE UNIVERSAL MEMORY MODULE

## RM 65 MICROCOMPUTER MODULES

The RM65-3264NE Universal Memory Module ( $16 \mathrm{~K}-128 \mathrm{~K}$ ) is one of the hardware options available for the RM 65 Microcomputer Module Family.

RM 65 Microcomputer Modules are designed for OEM and end user microcomputer applications when state-of-the-art performance, compact size, modular design, and low cost are required. 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.

RM 65 Modules plug into a motherboard designed to accept any card in any slot. The 64 -line RM 65 Bus accommodates memory addressing up to 128 K bytes, provides high immunity to electrical noise, and includes growth provisions for user functions. A selection of card cages permit packaging flexibility. RM 65 products may also be used with Rockwell AIM 65 or AIM 65/40 Microcomputers for product development and for portable or desktop microcomputer applications.


RM65-3264NE Universal Memory Module

## FEATURES

- In the high speed mode, supports Rockwell Design Center 4 MHz RAM operations
- In the universal memory mode, supports $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}$, and 16 K byte-wide memory devices
- On-board header and shunt configure the module into a 2 K to 128 K memory space
- Each half (four device sockets) independently configurable in the universal memory mode
- On-board memory bank select switches assign each half of the module to either one or both of two 64K memory banks
- On-board ROM select switches serve as write-protect switches for each half of the memory in universal memory mode
- Rockwell RM 65 Bus compatible
- Compact size-100 mm $\times 167 \mathrm{~mm}$ (approximately $4 \mathrm{in} . \times$ 6.3 in.)
- Operates from a single +5 V power source
- Fully assembled (except for user-supplied memory devices), tested and warranted
- Supports 16 K of 2 K devices, 32 K of 4 K devices, 64 K of 8 K devices, and 128 K of 16 K devices in universal memory mode
- Supports 64 K of 8 K devices in high speed mode (refer to Devices Supported for part numbers)


## OVERVIEW

Two major capabilities are provided in the Universal Memory Module: the flexibility of using $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}$, or 16 K memory devices on the module, and use of the memory in either a highspeed mode or a universal memory mode. Typical data-transfer rates are up to 4 MHz (to support the Rockwell Design Center (RDC) System) in the high speed mode and $1-$ to $2-\mathrm{MHz}$ in the universal memory mode. Rates are dependent both on memory devices used and system configuration. Memory devices that can be used with the module are RAM's, ROM's, EPROM's, and EEPROM's.

## ORDERING INFORMATION

| Part No. | Description |
| :---: | :---: |
| RM65-3264NE | Universal Memory Module |

## FUNCTIONAL DESCRIPTION

Data Bus Transceivers buffer and invert data signals BDO/ through BD7/. Data signals from the RM 65 Bus pass through the bidirectional transceivers into the module during a write operation and out from the module through the transceivers to the RM 65 Bus during a read operation. Data in is inverted for use in the module, and data out (from the module) is inverted for use on the RM 65 Bus. Transfers occur when any of the chipselect signals and the $\varnothing 2$ clock pulse are in the active states concurrently. Direction of data flow either into or out of the module is controlled by the $R / \bar{W}$ signal state.
Address and Control Buffer logic consists of inverters that buffer address signals BAO/ through BA13/ and the read/write signal $\mathrm{BR} / \mathrm{W} /$. These signals are converted to positive signals BAO through BA13 and BR/W for use within the module.

Bank Address Select logic is controlled by the state of the BADR/ signal, which functions as a seventeenth address bit. The state of the BADR/ signal indicates which of the two 65 K memory banks is addressed. In the high speed memory mode, the module can be configured to operate in either one or both 65 K memory banks. In the universal memory mode, each half of the memory is configurable to either one or both 65 K memory banks.
Module Active logic is enabled when any chip-select signal is enabled. Thus, when any memory device in either Memory A or Memory B is enabled by a chip-select signal, the BACT/, or Module Active, signal is in the active state.

Address signals BA13/, BA14/, and BA15/, in conjunction with BO, are decoded by a $3: 8$ decoder to enable one of eight possible outputs. Each output signal in a low state indicates an 8 K address boundary signal. Thus, the 8 K address boundaries are $\$ 0000, \$ 2000, \$ 4000, \ldots \$ 2000$. Each of these signals is used as a memory chip-select signal during operation of the memory in the high-speed mode and as a $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}$, and 16 K decoder enabling signal in the universal memory mode.
By connecting a pin on the Address Header to a specific output (chip select) pin from the 8K Decoder, that 8K address boundary signal is connected to one specific memory device (in one of the eight memory device sockets) only in high speed mode.

The module can be used either as a high speed memory or as a universal memory. The removable 16 -pin 8 -position shunt is placed either in the High Speed Option Shunt socket for high speed memory operation, or in the Universal Memory Option Shunt socket for universal memory operation. In the high speed mode, Memory A Decoder and Memory B Decoder are not used, and the address (chip-select) signal from the Address Header is applied directly to the applicable Memory A or Memory $B$ devices. As a result, decoding time is saved.

Memory A consists of $2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}$, or 16 K memory devices installed in the four sockets assigned as Memory A. Memory B also consists of memory devices located in four sockets designated as Memory B. Thus, the capacity of Memory A or Memory B is dependent on the capacity of the memory devices installed in each socket. Each of the two groups of four sockets can be configured with jumpers to accept one of the four types (2K, 4K, 8 K , or 16 K ) of memory devices. Each memory device in the memory sockets in Memory A or Memory B must have the same capacity.

Device Select A consists of jumpers E3, E4, and E7 through E 10 determine the particular type memory device $(2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~K}$, or 16 K ) installed in the Memory A sockets. Similarly, Device Select B jumpers E5, E6, and E11 through E14 determine memory device types in Memory B.

Memory A Decoder is a programmable array logic (PAL) device internally configured to decode a combination of input signals and generate one output (chip-select) signal. Memory Decoders $A$ and B are used only when the module is being operated in the universal memory mode. Both decoders operate in the same manner, but only one is used at a time. Thus, when Memory A is addressed, Memory Decoder A is used, and Memory Decoder B when Memory B is addressed.

## DEVICES SUPPORTED

In the universal memory mode, the following is a partial list of devices supported:

16 K of the following 2 K devices:

| R2316 | ROM-Rockwell |
| :--- | :--- |
| 2716 | EPROM-Intel |
| 2516 | EPROM-TI |
| 2016 | RAM-Toshiba |
| 5516 | RAM-Toshiba |
| 6116 | RAM-Hitachi |
| R5213/2816 | EEPROM-Rockwell |
| X2816 | EEROM-XICOR |

32 K of the following 4 K devices:

| R2332 | ROM-Rockwell |
| :--- | :--- |
| 2732 A | ROM-Intel |
| 2532 (350ns) | ROM-TI |

64 K of the following 8 K devices:

| R2364A, R2364B | ROM-Rockwell |
| :--- | :---: |
| 68 A764 | EPROM-Motorola |
| 68766 | EPROM-Motorola |
| 2764 | EPROM-Intel |
| 5564 | RAM-Toshiba |
| 6264 | RAM-Hitachi |
| 8464 | RAM-Fujitsu |

128K of the following 16 K devices:

| R23128 |  |
| :--- | :--- |
| 27128 | ROM-Rockwell |
| EPROM-Intel |  |

In the high speed mode, the following is a partial list of devices supported:

64 K of the following 8 K devices:

| R2364A, R2364B | ROM-Rockwell |
| :--- | :--- |
| 684764 | EPROM-Motorola |
| 68766 | EPROM-Motorola |
| 2764 | EPROM-Intel |
| 5564 | RAM-Toshiba |
| 6264 | RAM-Hitachi |
| 8464 | RAM-Fujitsu |

## RM 65 Bus Pin Assignments

| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | Pin | Signal Mnemonic | Signal Name |
| 1 a | GND | Ground | 1 c | +5V | $+5 \mathrm{Vdc}$ |
| 2a | BADR/ | Buffered Bank Address | 2 c | BA15/ | Buffered Address Bit 15 |
| 3 a | GND | Ground | 3 c | BA14/ | Buffered Address Bit 14 |
| 4 a | BA13/ | Buffered Address Bit 13 | 4 c | BA12/ | Buffered Address Bit 12 |
| 5 a | BA11/ | Buffered Address Bit 11 | 5 c | GND | Ground |
| 6 a | BA10/ | Buffered Address Bit 10 | 6 c | BA9/ | Buffered Address Bit 9 |
| 7 a | BAB/ | Buffered Address Bit 8 | 7 c | BA7/ | Buffered Address Bit 7 |
| 8 a | GND | Ground | 8 c | BA6/ | Buffered Address Bit 6 |
| 9 a | BA5/ | Buffered Address Bit 5 | 9 c | BA4 | Buffered Address Bit 4 |
| 10a | BA3/ | Buffered Address Bit 3 | 10c | GND | Ground |
| 11a | BA2/ | Buffered Address Bit 2 | 11 c | BA1/ | Buffered Address Bit 1 |
| 12a | BAO/ | Buffered Address Bit 0 | 12 c | B $\varnothing 1$ | *Buffered Phase 1 Clock |
| 13a | GND | Ground | 13 c | BSYNC | *Buffered Sync |
| 14a | BSO | *Buffered Set Overflow | 14 c | BDRQ1/ | *Buffered DMA Request 1 |
| 15a | BRDY | *Buffered Ready | 150 | GND | Ground |
| 16a |  | * User Spare 1 | 16 c | -12V/-V | *-12 Vdc/-V |
| 17a | $+12 \mathrm{~V} /+\mathrm{V}$ | *+12 Vdc/+V | 17 c |  | * User Spare 2 |
| 18a | GND | Ground Line | 18 C | BFLT/ | *Buffered Bus Float |
| 19a | BDMT/ | *Buffered DMA Terminate | 19c | Вфо | *Buffered External Phase 0 Clock |
| 20a |  | *User Spare 3 | 20c | GND | Ground |
| 21a | $\mathrm{BR} / \overline{\mathrm{W} /}$ | Buffered Read/Write "Not" | 21c | BDRQ2/ | *Buffered DMA Request 2 |
| 22a |  | *System Spare | 22 c | BR/ $\bar{W}$ | *Buffered Read/Write |
| 23a | GND | Ground | 23 c | BACT/ | Buffered Bus Active |
| 24a | BIRQ/ | *Buffered Interrupt Request | 24 c | BNMI/ | *Buffered Non-Maskable Interrupt |
| 25a | Bø21 | Buffered Phase 2 "Not" Clock, | 25 c | GND | Ground |
| 26a | Bø2 | Buffered Phase 2 Clock | 26c | BRES/ | *Buffered Reset |
| 27a | BD7/ | Buffered Data Bit 7 | 27 c | BD6/ | Buffered Data Bit 6 |
| 28a | GND | Ground | 28 c | BD5/ | Buffered Data Bit 5 |
| 29a | BD4/ | Buffered Data Bit 4 | 290 | BD3/ | Buffered Data Bit 3 |
| 30a | BD2/ | Buffered Data Bit 2 | 30c | GND | Ground |
| 31a | BD1/ | Buffered Data Bit 1 | 31 c | BDO/ | Buffered Data Bit 0 |
| 32a | +5V | +5 Vdc | 32c | GND | Ground |



Universal Memory Module Block Diagram

SPECIFICATIONS



# RM65-5101E <br> RM 65 FLOPPY DISK CONTROLLER (FDC) MODULE 

## RM 65 MICROCOMPUTER MODULES

The RM65-5101E Floppy Disk Controller Module is one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Module products are 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, PL65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.
RM 65 modules use a motherboard interconnect concept and accept 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 AIM 65 and AIM 65/40 Microcomputers 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
 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.


RM65-5101E Floppy Disk Controller (FDC) Module

## FEATURES

- Compact size-about $4^{\prime \prime} \times 61 / 4^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Pin and socket bus connection
- RM 65 Bus compatible
- Buffered address, data and control lines
- Supports single or double sided, standard or mini-floppy disk drive's
- 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 $/ / O$ for $8^{\prime \prime}$ or $51 / 4^{\prime \prime}$ drive interface
- Fully assembled, tested and warranted


## ORDERING INFORMATION

| Part No. | Description |
| :---: | :---: |
| RM65-5101E | Floppy Disk Controller (FDC) Module with on-board ROM* |
| RM65-5101NE | Floppy Disk Controiler (FDC) Module without on-board ROM |
| $\begin{aligned} & \text { A65-090 } \\ & \text { A65/40-7090 } \end{aligned}$ | AIM 65 DOS 1.0 ROM** AIM 65/40 DOS 1.0 ROM $^{* *}$ |
| Order No. | Description |
| 802 | FDC Module User's Manual (included with RM65-5101E, RM65-5101NE, A65-090 and A65/40-7090) |
| *ROM contains FDC module primitive subroutines only. <br> **ROM contains FDC module primitive subroutines and operator selectable file management functions integrated with host computer V/O functions. |  |

## 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 I/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 $514^{\prime \prime}$ or $8^{\prime \prime}$, single or double sided disk drives, with choice of single or double den-
sity, 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 I/O connector and FDC circuitry for either $51 / 4^{\prime \prime}$ mini-floppy or $8^{\prime \prime}$ standard floppy disk formats. The 50 -pin I/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 \frac{1}{4} 4^{\prime \prime}$ mini-floppy drives while a 50 -pin cable and mating connector is needed to connect to the $8^{\prime \prime}$ 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 primitive subroutines to support operations with up to four disk drives (single or double side, single or double density), including:

| Format a Disk | Read or Write Multiple |
| :--- | :---: |
| Read or Write a Sector | Sectors |
| Seek or Verify Seek of | Read or Write a Track |
| a Track | Turn Motors On or Off |
| Restore the Head | Select or De-select any Drive |

A user-provided program may call these subroutines to build an application dependent file-handling system.

## OPTIONAL DISK OPERATING SYSTEM (DOS) FIRMWARE

Two optional ROMs are available that integrate the FDC primitive subroutines with operator selectable file management functions for operation on the AIM 65 and AIM 65/40 microcomputers. Either of these ROMs may be installed into the PROM/ROM socket on the FDC module to provide a firmware based Disk Operating System (DOS).

This version 1.0 ROM-based system offers the same convenience as the other AIM 65 and AIM 65/40 firmware in that it is immediately available for use through the Debug Monitor/Text Editor upon power turn-on. Mass storage operation may, therefore, proceed without waiting for loading of the DOS into RAM.

Text and program source code may be written to, and read from, disk with the Editor LIST (L) and READ (R) commands, respectively. Similarly, binary data and program object code may be written to, and loaded from, disk using the Monitor DUMP (D) and LOAD (L) commands, respectively. AIM 65 and AIM 65/40

Assembler and PL/65 files, both source and object code, are therefore supported. AIM 65 and AIM 65/40 BASIC programs may also be saved on, and loaded from disk.

The primary DOS commands are:

Format a Disk
List the Directory
List a File

Delete a File Name Recover a File Name
Backup a Disk

Files are created automatically upon writing a file to disk. A file name (up to 10 characters in length) and the disk drive number (from 1 to 8) are operator entered in response to system prompts. (Double-sided drives are treated as two separate sides.)

The disk format function initializes a disk depending upon size, density and drive number. $51 / 4^{\prime \prime}$ and $8^{\prime \prime}$ disks are initialized to 35 and 77 tracks, respectively, however these values are useralterable.

The contents of a file may be listed to another peripheral, including a file on another disk drive to allow copying of a file. All the active files on a disk may be copied to another disk using the backup function.

A file may be deleted (if active) to prevent it from being accessed or recovered (if deleted) to allow it to be accessed.


9

Floppy Disk Controller Module Block Diagram

RM 65 Bus Pin Assignments

| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | Pin | Signal Mnemonic | Signal Name |
| 12 | GND | Ground | 1 c | +5V | +5 Vdc |
| 2 a | BADR/ | Buffered Bank Address | 2 c | BA15/ | Buffered Address Bit 15 |
| 3 a | GND | Ground | 3 c | BA14/ | Buffered Address Bit 14 |
| 4 a | BA13/ | Buffered Address Bit 13 | 4 c | BA12 | Buffered Address Bit 12 |
| 5 a | BA11/ | Buffered Address Bit 11 | 5 c | GND | Ground |
| 6 a | BA10/ | Buffered Address Bit 10 | 6 c | BA9/ | Buffered Address Bit 9 |
| 7 a | BA8/ | Buffered Address Bit 8 | 7c | BA7/ | Buffered Address Bit 7 |
| 8 a | GND | Ground | 8 C | BA6/ | Buffered Address Bit 6 |
| 9 a | BA5/ | Buffered Address Bit 5 | 9 c | BA4/ | Buffered Address Bit 4 |
| 10a | ВАЗ/ | Buffered Address Bit 3 | 10c | GND | Ground |
| 11a | BA2/ | Buffered Address Bit 2 | 11c | BA1/ | Buffered Address Bit 1 |
| 12a | BAO/ | Buffered Address Bit 0 | 12c | Bめ1 | *Buffered Phase 1 Clock |
| 13a | GND | Ground | 13 c | BSYNC | *Buffered Sync |
| 14a | BSO | *Buffered Set Overflow | 14 c | BDRQ1/ | Buffered DMA Request 1 |
| 15a | BRDY | Buffered Ready | 15 c | GND | Ground |
| 16a |  | *User Spare 1 | 16 c | -12V/-V | *-12 Vdc/-V |
| 17a | +12V/+V | +12 Vdc | 17 c |  | *User Spare 2 |
| 18a | GND | Ground Line | 18 C | BFLT/ | *Buffered Bus Float |
| 19 a | BDMT/ | *Buffered DMA Terminate | 198 | Bф0 | *Buffered External Phase 0 Clock |
| 20a |  | *User Spare 3 | 20c | GND | Ground |
| 21a | $\mathrm{BR} / \mathrm{W} /$ | Buffered Read/Write "Not" | 21c | BDRQ2/ | Buffered DMA Request 2 |
| 22a |  | *System Spare | 22 c | BR/W | *Buffered Read/Write ** |
| 23a | GND | Ground | 23 c | BACT/ | Buffered Bus Active |
| $24 a$ | BIRQ/ | Buffered Interrupt Request | 24 c | BNM/ | *Buffered Non-Maskable interrupt |
| 25a | B62/ | Buffered Phase 2 "Not" Clock | 25 c | GND | Ground |
| 26a | Bø2 | *Buffered Phase 2 Clock | 26 c | BRES/ | Buffered Reset |
| 27a | BD7/ | Buffered Data Bit 7 | 27c | BD6/ | Buffered Data Bit 6 |
| 28a | GND | Ground | 28 C | BD5/ | Buffered Data Bit 5 |
| 29a | BD4/ | Buffered Data Bit 4 | 29c | BD3/ | Buffered Data Bit 3 |
| 30a | BD2/ | Buffered Data Bit 2 | 30c | GND | Ground |
| 31a | BD1/ | Buffered Data Bit 1 | 31 c | BDO/ | Buffered Data Bit 0 |
| 32a | +5V | +5 Vdc | 32c | GND | Ground |
| te: | is module. |  |  |  |  |

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. |  | 4 |
| 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 Selut \#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 $/ / O$ connector.


Floppy Disk Controller Module Dimensions

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions (1, 2, 3) <br> Width <br> Length <br> Height | 3.9 in . $(100 \mathrm{~mm})$ 6.3 in . ( 160 mm ) 0.56 in . $(14 \mathrm{~mm})$ |
| Weight | 5.2 oz . (145 g) |
| Environment <br> Operating Temperature <br> Storage Temperature <br> 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 | $\begin{aligned} & +5 \mathrm{Vdc} \pm 5 \% @ 600 \mathrm{~mA} \text {-Typical } \\ & 900 \mathrm{~mA} \text {-Maximum } \\ & +12 \mathrm{Vdc} \pm 5 \% @ 60 \mathrm{~mA} \text {-Typical } \\ & 100 \mathrm{~mA} \text {-Maximum } \end{aligned}$ |
| Interfaces RM 65 Bus Interface I/O Connector | 64-pin plug ( 0.100 in . centers) per DIN 41612 (Row b not installed) <br> 50 -pin mass terminated connector ( 0.100 in . centers) Mates with I\&B/Ansley Part No. 609-5001M or equivalent |
| Notes: <br> 1. 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 .). <br> 2. Length does not include the added extension due to the module ejector. <br> 3. Dimensions conform to DIN 41612. |  |

## RM 65 MICROCOMPUTER MODULES

The RM65-5102E CRT Controller Module is one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Module products are 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.

RM 65 modules use a motherboard interconnect concept and accept 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 selection of card cages provides packaging flexibility. RM 65 products may also be used with Rockwell AIM 65 and AIM 65/ 40 Microcomputers for product development and for a broad variety of portable or desktop microcomputer applications.

## PRODUCT OVERVIEW

The CRT Controller (CRTC) Module interfaces the RM 65 to a CRT monitor or television receiver. The CRTC module outputs HSYNC, VSYNC, and raw video signals for direct connection to a CRT Monitor, and composite video for connection to a CRT monitor or to a TV receiver through an RF modulator. A socketed on-board ROM generates $5 \times 7$ characters with two descenders in a $7 \times 10$ dot matrix field to provide upper and lower case alphanumerics and special symbols. The 2 K bytes of onboard display RAM are memory-mapped.

A 2K-byte program ROM provides firmware to configure the display format for 80 columns by 25 rows or 40 columns by 16 rows, scan rate of 50 or 60 Hz , and a CRT display driver for AIM 65. There are also cursor control, screen editing, and utility routines.

## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-5102E | CRT Controller (CRTC) Module |
| Order No. | Description |
| 814 | CRT Controller (CRTC) Module User's <br> Manual (included with RM65-5102E) |

## FEATURES

- Compact size-about $4^{\prime \prime} \times 61 / 4^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- RM 65 bus compatible
- 4K Byte character generator ROM with:
-Upper and lower case alphabetics
-Special characters
-Numbers including subscripts and superscripts
-Math symbols
-Semi-graphics
- On-board ROM firmware supports:
-Scrolling
-Screen editing
-Full cursor movement control
-Full screen standard or inverse video
-Predefined formats for
80 column by 25 row ( $50 / 60 \mathrm{~Hz}$ )
72 column by 22 row ( $50 / 60 \mathrm{~Hz}$ )
40 column by 25 row ( 60 Hz )
40 column by 16 row ( 60 Hz )
-Selectable format from 1 to 80 columns by 1 to 25 rows
-NTSC ( $60 \mathrm{~Hz}, 525$ lines per frame) and European $(50 \mathrm{~Hz}$, 625 lines per frame) raster format
-CRT display driver for AIM 65
- Single 5 volt operation
- Fully assembled, tested and warranted


RM65-5102E CRT Controller (CRTC) Module

## FUNCTIONAL DESCRIPTION

The Data Transceivers invert and transfer 8 bits of parallel data between the CRTC 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 the 16 -bit parallel address lines from the RM 65 bus to the Base Address Decoders, the R2316 ROM, the CRT Controller (CRTC) device, and to the Refresh RAM device.

The Control Buffers invert and transfer the phase 2 clock 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 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 Base Address Decoder, with the Base Address Select switches, the Bank Select Control circuit, the ROM Disable Switch and the read/write and phase 2 clock signals, generates device selects for the on-board ROM, RAM, and I/O (CRTC device and Display Enable Status Buffer). The Base Address Select switches allow the module to be selected to any 4 K block. Within the selected 4 K block, the RAM is assigned to the lower 8 pages ( 2 K bytes), and the I/O to the first 256 byte page of the upper 2K bytes. When the ROM is disabled, only the RAM and I/O can be selected and the module is assigned 9 pages (2304 bytes) in memory. When the ROM is enabled, the module is assigned the full 4 K bytes, with 7 pages for ROM, in addition to the RAM and $\mathrm{I} / \mathrm{O}$.

The Controller Clock uses a crystal-controlled oscillator to derive a 6 MHz or 12 MHz reference for the shift register dot clock depending on the Dot Clock Select jumper position. With the 6 MHz clock, up to 40 characters per line can be displayed on any monitor or standard television using an RF modulator. Up to 80 characters per line can be achieved with the 12 MHz clock and a high bandwidth monitor. The dot clock is divided by seven to provide a Character Clock for the CRTC device and a load character signal for the shift register.

The Refresh RAM provides 2 K bytes of display memory, for screen densities of up to 25 lines with as many as 80 characters each. The RAM is directly mapped into the RM 65 memory map,
so the display can be updated by a block memory move or under DMA control. The Refresh RAM Multiplexer and RAM Transceiver allow the RM 65 bus and the CRTC device to both access the Refresh RAM, with the RM 65 bus having priority when any conflict occurs.

The Display Enable Status Buffer allows the RM 65 bus to monitor the active display times, so that display memory transfers can be made with no visible distortion.

The Character Generator ROM holds the fonts for the character set. These fonts are stored as 256 characters, each with 10 seven-bit rows. The four CRTC device row address lines and the eight Character Latch bits, which hold the character being refreshed, create an address for the character generator ROM. The output data of the ROM, which is seven parallel bits, represents the display pattern. The Shift Register takes this data and forms the serial video data. The Video Summer combines and buffers the serial video data with CRTC device timing signals to form a composite video output and a separate video, horizontal sync, and vertical sync.

The Program ROM contains the firmware for an intelligent CRT driver, in addition to utilities to aid in custom CRT display application software. There are six predefined screen formats, including 25 lines of 80 characters ( 50 or 60 Hz ), 22 lines of 72 characters ( 50 or 60 Hz ), 25 lines of 40 characters ( 50 Hz ), and 16 lines of 40 characters ( 60 Hz ). For other formats, any dimensions from 1 to 25 lines of from 1 to 80 characters can be defined ( 50 or 60 Hz ). Full screen inverse video and 256 display characters allow flexible display capabilities.

The intelligent display driver controls all screen updating and cursor movement for the selected screen format. The cursor can be on, off, or blinking with movements including up, down, left, right, home, and carriage return, as well as to any row and column position. There are many commands to facilitate screen editing, such as:

Insert character or line
Delete character or line
Clear to end of line
Clear to end of screen
Clear line or screen
Set or Clear special character mode
The firmware utilities are useful for special applications. There is also a display driver which replaces the AIM 65 on-board display with a CRT monitor and an AIM 65 Assembler listing reformatter which takes advantage of the longer display lines.

RM 65 CRTC Control Commands

| Hex Code | Character | Description | Hex Code | Character | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 00 | CTRL @ | * | 10 | CTRL P | Pass Through Next Character |
| 01 | CTRL A | Clear Line | 11 | CTRL Q |  |
| 02 | CTRL B | Clear to End of Line | 12 | CTRL R |  |
| 03 | CTRL C | Clear Screen | - 13 | CTRLS | Toggle Insert Character Mode |
| 04 | CTRL D | Clear to End of Screen | 14 | CTRL T | Delete One Character |
| 05 | CTRL E | Clear Screen | 15 | CTRL U | Insert One Line |
| 06 | CTRL F | Clear to End of Screen | 16 | CTRL V | Delete One Line |
| 07 | CTRL G | * | 17 | CTRL W | Display Cursor |
| 08 | CTRL H | Backspace (-) | 18 | CTRL X | Blank Cursor |
| 09 | CTRLI | Horizontal Tab $\rightarrow$ | 19 | CTRL Y | Relink AIM 65 Display |
| OA | CTRL J | Line Feed ( $\downarrow$ ) | 1A | CTRL Z | * ! ${ }^{\text {a }}$ |
| OB | CTRL K | Vertical Tab ( $\uparrow$ ) | 1 B | CTRL [ | Escape Character (ESC) (1) |
| OC | CTRL L | Form Feed (Clear Screen) | 1 C | CTRLI | Blinking Cursor |
| OD | CTRL M | Carriage Return (Home on Line) | 1D | CTRL] | Enter Normal Characters |
| OE | CTRL N | Home on Screen | 1E | CTRL $\wedge$ | Perform Self Test |
| OF | CTRL 0 | Home on Screen | 1F | CTRL - | Reverse Video |

*These characters have no effect.
(1) There are two escape sequences as follows:

Hex Code
Character Sequence

## Function

| 1B 3D YY XX | ESC $=y x$ |
| :--- | :--- |
| Move the cursor to the row $y$ and column $x$ position, with row $y$ between top ( $\$ 00$ ) and bottom |  |
| ( $\$ 19$ ), and column $x$ between leftmost $(\$ 00)$ and rightmost $(\$ 4 F)$. |  |



CRT Controller Module Block Diagram

RM 65 Bus Pin Assignments

| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | Pin | Signal Mnemonic | Signal Name |
| 1.a | GND | Ground | 1 c | +5V | +5 Vdc |
| 2 a | BADR/ | Buffered Bank Address | 2 c | BA15/ | Buffered Address Bit 15 |
| 3a | GND | Ground | 3 c | BA14/ | Buffered Address Bit 14 |
| 4 a | BA13/ | Buffered Address Bit 13 | 4 c | BA12/ | Buffered Address Bit 12 |
| 5 a | BA11/ | Buffered Address Bit 11 | 5 c | GND | Ground |
| 6 a | BA10/ | Buffered Address Bit 10 | 6c | BA9/ \% | Buffered Address Bit 9 |
| 7 a | BA8/ | Buffered Address Bit 8 | 7 c | BA7/ | Buffered Address Bit 7 |
| 8 a | GND | Ground | 8 c | BA6/ | Buffered Address Bit 6 |
| 9 a | BA5/ | Buffered Address Bit 5 | 9 c | BA4/ | Buffered Address Bit 4 |
| 10a | BA3/ | Buffered Address Bit 3 | 10c | GND | Ground |
| 11a | BA2/ | Buffered Address Bit 2 | 11c | BA1/ | Buffered Address Bit 1 |
| 12a | BAO/ | Buffered Address Bit 0 | 12 c | B61 | *Buffered Phase 1 Clock |
| 13a | GND | Ground | 130 | BSYNC | *Buffered Sync ${ }^{\text {a }}$ |
| 14a | BSO | *Buffered Set Overflow | 14c | BDRQ1/. | *Buffered DMA Request 1 |
| 15a | BRDY | *Buffered Ready | 15c | GND | Ground |
| 16a |  | * User Spare 1 | 16 c | -12V/-V | *-12 Vdc/-V |
| 17a | $+12 \mathrm{~V} /+\mathrm{V}$ | *+12 Vdc/+V | 17 c |  | * User Spare 2 |
| 18a | GND | Ground Line | 18 c | BFLT/ | *Buffered Bus Float |
| 19a | BDMT/ | *Buffered DMA Terminate | 19c | вфо | *Buffered External Phase 0 Clock |
| 20a |  | * User Spare 3 | 20c | GND | Ground |
| 21a | BR/W/ | *Buffered Read/Write "Not" | 21c | BDRQ2/ | *Buffered DMA Request 2 |
| 22a |  | *System Spare | 22 c | $\mathrm{BR} / \overline{\mathrm{W}}$ | Buffered Read/Write |
| 23a | GND | Ground | 23 c | BACT/ | Buffered Bus Active |
| 24a | BIRQ/ | *Buffered Interrupt Request- | 24c | BNM 1 | *Buffered Non-Maskable Interrupt |
| 25a | B $\chi^{2 / 1}$ | Buffered Phase 2 "Not" Clock | 25 c | GND | Ground |
| 26a | Bø2 | Buffered Phase 2 Clock | 26 c | BRES/ | Buffered Reset |
| 27a | BD7/ | Buffered Data Bit 7 | 27c | BD6/ | Buffered Data Bit 6 |
| 28a | GND | Ground | 28 c | BD5/ | Buffered Data Bit 5 |
| 29a | BD4/ | Buffered Data Bit 4 | 29 c | BD3/ | Buffered Data Bit 3 |
| 30a | BD2/ | Buffered Data Bit 2 | 30c | GND | Ground |
| 31 a | BD1/ | Buffered Data Bit 1 | 31 c | BDO/ | Buffered Data Bit 0 |
| 32a | +5V | $+5 \mathrm{Vdc}$ | 32c | GND | Ground |

Note:
*Not used on this module.


Character Set


## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions (1, 2, 3) Width Length Height | 3.9 in. ( 100 mm ) 6.3 in. $(160 \mathrm{~mm})$ $0.56 \mathrm{in} .(14 \mathrm{~mm})$ |
| Environment <br> Operating Temperature <br> 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 | $\begin{aligned} &+5 \mathrm{Vdc} \pm 5 \%, 0.94 \mathrm{~A}(4.7 \mathrm{~W}) \text {-Typical } \\ & 1.30 \mathrm{~A}(6.8 \mathrm{~W}) \text {-Maximum } \end{aligned}$ |
| Interface <br> RM 65 Bus Interface <br> I/O Connector Composite Video <br> Raw Video and Sync | 64 -pin plug ( 0.100 in. centers) per DIN 41612 (Row b not installed) <br> Mini-coax connector ( 50 ohm SMC type) <br> Mates to Sealectro Part No. 050-024-0000-220 or equivalent <br> 6 -pin connector <br> Mates to AMP No. 87159-6 or equivalent |
| Notes: <br> 1. 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 .). <br> 2. Length does not include the added extension due to the module ejector. <br> 3. Dimensions conform to DIN 41612. |  |

# RM65-5104E RM 65 DIRECT MEMORY ACCESS CONTROLLER MODULE 

## RM 65 MICROCOMPUTER MODULES

The RM65-5104E Direct Memory Access Controller (DMAC) Module is one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Modules products are designed for OEM and end user microcomputer applications when state-of-the-art performance, compact size, modular design, and low cost are required. 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.

RM 65 modules use a motherboard interconnect concept in which any card can be inserted into any slot. The 64-line RM 65 Bus permits memory addressing up to 128 K bytes, provides high immunity to electrical noise, and contains growth provisions for user functions. A selection of card cages allows packaging flexibility. RM 65 products may also be used with Rockwell AIM 65 and AIM 65/40 Microcomputers for product development and for a broad variety of portable or desk-top microcomputer applications.

## PRODUCT OVERVIEW

The RM65-5104E DMAC Module performs high speed data transfers between memory and/or VO devices connected to the RM 65 Bus. The data transfer rate when controlled by the DMAC Module hardware is typically four times faster than the data transfer rate achieved by CPU software. Thus by using the DMAC Module, substantial time is saved when transferring large blocks of data.

After a DMA transfer is initiated by the CPU module, the DMAC Module takes control of the RM 65 Bus and independently completes the data transfers. Operation of the DMAC Module can be controlled by an AIM 65, an AIM 65/40 SBC Module, or any other CPU module connected to the RM 65 Bus. During the DMA data transfers, the RM 65 SBC, AIM 65, or AIM 65/40 can continue operations on its internal buses.

The DMAC Module is especially effective in the rapid transfer of data between either $51 / 4$-inch or 8 -inch floppy disks controlled by either the FDC Module (RM65-5101E) or the RM 65 IEEE488 Module (RM65-7102E) and other memory or I/O modules connected to the RM 65 Bus.

## FEATURES

- Rockwell RM 65 Bus compatible
- Compact size-100 $\mathrm{mm} \times 160 \mathrm{~mm}$ (approximately 4 in . $\times$ 6.25 in .)
- Executes memory-to-memory, I/O-to-I/O, memory-to-I/O, and I/O-to-memory transfers
- DMA data transfers can be either within the same bank or beween banks
- Memory address counters can either be incremented or decremented
- Interleaved, cycle steal, and burst modes
- Processor-hold and processor-run operations
- Two DMA request channels
- DMA interrupt selectable either to the Non-Maskable Interrupt or the Interrupt Request (BIRQ) line
- 500K bytes per second maximum transfer rate
- DMA termination signal to abort any DMA transfer operation in progress
- Supports RM 65 FDC 8 -inch double-density operation
- Programmable Byte Counter for up to 65 K -byte transfers
- Bank switches to assign I/O addresses to either one or two 65K memory banks
- I/O Base Address switch selectable to a page boundary
- Operates from a single +5 V power source
- Fully assembled and tested with a one-year warranty


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-5104E | Direct Memory Access Controller (DMAC) Module |



RM65-5104E Direct Memory Access
Controller (DMAC) Module

## FUNCTIONAL DESCRIPTION

Addresses on the RM 65 Bus are compared with the address set by the module Base Address switches. If the Bank Select Enable switch is set, the bank-address signal (BADR/) is compared with the signal from the Bank Select switch. When the BADR/ and address signal states on the bus match the signal states generated by the Base Address and Bank Select switches, the Microcode Generator, Chip Select, and Data Buffer circuits are enabled.

When the module circuits are enabled, the four least significant address signals and the read/write signal ( $\mathrm{R} / \mathrm{W}$-) generate chipselect and microcode signals. The chip-select signals enable devices within the DMAC Module either to accept or to output data. The microcode signals control which registers are active in the DMA Source Address, Destination Address, and Byte Count Generators.

After the generators are enabled and selected, data can be transferred between the module and the RM 65 Bus. Before the start of a DMA operation, these generators must be initialized. The Source Address Generator and the Destination Address Generator, respectively, must be loaded to specify the starting address of the source and the destination address during DMA data transfers. Control registers must be loaded to specify if the address is to be incremented or decremented after each byte. The Byte Count Generator must be loaded to specify the number of bytes of data to be transferred. A control byte in the Byte Count Generator indicates whether the contents of the register are to be incremented or decremented. Typically, the Byte Count Generator is set up to count down because the DMA transfer stops when the byte count becomes zero.

Contents of the Command Register specify the parameters the DMAC Module is to use and start the DMA cycle. After the Command Register has been loaded, the DMAC Module waits for two signals before beginning a DMA cycle. If the DMAC Module is to transfer data to or from an I/O device, a DMA request signal must be received from the I/O device. For I/O-to-I/O transfers, a DMA request must be received from each I/O device. For memory-to-memory transfers, the DMA request is generated by the DMAC Module. The second signal required for DMA transfers is the sync signal. When the sync signal goes high, the DMAC Module forces the ready signal low (if the processor-stop mode is enabled), floats (effectively disconnects) the RM 65 Bus from the microprocessor, and switches module operation to the Read state.

During DMA cycles, the DMAC Module is controlled by the State Control Circuitry. When the DMAC Module is idle, module operation starts or concludes in the Initialize And Conclude state. In the Read state, the source address from the Source Address Generator is placed on the RM 65 address lines. Data on the RM 65 data lines is then transferred from the source device and saved in a temporary storage register. During the Write state, the destination address from the Destination Address Generator is placed on the RM 65 address lines. Data in the Temporary Data Register is then placed on the RM 65 data lines and transferred to the destination device.

After the Write state, the byte count and mode of operation affect the state which the DMAC Module next enters. If the byte count is zero, DMAC Module operation switches to the Initialize And Conclude state and control of both the RM 65 Bus and the system returns to the processor. If the byte count is not zero, then the mode of operation affects the next DMA state. When the byte count is not zero and the data transfer is between two memory devices, operation of the DMAC Module switches to the Read state.

When the data transfer involves I/O devices, DMAC Module operation switches to a Read state if the DMA request signal (or signals during I/O-to-l/O transfers) is present. If the DMA request signal is not present and the module is in the burst mode, the mode of operation switches to a Hold state and remains in the state until the DMA request signal is present. Module operation then switches to a Read state. If the DMAC Module is operating in an interleaved mode, the operation is switched to the Initialize And Conclude state and control returns to the processor. The module takes control again as soon as sync and DMA request signals are present.

At the end of a DMA cycle, after the byte count has been reduced to zero and DMAC Module control has switched to the Initialize And Conclude state, system control returns to the microprocessor. The ready signal is disabled. The DMAC Module Command Register is cleared and the transfer-complete flag is written into the Status Register. If the interrupt mask bit is not set, either an interrupt request or a nonmaskable interrupt signal is generated.

DMAC Module operating modes are controlled by bits in the DMAC Module Command Register. Modes available are Halt, Interrupt Mask, Burst, and Interleaved.


RM65-5104E DMAC Module Block Diagram

RM 65 Bus Pin Assignments

| Bottom (Solder Side) |  |  |  | Top (Component Side) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | I/O | Pin | Signal Mnemonic | Signal Name | I/O |
| 12 | GND | Ground |  | 1 c | $+5 \mathrm{~V}$ | +5 Vdc |  |
| 2 a | BADR/ | Buffered Bank Address | I/O | 2 c | BA15/ | Buffered Address Bit 15 | I/O |
| 3 a | GND | Ground |  | 3 c | BA14/ | Buffered Address Bit 14 | I/O |
| 4a | BA13 | Buffered Address Bit 13 | /O | 4 c | BA12/ | Buffered Address Bit 12 | I/O |
| 5 a | BA11/ | Buffered Address Bit 11 | I/O | 5 c | GND | Ground |  |
| 6a | BA10/ | Buffered Address Bit 10 | I/O | 6 c | BA9/ | Buffered Address Bit 9 | I/O |
| 7a | BA8/ | Buffered Address Bit 8 | I/O | 7 c | BA7/ | Buffered Address Bit 7 | I/O |
| 8 a | GND | Ground |  | 8 c | BA6/ | Buffered Address Bit 6 | I/O |
| 9 a | BA5/ | Buffered Address Bit 5 | 1/0 | 9 c | BA4/ | Buffered Address Bit 4 | I/O |
| 10a | BA3/ | Buffered Address Bit 3 | I/O | 10c | GND | Ground |  |
| 11a | BA2/ | Buffered Address Bit 2 | I/O | 11c | BA1/ | Buffered Address Bit 1 | I/O |
| 12a | BAO/ | Buffered Address Bit 0 | I/O | 12c | Bф1. | Buffered Phase 1 Clock | 1 |
| 13a | GND | Ground |  | 13c | BSYNC | Buffered Sync | I/O |
| 14a | BSO | *Buffered Set Overflow |  | 14c | BDRQ1/ | Buffered DMA Request 1 | 1 |
| 15a | BRDY | Buffered Ready | 0 | 15 c | GND | Ground |  |
| 16a |  | *User Spare 1 |  | 16c | -12V/-V | *-12 Vdc/-V |  |
| 17a | +12V/+V | *+12 Vdc/+V |  | 17c |  | * User Spare 2 |  |
| 18a | GND | Ground |  | 18 c | BFLT/ | Buffered Bus Float | 0 |
| 19a | BDMT/ | Buffered DMA Terminate | 1 | 19C | вфо | *Buffered External Phase 0 Clock |  |
| 20a |  | * User Spare 3 |  | 20c | GND | Ground |  |
| 21a | $\mathrm{BR} / \overline{\mathrm{W}} /$ | Buffered Read/Write "Not" | I/O | 21c | BDRQ2/ | Buffered DMA Request 2 | 1 |
| 22a |  | *System Spare |  | 22c | BR/W | Buffered Read/Write | 1/0 |
| 23a | GND | Ground |  | 23 c | BACT/ | Buffered Bus Active | 0 |
| 24a | BIRQ/ | Buffered Interrupt Request | 0 | 24c | BNMI/ | Buffered Non-Maskable Interrupt | 0 |
| 25a | B $\chi_{2} /$ | Buffered Phase 2 "Not" Clock | 0 | 25c | GND | Ground |  |
| 26a | Вф2 | Buffered Phase 2 Clock | I/O | 26c | BRES/ | Buffered Reset | 1 |
| 27a | BD7/ | Buffered Data Bit 7 | $1 / 0$ | 27c | BD6/ | Buffered Data Bit 6 | V/O |
| 28a | GND | Ground |  | 28c | BD5/ | Buffered Data Bit 5 | IV |
| 29a | BD4/ | Buffered Data Bit 4 | I/O | 29 C | BD3/ | Buffered Data Bit 3 | I/O |
| 30a | BD2/ | Buffered Data Bit 2 | I/O | 30 c | GND | Ground |  |
| 31 a | BD1/ | Buffered Data Bit 1 | I/O | 31 c | BDO/ | Buffered Data Bit 0 | I/O |
| 32a | +5V | +5 Vdc |  | 32c | GND | Ground |  |
| Note: <br> *Not used on this module. |  |  |  |  |  |  |  |

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions (1, 2, 3) Width Length Height | 100 mm ( 3.9 in .) <br> 164 mm ( 6.4 in .) <br> 14 mm ( 0.56 in .) |
| Weight | 137 g (4.8 oz.) |
| 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 | $\begin{array}{r} +5 \mathrm{Vdc} \pm 5 \% \text {, at } 1.2 \mathrm{~A}(6.0 \mathrm{~W}) \text {-Typical } \\ 1.9 \mathrm{~A}(9.5 \mathrm{~W}) \text {-Maximum } \end{array}$ |
| RM 65 Bus Interface | 64-pin plug ( 0.100 in . centers) per DIN 41612 ( a and b with c not installed). |
| Notes: <br> 1. Height includes the maximum values for component height above the board surface ( 0.4 in .), printed circuit board thickness ( 0.062 in.), and pin extension through the bottom of the module ( 0.1 in .). <br> 2. Length does not include extensions beyond the edge of the module due to connectors or the module ejector. <br> 3. Connector conforms to DIN 41612. |  |



RM65-5104E DMAC Module Dimensions

# RM65-5222E RM 65 GENERAL PURPOSE INPUT/OUTPUT (GPIO) \& TIMER MODULE 

## RM 65 MICROCOMPUTER MODULES

The RM65-5222E GPIO \& Timer Module is one of the hardware options available for the RM 65 Microcomputer Module family.
RM 65 Microcomputer Module products are 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.
RM 65 modules use a motherboard interconnect concept and accept 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 AIM 65 and AIM 65/40 Microcomputers for product development and for a broad variety of portable or desk-top microcomputer applications.

## PRODUCT OVERVIEW

The RM65-5222E General Purpose Input/Output (GPIO) \& Timer Module provides a parallel I/O interface to the RM 65 Bus. Two R6522 Versatile Interface Adapter (VIA) devices provide four 8bit bidirectional data ports and four 2-bit control ports; 40 VO 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 65 K byte memory banks or common to both banks. Eight switches allow I/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

| Part No. | Description |
| :--- | :--- |
| RM65-5222E | General Purpose Input/Output (GPIO) and <br> Timer Module |
| Order No. | Description |
| 801 | General Purpose Input/Output (GPIO) and <br> Timer Module User's Manual (included with <br> RM65-5222E) |

## FEATURES

- Compact size—about $4^{\prime \prime} \times 6114^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Pin and socket bus connector
- 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
- +5 V operation
- Fully assembled, tested and warranted


RM65-5222E General Purpose Input/Output (GPIO) \& Timer Module

## 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. Date 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, oneshot 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 16 -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 VO 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 R6522 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 direction 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 Control logic. There are also eight buffers provided for the control lines (2 per l/O port), six of which can be configured for input or output as determined by the Handshake Direction Buffers.
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.


RM 65 Bus Pin Assignments


1/O Connector Pin Assignments

| Pin | Signal |
| :---: | :---: |
| 1 | Port 1A Data 0 |
| 3 | Port 1A Data 1 |
| 5 | Port 1A Data 2 |
| 7 | Port 1A Data 3 |
| 9 | Port 1A Data 4 |
| 11 | Port 1A Data 5 |
| 13 | Port 1A Data 6 |
| 15 | Port 1A Data 7 |
| 17 | Port 1A Control CA1 |
| 19 | Port 1A Control CA2 |
|  |  |
| Notes: |  |
| 1. Similar for ports 1B, 2A and 2B |  |
| 2. Even Pins 2-20 are ground |  |

SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions (1, 2, 3) <br> Width <br> Length <br> Height | 3.9 in. ( 100 mm ) 6.3 in. $(160 \mathrm{~mm})$ 0.56 in . $(14 \mathrm{~mm})$ |
| Weight | 5.0 oz . (140 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 | $\begin{aligned} & +5 \mathrm{Vdc} \pm 5 \% 0.52 \mathrm{~A}(2.6 \mathrm{~W})-\text { Maximum } \\ & +5 \mathrm{Vdc} \pm 5 \% 0.94 \mathrm{~A}(4.70 \mathrm{~W}) \text {-Maximum } \end{aligned}$ |
| Interface <br> RM 65 Bus Interface <br> /O Interface I/O Connectors ( | 64-pin plug ( 0.100 in. centers) per DIN 41612 (Row b not installed) <br> 20 -pin vertical mass termination plug ( 0.3 in . pins on 0.100 in. centers) |
| Notes: <br> 1. 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 .). <br> 2. Length does not include extensions beyond the edge of the module due to connectors or the module ejector. <br> 3. Dimensions conform to DIN 41612. |  |



RM65-5222E Module Dimensions RM65-5223E
RM 65 MULTI-FUNCTION
PERIPHERAL INTERFACE MODULE

## RM 65 MICROCOMPUTER MODULES

The RM65-5223E Multi-Function Interface (MPI) Module is one of the hardware options available for the RM 65 Microcomputer Module family.
RM 65 Microcomputer Modules products are 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.
RM 65 modules use a motherboard interconnect concept and accept 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 AIM 65 and AIM 65/40 Microcomputers for product development and for a broad variety of portable or desk-top microcomputer applications.

## PRODUCT OVERVIEW

The RM65-5223E RM 65 Multi-function Interface (MPI) 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 I/O lines in all. Two multi-mode 16 -bit timer/counters extend the versatility of the module. All I/O lines are TTL buffered and available on two 40 pin I/O connectors compatible with the AIM 65/40 SBC and RM 65 SBC Parallel Application connectors. Data buffer direction is under direct software control. Twelve jumpers specify the direction of the control lines, while an additional 6 jumpers control the optional features.
The MPI Module I/O can be assigned either to one of two 65K byte memory banks or common to both banks. Eight switches allow I/O addresses to be set to any page ( 256 bytes).


RM65-5223E Multi-function Peripheral Interface (MPI) Module

## FEATURES

- Compact size—about $4^{\prime \prime} \times 6^{114^{\prime \prime}}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Pin and socket bus connection
- RM 65 Bus compatible
- Two R6522 Versatile Interface Adapter (VIA) devices
- Four fully buffered 8 -bit parallel data ports
- Four fully buffered 2-bit control ports
- Four programmable 16-bit counter/timers
- Two serial input/output ports
- Multiple interrupt conditions
- Full buffering on all I/O data and control lines
- Software-controlled data line direction
- Jumper-selectable control line direction
- Data port buffering can be removed
- All I/O lines are available on two $40-\mathrm{pin}$ I/Q connectors
- I/O connectors are compatible with both the AIM 65/40 and RM 65 SBC module parallel I/O connectors and AIM 65/40 intelligent peripherals
- One connector is fully compatible with the AIM 65/40 standard or extended keyboard
- Bank switches assign I/O addresses to one or two 65 K banks
- I/O base address switch selectable to a page boundary
- +5 V operation
- Fully assembled, tested and warranted

ORDERING INFORMATION

| Part No. | Description |
| :--- | :--- |
| RM65-5223E | Multi-function Peripheral Interface (MPI) <br> Module |
| Order No. | Description |
| 817 | Multi-function Peripheral Interface Module <br> (MPI) Module User's Manual (included with <br> RM65-5223E) |

## FUNCTIONAL DESCRIPTION

The heart of the MPI 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 $1 / 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, oneshot 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 16-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.

Four Port Transceivers buffer the VIA data lines for input or output modes. The I/O Data Direction Control logic allows the direction of each 8 -bit port to be independently set for input or output mode under software controls. In the buffered output mode, the Port Transceivers are capable of sinking 16 mA on any data line. For applications where buffering is not desired, any of the Port Transceivers can be replaced with DIP shunts for direct connection to the VIA peripheral data pins.

The I/O Control Signal Buffers fully buffer all eight VIA Control lines. On each VIA, one control line (CA1) has only an input mode which is buffered as such. Twelve I/O Control Direction Jumpers allow the three bidirectional control lines (CA2, CB1, and CB2) on each R6522 to be configured for either input or output mode.

A number of options available on VIA No. 1 make it particularly well-suited for keyboard applications. The A port of VIA No. 1 is supplemented with Line Low Detection circuitry which generates an interrupt through control line CA1 when any line goes
low; a reset switch on control line CB2 is passed off the board from the RESET connector to be used by reset conditioning circuitry on an RM 65 SBC module, AIM 65 micocomputer or AIM 65/40 SBC module; an attention switch on control line CB1 is debounced by the Attention Interrupt Conditioning circuitry to generate a non-maskable interrupt when enabled by the Attention Interrupt jumper.

Two 40-pin Parallel I/O connectors support all the R6522 VIA signals as well as the Attention and Reset switch options. These connectors can be configured to match the RM 65 or AIM 65/40 SBC module Parallel Application connectors, while also being compatible with AIM 65/40 peripherals-keyboard, display or printer. The I/O Power Source jumpers allow +5 V to be supplied to the interfacing equipment through the Parallel $\mathrm{I} / \mathrm{O}$ Connector.

The Data Transceivers invert and buffer 8-bits of parallel data between the RM 65 Bus and the two R6522 VIA devices or the V/O Direction Control logic. 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 I/O to the RM 65 Bus. During a write operation, data is transferred from the RM 65 Bus to the addressed I/O.

The Address Buffers invert the six least significant address bits used to select the R6522 devices and registers and also the I/O Direction Control Logic.

The Control Buffers drive read/write, phase 2 clock, and reset signals from the RM 65 Bus to the MPI module. The interrupt request and bus active signals are driven from the MPI module.

The Bank Select Control circuit detects when the MPI 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 either common to both banks, or to Bank O (lower 65K) or Bank 1 (upper 65K) depending on the Bank Select switch.

The Base Address Decoders use the eight most significant address lines to assign the MPI module 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 R6522 devices or the I/O Direction Control logic is selected.


RM 65 Bus Pin Assignments

| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | Pin | Signal Mnemonic | Signal Name |
| 1 a | GND | Ground | 1 c | +5V | +5 Vdc |
| 2 a | BADR/ | Buffered Bank Address | 2 c | BA15/ | Buffered Address Bit 15 |
| 3 a | GND | Ground | 3 c | BA14/ | Buffered Address Bit 14 |
| 4a | BA13/ | Buffered Address Bit 13 | 4 c | BA12/ | Buffered Address Bit 12 |
| 5 a | BA11/ | Buffered Address Bit 11 | 5 c | GND | Ground |
| 6 a | BA10/ | Buffered Address Bit 10 | 6 c | BA9/ | Buffered Address Bit 9 |
| 7 a | BA8/ | Buffered Address Bit 8 | 7 c | BA7/ | *Buffered Address Bit 7 |
| 8 a | GND | Ground | 8 c | BA6/ | *Buffered Address Bit 6 |
| 9 a | BA5/ | Buffered Address Bit 5 | 9 c | BA4/ | Buffered Address Bit 4 |
| 10a | BA3/ | Buffered Address Bit 3 | 10c | GND | Ground |
| 11a | BA2/ | Buffered Address Bit 2 | 11c | BA1/ | Buffered Address Bit 1 |
| 12a | BAO/ | Buffered Address Bit 0 | 12 c | B $\varnothing 1$ | *Buffered Phase 1 Clock |
| 13a | GND | Ground | 13 c | BSYNC | *Buffered Sync |
| 14a | BSO | *Buffered Set Overflow | 14 c | BDRQ1/ | *Buffered DMA Request 1 |
| 15a | BRDY | *Buffered Ready | 15c | GND | Ground |
| 16a |  | *User Spare 1 | 16c | -12V/-V | *-12 Vdc/-V |
| 17a | $+12 \mathrm{~V} /+\mathrm{V}$ | *+12 Vdc/ + V | 17 c |  | * User Spare 2 |
| 18a | GND | Ground Line | 18c | BFLT/ | *Buffered Bus Float |
| 19a | BDMT/ | *Buffered DMA Terminate | 19 c | Bø0 | *Buffered External Phase 0 Clock |
| 20a |  | * User Spare 3 | 20c | GND | Ground |
| 21a | $\mathrm{BR} / \overline{\mathrm{W}} /$ | Buffered Read/Write "Not" | 21c | BDRQ2/ | *Buffered DMA Request 2 |
| 22a |  | *System Spare | 22 c | $\mathrm{BR} / \bar{W}$ | *Buffered Read/Write |
| 23a | GND | Ground | 23 c | BACT/ | Buffered Bus Active |
| 24a | BIRQ/ | Buffered Interrupt Request | 24 c | BNMI/ | Buffered Non-Maskable Interrupt |
| 25a | B $\chi^{2 /}$ | Buffered Phase 2 "Not" Clock | 25 c | GND | Ground |
| 26a | Bø2 | *Buffered Phase 2 Clock | 26 c | BRES/ | Buffered Reset |
| 27a | BD7/ | Buffered Data BH' 7 | 27 c | BD6/ | Buffered Data Bit 6 |
| 28a | GND | Ground | 28 c | BD5/ | Buffered Data Bit 5 |
| 29a | BD4/ | Buffered Data Bit 4 | 29 c | BD3/ | Buffered Data Bit 3 |
| 30a | BD2/ | Buffered Data Bit 2 | 30c | GND | Ground |
| 31 a | BD1/ | Buffered Data Bit 1 | 31 c | BDO/ | Buffered Data Bit 0 |
| 32a | +5V | +5 Vdc | 32c | GND | Ground |
| Note: <br> Not us | this module. |  |  |  |  |

Connector J1 and J2 (Parallel I/O Connector) Pin Assignments

| Pin | Signal | 1/0 | Type | Pin | Signal | Type |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | CB2/RES | VO | NMOS | 2 | GND/ $+5 \mathrm{~V}^{*}$ | Power |
| 3 | CB1/ATTN | 1/0 | NMOS | 4 | GND | Power |
| 5 | PB7 | $1 / 0$ | NMOS | 6 | GND | Power |
| 7 | PB6 | 1/0 | NMOS | 8 | GND | Power |
| 9 | PB5 | $1 / 0$ | NMOS | 10 | GND | Power |
| 11 | PB4 | vo | NMOS | 12 | GND | Power |
| 13 | PB3 | $1 / 0$ | NMOS | 14 | GND | Power |
| 15 | PB2 | $1 / 0$ | NMOS | 16 | GND | Power |
| 17 | PB1 | 1/O | NMOS | 18 | GND | Power |
| 19 | PBO | vo | NMOS | 20 | GND | Power |
| 21 | PA7 | vo | NMOS | 22 | GND | Power |
| 23 | PA6 | 1/0 | NMOS | 24 | GND | Power |
| 25 | PA5 | 1/0 | NMOS | 26 | GND | Power |
| 27 | PA4 | 1/0 | NMOS | 28 | GND | Power |
| 29 | PA3 | 1/0 | NMOS | 30 | GND | Power |
| 31 | PA2 | 1/0 | NMOS | 32 | GND | Power |
| 33 | PA1 | 1/0 | NMOS | 34 | GND | Power |
| 35 | PAO | 1/0 | NMOS | 36 | GND | Power |
| 37 | CA2 | 1/0 | NMOS | 38 | GND | Power |
| 39 | CA1 | 1 | NMOS | 40 | GND/ $+5 \mathrm{~V}^{*}$ | Power |

## Notes:

1. Pins 2 and 40 can be optionally jumpered to +5 V (maximum current through each pin should not exceed 200 mA ).
2. Pin 1 of J 1 can be optionally jumpered to RESET connector or to CB2.
3. Pin 3 of J 1 can be optionally jumpered to the Attention Interrupt Conditioning circuit or to CB1.

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimenslons (1, 2, 3) <br> Width <br> Length <br> Height | $3.9 \mathrm{in} .(100 \mathrm{~mm})$ <br> $6.3 \mathrm{in} .(160 \mathrm{~mm})$ <br> $0.56 \mathrm{in} .(14 \mathrm{~mm})$ |
| Weight | 5.1 oz. (145 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} \end{aligned}$ <br> $0 \%$ to $85 \%$ (without condensation) |
| Power Requirements | $\begin{aligned} & +5 \mathrm{Vdc} \pm 5 \% \text { 0.65 A }(3.25 \mathrm{~W}) \text {-Typical } \\ & \text { +5 Vdc } \pm 5 \% \text { 1.03 A }(5.15 \mathrm{~W}) \text {-Maximum } \end{aligned}$ |
| Interfaces <br> RM 65 Bus Interface <br> I/O Interface Parallel I/O Connectors (2) <br> Reset Connector | 64-pin plug ( 0.100 in. centers) per DIN 41612 (Row b not installed) <br> 40-pin 3M \#3495-1002, or equivalent, receptacle. Mates with 3M \#3418-0000T, or equivalent, ribbon cable connector 2 vertical pins ( 0.3 in . high) on 0.200 in , center |
| Notes: <br> 1. Height includes the maximum valu thickness ( 0.062 in.), and pin exten <br> 2. Length does not include extensions <br> 3. Dimensions conform to DIN 41612 | height above the board surface ( 0.4 in . for populated modules), printed circuit board ottom of the module ( 0.1 in .). of the module due to connectors or the module ejector. |

 RM 65 ANALOG INPUT AND ANALOG INPUT/OUTPUT MODULES

## RM 65 MICROCOMPUTER MODULES

The RM65-5302E Analog Input Module and the RM65-5303E Analog input/Output Module are hardware options available for the RM 65 Microcomputer Module family.
RM 65 Microcomputer Module products are 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.

RM 65 modules use a motherboard interconnect concept in which any card can be inserted in any slot. The 64-line RM 65 Bus offers memory addressing up to 128 K bytes, provides high immunity to electrical noise and includes growth provisions for user functions. A selection of card cages allows packaging flexibility. RM 65 products can also be used with Rockwell AIM 65 and AIM 65/40 Microcomputers for product development and for a broad variety of portable or desktop microcomputer applications.

## PRODUCT OVERVIEW

The RM65-5303E Analog Input/Output module provides either 16 single-ended or 8 differential analog input channels with 12-bit analog-to-digital conversion and two independent analog output channels with 12-bit digital-to-analog conversion. This single module can satisfy a wide range of applications requiring both monitoring and control of interfacing analog devices. For applications requiring only the monitoring of sensors, the RM655302E Analog Input module provides the same input capability as the RM65-5303E module but does not have analog output provision.

The analog input section is easily jumper configured to accept inputs in one of five voltage ranges in either single-ended or differential input connection (depending upon the position of a plug-in header). Automatic input conversion start upon reading of input data simplifies software processing. Each of the two independent analog output channels initiates output conversion automatically upon the receipt of output data thus similarly reducing software steps. Each output channel can also be separately configured to operate in one of five output ranges with internal reference or in one of six output gain ranges with external reference.

## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-5302E <br> RM65-5303E | Analog Input Module <br> Analog Input/Output Module |
| Order No. | Description |
| 818 | Analog Input/Output Module User's Manual <br> (included with RM65-5302E and RM65-5303E) |

## FEATURES

- Compact size—about $100 \mathrm{~mm} \times 160 \mathrm{~mm}\left(4^{\prime \prime} \times 61 / 4^{\prime \prime}\right)$
- RM 65 Bus compatible
- 16 Single-ended or 8 differential analog input channels
-12-bit analog-to-digital converter (ADC)
-Software control of input channel
- Input over-voltage protected to $\pm 15 \mathrm{~V}$
- Input impedance of 100 megohms minimum
-Five analog input voltage ranges
-70 db of common-mode rejection with differential inputs
-Sample and hold isolation of analog input during conversion time
-Software selectable data length conversion (8 or 12 bits)
-Automatic conversion start upon reading the most significant byte
-Maskable interrupt generation upon conversion completion
- Two independent analog output channels each with:
-12-bit digital-to-analog converter (DAC)
-Five analog output voltage ranges with internal reference
-Six analog output gain ranges with external reference
-Settling time of 6 microseconds
-Double-buffered DAC data registers
-Automatic conversion start upon writing the least significant byte
- Trim potentiometers for zero-offset and full-scale reference adjustments
- All analog I/O signals are available on a 40 -pin connector compatible with mass-terminated twisted-pair cables
- Fully assembled and tested with a one-year warranty


RM65-5303E Analog Input/Output Module

## Analog Input and Input/Output Modules

## FUNCTIONAL DESCRIPTION

## RM 65 BUS INTERFACE

The Base Address Comparator compares the address lines to Base Address switches S1-1 through S1-8 to determine if the address is within the 256-byte (1 page) block of memory selected by the switches. When the address lines match the switch positions, the module is enabled.

Bank Select logic exclusively NORs the Bank Address line with the Bank Select switch position (S1-9) then routes the output through the Bank Select Enable switch (S1-10) to select the bank ( 0,1 or both) that the module responds to when addressed. This bank enable signal is then routed to the Command Decoder.

Control Line Buffers invert and drive the read/write, reset, phase 2 and address line 0 onto the module for use by other on-board circuitry. The Interrupt Request from the ADC conversion logic and the Bus Active from the Address Decoder logic are driven onto the RM 65 Bus.

Data Transceivers invert and transfer eight parallel data lines between the module and the RM 65 data bus. The transceivers are enabled by the Address Decoder logic when the module is addressed in the selected page and bank. The direction of data transfer is controlled by $\mathrm{R} / \overline{\mathrm{W}}$. When the transceivers are enabled during a write operation, data is transferred from the RM 65 data bus for use by the ADC MUX Channel Select, the ADC Control Register, or the two DACs. When the transceivers are enabled during a read operation, data is transferred to the RM 65 data bus from the ADC, the ADC MUX Channel Monitor, or the ADC Status Register.

## COMMAND DECODER

Command Decoder logic is enabled when the address is within the page selected by the base address switches, and the bank address matches the selected bank. When enabled, bus address lines BA1/ and BA2/ as well as R/W from the Control Line Buffers are decoded and combined with other logic into the following major control lines, which enable the Data Transceivers, drive Bus Active, and control the other major module functions.

## ANALOG INPUT

Analog input signals are routed from the J1 VO Connector to the multiplexer (MUX) which consists of two 8-to-1 MUX devices. For single-ended inputs, the 16 individual signals are routed to one of the two MUX devices; eight channels ( $\mathrm{CHO}-\mathrm{CH} 7$ ) to MUX 2 and eight channels ( $\mathrm{CH} 8-\mathrm{CH} 15$ ) to MUX 1 . The signal return is connected to ground through the corresponding channel return at Connector J1. For differential inputs, eight channels are connected to both MUX devices; eight ( $\mathrm{CHO}+$ through $\mathrm{CH} 7+$ ) to MUX 2 and the accompanying eight ( CHO - through $\mathrm{CH} 7-$ ) to MUX 1.

The ADC MUX Channel Select logic latches the upper four RM 65 data bus lines. When a Write ADC MUX Channel command is decoded by the Command Decoder, the encoded channel number ( 0 to 7 ) is output to the MUX devices. Latched data lines are routed to each MUX device to select one of eight channels. The high and low latched D7 and $\overline{\mathrm{D7}}$ lines are routed through
the Analog Input Header to enable either MUX 1 or MUX 2. For single-ended inputs, MUX 2 is enabled when channel $0-7$ is selected while MUX 1 is enabled when Channel $8-15$ is selected. For differential inputs, both MUX devices are enabled when channel 0-7 is selected. The ADC MUX Channel Monitor copies the latched MUX channel select lines onto data bus lines when a Read ADC MUX Channel Monitor command is decoded by the Command Decoder.

The selected MUX output is routed through the Analog Input Header to the INST AMP. The plug-in shunt type header contains alternating open and closed circuits and is provided with the module to allow easy selection of either single-ended or differential inputs by merely reversing the orientation of the header in the socket. When single-ended inputs are selected, the high signal from the selected MUX device is routed to the INST AMP "+" input while GND is routed to the INST AMP "-" input. When a differential input is selected, the signal from MUX 2 is connected to the INST AMP " + " input while the signal from MUX 1 is routed to the INST AMP "-" input. One pin of the Analog Input Header socket is routed to ADC Status Register to indicate the installed position of the header to the processor.

The INST AMP provides a precision gain to the differential voltage between its " + " and "-" input terminals. The ADC Amplifier Gain jumper allows a gain of either 1 or 2 to be selected. Two potentiometers allow the zero offset and gain to be adjusted.

The S/H amplifier and associated hold capacitor samples the output from the INST AMP and holds its output steady while the interfacing ADC device converts the analog signal to the digital equivalent.

## A/D CONVERSION AND ADC READ LOGIC

The ADC and associated A/D conversion/read logic controls the converting of the analog input signal to digital format and the transferring of the digital data onto the data bus.

## CONVERT A/D CYCLE

The convert AVD cycle controls the sampling and holding of the analog input signal and its conversion to digital format. The convert cycle is initiated in response to a Read ADC MSB command.

The ADC device uses a 12-bit successive approximation technique to convert the analog input voltage to a 12 - or 8 -bit digital format then stores the digital data in an internal data storage register (for subsequent output to data lines D0-D7 in response to read ADC commands). The Input Type jumper selects either unipolar or bipolar operation. The ADC Range jumper routes the input signal from the $\mathrm{S} / \mathrm{H}$ to either the 10 V or 20 V input pin on the ADC.

When the conversion is complete, the ADC Data Ready bit (ADCRDY) is set in the ADC Status Register. This indicates that the conversion is complete and that ADC data may be read from the ADC. ADCRDY also generates the Interrupt Request if the Interrupt Enable (IRQEN) is set in the ADC Control Register.

## READ ADC CYCLE

The converted analog input signal is output to the RM 65 data bus through Data Transceivers in response to one of two read

ADC commands decoded by the Command Decoder. One command, Read ADC LSB, transfers the least significant byte consisting of the four least significant bits and four zeros onto the RM 65 data bus. One other command, Read ADC MSB, transfers the most significant byte consisting of the eight most significant bits onto the RM 65 data bus. The least significant byte is always read first since reading the most significant byte restarts the conversion cycle.

## ADC STATUS AND CONTROL REGISTER

The ADC Status Register, when enabled by the decoded Read ADC Status Register command, drives the status of four signals onto the data bus.

| Signal Name | Description |
| :--- | :--- |
| HDRPOS | Analog Input Header Position |
| IRQENS | Interrupt Request Enable Status |
| ADCRDY | ADC Data Ready |
| IRQ- | Interrupt Request Flag Status |

HDRPOS reflects the installed position of the Analog input Header. IRQENS copies the Interrupt Request Enable Command output from the ADC Control Register. ADCRDY indicates the ADC conversion status from the ADC. The IRQ- Interrupt Request Flag indicates if an interrupt request has been issued to the RM 65 Bus.

The ADC Control Register, when enabled by the decoded Write ADC Control Register command, latches the lower four bits of the data bus lines to drive two ADC control signals.

Signal Name
$12 / 8$

IRQENC Interrupt Request Enable Command

## Description

 Conversion LengthIRQEN is the status of the interrupt enable command to the ADC Status Register. $12 / 8$ is the A/D conversion length command to the ADC device.

## ANALOG OUTPUT

Analog output signals originate as digital data (two bytes) on the RM 65 Bus. These data bytes are input through the Data Transceivers into DAC 1 and DAC 2 in response to commands decoded by the Command Decoder and other logic to distinguish the individual data bytes. These commands enable the respective DACs and initiate the data conversion upon writing of the least significant data byte. Two addresses associated with each DAC transfer the 12 -bit digital data in separate 8 -bit bytes.

The reference voltage to each DAC may be either an internal precision reference originating from the ADC or an external input voltage of $\pm 11 \mathrm{~V}$. Separate buffers amplify the internal reference voltage and the external reference voltage. Either the internal or external reference voltage source is selected by a Reference Source jumper on each channel.

The selected reference voltage is amplified using a gain selected by the DAC Reference Amplifier Gain jumper position. The DAC gain adjust potentiometer trims the amplifier gain.

Each DAC provides an output current directly proportional to the product of the reference voltage and the digital input word. A second output current is similarly proportional to the complement of the digital input value.

An OP AMP converts the output current to a unipolar voltage and a second OP AMP converts the voltage to bipolar levels if jumper selected. One jumper selects the output gain while another jumper determines the output polarity. A potentiometer trims the output gain.


Analog Input/Output Module Block Diagram

I/O Connector Pin Assignments


Notes:

1. Signal name in parentheses applies to differential input connection.
2. Pins 39 and 40 are connected internally to DAC 2 GND.

RM 65 Bus Pin Assignments

| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | Pin | Signal Mnemonic | Signal Name |
| 1 a | GND | Ground | 1 c | +5V | $+5 \mathrm{Vdc}$ |
| 2 a | BADR/ | Buffered Bank Address | 2 c | BA15/ | Buffered Address Bit 15 |
| 3 a | GND | Ground | 3 c | BA14/ | Buffered Address Bit 14 |
| 4 a | BA13/ | Buffered Address Bit 13 | 4 c | BA12/ | Buffered Address Bit 12 |
| 5 | BA11/ | Buffered Address Bit 11 | 5 c | GND | Ground |
| 6 a | BA10/ | Buffered Address Bit 10 | 6 c | BA9/ | Buffered Address Bit 9 |
| 7 a | BA8/ | Buffered Address Bit 8 | 7 c | BA7/ | *Buffered Address Bit 7 |
| 8 a | GND | Ground | 8 c | BA6/ | *Buffered Address Bit 6 |
| 9 a | BA5/ | *Buffered Address Bit 5 | 9 c | BA4/ | *Buffered Address Bit 4 |
| 10a | BA3/ | *Buffered Address Bit 3 | 10c | GND | Ground |
| 11a | BA2/ | Buffered Address Bit 2 | 11c | BA1/ | *Buffered Address Bit 1 |
| 12a | BAO/ | Buffered Address Bit 0 | 12 c | B $\square_{1}$ | *Buffered Phase 1 Clock |
| 13a | GND | Ground | 13c | BSYNC | *Buffered Sync |
| 14a | BSO | *Buffered Set Overflow | 14 c | BDRQ1/ | *Buffered DMA Request 1 |
| 15a | BRDY | Buffered Ready | 15 c | GND | Ground |
| 16a |  | * User Spare 1 | 16 c | $-12 \mathrm{~V} /-\mathrm{V}$ | -15 Vdc |
| 17a | $+12 \mathrm{~V} /+\mathrm{V}$ | +15 Vdc | 17 c |  | *User Spare 2 |
| 18a | GND | Ground Line | 18c | BFLT/ | *Buffered Bus Float |
| 19a | BDMT/ | *Buffered DMA Terminate | 19c | Bø0 | *Buffered External Phase 0 Clock |
| 20a |  | *User Spare 3 | 20c | GND | Ground |
| 21a | $\mathrm{BR} / \overline{\mathrm{W}} /$ | Buffered Read/Write "Not" | 21 c | BDRQ2/ | *Buffered DMA Request 2 |
| 22a |  | *System Spare | 22c | BR/W | *Buffered Read/Write |
| 23a | GND | Ground | 23c | BACT/ | Buffered Bus Active |
| 24a | BIRQ/ | Buffered Interrupt Request | 24 c | BNMI/ | *Buffered Non-Maskable Interrupt |
| 25a | Bø2/ | Buffered Phase 2 "Not". Clock | 25 c | GND | Ground |
| 26a | Bø2 | Buffered Phase 2 Clock | 26c | BRES/ | Buffered Reset |
| 27a | BD7/ | Buffered Data Bit 7 | 27 c | BD6/ | Buffered Data Bit 6 |
| 28a | GND | Ground | 28 c | BD5/ | Buffered Data Bit 5 |
| 29a | BD4/ | Buffered Data Bit 4 | - 299 | BD3/ | Buffered Data Bit 3 |
| 30a | BD2/ | Buffered Data Bit 2 | 30c | GND | Ground |
| 31 a | BD1/ | Buffered Data Bit 1 | 31 c | BDO/ | Buffered Data Bit 0 |
| 32a | +5V | $+5 \mathrm{Vdc}$ | 32 c | GND | Ground |

Analog Input/Output Module Conversion Characteristics

| Characteristic | Value |
| :---: | :---: |
| Analog Inputs |  |
| Number of Inputs (Header Selectable) |  |
| Single-Ended | 16 |
| Differential | 8 |
| Input Voltage Ranges (Jumper Selectable) |  |
| Unipolar | 0 to $+5 \mathrm{~V}, 0$ to +10 V |
| Bipolar | $\pm 2.5 \mathrm{~V}, \pm 5 \mathrm{~V}, \pm 10 \mathrm{~V}$ |
| Input (Bias) Current | $\pm 50 \mathrm{nA}$ (max.) $\left(25^{\circ} \mathrm{C}\right)$ |
| Input Impedance |  |
| ON Channel | $3 \times 10^{9} \mathrm{ohm}, 50 \mathrm{pf}$ |
| OFF Channel | $1 \times 10^{10} \mathrm{ohm}, 20 \mathrm{pf}$ |
| Input Overvoltage | $\pm \mathrm{V} \pm 15 \mathrm{~V}$ (max.) ( $\pm \mathrm{V}$ supply ON or OFF) |
| Input Overvoltage Current | $15 \mathrm{ma}( \pm \mathrm{V} \pm 15 \mathrm{~V}$ ) |
| Common Mode Rejection |  |
| Resolution | 12 bits (1 part in 4096) |
| Accurancy |  |
| Gain error | 0.3\% FSR (max., adjustable to zero) |
| Unipolar offset | $\pm 110 \mathrm{mV}$ (max., adjustable to zero) |
| Bipolar offset | $\pm 150 \mathrm{mV}$ max., adjustable to zero) |
| Linearity error | 0.1\% FSR (max.) |
| Temperature Coefficients |  |
| Gain | $\pm 50 \mathrm{PPM}$ FSR $/{ }^{\circ} \mathrm{C}$ |
| Offset | $\pm 60 \mathrm{PPM} \mathrm{FSR} /{ }^{\circ} \mathrm{C}$ |
| Differential Linearity (no missing codes over temperature range) | 10 Bits |
| Signal Dynamics |  |
| Conversion Time (from read of most significant byte) |  |
| 12-Bit | $35 \mu$ s-typical |
|  | $45 \mu$ s-maximum |
| 8 -Bit | $25 \mu \mathrm{~s}$-typical |
|  | $35 \mu \mathrm{~s}$-maximum |
| Small-signal Bandwidth, 1\% flatness | 50 kHz |
| Full Peak Response | 15 kHz |
| Analog Outputs |  |
| Number of Outputs | 2 |
| With Internal Reference Voltage |  |
| Output Voltage Ranges (Jumper Selectable) |  |
| Unipolar | 0 to $+5 \mathrm{~V}, 0$ to +10 V |
| Bipolar | $\pm 2.5 \mathrm{~V}, \pm 5 \mathrm{~V}, \pm 10 \mathrm{~V}$ |
| With External Reference Voltage ( $\mathrm{V}_{\text {REF }}$ ) |  |
| Input impedance .... | 4.7K ohms $\pm 5 \%$ |
| Reference Voltage Range | $\pm 11 \mathrm{~V}$ |
| Output Voltage Gain Range (Jumper Selectable) |  |
| Unipolar | . 0 to $+.5 \mathrm{~V}_{\text {REF }}, 0$ to $\mathrm{V}_{\text {REF }}, 0$ to $2 \mathrm{~V}_{\text {REF }}$ |
| Bipolar | $\pm .25 \mathrm{~V}_{\mathrm{REF}} \pm \pm .5 \mathrm{~V}_{\mathrm{REF}}, \pm \mathrm{V}_{\mathrm{REF}}$ |
| Output Drive Current ( $\pm 10 \mathrm{~V}$ ) | +5 mA ( min ) |
| Resolution | 12 Bits (1 part in 4096) |
| Accuracy |  |
| Gain Error | 0.3\% FSR (max., adjustable to zero) |
| Unipolar Offset | 30 mV (max., adjustable to zero) |
| Bipolar Offset | 60 mV (max., adjustable to zero) |
| Linearity Error | 0.05\% FSR (max.) |
| Temperature Coefficients |  |
| Gain | $\pm 60 \mathrm{PPM}$ FSR $/{ }^{\circ} \mathrm{C}$ |
| Offset | $\pm 15 \mathrm{PPM} \mathrm{FSR} /{ }^{\circ} \mathrm{C}$ |
| Differential Linearity (no missing codes over temperature range) | 10 Bits |
| Signal Dynamics |  |
| Settling time to 0.05\% FSR | $10 \mu \mathrm{~s}$ |
| Output Slew Rate | $10 \mathrm{~V} / \mu \mathrm{s}$ |

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions (1, 2, 3) <br> Width <br> Length <br> Height | $\begin{aligned} & 100 \mathrm{~mm}(3.94 \mathrm{in} .) \\ & 160 \mathrm{~mm}(6.3 \mathrm{in} .) \\ & 14 \mathrm{~mm}(0.56 \mathrm{in} .) \end{aligned}$ |
| Weight | $156 \mathrm{~g}(5.5 \mathrm{oz}$.$) \quad )$ |
| Environment <br> Operating Temperature <br> Storage Temperature <br> Relative Humidity | $\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) |
| Power Requirements <br> Analog Input/Output (RM65-5303E) <br> Analog Input (RM65-5302E) | $\begin{aligned} &+5 \mathrm{Vdc} \pm 5 \% \text { at } 425 \mathrm{~mA} \text {-typical, } 675 \mathrm{~mA} \text {-max. } \\ &+15 \mathrm{Vdc} \pm 5 \% \text { at } 30 \mathrm{~mA} \text {-typical, } 60 \mathrm{~mA}-\max . \\ &-15 \mathrm{Vdc} \pm 5 \% \text { at } 40 \mathrm{~mA} \text {-typical, } 80 \mathrm{~mA}-\max . \\ &+5 \mathrm{Vdc} \pm 5 \% \text { at } 425 \mathrm{~mA} \text {-typical, } 675 \mathrm{~mA}-\max . \\ &+15 \mathrm{Vdc} \pm 5 \% \text { at } 12 \mathrm{~mA} \text {-typical, } 25 \mathrm{~mA} \text {-max. } \\ &-15 \mathrm{Vdc} \pm 5 \% \text { at } 25 \mathrm{~mA} \text {-typical, } 50 \mathrm{~mA} \text {-max. } \end{aligned}$ |
| Connectors <br> RM 65 Bus Connector P1 <br> I/O Connector J1 | 64-pin plug ( 0.100 in. centers) per DIN 41612 (Row b not installed)-mates with Burndy P196B32R00A00L-9 or equivalent. <br> 40-pin mass termination ( 0.100 in . centers)-mates with Burndy FRS40BS4P connector or equivalent. |

## Notes:

1. 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 throuigh the bottom of the module ( 0.1 in .).
2. Length does not include the added extension due to the module ejector.
3. Dimensions conform to DIN 41612.


Module Dimensions

## RM65-5451E RM 65 ASYNCHRONOUS COMMUNICATIONS INTERFACE ADAPTER (ACIA) MODULE

## RM 65 MICROCOMPUTER MODULES

The RM65-5451E ACIA Module is one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Module products are 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.

RM 65 modules use a motherboard interconnect concept and accept any card in any slot. The $64-l i n e ~ R M ~ 65 ~ B u s ~ o f f e r s ~$ 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 AIM 65 and AIM 65/40 Microcomputers for product development and for a broad variety of portable or desk-top microcomputer applications.

## PRODUCT OVERVIEW

The RM65-5451E Asynchronous Communications Interface Adapter (ACIA) Module interfaces two independent, asynchronous serial I/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 I/O channel performs serial-to-parallel and parallel-to-serial data conversions 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.

## FEATURES

- Compact size—Approximately $4^{\prime \prime} \times 61 / 4^{\prime \prime}(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 +5 V only operation for RS-232 interface.

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-5451E | Asynchronous Communications Interface <br> Adapter (ACIA) Module |
| Order No. | Description |
| 804 | Asynchronous Communications Interface <br> Adapter (ACIA) Module User's Module |



RM65-5451E Asynchronous Communications Interface Adapter (ACIA) Module

## 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 bank-addressed, 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 parallel-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$ Vdc must be obtained from the RM 65 Bus, by removing the DC/DC voltage converter and installing two jumpers.


| Bottom (Solder Side) |  |  |  | Top (Component Side) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | Input/ Output | Pin | Signal Mnemonic | Signal Name | Input/ Output |
| 1a | GND | Ground |  | 1 c | $+5 \mathrm{~V}$ | $+5 \mathrm{Vdc}$ |  |
| 2a | BADR/ | Buffered Bank Address | 1 | 2 c | BA15/ | Buffered Address Bit 15 | 1 |
| 3 a | GND | Ground |  | 3 c | BA14/ | Buffered Address Bit 14 | 1 |
| 4 a | BA13/ | Buffered Address Bit 13 | 1 | 4 c | BA12/ | Buffered Address Bit 12 | 1 |
| 5a | BA11/ | Buffered Address Bit 11 | 1 | 5 c | GND | Ground |  |
| 6 a | BA10/ | Buffered Address Bit 10 | 1 | 6 c | BA9/ | Buffered Address Bit 9 | 1 |
| 7 a | BA8/ | Buffered Address Bit 8 | 1 | 7 c | BA7/ | *Buffered Address Bit 7 |  |
| 8 Ba | GND | Ground |  | 8 c | BA6/ | *Buffered Address Bit 6 |  |
| 9 a | BA5/ | *Buffered Address Bit 5 |  | 9 c | BA4/ | *Buffered Address Bit 4 |  |
| 10a | BA3/ | *Buffered Address Bit 3 |  | 10c | GND | Ground |  |
| 11a | BA2/ | Buffered Address Bit 2 | 1 | 11 c | BA1/ | Buffered Address Bit 1 | 1 |
| 12a | BAO/ | Buffered Address Bit 0 | 1 | 12c | B ${ }^{1} 1$ | *Buffered Phase 1 Clock |  |
| 13a | GND | Ground |  | 13c | BSYNC | *Buffered Sync |  |
| 14a | BSO | *Buffered Set Overflow |  | 14c | BDRQ1/ | Buffered DMA Request 1 |  |
| 15a | BRDY | *Buffered Ready |  | 15c | GND | Ground |  |
| 16a |  | * User Spare 1 |  | 16 c | -12V/-V | -12 Vdc/-V |  |
| 17a | +12V/+V | +12 Vdc/+V |  | 17 c . |  | * User Spare 2 |  |
| 18a | GND | Ground Line |  | 18 c | BFLT/ | *Buffered Bus Float |  |
| 19a | BDMT/ | *Buffered DMA Terminate |  | 19c | вфо | *Buffered External Phase 0 Clock |  |
| 20a |  | * User Spare 3 |  | 20 c | GND | Ground |  |
| 21a | BR/W/ | Buffered Read/Write "Not" | 1 | 21 c | BDRQ2/ | *Buffered DMA Request 2 |  |
| 22a |  | *System Spare |  | 22 c | BR/ $\bar{W}$ | *Buffered Read/Write |  |
| 23a | GND | Ground |  | 23 c | BACT/ | Buffered Bus Active | 0 |
| 24a | BIRQ/ | Buffered Interrupt Request | 0 | 24c | BNMI/ | *Buffered Non-Maskable Interrupt |  |
| 25a | Bø2/ | Buffered Phase 2 "Not" Clock | 1 | 25c | GND | Ground |  |
| 26a | Bø2 | *Buffered Phase 2 Clock |  | 26c | BRES/ | Buffered Reset | 1 |
| 27a | BD7/ | Buffered Data Bit 7 | I/O | 27c | BD6/ | Buffered Data Bit 6 | 1/0 |
| 28a | GND | Ground |  | 28 c | BD5/ | Buffered Data Bit 5 | VO |
| 29a | BD4/ | Buffered Data Bit 4 | 1/0 | 290 | BD3/ | Buffered Data Bit 3 | I/O |
| 30a | BD2/ | Buffered Data Bit 2 | 1/0 | 30c | GND | Ground |  |
| 31 a | BD1/ | Buffered Data Bit 1 | 1/0 | 312 | BDO/ | Buffered Data Bit 0 | $1 / 0$ |
| 32a | $+5 \mathrm{~V}$ | +5 Vdc |  | 32c | GND | Ground |  |

I/O Connector J1-TTY Interface

| Pin | Signal <br> Mnemonic | Signal Name | Input/Output |
| :---: | :---: | :---: | :---: |
| 1 | RTS | Request-To-Send | 0 |
| 2 | TD | Transmit Data |  |
| RD | -12 Vdc |  |  |

I/O Connector J2 and J3-RS-232 Interface

|  | Signal |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Pin | Mnemonic | Signal Name | Data Set | Data Terminal |
| 1 | GND | Ground |  |  |
| 2 | TD | Transmit Data | 1 | 0 |
| 3 | RD | Receive Data | 0 | 1 |
| 4 | RTS | Request-To-Send | 1 | 0 |
| 5 | CTS | Clear-To-Send | 0 | 1 |
| 6 | DSR | Data-Set-Ready | 0 | 1 |
| 7 | GND | Ground | 0 | 1 |
| 8 | DCD | Data-Carrier-Detected |  |  |
| $9-19$ | Not Used |  |  |  |
| 20 | DTR | Data-Terminal-Ready | Not Used |  |
| $21-26$ |  |  |  | 0 |

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions (1, 2, 3) <br> Width <br> Length <br> Height | 3.9 in. ( 100 mm ) 6.3 in. ( 160 mm ) 0.56 in . $(14 \mathrm{~mm}$ ) |
| Weight | 5.2 oz . 145 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} \end{aligned}$ <br> $0 \%$ to $85 \%$, without condensation |
| Power Requirements RS-232 Interface Operation, with DC/DC Converter TTY Operation, without DC/DC Converter | $\begin{array}{r} +5 \mathrm{Vdc} \pm 5 \% @ 0.4 \mathrm{~A}(2.0 \mathrm{~W})-\text { Typical } \\ 0.7 \mathrm{~A}(3.5 \mathrm{~W}) \text {-Maximum } \\ +5 \mathrm{Vdc} \pm 5 \% @ 0.5 \mathrm{~A}(2.5 \mathrm{~W})-\text { Maximum } \\ +12 \mathrm{Vdc} \pm 10 \% @ 0.12 \mathrm{~A}(1.4 \mathrm{~W})-\text { Maximum } \\ -12 \mathrm{Vdc} \pm 10 \% @ 0.12 \mathrm{~A}(1.4 \mathrm{~W}) \text {-Maximum } \end{array}$ |
| Interfaces RM 65 Bus <br> I/O Interface RS-232 TTY | 64 -pin plug ( 0.100 in . centers) per DIN 41612 (Row b not installed) <br> 26-pin mass termination connector ( 0.100 in . centers) <br> 4 -pin plug ( 0.156 in. centers) |

Notes:

1. 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. Length does not include extensions beyond the edge of the module due to connectors or the module ejector.
3. Dimensions conform to DIN 41612.


## RM65-7004E AND RM65-7004NE RM 65 4-SLOT PIGGYBACK MODULE STACK AND MOTHERBOARD

## RM 65 MICROCOMPUTER MODULES

The RM65-7004E 4-Slot Piggyback Module Stack (PMS) and RM65-7004NE Motherboard is one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Modules products are 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.

RM 65 module products use a motherboard interconnect concept and accept 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 AIM 65 and AIM 65/40 Microcomputers 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 the AIM 65 Microcomputer by use of the PMS. When connected to the AIM 65 Master Module through the Buffer/Adapter Module, the PMS may be mounted over, under, or behind the AIM 65 Master Module 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.

The 4-Slot Motherboard is a printed circuit board (PCB) less four connectors, mini-terminal strip, four mounting blocks used to fasten the PCB to the card cage. Connectors, mini-terminal strip and custom mounting blocks can easily be added to meet unique installation requirements.

## 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}$, GND)
- Predrilled holes for various mounting configurations
- Assembled, tested and warranted


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-7004E | 4-Slot Piggyback Module Stack |
| RM65-7004NE | 4-Slot Motherboard |



RM65-7004E 4-Slot Piggyback Module Stack (PMS)

RM65-7004E • RM65-7004NE 4-Slot Piggyback Module Stack and Motherboard
RM 65 Bus Pin Assignments


## MOTHERBOARD CONNECTION AND MODULE INSTALLATION

Connect power to TB1. The power lines should be long enough to allow the PMS to be oriented and positioned as required.

## WARNING

The external power supplies must be turned off before connecting to TB1.
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 $+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.
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.
f. Connect GND from the $-12 \mathrm{~V} /-\mathrm{V}$ power supply to either " G " terminal.

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.

Attach an axial cooling fan to the left side of the PMS. Connect the cooling fan power leads to the required power supply.

The following $35 / 8$ inch cooling fans or equivalent are recommended:

## Manufacturer-ETRI Inc

- Model 760-99XW-182-11115*
$115 \mathrm{Vac}, 50 / 60 \mathrm{~Hz}, 6$ watts 2500 RPM, 30 CFM 10 oz .
- Módel 760-99XW-181-11220*
$220 \mathrm{Vac}, 50 / 60 \mathrm{~Hz}, 6$ watts
2500 RPM, 30 CFM 10 oz .
*Requires plug-in power cord, 30 " long-Model 760-9601-6.


## Manufacturer-ROTRON Inc

- Model WA2F79** $115 \mathrm{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.

## NOTE

ETRI Finger guard Model 760-9901-43 may be used with any of these fans.

Install a module in the PMS as follows:

## CAUTION

Power must be 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.

Remove a module from the PMS as follows:

## 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. Pull the module straight back until it is free from the card slot guides.

RM65-7004E•RM65-7004NE 4-Slot Piggyback Module Stack and Motherboard

## 4-CONNECTOR MOTHERBOARD <br> ASSEMBLY

The RM65-7004NE 4-slot motherboard can be assembled as follows:
a. Install up to four module connectors (receptacles) from the front of the PCB. Be sure to observe correct connector orientation. The following connectors or their equivalent, may be used:

| Part No. | Manufacturer |
| :---: | :--- |
| P196B32R00KOOK9 | Burndy Corporation <br> Norwalk, CT 06856 |
| 96 S-6033-0531-3 | Winchester Electronics <br> Oakville, CT 06779 |
| $00-8257-096-649-124$ | Elco Corporation <br> Huntington, PA 16652 |

b. Solder the receptacle pin connections to the back of the PCB.
c. Install the mini-terminal strip to the power supply connection holes from the back of the PCB.
d. Solder the mini-terminal strip leads to the front of the PCB.


4-Slot Piggyback Module Stack and Motherboard

## SPECIFICATIONS




RM65-7004NE 4-Slot Motherboard (Rear View)

## RM65-7008E AND RM65-7008NE RM 65 8-SLOT CARD CAGE AND MOTHERBOARD

## RM 65 MICROCOMPUTER MODULES

The RM65-7008E 8-Slot Card Cage and RM65-7008NE 8-Slot Motherboard is one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Module products are 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.

RM 65 modules use a motherboard interconnect concept and accept 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 AIM 65 and AIM 65/40 Microcomputers for product development and desktop microcomputer applications.

## PRODUCT OVERVIEW

The RM65-7008E 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 the AIM 65 Microcomputer by use of the 8 -slot card cage. When connected to the AIM 65 Master Module through the Buffer/Adapter Module, the card cage may be mounted over, under, or behind the AIM 65 Master Module 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.

The RM65-7008NE 8-Slot Motherboard is a printed circuit board (PCB) less eight connectors, three filter capacitors, two miniterminal strips and eight mounting blocks used to fasten the PCB to the card cage. Connectors, mini-terminal strips, filter capacitors and custom mounting blocks as needed can easily be added to meet unique installation requirements.

## 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 V , $+12 \mathrm{~V} /+\mathrm{V},-12 \mathrm{~V} /-\mathrm{V}$, 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}$.


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-7008E | 8-Slot Card Cage |
| RM65-7008NE | 8-Slot Motherboard |



RM65-7008E 8-Slot Card Cage

## RM 65 Bus Pin Assignments

| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | PIn | Signal Mnemonic | Slgnal Name |
| 1 a | GND | Ground | 15 | +5V | $+5 \mathrm{Vdc}$ |
| 2 a | BADR/ | Buffered Bank Address | 2 c | BA15/ | Buffered Address Bit 15 |
| 3 a | GND | Ground | 3 c | BA14/ | Buffered Address Bit 14 |
| 4a | BA13/ | Buffered Address Bit 13 | 4 c | BA12/ | Buffered Address Bit 12 |
| 5a | BA11/ | Buffered Address Bit 11 | 5 c | GND | Ground |
| 6 a | BA10/ | Buffered Address Bit 10 | 6 c | BA9/ | Buffered Address Bit 9 |
| 7a | BA8/ | Buffered Address Bit 8 | 7 c | BA7/ | Buffered Address Bit 7 |
| 8 a | GND | Ground | 8 c | BA6/ | Buffered Address Bit 6 |
| 9 a | BA5/ | Buffered Address Bit 5 | 9 c | BA4/ | Buffered Address Bit 4 |
| 10a | BA3/ | Buffered Address Bit 3 | 10c | GND | Ground |
| 11a | BA2/ | Buffered Address Bit 2 | 119 | BA1/ | Buffered Address Bit 1 |
| 12a | BAO/ | Buffered Address Bit 0 | 12 c | B ${ }_{1} 1$ | Buffered Phase 1 Clock |
| 13a | GND | Ground | 13c | BSYNC | Buffered Sync |
| 14a | BSO | Buffered Set Overflow | 14c | BDRQ1/ | Buffered DMA Request 1 |
| 15a | BRDY | Buffered Ready | 15c | GND | Ground |
| 16a |  | User Spare 1 | 16c | $-12 \mathrm{~V} /-\mathrm{V}$ | -12 Vdc/-V |
| 17a | +12V/+V | +12 Vdc/+V | 17 c |  | User Spare 2 |
| 18a | GND | Ground Line | 18c | BFLT/ | Buffered Bus Float |
| 19a | BDMT/ | Buffered DMA Terminate | 19c | Вфо | Buffered External Phase 0 Clock |
| 20a |  | User Spare 3 | 20c | GND | Ground |
| 21a | BR// $/$ / | Buffered Read/Write "Not" | 21c | BDRQ2/ | Buffered DMA Request 2 |
| 22a |  | System Spare | 22c | BR/W | Buffered Read/Write |
| 23a | GND | Ground | 23c | BACT/ | Buffered Bus Active |
| 24a | BIRQ/ | Buffered Interrupt Request | 24c | BNMI/ | Buffered Non-Maskable Interrupt |
| 25a | B $\varnothing 21$ | Buffered Phase 2 "Not" Clock | 25 c | GND | Ground |
| 26a | Bø2 | Buffered Phase 2 Clock | 26c | BRES/ | Buffered Reset |
| 27a | BD7/ | Buffered Data Bit 7 | 27c | BD6/ | Buffered Data Bit 6 |
| 28a | GND | Ground | 28 c | BD5/ | Buffered Data Bit 5 |
| 29a | BD4/ | Buffered Data Bit 4 | 29c | BD3/ | Buffered Data Bit 3 |
| 30a | BD2/ | Buffered Data Bit 2 | 30c | GND | Ground |
| 31a | BD1/ | Buffered Data Bit 1 | 31c | BD0/ | Buffered Data Bit 0 |
| 32a | +5V | $+5 \mathrm{Vdc}$ | 32c | GND | Ground |

## MOTHERBOARD CONNECTION AND MODULE INSTALLATION

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

The external power supplies must be turned off before connecting to TB1 or TB2.
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

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 TB 2 if more than six modules require +12 V . Connect +V to the other terminal strip.

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

## NOTES

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.

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.

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

Adequate cooling must be provided to keep the temperature of the installed modules within specified operating limits.

Install a module in the card cage as follows:

## CAUTION

Power must be 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 \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 module.
c. Ensure that the module connector is positoned 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.

Remove a module from the card cage as follows:

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

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| 8-Slot Card Cage Dimensions <br> Width <br> Length <br> Height <br> Module Separation <br> Slot 1: Centerline to Inside Top Cover <br> Other Slots: Centerline to Centerline | 4.96 in. ( 126 mm ) <br> 8.00 in . 203 mm ) <br> 6.40 in. $(162.6 \mathrm{~mm})$ <br> 0.85 in. ( 22 mm ) <br> 0.6 in. ( 15 mm ) |
| Weight | $1 \mathrm{lb} .6 \mathrm{oz} .(624 \mathrm{~g})$ |
| 8-Slot Motherboard Dimensions <br> Width <br> Length <br> Height | 3.938 in. $(100 \mathrm{~mm})$ 5.725 in. ( 145 mm ) 0.062 in. ( 1.6 mm ) |
| Hole Size Uncoded A B | $0.037 \mathrm{in} .(0.940 \mathrm{~mm})$ dia. 0.044 in. ( 1.12 mm ) dia 0.128 in. ( 3.25 mm ) dia. |



8-Slot Card Cage Dimensions

## 8-SLOT MOTHERBOARD ASSEMBLY

The RM65-7008NE 8-slot motherboard can be assembled using the printed circuit board as follows:
a. Install up to eight module connectors (receptacles) from the front of the PCB. Be sure to observe correct connector or:entation. The following connectors or their equivalent, may be used:

| Part No. | Manufacturer |
| :---: | :---: |
| P196B32R00K00K9 | Burndy Corporation Norwalk, CT 06856 |
| 96S-6033-0531-3 | Winchester Electronics Oakville, CT 06779 |
| 00-8257-096-649-124 | Elco Corporation Huntington, PA 16652 |

b. Solder the receptacle pin connections to the back of the PCB.
c. Install three 100 ufd, 25 Vdc capacitors from +5 V to GND, $+V$ to GND, and $-V$ to GND, from the front of the PCB. Be sure to observe correct polarity.
d. Solder the capacitor leads to the back of the PCB.
e. Install one or two miniterminal strips to the power supply connection holes from the back of the PCB.
f. Solder the miniterminal strip leads to the front of the PCB.


RM65-7008NE 8-Slot Motherboard (Rear View)

## RM65-7016E AND RM65-7016NE RM 65 16-SLOT CARD CAGE AND MOTHERBOARD

## RM 65 MICROCOMPUTER MODULES

The RM65-7016E 16-Slot Card Cage and RM65-7016NE Motherboard are one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Modules products are 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.

RM 65 modules use a motherboard interconnect concept and accept 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 AIM 65 and AIM 65/40 Microcomputers for product development and desktop microcomputer applications.

## PRODUCT OVERVIEW

The RM65-7016E 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 the AIM 65 Microcomputer by use of the 16 -slot card cage. When connected to the AIM 65 Master Module through the Adapter/Buffer, the card cage may be mounted over, under, or behind the AIM 65 Master Module 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.

The RM65-7016NE 16-Slot Motherboard is a printed circuit board (PCB) less 16 connectors, two mini-terminal strips, three filter capacitors and 16 mounting blocks used to fasten the PCB to the RM65-7016E card cage. Connectors, mini-terminal strips, filter capacitors, and custom mounting blocks as needed can easily be added to meet unique installation requirements.

## FEATURES

- 16-slot card cage with integral module guides
- Rugged, yet lightweight construction
- Screw-down terminals for connecting external power ( +5 V , $+12 \mathrm{~V} /+\mathrm{V},-12 \mathrm{~V} /-\mathrm{V}$, 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}$.


## ORDERING INFORMATION

| Part No. | Description |
| :--- | :--- |
| RM65-7016E | 16-Slot Card Cage |
| RM65-7016NE | 16-Slot Motherboard |



RM65-7016E 16-Slot Card Cage

RM 65 Bus Pin Assignments

| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | Pin | Signal Mnemonic | Signal Name |
| 12 | GND | Ground | 1 c | +5V | $+5 \mathrm{Vdc}$ |
| 2 a | BADR/ | Buffered Bank Address | 2 c | BA15/ | Buffered Address Bit 15 |
| 3 a | GND | Ground | 3 c | BA14/ | Buffered Address Bit 14 |
| 4 a | BA13/ | Buffered Address Bit 13 | 4 c | BA12/ | Buffered Address Bit 12 |
| 5 a | BA11/ | Buffered Address Bit 11 | 5 c | GND | Ground |
| 6 a | BA10/ | Buffered Address Bit 10 | 6 c | BA9/ | Buffered Address Bit 9 |
| 7 a | BA8/ | Buffered Address Bit 8 | 7 c | BA7/ | Buffered Address Bit 7 |
| 8 a | GND | Ground | 8 c | BA6/ | Buffered Address Bit 6 |
| 9 a | BA5/ | Buffered Address Bit 5 | 9 c | BA4/ | Buffered Address Bit 4 |
| 10a | BA3/ | Buffered Address Bit 3 | 10c | GND | Ground |
| 11a | BA2/ | Buffered Address Bit 2 | 11c | BA1/ | Buffered Address Bit 1 |
| 12a | BAO/ | Buffered Address Bit 0 | 12c | B ${ }_{1} 1$ | Buffered Phase 1 Clock |
| 13a | GND | Ground | 13c | BSYNC | Buffered Sync |
| 14a | BSO | Buffered Set Overflow | 14 c | BDRQ1/ | Buffered DMA Request 1 |
| 15a | BRDY | Buffered Ready | 15 c | GND | Ground |
| 16a |  | User Spare 1 | 16 c | $-12 \mathrm{~V} /-\mathrm{V}$ | $-12 \mathrm{Vdc} /-\mathrm{V}$ |
| 17a | +12V/+V | +12 Vdc/+V | 17 c |  | User Spare 2 |
| 18a | GND | Ground Line | 18 c | BFLT/ | Buffered Bus Float |
| 19a | BDMT/ | Buffered DMA Terminate | 19c | вфо | Buffered External Phase 0 Clock |
| 20a |  | User Spare 3 | 20c | GND | Ground |
| 21a | $\mathrm{BR} / \overline{\mathrm{W}} /$ | Buffered Read/Write "Not" | 21 c | BDRQ2/ | Buffered DMA Request 2 |
| 22a |  | System Spare | 22c | BR $\bar{W}$ | Buffered Read/Write |
| 23a | GND | Ground | 23 c | BACT/ | Buffered Bus Active |
| 24a | BIRQ/ | Buffered Interrupt Request | 24 c | BNMI/ | Buffered Non-Maskable Interrupt |
| 25a | Bø2/ | Buffered Phase 2 "Not" Clock | 25 c | GND | Ground |
| 26a | Bø2 | Buffered Phase 2 Clock | 26 c | BRES/ | Buffered Reset |
| 27a | BD7] | Buffered Data Bit 7 | 27 c | BD6/ | Buffered Data Bit 6 |
| 28a | GND | Ground | 28c | BD5/ | Buffered Data Bit 5 |
| 29a | BD4/ | Buffered Data Bit 4 | 29 c | BD3/ | Buffered Data Bit 3 |
| 30a | BD2/ | Buffered Data Bit 2 | 30c | GND | Ground |
| 31a | BD1/ | Buffered Data Bit 1 | 31 c | BD0/ | Buffered Data Bit 0 |
| 32a | +5V | +5 Vdc | 32c | GND | Ground |

## MOTHERBOARD CONNECTION AND MODULE INSTALLATION

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

The external power supplies must be turned off before connecting to TB1 or TB2.
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 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 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 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.

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.

Install a module in the card cage as follows:

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

Remove a module from the card cage as follows:

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

## SPECIFICATIONS

| Characteristic | Value |
| :---: | :---: |
| RM65-7016E Card Cage Dimensions Width Length Height | 4.96 in. $(126 \mathrm{~mm})$ <br> $8.00 \mathrm{in}$. ( 203 mm ) <br> $11.20 \mathrm{in} .(285 \mathrm{~mm})$ |
| Weight | $2 \mathrm{lb} .10 \mathrm{oz} .(1.20 \mathrm{~kg})$ |
| Module Separation: <br> Slot 1: Centerline to Inside Top Cover Other Slots: Centerline to Centerline | 0.85 in. ( 22 mm ) <br> 0.6 in. ( 15 mm ) |
| RM65-7016NE Motherboard Dimensions Width Length Height | 3.938 in. ( 100 mm ) 10.525 in. ( 267 mm ) 0.062 in. ( 1.6 mm ) |
| Hole Size Uncoded A B | 0.037 in . $(0.940 \mathrm{~mm})$ dia. 0.044 in. ( 1.12 mm ) dia. 0.128 in. ( 3.25 mm ) dia. |



## 16-CONNECTOR MOTHERBOARD ASSEMBLY

The RM65-7016NE 16-slot motherboard can be assembled as follows:

Install up to 16 module connectors (receptacies) from the front of the PCB. Be sure to observe correct connector orientation.
a. The following connectors or their equivalent, may be used:

| Part No. | Manufacturer |
| :--- | :--- |
| P196B32R00K00K9 | Burndy Corporation <br> Norwalk, CT 06856 |
| 96 S-6033-0531-3 | Winchester Electronics <br> Oakville, CT 06779 |
| $00-8257-096-649-124$ | Elco Corporation <br> Huntington, PA 16652 |

b. Solder the receptacle pin connections to the back of the PCB.
c. Install three 100 ufd, 25 VDC capacitors from +5 V to GND, $+V$ to GND, and $-V$ to GND, from the front of the PCB. Be sure to observe correct polarity.
d. Solder the capacitor leads to the back of the PCB.
e. Install one or two mini-terminal strips to the power supply connection holes from the back of the PCB.
f. Solder the mini-terminal strip leads to the front of the PCB.


16-Slot Motherboard (Rear View)

## RM65-7101E RM 65 SINGLE CARD ADAPTER FOR AIM 65

## RM 65 MICROCOMPUTER MODULES

The RM65-7101E Single Card Adapter for the AIM 65 Microcomputer is one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Module products are 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.

RM 65 module products use a motherboard interconnect concept and accept 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 AIM 65 and AIM 65/40 Microcomputers for product development and for a broad variety of portable or desktop microcomputer applications.

## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-7101E | Single Card Adapter for AIM 65 |

## FEATURES

- Drives one RM 65 Bus-compatible module
- Provision for power and ground routing
- Extends address, data and control lines
- Pin and socket bus connector
- Fully assembled, tested and warranted


## PRODUCT OVERVIEW

The RM65-7101E Single-Card Adapter allows one RM 65 Bus compatible module to be connected to the AIM 65 Master Module, through the AIM 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.


RM65-7101E Single Card Adapter for AIM 65

## 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 bits from the AIM 65 to the connected RM 65 module. The bank address line is held high to address Bank 0 (lower 65K) 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.

## POWER CONNECTION

## +5 VOLT POWER CONNECTION

The +5 volt $(+5 \mathrm{~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 $A / 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 +5V POWER SOURCE CONNECTION

a. Install Jumper $A / B$ in the $A$ position.
b. 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.5A, the external connection to +5 V must be used or the AIM 65 Master Module may be damaged.

## EXTERNAL +5V POWER SOURCE CONNECTION

a. Install Jumper $A B$ in the $B$ position.
b. Connect the +5 V lead from the external power supply to the +5 V connection on TB1.
c. 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.
a. 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 J1 pin 17a.
b. 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 $\mathrm{J} 1 \mathrm{pin} \mathrm{16c}$.

## INSTALLATION

Before installing the module, inspect for damage and grease, dirt, liquid or other foreign material that will affect performance.

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

## REMOVAL

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

RM 65 Bus Pin Assignments

| Bottom (Solder Side) |  |  |  | Top (Component Side) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | 1/0 | Pin | Signal Mnemonic | Signal Name | I/O |
| 1 a | GND | Ground |  | 1 c | +5V | +5 Vdc. |  |
| 2 a | BADR/ | Buffered Bank Address | 0 | 2 c | BA15/ | Buffered Address Bit 15 | 0 |
| 3 a | GND | Ground |  | 3 c | BA14/ | Buffered Address Bit 14 | 0 |
| 4a | BA13/ | Buffered Address Bit 13 | 0 | 4 c | BA12/ | Buffered Address Bit 12 | 0 |
| 5a | BA11/ | Buffered Address Bit 11 | 0 | 5 c | GND | Ground |  |
| 6 a | BA10/ | Buffered Address Bit 10 | 0 | 6 c | BA9/ | Buffered Address Bit 9 | 0 |
| 7 a | BA8/ | Buffered Address Bit 8 | 0 | 7 c | BA7/ | Buffered Address Bit 7 | 0 |
| 8 a | GND | Ground |  | 8 c | BÄ6/ | Buffered Address Bit 6 | 0 |
| 9 a | BA5/ | Buffered Address Bit 5 | 0 | 9 c | BA4/ | Buffered Address Bit 4 | 0 |
| 10a | BA3/ | Buffered Address Bit 3 | 0 | 10c | GND | Ground |  |
| 11a | BA2/ | Buffered Address Bit 2 | 0 | 11c | BA1/ | Buffered Address Bit 1 | 0 |
| 12a | BAO/ | Buffered Address Bit 0 | 0 | 12c | B ${ }_{1} 1$ | Buffered Phase 1 Clock | 0 |
| 13a | GND | Ground |  | 13 c | BSYNC | Buffered Sync | 0 |
| 14a | BSO | Buffered Set Overflow | 1 | 14 c | BDRQ1/ | *Buffered DMA Request 1 |  |
| 15a | BRDY | Buffered Ready | 1 | 15 c | GND | Ground |  |
| 16a |  | *User Spare 1 |  | 16c | -12V/-V | -12 Vdc/-V |  |
| 17a | $+12 \mathrm{~V} /+\mathrm{V}$ | + $12 \mathrm{Vdc} /+\mathrm{V}$ |  | 17 c |  | *User Spare 2 |  |
| 18a | GND | Ground Line |  | 18c | BFLT/ | *Buffered Bus Float | 1 |
| 19a | BDMT/ | *Buffered DMA Terminate |  | 190 | Bф0 | *Buffered External Phase 0 Clock |  |
| 20a |  | * User Spare 3 |  | 20c | GND | Ground |  |
| 21a | BR/W/ | Buffered Read/Write "Not" | 0 | 21c | BDRQ2/ | *Buffered DMA Request 2 |  |
| 22a |  | *System Spare |  | 22 c | $B R / \bar{W}$ | Buffered Read/Write | 0 |
| 23a | GND | Ground |  | 23 c | BACT/ | Buffered Bus Active | I |
| 24a | BIRQ/ | Buffered Interrupt Request | 1 | 24 c | BNMI/ | Buffered Non-Maskable Interrupt | 1 |
| 25a | Bф2/ | Buffered Phase 2 "Not" Clock | 0 | 25c | GND | Ground |  |
| 26a | B 12 | Buffered Phase 2 Clock | 0 | 26c | BRES/ | Buffered Reset | 0 |
| 27a | BD7/ | Buffered Data Bit 7 | I/O | 27c | BD6/ | Buffered Data Bit 6 | I/O |
| 28a | GND | Ground |  | 28c | BD5/ | Buffered Data Bit 5 | I/O |
| 29a | BD4/ | Buffered Data Bit 4 | 1/O | 290 | BD3/ | Buffered Data Bit 3 | I/O |
| 30a | BD2/ | Buffered Data Bit 2 | 1/0 | 30c | GND | Ground |  |
| 31a | BD1/ | Buffered Data Bit 1 | 1/O | 31 c | BDO/ | Buffered Data Bit 0 | I'O |
| 32a | +5V | +5 Vdc |  | 32c | GND | Ground |  |

## SINGLE CARD ADAPTER SCHEMATIC



NOTE: LNLESS OTHERWISE SPECIFIED

1. REF ASSY DWG PAIO-DOIO

2 PINS $1 a, 3 a, 5 c, 8 a, 10 c, 13 a, 15 c$, 18a, 20c, 23a, 25c, $28 a, 30 c$,
$32 C$ SHALL BE CONNECTED TO GROUND.
3. PINS $/ c, 3 Z_{a}$ ON ELRO CONNECTOR AND PINS $x a x c, y_{a}, y_{c}$, IC, sZa ON US. CONNECTOR SHALL BE TIED TO +5V.

AIM 65 Expansion Connector Pin Assignments

| Top (Component Side) |  |  |  | Bottom (Solder Side) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | Input/ Output | Pin | Signal Mnemonic | Signal Name | Input/ Output |
| 1 | SYNC | Sync | 1 | A | AO | Address Bit 0 | 1 |
| 2 | RDY | Ready | 0 | B | A1 | Address Bit 1 | 1 |
| 3 | $\not{ }^{1}$ | Phase 1 Clock | 1 | C | A2 | Address Bit 2 | I |
| 4 | $\overline{\mathrm{R} Q}$ | Interrupt Request | 0 | D | A3 | Address Bit 3 | 1 |
| 5 | S.O. | Set Overflow | 0 | E | A4 | Address Bit 4 | 1 |
| 6 | NMI | Non-Maskable Interrupt | 0 | F | A5 | Address Bit 5 | 1 |
| 7 | RES | Reset | 1 | H | A6 | Address Bit 6 | I |
| 8 | D7 | Data Bit 7 | 1/0 | $J$ | A7 | Address Bit 7 | 1 |
| 9 | D6 | Data Bit 6 | 1/0 | K | A8 | Address Bit 8 | I |
| 10 | D5 | Data Bit 5 | 1/0 | L | A9 | Address Bit 9 | I |
| 11 | D4 | Data Bit 4 | 1/0 | M | A10 | Address Bit 10 | 1 |
| 12 | D3 | Data Bit 3 | 1/0 | N | A11 | Address Bit 11 | 1 |
| 13 | D2 | Data Bit 2 | I/O | P | A12 | Address Bit 12 | 1 |
| 14 | D1 | Data Bit 1 | 1/0 | R | A13 | Address Bit 13 | 1 |
| 15 | D0 | Data Bit 0 | 1/0 | S | A14 | Address Bit 14 | 1 |
| 16 | -12V | *-12 Vdc |  | T | A15 | Address Bit 15 | 1 |
| 17 | +12V | *+12 Vdc |  | U | SYS $\emptyset 2$ | System Phase 2 Clock | 1 |
| 18 | CS8 | *Chip Select 8 |  | V | SYS R/W | System Read/Write | 1 |
| 19 | CS9 | *Chip Select 9 |  | W | R/W | Read/Write "Not" | 1 |
| 20 | CSA | Chip Select A |  | X | *TEST | Test |  |
| 21 | +5V | $+5 \mathrm{Vdc}$ | 1 | Y | $\overline{6}$ | Phase 2 Clock "Not" | 1 |
| 22 | GND | Ground |  | z | *RAM R/W | RAM Read/Write |  |



Module Dimensions

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions (1, 2, 3) |  |
| Width | 4.4 in. (111 mm) |
| Length | 3.7 in. (93 mm) |
| Height | 0.56 in . $(14 \mathrm{~mm})$ |
| Weight | 3.0 oz. (90 g) |
| 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) |
| Power | $\begin{gathered} +5 \mathrm{~V} \pm 5 \% 110 \mathrm{~mA}(0.55 \mathrm{~W})-\text { Typical } \\ 200 \mathrm{~mA}(1.00 \mathrm{~W})-\text { Maximum } \end{gathered}$ |
| Interface |  |
| AIM 65 Expansion Connector | 22/44-edge receptacle (0.156 in. centers) |
| RM 65 Bus | 64 -pin receptacle ( 0.100 centers) per DIN 41612 (Row b is not installed) |
| Notes: <br> 1. 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 .). <br> 2. Length does not include extensions beyond the edge of the module due to connectors. <br> 3. Dimensions conform to DIN 41612. |  |
|  |  |
|  |  |
|  |  |

# RM65-7102E <br> RM 65 IEEE-488 BUS INTERFACE MODULE 

## RM 65 MICROCOMPUTER MODULES

The RM65-7102E IEEE-48 Bus Interface Module is one of the hardware options available for the RM 65 Microcomputer Module family.
RM 65 Microcomputer Module products are 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.
RM 65 modules use a motherboard interconnect concept and accept 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 AIM 65 and AIM 65/40 Microcomputers for product development and for a broad variety of portable or desktop microcomputer applications.

## PRODUCT OVERVIEW

The RM 65 IEEE-488 Bus Interface Module connects an AIM 65, AIM 65/40 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 System 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.

## ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-7102E | IEEE-488 Bus Interface Module |
| Order No. | Description |
| 815 | IEEE-488 Bus Interface Module User's Manual <br> (included with RM65-7102E) |

## FEATURES

- Compact size-about $4^{\prime \prime} \times 61 / 2^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Pin and socket bus connection
- 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 I/O
-Bank Selection to one or both 65K banks
- Jumper for ROM enable/disable
- LEDs show current address register contents
- Supports DMA data transfers
- +5 V operation
- Fully assembled, tested and warranted


RM65-7102E IEEE-488 Bus Interface Module

## 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 4K 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 cóntrol of the IEEE-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 IEEE-488 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 inter-rupt-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 allow 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.

The firmware is compatible with the input/output functions in the AIM 65 Debug Monitor and the AIM 65/40 VO ROM.


IEEE-488 Bus Interface Module Block Diagram

IEEE-488 Bus Interface Connector Pin Assignments

| Pin | Signal Mnemonic | Signal Name | Input/ Output | Pin | Signal Mnemonic | Signal Name | Input/ Output |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | D101 | Data Input/Output 1 | 1/0 | 13 | D105 | Data Input/Output 5 | I/O |
| 2 | D102 | Data Input/Output 2 | 1/0 | 14 | D106 | Data Input/Output 6 | vo |
| 3 | D103 | Data Input/Output 3 | 1/0 | 15 | D107 | Data Input/Output 7 | 1/0 |
| 4 | D104 | Data Input/Output 4 | VO | 16 | D108 | Data Input/Output 8 | 1/0 |
| 5 | EOI | End or Identify | $1 / \mathrm{O}$ | 17. | REN | Remote Enable | 1/O |
| 6 | DAV | Data Available | 1/O | 18 | GND | Ground | N/A |
| 7 | NRFD | Not Ready for Data | 1/0 | 19 | GND | Ground | N/A |
| 8 | NDAC | Not Data Accepted | 1/0 | 20 | GND | Ground | N/A |
| 9 | IFC | Interface Clear | 1/O | 21 | GND | Ground | N/A |
| 10 | SRQ | Service Request | $1 / \mathrm{O}$ | 22 | GND | Ground | N/A |
| 11 | ATN | Attention | 1/0 | 23 | GND | Ground | N/A |
| 12 | SHIELD | Ground | N/A | 24 | GND | Logic Ground | N/A |

External Trigger Pin Assignments

| Pin | Signal Mnemonic | Signal Name | Input/Output |
| :---: | :---: | :---: | :---: |
| 1 | TRIG | Trigger Out <br> Ground | O |
| 2 | GND |  |  |

RM 65 Bus Pin Assignments

| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | Pin | Signal Mnemonic | Signal Name |
| 1 a | GND | Ground | 1 c | $+5 \mathrm{~V}$ | +5 Vdc |
| 2a | BADR/ | Buffered Bank Address | 2 c | BA15/ | Buffered Address Bit 15 |
| 3 a | GND | Ground | 3 c | BA14/ | Buffered Address Bit 14 |
| 4a | BA13/ | Buffered Address Bit 13 | 4 c | BA12/ | Buffered Address Bit 12 |
| 5 a | BA11/ | Buffered Address Bit 11 | 5 c | GND | Ground |
| 6 a | BA10/ | Buffered Address Bit 10 | 6 c | BA9/ | Buffered Address Bit 9 |
| 7 a | BA8/ | Buffered Address Bit 8 | 7 c | BA7/ | Buffered Address Bit 7 |
| 8 a | GND | Ground | 8 c | BA6/ | Buffered Address Bit 6 |
| 9 a | BA5/ | Buffered Address Bit 5 | 9 c | BA4/ | Buffered Address Bit 4 |
| 10a | BA3/ | Buffered Address Bit 3 | 10c | GND | Ground |
| 11a | BA2/ | Buffered Address Bit 2 | 11c | BA1/ | Buffered Address Bit 1 |
| 12a | BAO/ | Buffered Address Bit 0 | 12 c | B $\quad 1$ | *Buffered Phase 1 Clock |
| 13a | GND | Ground | 13 c | BSYNC | *Buffered Sync |
| 14a | BSO | *Buffered Set Overflow | 14 c | BDRQ1/ | Buffered DMA Request 1 |
| 15a | BRDY | *Buffered Ready | 15 c | GND | Ground |
| 16a |  | *User Spare 1 | 16 c | -12V/-V | *-12 Vdc/-V |
| 17a | $+12 \mathrm{~V} /+\mathrm{V}$ | *+12 Vdc/+V | 17 c |  | *User Spare 2 |
| 18a | GND | Ground Line | 18 c | BFLT/ | *Buffered Bus Float |
| 19a | BDMT/ | *Buffered DMA Terminate | 190 | вфо | *Buffered External Phase 0 Clock |
| 20a |  | *User Spare 3 | 20c | GND | Ground |
| 21a | $\mathrm{BR} / \overline{\mathrm{W}} /$ | Buffered Read/Write "Not" | 21 c | BDRQ2/ | Buffered DMA Request 2 |
| 22a |  | *System Spare | 22c | BR/W | Buffered Read/Write |
| 23a | GND | Ground | 23c | BACT/ | Buffered Bus Active |
| 24a | BIRQ/ | Buffered Interrupt Request | 24 c | BNMI/ | *Buffered Non-Maskable Interrupt |
| 25a | Bф2/ | Buffered Phase 2 "Not" Clock | 25 c | GND | Ground |
| 26a | B $¢ 2$ | Buffered Phase 2 Clock | 26 c | BRES/ | Buffered Reset |
| 27a | BD7/ | Buffered Data Bit 7 | 27 c | BD6/ | Buffered Data Bit 6 |
| 28a | GND | Ground | 28c | BD5/ | Buffered Data Bit 5 |
| 29a | BD4/ | Buffered Data Bit 4 | 29 C | BD3/ | Buffered Data Bit 3 |
| 30a | BD2/ | Buffered Data Bit 2 | 30 c | GND | Ground |
| 31a | BD1/ | Buffered Data Bit 1 | 31 c | BDO/ | Buffered Data Bit 0 |
| 32a | +5V | +5 Vdc | 32c | GND | Ground |
| te: Not us | his module. |  |  |  |  |

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions (1, 2, 3) Width Length Height | 3.9 in . ( 100 mm ) 6.3 in. $(160 \mathrm{~mm}$ ) $0.56 \mathrm{in} .(14 \mathrm{~mm})$ |
| Weight | 5.0 oz. (140 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 | $\begin{array}{r} +5 \mathrm{Vdc} \pm 5 \% @ 0.65 \mathrm{~A}(3.25 \mathrm{~W}) \text {-Typical } \\ 1.0 \mathrm{~A}(5.25 \mathrm{~W}) \text {-Maximum } \end{array}$ |
| Interface <br> RM 65 Bus Interface <br> Module <br> I/O Interface <br> Cable Receptacle <br> Trigger Connector <br> IEEE-488 Bus Interface Cable IEEE-488 Bus Connector <br> Module Connector <br> Cable Length <br> Type <br> Number of Conductors <br> Wire Size | 64-pin plug ( 0.100 in . centers) per DIN 41612 (Row b not installed) <br> 26-pin mass terminated ( 0.100 in . centers) <br> Two vertical wire wrap pins ( 0.3 in . high on 0.200 in . centers) <br> 24-pin mass terminated ( 2.16 mm centers) with metric thread lock screws (Amphenol 57 or equivalent) <br> 26-pin mass terminated ( 0.100 in . centers) <br> 8 inches <br> Flat ribbon <br> 24 <br> \#28 AWG |
| Notes: <br> 1. Height includes the maximum values for thickness ( 0.062 in.), and pin extension <br> 2. Length does not include the added exten <br> 3. Dimensions conform to DIN 41612. | above the board surface ( 0.4 in . for populated modules), printed circuit board f the module ( 0.1 in .). ule ejector. |

3. Dimensions conform to DIN 41612.


Module Dimensions

## RM65-7104E RM 65 ADAPTER/BUFFER FOR AIM 65

## RM 65 MICROCOMPUTER MODULES

RM 65 Microcomputer Module products are 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.

RM 65 Module products use a motherboard interconnect concept and accept 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

| Part No. | Description |
| :--- | :---: |
| RM65-7104E | Adapter Buffer for AIM 65 |

## FEATURES

- RM 65 Bus Compatible
- Buffered address data and control lines
- Drives up to 15 modules
- Fully assembled, tested and warranted


## PRODUCT OVERVIEW

The RM65-7104E Adapter/Buffer extends the AIM 65 Expansion Bus from the AIM 65 Expansion Connector to an RM 65 Bus motherboard that is situated up to 16 inches away. Included circuitry permits the Adapter/Buffer to drive up to 15 RM 65 Buscompatible modules. (The similar Cable Driver Adapter/Buffer, Part Number RM65-7116, provides 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.


RM65-7104E Adapter/Buffer for 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 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 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 nonmaskable 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/REMOVAL

## Installing the Adapter/Buffer

Before installing the module, inspect for damage and grease, dirt, liquid or other foreign material that will affect performance.
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 J3 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.

| 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 |
| GND | Ground |  | 1 a | 1 c | $+5 \mathrm{~V}$ | $+5 \mathrm{Vdc}$ |  |
| BADR/ | Buffered Bank Address | 0 | 2a | 2 c | BA15/ | Buffered Address Bit 15 | 0 |
| GND | Ground |  | 3а | 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 | 9 c | 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 | В ${ }_{1}$ | Buffered Phase 1 Clock | 0 |
| GND | Ground |  | 13a | 13 c | BSYNC | Buffered Sync | 0 |
| BSO | Buffered Set Overflow | 1 | 14a | 14 c | 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 | 17 c |  | * User Spare 2 |  |
| GND | Ground Line |  | 18a | 18 c | BFLT/ | Buffered Bus Float | 1 |
| BDMT/ | Buffered DMA Terminate |  | 19a | 19c | Вфо | *Buffered External Phase 0 Clock |  |
|  | *User Spare 3 |  | 20a | 20c | GND | Ground |  |
| $\mathrm{BR} / \overline{\mathrm{W}} /$ | Buffered Read/Write "Not" | 0 | 21a | 21c | BDRQ2/ | *Buffered DMA Request 2 |  |
|  | *System Spare |  | 22a | 22c | $B R / \bar{W}$ | Buffered Read/Write | 0 |
| GND | Ground |  | 23a | 23 c | BACT/ | Buffered Bus Active | 1 |
| BIRQ/ | Buffered Interrupt Request | 1 | 24a | 24 c | BNMI/ | Buffered Non-Maskable Interrupt | 1 |
| B $\emptyset 2 /$ | Buffered Phase 2 "Not" Clock | 0 | 25a | 25c | GND | Ground |  |
| B¢2 | Buffered Phase 2 Clock | 0 | 26a | 26c | BRES/ | Buffered Reset | 0 |
| BD7/ | Buffered Data Bit 7 | //O | 27a | 27 c | BD6/ | Buffered Data Bit 6 | 1/0 |
| GND | Ground |  | 28a | 28c | BD5/ | Buffered Data Bit 5 | 1/0 |
| BD4/ | Buffered Data Bit 4 | I/O | 29a | 290 | BD3/ | Buffered Data Bit 3 | 1/0 |
| BD2/ | Buffered Data Bit 2 | /10 | 30a | 30c | GND | Ground |  |
| BD1/ | Buffered Data Bit 1 | 1/0 | 31a | 31c | BDO/ | Buffered Data Bit 0 | 1/O |
| $+5 \mathrm{~V}$ | $+5 \mathrm{Vdc}$ |  | 32a | 32c | GND | Ground |  |



| 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/ Output |
| SYNC | SYNC | 1 | 1 | A | AO | Address Bit 0 | 1 |
| RDY | Ready | 0 | 2 | B | A1 | Address Bit 1 | 1 |
| \$1 | Phase 1 Clock | 1 | 3 | C | A2 | Address Bit 2 | 1 |
| $\underline{\text { IRO }}$ | Interrupt Request | 0 | 4 | D | A3 | Address Bit 3 | 1 |
| S.O. | Set Overflow | 0 | 5 | E | A4 | Address Bit 4 | I |
| NMI | Non-Maskable Interrupt | 0 | 6 | F | A5 | Address Bit 5 | 1 |
| RES | Reset | 0 | 7 | H | A6 | Address Bit 6 | 1 |
| D7 | Data Bit 7 | $1 / \mathrm{O}$ | 8 | $J$ | A7 | Address Bit 7 | 1 |
| D6 | Data Bit 6 | /O | 9 | K | A8 | Address Bit 8 | 1 |
| D5 | Data Bit 5 | 1/0 | 10 | L | A9 | Address Bit 9 | 1 |
| D4 | Data Bit 4 | vo | 11 | M | A10 | Address Bit 10 | 1 |
| D3 | Data Bit 3 | 1/0 | 12 | N | A11 | Address Bit 11 | 1 |
| D2 | Data Bit 2 | VO | 13 | P | A12 | Address Blt 12 | I |
| D1 | Data Bit 1 | $1 / 0$ | 14 | R | A13 | Address Bit 13 | 1 |
| DO | Data Bit 0 | //O | 15 | S | A14 | Address Bit 14 | 1 |
| -12V | *-12 Vdc |  | 16 | T | A15 | Address Bit 15 | 1 |
| +12V | * +12 Vdc |  | 17 | U | SYS $\chi^{2}$ | System Phase 2 Clock | 1 |
| CS8 | *Chip Select 8 |  | 18 | V | SYS R/W | System Read/Write | 1 |
| CS9 | *Chip Select 9 |  | 19 | w | R/W | Read/Write "Not" | 1 |
| CSA | *Chip Select A |  | 20 | X | TEST | *Test |  |
| +5V | +5 Vdc |  | 21 | Y | $\overline{62}$ | Phase 2 Clock "Not" | 1 |
| GND | Ground |  | 22 | z | RAM R/W | *RAM Read/Write |  |
| Note <br> * $=$ Not used on this module. |  |  |  |  |  |  |  |



## ADAPTER/BUFFER SCHEMATIC



9

## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimension (See Notes) <br> Adapter Module <br> Width <br> Length <br> Height <br> Buffer Module Width Length Height | 4.4 in. ( 111 mm ) 2.6 in. ( 67 mm ) 0.56 in . $(14 \mathrm{~mm})$ <br> 3.9 in. $(100 \mathrm{~mm})$ 6.3 in. $(160 \mathrm{~mm})$ $0.56 \mathrm{in} .(14 \mathrm{~mm})$ |
| Weight | $7.2 \mathrm{oz}.(205 \mathrm{~g})$ |
| Power <br> Adapter Module <br> Buffer Module | $\begin{array}{r} +5 \mathrm{~V} \pm 5 \% 30 \mathrm{~mA}(0.15 \mathrm{~W})-\text { Typical } \\ 50 \mathrm{~mA}(0.25 \mathrm{~W}) \text {-Maximum } \\ +5 \mathrm{~V} \pm 5 \% 190 \mathrm{~mA}(0.95 \mathrm{~W}) \text {-Typical } \\ 330 \mathrm{~mA}(1.7 \mathrm{~W}) \text {-Maximum } \end{array}$ |
| Environmental <br> Operating Temperature <br> Storage Temperature Relative Humidity | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ <br> $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ <br> $0 \%$ to $85 \%$ (without condensation) |
| Propagation Time | 20 ns-Maximum |
| Interface Connectors <br> AIM 65 Expansion Connector <br> RM 65 Bus | 22/44-edge receptacle <br> ( 0.156 in. centers) <br> 64-pin plug ( 0.100 in. centers) per DIN 41612 <br> (Row $b$ is not installed) |
| Interface Cables <br> Number of Cables <br> Cable Length <br> Type <br> Number of conductors per cable <br> Wire Size | Two 16 inches Flat ribbon 40 \#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 the connectors or the module ejector.
3. The Adapter Module dimensions conform to DIN 41612.

## RM65-7116E RM 65 CABLE DRIVER ADAPTER/BUFFER FOR AIM 65

## RM 65 MICROCOMPUTER MODULES

The RM65-7116E Cable Driver Adapter/Buffer is one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Module products are 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, PL65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

RM 65 module products use a motherboard interconnect concept and accept 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 fiexibility. RM 65 products may also be used with Rockwell AIM 65 Microcomputer for product development and for a broad variety of portable or desktop microcomputer applications.

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-7116E | Cable Driver Adapter Buffer for AIM 65 |

## 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
- Fully assembled, tested and warranted


## PRODUCT OVERVIEW

The RM65-7116E Cable Driver Adapter/Buffer extends the AIM 65 Expansion Bus from the AIM 65 Expansion Connector to an RM 65 Bus 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.


RM65-7116E Cable Driver Adapter/Buffer for AIM 65

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

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 nonmaskable 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 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 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/REMOVAL

## CABLE DRIVER ADAPTER/BUFFER INSTALLATION

## 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.
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 J3 pin 1.
d. Plug the Cable Driver 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.
f. Apply power to the AIM 65 and to the mating RM 65 Bus motherboard.

## CABLE DRIVER/ADAPTER/BUFFER REMOVAL

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) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | Input/ Output | Pin | Signal Mnemonic | Signal Name | Input/ Output |
| 1 a | GND | Ground |  | 1 c | $+5 \mathrm{~V}$ | $+5 \mathrm{Vdc}$ |  |
| 2a | BADR/ | Buffered Bank Address | 0 | 2 c | BA15/ | Buffered Address Bit 15 | 0 |
| 3а | GND | Ground |  | 3 c | BA14/ | Buffered Address Bit 14 | 0 |
| 4 a | BA13/ | Buffered Address Bit 13 | 0 | 4 c | BA12 | Buffered Address Bit 12 | 0 |
| 5 a | BA11/ | Buffered Address Bit 11 | 0 | 5 c | GND | Ground |  |
| 6 a | BA10/ | Buffered Address Bit 10 | 0 | 6 c | BA9/ | Buffered Address Bit 9 | 0 |
| 7a | BA8/ | Buffered Address Bit 8 | 0 | 7 c | BA7/ | Buffered Address Bit 7 | 0 |
| 8 a | GND | Ground |  | 8 c | BA6/ | Buffered Address Bit 6 | 0 |
| 9 a | BA5/ | Buffered Address Bit 5 | 0 | 9 c | BA4/ | Buffered Address Bit 4 | 0 |
| 10a | BA3/ | Buffered Address Bit 3 | 0 | 10c | GND | Ground |  |
| 11a | BA2/ | Buffered Address Bit 2 | 0 | 11c | BA1/ | Buffered Address Bit 1 | 0 |
| 12a | BAO/ | Buffered Address Bit 0 | 0 | 12 c | B ${ }_{1} 1$ | Buffered Phase 1 Clock | 0 |
| 13a | GND | Ground |  | 13 c | BSYNC | Buffered Sync | 0 |
| 14a | BSO | Buffered Set Overflow | 1 | 14 c | BDRQ1/ | *Buffered DMA Request 1 |  |
| 15a | BRDY | Buffered Ready | 1 | 15c | GND | Ground |  |
| 16a |  | * User Spare 1 |  | 16 c | -12V/-V | *-12 Vdc/-V |  |
| 17a | $+12 \mathrm{~V} /+\mathrm{V}$ | *+12 Vdc/+V |  | 17c |  | *User Spare 2 |  |
| 18a | GND | Ground Line |  | 18 C | BFLT/ | Buffered Bus Float | 1 |
| 19a | BDMT/ | Buffered DMA Terminate |  | 198 | Bф0 | *Buffered External Phase 0 Clock |  |
| 20a |  | * User Spare 3 |  | 20c | GND | Ground |  |
| 21a | BR/W/ | Buffered Read/Write "Not" | 0 | 21c | BDRQ2/ | *Buffered DMA Request 2 |  |
| 22a |  | *System Spare |  | 22c | BR/W | Buffered Read/Write | 0 |
| 23a | GND | Ground |  | 23c | BACT/ | Buffered Bus Active | 1 |
| 24a | BIRQ/ | Buffered Interrupt Request | 1 | 24 c | BNMI/ | Buffered Non-Maskable Interrupt | 1 |
| 25a | Bф2/ | Buffered Phase 2 "Not" Clock | 0 | 25 c | GND | Ground |  |
| 26a | B¢2 | Buffered Phase 2 Clock | 0 | 26c | BRES/ | Buffered Reset | 0 |
| 27a | BD7/ | Buffered Data Bit 7 | 1/0 | 27c | BD6/ | Buffered Data Bit 6 | yo |
| 28a | GND | Ground |  | 28 c | BD5/ | Buffered Data Bit 5 | vo |
| 29a | BD4/ | Buffered Data Bit 4 | I/O | 29c | BD3/ | Buffered Data Bit 3 | 1/0 |
| 30a | BD2/ | Buffered Data Bit 2 | 1/0 | 30c | GND | Ground |  |
| 31a | BD1/ | Buffered Data Bit 1 | $1 / 0$ | 31 c | BD0/ | Buffered Data Bit 0 | /10 |
| 32a | +5V | +5 Vdc |  | 32c | GND | Ground |  |
| Note: <br> *Not used on this module. |  |  |  |  |  |  |  |



Cable Driver Adapter Module to AIM 65 Expansion Connector Pin Assignments

| Top (Component Side) |  |  |  | Bottom (Solder Side) |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | Input/ Output | Pin | Signal Mnemonic | Signal Name | Input/ Output |
| 1 | SYNC | SYNC | 1 | A | A0 | Address Bit 0 | 1 |
| 2 | RDY | Ready | 0 | B | A1 | Address Bit 1 | 1 |
| 3 | 01 | Phase 1 Clock | 1 | C | A2 | Address Bit 2 | 1 |
| 4 | IRQ | Interrupt Request | 0 | D | A3 | Address Bit 3 | 1 |
| 5 | S.O. | Set Overflow | 0 | E | A4 | Address Bit 4 | 1 |
| 6 | NMI | Non-Maskable Interrupt | 0 | F | A5 | Address Bit 5 | 1 |
| 7 | RES | Reset | 0 | H | A6 | Address Bit 6 | 1 |
| 8 | D7 | Data Bit 7 | 1/0 | J | A7 | Address Bit 7 | 1 |
| 9 | D6 | Data Bit 6 | 1/0 | K | A8 | Address Bit 8 | 1 |
| 10 | D5 | Data Bit 5 | 1/0 | L | A9 | Address Bit 9 | 1 |
| 11 | D4 | Data Bit 4 | 1/0 | M | A10 | Address Bit 10 | 1 |
| 12 | D3 | Data Bit 3 | 1/0 | N | A11 | Address Bit 11 | 1 |
| 13 | D2 | Data Bit 2 | 1/O | P | A12 | Address Bit 12 | 1 |
| 14 | D1 | Data Bit 1 | 1/O | R | A13 | Address Bit 13 | 1 |
| 15 | D0 | Data Bit 0 | 1/0 | S | A14 | Address Bit 14 | 1 |
| 16 | -12V | *-12 Vdc |  | T | A15 | Address Bit 15 | 1 |
| 17 | +12V | *+12 Vdc |  | U | SYS 02 | System Phase 2 Clock | 1 |
| 18 | CS8 | *Chip Select 8 |  | v | SYS R/W | System Read/Write | 1 |
| 19 | CS9 | *Chip Select 9 |  | w | R/W | Read/Write "Not" | 1 |
| 20 | CSA | *Chip Select A |  | X | TEST | 'Test |  |
| 21 | +5V | $+5 \mathrm{Vdc}$ |  | Y | 02 | Phase 2 Clock "Not" | 1 |
| 22 | GND | Ground |  | z | RAM R/W | *RAM Read/Write |  |

Note:

* $=$ Not used on this module.


CABLE DRIVER ADAPTER/BUFFER SCHEMATIC


[^21]
## SPECIFICATIONS

| Parameter | Value |
| :---: | :---: |
| Dimensions (1, 2, 3) <br> Cable Driver Adapter Module Width Length Height <br> Buffer Module Width Length Height | 4.4 in. ( 111 mm ) 5 in. ( 127 mm ) 0.56 in. ( 14 mm ) <br> 3.9 in . ( 100 mm ) $6.3 \mathrm{in} .(160 \mathrm{~mm})$ 0.56 in. $(14 \mathrm{~mm})$ |
| Weight | $1.0 \mathrm{lb}(450 \mathrm{~g})$ |
| Power Cable Driver Adapter Module Buffer Module | $\begin{gathered} +5 \mathrm{~V} \pm 5 \% 30 \mathrm{~mA}(0.15 \mathrm{~W}) \text {-Typical } \\ 275 \mathrm{~mA}(0.25 \mathrm{~W}) \text {-Maximum } \\ +5 \mathrm{~V} \pm 5 \% 190 \mathrm{~mA}(0.95 \mathrm{~W}) \text {-Typical } \\ 330 \mathrm{~mA}(1.7 \mathrm{~W}) \text {-Maximum } \end{gathered}$ |
| Environment <br> Operating Temperature <br> 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}$ |
| Propagation Time | 50 ns -Maximum |
| Interfaces Interface Connectors AIM 65 Expansion Connector <br> RM 65 Bus <br> Interface Cables <br> Number of Cables <br> Cable Length <br> Type <br> Number of conductors per cable <br> Wire Size | 22/44-edge receptacle ( 0.156 in. centers) <br> 64-pin plug ( 0.100 in. centers) per DIN 41612 (Row b is not installed) <br> Two <br> 6 feet <br> Flat ribbon <br> 40 <br> \#28 AWG |
| Notes: <br> 1. 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 .). <br> 2. Length does not include extensions beyond the edge of the module due to connectors or the module ejector. <br> 3. Dimensions conform to DIN 41612 . |  |

## RM65-7141E RM 65 ADAPTER CABLE AND BUFFER MODULE FOR AIM 65/40

## RM 65 MICROCOMPUTER MODULES

RM 65 Microcomputer Module products are 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, PL65, BASIC and FORTH. Both BASIC and FORTH are available in ROM and can be incorporated into the user's system.

RM 65 Module products use 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 AIM 65 and AIM 65/40 Microcomputers for product development and for a broad variety of portable or desktop microcomputer applications.

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-7141E | Adapter Cable and Buffer Module for AIM 65/40 |

## PRODUCT OVERVIEW

The RM65-7141E Adapter Cable and Buffer Module extends the AIM 65/40 Expansion Bus from the AIM 65/40 Expansion Connector to RM 65 Bus motherboard that is situated up to two meters ( 78 inches) away. On-board circuitry permits the buffer module to drive up to 15 RM 65 Bus-compatible modules.

The Adapter Cable and Buffer Module consists of a buffer module and a 2-meter interconnect cable. The cable is flexible, so the motherboard may be installed in a wide variety of locations and orientations relative to the AIM 65/40 SBC module.

## FEATURES

- RM 65 Bus compatible
- Buffered address, data and control lines
- Drives up to 15 modules
- Long cable for distances up to 2 meters
- Edge connector and Eurocard versions
- Fülly assembled, tested and warranted



## FUNCTIONAL DESCRIPTION

The RM65-7141E Adapter Cable and Buffer Module consists of one module and one interconnect cable. The cable connects to the AIM 65/40 SBC module Expansion connector and the module connects to an RM 65 Bus motherboard receptacle.

The two meter 64-conductor flat ribbon cable connects the AIM $65 / 40$ SBC module to the buffer module. The cable is mass terminated at each end. One end of the cable connects to the SBC module Expansion connector (Euro connector) and the other end connects to the buffer module.

The module buffers and routes all interface signals between the interconnect cable and the RM 65 Bus connector.

The Data Transceivers (Z6) invert and drive 8-bits of parallel data. During a write operation, data received from the cable are driven onto the RM 65 Bus. During a read operation, data received from the RM 65 Bus are driven onto the cable. The bus active signal (BACT/) enables the Transceivers. When the bus float signal (BFLT/) is active, the Transceivers are disabled.

The Address Buffers ( Z 1 and Z 3 ) invert and transfer 16 parallel address lines from the interconnect cables to the RM 65 Bus. When the bus float signal (BFLT/) is active, the Buffers are disabled.

Jumper E1 selects the source for the bank address line (BADR/)-either the AIM $65 / 40$ SBC module or another controlling module on the RM 65 Bus. When the AIM 65/40 SBC module is the source (position A), the bank address line (BADR/) is sourced by the AIM 65/40 SBC module; this line is disabled when the bus float line (BFLT/) 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 RM 65 Bus.

The read/write (BR/W and BR/W/), clock (B02, B02/ and B01), BSYNC and reset (BRES/) lines from the cable to the bus are buffered by the Control Buffers (Z5). All of these lines, except BRES/ and B01 are disabled when the bus float line (BFLT/) is active. The ready (BRDY), set overflow (BSO), interrupt request (BIRQ/) and non-maskable interrupt (BNMI/) lines from the bus to the interconnect cable 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 AIM 65/40 SBC module is the source (position A), the DMA terminate line (BDMT/) from the AIM 65/40 SBC module is put on the RM 65 Bus. 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/REMOVAL

## Installing the Adapter Cable and Buffer Module

Before installing the module, inspect for damage and grease, dirt, liquid or other foreign materials that will affect performance.
a. Before installing the AIM 65/40 Adapter Cable and Buffer Module, turn off power to the AIM 65/40 SBC module and the interfacing RM 65 Bus motherboard.
b. Configure Jumpers E1 and E2, per the Functional Description.
c. Connect the cable Euro receptacle connector onto the AIM 65/40 SBC module Expansion connector (Euro connector).
d. Connect the other cable connector onto buffer module connector P2.
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/40 SBC module and to the mating RM 65 Bus motherboard. (Power to the RM 65 motherboard is not supplied bv the Adapter Cable and Buffer Module.)

## Removing the Adapter Cable and Buffer Module

a. Turn off power to the AIM 65/40 SBC module and to the RM 65 Bus motherboard.
b. Pull the buffer module straight back until it is free from the RM 65 Bus receptacle and card cage slot guides.
c. Disconnect the cable connector from the AIM 65/40 SBC module Expansion connector.

## RM 65 Bus Pin Assignments

| Bottom (Solder Side) |  |  |  |  | Top (Component Side) |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | I/O | Type | Pin | Signal Mnemonic | Signal Name | 1/0 | Type |
| 1 a | GND | Ground |  | Power | 1 c | $+5 \mathrm{~V}$ | +5 Vdc |  | Power |
| 2 a | BADR/ | Buffered Bank Address | 0 | 3S TTL | 2 c | BA15/ | Buffered Address Bit 15 | 0 | 35 TTL |
| 3 a | GND | Ground |  | Power | 3 c | BA14/ | Buffered Address Bit 14 | 0 | 3S TTL |
| 4a | BA13/ | Buffered Address Bit 13 | 0 | 3 STTL | 4 c | BA12/ | Buffered Address Bit 12 | 0 | 35 TTL |
| 5 | BA11/ | Buffered Address Bit 11 | 0 | 3 STTL | 5 | GND | Ground |  | 3 S TTL |
| 6 | BA10/ | Buffered Address Bit 10 | 0 | 35 TTL | 6 c | BA9/ | Buffered Address Bit 9 | 0 | 3 STTL |
| $7 \mathrm{7a}$ | BA8/ | Buffered Address Bit 8 | $\bigcirc$ | 3 S TTL | 7 c | BA7/ | Buffered Address Bit 7 | 0 | 3S TTL |
| 8 8 | GND | Ground |  | Power | 8 c | BA6/ | Buffered Address Bit 6 | 0 | 3S TTL |
| 9 a | BA5/ | Buffered Address Bit 5 | 0 | 3 STTL | 9 c | BA4/ | Buffered Address Bit 4 | 0 | 3S TTL |
| 10a | BA3/ | Buffered Address Bit 3 | $\bigcirc$ | 3S TTL | 10c. | GND | Ground |  | Power |
| 11a | BA2/ | Buffered Address Bit 2 | 0 | 35 TTL | 11c | BA1/ | Buffered Address Bit 1 | 0 | 3S TTL |
| 12a | BAO/ | Buffered Address Bit 0 | 0 | 3 STTL | 12 c | B01 | Buffered Phase 1 Clock | 0 | TP TTL |
| 13a | GND | Ground |  | Power | 13c | BSYNC | Buffered Sync |  | 35 TTL |
| 14a | BSO | Buffered Set Overflow | 1 | OC TTL | 14c | BDRQ1/ | *Buffered DMA Request 1 |  |  |
| 15a | BRDY | Buffered Ready | 1 | OC TTL | 15c | GND | Ground |  | Power |
| 16a |  | * User Spare 1 |  |  | 16 c | -12V/-V | *-12 Vdc/-V |  |  |
| 17a | $+12 \mathrm{~V} /+\mathrm{V}$ | *+12 Vdc/+V |  |  | 17 c |  | * User Spare 2 |  |  |
| 18a | GND | Ground Line |  | Power | 18c | BFLT/ | Buffered Bus Float | 1 | OC TTL |
| 19a | BDMT/ | Buffered DMA Terminate | 0 |  | 19c | B00 | *Buffered External Phase 0 Clock |  |  |
| 20a |  | * User Spare 3 |  |  | 20c | GND | Ground |  | Power |
| 21a | BR/W/ | Buffered Read/Write "Not" | 0 | 3 STTL | 21c | BDRQ2/ | *Buffered DMA Request 2 |  |  |
| 22a |  | *System Spare |  |  | 22c | BR/W | Buffered Read/Write | 0 | 35 TTL |
| 23a | GND | Ground |  | Power | 23c | BACT/ | Buffered Bus Active | 1 | OC TTL |
| 24a | BIRQ/ | Buffered Interrupt Request | 1 | OC TTL | 24c | BNMI/ | Buffered Non-Maskable Interrupt | 1 | OC TTL |
| 25a | B02/ | Buffered Phase 2 "Not" Clock | 0 | 3S TTL | 25c | GND | Ground |  | Power |
| 26a | B02 | Buffered Phase 2 Clock | 0 | 3S TTL | 26c | BRES/ | Buffered Reset | 0 | OC TTL |
| 27a | BD7/ | Buffered Data Bit 7 | 1/0 | 3S TTL | 27 c | BD6/ | Buffered Data Bit 6 | 1/0 | 35 TTL |
| 28a | GND | Ground |  | Power | 28c | BD5/ | Buffered Data Bit 5 | $1 / 0$ | 3S TTL |
| 29a | BD4/ | Buffered Data Bit 4 | 1/O | 3S TTL | 290 | BD3/ | Buffered Data Bit 3 | $1 / \mathrm{O}$ | 35 TTL |
| 30a | BD2/ | Buffered Data Bit 2 | 1/0 | 3S TTL | 30c | GND | Ground |  | Power |
| 31a | BD1/ | Buffered Data Bit 1 | I/O | 3S TTL | 31c | BD0/ | Buffered Data Bit 0 | 1/O | 3S TTL |
| 32a | $+5 \mathrm{~V}$ | +5 Vdc |  | Power | 32c | GND | Ground |  | Power |



RM65-7141E Adapter Cable and Buffer Module Block Diagram


SPECIFICATIONS

| Characteristic | Value |
| :---: | :---: |
| Dimension (See Notes) <br> Width <br> Length <br> Height (see Note 1) | $\begin{gathered} 100 \mathrm{~mm}(3.9 \mathrm{in} .) \\ 160 \mathrm{~mm}(6.3 \mathrm{in} .) \\ 14 \mathrm{~mm}(0.56 \mathrm{in} .) \end{gathered}$ |
| Weight | $1.0 \mathrm{lb} .(140 \mathrm{~g})$ |
| Power (Supplied from RM 65 Bus) | $\begin{array}{rl} +5 \mathrm{~V} \pm 5 \% & 170 \mathrm{~mA}(0.85 \mathrm{~W}) \text {-Typical } \\ 270 \mathrm{~mA}(1.35 \mathrm{~W}) \text {-Maximum } \end{array}$ |
| 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} \end{aligned}$ <br> $0 \%$ to $85 \%$ (without condensation) |
| Propagation Time (maximum) | 35 ns Address Bus <br> 70 ns Data Bus (ref BACT/) |
| Interface Connectors AIM 65/40 Expansion Connector <br> RM 65 Bus | 64-pin DIN connector ( 0.100 in. centers) per DIN 41612 (mates with Burndy RPI96B32POA02K9 or equivalent) <br> 64-pin plug ( 0.100 in. centers) per DIN 41612 (Row $b$ is not installed) |
| Interface Cables <br> Number of Cables <br> Cable Length <br> Type <br> Number of conductors per cable <br> Wire Size <br> Connectors (Part Number) | One <br> 2 m (78 in.) <br> Flat ribbon <br> 64 <br> \#28 AWG <br> J1 Winchester 965-6053-0531-12 or equivalent <br> J2 Winchester 645-6053-422-12 <br> T \& B Ansley 609-641-2 <br> Cannon 006D64R3BAL or equivalent |
| Notes: <br> 1. The height includes the maximum values for $c$ thickness ( 0.062 in .), and pin extension throug the bottom of the module and cable bend. <br> 2. The length does not include extensions beyond <br> 3. The dimensions conform to DIN 41612. | ent height above the board surface ( 0.4 in . for populated modules), printed circuit board bottom of the module ( 0.1 in .). Allow an additional 19 mm ( 0.75 in .) for the connector on dge of the module due to connectors or the module ejector. |



## RM65-7201E RM 65 DESIGN PROTOTYPING MODULE

## RM 65 MICROCOMPUTER MODULES

The RM65-7201E Design Prototyping Module is one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Module products are 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.

RM 65 module products use a motherboard interconnect concept and accept 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 AIM 65 and AIM 65/40. Microcomputers for product development and for a broad variety of portable or desktop microcomputer applications.

ORDERING INFORMATION

| Part No. | Description |
| :--- | :--- |
| RM65-7201E | Design Prototyping Module |

## FEATURES

- Compact size—approximately $4^{\prime \prime} \times 61 / 4^{\prime \prime}(100 \mathrm{~mm} \times 160 \mathrm{~mm})$
- Provision for mounting mass-terminated cable connectors
- 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 components
- +5 V and ground extended throughout the module
- Isolated power strips allow connection to other supply voltages


## PRODUCT OVERVIEW

The RM65-7201E 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 module. 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 predrilled holes permit mounting of decoupling capacitors.


RM65-7201E Design Prototyping Module


RM 65 Bus Pin Assignments


## INSTALLATION

Before installing the module, inspect for damage and grease, dirt, liquid or other foreign materials that will affect performance.
a. Solder jumpers between the isolated power strips and the power $(+5 \mathrm{~V},+12 /+\mathrm{V}$, or $-12 \mathrm{~V} /-\mathrm{V})$ traces as required.

## CAUTION

Before proceeding, ensure that the power strips are not shorted to GND.
b. Solder power filter capacitors as required between the power strips and GND.
c. Install and wire components on the Design Prototype Module:

1. 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.
2. Insert the solder stakes for mounting of discrete components, power connection and test points into the desired holes and solder to the associated feedthroughs.
3. Insert and solder individual or strip stakes into connector holes for all RM 65 bus signals used on the module.
4. Wire wrap wires between the protruding pins and other pins or power/GND traces as required.
d. Double check the hookup to ensure proper connection.

## CAUTION

Ensure that no power lines are shorted 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.
e. Install components into sockets as required.
f. 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.
g. Insert the module in the RM 65 Bus motherboard or single card adapter receptacle.
h. Apply power to the RM 65 bus.

## SPECIFICATIONS



## Notes:

1. 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. Length does not include the added extensions due to the module ejector.
3. Dimensions conform to DIN 41612.


## RM65-7211E <br> RM 65 EXTENDER MODULE

## RM 65 MICROCOMPUTER MODULES

The RM65-7211E Extender Module is one of the hardware options available for the RM 65 Microcomputer Module family.

RM 65 Microcomputer Module products are 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.

RM 65 module products use a motherboard interconnect concept and accept 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 AIM 65 and AIM 65/40 Microcomputers for product development and for a broad variety of portable or desktop microcomputer applications.

## FEATURES

- Extends all RM 65 Bus Lines
- Terminals for GND and +5 V
- 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.

ORDERING INFORMATION

| Part No. | Description |
| :--- | :---: |
| RM65-7211E | Extender Module |



RM65-7211E Extender Module

RM65-7211E
Extender Module
RM 65 Bus Pin Assignments

| Bottom (Solder Side) |  |  | Top (Component Side) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Pin | Signal Mnemonic | Signal Name | Pin | Signal Mnemonic | Signal Name |
| 1a | GND | Ground | 1 c | $+5 \mathrm{~V}$ | $+5 \mathrm{Vdc}$ |
| 2 a | BADR/ | Buffered Bank Address | 2 c | BA15/ | Buffered Address Bit 15 |
| 3 a | GND | Ground | 3 c | BA14/ | Buffered Address Bit 14 |
| 4 a | BA13/ | Buffered Address Bit 13 | 4 c | BA12/ | Buffered Address Bit 12 |
| 5 a | BA11/ | Buffered Address Bit 11 | 5 c | GND | Ground |
| 6 a | BA10/ | Buffered Address Bit 10 | 6 c | BA9/ | Buffered Address Bit 9 |
| 7 a | BA8/ | Buffered Address Bit 8 | 7 c | BA7/ | Buffered Address Bit 7 |
| 8 a | GND | Ground | 8 c | BA6/ | Buffered Address Bit 6 |
| 9 a | BA5/ | Buffered Address Bit 5 | 9c | BA4/ | Buffered Address Bit 4 |
| 10a | BA3/ | Buffered Address Bit 3 | 10c | GND | Ground |
| 11a | BA2/ | Buffered Address Bit 2 | 11c | BA1/ | Buffered Address Bit 1 |
| 12a | BAO/ | Buffered Address Bit 0 | 12c | Bø1 | Buffered Phase 1 Clock |
| 13a | GND | Ground | 13c | BSYNC | Buffered Sync |
| 14a | BSO | Buffered Set Overflow | 14c | BDRQ1/ | Buffered DMA Request 1 |
| 15a | BRDY | Buffered Ready | 15c | GND | Ground |
| 16a |  | User Spare 1 | 16c | -12V/-V | -12 Vdc/-V |
| 17a | +12V/+V | +12 Vdc/ $/ \mathrm{V}$ | 17 c |  | User Spare 2 |
| 18a | GND | Ground Line | 18 c | BFLT/ | Buffered Bus Float |
| 19a | BDMT/ | Buffered DMA Terminate | 19c | Вфо | Buffered External Phase 0 Clock |
| 20a |  | User Spare 3 | 20c | GND | Ground |
| 21a | BR/ $\bar{W} /$ | Buffered Read/Write "Not" | 21 c | BDRQ2/ | Buffered DMA Request 2 |
| 22a |  | System Spare | 22c | BR/W | Buffered Read/Write |
| 23a | GND | Ground | 23c | BACT/ | Buffered Bus Active |
| 24a | BIRQ/ | Buffered Interrupt Request | 24 c | BNMI/ | Buffered Non-Maskable Interrupt |
| 25a | B $¢ 2 /$ | Buffered Phase 2 "Not" Clock | 25 c | GND | Ground |
| 26a | B $\dagger 2$ | Buffered Phase 2 Clock | 26c | BRES/ | Buffered Reset |
| 27a | BD7/ | Buffered Data Bit 7 | 27 c | BD6/ | Buffered Data Bit 6 |
| 28a | GND | Ground | 28c | BD5/ | Buffered Data Bit 5 |
| 29a | BD4/ | Buffered Data Bit 4 | 290 | BD3/ | Buffered Data Bit 3 |
| 30a | BD2/ | Buffered Data Bit 2 | 30c | GND | Ground |
| 31 a | BD1/ | Buffered Data Bit 1 | 31c | BDO/ | Buffered Data Bit 0 |
| 32a | $+5 \mathrm{~V}$ | $+5 \mathrm{Vdc}$ | 32c | GND | Ground |

## INSTALLATION

Before installing the module, inspect for damage and grease, dirt, liquid or other foreign materials that will affect performance.
a. 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.
b. Remove module to be extended from the RM 65 card cage (if present).
c. Insert the Extender Module in a vacant card slot in the card cage and connect it to the motherboard.
d. Connect the module to be extended to J 1 of the Extender Module.

## CAUTION

Be sure the extended module is properly supported to prevent damage to the module and/or the Extender Module.
e. Apply power to the RM 65 bus.

## SPECIFICATIONS



Notes:

1. 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. Length does not include the added extension due to the module ejector.
3. Dimensions conform to DIN 41612.


## Module Dimensions

## SECTION 10 INTEGRAL MODEMS

Page
Product Family Overview ..... 10-2
High Speed
R96FAX 9600 BPS Facsimile Modem ..... 10-3
R96DP 9600 BPS Data Pump Modem ..... 10-13
R96FT 9600 BPS Fast Train Modem ..... 10-26
V96P/1 9600 BPS Modem ..... 10-28
R48DP 4800 BPS Data Pump Modem ..... 10-36
V27P/1 4800 BPS Modem ..... 10-49
Low to Medium Speed
R1212 1200 BPS Full Duplex Modem ..... 10-56
R2424 2400 BPS Full Duplex Modem ..... 10-70
R24DC 2400 BPS Direct Connect Modem ..... 10-84
R24LL 2400 BPS Leased Line Modem ..... 10-92
R24 2400 BPS Integral Modem ..... 10-101
Modem Interfacing Products
R24MEB Modem Evaluation Board ..... 10-109
RDAA Rockwell Data Access Arrangement Module ..... 10-111

## INTEGRAL MODEMS Highest Quality, Performance at Competitive Cost

Rockwell International's high-speed integral modem subsystems offer better performance and greater reliability than any others. They're also more cost effective and are optimized to match more applications than others. That's why Rockwell produces more high-speed integral modem subsystems than any other company.
The chances are, if you're using a high-speed box modem, a Rockwell subsystem is in it. Practically every facsimile machine uses our modems. Rockwell is, by far, the leading supplier to Japanese facsimile machine manufacturers. With $99.6 \%$ of our subsystems accepted by incoming inspection, we have documented an MTBF of 200,000 hours, or about 23 years between service calls.
As for performance, our modems don't lose a bit in a million, even over long distance lines of the commercial telephone network. Much of this is because of our signal processing capabilities, equalization and diagnostics.
Built-in diagnostics, such as eye pattern and mean squared error, allow thorough modem testing. Several stages of equalization permit accurate transmission over even unconditioned lines. In fact, adaptive equalization, which compensates for phase shifts and frequency delays, was originated in modem technology under a basic patent owned by Rockwell.

Much of modem technology came from Rockwell International. Our first modems date back to vacuum tube versions in 1955. We made the first LSI integral modems in 1969. Today, we cover all speeds from 1200 to 9600 bps, with a $14,400 \mathrm{bps}$ model to be announced.

Our newest third-generation LSI family members are designed to be addressed as microcomputer peripherals, thus simplifying design and reducing costs of the host equipment. They're on interchangeable cards, small Eurocard sized, so you can switch communication speeds , without expensive design changes.

And, they're optimized for specific applications-for box modems and statistical multiplexers, for facsimile equipment, for use in multi-point system terminals, etc.
They're also low in price and readily available. Being the largest manufacturer lets us pass our advantages on to our customers. We offer the best cost/performance modem subsystems, with the highest reliability. There's no one else close.

Rockwell Integral Modem Subsystems Lead The Industry

1973
1983


MTBF (Thousand Hours)
ACCEPTANCE (\%)
CARD SIZE (Sq. In.)

| 50 | 100 | 200 |
| :---: | :---: | :---: |
| 95 | 99.5 | 99.7 |
| 112 | 54 | 10 |

## R96FAX <br> 9600 BPS FACSIMILE MODEM

## PRELIMINARY

## INTRODUCTION

The Rockwell R96FAX is a synchronous serial 9600 bps modem designed for operation over either dedicated unconditioned lines or over the general switched telephone network.

The modem satisfies telecommunications requirements specified in CCITT Recommendations V. 29 and V. 27 ter, and of Recommendations T.30, T. 4 and T. 3 .

The R96FAX is specifically optimized for use in Group III Facsimile machines with the added capability of Group II compatibility. The small size and low power consumption of the modem offer the user flexibility in creating a 9600 bps modem design customized for specific packaging and functional requirements.

The modem is capable of operating at $9600,7200,4800,2400$, and 300 bps .

## FEATURES

- Ultimate User Compatibility: - CCITT V.29, V. 27 ter, T.30, V. 21 Channel 2, T.4, T. 3
- Group III and Group II Facsimile
- Half-Duplex (2-Wire)
- Programmable Tone Generation and Detection
- Dynamic Range -43 dBm to 0 dBm
- Diagnostic Capability
- Equalization:
- Automatic Adaptive
- Compromise Cable (Selectable)
- Compromise Link Amplitude (Selectable)
- DTE Interface:
- Microprocessor Bus
- CCITT V. 24 (RS-232-C Compatible)
- Small Size $-100 \mathrm{~mm} \times 65 \mathrm{~mm}(3.94 \times 2.56$ inches)
- Low Power Consumption (2 Watts, Typical)
- Transmit Output Level ( $+5.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ )
- TTL and CMOS Compatible



## TECHNICAL SPECIFICATIONS

The following are the technical specifications for the R96FAX modem.

## TRANSMITTER TONAL SIGNALING AND CARRIER FREQUENCIES

The transmitter tonal signaling and carrier frequencies are given in the following tables:
T. 30 Tonal Signaling Frequencies

| Frequency Type | Specification <br> (Hz $\pm \mathbf{0 . 5 ~ H z})$ |
| :--- | :---: |
| Calling Tone (CNG) | 1100 |
| Answer Tone (CED) | 2100 |
| Group II Identification (C12) | 1850 |
| Group I Command (GC2) | 2100 |
| Group II Confirmation (CFR2, MCF2) | 1650 |
| Line Conditioning Signal (LCS) | 1100 |
| End of Message (EOM) | 1100 |
| Procedure Interrupt (PIS) | 462 |

Carrier Frequencies

| Frequency Type | Specification <br> $\mathbf{( H z} \pm \mathbf{0 . 5} \mathbf{~ H z})$ |
| :--- | :---: |
| T.3 Carrier (Group II) | 2100 |
| V.27 ter Carrier | 1800 |
| V. 29 Carrier | 1700 |

## TONE GENERATION

Under control of the host processor, the R96FAX can generate voice band tones up to 4800 Hz with a resolution of 0.15 Hz and an accuracy of $0.01 \%$. Tones over 3000 Hz are attenuated.

## TONE DETECTION

In the 300 bps FSK receive configuration, the presence of tones at preset frequencies is indicated by bits in the interface memory of the R96FAX. The frequencies and responses may be altered by the user via microprocessor control.

## SIGNALING AND DATA RATES

The signaling and data rates for the R96FAX are defined in the table below:

| Signaling/Data Rates |  |
| :--- | :---: |
| Parameter | Specification <br> $( \pm 00.01 \%)$ |
| Signaling Rate: | 2400 Baud |
| Data Rate: | 9600 bps, |
|  | 7200 bps, |
| Signaling Rate: | 4800 bps |
| Data Rate: | 1600 Baud |
| Signaling Rate: | 4800 bps |
| Data Rate: | 1200 Baud |

## DATA ENCODING

At 2400 baud, the data stream is encoded per CCITT V.29. At 9600 bps , the data stream is divided in groups of four-bits (quadbits) forming a 16 -point structure. At 7200 bps, the data stream
is divided into three bits (tribits) forming an 8-point structure. At 4800 bps , the data stream is divided into two bits (dibits) forming a 4 -point structure.

At 1600 baud, the 4800 bps data stream is encoded into tribits per CCITT V. 27 ter.

At 1200 baud, the 2400 bps data stream is encoded into dibits per CCITT V. 27 ter.

## EQUALIZERS

The R96FAX provides equalization functions which can be used to improve performance when operating over poor lines.

Cable Equalizers - Selectable compromise cable equalizers are provided to optimize performance over different lengths of non-loaded cable of 0.4 mm diameter.

Link Amplitude Equalizer - The selectable compromise amplitude equalizer may be inserted into the transmit and/or receive paths under control of the transmit amplitude equalizer enable and the receive amplitude equalizer enable bits in the interface memory. The amplitude select bit controls which of two amplitude equalizers is selected.

Automatic Adaptive Equalizer - An automatic adaptive equalizer is provided in the receiver circuit for V. 27 and V. 29 configurations. The equalizer can be configured as either a $T$ or a T/2 equalizer.

## TRANSMITTED DATA SPECTRUM

If neither the link amplitude nor cable equalizer is enabled, the transmitter spectrum is shaped by the following raised cosine filter functions:

1. 1200 Baud. Square root of 90 percent
2. 1600 Baud. Square root of 50 percent
3. 2400 Baud. Square root of 20 percent

The out-of-band transmitter power limitations meet those specified by Part 68 of the FCC's Rules, and typically exceed the requirements of foreign telephone regulatory bodies.

## SCRAMBLER/DESCRAMBLER

The R96FAX incorporates a self-synchronizing scrambler/ descrambler. This facility is in accordance with either V. 27 ter or V. 29 depending on the selected configuration.

## RECEIVED SIGNAL <br> FREQUENCY TOLERANCE

The receiver circuit of the R96FAX can adapt to received frequency error of up to $\pm 10 \mathrm{~Hz}$ with less than a 0.2 dB degradation in BER performance. Group II carrier recovery capture range is $2100 \pm 30 \mathrm{~Hz}$.

## RECEIVE LEVEL

The receiver circuit of the R96FAX satisfies all specified performance requirements for received line signal levels from 0 dBm to -43 dBm . The received line signal level is measured at the receiver analog input (RXA).

## RECEIVE TIMING

In the receive state, the R96FAX provides a Data Clock (DCLK) output in the form of a square wave. The low to high transitions of this output coincide with the center of received data bits. The timing recovery circuit is capable of tracking a $\pm 0.01 \%$ frequency error in the associated transmit timing source.

## TRANSMIT LEVEL

The transmitter output level is fixed at $+5.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$. When driving a 600 ohm load the TXA output requires a 600 ohm series resistor to provide $-0.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ to the load.

## TRANSMIT TIMING

In the transmit state, the R96FAX provides a Data Clock (DCLK) output with the following characteristics:

1. Frequency. Selected data rate of $9600,7200,4800,2400$, or $300 \mathrm{~Hz}( \pm 0.01 \%)$. In Group II, DCLK tracks an external 10368 Hz clock.
2. Duty Cycle. $50 \pm 1 \%$

Transmit Data (TXD) must be stable during the 1 microsecond periods immediately preceding and following the rising edge of DCLK.

## TURN-ON SEQUENCE

A total of ten selectable turn-on sequences can be generated by the R96FAX, as defined in the following table:

Turn-On Sequences

| NO. | V.29 | V.27 ter | RTS-CTS <br> Time (ms) | Comments |
| ---: | :--- | :--- | :--- | :--- |
| 1 | 9600 bps |  | 253 |  |
| 2 | 7200 bps |  | 253 |  |
| 3 | 4800 bps |  | 253 |  |
| 4 |  | $4800 \mathrm{bps}^{2}$ | 708 |  |
| 5 |  | $2400 \mathrm{bps}^{2}$ | 943 |  |
| 6 | 9600 bps |  | 458 | Preceded |
| 7 | 7200 bps |  | 458 | By Echo |
| 8 | 4800 bps |  | 458 | Suppressor |
| 9 |  | $4800 \mathrm{bps}^{2}$ | 913 | Disable |
| 10 |  | $2400 \mathrm{bps}^{2}$ | 1148 | Tone |

## NOTES

1. Turn-on sequences six through ten can be generated for lines with protection against talker echo.
2. V. 27 ter long training sequence only.

## TURN-OFF SEQUENCE

For V. 27 ter, the turn-off sequence consists of approximately 10 ms of remaining data and scrambled ones at 1200 baud or approximately 7 ms of data and scrambled ones at 1600 baud followed by a 20 ms period of no transmitted energy. For V.29, the turn-off sequence consists of approximately 5 ms of remaining data and scrambled 1 's followed by a 20 ms period of no transmitted energy.

## CLAMPING

The following clamps are provided with the R96FAX:

1. Received Data (RXD). RXD is clamped to a constant mark (1) whenever RLSD is off.
2. Received Line Signal Detector (RLSD). RLSD is clamped off (squelched) during the time when RTS is on.
3. Extended Squelch. Optionally, RLSD remains clamped off for 130 ms after the on-to-off transition of RTS.

## RESPONSE TIMES OF CLEAR-TO-SEND (CTS)

The time between the off-to-on transition of RTS and the off-toon transition of CTS is dictated by the length of the training sequence. Response time is 253 ms for V.29, 708 ms for V. 27 ter at 4800 bps , and 943 ms for V. 27 ter at 2400 bps .

The time between the on-to-off transition of RTS and the on-tooff transition of CTS in the data state is a maximum of 2 baud times for all configurations.

## RECEIVED LINE SIGNAL DETECTOR (RLSD)

For either V. 27 ter or V. 29 , RLSD turns on at the end of the training sequence. If training is not detected at the receiver, the RLSD off-to-on response time is $15 \pm 10 \mathrm{~ms}$. The RLSD on-to-off response time for $V .27$ is $10 \pm 5 \mathrm{~ms}$ and for $V .29$ is $30 \pm 9 \mathrm{~ms}$. Response times are measured with a signal at least 3 dB above the actual RLSD on threshold or at least 5 dB below the actual RLSD off threshold.

The RLSD on-to-off response time ensures that all valid data bits have appeared on RXD.

Two threshold options are provided:

1. Greater than -43 dBm (RLSD on)

Less than -48 dBm (RLSD off)
2. Greater than -47 dBm (RLSD on)

Less than $\mathbf{- 5 2 \mathrm { dBm }}$ (RLSD off)

## NOTE

Performance may be at a reduced level when the received signal is less than -43 dBm .

A minimum hysteresis action of 2 dB exists between the actual off-to-on and on-to-off transition levels. The threshold levels and hysteresis action are measured with an unmodulated carrier signal applied to the receiver's audio input (RXA).

## MODES OF OPERATION

The R96FAX is capable of being operated in either a serial or a parallel mode of operation.

## SERIAL MODE

The serial mode uses standard V. 24 (RS-232-C compatible) signals to transfer channel data. An optional USRT device (shown in the R96FAX Interface Diagram) illustrates this capability.

## PARALLEL MODE

The R96FAX has the capability of transferring channel data eight bits at a time via the microprocessor bus.


R96FAX Functional Interconnect Diagram

## MODE SELECTION

Selection of either the serial or parallel mode of operation is by means of a control bit. To enable the parallel mode, the control bit must be set to a 1 . The modem automatically defaults to the serial mode at power-on. In either mode the R96FAX is configured by the host processor via the microprocessor bus.

## INTERFACE CRITERIA

The modem interface comprises both hardware and software circuits. Hardware circuits are assigned to specific pins in a 40 -pin ribbon connector. Software circuits are assigned to specific bits in a 32-byte interface memory.

## HARDWARE SUPERVISORY CIRCUITS

Signal names and descriptions of the hardware supervisory circuits, including the microprocessor interface, are listed in the R96FAX Hardware Supervisory Circuits table. The microprocessor interface is designed to be directly compatible with an 8080 microprocessor. With the addition of a few external logic gates, it can be made compatible with 6500,6800 , or 68000 microprocessors.

R96FAX Hardware Supervisory Circuits

| Name | I/O | Pin No. | Description |
| :--- | :---: | :---: | :--- |
| A. OVERHEAD: |  |  |  |
| GND | I | 14,39 | Ground |
| + 5 volts | 1 | 3,4 | +5 volt supply |
| + 12 volts | 1 | 26 | +12 volt supply |
| -12 volts | 1 | 37 | -12 volt supply |
| POR | I/O | 36 | Power-on-reset |

R96FAX Hardware Supervisory Circuits (Cont.)

| Name | I/O | Pin No. | Description |
| :---: | :---: | :---: | :---: |
| B. MICROPROCESSOR INTERFACE: |  |  |  |
| D7 | I/O | 7 |  |
| D6 | 1/0 | 5 |  |
| D5 | I/O | 9 |  |
| D4 | I/O | 31 | Data Bus (8 Bits) |
| D3 | I/O | 15 |  |
| D2 | 1/O | 28 |  |
| D1 | I/O | 23 |  |
| D0 | I/O | 29 |  |
| RS3 | 1 | 30 |  |
| RS2 |  | 8 | Register Select (4 Bits) |
| RS1 | , | 27 |  |
| RSO | 1 | 10 |  |
| $\overline{\mathrm{CSO}}$ | 1 | 6 | Chip Select for Bank 0 |
| CS1 | 1 | 18 | Chip Select for Bank 1 |
| READ | 1 | 1 | Read Enable |
| WRITE | 1 | 2 | Write Enable |
| IRQ | 0 | 32 | Interrupt Request |
| C. V. 24 INTERFACE: |  |  |  |
| DCLK | 0 | 13 | Data Clock |
| XCLK | 1 | 22 | External Clock for Group II |
| RTS | 1 | 19 | Request-to-Send |
| CTS | 0 | 17 | Clear-to-Send |
| TXD | 1 | 20 | Transmitter Data |
| RXD | 0 | 21 | Receiver Data |
| RLSD | 0 | 16 | Received Line Signal Detector |

D. CABLE EQUALIZER:

| CABS1 1 33 Cable Select 1 <br> CABS2 <br> E. ANALOG SIGNALS:    <br> Cable Select 2    <br> TXA O 38 Transmitter Analog Output <br> RXA 1 40 Receiver Analog Input <br> AUXIN 1 35 Auxiliary Analog Input |
| :--- |



Microprocessor Interface Timing Diagram
Critical Timing Requirements

| Characteristic | Symbol | Min | Max | Units |
| :--- | :---: | :---: | :---: | :---: |
| $\overline{\mathrm{CSi}}, \mathrm{RSi}$ setup time prior |  |  |  |  |
| to Read or Write | TCS | 30 | - | NS |
| Data Access time after Read | TDA | - | 140 | NS |
| Data hold time after Read | TDH | 10 | 50 | NS |
| CSi, RSi hold time after |  |  |  |  |
| Read or Write | TCH | 10 | - | NS |
| Write data setup time | TWDS | 75 | - | NS |
| Write data hold time | TWDH | 10 | - | NS |
| Write strobe pulse width | TWR | 75 | - | NS |

Cable Equalizer Selection

| CABS 2 | CABS 1 | Length of 0.4mm Diameter Cable. |
| :---: | :---: | :---: |
| 0 | 0 | 0.0 |
| 0 | 1 | 1.8 km |
| 1 | 0 | 3.6 km |
| 1 | 1 | 7.2 km |

## INTERFACE MEMORY

The R96FAX has two banks of 16 registers to which an external (host) microprocessor has access. Although these registers are within the modem, they may be addressed as part of the host processor's memory space. The host may read data out of or write data into these registers. These registers are referred to as interface memory. See R96FAX Interface Memory table. Registers in bank 0 update at the modem sample rate ( 9600 bps ). Registers in bank 1 update at the selected baud rate.

When information in these registers is being discussed, the format $Y: Z: Q$ is used. The bank is specified by $Y(0$ or 1), the register by $Z(0-F)$, and the bit by $Q(0-7,0=L S B)$. A bit is considered to be 'on'" when set to a 1.

| (HEX) <br> Reg No. |  | Description |
| :--- | :--- | :--- |
| 0 | F | Diagnostic Control |
| 0 | E | Handshake Status |
| 0 | D | Do Not Use |
| 0 | C | Do Not Use |
| 0 | B | Do Not Use |
| 0 | A | Do Not Use |
| 0 | 9 | Do Not Use |
| 0 | 8 | Do Not Use |
| 0 | 7 | Do Not Use |
| 0 | 6 | Do Not Use |
| 0 | 5 | Option |
| 0 | 4 | Configuration |
| 0 | 3 | Diagnostic Data Real MSB's; FREQM |
| 0 | 2 | Diagnostic Data Real LSB's; FREQL |
| 0 | 1 | Diagnostic Imaginary MSB's |
| 0 | 0 | Diagnostic Imaginary LSB's; Data |
|  |  | Transfer Register |
| 1 | F | Diagnostic Control |
| 1 | E | Handshake Status |
| 1 | D | RAM Write Control |
| 1 | C | Gll AGC Slew Rate Select |
| 1 | B | Tone Detect Indicator |
| 1 | A | Do Not Use |
| 1 | 9 | Do Not Use |
| 1 | 8 | Do Not Use |
| 1 | 7 | Receiver Status |
| 1 | 6 | Do Not Use |
| 1 | 5 | Receiver Status |
| 1 | 4 | Receiver Status |
| 1 | 3 | Diagnostic Data Real MSB's |
| 1 | 2 | Diagnostic Data Real LSB's |
| 1 | 1 | Diagnostic Imaginary MSB's |
| 1 | 0 | Diagnostic Imaginary LSB's |
|  |  |  |

## SOFTWARE SUPERVISORY CIRCUITS

The operation of the R96FAX is affected by a number of software control inputs. These inputs are written into registers within the modem via a microprocessor bus under external control. Modem operation is monitored by various software flags that are read from modem registers using the same microprocessor bus. The functions of all modem I/O registers are listed in the R96FAX Interface Memory table and are defined as follows:

## CONFIGURATION REGISTER

The host processor configures the R96FAX by writing a control byte into the configuration register ( $0: 4$ ) in its interface memory space as shown in the following table:

Configuration Register (0:4)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TNXMT | G2 | FSK | V29 | V27 | DR3 | DR2 | DR1 |

## Definition of Configuration Terms:

TNXMT. Tone Transmit
G2. Group II Facsimile
FSK. $\quad 300 \mathrm{bps}$ FSK/Tone Detection
V29. V. 29 Configuration
V27. V. 27 Configuration
DR3. Selects 9600 bps/V. 29
DR2. Selects 7200 bps/V.29,
Selects 4800 bps/V. 27
DR1. $\quad$ Selects 4800 bps/V.29,
Selects $2400 \mathrm{bps} / \mathrm{V} .27$.

Control words for the five configurations are given in hexadecimal format in the following table:

Configuration Control Words

| No. | Configuration | Configuration Word (HEX) |
| :---: | :--- | :---: |
| 1 | V. $29 ~ 9600$ | 14 |
|  | V. 297200 | 12 |
|  | V. 294800 | 11 |
| 2 | V. 274800 | $0 A$ |
|  | V. 272400 | 09 |
| 3 | FSK | 20 |
| 4 | Group II | 40 |
| 5 | Tone Transmit | 80 |

## Definition of Configurations:

1. V.29. When any of the V. 29 configurations has been selected, the modem operates as specified in CCITT Recommendation V. 29.
2. V.27. When any of the V. 27 configurations has been selected, the modem operates as specified in CCITT Recommendation V. 27 ter.
3. FSK. The modem operates as a CCITT T. 30 compatible 300 bps FSK modem having characteristics of the CCITT V. 21 channel 2 modulation system.
4. Group 'II. The modem operates as a CCITT T. 3 compatible AM modem. This permits transmission to and reception from Group II facsimile apparatus. A carrier frequency of 2100 Hz is used. A white signal is transmitted as maximum carrier. A black signal is transmitted as no carrier. The phase of the carrier representing white is reversed after each transition through black.

When in the receive state, the R96FAX recovers the carrier of the remote transmitting modem to perform a coherent demodulation of the incoming signal. This allows a baseband of 3400 Hz to be recovered. The recovered baseband signal is made available on the microprocessor bus as diagnostic data.

The baseband signal is converted to black or white by comparing the received signal level with a preset threshold number. This number may be changed by the user.

Receiver data is presented to the RXD output at a rate of 10368 samples per second. The user should strobe the data on the rising edge of the data clock (DCLK). A logical 1 level (high voltage): represents white. A logical 0 level (low voltage) represents black.
5. Tone Transmit. In this configuration, activating signal RTS causes the modem to transmit a tone at a single frequency specified by the user. Two registers in the host interface memory space contain the frequency code. The most significant bits are specified in the FREQM register (0:3). The least significant bits are specified in the FREQL register (0:2). The least significant bit represents $0.146484 \mathrm{~Hz} \pm 0.01 \%$. The frequency generated is: $f=0.146484$ (256 FREQM + FREQL) $\mathrm{Hz} \pm 0.01 \%$.

Hexadecimal frequency numbers (FREQM, FREQL) for commonly generated tones are shown in the following chart:

Commonly Generated Tones

| Frequency | FREQM | FREQL |
| :---: | :---: | :---: |
| 462 Hz | 0 C | 52 |
| 1100 Hz | 1 D | 55 |
| 1650 Hz | 2 C | 00 |
| 2150 Hz | 31 | 55 |
| 2100 Hz | 38 | 00 |

## OPTION REGISTER

The host processor conveys option information to the R96FAX by writing a control byte into the Option Register (0:5) in its memory space as shown in the table below:
Option Register (0:5)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RTS | TDIS |  |  | EDIS | SQEXT | T2 | LRTH |

## Definition of Option Terms:

RTS. Request-to-Send
TDIS. Training Disable
EDIS. Echo Protector Disable
SQEXT. Squelch Extend
T2. T/2 Equalizer
LRTH. Lower Receive Threshold

## Definition of Options:

1. Request-to-Send. The R96FAX operates in the receive state until RTS ( $0: 5: 7$ ) is turned on. At that time the modem switches to the transmit state and remains there until RTS is turned off, and the turn-off sequence has been completed.
2. Training Disable. When the TDIS bit $(0: 5: 6)$ is on in the receive state, this bit prevents the modem from entering the training phase. When turned on prior to RTS going on, this bit prevents the generation of a training sequence at the start of transmission.
3. Echo Protector Disable. If the EDIS bit $(0: 5: 3)$ is on, an unmodulated carrier is transmitted for 185 to 200 ms followed by 20 to 25 ms of no transmitted energy at the beginning of the training sequence. This option is available in both the V. 27 and V. 29 configurations although it is not specified in the CCITT V. 29 Recommendation.
4. Squelch Extend. When on, the SQEXT bit (0:5:2) inhibits reception of signals for 130 ms after RTS is turned off.
5. $T / 2$ Equalizer. If the $T / 2$ equalizer bit ( $0: 5: 1$ ) is off, an adaptive equalizer with one tap per baud is used. If the T/2 bit is on, an adaptive equalizer with two taps per baud is used.
6. Lower Receive Threshold. When on, the LRTH bit (0:5:0) lowers the receiver turn-on threshold from -43 dBm to -47 dBm .

## DISCRETE CONTROL BITS

The discrete control bits are defined in the following table:

Discrete Control Bits

| Name | I.D. No. | Description |
| :---: | :---: | :---: |
| PDM | 0:F:7 | When on, PDM places the R96FAX in the parallel mode and inhibits bank 0 diagnostics. |
| SETUP | 0:E:3 | When on, SETUP causes the R96FAX to reconfigure to the control word in the configuration register and to assume the options specified for equalizer ( $0: 5: 1$ ) and threshold (0:5:0). Resets automatically. Note: Bit 0:4:0 through 0:4:4 should only change state while RTS is off to prevent errors in transmission. |
| IEO | 0:E:2 | When on, Interrupt Enable (Zero), causes the $\overline{\mathrm{IRQ}}$ output to be low when the DAO bit ( $0: E: 0$ ) is on. |
| RAMW | 1:D:0 | RAMW, when on, causes the 16 -bit word in locations $1: 0$ and $1: 1$ to be written into RAM at the location specified in the diagnostic con trol register (1:F). |
| J3L | 1:D:4 | Japanese 3 link, when on, selects this standard for link amplitude equalizer; when off selects U.S. survey long. |
| RLE | 1:D:5 | Receiver link equalizer, when on, enables the link amplitude equalizer in the receiver. |
| TLE | 1:D:6 | Transmitter link equalizer, when on, enables the link amplitude equalizer in the transmitter |
| G2FGC | 1:C:0 | G2FGC, when on, selects a fast AGC rate in Group II. |
| IE1 | 1:E;2 | When on, Interrupt Enable (One) causes the IRQ output to be low when the DA1 bit ( $1: E: 0$ ) is on. |

## STATUS BITS

The status bits are defined in the following table:

## Status Bits

| Name | I.D. No. | Description |
| :---: | :---: | :---: |
| DAO | 0:E:0 | Data Available (Zero) goes on when the R96FAX writes data into registered 0:0. It is reset when the host processor reads or writes register 0:0. DA0 is used in the parallel mode and also for diagnostic data retrieval. |
| IAO | 0:E:7 | Interrupt Active (Zero) is on when bank 0 is causing IRQP to be active. |
| FED | 1:5:6 | Fast Energy Detect, when off, indicates energy on the receiver input. Not used for Group II. |
| P2DET | 1:4:2 | When off, P2DET indicates a P2 sequence has been detected. Sets to 1 at start of PN sequence. |
| PNDET | 1:7:6 | When off, PNDET indicates a PN sequence has been detected. Sets to 1 at end of PN sequence. |
| CDET | 1:7:0 | When off, CDET indicates that energy is being detected and a training sequence is not present. Goes off at start of data state. |
| DA1 | 1:E:0 | Data Available (One) goes on when the R96FAX writes data into register 1:0. It is reset when the host processor reads or writes register 1:0. |
| IA1 | 1:E:7 | Interrupt Active (One) is on when bank 1 is causing $\overline{\mathrm{RQ}}$ to be active. |
| F3 | 1:B:7 | When on, these bits indicate reception of their respective tonal frequencies if the R96FAX is |
| F2 | 1:B:6 | configured in FSK. Default frequencies are: |
| F1 | 1:B:5 | $\begin{aligned} & F 3=462 \mathrm{~Hz}, F 2=1100 \mathrm{~Hz} \text {, and } F 1= \\ & 2100 \mathrm{~Hz} . \end{aligned}$ |

## DIAGNOSTIC CAPABILITIES

The R96FAX provides the user with access to much of the data stored in the modem's memories. This data is a useful tool in performing certain diagnostic functions.

## HARDWARE DIAGNOSTIC CIRCUITS

Signal names and descriptions of the hardware diagnostic circuits are given in the table below:

Hardware Diagnostic Circuits

| Name | I/O | Pin No. | Description |
| :--- | :---: | :---: | :--- |
| EYEX | 0 | 24 | Eye Pattern Data - X Axis |
| EYEY | 0 | 25 | Eye Pattern Data - Y Axis |
| EYECLK | 0 | 11 | Eye Pattern Clock |
| EYESYNC | 0 | 12 | Eye Pattern Synchronizing <br> Signal |

Eye Pattern Generation - The four hardware diagnostic circuits allow the user to generate and display an eye pattern. Circuits EYEX and EYEY serially present eye pattern data for the horizontal and vertical display inputs respectively. The 8-bit data words are shifted out most significant bit first, clocked by the rising edge of the EYECLK output. The EYESYNC output is provided for word synchronization. The falling edge of EYESYNC may be used to transfer the 8 -bit word from the shift register to a holding register. Digital to analog conversion can then be performed for driving the $X$ and $Y$ inputs of an oscilloscope.

## SOFTWARE DIAGNOSTIC CIRCUITS

Two diagnostic control registers are provided in the interface memory to allow user access to various RAM locations within the modem. The access code stored in bank $0(0: F)$ selects the source of data for the real and imaginary diagnostic data registers in bank 0 (0:0 through 0:3). Similarly the access code stored in bank $1(1: F)$ selects the source of data for registers 1:0 through 1:3. Bank 1 also provides the user with the ability to store the contents of registers 1:0 and 1:1 in the RAM location specified in register 1:F. Writing is performed by turning on control bit RAMW (1:13:0). Reading is performed by handshaking with the appropriate Data Available status bit. The eight most significant bits of real and imaginary data from bank 1 are also presented serially on EYEX and EYEY respectively.

## RAM ACCESS CODES (READ)

The RAM Access Codes defined in the table below allow the host processor to read diagnostic information within the R96FAX.

RAM Access Codes (Read)

| Bank | Function | Access | Data Type |
| :---: | :--- | :---: | :--- |
| 0 | Received Signal Samples | 40 | Real |
|  | Demodulator Output | 42 | Complex |
|  | Low Pass Filter Output | 54 | Complex |
|  | One Baud Energy | 04 | Imaginary |
|  | AGC Gain Word - MSB's | 01 | Real |
|  | AGC Gain Word - LSB's | 01 | Imaginary |
| 1 | Equalizer Input | 40 | Complex |
|  | Equalizer Tap Coefficients | $01-20$ | Complex |
|  | Unrotated Equalizer Output | 22 | Complex |
|  | Rotated Equalizer Output | 22 | Complex |
|  | (Received Point-Eye Pattern) |  |  |
|  | Decision Points (Ideal) | 62 | Complex |
|  | Error Vector | 63 | Complex |
|  | Rotation Angle | 00 | Imaginary |
|  | Frequency Correction - MSB's | 28 | Real |
|  | Frequency Correction - LSB's | 28 | Imaginary |
|  | Group II Base Band Signal | $4 B$ | Real |
|  | Group II Threshold | $2 A$ | Imaginary |
|  | EQM | $2 B$ | Real |

## RAM ACCESS CODES (WRITE)

The RAM access codes defined in the following table allow the host processor to write parameter information into the R96FAX.

| Bank | Function | Access | Data Type |
| :---: | :---: | :---: | :---: |
| 1 | Gll Black/White Threshold | 2 A | Imaginary |
|  | F1 A10 | 2 B | Imaginary |
|  | F1 B11 | 2 C | Imaginary |
|  | F1 B12 | 2D | Imaginary |
|  | F1 A00 | 2E | Imaginary |
|  | F1 B01 | 2 F | Imaginary |
|  | F1 802 | 30 | Imaginary |
|  | F2 A10 | 31 | Imaginary |
|  | F2 B11 | 32 | Imaginary |
|  | F2 B12 | 33 | Imaginary |
|  | F2 A00 | 34 | Imaginary |
|  | F2 B01 | 35 | Imaginary |
|  | F2 B02 | 36 | Imaginary |
|  | F3 A10 | 37 | Imaginary |
|  | F3 B11 | 38 | Imaginary |
|  | F3 B12 | 39 | Imaginary |
|  | F3 A00 | 3A | Imaginary |
|  | F3 B01 | 3 B | Imaginary |
|  | F3 B02 | 3 C | Imaginary |
|  | F1 A20 | B7 | Real |
|  | F1 B21 | B8 | Real |
|  | F2 A20 | B9 | Real |
|  | F2 B21 | BA | Real |
|  | F3 A20 | BB | Real |
|  | F3 B21 | BC | Real |

## POWER-ON INITIALIZATION

When power is applied to the R96FAX, a period of 100 to 300 ms is required for initialization. The power-on-reset signal (POR) remains low during the initialization period. After the low to high transition of POR, the modem is ready to be configured.

At POR time the modem defaults to the following configuration: V.29/9600 bps, T/2 equalizer, serial mode, training enabled, echo protector disable tone, no extended squelch, higher receive threshold, interrupts disabled, no link equalizer, RAM access codes 00.

POR can also be used to initialize the users's host processor. It may be connected to a user supplied power-on-reset signal in a wire-or configuration.

## PERFORMANCE

Whether functioning as a V. 27 ter or V. 29 type modem, the R96FAX provides the user with unexcelled high performance.

Bit Error Rates - The Bit Error Rate (BER) performance of the modem is specified for a test configuration conforming to that specified in CCITT Recommendation V.56, except with regard to the placement of the filter used to bandlimit the white noise source. Bit error rates are measured at a received line signal level of -40 dBm as illustrated.

Phase Jitter -At 2400 bps, the modem exhibits a bit error rate of $10^{-6}$ or less with a signal-to-noise ratio of 12.5 dB in the presence of $15^{\circ}$ peak-to-peak phase jitter at 150 Hz or with a signal-to-noise ratio of 15 dB in the presence of $30^{\circ}$ peak-topeak phase jitter at 120 Hz (scrambler inserted).

At 4800 bps (V. 27 ter), the modem exhibits a bit error rate of $10^{-6}$ or less with a signal-to-noise ratio of 19 dB in the presence of $15^{\circ}$ peak-to-peak phase jitter at 60 Hz .

At 9600 bps , the modem exhibits a bit error rate of $10^{-6}$ or less with a signal-to-noise ratio of 23 dB in the presence of $10^{\circ}$ peak-to-peak phase jitter at 60 Hz . The modem exhibits a bit error rate of $10^{-5}$ or less with a signal-to-noise ratio of 23 dB in the presence of $60^{\circ}$ peak-to-peak phase jitter at 30 Hz .


Typical Bit Error Rate Performance

INTERFACE CIRCUIT CHARACTERISTICS
digital interface circuits

Digital Input Characteristics

| Input Logic State | Allowed Input Voltage Levels |  |
| :---: | :---: | :---: |
| Low | 0.0 V to +0.8 V at -0.01 mA |  |
| High | +2.0 V to +5.0 V at +0.1 mA |  |
| Notes |  |  |
| 1. The digital inputs are directly TTL/CMOS compatible. The <br> capacitive loading on each input is 25 pF (maximum). |  |  |
| 2. Positive current is defined as current into the node. |  |  |

Digital Output Characteristics

| Input Logic State | Allowed Input Voltage Levels |
| :---: | :---: |
| Low | 0.0 V to +0.4 V at +1.6 mA |
| High | +2.4 V to +5.0 V at $-40 \mu \mathrm{~A}$ |$|$| Notes |  |  |
| :---: | :---: | :---: |
| 1. The digital outputs are directly CMOS and TTL compatible. <br> 2. Positive current is defined as current into the node. |  |  |

## ANALOG INTERFACE CIRCUITS

Transmitter Output - The transmitter output is a low impedance operational amplifier output. To match to $600 \Omega$, an external series resistor is required.

Receiver Input - The receiver input impedance is 63.4 K ohm $\pm 5 \%$.


Auxiliary Analog Input - The auxiliary analog input (AUXIN) allows access to the transmitter for the purpose of interfacing with user provided equipment. Because this is a sampled data input signals above 4800 Hz will cause aliasing errors. The input impedance is 1 K ohm and the gain to transmitter output is 0 dB .


Header Pin Assignment


Printed Circuit Board Dimensions

R96FAX SPECIFICATIONS

| Power |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Voltage | Tolerance | Current (Typical) | Current (Max) |  |
| +5 Vdc | $\pm 5 \%$ | 300 mA | $<500$ |  |
| +12 Vdc | $\pm 5 \%$ | 5 mA | $<10$ |  |
| -12 Vdc | $\pm 5 \%$ | 30 mA | $<50$ |  |
| Note: All voltages must have ripple $\leq 0.1$ volts peak-to-peak. |  |  |  |  |

## Environmental

| Parameter |  |
| :---: | :---: |
| Temperature |  |
| Operating | $0^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}\left(32\right.$ to $\left.140^{\circ} \mathrm{F}\right)$ |
| Storage | $-40^{\circ} \mathrm{C}$ to $+90^{\circ} \mathrm{C}\left(-40\right.$ to $\left.176^{\circ} \mathrm{F}\right)$ (Stored in heat sealed antistatic bag and shipping container) |
| Relative Humidity | Up to $90 \%$ noncondensing, or a wet bulb temperature up to $35^{\circ} \mathrm{C}$, whichever is less. |

## Mechanical

| Parameter | Specification |
| :---: | :--- |
| Board Structure | Single PC board with single right angle header with 40 pins |
|  | 3VH50/IJND5 or equivalent mating connector. |
| Dimensions | Width-2.56 in. $(65 \mathrm{~mm})$ |
|  | Length- $3.94 \mathrm{in} .(100 \mathrm{~mm})$ |
|  | Height- $0.40 \mathrm{in} .(1.02 \mathrm{~cm})$ |
|  | Less than $0.16 \mathrm{lbs} .(0.07 \mathrm{~kg})$ |

## R96DP 9600 BPS DATA PUMP MODEM

## PRELIMINARY

## INTRODUCTION

The Rockwell R96DP is a synchronous serial 9600 bps modem designed for full-duplex operation over either four-wire dedicated unconditioned lines or half-duplex operation over the general switched telephone network.

The modem satisfies telecommunications requirements specified in CCITT Recommendations V. 29 and V. 27 bis/ter.

The small size and low power consumption of the modem offer the user flexibility in creating a 9600 bps modem design customized for specific packaging and functional requirements.

The modem is capable of operating at 9600, 7200, 4800, and 2400 bps.

## FEATURES

- User Compatibility:
- CCITT V.29, and V. 27 bis/ter
- Full-Duplex (4-Wire)
- Half-Duplex
- Programmable Tone Generation
- Dynamic Range -43 dBm to 0 dBm
- Diagnostic Capability
- Equalization:
- Automatic Adaptive
- Compromise Cable (Selectable)
- Compromise Link (Selectable)
- DTE Interface:
- Microprocessor Bus
- CCITT V. 24 (RS-232-C Compatible)
- Loopbacks (V. 54 Loop 2, 3 and 4)
- Local Analog
- Remote Analog (Locally Activated)
- Remote Digital (Locally Activated)
- Small Size $-100 \mathrm{~mm} \times 120 \mathrm{~mm}(4.0 \times 4.8$ inches)
- Low Power Consumption (3 watts, typical)
- Programmable Transmit Output Level
- TTL and CMOS Compatible


R96DP Modem

## TECHNICAL SPECIFICATIONS

The following are the technical specifications for the R96DP modem.

## TRANSMITTER CARRIER FREQUENCIES

The transmitter carrier frequencies are giver: in the following table:

Transmitter Carrier Frequencies

| Frequency Type | Specification <br> $(\mathbf{H z} \pm \mathbf{0 . 5 ~ H z )}$ |
| :--- | :---: |
| V.27 bis/ter Carrier | 1800 |
| V.29 Carrier | 1700 |

## TONE GENERATION

Under control of the host processor, the R96DP can generate voice band tones up to 4800 Hz with a resolution of 0.15 Hz and an accuracy of $0.01 \%$. Tones over 3000 Hz are attenuated.

## SIGNALING AND DATA RATES

The signaling and data rates for the R96DP are defined in the table below:

| Signaling/Data Rates |  |
| :--- | :---: |
| Parameter | Specification <br> $( \pm 0.01 \%)$ |
| Signaling Rate: | 2400 Baud |
| Data Rate: | 9600 bps, |
|  | 7200 bps, |
|  | 4800 bps |
| Signaling Rate: | 1600 Baud |
| Data Rate: | 4800 bps |
| Signaling Rate: | 1200 Baud |
| Data Rate: | 2400 bps |

## DATA ENCODING

At 2400 baud, the data stream is encoded per CCITT V.29. At 9600 bps , the data stream is divided in groups of four-bits (quadbits) forming a 16 -point structure. At 7200 bps , the data stream is divided into three bits (tribits) forming an 8-point structure. At 4800 bps , the data stream is divided into two bits (dibits) forming a 4 -point structure.

At 1600 baud, the 4800 bps data stream is encoded into tribits per CCITT V. 27 bis/ter.

At 1200 baud, the 2400 bps data stream is encoded into dibits per CCITT V. 27 bis/ter.

## EQUALIZERS

The R96DP provides equalization functions that improve performance when operating over low quality lines.

Cable Equalizers - Selectable compromise cable equalizers in the receiver and transmitter are provided to optimize performance over different lengths of non-loaded cable of 0.4 mm diameter.

Link Equalizers - Selectable compromise link equalizers in the receiver optimize performance over channels exhibiting severe amplitude and delay distortion. Two standards are provided: U.S. survey long and Japanese 3 -link.

Automatic Adaptive Equalizer - An automatic adaptive equalizer is provided in the receiver circuit. The equalizer can be configured as either a $T$ or a $T / 2$ equalizer.

## TRANSMITTED DATA SPECTRUM

If the cable equalizer is not enabled, the transmitter spectrum is shaped by the following raised cosine filter functions:

1. 1200 Baud. Square root of 90 percent
2. 1600 Baud. Square root of 50 percent
3. 2400 Baud. Square root of 20 percent

The out-of-band transmitter power limitations meet those specified by Part 68 of the FCC's Rules, and typically exceed the requirements of foreign telephone regulatory bodies.

## SCRAMBLER/DESCRAMBLER

The R96DP incorporates a self-synchronizing scrambler/ descrambler. This facility is in accordance with either V. 27 bis/ter or V. 29 depending on the selected configuration.

## RECEIVED SIGNAL FREQUENCY TOLERANCE

The receiver circuit of the R96DP can adapt to received frequency error of up to $\pm 10 \mathrm{~Hz}$ with less than 0.2 dB degradation in BER performance.

## RECEIVE LEVEL

The receiver circuit of the modem satisfies all specified performance requirements for received line signal levels from 0 dBm to -43 dBm . The received line signal level is measured at the receiver analog input (RXA).

## RECEIVE TIMING

The R96DP provides a data derived Receive Data Clock (RDCLK) output in the form of a squarewave. The low to high transitions of this output coincide with the centers of received data bits. The timing recovery circuit is capable of tracking a $\pm 0.01 \%$ frequency error in the associated transmit timing source.

## TRANSMIT LEVEL

The transmitter output level is accurate to $\pm 1.0 \mathrm{~dB}$ and is programmable from -1.0 dBm to -15.0 dBm in 2 dB steps.

## TRANSMIT TIMING

The R96DP provides a Transmit Data Clock (TDCLK) output with the following characteristics:

1. Frequency. Selected data rate of $9600,7200,4800$, or $2400 \mathrm{~Hz}( \pm 0.01 \%)$.
2. Duty Cycle. $50 \% \pm 1 \%$

Input data presented on TXD is sampled by the R96DP at the low to high transition of TDCLK. Data on TXD must be stable for at least one microsecond prior to the rising edge of TDCLK and remain stable for at least one microsecond after the rising edge of TDCLK.

## EXTERNAL TRANSMIT CLOCK

The transmitter data clock (TDCLK) can be phase locked to a signal on input XTCLK. This input signal must equal the desired data rate to $\pm 0.01 \%$ with a duty cycle of $50 \% \pm 20 \%$.

## TURN-ON SEQUENCE

A total of 14 selectable turn-on sequences can be generated as defined in the following table:

| No. | V. 29 | V. 27 bis/ter | CTS <br> Response Time (milliseconds) | Comments |
| :---: | :---: | :---: | :---: | :---: |
| 1 | 9600 bps 7200 bps 4800 bps |  | 253 |  |
| 2 |  |  | 253 |  |
| 3 |  |  | 253 |  |
| 4 |  | 4800 bps long | 708 |  |
| 5 |  | 2400 bps long | 943 |  |
| 6 |  | 4800 bps short | 50 |  |
| 7 |  | 2400 bps short | 67 |  |
| 8 | $\begin{aligned} & 9600 \mathrm{bps} \\ & 7200 \mathrm{bps} \\ & 4800 \mathrm{bps} \end{aligned}$ |  | 458 | Preceded by Echo Suppressor Disable Tone for lines using echo suppressors* |
| 9 |  |  | 458 |  |
| 10 |  |  | 458 |  |
| 11 |  | 4800 bps long | 913 |  |
| 12 |  | 2400 bps long | 1148 |  |
| 13 |  | 4800 bps short | 255 |  |
| 14 |  | 2400 bps short | . 272 |  |
| *For short echo protect tone, subtract 155 ms from values of CTS response time. |  |  |  |  |

## TURN-OFF SEQUENCE

For V. 27 ter, the turn-off sequence consists of approximately 10 ms of remaining data and scrambled ones at 1200 baud or approximately 7 ms of data and scrambled ones at 1600 baud followed by a 20 ms period of no transmitted energy. For V.29, the turn-off sequence consists of approximately 5 ms of remaining data and scrambled 1 's followed by a 20 ms period of no transmitted energy.

## CLAMPING

Received Data (RXD) is clamped to a constant mark (one) whenever the Received Line Signal Detector (RLSD) is off.

## RESPONSE TIMES OF CLEAR-TO-SEND (CTS)

The time between the off-to-on transition of Request-To-Send (RTS) and the off-to-on transition of CTS is dictated by the length of the training sequence and the echo suppressor disable tone, if used. These times are listed in the Turn-On Sequences table. If training is not enabled RTS/CTS delay is less than 1 ms .

The time between the on-to-off transition of RTS and the on-tooff transition of CTS in the data state is a maximum of 2 baud times for all configurations.

## RECEIVED LINE SIGNAL DETECTOR (RLSD)

For either V. 27 bis/ter or V.29, RLSD turns on at the end of the training sequence. If training is not detected at the receiver, the RLSD off-to-on response time is $15 \pm 10 \mathrm{~ms}$. The RLSD on-to-off response time for V. 27 is $10 \pm 5 \mathrm{~ms}$ and for V. 29 is $30 \pm 9 \mathrm{~ms}$. Response times are measured with a signal at least 3 dB above the actual RLSD on threshold or at least 5 dB below the actual RLSD off threshold.

The RLSD on-to-off response time ensures that all valid data bits have appeared on RXD.

Four threshold options are provided:

1. Greater than -43 dBm (RLSD on) Less than -48 dBm (RLSD off)
2. Greater than -33 dBm (RLSD on) Less than -38 dBm (RLSD off)
3. Greater than -26 dBm (RLSD on) Less than -31 dBm (RLSD off)
4. Greater than -16 dBm (RLSD on) Less than -21 dBm (RLSD off)

## NOTE

Performance may be at a reduced level when the received signal is less than -43 dBm .

A minimum hysteresis action of 2 dB exists between the actual off-to-on and on-to-off transition levels. The threshold levels and hysteresis action are measured with an unmodulated carrier signal applied to the receiver's audio input (RXA).

## MODES OF OPERATION

The R96DP is capable of being operated in either a serial or a parallel mode of operation.

## SERIAL MODE

The serial mode uses standard V. 24 (RS-232-C compatible) signals to transfer channel data. An optional USRT device (shown in the Functional Interconnect Diagram) illustrates this capability.

## PARALLEL MODE

The R96DP has the capability of transferring channel data up to eight bits at a time via the microprocessor bus.

## MODE SELECTION

Selection of either the serial or parallel mode of operation is by means of a control bit. To enable the parallel mode, the control bit must be set to a 1. The modem automatically defaults to the serial mode at power-on. In either mode the R96DP is configured by the host processor via the microprocessor bus.


R96DP Functional Interconnect Diagram

## INTERFACE CRITERIA

The modem interface comprises both hardware and software circuits. Hardware circuits are assigned to specific pins in a 64 -pin DIN connector. Software circuits are assigned to specific bits in a 48 -byte interface memory.

## HARDWARE SUPERVISORY CIRCUITS

Signal names and descriptions of the hardware supervisory circuits, including the microprocessor interface, are listed in the R96DP Hardware Supervisory Circuits table. The microprocessor interface is designed to be directly compatible with an 8080 microprocessor. With the addition of a few external logic gates, it can be made compatible with 6500, 6800, or 68000 microprocessors.

R96DP Hardware Supervisory Circuits

| Name | I/O | Pin No. | Description |
| :---: | :---: | :---: | :---: |
| A. OVERHEAD: |  |  |  |
| AGND | 1 | 31C,32C | Analog Ground |
| DGND | 1 | 3C,8C,5A, 10A | Digital Ground |
| + 5 volts | 1 | 19C,23C,26C,30C | +5 volt supply |
| + 12 volts | 1 | 15A | + 12 volt supply |
| -12 volts | 1 | 12A | -12 volt supply |
| POR | $1 / \mathrm{O}$ | 13C | Power-on-reset |

R96DP Hardware Supervisory Circuits (Cont.)

| Name | 1/0 | Pin No. | Description |
| :---: | :---: | :---: | :---: |
| B. MICROPROCESSOR INTERFACE: |  |  |  |
| D7 | 1/O | $1 \mathrm{C})$ |  |
| D6 | 1/0 | 1A |  |
| D5 | 1/0 | 2C |  |
| D4 | 1/0 | 2 A | Data Bus (8 Bits) |
| D3 | I/O | 3 A \} |  |
| D2 | 1/0 | 4C |  |
| D1 | 1/0 | 4A |  |
| D0 | 1/0 | 5C) |  |
| RS3 | 1 | 6C |  |
| RS2 | 1 | 6A | Register Select (4 Bits) |
| RS1 | 1 | 7 C |  |
| RSO | 1 | 7A |  |
| $\overline{\text { CSO }}$ | 1 | 10C | Chip Select for Bank 0 |
| CS1 | 1 | 9C | Chip Select for Bank 1 |
| CS2 | 1 | 9A | Chip Select for Bank 2 |
| READ | 1 | 12C | Read Enable |
| WRITE | - | 11A | Write Enable |
| $\overline{\text { IRQ }}$ | 0 | 11C | Interrupt Request |
| C. V. 24 INTERFACE: |  |  |  |
| $\overline{\text { RDCLK }}$ | 0 | 21A | Receive Data Clock |
| TDCLK | 0 | 23A | Transmit Data Clock |
| XTCLK | 1 | 22A | External Transmit Clock |
| RTS | 1 | 25A | Request-to-Send |
| CTS | 0 | 25C | Clear-to-Send |
| TXD | 1 | 24C | Transmitter Data |
| RXD - | 0 | 22C | Receiver Data |
| $\overline{\text { RLSD }}$ | 0 | 24A | Received Line Signal Detector |


| R96DP Hardware Supervisory Circuits (Cont.) |
| :--- |
| Name I/O Pin No. Description <br> D. ANCILLARY CIRCUITS:    <br> $\overline{\text { RBCLK }}$ O 26A Receiver Baud Clock <br> TBCLK O 27C Transmitter Baud Clock <br> E. ANALOG SIGNALS:    <br> TXA O 31 A Transmitter Analog Output <br> RXA 1 $32 A$ Receiver Analog Input <br> AUXIN 1 $30 A$ Auxiliary Analog Input |



Microprocessor Interface Timing Diagram

| Characteristic | Symbol | Min | Max | Units |
| :--- | :---: | :---: | :---: | :---: |
| CSi, RSi setup time prior |  |  |  |  |
| to Read or Write | TCS | 30 | - | nsec |
| Data access time after Read | TDA | - | 140 | nsec |
| Data hold time after Read | TDH | 10 | 50 | nsec |
| CSi, RSi hold time after |  |  |  |  |
| $\quad$ Read or Write | TCH | 10 | - | nsec |
| Write data setup time | TWDS | 75 | - | nsec |
| Write data hold time | TWDH | 10 | - | nsec |
| Write strobe pulse width | TWR | 75 | - | nsec |

## INTERFACE MEMORY

The R96DP has three banks of 16 input/output (I/O) registers to which an external (host) microprocessor has access. Although these I/O registers are within the modem, they may be addressed as part of the host processor's memory space. These I/O
registers are collectively referred to as interface memory. See R96DP Interface Memory table. Access to the three banks of registers (bank 0, bank 1 and bank 2) is enabled by the Chip Select signals $\overline{\mathrm{CSO}}, \overline{\mathrm{CS1}}$ and $\overline{\mathrm{CS} 2}$ respectively. Four Register Select signals (RS0, RS1, RS2, and RS3 are provided to address an individual register within an enabled bank. Registers in bank 1 operate at the sample rate of 9600 samples per second Registers in banks 0 and 2 operate at the selected baud rate.

| Bank | (HEX) <br> Reg No. | Description |
| :---: | :---: | :---: |
| 0 | F | Do Not Use |
| 0 | E | Transmitter Handshake |
| 0 | D | Do Not Use |
| 0 | C | Do Not Use |
| 0 | B | Do Not Use |
| 0 | A | Do Not Use |
| 0 | 9 | Do Not Use |
| 0 | 8 | Do Not Use |
| 0 | 7 | Transmitter Option |
| 0 | 6 | Transmitter Configuration |
| 0 | 5 | Equalizer |
| 0 | 4 | Loop/Level |
| 0 | 3 | FREQM |
| 0 | 2 | FREQL |
| 0 | 1 | Do Not Use : |
| 0 | 0 | Transmitter Data |
| 1 | F | Do Not Use |
| 1 | E | Receiver Sample Handshake |
| 1 | D | Do Not Use |
| 1 | C | Do Not Use |
| 1 | B | Receiver Baud Status |
| 1 | A | Do Not Use |
| 1 | 9 | Receiver Sample Status 2 |
| 1 | 8 | Receiver Sample Status 1 |
| 1 | 7 | Receiver Option |
| 1 | 6 | Receiver Configuration |
| 1 | 5 | Diagnostic Control XS |
| 1 | 4 | Diagnostic Control YS |
| 1 | 3 | Diagnostic Data XSM |
| 1 | 2 | Diagnostic Data XSL |
| 1 | 1 | Diagnostic Data YSM |
| 1 | 0 | Diagnostic Data YSL; Receiver Data |
| 2 | F | Do Not Use |
| 2 | $E$ | Receiver Baud Handshake |
| 2 | D | Do Not Use |
| 2 | C | Do Not Use |
| 2 | B | Do Not Use |
| 2 | A | Do Not Use |
| 2 | 9. | Do Not Use |
| 2 | 8 | Do Not Use |
| 2 | 7 | Do Not Use |
| 2 | 6 | Do Not Use |
| 2 | 5 | Diagnostic Control XB |
| 2 | 4 | Diagnostic Control YB |
| 2 | 3 | Diagnostic Data XBM |
| 2 | 2 | Diagnostic Data XBL |
| 2 | 1 | Diagnostic Data YBM |
| 2 | 0 | Diagnostic Data YBL |

When information in these I/O registers is being discussed, the format $Y: Z: Q$ is used. The bank is specified by $Y(0-2)$, the register by $Z(0-F)$, and the bit by $Q(0-7,0=L S B)$. A bit is considered to be "on" when set to a 1 .

## SOFTWARE SUPERVISORY CIRCUITS

The operation of the R96DP is affected by a number of software control inputs. These inputs are written into registers within the modem via a microprocessor bus under external control. Bits designated by an $X$ are "Don't Care" inputs that can be set to either 1 or 0 . Modem operation is monitored by various software flags that are read from modem registers using the same microprocessor bus. Bits designated by an X are "undefined" outputs that may be either 1 or 0 . The functions of all modem I/O registers are listed in the R96DP Interface Memory table and are defined as follows:

## TRANSMITTER CONFIGURATION REGISTER

The host processor configures the R96DP transmitter by writing a control byte into the transmitter configuration register ( $0: 6$ ) in its interface memory space as shown in the following table:

Transmitter Configuration Register (0:6)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TNXMT | 0 | TLTS | TV29 | X | TDR3 | TDR2 | TDR1 |

## Definition of Transmitter Configuration Terms:

TNXMT. Tone Transmit
TLTS. Transmitter Long Training Sequence
TV29. Transmitter V. 29 Configuration
TDR3. Transmitter Data Rate 3 (Selects $9600 \mathrm{bps} / \mathrm{V} .29$ )
TDR2. Transmitter Data Rate 2 (Selects 7200 bps/V.29, and Selects $4800 \mathrm{bps} / \mathrm{V} .27$ )
TDR1. Transmitter Data Rate 1 (Selects 4800 bps/V.29, and Selects $2400 \mathrm{bps} / \mathrm{V} .27$ )

Control bytes for the three configurations are given in hexadecimal format in the following table:

Configuration Control Bytes

|  | No. | Configuration |
| :---: | :---: | :---: |
|  | 1 | V. 299600 |
| Configuration Bytes (HEX) |  |  |
|  | V. 297200 | 14 |
|  | V. 294800 | 12 |
|  | 2 | V.27 4800 Long |
|  | V.27 2400 Long | 11 |
|  | V.27 4800 Short | 22 |
|  | V.27 2400 Short | 21 |
|  | 3 | Tone Transmit |

## Definition of Transmitter Configurations:

1. V.29. When any of the V. 29 configurations have been selected, the modem operates as specified in CCITT recommendation V. 29.
2. V.27. When any of the V. 27 configurations have been selected, the modem operates as specified in CCITT recommendation V. 27 .
3. Tone Transmit. In this configuration, activating signal RTS causes the modem to transmit a tone at a single frequency specified by the user. Two registers in the host interface memory space contain the frequency code. The most significant bits are specified in the FREQM register ( $0: 3$ ). The least significant bits are specified in the FREQL register ( $0: 2$ ). The least significant bit represents $0.146484 \mathrm{~Hz} \pm 0.01 \%$.

## TRANSMITTER OPTION

The host processor conveys option information to the transmitter by writing a control byte into the Option Register ( $0: 7$ ) in its interface memory space as shown in the table below:

Transmitter Option Register (0:7)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RTS | TTDIS | SDIS | MHLD | EDIS | TPDM | XCEN | SEDT |

## Definition of Transmitter Option Terms:

RTS: Request-to-Send
TTDIS: Transmitter Training Disable
SDIS: Scrambler Disable
MHLD: Mark Hold
EDIS: Echo Protector Disable
TPDM: Transmitter Parallel Data Mode
XCEN: External Clock Enable
SEDT: Short Echo Protection Disable Tone

## Definition of Transmitter Options:

1. Request-to-Send. The R96DP begins a transmit sequence when the RTS bit ( $0: 7: 7$ ) is turned on and continues transmitting until RTS is turned off and the turn-off sequence has been completed. This input bit parallels the operation of the hardware RTS control input.
2. Transmitter Training Disable. When the TTDIS bit ( $0: 7: 6$ ) is on, the transmitter does not generate a training sequence at the start of transmission.
3. Scrambler Disable. When the SDIS bit $(0: 7: 5)$ is on, the transmitter scrambler circuit is removed from the data path.
4. Mark Hold. When the MHLD bit ( $0: 7: 4$ ) is on, the transmitter input data stream is forced to all marks ( 1 's).
5. Echo Protector Disable. When the EDIS bit ( $0: 7: 3$ ) is on, an unmodulated carrier is transmitted for 185 ms (optionally 30 ms ) followed by 20 ms of no transmitted energy at the start of transmission. Note that this option is available in both V. 27 and $\mathrm{V}: 29$ configurations although it is not specified in the CCITT V. 29 recommendation.
6. Transmitter Parallel Data Mode. When the TPDM bit (0:7:2) is on, the transmitter accepts data for transmission from the data input register rather than the serial hardware data input.
7. External Clock Enable. When the XCEN bit ( $0: 7: 1$ ) is on, the transmitter timing is established by the external clock supplied at the hardware input XTCLK (pin 22A).
8. Short Echo Protector Disable Tone. When the SEDT bit ( $0: 7: 0$ ) is on, the echo protector disable tone is 30 ms long rather than 185 ms .

## EQUALIZER

The host processor conveys equalizer selection information to the modem by writing a control byte into the equalizer register $(0: 5)$ in the interface memory space as shown in the following:

Equalizer Register (0:5)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{X}$ | X | CABS2 | CABS1 | LAEN | LDEN | A3L | D3L |

## Definition of Equalizer Terms:

CABS1,2: Cable Equalizer (Selects bits 1 or 2)
LAEN: Link Amplitude Equalizer Enable
LDEN: Link Delay Equalizer Enable
A3L: Amplitude 3-Link Select
D3L: Delay 3-Link Select

## Definition of Equalizer Parameters:

1. Cable Equalizer. The cable equalizer select bits simultaneously control amplitude and delay compromise equalizers in both the transmit and receive paths. The following table gives the possible bit combinations.

Cable ( 0.4 mm diameter) Equalizer Selection

| CABS2 | CABS1 | Cable Length |
| :---: | :---: | :---: |
| 0 | 0 | 0.0 |
| 0 | 1 | 1.8 km |
| 1 | 0 | 3.6 km |
| 1 | 1 | 7.2 km |

2. Link Equalizer. The link equalizer enable and select bits control separate amplitude and delay compromise equalizers in the receive path. The following tables give the possible bit combinations.

Link Amplitude Equalizer Selection

| LAEN | A3L | Curve Matched |
| :---: | :---: | :---: |
| 0 | $\mathbf{X}$ | No Equalizer |
| 1 | 0 | U.S. Survey Long |
| $\mathbf{1}$ | $\mathbf{1}$ | Japanese 3-Link |

## Link Delay Equalizer Selection

| LDEN | D3L | Curve Matched |
| :---: | :---: | :---: |
| 0 | $\mathbf{X}$ | No Equalizer |
| 1 | 0 | U.S. Survey Long |
| 1 | 1 | Japanese 3-Link |

## LOOP/LEVEL

The host processor conveys loopback selection and transmitter output level to the modem by writing a control byte into the loop/level register ( $0: 4$ ) in the interface memory space as shown in the following table:

> Loop/Level Register (0:4)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L3ACT | L4ACT | L4HG | TL3 | TL2 | TL1 | L2ACT | X |

## Definition of Loop/Level Terms:

LBACT: Local Analog Loopback (CCITT loop 3) Activate
L4ACT: Remote Analog Loopback (CCITT loop 4) Activate L4HG: Loop 4 High Gain
TL3-TL1: Transmitter Level (Selects bits 3, 2, and 1)
L2ACT: Remote Digital Loopback (CCITT loop 2) Activate

## Definition of Loop/Level Control:

1. Local Analog Loopback Activate. When the L3ACT bit ( $0: 4: 7$ ) is on, the transmitter analog output is coupled to the receiver analog input through an attenuator in accordance with CCITT recommendation V. 54 loop 3.
2. Remote Analog Loopback Activate. When the L4ACT bit ( $0: 4: 6$ ) is on, the receiver analog input is connected to the transmitter analog output through a variable gain amplifier.
3. Loop 4 High Gain. When the L4HG bit $(0: 4: 5)$ is on, the loop 4 variable gain amplifier is set for +16 dB . When L4HG is off, the gain is 0 dB .
4. Remote Digital Loopback Activate. When the L2ACT bit ( $0: 4: 1$ ) is on, the receiver digital output is connected to the transmitter digital input in accordance with CCITT recommendation V. 54 loop 2.
5. Transmitter Level Select 3, 2 and 1. Transmitter analog output level is determined by bits TL3, TL2, and TL1 as shown in the following table:

## Transmitter Level Selection

| TL3 TL2 TL1 Transmitter Analog Output <br> 0 0 0 $-0.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ <br> 0 0 1 $-2.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ <br> 0 1 0 $-4.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ <br> 0 1 1 $-6.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ <br> 1 0 0 $-8.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ <br> 1 0 1 $-10.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ <br> 1 1 0 $-12.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ <br> 1 1 1 $-14.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ |
| :--- |
|  |

## TRANSMITTER DATA

The host processor conveys output data to the transmitter in parallel mode by writing a data byte to the transmitter Data Register (0:0) in the interface memory space. The data must be divided on integral baud boundries as shown in the following table:

Transmitter Data Register (0:0)

| Configuration | Bit 7 Bit 6 | Bit 5 Bit 4 | Bit 3 Bit 2 | Bit 1 Bit 0 |
| :---: | :---: | :---: | :---: | :---: |
| V. 299600 bps | Baud 1 |  | Baud 0 |  |
| V. 297200 bps | X | Baud 1 |  | Baud 0 |
| V. 294800 bps | Baud 3 | Baud 2 | Baud 1 | Baud 0 |
| V. 274800 bps | X | Baud 1 | Baud 0 |  |
| V. 272400 bps | Baud 3 | Baud 2 | Baud 1 | Baud 0 |
| NOTE: Data Transmitted Bit 0 First. |  |  |  |  |

## FREQM/FREQL

The host processor conveys tone generation data to the transmitter by writing a 16 -bit data word to the FREQM/FREQL registers ( $0: 3$ and 0:2) in the interface memory space as shown in the following tables:

FREQM Register

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{15}$ | $2^{14}$ | $2^{13}$ | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ |

FREQL Register

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |

The frequency number ( N ) determines the frequency $(\mathrm{F}$ ) as follows: $F=0.146484 \mathrm{~N} \mathrm{~Hz} \pm 0.01 \%$

Hexadecimal frequency numbers (FREQM, FREQL) for commonly generated tones are given in the following table:

Commonly Generated Tones

| Frequency | FREQM | FREQL |
| :---: | :---: | :---: |
| 462 Hz | OC | 52 |
| 1100 Hz | 1 D | 55 |
| 1650 Hz | 2 C | 00 |
| 1850 Hz | 31 | 55 |
| 2100 Hz | 38 | 00 |

## TRANSMITTER HANDSHAKE

The host processor performs a handshake sequence with the transmitter by controlling and testing bits in the transmitter handshake register ( $0: E$ ) in the interface memory space as shown in the following table:

Transmitter Handshake Register (0:E)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TIA | X | X | X | TSB | TIE | X | TBA |

## Definition of Transmitter Handshake Terms:

TIA: Transmitter Interrupt Active
TSB: Transmitter Setup Bit
TIE: Transmitter Interrupt Enable
TBA: Transmitter Buffer Available

## Definition of Transmitter Handshake Sequences:

1. Transmitter Buffer Available. The TBA bit goes off when the host processor writes data to transmitter data register ( $0: 0$ ). When the transmitter empties register 0:0 the TBA bit is on.
2. Transmitter Interrupt Enable. When the host processor writes a 1 in the TIE bit, the $\overline{\operatorname{RQ}}$ line of the hardware interface is driven low when TBA is on.
3. Transmitter Interrupt Active. Status bit TIA is on whenever the transmitter is driving $\overline{\operatorname{RQ}}$ low.
4. Transmitter Setup Bit. When the host processor changes the transmitter configuration register, the host must write a 1 in the TSB bit. Bit TSB goes to 0 when the change becomes effective.

## RECEIVER CONFIGURATION

The host processor configures the receiver by writing a control byte into the receiver configuration register ( $1: 6$ ) in the interface memory space as shown in the following table:

Receiver Configuration Register (1:6)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | X | RLTS | RV29 | X | RDR3 | RDR2 | RDR1 |

## Definition of Receiver Configuration Terms:

RLTS: Receiver Long Training Sequence
RV29: Receiver V. 29 Configuration
RDR3: Receiver Data Rate 3 (Selects 9600 bps/V.29)
RDR2: Receiver Data Rate 2 (Selects $7200 \mathrm{bps} / \mathrm{V} .29$ and Selects 4800 bps/V.27)
RDR1: Receiver Data Rate 1 (Selects 4800 bps/V. 29 and Selects $2400 \mathrm{bps} / \mathrm{N} .27$ )

Control words for the two receiver configurations are given in hexadecimal format in the following table:

## Receiver Configuration Control

| No. | Configuration | Configuration Word (HEX) |
| :---: | :---: | :---: |
| 1 | V. 299600 | 14 |
|  | V. 297200 | 12 |
|  | V.29 4800 | 11 |
| 2 | V. 274800 Long | 22 |
|  | V. 272400 Long | 21 |
|  | V.27 4800 Short | 02 |
|  | V.27 2400 Short | 01 |

## Definition of Receiver Configurations:

1. V.29. When any of the V. 29 configurations has been selected, the transmitter operates as specified in CCITT recommendation V. 29.
2. V.27. When any of the V .27 configurations has been selected, the transmitter operates as specified in CCITT recommendation V.27.

## RECEIVER OPTION

The host processor conveys option information to the transmitter by writing a control byte into the option register (1:7) in its interface memory space as shown in the following table:

Receiver Option Register (1:7)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RTH2 | RTH1 | DDIS | RPDM | SWRT | BWRT | T2 | RTDIS |

## Definition of Receiver Option Terms:

RTH2, 1: Receiver Energy Detector Threshold (Bits 2 and 1)
DDIS: Descrambler Disable
RPDM: Receiver Parallel Data Mode
SWRT: Sample Write
BWRT: Baud Write
T2:
T/2 Equalizer Select
RTDIS: Receiver Training Disable

## Definition of Receiver Options:

1. Receiver Energy Detector Threshold (Bits 2 and 1). The receiver energy detector threshold is set by bits RTH2 and RTH1 according to the following table:

## Receiver Energy Detect Thresholds

| RTH2 | RTH1 | RLSD On | RLSD Off |
| :---: | :---: | :---: | :---: |
| 0 | 0 | $>-43 \mathrm{dBm}$ | $<-48 \mathrm{dBm}$ |
| 0 | 1 | $>-33 \mathrm{dBm}$ | $<-38 \mathrm{dBm}$ |
| 1 | 0 | $>-26 \mathrm{dBm}$ | $<-31 \mathrm{dBm}$ |
| 1 | 1 | $>-16 \mathrm{dBm}$ | $<-21 \mathrm{dBm}$ |

2. Descrambler Disable. When the DDIS bit ( $1: 7: 5$ ) is on, the receiver descrambler circuit is removed from the data path.
3. Receiver Parallel Data Mode. When the RPDM bit (1:7:4) is on, the receiver supplies data to the receiver data register (1:0) in parallel with the hardware serial data output.
4. Sample Write. When the SWRT bit (1:7:3) is on, the 16 -bit word in registers $1: 1$ and $1: 0$ is written in the RAM location specified by the contents of register 1:4.
5. Baud Write. When the BWRT bit ( $1: 7: 2$ ) is on, the 16 -bit word in locations 2:1 and 2:0 is written in the RAM location specified by the contents of register 2:4.
6. T/2 Equalizer Select. When the T2 bit (1:7:1) is on, an adaptive equalizer with two taps per baud is used. When T2 is off the equalizer has one tap per baud.
7. Receiver Training Disable. When the RTDIS bit (1:7:0) is on, the receiver is prevented from recognizing a training sequence.

## RECEIVER SAMPLE HANDSHAKE

The host processor performs a handshake sequence with the receiver sample rate device by controlling and testing bits in the receiver sample handshake register (1:E) in the interface memory space as shown in the following table:

Receiver Sample Handshake Register (1:E)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RSIA | X | X | X | RSSB | RSIE | X | RSDA |

## Definition of Receiver Sample Handshake Terms:

RSIA: Receiver Sample Interrupt Active
RSSB: Receiver Sample Setup Bit
RSIE: Receiver Sample Interrupt Enable
RSDA: Receiver Sample Data Available

## Definition of Receiver Sample Handshake Sequence:

1. Receiver Sample Data Available. The RSDA bit goes on when the receiver writes data into the receiver data register (1:0). The bit goes off when the host processor reads data from register 1:0.
2. Receiver Sample Interrupt Enable. When the host processor writes a 1 in the RSIE bit, the IRQ line of the hardware interface is driven low when RSDA is on.
3. Receiver Sample Interrupt Active. Status bit RSIA is on whenever the Receiver Sample rate device is driving $\overline{\mathrm{R} Q}$ low.
4. Receiver Setup Bit. When the host processor changes the receiver configuration or bits 6 or 7 in the option register, the host must write a 1 in the RSB bit. Bit RSB goes to 0 when the changes become effective.

## RECEIVER BAUD HANDSHAKE

The host processor performs a handshake sequence with the receiver baud rate device by controlling and testing bits in the receiver baud handshake register (2:E) in the interface memory space as shown in the following table:

Receiver Baud Handshake Register (2:E)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RBIA | X | X | X | X | RBIE | X | RBDA |

## Definition of Receiver Baud Handshake Terms:

RBIA: Receiver Baud Interrupt Active
RBIE: Receiver Baud Interrupt Enable
RBDA: Receiver Baud Data Available

## Definition of Receiver Baud Handshake Sequence:

1. Receiver Baud Data Available. The RBDA bit goes on when the receiver writes data into register (2:0). The bit goes off when the host processor reads data from register 2:0.
2. Receiver Baud Interrupt Enable. When the host processor writes a 1 in the RBIE bit, the $\overline{\mathrm{RQQ}}$ line of the hardware interface is driven low when RBDA is on.
3. Receiver Baud Interrupt Active. Status bit RBIA is on whenever the receiver baud rate device is driving IRQ low.

## RECEIVER SAMPLE STATUS

The host processor has access to various status bits that reflect operation of the receiver sample rate device. These bits can be tested by the host by reading the receiver sample status word (1:8 and 1:9) in the interface memory space as shown in the following tables:

Receiver Sample Status Register 1 (1:8)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | X | X | X | X | P2DET | X | X |

## Receiver Sample Status Register 2 (1:9)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | FED | X | X | X | X | X | X |

## Definition of Receiver Sample Status Terms:

P2DET: Period Two Detector
FED: Fast Energy Detector

## Definition of Receiver Sample Status Conditions:

1. Period Two Detector. When the P2DET bit (1:8:2) is off, it indicates that a P2 sequence has been detected. This bit sets to a 1 at the start of the receive data state.
2. Fast Energy Detector. When the FED bit (1:9:6) is off, it indicates that energy above the receiver threshold is present in the passband.

## RECEIVER BAUD STATUS

The host processor has access to status bits that reflect operation of the receiver baud rate device. These bits can be tested by the host by reading the receiver baud status word (1:B) in the interface memory space as shown in the following table:

Receiver Baud Status Register (1:B)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | PNDET | X | X | X | X | X | CDET |

## Definition of Receiver Baud Status Terms:

PNDET: Period N Detector
CDET: Carrier Detector

## Definition of Receiver Baud Status Conditions:

1. Period $N$ Detector. When the PNDET bit (1:B:6) is off, it indicates a PN sequence has been detected. This bit sets to a 1 at the end of the PN sequence.
2. Carrier Detector. When the CDET bit ( $1: \mathrm{B}: 0$ ) is off, it indicates that passband energy is being detected and that a training sequence is not in process. It goes off at start of data state and goes to a 1 at end of received signal.

## RECEIVER DATA

The host processor accepts input data from the receiver in parallel mode by reading a byte from the receiver data register (2:0) in the interface memory space. The data is divided on integral baud boundries identical to the transmitter data register with bit 0 received first. Note that the receiver data register is used for diagnostic data in the serial mode.

## DIAGNOSTIC CAPABILITIES

The R96DP provides the user with access to much of the data stored in the modem's memories. This data is a useful tool in performing certain diagnostic functions.

## HARDWARE DIAGNOSTIC CIRCUITS

Signal names and descriptions of the hardware diagnostic circuits are given in the following table:

Hardware Diagnostic Circuits

| Name | I/O | Pin No. | Description |
| :--- | :---: | :---: | :--- |
| EYEX | 0 | 15 C | Eye Pattern Data - X Axis |
| EYEY | 0 | 14 A | Eye Pattern Data - Y Axis |
| EYECLK | 0 | 14 C | Eye Pattern Clock |
| EYESYNC | 0 | 13 A | Eye Pattern Synchronizing <br> Signal |

Eye Pattern Generation - The four hardware diagnostic circuits allow the user to generate and display an eye pattern. Circuits EYEX and EYEY serially present eye pattern data for the horizontal and vertical display inputs respectively. The 8-bit data words are shifted out most significant bit first, clocked by the rising edge of the EYECLK output. The EYESYNC output is provided for word synchronization. The falling edge of EYESYNC may be used to transfer the 8 -bit word from the shift register to a holding register. Digital to analog conversion can then be performed for driving the $X$ and $Y$ inputs of an oscilloscope.

## SOFTWARE DIAGNOSTIC CIRCUITS

Each receiver device (sample rate and baud rate) contains six registers in the interface memory space dedicated to reading and writing modem RAM locations from the host processor bus. Four of these registers are organized into 2-byte data words and the remaining two registers form 1-byte control registers that hold RAM access codes. Data is read from RAM into the data registers. Data is written into RAM from the data registers. The RAM location involved in the data transfer is specified by the RAM access code stored in the associated diagnostic control register. The diagnostic registers are related as shown in the following table:

## Software Diagnostic Registers

| Device | Control Register | Write Bit | Data Word (MSB) | Data Word (LSB) |
| :---: | :---: | :---: | :---: | :---: |
| Sample | XS (1:5) | None | XSM (1:3) | XSL (1:2) |
| Sample | YS (1:4) | SWRT (1:7:3) | YSM (1:1) | YSL (1:0)* |
| Baud | XB (2:5) | None | XBM (2:3) | XBL (2:2) |
| Baud | YB (2:4) | BWRT (1:7:2) | YBM (2:1) | YBL (2:0) |
| *In parallel mode, register 1:0 is used for receive data and not diagnostic data. |  |  |  |  |

Data transfer is regulated by the appropriate data available bit. Reading always takes place at the designated rate, and data left in the data registers is overwritten each cycle. When the associated write bit is set, a write cycle is performed each time the associated data available bit is off.

The eight bits of registers 2:3 and 2:1 are continuously presented serially on hardware interface lines EYEX and EYEY respectively.

## RAM ACCESS CODES

The following table lists access codes for frequently used RAM data:

| Bank | Function | Real Access | Imag. <br> Access |
| :---: | :---: | :---: | :---: |
| 1 | Received Signal Samples | Co | - |
|  | Demodulator Output | C 2 | 42 |
|  | Low Pass Filter Output | D4 | 54 |
|  | One Baud Energy | - | 04 |
|  | AGC Gain Word - MSB's | 81 | - |
|  | AGC Gain Word - LSB's | - | 01 |
| 2 | Equalizer Input | CO | 40 |
|  | Equalizer Tap Coefficients | 81-A0 | 01-20 |
|  | Unrotated Equalizer Output | E1 | 61 |
|  | Rotated Equalizer Output (Received Points) | A2 | 22 |
|  | Decision Points (Ideal Data Points) | E2 | 62 |
|  | Error | E3 | 63 |
|  | Rotation Angle | - | 00 |
|  | Frequency Correction (MSB's) | AA | - |
|  | Frequency Correction (LSB's) | - | 2 A |
|  | EQM | 2B | - |

## POWER-ON INITIALIZATION

When power is applied to the R96DP, a period of 100 to 300 ms is required for initialization. The power-on-reset signal (POR) remains low during the initialization period. After the low to high transition of POR, the modem is ready to operate. At POR time the modem defaults to the following configuration: V.29, $9600 \mathrm{bps}, \mathrm{T} / 2$, long echo protect disable tone, serial data mode, internal clock, cable select 1.8 Km , amplitude and delay equalizers enabled and Japanese 3 link curves selected, transmitter output level set to $-0.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$, interrupts disabled, and receiver threshold set to -43 dBm .

POR can also be used to initialize the users's host processor. It may be connected to a user supplied power-on-reset signal in a wire-or configuration.

## PERFORMANCE

Whether functioning as a V. 27 bis/ter or V. 29 type modem, the R96DP provides the user with unexcelled high performance.

Bit Error Rates - The Bit Error Rate (BER) performance of the modem is specified for a test configuration conforming to that specified in CCITT recommendation V.56, except with regard to the placement of the filter used to bandlimit the white noise source. Bit error rates are measured at a received line signal level of -40 dBm as illustrated.

Phase Jitter -At 2400 bps, the modem exhibits a bit error rate of $10^{-6}$ or less with a signal-to-noise ratio of 12.5 dB in the presence of $15^{\circ}$ peak-to-peak phase jitter at 150 Hz or with a signal-to-noise ratio of 15 dB in the presence of $30^{\circ}$ peak-to-peak phase jitter at 120 Hz (scrambler inserted).

At 4800 bps (V. 27 bis/ter), the modem exhibits a bit error rate of $10^{-6}$ or less with a signal-to-noise ratio of 19 dB in the presence of $15^{\circ}$ peak-to-peak phase jitter at 60 Hz .


Typical Bit Error Rate Performance

At 9600 bps, the modem exhibits a bit error rate of $10^{-6}$ or less with a signal-to-noise ratio of 23 dB in the presence of $10^{\circ}$ peak-to-peak phase jitter at 60 Hz . The modem exhibits a bit error rate of $10-5$ or less with a signal-to-noise ratio of 23 dB in the presence of $60^{\circ}$ peak-to-peak phase jitter at 30 Hz .

## INTERFACE CIRCUIT CHARACTERISTICS DIGITAL INTERFACE CIRCUITS

Digital Input Characteristics

| Input Logic State | Allowed Input Voltage Levels |
| :---: | :---: |
| Low | 0.0 V to +0.8 V at $-2.5 \mu \mathrm{~A}$ |
| High | +2.0 V to +5.0 V at $+2.5 \mu \mathrm{~A}$ |
| Notes |  |

Notes

1. The digital inputs are directly TTL/CMOS compatible. The capacitive loading on each input is 25 pF (maximum).
2. Positive current is defined as current into the node

Digital Output Characteristics

| Output Logic State | Output Voltage Level |
| :---: | :---: |
| Low | +0.4 V at +1.6 mA |
| High | +2.4 V at $-100 \mu \mathrm{~A}$ |

## Notes

1. The digital outputs are directly TTL/CMOS compatible. Capacitive drive capability is 25 pF .
2. Positive current is defined as current into the node.


BER Performance Test Set-up

## ANALOG INTERFACE CIRCÜITS

Transmitter Output Level - The transmitter output level is adjustable in 2 dB steps from -0.5 dBm to -14.5 dBm accurate to $\pm 0.5 \mathrm{~dB}$. This level is measured at TXA into a 600 ohm impedance.

Receiver Input - The receiver input impedance is 63.4 K ohm $\pm 5 \%$.

Auxiliary Transmitter Input - The auxiliary transmitter input (AUXIN) allows access to the transmitter for the purpose of interfacing with user provided equipment. Because this is a sampled data input, signals above 4800 Hz will cause aliasing errors. The input impedance is 1 K ohm and the gain to transmitter output is 0 dB .

## R96DP SPECIFICATIONS

Power Requirements

| Voltage | Tolerance | Current (Max) |
| :---: | :---: | :---: |
| +5 Vdc | $\pm 5 \%$ | $<700 \mathrm{~mA}$ |
| +12 Vdc | $\pm 5 \%$ | $<20 \mathrm{~mA}$ |
| -12 Vdc | $\pm 5 \%$ | $<80 \mathrm{~mA}$ |

Note: All voltages must have ripple $\leq 0.1$ volts peak-to-peak.
Environmental

| Parameter | Specification |
| :---: | :--- |
| Temperature: | $0^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}\left(32\right.$ to $\left.140^{\circ} \mathrm{F}\right)$ <br> $-40^{\circ} \mathrm{C}$ to $+90^{\circ} \mathrm{C}\left(-40\right.$ to $\left.176^{\circ} \mathrm{F}\right)$ <br> Operating- <br> Storage- <br> Stored in heat sealed antistatic bag <br> and shipping container |
| Relative Humidity: | Up to $90 \%$ noncondensing, or a wet <br> bulb temperature up to $35^{\circ} \mathrm{C}$, <br> whichever is less. |

Mechanical Information

| Parameter | Specification |
| :---: | :--- |
| Board Structure: | Single PC board with single right <br> angle header with 64 pins, DIN 41612 <br> or equivalent mating connector. |
| Dimensions: | Width- 3.94 in. $(100 \mathrm{~mm})$ <br> Length-4.70 in. $(120 \mathrm{~mm})$ |
| Weight: | Height- $0.55 \mathrm{in} .(1.40 \mathrm{~cm})$ <br> Less than $.22 \mathrm{lbs} .(.08 \mathrm{~kg})$ |

## 0 Rockwell

## R96FT 9600 BPS FAST TRAIN MODEM

## PRELIMINARY

## INTRODUCTION

The R96 Fast Train (FT) is a synchronous, serial 9600/7200/ $4800 / 2400$ bps modem suitable for operation over dedicated unconditioned lines. It satisfies the telecommunications requirements specified in CCITT Recommendations V. 29 and V. 27 bis/ter.

The R96FT is specifically optimized for use in a multipoint environment requiring a fast training sequence of less than 30 msec at 9600 bps and less than 20 msec at 4800 bps . The optional secondary channel, small size ( 100 mm by 160 mm ), and low power consumption (4 watts typical) offer the user flexibility in creating a 9600 bps modem customized for specific packaging and functional requirements.

Data can be transferred to and from the modem either serially over the CCITT V. 24 interface or in parallel over the microprocessor bus interface.

The R96FT is a member of Rockwell's family of plug compatible 9600/4800 bps modems.

Product availability is winter, 1984.


R96FT Modem

## FEATURES

- Configurations
—CCITT V.29, V. 27 bis/ter
- Fast Training Sequence $<30 \mathrm{msec} / 9600 \mathrm{bps},<20 \mathrm{msec} /$ 4800 bps
- Ideal for Multipoint Applications
- Plug Compatible with Rockwell R96DP, R48DP Modems
- Secondary Channel (Optional) 110, 75 bps
- Dynamic Range: -43 dBm to 0 dBm
- Equalization
-Automatic Adaptive
- Compromise Cable (Selectable)
-Compromise Link Amplitude (Selectable)
- DTE Interface: Two Alternate Ports
-Microprocessor Bus
-CCITT V. 24 (RS-232-C Compatible)
- Diagnostics
-Provides Telephone Line Quality Monitoring Statistics
- Programmable Transmit Output Level
- Loopbacks
-Local Analog
-Remote Analog (Locally Activated)
—Remote Digital (Locally Activated)
- Small Size- $100 \mathrm{~mm} \times 160 \mathrm{~mm}\left(3.94^{\prime \prime} \times 6.30^{\prime \prime}\right)$
- Power Consumption-5 Watts Typical
- TTL and CMOS Compatible


R96FT Functional Interconnect Diagram

## SPECIFICATIONS

## Power Requirements

$+5 \mathrm{Vdc} \pm 5 \%<900 \mathrm{ma}$
$+12 \mathrm{Vdc} \pm 5 \%<30 \mathrm{ma}$
$-12 \mathrm{Vdc} \pm 5 \%<130 \mathrm{ma}$

Temperature: Operating 0 to $60^{\circ} \mathrm{C}$
Storage -40 to $90^{\circ} \mathrm{C}$
Relative Humidity: Up to $90 \%$ noncondensing, or a wet bulb temperature up to $35^{\circ} \mathrm{C}$, whichever is less.

## V96P/1 HIGH SPEED 9600 BPS MODEM

## INTRODUCTION

The Rockwell V96P/1 is a versatile, high performance, 9600 bps modem on a single printed circuit board. Being CCITT V. 29 and V. 27 compatible, the V96P/1 (with minimal interface circuitry) can operate on dedicated 2-wire or 4 -wire half-duplex or 4 -wire full-duplex lines. The V96P/1 can also operate in half-duplex on the general switched network.

Measuring approximately 9.2 inches ( 23.3 cm ) by 6.3 inches $(16.0 \mathrm{~cm})$, the V96P/1 is the smallest full-feature 9600 bps modem that approaches data communication theoretical performance limits.

The V96P/1 meets the tolerances specified in the CCITT V.29, V. 27 bis (alternate A), V. 27 ter and FSK T. 30 specifications. In addition, the V96P/1 can be configured to be functionally compatible with those enhanced specifications available in the Rockwell V96P, M96P, and V29P modem series.

## FEATURES

- Single printed circuit card
- 9600/7200/4800/2400 bps modes
- Full-duplex or half-duplex
- Dedicated or general switched network lines operation
- Ultimate user flexibility:
-CCITT V.29, V. 27 ter, V. 27 bis compatible
-Also 300 bps binary signalling per CCITT T. 30
- TTL compatibility
- Automatic adaptive equalizer
- Analog loopback test circuitry
- 0 to - 45 dBm dynamic AGC
- LSI signal processing
- High reliability
- Low power consumption:
-Typically 3.5 watts
- Automatic training sequence for receiver



## FUNCTIONAL SPECIFICATIONS



## Transmit Carrier and Signalling Frequencies

Carrier Frequency Codex

Compatible QAM:
Carrier Frequency V.29:
Carrier Frequency V.27:
Echo Suppression Frequencies:
Signalling Frequencies of T.30:

$$
\begin{array}{r}
1706.667 \mathrm{~Hz} \pm 0.01 \% \\
1700 \mathrm{~Hz} \pm 0.01 \% \\
1800 \mathrm{~Hz} \pm 0.01 \% \\
2100 \mathrm{~Hz} \pm 0.01 \% \\
2025 \mathrm{~Hz} \pm 0.01 \% \\
1850 \mathrm{~Hz} \pm 0.01 \% \\
1650 \mathrm{~Hz} \pm 0.01 \% \\
1300 \mathrm{~Hz} \pm 0.01 \% \\
1100 \mathrm{~Hz} \pm 0.01 \%
\end{array}
$$

## Received Signal Frequency Tolerance

The receiver can receive frequency errors of up to $\pm 10$ Hz with less than a 0.2 dB degradation in Bit Error Rate performance.

## Data Signalling and Modulation Rate

At 2400 baud:

Signalling Rate-
Data Rate-

At 1600 baud:
Signalling Rate-
Data Rate-
At 1200 baud:
Signalling Rate-
Data Rate-

$$
\begin{array}{r}
2400 \text { baud } \pm 0.01 \% \\
9600 \text { bps } \pm 0.01 \% \\
7200 \text { bps } \pm 0.01 \% \\
4800 \text { bps } \pm 0.01 \% \\
1600 \text { baud } \pm 0.01 \% \\
4800 \text { bps } \pm 0.01 \% \\
\\
1200 \text { baud } \pm 0.01 \% \\
2400 \text { bps } \pm 0.01 \%
\end{array}
$$

## Transmitted Data Spectrum

At 2400 and 1600 baud the transmitted spectrum is shaped by approximately a square root of 50 percent raised cosine filter function. At 1200 baud the spectrum is shaped by approximately a square root of 90 percent raised cosine filter function.

The 2400 baud configurations require a line with typical 3002-C2 or M1020 characteristics over the frequency range from 450 Hz to 2950 Hz . The 1600 and 1200 baud rate configurations require a usable bandwidth from 950 Hz to 2650 Hz and 1150 Hz to 2450 Hz respectively.

## Data Encoding

At 2400 baud the data stream is divided into groups of four bits (quadbits), three bits (tribits), or two bits (dibits). The data rate of $9600 \mathrm{bps}, 7200 \mathrm{bps}$, or 4800 bps is selected by a 16 point, 8 -point, or 4 -point data structure, respectively. For 2400 baud operation, when V. 29 configuration is selected, encoding of the quadbits, tribits, and dibits are per CCITT Recommendation V. 29.

At 1600 baud the data stream is divided into groups of three bits (tribits). The data rate of 4800 bps may use either an 8 point QAM structure or 8-phase structure. Encoding of the tribits in the 8-phase structure are per CCITT Recommendation V. 27 ter.

At 1200 baud the data stream is divided into groups of two bits (dibits). The data rate of 2400 bps uses a 4-phase data
structure. Encoding of the dibits may be per the fallback rate of CCITT Recommendation V. 27 bis and ter (same as V.26A) or V26B depending on the selected configuration.

## Turn-on, Turn-off Sequences

The V96P/1 turn-on sequences are compatible with CCITT Recommendations V. 29 , V. 27 bis (alternate i), V. 27 and Rockwell M96P modem specifications.

The turn-off sequences for all V. 27 modes (except the 1600 baud rate manual V. 27 mode) consists of 5 to 10 milliseconds of remaining data followed by continuous scrambled 1 's followed by no transmission energy. The period of no transmission energy is provided by turning off the transmitter key signal for a recommended duration of 20 milliseconds.

The turn-off sequences for all non-V. 27 modes consists of 4 to 7 milliseconds of remaining data followed by a period of no transmission energy.

## Ready For Sending Response Times

The Ready For Sending response time to a Request To Send is determined by the configuration selected and its corresponding training time. In the following chart of configurations, the Training Times are shown in milliseconds. Note, however, that the 1600 baud manual CCITT configurations actually specify the synchronizing sequence timing per CCITT V. 27 rather than the training time. Also note the following abbreviations.

ITC (1P-5P): Transmitter Configuration Inputs 1 through 5. These five bits establish the octal code shown where P1 and P2 are the most significant octal digit and P3 through P5 establish the least significant octal digit shown in the chart.

IRC (1P-5P): Receiver Configuration Inputs 1 through 5. These five bits establish the octal code shown where P1 and P2 are the most significant octal digit and P3 through P5 establish the least significant octal digit shown in the chart.

IRSS (1P-2P), Receiver Signal Structure and Transmitter ITSS (1P-2P): Signal Structure. Where P1 and P2 estab- lish an octal code of $0,1,2$, or 3 . They define the signal structures as follows:

0 selects 16 -point QAM
1 selects 8-point QAM
2 selects 4-point QAM
3 selects DPSK as:
8 -phase at 1600 baud
4 -phase at 1200 baud

## Received Line Signal Detector (D109)

The time response of the Received Line Signal detector circuit (D109) is a function of the length of the received turn-on sequence. Circuit D109 turns on after synchronizing is completed and prior to user data appearing on the received output line. D109 turns on for approximately 2 milliseconds after the echo protect tone disappears in the V27EP configurations (Nos. 16, 18, 21, 23, 25, 29 and 32 in Table 1).

For non-CCITT configurations (Nos. 7, 8 and 9 in the table on page 4), D109 momentarily goes on at the beginning of the synchronizing sequence.

When no synchronizing signal is detected at the receiver, D109 turns on in 5 to 15 milliseconds for an applied signal greater than 3 dB above the turn-on threshold. If training is not enabled at the receiver, D109 turns on in 5 to 15 milliseconds.

Three threshold options are provided:

1) Greater than $-43 \mathrm{dBm}: \quad$ D109 ON Less than -48 dBm : D109 OFF
2) Greater than -26 dBm : D109 ON Less than $-31 \mathrm{dBm}: \quad$ D109 OFF
3) Greater than -16 dBm : D109 ON Less than -21 dBm : D109 OFF

The three threshold options are controlled by the condition of the THRESH1 and THRESH2 control lines as indicated below.

| dB Level | THRESH1 | THRESH2 |
| :---: | :---: | :--- |
| -43 dBm ON | Open Circuit | Open Circuit |
| -26 dBm ON | Open Circuit | 0 to -0.5 V |
| -16 dBm ON | 0 to -0.5 V | Open Circuit |

When the received signal drops 5 dB below the D109 turn off threshold, D109 will turn off in 5 to 15 milliseconds. The condition of D109 between the selected turn-on and turn-off thresholds is not specified except that a hysteresis action of greater than 2 dB exists between the off-to-on and on-to-off transition levels.

Recommended circuits to control THRESH1 and THRESH2 input interface lines are shown in the diagrams on page 5 (A, B and C).

## Bit Error Rates

The V96P/1 is thoroughly tested to guarantee Bit Error Rate (BER) performance under test conditions equivalent to CCITT Recommendation V.26. The test set-up used by Rockwell is shown in the BER Performance Test Set-up diagram.

The results of these BER performance tests are shown in the Typical Bit Error Rate Performance diagram.

## V96P/1 Configurations

| No. | Configuration | Transmitter ITC (1P-5P) (Octal Code) | Receiver IRC (1P-5P) (Octal Code) | Signal Structure IRSS (1P-2P) ITSS (1P-2P) (Octal Code) | Data Rate (bps) | Training Time ( msec ) | Carrier Frequency (Hz) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1. | 2400 Baud DIAL | 02 | 00 | 0,1,2 |  | 320 | 1706 2/3 |
| 2. | 2400 Baud DIAL - T/2 | 02 | 01 | 0,1,2 | 9600 | 320 | 1706 2/3 |
| 3. | 2400 Baud P-P | 00 | 00 | 0,1,2 | 7200 | 280 | 1706 2/3 |
| 4. | 2400 Baud P-P - T/2 | 00 | 01 | 0,1,2 | 4800 | 280 | $17062 / 3$ |
| 5. | 2400 Baud V29 | 01 | 02 | 0,1,2 |  | 233 | 1700 |
| 6. | 2400 Baud V29 - T/2 | 01 | 03 | 0,1,2 |  | 233 | 1700 |
| 7. | 1600 Baud DIAL, CCITT DIAL | 22 | 22 | 1,3 | 4800 | 181 | NOTE |
| 8. | 1600 Baud DIAL - T/2 | 22 | 36 | 1,3 | 4800 | 181 | NOTE |
| 9. | 1600 Baud DIAL Slow | 36 | 22 | 1,3 | 4800 | 221 | NOTE |
| 10. | 1600 Baud P-P | 20 | 20 | 1,3 | 4800 | 141 | NOTE |
| 11. | 1600 Baud P-P - T/2 | 20 | 32 | 1,3 | 4800 | 141 | NOTE |
| 12. | 1600 Baud Echo | 34 | 34 | 1,3 | 4800 | 480 | NOTE |
| 13. | 1600 Baud Manual CCITT | 32 | 30 | 3 | 4800 | 20 (V. 27 Sync Sequence) | 1800 |
| 14. | 1600 Baud Manual CCITT | 30 | 30 | 3 | 4800 | 50 (V. 27 Sync Sequence) | 1800 |
| 15. | 1600 Baud V27 DIAL/P-P | 23 | 23 | 3 | 4800 | 708 | 1800 |
| 16. | 1600 Baud V27 DIAL/P-P EP | 27 | 23 | 3 | 4800 | 923 | 1800 |
| 17. | 1600 Baud V27 DIAL/P-P - T/2 | 23 | 33 | 3 | 4800 | 708 | 1800 |
| 18. | 1600 Baud V27 DIAL/P-P - T/2 EP | 27 | 33 | 3 | 4800 | 923 | 1800 |
| 19. | 1600 Baud V27 Multipoint - T/2 | 21 | 27 | 3 | 4800 | 50 | 1800 |
| 20. | 1600 Baud V27 Resync (use with configuration 15) | 21 | 25 | 3 | 4800 | 50 | 1800 |
| 21. | 1600 Baud V27 Resync EP (use with configuration 16) | 25 | 25 | 3 | 4800 | 265 | 1800 |
| 22. | 1600 Baud V27 Resync - T/2 (use with configuration 17) | 21 | 35 | 3 | 4800 | 50 | 1800 |
| 23. | 1600 Baud V27 Resync - T/2 EP (use with configuration 18) | 25 | 35 | 3 | 4800 | 265 | 1800 |
| 24. | 1600 Baud V27 Echo | 23 | 37 | 3 | 4800 | 708 | 1800 |
| 25. | 1600 Baud V27 Echo EP | 27 | 37 | 3 | 4800 | 923 | 1800 |
| 26. | 1200 Baud DIAL | 14 | 10 | 3 | 2400 | 170 | 1800 |
| 27. | 1200 Baud P-P | 10 | 10 | 3 | 2400 | 117 | 1800 |
| 28. | 1200 Baud V27 DIALP-P | 13 | 11 | 3 | 2400 | 943 | 1800 |
| 29. | 1200 Baud V27 DIALP-P EP | 17 | 11 | 3 | 2400 | 1158 | 1800 |
| 30. | 1200 Baud V27 Multipoint | 11 | 15 | 3 | 2400 | 66 | 1800 |
| 31. | 1200 Baud V27 Resync (use with configuration 28) | 11 | 13 | 3 | 2400 | 66 | 1800 |
| 32. | 1200 Baud V27 Resync EP (use with configuration 29) | 15 | 13 | 3 | 2400 | 281 | 1800 |

NOTE: Carrier frequency is $17062 / 3 \mathrm{~Hz}$ when IRSS (1P-2P) is a 1 ( 8 -point). Carrier frequency is 1800 Hz when IRSS (1P-2P) is a 3 ( 8 -phase DPSK).

## Data Scrambler Selection

The V96P/1 makes available to the user one CCITT V. 29 compatible scrambler, five different period 127 scramblers (and descramblers), and a no-scramble option. These scramblers provide data transmitted by the V96P/1 with the degree of randomness necessary to ensure the continued convergence of all adaptive processes at the receiver. The seven possible scrambler configurations that are user software selectable are:

- Period 127 cryptographic
- Period 127 synchronizing
- CCITT period 127 self-synchronizing (compatible with CCITT Recommendation V.29)
- Period $8,388,607$ self-synchronizing (compatible with CCITT Recommendation V.29)
- Period 127 self-synchronizing with 8 -bit protection
- CCITT period 127 self-synchronizing (compatible with CCITT Recommendations V. 27 bis and ter)
- No scrambler

All scramblers can be used with all modem configurations listed in the above table except for the cryptographic scrambler which cannot be used in the CCITT V. 29 configuration.

## MODES OF OPERATION

The V96P/1 has two modes of operation; a training mode and a data mode. In order for the receiver to correctly decode the transmitted data, the V96P/1 must detect the presence of a line signal, adjust the AGC, detect the presence of a training sequence, recover the baud timing of the transmitter, phase and frequency lock to the carrier associated with the received signal, and adapt the equalizer to the amplitude and delay characteristics of the channel. This learning process is accomplished most efficiently when the transmitter initiates a training sequence whenever a new transmitter-receiver

connection is made. It is possible to set up the receiver without a training sequence, but it is a manual mode requiring considerable user effort. In a training mode, an internal generated pattern is transmitted to the receiver to facilitate synchronization. During the training mode, the data input line to the receiver is ignored and the output line does not reflect the state of the data input.

In the data mode of operation, information on the data input is strobed by the transmitter signal element clock and transmitted to the receiver. The receiver demodulates and decodes the passband signal and outputs the recovered data on the output where it is then ready to.be strobed by the receiver signal element clock.

## Request To Send-Ready For Sending

To initiate transmitter operation in the data or training mode, the Request to Send input is brought high. If a training mode is not initiated, the Ready for Sending indicator goes high within one baud interval and data transmission commences.

The mode of the receiver is indicated by the data channel received line signal detector (D109). For data mode, D109 is high and the receiver training mode indicator is low.

If the receiver enters the training mode, the receiver training mode indicator goes high until the training mode is completed. When training is completed the receiver training mode indicator goes low and, if sufficient signal energy is present on the input line, D109 goes high, enabling the data mode.

## Training Mode—Dial and Point-To-Point

For dial and point-to-point configurations, the V96P/1 receiver training is automatically initiated whenever a training sequence is detected in the received line signal. The training sequence consists of two phases: Phase 1 causes the training detector to turn on and also makes a course adjustment of the carrier frequency variable, which compensates for any frequency translation due to the channel; Phase 2 is used to converge the adaptive equalizer, which is part of the V96P/1 structure.

A short scrambler synchronization sequence follows Phase 2 and is used to generate the success indicator. In order for training to be successful, the incoming training sequence must have been generated by a similarly configured transmitter using a compatible training sequence.

At the receiver, detection of a training sequence requires that there be sufficient signal energy and that the receiver's carrier frequency variable be within 30 Hz of nominal.

## Training Resync (V. 27 bis/ter Turnaround)

In a 2-wire half-duplex data communication system, data can be transmitted in only one direction at any given instant. Therefore, the modems at the local and remote sites are required to interchange their roles as the receiver and the transmitter, respectively. This turnaround operation requires constant resynchronization to meet CCITT Recommendations for V. 27 bis/ter.

The resync configurations are used for reacquiring synchronization in turnaround operation without having to go through the normal long training sequence. The resync training sequences are relatively short and are used for recovering carrier phase, symbol timing and achieving equalizer convergence without resetting carrier frequency and equalizer taps.

## Training Mode-Multipoint

In the V96P/1 modem, two multipoint configurations are provided for 4 -wire circuits conforming to M1020 which permit short training sequences. In these configurations, the first train signal must be high to process the short training sequences; otherwise the receiver will ignore the training sequence and enter directly into the data mode. The receiver will enter into the training mode if the first train signal is high and there is sufficient signal energy.

For 4-wire circuits which are worse than M1020 and for 2 -wire circuits, a long training sequence should be used rather than the multipoint configuration. These training sequences require that the receiver be in the proper dial/ point-to-point configuration.

## Training Mode-Manual

The V96P/1 modem includes two manual configurations in which the remote modem need not transmit a special training sequence to the local receiver. In these configurations, the equalizer tap coefficients for the local receiver must be initialized from an external source. The tap coefficients may be initialized by controlling three input terms-ICR, ICl and ICLCP-in synchronization with the Baud Rate Clock.

In order to operate the modem in the manual configurations, both the transmitter and receiver must be set according to the code shown in Table 1 Modem Configuration. Manual configuration code octal 30 has a longer synchronizing sequence than configuration code octal 32, but both synchronizing sequences conform to the CCITT Recommendation V.27. However, neither sequence is of sufficient duration to aid in training the receiver.

## Receiver Operation During Loss of Line Signal

When there is no line signal present, all receiver update relating to the equalizer, carrier frequency variable and baud timing are inhibited and the current values of the equalizer taps and the carrier frequency variable are retained.

## DATA QUALITY

The receiver generates an Eye Quality Monitor (EQM) signal that can be used to determine the equivalent Gaussian signal to noise ratio of the overall system within approximately $\pm$

2 db . Eye quality is determined by calculating the difference between the received signal point after equalization and the transmitted or expected signal point. The receiver output DEQ2P is a filtered version of this error signal. It is a serial word clocked by the system bit clock ( 345.6 kHz or 230.4 kHz , depending on baud rate). Output signal DQGTP is a gating signal which delineates the eight MSB's of DEQ2P. The use and interpretation of these binary signals are quite complex and are dependent on the application and the signal structure. The user can derive a meaningful interpretation of the EQM readings by monitoring them while testing the modem against his performance criteria.

## Visual Display of Eye Pattern

A visual indication of the modem's performance can be obtained by displaying the received baseband signal structure after equalization. This is done by converting the eight MSB's of the real and imaginary equalized signal points available on DRERP and DIERP to analog voltages which are then used to drive the horizontal and vertical sweeps of an oscilloscope. The resultant display will be a symmetrical dot pattern of 16 points, 8 points, or 4 points which is a time representation of the received baseband signal. Any uncompensated distortion over the transmission path will cause each dot in the pattern to enlarge or otherwise show distortion. A typical visual eye pattern of a 4-point display is shown in the following diagram.


Typical Eye Pattern

## Success Indicator

A second data quality indicator is provided for in all configurations except the 1200 baud non-V. 27 modes. This signal provides a rough indication that the training has been successful and that data will be properly received. This "success" output (DSUCP) will go high during the last one to twenty milliseconds of receiver training, provided training has been successful. During the data mode (DRTMP low and D109 high), DSUCP will go high whenever 15 consecutive data marks or spaces are decoded at the receiver data output.

## ADDITIONAL CAPABILITIES

The V96P/1 provides many additional capabilities germane to data communication system design and implementation. Capabilities such as local loopback, tone generation and detection, external clock facilities, and 300 bps FSK operation are briefly described in the following paragraphs.

## Local Loopback Capability

A local loopback option is available for all half duplex and full duplex modem configurations. The Local Loopback Command (ILB) connects the transmitter's output through a buffer amplifier to the receiver input, thereby allowing a check of the local modem. The ILB command squelches the input to the receiver and loops the analog signal from the transmitter to the receiver input.

An internal pattern generator is also incorporated in the modem which can be used when no modem test set is available.

## Tone Generation And Detection

The transmitter can be used to transmit single frequency tones for disabling echo suppressors or for system signaling. Tones that can be transmitted (selected through software control) are: $1100 \mathrm{~Hz}, 1300 \mathrm{~Hz}, 1650 \mathrm{~Hz}, 1850 \mathrm{~Hz}, 2025 \mathrm{~Hz}$, and 2100 Hz . Other tones are also possible and the carrier frequency can be altered by selection of values for a binary bit stream.

## External Data Clock

The data input to the transmitter can be clocked from an external source when the external clock is used as a reference input to the data clock's phase locked loop. By applying an external clock the reference input will cause the transmitter data clock to track the frequency and phase of the reference. The frequency of the reference clock must be within 100 ppm of nominal in order for the receiver's baud timing to properly track that of the transmitter. The reference clock can be equal to the nominal data clock frequency or be a subharmonic of it as long as the frequency tolerance is adhered to.

## 300 bps FSK Modem Operation

A CCITT T. 30 compatible 300 bps FSK modem having characteristics of the CCITT V. 21 channel 2 modulation system can also be configured. The FSK modem is capable of generating the $1100,1300,1650$ and 1850 Hz tones.

## SPECIFICATIONS

V96P/1 Specifications

| DC Voltages |  |  |  |
| :---: | :---: | :---: | :---: |
| Voltage | Tolerance | Current (Typical) | Current (Max) |
| $\begin{aligned} & +5 \text { volt } \\ & +12 \text { volt } \\ & -12 \text { volt } \end{aligned}$ | $\begin{aligned} & \pm 5 \% \\ & \pm 5 \% \\ & \pm 5 \% \end{aligned}$ | 135 ma 40 ma 175 ma | $\begin{aligned} & <200 \mathrm{ma} \\ & <70 \mathrm{ma} \\ & <230 \mathrm{ma} \end{aligned}$ |
| NOTE: All voltages must have ripple $\leqslant 0.1$ volts peak-to-peak. |  |  |  |
| Environment |  |  |  |
| Temperature: <br> Relative Humidity: | Operating: $0^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}$ (32 to $\left.140^{\circ} \mathrm{F}\right)$ <br> Storage: $-40^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}\left(-40\right.$ to $176^{\circ} \mathrm{F}$ ) <br> (Stored in heat sealed antistatic bag and shipping container) Up to $90 \%$ noncondensing, or a wet bulb temperature up to $35^{\circ} \mathrm{C}$, whichever is less. |  |  |
| Mechanical |  |  |  |
| Board Structure: <br> Mating Connector: <br> Dimensions: <br> Weight: | Single PC board with edge connector <br> 100 pin, edge connector, two sided, with 0.1 in $(2.54 \mathrm{~cm})$ centers. Recommended Viking $3 \mathrm{VH} 50 / \mathrm{IJND} 5$ or equivalent mating connector. <br> Width-9.188 in ( 23.338 cm ) . Depth-6.288 in ( 15.972 cm ) <br> Less than $0.45 \mathrm{lbs}(0.20 \mathrm{~kg})$ |  |  |

## R48DP 4800 BPS DATA PUMP MODEM

## PRELIMINARY

## INTRODUCTION

The Rockwell R48DP is a synchronous serial 4800 bps modem designed for full-duplex operation over either four-wire dedicated unconditioned lines or half-duplex operation over the general switched telephone network.

The modem satisfies telecommunications requirements specified in CCITT Recommendations V. 27 bis/ter.

The small size and low power consumption of the modem offer the user flexibility in creating a 4800 bps modem design customized for specific packaging and functional requirements.

The modem is capable of operating at 4800 and 2400 bps.

## FEATURES

- User Compatibility: - CCITT V. 27 bis/ter
- Full-Duplex (4-Wire)
- Half-Duplex
- Programmable Tone Generation
- Dynamic Range -43 dBm to 0 dBm
- Diagnostic Capability
- Equalization:
- Automatic Adaptive
- Compromise Cable (Selectable)
- Compromise Link (Selectable)
- DTE Interface:
- Microprocessor Bus
- CCITT V. 24 (RS-232-C Compatible)
- Loopbacks (V. 54 Loop 2, 3 and 4)
- Local Analog
- Remote Analog (Locally Activated)
- Remote Digital (Locally Activated)
- Small Size $-100 \mathrm{~mm} \times 120 \mathrm{~mm}$ ( $4.0 \times 4.8$ inches)
- Low Power Consumption (3 watts,typical)
- Programmable Transmit Output Level
- TTL and CMOS Compatible


R48DP Modem

## TECHNICAL SPECIFICATIONS

The following are the technical specifications for the R48DP modem.

## TRANSMITTER CARRIER FREQUENCIES

The transmitter carrier frequencies are given in the following table:

## Transmitter Carrier Frequencies

| Frequency Type | Specification <br> $(\mathbf{H z} \pm \mathbf{0 . 5 ~ H z})$ |
| :---: | :---: |
| V.27 bis/ter Carrier | 1800 |

## TONE GENERATION

Under control of the host processor, the R48DP can generate voice band tones up to 4800 Hz with a resolution of 0.15 Hz and an accuracy of $0.01 \%$. Tones over 3000 Hz are attenuated.

## SIGNALING AND DATA RATES

The signaling and data rates for the R48DP are defined in the table below:

Signaling/Data Rates

| Parameter | Specification <br> $( \pm \mathbf{0 . 0 1 \% )}$ |
| :--- | :---: |
| Signaling Rate: | 1600 Baud |
| Data Rate: | 4800 bps |
| Signaling Rate: | 1200 Baud |
| Data Rate: | 2400 bps |

## DATA ENCODING

At 1600 baud, the 4800 bps data stream is encoded into tribits per CCITT V. 27 bis/ter.

At 1200 baud, the 2400 bps data stream is encoded into dibits per CCITT V. 27 bis/ter.

## EQUALIZERS

The R48DP provides equalization functions that improve performance when operating over low quality lines.

Cable Equalizers - Selectable compromise cable equalizers in the receiver and transmitter are provided to optimize performance over different lengths of non-loaded cable of 0.4 mm diameter.

Link Equalizers - Selectable compromise link equalizers in the receiver optimize performance over channels exhibiting severe amplitude and delay distortion. Two standards are provided: U.S. survey long and Japanese 3 -link.

Automatic Adaptive Equalizer - An automatic adaptive equalizer is provided in the receiver circuit. The equalizer can be configured as either a $T$ or a $T / 2$ equalizer.

## TRANSMITTED DATA SPECTRUM

If the cable equalizer is not enabled, the transmitter spectrum is shaped by the following raised cosine filter functions:

1. 1200 Baud. Square root of 90 percent
2. 1600 Baud. Square root of 50 percent

The out-of-band transmitter power limitations meet those specified by Part 68 of the FCC's Rules, and typically exceed the requirements of foreign telephone regulatory bodies.

## SCRAMBLER/DESCRAMBLER

The R48DP incorporates a self-synchronizing scrambler/ descrambler. This facility is in accordance with V. 27 bis/ter.

## RECEIVED SIGNAL FREQUENCY TOLERANCE

The receiver circuit of the R48DP can adapt to received frequency error of up to $\pm 10 \mathrm{~Hz}$ with less than 0.2 dB degradation in BER performance.

## RECEIVE LEVEL

The receiver circuit of the modem satisfies all specified performance requirements for received line signal levels from 0 dBm to -43 dBm . The received line signal level is measured at the receiver analog input (RXA).

## RECEIVE TIMING

The R48DP provides a data derived Receive Data Clock (RDCLK) output in the form of a squarewave. The low to high transitions of this output coincide with the centers of received data bits. The timing recovery circuit is capable of tracking a $\pm 0.01 \%$ frequency error in the associated transmit timing source.

## TRANSMIT LEVEL

The transmitter output level is accurate to $\pm 1.0 \mathrm{~dB}$ and is programmable from -1.0 dBm to -15.0 dBm in 2 dB steps.

## TRANSMIT TIMING

The R48DP provides a Transmit Data Clock (TDCLK) output with the following characteristics:

1. Frequency. Selected data rate of 4800 or $2400 \mathrm{~Hz}( \pm 0.01 \%)$.
2. Duty Cycle. $50 \% \pm 1 \%$

Input data presented on TXD is sampled by the R48DP at the low to high transition of TDCLK. Data on TXD must be stable for at least one microsecond prior to the rising edge of TDCLK and remain stable for at least one microsecond after the rising edge of TDCLK.

## EXTERNAL TRANSMIT CLOCK

The transmitter data clock (TDCLK) can be phase locked to a signal on input XTCLK. This input signal must equal the desired data rate to $\pm 0.01 \%$ with a duty cycle of $50 \% \pm 20 \%$.

## TURN-ON SEQUENCE

A total of 8 selectable turn-on sequences can be generated as defined in the following table:

Turn-On Sequences

| No. | V. 27 bis/ter | CTS <br> Response Time <br> (milliseconds) | Comments |
| :---: | :---: | :---: | :--- |
| 1 | 4800 bps long | 708 |  |
| 2 | 2400 bps long | 943 |  |
| 3 | 4800 bps short | 50 |  |
| 4 | 2400 bps short | 67 |  |
| 5 | 4800 bps long | 913 | Preceded by |
| 6 | 2400 bps long | 1148 | Echo Suppressor |
| 7 | 4800 bps short | 255 | Disable Tone |
| 8 | 2400 bps short | 272 | for lines using |
|  |  | echo supressors ${ }^{*}$ |  |

*For short echo protect tone, subtract 155 ms from values of CTS response time.

## TURN-OFF SEQUENCE

For V. 27 ter, the turn-off sequence consists of approximately 10 ms of remaining data and scrambled ones at 1200 baud or approximately 7 ms of data and scrambled ones at 1600 baud followed by a 20 ms period of no transmitted energy.

## CLAMPING

Received Data (RXD) is clamped to a constant mark (one) whenever the Received Line Signal Detector (RLSD) is off.

## RESPONSE TIMES OF CLEAR-TO-SEND (CTS)

The time between the off-to-on transition of Request-To-Send (RTS) and the off-to-on transition of CTS is dictated by the length of the training sequence and the echo suppressor disable tone, if used. These times are listed in the Turn-On Sequences table. If training is not enabled RTS/CTS delay is less than 1 ms .

The time between the on-to-off transition of RTS and the on-tooff transition of CTS in the data state is a maximum of 2 baud times for all configurations.

## RECEIVED LINE SIGNAL DETECTOR (RLSD)

For V. 27 bis/ter, RLSD turns on at the end of the training sequence. If training is not detected at the receiver, the RLSD off-to-on response time is $15 \pm 10 \mathrm{~ms}$. The RLSD on-to-off response time for V. 27 is $10 \pm 5 \mathrm{~ms}$. Response times are measured with a signal at least 3 dB above the actual RLSD on threshold or at least 5 dB below the actual RLSD off threshold.

The RLSD on-to-off response time ensures that all valid data bits have appeared on RXD.

Four threshold options are provided:

1. Greater than -43 dBm (RLSD on) Less than -48 dBm (RLSD off)
2. Greater than -33 dBm (RLSD on) Less than -38 dBm (RLSD off)
3. Greater than -26 dBm (RLSD on) Less than -31 dBm (RLSD off)
4. Greater than -16 dBm (RLSD on) Less than $\mathbf{- 2 1 d B m}$ (RLSD off)

## NOTE

Performance may be at a reduced level when the received signal is less than -43 dBm .

A minimum hysteresis action of 2 dB exists between the actual off-to-on and on-to-off transition levels. The threshold levels and hysteresis action are measured with an unmodulated carrier signal applied to the receiver's audio input (RXA).

## MODES OF OPERATION

The R48DP is capable of being operated in either a serial or a parallel mode of operation.

## SERIAL MODE

The serial mode uses standard V. 24 (RS-232-C compatible) signals to transfer channel data. An optional USRT device (shown in the Functional Interconnect Diagram) illustrates this capability.

## PARALLEL MODE

The R48DP has the capability of transferring channel data up to eight bits at a time via the microprocessor bus.

## MODE SELECTION

Selection of either the serial or parallel mode of operation is by means of a control bit. To enable the parallel mode, the control bit must be set to a 1 . The modem automatically defaults to the serial mode at power-on. In either mode the R48DP is configured by the host processor via the microprocessor bus.


R48DP Functional Interconnect Diagram

## INTERFACE CRITERIA

The modem interface comprises both hardware and software circuits. Hardware circuits are assigned to specific pins in a 64 -pin DIN connector. Software circuits are assigned to specific bits in a 48-byte interface memory.

## HARDWARE SUPERVISORY CIRCUITS

Signal names and descriptions of the hardware supervisory circuits, including the microprocessor interface, are listed in the R48DP Hardware Supervisory Circuits table. The microprocessor interface is designed to be directly compatible with an 8080 microprocessor. With the addition of a few external logic gates, it can be made compatible with 6500, 6800, or 68000 microprocessors.

R48DP Hardware Supervisory Circuits

| Name | I/O | Pin No. | Description |
| :--- | :---: | :---: | :--- |
| A. OVERHEAD: |  |  |  |
| AGND | 1 | $31 C, 32 C$ | Analog Ground |
| DGND | 1 | $3 C, 8 C, 5 A, 10 \mathrm{~A}$ | Digital Ground |
| +5 volts | 1 | $19 \mathrm{C}, 23 \mathrm{C}, 26 \mathrm{C}, 30 \mathrm{C}$ | +5 volt supply |
| + 12 volts | 1 | $15 A$ | +12 volt supply |
| -12 volts | 1 | 12 A | -12 volt supply |
| POR | I/O | 13 C | Power-on-reset |

R48DP Hardware Supervisory Circuits (Cont.)

| Name | I/O | Pin No. | Description |
| :---: | :---: | :---: | :---: |
| B. MICROPROCESSOR INTERFACE: |  |  |  |
| D7 | 1/0 | 1 C |  |
| D6 | $1 / 0$ | 1A |  |
| D5 | 1/0 | 2 C |  |
| D4 | 1/0 | 2A | Data Bus (8 Bits) |
| D3 | 1/O | 3A |  |
| D2 | $1 / 0$ | 4 C |  |
| D1 | $1 / 0$ | 4A |  |
| D0 | 1/0 | 5 C |  |
| RS3 | 1 | 6 C |  |
| RS2 | I | 6A | Register Select (4 Bits) |
| RS1 | I | 7 C |  |
| RSO | 1 | 7A |  |
| $\overline{\text { CSO }}$ | 1 | 10 C | Chip Select for Bank 0 |
| CS1 | , | 9 C | Chip Select for Bank 1 |
| CS2 | 1 | 9 A | Chip Select for Bank 2 |
| READ | 1 | 12 C | Read Enable |
| WRITE | 1 | 11 A | Write Enable |
| $\overline{\mathrm{IRQ}}$ | 0 | 11C | Interrupt Request |
| C. V. 24 INTERFACE: |  |  |  |
| $\overline{\text { RDCLK }}$ | 0 | 21A | Receive Data Clock |
| TDCLK | 0 | 23A | Transmit Data Clock |
| XTCLK | 1 | 22A | External Transmit Clock |
| RTS | 1 | 25A | Request-to-Send |
| CTS | 0 | 25C | Clear-to-Send |
| TXD | 1 | 24 C | Transmitter Data |
| RXD | 0 | 22 C | Receiver Data |
| $\overline{\text { RLSD }}$ | 0 | 24A | Received Line Signal Detector |

R48DP Hardware Supervisory Circuits (Cont.)

| Name | I/O | Pin No. | Description |
| :--- | :---: | :---: | :--- |
| D. ANCILLARY CIRCUITS: |  |  |  |
| $\overline{\text { RBCLK }}$ | 0 | $26 A$ | Receiver Baud Clock <br> Transmitter Baud Clock |
| TBCLK | 0 | $27 C$ |  |
| E. ANALOG SIGNALS: |  |  |  |
| TXA | 0 | $31 A$ | Transmitter Analog Output |
| RXA | 1 | $32 A$ | Receiver Analog Input |
| AUXIN | 1 | $30 A$ | Auxiliary Analog Input |



Microprocessor Interface Timing Diagram
Critical Timing Requirements

| Characteristic | Symbol | Min | Max | Units |
| :--- | :---: | :---: | :---: | :---: |
| $\overline{\text { CSi, RSi setup time prior }}$to Read or Write | TCS | 30 | - | nsec |
| Data access time after Read | TDA | - | 140 | nsec |
| Data hold time after Read | TDH | 10 | 50 | nsec |
| CSi, RSi hold time after |  |  |  |  |
| Read or Write | TCH | 10 | - | nsec |
| Write data setup time | TWDS | 75 | - | nsec |
| Write data hold time | TWDH | 10 | - | nsec |
| Write strobe pulse width | TWR | 75 | - | nsec |

## INTERFACE MEMORY

The R48DP has three banks of 16 input/output (I/O) registers to which an external (host) microprocessor has access. Although these I/O registers are within the modem, they may be addressed as part of the host processor's memory space. These I/O
registers are collectively referred to as interface memory. See R48DP Interface Memory table. Access to the three banks of registers (bank 0, bank 1 and bank 2 ) is enabled by the Chip Select signals $\overline{\text { CSO }}, \overline{\mathrm{CS} 1}$ and $\overline{\mathrm{CS} 2}$ respectively. Four Register Select signals (RS0, RS1, RS2, and RS3 are provided to address an individual register within an enabled bank. Registers in bank 1 operate at the sample rate of 9600 samples per second. Registers in banks 0 and 2 operate at the selected baud rate.

R48DP Interface Memory

| Bank | (HEX) <br> Reg No. | Description |
| :---: | :---: | :---: |
| 0 | F | Do Not Use |
| 0 | E | Transmitter Handshake |
| 0 | D | Do Not Use |
| 0 | C | Do Not Use |
| 0 | B | Do Not Use |
| 0 | A | Do Not Use |
| 0 | 9 | Do Not Use |
| 0 | 8 | Do Not Use |
| 0 | 7 | Transmitter Option |
| 0 | 6 | Transmitter Configuration |
| 0 | 5 | Equalizer |
| 0 | 4 | Loop/Level |
| 0 | 3 | FREQM |
| 0 | 2 | FREQL |
| 0 | 1 | Do Not Use |
| 0 | 0 | Transmitter Data |
| 1 | F | Do Not Use |
| 1 | E | Receiver Sample Handshake |
| 1 | D | Do Not Use |
| 1 | C | Do Not Use |
| 1 | B | Receiver Baud Status |
| 1 | A | Do Not Use |
| 1 | 9 | Receiver Sample Status 2 |
| 1 | 8 | Receiver Sample Status 1 |
| 1 | 7 | Receiver Option |
| 1 | 6 | Receiver Configuration |
| 1 | 5 | Diagnostic Control XS |
| 1 | 4 | Diagnostic Control YS |
| 1 | 3 | Diagnostic Data XSM |
| 1 | 2 | Diagnostic Data XSL |
| 1 | 1 | Diagnostic Data YSM |
| 1 | 0 | Diagnostic Data YSL; Receiver Data |
| 2 | F | Do Not Use |
| 2 | E | Receiver Baud Handshake |
| 2 | D | Do Not Use |
| 2 | C | Do Not Use |
| 2 | B | Do Not Use |
| 2 | A | Do Not Use |
| 2 | 9 | Do Not Use |
| 2 | 8 | Do Not Use |
| 2 | 7 | Do Not Use |
| 2 | 6 | Do Not Use |
| 2 | 5 | Diagnostic Control XB |
| 2 | 4 | Diagnostic Control YB |
| 2 | 3 | Diagnostic Data XBM |
| 2 | 2 | Diagnostic Data XBL |
| 2 | 1 | Diagnostic Data YBM |
| 2 | 0 | Diagnostic Data YBL |

When information in these I/O registers is being discussed, the format $Y: Z: Q$ is used. The bank is specified by $Y(0-2)$, the register by $Z(0-F)$, and the bit by $Q(0-7,0=L S B)$. $A$ bit is considered to be 'on'" when set to a 1.

## SOFTWARE SUPERVISORY CIRCUITS

The operation of the R48DP is affected by a number of software control inputs. These inputs are written into registers within the modem via a microprocessor bus under external control. Bits designated by an $X$ are "Don't Care"' inputs that can be set to either 1 or 0 . Modem operation is monitored by various software flags that are read from modem registers using the same microprocessor bus. Bits designated by an X are "undefined"' outputs that may be either 1 or 0 . The functions of all modem I/O registers are listed in the R48DP Interface Memory table and are defined as follows:

## TRANSMITTER CONFIGURATION REGISTER

The host processor configures the R48DP transmitter by writing a control byte into the transmitter configuration register ( $0: 6$ ) in its interface memory space as shown in the following table:
Transmitter Configuration Register (0:6)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TNXMT | 0 | TLTS | X | X | X | TDR2 | TDR1 |

## Definition of Transmitter Configuration Terms:

TNXMT: Tone Transmit
TLTS: Transmitter Long Training Sequence
TDR2: Transmitter Data Rate 2
Selects 4800 bps/V.27)
TDR1: Transmitter Data Rate 1
Selects 2400 bps/N.27)

Control bytes for the three configurations are given in hexadecimal format in the following table:

Configuration Control Bytes

| No. | Configuration | Configuration Bytes (HEX) |
| :---: | :---: | :---: |
| 1 | V.27 4800 Long | 22 |
|  | V.27 2400 Long | 21 |
|  | V.27 4800 Short | 02 |
|  | V.27 2400 Short | 01 |
| 2 | Tone Transmit | 80 |

## Definition of Transmitter Configurations:

1. V.27. When any of the V. 27 configurations have been selected, the modem operates as specified in CCITT recommendation V. 27.
2. Tone Transmit. In this configuration, activating signal RTS causes the modem to transmit a tone at a single frequency specified by the user. Two registers in the host interface memory space contain the frequency code. The most significant bits are specified in the FREQM register ( $0: 3$ ). The least significant bits are specified in the FREQL register ( $0: 2$ ). The least significant bit represents $0.146484 \mathrm{~Hz} \pm 0.01 \%$.

## TRANSMITTER OPTION

The host processor conveys option information to the transmitter by writing a control byte into the Option Register ( $0: 7$ ) in its interface memory space as shown in the table below:

Transmitter Option Register (0:7)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RTS | TTDIS | SDIS | MHLD | EDIS | TPDM | XCEN | SEDT |

## Definition of Transmitter Option Terms:

RTS: Request-to-Send
TTDIS: Transmitter Training Disable
SDIS: Scrambler Disable
MHLD: Mark Hold
EDIS: Echo Protector Disable
TPDM: Transmitter Parallel Data Mode
XCEN: External Clock Enable
SEDT: Short Echo Protection Disable Tone

## Definition of Transmitter Options:

1. Request-to-Send. The R48DP begins a transmit sequence when the RTS bit ( $0: 7: 7$ ) is turned on and continues transmitting until RTS is turned off and the turn-off sequence has been completed. This input bit parallels the operation of the hardware RTS control input.
2. Transmitter Training Disable. When the TTDIS bit ( $0: 7: 6$ ) is on, the transmitter does not generate a training sequence at the start of transmission.
3. Scrambler Disable. When the SDIS bit $(0: 7: 5)$ is on, the transmitter scrambler circuit is removed from the data path.
4. Niark Hold. When the MHLD bit ( $0: 7: 4$ ) is on, the transmitter input data stream is forced to all marks ( 1 's).
5. Echo Protector Disable. When the EDIS bit ( $0: 7: 3$ ) is on, an unmodulated carrier is transmitted for 185 ms (optionally 30 ms ) followed by 20 ms of no transmitted energy at the start of transmission.
6. Transmitter Parallel Data Mode. When the TPDM bit ( $0: 7: 2$ ) is on, the transmitter accepts data for transmission from the data input register rather than the serial hardware data input.
7. External Clock Enable. When the XCEN bit ( $0: 7: 1$ ) is on, the transmitter timing is established by the external clock supplied at the hardware input XTCLK (pin 22A).
8. Short Echo Protector Disable Tone. When the SEDT bit ( $0: 7: 0$ ) is on, the echo protector disable tone is 30 ms long rather than 185 ms .

## EQUALIZER

The host processor conveys equalizer selection information to the modem by writing a control byte into the equalizer register $(0: 5)$ in the interface memory space as shown in the following:

Equalizer Register (0:5)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | X | CABS2 | CABS1 | LAEN | LDEN | A3L | D3L |

## Definition of Equalizer Terms:

CABS1,2: Cable Equalizer (Selects bits 1 or 2)
LAEN: Link Amplitude Equalizer Enable
LDEN: Link Delay Equalizer Enable
A3L: Amplitude 3-Link Select
D3L: Delay 3-Link Select

## Definition of Equalizer Parameters:

1. Cable Equalizer. The cable equalizer select bits simultaneously control amplitude and delay compromise equalizers in both the transmit and receive paths. The following table gives the possible bit combinations.

Cable ( 0.4 mm diameter) Equalizer Selection

| CABS2 | CABS1 | Cable Length |
| :---: | :---: | :---: |
| 0 | 0 | 0.0 |
| 0 | 1 | 1.8 km |
| 1 | 0 | 3.6 km |
| 1 | 1 | 7.2 km |

2. Link Equalizer. The link equalizer enable and select bits control separate amplitude and delay compromise equalizers in the receive path. The following tables give the possible bit combinations.

Link Amplitude Equalizer Selection

| LAEN | A3L | Curve Matched |
| :---: | :---: | :---: |
| 0 | $X$ | No Equalizer |
| 1 | 0 | U.S. Survey Long |
| 1 | 1 | Japanese 3-Link |

## Link Delay Equalizer Selection

| LDEN | D3L | Curve Matched |
| :---: | :---: | :---: |
| 0 | X | No Equalizer |
| 1 | 0 | U.S. Survey Long |
| 1 | 1 | Japanese 3-Link |

## LOOP/LEVEL

The host processor conveys loopback selection and transmitter output level to the modem by writing a control byte into the loop/level register ( $0: 4$ ) in the interface memory space as shown in the following table:
Loop/Level Register (0:4)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| L3ACT | L4ACT | L4HG | TL3 | TL2 | TL1 | L2ACT | X |

## Definition of Loop/Level Terms:

LBACT: Local Analog Loopback (CCITT loop 3) Activate
L4ACT: Remote Analog Loopback (CCITT loop 4) Activate
L4HG: Loop 4 High Gain
TL3-TL1: Transmitter Level (Selects bits 3, 2, and 1)
L2ACT: Remote Digital Loopback (CCITT loop 2) Activate

## Definition of Loop/Level Control:

1. Local Analog Loopback Activate. When the L3ACT bit ( $0: 4: 7$ ) is on, the transmitter analog output is coupled to the receiver analog input through an attenuator in accordance with CCITT recommendation V. 54 loop 3.
2. Remote Analog Loopback Activate. When the L4ACT bit ( $0: 4: 6$ ) is on, the receiver analog input is connected to the transmitter analog output through a variable gain amplifier.
3. Loop 4 High Gain. When the L4HG bit ( $0: 4: 5$ ) is on, the loop 4 variable gain amplifier is set for +16 dB . When L4HG is off, the gain is 0 dB .
4. Remote Digital Loopback Activate. When the L2ACT bit ( $0: 4: 1$ ) is on, the receiver digital output is connected to the transmitter digital input in accordance with CCITT recommendation V. 54 loop 2.
5. Transmitter Level Select 3, 2 and 1. Transmitter analog output level is determined by bits TL3, TL2, and TL1 as shown in the following table:

Transmitter Level Selection

| TL3 TL2 TL1 Transmitter Analog Output <br> 0 0 0 $-0.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}{ }^{*}$ <br> 0 0 1 $-2.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ <br> 0 1 0 $-4.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ <br> 0 1 1 $-6.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ <br> 1 0 0 $-8.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ <br> 1 0 1 $-10.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ <br> 1 1 0 $-12.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ <br> 1 1 1 $-14.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$ |
| :--- |
| *Each step is a 2 dB change $\pm 0.2 \mathrm{~dB}$ |

## TRANSMITTER DATA

The host processor conveys output data to the transmitter in parallel mode by writing a data byte to the transmitter Data Register ( $0: 0$ ) in the interface memory space. The data must be divided on integral baud boundries as shown in the following table:

Transmitter Data Register (0:0)

| Configuration | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| V. 274800 bps | X | Baud 1 |  | Baud 0 |  |  |  |  |
| V. 272400 bps | Baud 3 | Baud 2 | Baud 1 | Baud 0 |  |  |  |  |
| NOTE: Data Transmitted Bit 0 First. |  |  |  |  |  |  |  |  |

## FREQM/FREQL

The host processor conveys tone generation data to the transmitter by writing a 16 -bit data word to the FREQM/FREQL registers (0:3 and 0:2) in the interface memory space as shown in the following tables:

FREQM Register

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{15}$ | $2^{14}$ | $2^{13}$ | $2^{12}$ | $2^{11}$ | $2^{10}$ | $2^{9}$ | $2^{8}$ |

FREQL Register

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2^{7}$ | $2^{6}$ | $2^{5}$ | $2^{4}$ | $2^{3}$ | $2^{2}$ | $2^{1}$ | $2^{0}$ |

The frequency number ( N ) determines the frequency $(\mathrm{F}$ ) as follows: $\mathrm{F}=0.146484 \mathrm{~N} \mathrm{~Hz} \pm 0.01 \%$

Hexadecimal frequency numbers (FREQM, FREQL) for commonly generated tones are given in the following table:

Commonly Generated Tones

| Frequency | FREQM | FREQL |
| :---: | :---: | :---: |
| 462 Hz | 0 C | 52 |
| 1100 Hz | 1 D | 55 |
| 1650 Hz | 2 C | 00 |
| 1850 Hz | 31 | 55 |
| 2100 Hz | 38 | 00 |

## TRANSMITTER HANDSHAKE

The host processor performs a handshake sequence with the transmitter by controlling and testing bits in the transmitter handshake register ( $0: E$ ) in the interface memory space as shown in the following table:

Transmitter Handshake Register (0:E)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TIA | X | X | X | TSB | TIE | X | TBA |

## Definition of Transmitter Handshake Terms:

TIA: Transmitter Interrupt Active
TSB: Transmitter Setup Bit
TIE: Transmitter Interrupt Enable
TBA: Transmitter Buffer Available

## Definition of Transmitter Handshake Sequences:

1. Transmitter Buffer Available. The TBA bit goes off when the host processor writes data to transmitter data register ( $0: 0$ ). When the transmitter empties register 0:0 the TBA bit is on.
2. Transmitter Interrupt Enable. When the host processor writes a 1 in the TIE bit, the $\overline{\operatorname{RQQ}}$ line of the hardware interface is driven low when TBA is on.
3. Transmitter Interrupt Active. Status bit TIA is on whenever the transmitter is driving $\overline{\mathrm{RQ}}$ low.
4. Transmitter Setup Bit. When the host processor changes the transmitter configuration register, the host must write a 1 in the TSB bit. Bit TSB goes to 0 when the change becomes effective.

## RECEIVER CONFIGURATION

The host processor configures the receiver by writing a control byte into the receiver configuration register (1:6) in the interface memory space as shown in the following table:

Receiver Configuration Register (1:6)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | X | RLTS | X | X | X | RDR2 | RDR1 |

## Definition of Receiver Configuration Terms:

RLTS: Receiver Long Training Sequence
RDR2: Receiver Data Rate 2
Selects $4800 \mathrm{bps} / \mathrm{V} .27$ )
RDR1: Receiver Data Rate 1
Selects 2400 bps/V.27)
Control words for receiver configuration are given in hexadecimal format in the following table:

## Receiver Configuration Control

| No. | Configuration | Configuration Word (HEX) |
| :---: | :---: | :---: |
| 1 | V.27 4800 Long | 22 |
|  | V.27 2400 Long | 21 |
|  | V.27 4800 Short | 02 |
|  | V. 272400 Short | 01 |

## Definition of Receiver Configurations:

When any of the V. 27 configurations has been selected, the transmitter operates as specified in CCITT recommendation V.27.

## RECEIVER OPTION

The host processor conveys option information to the transmitter by writing a control byte into the option register (1:7) in its interface memory space as shown in the following table:

Receiver Option Register (1:7)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RTH2 | RTH1 | DDIS | RPDM | SWRT | BWRT | T2 | RTDIS |

## Definition of Receiver Option Terms:

RTH2, 1: Receiver Energy Detector Threshold (Bits 2 and 1)
DDIS: Descrambler Disable
RPDM: Receiver Parallel Data Mode
SWRT: Sample Write
BWRT: Baud Write
T2: $\quad$ T/2 Equalizer Select
RTDIS: Receiver Training Disable

## Definition of Receiver Options:

1. Receiver Energy Detector Threshold (Bits 2 and 1). The receiver energy detector threshold is set by bits RTH2 and RTH1 according to the following table:

Receiver Energy Detect Thresholds

| RTH2 | RTH1 | RLSD On | RLSD Off |
| :---: | :---: | :---: | :---: |
| 0 | 0 | $>-43 \mathrm{dBm}$ | $<-48 \mathrm{dBm}$ |
| 0 | 1 | $>-33 \mathrm{dBm}$ | $<-38 \mathrm{dBm}$ |
| 1 | 0 | $>-26 \mathrm{dBm}$ | $<-31 \mathrm{dBm}$ |
| 1 | 1 | $>-16 \mathrm{dBm}$ | $<-21 \mathrm{dBm}$ |

2. Descrambler Disable. When the DDIS bit $(1: 7: 5)$ is on, the receiver descrambler circuit is removed from the data path.
3. Receiver Parallel Data Mode. When the RPDM bit (1:7:4) is on, the receiver supplies data to the receiver data register ( $1: 0$ ) in parallel with the hardware serial data output.
4. Sample Write. When the SWRT bit (1:7:3) is on, the 16 -bit word in registers $1: 1$ and $1: 0$ is written in the RAM location specified by the contents of register 1:4.
5. Baud Write. When the BWRT bit ( $1: 7: 2$ ) is on, the 16 -bit word in locations 2:1 and 2:0 is written in the RAM location specified by the contents of register 2:4.
6. $T / 2$ Equalizer Select. When the $T 2$ bit ( $1: 7: 1$ ) is on, an adaptive equalizer with two taps per baud is used. When T2 is off the equalizer has one tap per baud.
7. Receiver Training Disable. When the RTDIS bit (1:7:0) is on, the receiver is prevented from recognizing a training sequence.

## RECEIVER SAMPLE HANDSHAKE

The host processor performs a handshake sequence with the receiver sample rate device by controlling and testing bits in the receiver sample handshake register ( $1: E$ ) in the interface memory space as shown in the following table:

Receiver Sample Handshake Register (1:E)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RSIA | X | X | X | RSSB | RSIE | X | RSDA |

## Definition of Receiver Sample Handshake Terms:

RSIA: Receiver Sample Interrupt Active
RSSB: Receiver Sample Setup Bit
RSIE: Receiver Sample Interrupt Enable
RSDA: Receiver Sample Data Available

## Definition of Receiver Sample Handshake Sequence:

1. Receiver Sample Data Available. The RSDA bit goes on when the receiver writes data into the receiver data register (1:0). The bit goes off when the host processor reads data from register 1:0.
2. Receiver Sample Interrupt Enable. When the host processor writes a 1 in the RSIE bit, the $\overline{\mathrm{RQ}}$ line of the hardware interface is driven low when RSDA is on.
3. Receiver Sample Interrupt Active. Status bit RSIA is on whenever the Receiver Sample rate device is driving $\overline{\mathrm{RQ}}$ low.
4. Receiver Setup Bit. When the host processor changes the receiver configuration or bits 6 or 7 in the option register, the host must write a 1 in the RSB bit. Bit RSB goes to 0 when the changes become effective.

## RECEIVER BAUD HANDSHAKE

The host processor performs a handshake sequence with the receiver baud rate device by controlling and testing bits in the receiver baud handshake register (2:E) in the interface memory space as shown in the following table:

Receiver Baud Handshake Register (2:E)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RBIA | X | X | X | X | RBIE | X | RBDA |

## Definition of Receiver Baud Handshake Terms:

RBIA: Receiver Baud Interrupt Active
RBIE: Receiver Baud Interrupt Enable
RBDA: Receiver Baud Data Available

## Definition of Receiver Baud Handshake Sequence:

1. Receiver Baud Data Available. The RBDA bit goes on when the receiver writes data into register (2:0). The bit goes off when the host processor reads data from register 2:0.
2. Receiver Baud Interrupt Enable. When the host processor writes a 1 in the RBIE bit, the $\overline{\mathrm{IRQ}}$ line of the hardware interface is driven low when RBDA is on.
3. Receiver Baud Interrupt Active. Status bit RBIA is on whenever the receiver baud rate device is driving $\overline{\mathrm{RQ}}$ low.

## RECEIVER SAMPLE STATUS

The host processor has access to various status bits that reflect operation of the receiver sample rate device. These bits can be tested by the host by reading the receiver sample status word ( $1: 8$ and 1:9) in the interface memory space as shown in the following tables:

## Receiver Sample Status Register 1 (1:8)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | X | X | X | X | P2DET | X | X |

Receiver Sample Status Register 2 (1:9)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | FED | X | X | X | X | X | X |

## Definition of Recelver Sample Status Terms:

P2DET: Period Two Detector
FED: Fast Energy Detector

## Definition of Receiver Sample Status Conditions:

1. Period Two Detector. When the P2DET bit ( $1: 8: 2$ ) is off, it indicates that a P2 sequence has been detected. This bit sets to a 1 at the start of the receive data state.
2. Fast Energy Detector. When the FED bit (1:9:6) is off, it indicates that energy above the receiver threshold is present in the passband.

## RECEIVER BAUD STATUS

The host processor has access to status bits that reflect operation of the receiver baud rate device. These bits can be tested by the host by reading the receiver baud status word (1:B) in the interface memory space as shown in the following table:

Receiver Baud Status Register (1:B)

| Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| X | PNDET | X | X | X | X | X | CDET |

Definition of Receiver Baud Status Terms:
PNDET: Period N Detector
CDET: Carrier Detector

## Definition of Receiver Baud Status Conditions:

1. Period $N$ Detector. When the PNDET bit ( $1: \mathrm{B}: 6$ ) is off, it indicates a PN sequence has been detected. This bit sets to a 1 at the end of the PN sequence.
2. Carrier Detector. When the CDET bit (1:B:0) is off, it indicates that passband energy is being detected and that a training sequence is not in process. It goes off at start of data state and goes to a 1 at end of received signal.

## RECEIVER DATA

The host processor accepts input data from the receiver in parallel mode by reading a byte from the receiver data register (2:0) in the interface memory space. The data is divided on integral baud boundries identical to the transmitter data register with bit 0 received first. Note that the receiver data register is used for diagnostic data in the serial mode.

## DIAGNOSTIC CAPABILITIES

The R48DP provides the user with access to much of the data stored in the modem's memories. This data is a useful tool in performing certain diagnostic functions.

## HARDWARE DIAGNOSTIC CIRCUITS

Signal names and descriptions of the hardware diagnostic circuits are given in the following table:

Hardware Diagnostic Circuits

| Name | I/O | Pin No. | Description |
| :--- | :---: | :---: | :--- |
| EYEX | 0 | $15 C$ | Eye Pattern Data - X Axis |
| EYEY | 0 | 14 A | Eye Pattern Data - Y Axis |
| EYECLK | 0 | 14 C | Eye Pattern Clock |
| EYESYNC | 0 | 13 A | Eye Pattern Synchronizing |
|  |  |  | Signal |

Eye Pattern Generation - The four hardware diagnostic circuits allow the user to generate and display an eye pattern. Circuits EYEX and EYEY serially present eye pattern data for the horizontal and vertical display inputs respectively. The 8-bit data words are shifted out most significant bit first, clocked by the rising edge of the EYECLK output. The EYESYNC output is provided for word synchronization. The falling edge of EYESYNC may be used to transfer the 8 -bit word from the shift register to a holding register. Digital to analog conversion can then be performed for driving the $X$ and $Y$ inputs of an oscilloscope.

## SOFTWARE DIAGNOSTIC CIRCUITS

Each receiver device (sample rate and baud rate) contains six registers in the interface memory space dedicated to reading and writing modem RAM locations from the host processor bus. Four of these registers are organized into 2-byte data words and the remaining two registers form 1-byte control registers that hold RAM access codes. Data is read from RAM into the data registers. Data is written into RAM from the data registers. The RAM location involved in the data transfer is specified by the RAM access code stored in the associated diagnostic control register. The diagnostic registers are related as shown in the following table:

## Software Diagnostic Registers

| Device | Control <br> Register | Write Bit | Data Word <br> (MSB) | Data Word <br> (LSB) |
| :---: | :---: | :---: | :---: | :---: |
| Sample | XS (1:5) | None | XSM (1:3) | XSL (1:2) |
| Sample | YS (1:4) | SWRT (1:7:3) | YSM (1:1) | YSL (1:0) |
| Baud | XB (2:5) | None | XBM (2:3) | XBL (2:2) |
| Baud | YB (2:4) | BWRT (1:7:2) | YBM (2:1) | YBL (2:0) |
| In parallel mode, register 1:0 is used for receive data and |  |  |  |  |
| not diagnostic data. |  |  |  |  |

Data transfer is regulated by the appropriate data available bit. Reading always takes place at the designated rate, and data left in the data registers is overwritten each cycle. When the associated write bit is set, a write cycle is performed each time the associated data available bit is off.

The eight bits of registers 2:3 and 2:1 are continuously presented serially on hardware interface lines EYEX and EYEY respectively.

## RAM ACCESS CODES

The following table lists access codes for frequently used RAM data:

RAM Access Codes

| Bank | Function | Real Access | Imag. <br> Access |
| :---: | :---: | :---: | :---: |
| 1 | Received Signal Samples | C0 | - |
|  | Demodulator Output | C2 | 42 |
|  | Low Pass Filter Output | D4 | 54 |
|  | Average Energy | - | 5C |
|  | AGC Gain Word - MSB's | 81 | - |
|  | AGC Gain Word - LSB's | - | 01 |
| 2 | Equalizer Input | C0 | 40 |
|  | Equalizer Tap Coefficients | 81-A0 | 01-20 |
|  | Unrotated Equalizer Output | E1. | 61 |
|  | Rotated Equalizer Output (Received Points) | A2 | 22 |
|  | Decision Points (Ideal Data Points) | E2 | 62 |
|  | Error | E3 | 63 |
|  | Rotation Angle | - | 00 |
|  | Frequency Correction (MSB's) | AA | - |
|  | Frequency Correction (LSB's) | - | 2 A |
|  | EQM | A7 | - |

## POWER-ON INITIALIZATION

When power is applied to the R48DP, a period of 100 to 300 ms is required for initialization. The power-on-reset signal (POR) remains low during the initialization period. After the low to high transition of POR, the modem is ready to operate. At POR time the modem defaults to the following configuration: V.27, $4800 \mathrm{bps}, \mathrm{T} / 2$, long echo protect disable tone, serial data mode, internal clock, cable select 1.8 Km , amplitude and delay equalizers enabled and Japanese 3 -link curves selected, transmitter output level set to $-0.5 \mathrm{dBm} \pm 0.5 \mathrm{~dB}$, interrupts disabled, and receiver threshold set to -43 dBm .

POR can also be used to initialize the users's host processor. It may be connected to a user supplied power-on-reset signal in a wire-or configuration.

## PERFORMANCE

Functioning as a V. 27 bis/ter type modem, the R48DP provides the user with unexcelled high performance.

Bit Error Rates - The Bit Error Rate (BER) performance of the modem is specified for a test configuration conforming to that specified in CCITT recommendation V.56, except with regard to the placement of the filter used to bandlimit the white noise source. Bit error rates are measured at a received line signal level of -20 dBm as illustrated.


Typical Bit Error Rate Performance

Phase Jitter -At 2400 bps, the modem exhibits a bit error rate of $10^{-6}$ or less with a signal-to-noise ratio of 12.5 dB in the presence of $15^{\circ}$ peak-to-peak phase jitter at 150 Hz or with a signal-to-noise ratio of 15 dB in the presence of $30^{\circ}$ peak-to-peak phase jitter at 120 Hz (scrambler inserted).

At 4800 bps (V. 27 bis/ter), the modem exhibits a bit error rate of $10^{-6}$ or less with a signal-to-noise ratio of 19 dB in the presence of $15^{\circ}$ peak-to-peak phase jitter at 60 Hz .

## INTERFACE CIRCUIT CHARACTERISTICS DIGITAL INTERFACE CIRCUITS

Digital Input Characteristics

| Input Logic State | Allowed Input Voltage Levels |
| :---: | :---: |
| Low | 0.0 V to +0.8 V at $-2.5 \mu \mathrm{~A}$ |
| High | +2.0 V to +5.0 V at $+2.5 \mu \mathrm{~A}$ |

Notes

1. The digital inputs are directly TTL/CMOS compatible. The capacitive loading on each input is 25 pF (maximum).
2. Positive current is defined as current into the node.

Digital Output Characteristics

| Output Logic State | Output Voltage Level |
| :---: | :---: |
| Low | +0.4 V at +1.6 mA <br> +2.4 V at $-100 \mu \mathrm{~A}$ |
| Notes |  |

1. The digital outputs are directly TTL/CMOS compatible.

Capacitive drive capability is 25 pF .
2. Positive current is defined as current into the node.


## ANALOG INTERFACE CIRCUITS

Transmitter Output Level - The transmitter output level is adjustable in 2 dB steps from -0.5 dBm to -14.5 dBm accurate to $\pm 0.5 \mathrm{~dB}$. This level is measured at TXA into a $\mathbf{6 0 0} \mathrm{ohm}$ impedance.

Receiver Input - The receiver input impedance is 63.4 K ohm $\pm 5 \%$.

Auxiliary Transmitter Input - The auxiliary transmitter input (AUXIN) allows access to the transmitter for the purpose of interfacing with user provided equipment. Because this is a sampled data input, signals above 4800 Hz will cause aliasing errors. The input impedance is 1 K ohm and the gain to transmitter output is 0 dB .

## R48DP SPECIFICATIONS

Power Requirements

| Voltage | Tolerance | Current (Max) |
| :---: | :---: | :---: |
| +5 Vdc | $\pm 5 \%$ | $<700 \mathrm{~mA}$ |
| +12 Vdc | $\pm 5 \%$ | $<20 \mathrm{~mA}$ |
| -12 Vdc | $\pm 5 \%$ | $<80 \mathrm{~mA}$ |

Note: All voltages must have ripple $\leq 0.1$ volts peak-to-peak.
Environmental

| Parameter | Specification |
| :---: | :--- |
| Temperature: | $0^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}\left(32\right.$ to $\left.140^{\circ} \mathrm{F}\right)$ |
| Operating- | $-40^{\circ} \mathrm{C}$ to $+90^{\circ} \mathrm{C}\left(-40\right.$ to $\left.176^{\circ} \mathrm{F}\right)$ <br> Storage- |
| Relored in heat sealed antistatic bag Humidity: | and shipping container <br> Up to $90 \%$ noncondensing, or a wet <br> bulb temperature up to $35^{\circ} \mathrm{C}$, <br> whichever is less. |

## Mechanical Information

| Parameter | Specification |
| :---: | :--- |
| Board Structure: | $\begin{array}{l}\text { Single PC board with single right } \\ \text { angle header with } 64 \text { pins, DIN } 41612\end{array}$ |
| or equivalent mating connector. |  |$\}$| Width-3.94 in. $(100 \mathrm{~mm})$ |
| :--- |
| Limensions: |
| Length-4.70 in. $(120 \mathrm{~mm})$ |
| Height- $0.55 \mathrm{in} .(1.40 \mathrm{~cm})$ |
| Less than $.22 \mathrm{lbs} .(.08 \mathrm{~kg})$ |

## V27P/1 <br> HIGH SPEED 4800 BPS MODEM

## INTRODUCTION

The Rockwell V27P/1 is a versatile, high performance, 4800 bps modem on a single printed circuit board. Being CCITT V. 27 compatible, the V27P/1 (with minimal interface circuitry) can operate on dedicated 2-wire or 4-wire half-duplex or 4-wire fullduplex lines. The V27P/1 can also operate in half-duplex on the general switched network.

Measuring approximately 9.2 inches ( 23.3 cm ) by 6.3 inches $(16.0 \mathrm{~cm})$, the $\mathrm{V} 27 \mathrm{P} / 1$ is the smallest full-feature 4800 bps modem that approaches data communication theoretical performance limits.

The V27P/1 meets the tolerances specified in the CCITT V. 27 bis (alternate A), V. 27 ter and FSK T. 30 specifications. In addition, the V27P/1 can be configured to be functionally compatible with those enhanced specifications available in the Rockwell V27P and M48P modem series.

## FEATURES

- Single printed circuit card
- 4800/2400 bps modes
- Full-duplex or half-duplex
- Dedicated or general switched network lines operation
- Ultimate user flexibility:
-CCITT V. 27 ter, V. 27 bis compatible
—Also 300 bps binary signalling per CCITT T. 30
- TTL compatibility
- Automatic adaptive equalizer
- Analog loopback test circuitry
- 0 to -45 dBm dynamic AGC
- LSI signal processing
- High reliability
- Low power consumption:
-Typically 3.5 watts
- Automatic training sequence for receiver


FUNCTIONAL SPECIFICATIONS


## Transmit Carrier and Signalling Frequencies

Carrier Frequency Codex

Compatible QAM:
Carrier Frequency V.27:
Echo Suppression Frequencies:
Signalling Frequencies of T.30:
$1706.667 \mathrm{~Hz} \pm 0.01 \%$ $1800 \mathrm{~Hz} \pm 0.01 \%$ $2100 \mathrm{~Hz} \pm 0.01 \%$ $2025 \mathrm{~Hz} \pm 0.01 \%$ $1850 \mathrm{~Hz} \pm 0.01 \%$ $1650 \mathrm{~Hz} \pm 0.01 \%$ $1300 \mathrm{~Hz} \pm 0.01 \%$ $1100 \mathrm{~Hz} \pm 0.01 \%$

## Received Signal Frequency Tolerance

The receiver can receive frequency errors of up to $\pm 10$ Hz with less than a 0.2 dB degradation in Bit Error Rate performance.

## Data Signalling and Modulation Rate

## At 1600 baud:

| Signalling Rate - | 1600 baud $\pm 0.01 \%$ |
| :--- | ---: |
| Data Rate- | 4800 bps $\pm 0.01 \%$ |
| t 1200 baud: |  |
| Signalling Rate - | 1200 baud $\pm 0.01 \%$ |
| Data Rate- | $2400 \mathrm{bps} \pm 0.01 \%$ |

## Transmitted Data Spectrum

At 1600 baud the transmitted spectrum is shaped by approximately a square root of 50 percent raised cosine filter func-
tion. At 1200 baud the spectrum is shaped by approximately a square root of 90 percent raised cosine filter function.

The 1600 and 1200 baud configurations require a usable bandwidth from 950 Hz to 2650 Hz and 1150 Hz to 2450 Hz respectively.

## Data Encoding

At 1600 baud the data stream is divided into groups of three bits (tribits). The data rate of 4800 bps may use either an 8point QAM structure or 8 -phase structure. Encoding of the tribits in the 8 -phase structure are per CCITT Recommendation V. 27 ter.

At 1200 baud the data stream is divided into groups of two bits (dibits). The data rate of 2400 bps uses a 4-phase data structure. Encoding of the dibits may be per the fallback rate of CCITT Recommendation V. 27 bis and ter (same as V.26A) or V26B depending on the selected configuration.

## Turn-on, Turn-off Sequences

The V27P/1 turn-on sequences are compatible with CCITT Recommendations V. 27 bis (alternate i), V.27, and Rockwell M48P modem specifications.

The turn-off sequences for all V. 27 modes (except the 1600 baud rate manual V. 27 mode) consists of 5 to 10 millisec-
onds of remaining data followed by continuous scrambled 1 's followed by no transmission energy. The period of no transmission energy is provided by turning off the transmitter key signal for a recommended duration of 20 milliseconds.

The turn-off sequences for all non-V. 27 modes consists of 4 to 7 milliseconds of remaining data followed by a period of no transmission energy.

## Ready For Sending Response Times

The Ready For Sending response time to a Request To Send is determined by the configuration selected and its corresponding training time. In Table 1 the Training Times are shown in milliseconds. Note, however, that the 1600 baud manual CCITT configurations actually specify the synchronizing sequence timing per CCITT V. 27 rather than the training time. Also note the following abbreviations.

ITC (1P-5P): Transmitter Configuration Inputs 1 through 5. These five bits establish the octal code
shown where P1 and P2 are the most significant octal digit and P3 through P5 establish the least significant octal digit shown in the chart.

IRC (1P-5P): Receiver Configuration Inputs 1 through 5. These five bits establish the octal code shown where P1 and P2 are the most significant octal digit and P3 through P5 establish the least significant octal digit shown in the chart.

IRSS (1P-2P), Receiver Signal Structure and Transmitter ITSS (1P-2P): Signal Structure. Where P1 and P2 establish an octal code of $0,1,2$, or 3 . They define the signal structures as follows:

1 selects 8 point QAM
3 selects DPSK as: 8 -phase at 1600 baud 4-phase at 1200 baud

V27P/1 Configurations

| No. | Configuration | Transmitter ITC (1P-5P) <br> (Octal Code) | $\begin{gathered} \text { Receiver } \\ \text { IRC (1P-5P) } \\ \text { (Octal Code) } \\ \hline \end{gathered}$ | Signal Structure IRSS (1P-2P) ITSS (1P-2P) (Octal Code) | Data Rate (bps) | Training Time (msec) | Carrier Frequency (hz) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1. | 1600 Baud DIAL, CCITT DIAL | 22 | 22 | 1,3 | 4800 | 181 | NOTE |
| 2. | 1600 Baud DIAL - T/2 | 22 | 36 | 1,3 | 4800 | 181 | NOTE |
| 3. | 1600 Baud DIAL Slow | 36 | 22 | 1,3 | 4800 | 221 | NOTE |
| 4. | 1600 Baud P-P | 20 | 20 | 1,3 | 4800 | 141 | NOTE |
| 5. | 1600 Baud P-P - T/2 | 20 | 32 | 1,3 | 4800 | 141 | NOTE |
| 6. | 1600 Baud Manual CCITT | 32 | 30 | 3 | 4800 | $\begin{aligned} & 20 \text { (Sync } \\ & \text { Sequence) } \end{aligned}$ | 1800 |
| 7. | 1600 Baud Manual CCITT | 30 | 30 | 3 | 4800 | 50 (Sync Sequence) | 1800 |
| 8. | 1600 Baud V27 DIAL/P-P | 23 | 23 | 3 | 4800 | 708 | 1800 |
| 9. | 1600 Baud V27 DIAL/P-P EP | 27 | 23 | 3 | 4800 | 923 | 1800 |
| 10. | 1600 Baud V27 DIAL/P-P - T/2 | 23 | 33 | 3 | 4800 | 708 | 1800 |
| 11. | 1600 Baud V27 DIALP-P - T/2 EP | 27 | 33 | 3 | 4800 | 923 | 1800 |
| 12. | 1600 Baud V27 Multipoint - T/2 | 21 | 27 | 3 | 4800 | 50 | 1800 |
| 13. | 1600 Baud V27 Resync (use with configuration 8) | 21 | 25 | 3 | 4800 | 50 | 1800 |
| 14. | 1600 Baud V27 Resync EP (use with configuration 9) | 25 | 25 | 3 | 4800 | 265 | 1800 |
| 15. | 1600 Baud V27 Resync - T/2 (use with configuration 10) | 21 | 35 | 3 | 4800 | 50 | 1800 |
| 16. | 1600 Baud V27 Resync - T/2 EP (use with configuration 11) | 25 | 35 | 3 | 4800 | 265 | 1800 |
| 17. | 1200 Baud DIAL | 14 | 10 | 3 | 2400 | 170 | 1800 |
| 18. | 1200 Baud P-P | 10 | 10 | 3 | 2400 | $117$ | 1800 |
| 19. | 1200 Baud V27 DIAL/P-P | $13$ | 11 | 3 | 2400 | $943$ | 1800 |
| 20. | 1200 Baud V27 DIAL/P-P EP | $17$ | $11$ | 3 | 2400 | $1158$ | 1800 |
| 21. | 1200 Baud V27 Multipoint | $11$ | $15$ | 3 | $2400$ | $66$ | 1800 |
| 22. | 1200 Baud V27 Resync (use with configuration 19) | 11 | 13 | 3 | 2400 | $66$ | 1800 |
| 23. | 1200 Baud V27 Resync EP (use with configuration 20) | 15 | 13 | 3 | 2400 | 281 | 1800 |

## Received Line Signal Detector (D109)

The time response of the Received Line Signal detector circuit (D109) is a function of the length of the received turn-on sequence. Circuit D109 turns on after synchronizing is completed and prior to user data appearing on the received output line. D109 turns on for approximately 2 milliseconds after the echo protect tone disappears in the V27EP configurations (No. 9, 11, 14, 16, 20 and 23 of the V27P/1 Configuration Chart).

For non-CCITT configurations (No. 1, 2 and 3 in the table on page 3), D109 momentarily goes on at the beginning of the synchronizing sequence.

When no synchronizing signal is detected at the receiver, D109 turns on in 5 to 15 milliseconds for an applied signal greater than 3 dB above the turn on threshold. If training is not enabled at the receiver, D109 turns on in 5 to 15 milliseconds.

Three threshold options are provided:

1) Greater than -43 dBm : Less than -48 dBm :
D109 ON D109 OFF
2) Greater than -26 dBm : Less than -31 dBm :
D109 ON D109 OFF
3) Greater than -16 dBm : Less than - 21 dBm : D109 ON D109 OFF

The three threshold options are controlled by the condition of the THRESH1 and THRESH2 control lines as indicated below.

| dB LEVEL | THRESH1 | THRESH2 |
| :---: | :--- | :--- |
| -43 dBm ON | Open Circuit | Open Circuit |
| -26 dBm ON | Open Circuit | 0 to -0.5 V |
| -16 dBm ON | 0 to -0.5 V | Open Circuit |

When the received signal drops 5 dB below the D109 turn off threshold, D109 will turn off in 5 to 15 milliseconds. The condition of D109 between the selected turn on and turn off thresholds is not specified except that a hysteresis action of greater than 2 dB exists between the off-to-on and on-to-off transition levels.

Recommended circuits to control THRESH1 and THRESH2 input interface lines are shown in diagrams ( $A, B$ and $C$ ).

## Bit Error Rates

The V27P/1 is thoroughly tested to guarantee Bit Error Rate (BER) performance under test conditions equivalent to CCITT Recommendation V.26. The test set-up used by Rockwell is shown in the BER Performance Test Set-up diagram.

The results of these BER performance tests are shown in the Typical Bit Error Rate Performance diagram.

B.


## Suggested Interface Circuits for Controlling THRESH1 and THRESH2 Input Lines

## Data Scrambler Selection

The V27P/1 makes available to the user one CCITT V. 29 compatible scrambler, five different period 127 scramblers (and descramblers), and a no scramble option. These scramblers provide data transmitted by the V27P/1 with the degree of randomness necessary to ensure the continued convergence of all adaptive processes at the receiver. The seven possible, scrambler configurations that are user software selectable are:

- Period 127 cryptographic
- Period 127 synchronizing
- CCITT period 127 self synchronizing (compatible with CCITT Recommendation V.27)
- Period $8,388,607$ self synchronizing (compatible with CCITT Recommendation V.29)
- Period 127 self synchronizing with 8 -bit protection
- CCITT period 127 self synchronizing (compatible with CCITT Recommendations V .27 bis and ter)
- No scrambler

All scramblers can be used with all modem configurations listed in the table on page 3.



Typical Bit Error Rate Performance

## MODES OF OPERATION

The V27P/1 has two modes of operation; a training mode and a data mode. In order for the receiver to correctly decode the transmitted data the V27P/1 must detect the presence of a line signal, adjust the AGC, detect the presence of a training sequence, recover the baud timing of the transmitter, phase and frequency lock to the carrier associated with the received signal, and adapt the equalizer to the amplitude and delay characteristics of the channel. This learning process is accomplished most efficiently when the transmitter initiates a training sequence whenever a new transmitter-receiver connection is made. It is possible to set up the receiver
without a training sequence, but it is a manual mode requiring considerable user effort. In a training mode, an internally generated pattern is transmitted to the receiver to facilitate synchronization. During the training mode, the data input line to the receiver is ignored and the output line does not reflect the state of the data input.

In the data mode of operation, information on the data input is strobed by the transmitter signal element clock and transmitted to the receiver. The receiver demodulates and decodes the passband signal and outputs the recovered data on the output where it is then ready to be strobed by the receiver signal element clock.

## Request To Send-Ready For Sending

To initiate transmitter operation in the data or training mode, the Request to Send input is brought high. If a training mode is not initiated the Ready for Sending indicator goes high within one baud interval and data transmission commences.

The mode of the receiver is indicated by the data channel received line signal detector (D109). For data mode, D109 is high and the receiver training mode indicator is low.

If the receiver enters the training mode, the receiver training mode indicator goes high until the training mode is completed. When training is completed the receiver training mode indicator goes low and, if sufficient signal energy is present on the input line, D109 goes high, enabling the data mode.

## Training Mode-Dial and Point-To-Point

For dial and point-to-point configurations, the V27P/1 receiver training is automatically initiated whenever a training sequence is detected in the received line signal. The training sequence consists of two phases: Phase 1 causes the training detector to turn on and also makes a course adjustment of the carrier
frequency variable which compensates for any frequency translation due to the channel; Phase 2 is used to converge the adaptive equalizer which is part of the V27P/1 structure.

A short scrambler synchronization sequence follows Phase 2 and is used to generate the success indicator. In order for training to be successful, the incoming training sequence must have been generated by a similarly configured transmitter using a compatible training sequence.

At the receiver, detection of a training sequence requires that there be sufficient signal energy and that the receiver's carrier frequency variable be within 30 Hz of nominal.

## Training Resync (V. 27 bis/ter Turnaround)

In a 2-wire half duplex data communication system, data can be transmitted in only one direction at any given instant. Therefore, the modems at the local and remote sites are required to interchange their roles as the receiver and the transmitter respectively. This turnaround operation requires constant resynchronization to meet CCITT Recommendations for V. 27 bis/ter.

The resync configurations are used for reacquiring synchronization in turnaround operation without having to go through the normal long training sequence. The resync training sequences are relatively short and are used for recovering carrier phase, symbol timing and achieving equalizer convergence without resetting carrier frequency and equalizer taps.

## Training Mode-Multipoint

In the V27P/1 modem, two multipoint configurations are provided for 4 -wire circuits conforming to M1020 which permit short training sequences. In these configurations, the first train signal must be high to process the short training sequences; otherwise the receiver will ignore the training sequence and enter directly into the data mode. The receiver will enter into the training mode if the first train signal is high and there is sufficient signal energy.

For 4-wire circuits which are worse than M1020 and for 2 -wire circuits, a long training sequence should be used rather than the multipoint configuration. These training sequences require that the receiver be in the proper dial/ point-to-point configuration.

## Training Mode-Manual

The V27P/1 modem includes two manual configurations in which the remote modem need not transmit a special training sequence to the local receiver. In these configurations, the equalizer tap coefficients for the local receiver must be initialized from an external source. The tap coefficients may be initialized by controlling three input terms-ICR, ICI and ICLCP-in synchronization with the Baud Rate Clock.

In order to operate the modem in the manual configurations, both the transmitter and receiver must be set according to
the code shown in Table 1. Manual configuration code octal 30 has a longer synchronizing sequence than configuration code octal 32, but both synchronizing sequences conform to the CCITT Recommendation V.27. However, neither sequence is of sufficient duration to aid in training the receiver.

## Receiver Operation During Loss of Line Signal

When there is no line signal present, all receiver update relating to the equalizer, carrier frequency variable and baud timing are inhibited and the current values of the equalizer taps and the carrier frequency variable are retained.

## DATA QUALITY

The receiver generates an Eye Quality Monitor (EQM) signal that can be used to determine the equivalent Gaussian signal to noise ratio of the overall system within approximately $\pm$ 2 db . Eye quality is determined by calculating the difference between the received signal point after equalization and the transmitted or expected signal point. The receiver output DEQ2P is a filtered version of this error signal. It is a serial word clocked by the system bit clock ( 345.6 KHz or 230.4 KHz , depending on baud rate). Output signal DQGTP is a gating signal which delineates the eight MSB's of DEQ2P. The use and interpretation of these binary signals are quite complex and are dependent on the application and the signal structure. The user can derive a meaningful interpretation of the EQM readings by monitoring them while testing the modem against his performance criteria.

## Visual Display of Eye Pattern

A visual indication of the modem's performance can be obtained by displaying the received baseband signal structure after equalization. This is done by converting the eight MSB's of the real and imaginary equalized signal points available on DRERP and DIERP to analog voltages which are then used to drive the horizontal and vertical sweeps of an oscilloscope. The resultant display will be a symmetrical dot pattern of 16 points, 8 points, or 4 points which is a time representation of the received baseband signal. Any uncompensated distortion over the transmission path will cause each dot in the pattern to enlarge or otherwise show distortion. A typical visual eye pattern of a 4 point display is shown in the following diagram.


Typical Eye Pattern

## Success Indicator

A second data quality indicator is provided for in all configurations except the 1200 baud non-V. 27 modes. This signal provides a rough indication that the training has been successful and that data will be properly received. This "success" output (DSUCP) will go high during the last one to twenty milliseconds of receiver training, provided training has been successful. During the data mode (DRTMP low and D109 high), DSUCP will go high whenever 15 consecutive data marks or spaces are decoded at the receiver data output.

## ADDITIONAL CAPABILITIES

The V27P/1 provides many additional capabilities germane to data communication system design and implementation. Capabilities such as local loopback, tone generation and detection, external clock facilities, and 300 bps FSK operation are briefly described in the following paragraphs.

## Local Loopback Capability

A local loopback option is available for all half duplex and full duplex modem configurations. The Local Loopback Command (ILB) connects the transmitter's output through a buffer amplifier to the receiver input, thereby allowing a check of the local modem. The ILB command squelches the input to the receiver and loops the analog signal from the transmitter to the receiver input.

An internal pattern generator is also incorporated in the modem which can be used when no modem test set is available.

## Tone Generation And Detection

The transmitter can be used to transmit single frequency tones for disabling echo suppressors or for system signaling. Tone that can be transmitted (selected through software control) are: $1100 \mathrm{~Hz}, 1300 \mathrm{~Hz}, 1650 \mathrm{~Hz}, 1850 \mathrm{~Hz}, 2025 \mathrm{~Hz}$, and 2100 Hz . Other tones are also possible. The carrier frequency can be altered by selection of values for a binary bit stream.

## External Data Clock

The data input to the transmitter can be clocked from an external source when the external clock is used as a reference input to the data clock's phase locked loop. By applying an external clock the reference input will cause the transmitter data clock to track the frequency and phase of the reference. The frequency of the reference clock must be within 100 ppm of nominal in order for the receiver's baud timing to properly track that of the transmitter. The reference clock can be equal to the nominal data clock frequency or be a subharmonic of it as long as the frequency tolerance is adhered to.

## 300 bps FSK Modem Operation

A CCITT T. 30 compatible 300 bps FSK modem having characteristics of the CCITT V. 21 channel 2 modulation system can also be configured. The FSK modem is capable of generating the $1100,1300,1650$ and 1850 Hz tones.

## SPECIFICATIONS

V27P/1 Specifications

| DC Voltages |  |  |  |
| :---: | :---: | :---: | :---: |
| Voltage | Tolerance | Current (Typical) | Current (Max) |
| +5 volt <br> +12 volt <br> -12 volt | $\begin{aligned} & \pm 5 \% \\ & \pm 5 \% \\ & \pm 5 \% \end{aligned}$ | $\begin{array}{r} 135 \mathrm{ma} \\ 40 \mathrm{ma} \\ 175 \mathrm{ma} \end{array}$ | $\begin{aligned} & <200 \mathrm{ma} \\ & <70 \mathrm{ma} \\ & <230 \mathrm{ma} \end{aligned}$ |
| Note: All voltages must have ripple $\leq 0.1$ volts peak-to-peak. |  |  |  |
| Environment |  |  |  |
| Temperature: <br> Relative Humidity: | Operating: $0^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}\left(32\right.$ to $140^{\circ} \mathrm{F}$ ) <br> Storage: $-40^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}\left(-40\right.$ to $176^{\circ} \mathrm{F}$ ) <br> (Stored in heat sealed antistatic bag and shipping container) <br> Up to $90 \%$ noncondensing, or a wet bulb temperature up to $35^{\circ} \mathrm{C}$, whichever is less. |  |  |
| Mechanical |  |  |  |
| Board Structure: <br> Mating Connector: <br> Dimensions: <br> Weight: | Single PC board with edge connector 100 pin, edge connector, two sided, with 0.1 in ( 2.54 cm ) centers. Recommended Viking 3VH50/IJND5 or equivalent mating connector. |  |  |

## PRELIMINARY

## INTRODUCTION

The Rockwell R1212 is a high performance full-duplex 1200 bps modem. Using state-of-the-art VLSI and signal processing technology, the R1212 provides the user with enhanced performance and reliability on a single printed circuit board of less than 22 square-inches-overall size.

The R1212 modem is ideal for data transmission over the 2-wire dial-up telephone network. The direct-connect, auto dial/answer features are specifically designed for remote and central site computer applications. The bus interface allows easy integration into a personal computer, box modem, microcomputer, terminal or any other communications product that demands the utmost in reliability and performance.

The added test features, such as local analog loopback, remote digital loopback, and a self-test function, offer the user flexibility in creating a 1200 bps modem design customized for specific packaging and functional requirements.

Being CCITT V. 22 A, B compatible, as well as Bell 212A and 103 compatible, this modem fits any application for full-duplex 1200 bps (synchronous and asynchronous) and 0 to 300 bps asynchronous data transmission over the general switched telephone network.

## FEATURES

- CCITT V. 22 A, B Compatible
- Bell 212A and 103 Compatible
- Synchronous: $1200 \mathrm{bps}, 600 \mathrm{bps} \pm 0.01 \%$
- Asynchronous: $1200 \mathrm{bps}, 600 \mathrm{bps}+1 \%,-2.5 \%, 0-300 \mathrm{bps}$ -Character length 8, 9, 10, or 11 bits
- DTE Interface
-Functionally: Microprocessor Bus (Control) and RS-232-C Interface (Data/Control)
-Electrically: TL Compatible
- Operation: 2 -wire full-duplex
- Adaptive and Fixed Compromize Equalization
- Test Configurations:
-Local Analog Loopback
-Remote Digital Loopback
-Self Test
- Auto/Manual Answer
- Auto/Manual Dial:
-Tone or Pulse Dial
- Power Consumption: 3 Watts Typical
- Power Requirements: +5 Vdc, $\pm 12 \mathrm{Vdc}$
- Plug-compatible member of new Rockwell modem line
- Two Versions: R1212DC (Direct Connect) with FCC approved DAA Part 68 Interface and R1212M (Module) without DAA


R1212 Full-Duplex Modem

## TECHNICAL SPECIFICATIONS

The following are the technical specifications for the R1212 modem.

## transmitter Carrier and signaling FREQUENCIES

The transmitter carrier and signaling frequencies are given in the following table:

## Transmitter Carrier and Signaling Frequencies Specifications

| Frequency | Specification <br> $(\mathbf{H z} \pm \mathbf{0 . 0 1 \% )}$ |
| :--- | :---: |
| V.22 low channel, Originate Mode | 1200 |
| V.22 high channel, Answer Mode | 2400 |
| Bell 212A high channel Answer Mode | 2400 |
| Bell 212A low channel Originate Mode | 1200 |
| Bell 103/113 Originating Mark | 1270 |
| Bell 103/113 Originating Space | 1070 |
| Bell 103/113 Answer Mark | 2225 |
| Bell 103/113 Answer Space | 2025 |

## TONE GENERATION

The specifications for tone generation are as follows:

1. Answer Backtones: The R1212 is capable of generating echo disabling tones both of the CCITT and Bell versions, as follows:
a. CCITT: $2100 \mathrm{~Hz} \pm 15 \mathrm{~Hz}$.
b. Bell: $2225 \mathrm{~Hz} \pm 10 \mathrm{~Hz}$.
2. Guard Tones: If GTS is low, an 1800 Hz guard tone frequency is selected; if GTS if high, a 553.846 Hz tone is employed. In accordance with the CCITT V. 22 Recommendation, the level of transmitted power for the 1800 Hz guard tone should be $6 \pm 1 \mathrm{~dB}$ below the level of the data power in the main channel. The total power is transmitted to the line should be the same whether or not a guard tone is enabled. If a 553.846 Hz guard is used, its transmitted power should be $3 \pm 1 \mathrm{~dB}$
below the level of the main channel power, and again the overall power transmitted to the line should remain constant whether or not a guard tone is enabled. The device accomplishes this by reducing the main channel transmit path gain by .97 dB and 1.76 dB for the cases of the 1800 Hz and 553.846 Hz guard tones respectively.
3. DTMF Tones: The R1212 is capable of generating dual tone multi-frequency tones. When the transmission of DTMF tones are required, the CRQ and DTMF bits must be set to a 1 . (see Interface Memory). When in this mode, the specific DTMF tones generated are decided by loading transmit register with the appropriate digit as shown in the following table:

Interface Memory Signals

| BCD |  |  |  | Dlal Dlgits | Tone Pairs |  |
| :--- | :--- | :--- | :--- | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 941 | 1336 |
| 0 | 0 | 0 | 1 | 1 | 697 | 1209 |
| 0 | 0 | 1 | 0 | 2 | 697 | 1336 |
| 0 | 0 | 1 | 1 | 3 | 697 | 1477 |
| 0 | 1 | 0 | 0 | 4 | 770 | 1209 |
| 0 | 1 | 0 | 1 | 5 | 770 | 1336 |
| 0 | 1 | 1 | 0 | 6 | 770 | 1477 |
| 0 | 1 | 1 | 1 | 7 | 852 | 1209 |
| 1 | 0 | 0 | 0 | 8 | 852 | 1336 |
| 1 | 0 | 0 | 1 | 9 | 852 | 1477 |
| 1 | 0 | 1 | 0 | $\star$ | 941 | 1209 |
| 1 | 0 | 1 | 1 | Spare (B) | 697 | 1633 |
| 1 | 1 | 0 | 0 | Spare (C) | 770 | 1633 |
| 1 | 1 | 0 | 1 | Spare (D) | 852 | 1633 |
| 1 | 1 | 1 | 0 | $\#$ | 941 | 1477 |
| 1 | 1 | 1 | 1 | Spare (F) | 941 | 1633 |

## TONE DETECTION

The R1212 can detect tones in the 340 to 645 Hz band.

## SIGNALING AND DATA RATES

The signaling and data rates for the R1212 are defined in the table below:

Signaling and Data Rates

| Operating Mode | Signaling Rate (Baud) | Data Rate |
| :---: | :---: | :---: |
| V.22: <br> (Alternative A) <br> Mode i |  |  |
| Mode iii | 600 | $1200 \mathrm{bps} \pm 0.01 \%$ Synchronous |
| (Alternative B) |  |  |
| Mode i |  |  |
| Mode iii | 600 | $600 \mathrm{bps} \pm 0.01 \%$ Synchronous |
| Mode ii | 600 | $1200 \mathrm{bps} \pm 0.01 \%$ Synchronous |
| Mode iv | 600 | $600 \mathrm{bps} \pm 0.01 \%$ Synchronous |
|  | 600 | 1200 bps Asynchronous |
| Bell 212A |  | $8,9,10$, or 11 Bits Per Character |
|  | 600 | $8,9,10$, or 11 Bits Per Character |

## DATA ENCODING

The specifications for data encoding are as follows:

1. 1200 bps (V. 22 and Bell 212A). The transmitted data is divided into groups of two consecutive bits (dibits) forming a four-point signal structure.
2. 600 bps (V.22). Each bit is encoded as a phase change relative to the phase preceding signal elements.

## EQUALIZERS

The R1212 provides equalization functions which can be used to improve performance when operating over poor lines.

Automatic Adaptive Equalizer-An automatic adaptive equalizer is provided in the receiver circuit for V. 22 and Bell 212A configurations.

Fixed Compromise Equalizer-Compromise equalizers are provided in the transmitter and receiver.

## TRANSMITTED DATA SPECTRUM

After making allowance for the nominal specified compromise equalizer characteristic, the transmitted line signal has a frequency spectrum shaped by the square root of a 75 percent raised cosine filter. Similarly, the group delay of the transmitter output is within $\pm 100$ microseconds over the frequency range 800 to 1600 Hz (low channel) and 2000 to 2800 Hz (high channel).

## SCRAMBLER/DESCRAMBLER

The R1212 incorporates a self-synchronizing scrambler/ descrambler. In accordance with the CCITT V. 22 and the Bell 212A recommendations.

## RECEIVED SIGNAL FREQUENCY TOLERANCE

The receiver circuit of the R1212 can adapt to received frequency errors of up to $\pm 7 \mathrm{~Hz}$ with less than a 0.2 dBm degradation in BER performance.

## RECEIVE LEVEL

The receiver circuit of the R1212 satisfies all specified performance requirements for the received line signals from -12 dBm to -45 dBm . The received line signal is measured at the receiver analog input RXA.

## RECEIVE TIMING

The R1212 provides a Receive Data Clock (RDCLK) output in the form of a ( $50 \pm 1 \%$ duty cycle) squarewave. The low to high transitions of this output coincide with the center of received data bits. The timing recovery circuit is capable of tracking a $\pm 0.01 \%$ frequency error in the associated transmit timing source.

## TRANSMIT LEVEL

The R1212M output control circuitry contains a variable gain buffer which reduces the modem output level. The R1212M can be strapped via the host interface memory to accomplish this.

## Transmit Level

| Configuration Word | Transmit Level |
| :---: | :---: |
| 000 | 0 dbm |
| 001 | -2 dbm |
| 010 | -4 dbm |
| 011 | -6 dbm |
| 100 | -8 dbm |
| 101 | $-10 \mathrm{dbm}$ |
| 110 | -12 dbm |
| 111 | -14 dbm |

PERMISSIVE/PROGRAMMABLE CONFIGURATIONS
The R1212M transmit level is set to 0 dBm to allow a DAA to be used. The DAA would then determine the permissive or programmable configuration.
The R1212DC transmit level is strapped in the permissive mode so that the maximum output level is $-9.5 \mathrm{dBm} \pm 0.5 \mathrm{dBm}$.

## TRANSMIT TIMING

The R1212 provides a Transmit Data Clock (TDCLK) output with the following characteristics:

1. Frequency. Selected data rate of 1200 or $600 \mathrm{~Hz}( \pm 0.01 \%)$.
2. Duty Cycle. $50 \pm 1 \%$.

Transmit Data (TXD) must be stable during the one microsecond periods immediately preceding and following the rising edge of TDCLK.

## CLAMPING

The following clamp is provided with the R1212:

1. Receive Data (RXD). RXD is clamped to a constant mark (1) whenever RLSD is off.

## RECEIVED LINE SIGNAL DETECTOR

The high and low channel thresholds are greater than -45 dBm (RLSD on) and less than -48 dBm (RLSD off) for V. 22 and Bell 212A configurations.

## DATA SET READY

The on condition of the R1212 output Data Set Ready (DSR) indicates that the modem is in the data transfer state. The off condition of DSR is an indication that the DTE is to disregard all signals appearing on the interchange circuits-except the calling indicator and the test signal. DSR will switch to the off state when in test state. The on condition of DSR indicates the following:

1. The modem is not in the talk state, i.e., an associated telephone handset is not in control of the line.
2. The modem is not in the process of automatically establishing a call via pulse or DTMF dialing.
3. The modem is generating an answer tone or detecting answer tone.
4. After ring indicate goes on, DSR waits at least two seconds before turning on to allow the bell equipment to be engaged.

DSR will go off 50 msec after DTR goes off or 50 msec plus a maximum of 4 sec when SSD is enabled.


R1212 Functional Interconnect Diagram

## DATA TERMINAL READY

An on condition of DTR prepares the modem to be connected to the communications channel, and maintains the connection established by the DTE (manual answering) or internal (automatic answering) means. The off condition places the modem in the disconnect state.

## MODES OF OPERATION

The R1212 is capable of being operated in either a serial or a parallel mode of operation.

## SERIAL MODE

The serial mode uses standard V. 24 (RS-232-C compatible) signals to transfer channel data. An optional USART device (shown in the diagram above) illustrates this capability.

## CONTROL SELECTION

Selection of either the serial or parallel control is by means of bits ( $[0,1]: \mathrm{D}: 7$ ). To enable the parallel control, the bits must be set to a one. In either mode, the R1212 is configured by the host processor via the microprocessor bus.

## INTERFACE CRITERIA

The modem interface comprises both hardware and software circuits. Hardware circuits are assigned to specific pins in a 64-pin DIN connector. Software circuits are assigned to specific bits in a 32-byte interface memory.

## HARDWARE SUPERVISORY CIRCUITS

Signal names and descriptions of the hardware supervisory circuits, including the microprocessor interface, are given in the following table. The microprocessor interface was designed to be compatible with an $8080,6500,6800$, and 68000 microprocessor.

R1212 Hardware Supervisory Circuits

| Name | Type | Pin No. | Description |
| :---: | :---: | :---: | :---: |
| A. OVERHEAD |  |  |  |
| DGND | G | $5 \mathrm{~A}, 10 \mathrm{~A}$ | Digital Ground |
| AGND | G | 31C, 32C | Analog Ground |
| + 5 VDC | P | 19C, 23C, | +5 Volt Supply |
|  |  | 26C, 30C |  |
| + 12 VDC | P | 15A | +12 Volt Supply |
| $\frac{-12}{P O R} \mathrm{VDC}$ | P | 12A | -12 Volt Supply |
|  | OC | 13C | Power-On-Reset |
| B. MICROPROCESSOR INTERFACE |  |  |  |
| D7 | B | 1 C 7 |  |
| D6 | B | 1A |  |
| D5 | B | 2 C |  |
| D4 | B |  | Data Bus (8-Bits) |
| D3 | B | 3 A |  |
| D2 | B | 4C |  |
| D1 | B | 4A |  |
| D0 | B | 5C |  |
| RS3 | , | 6 C ] |  |
| RS2 | 1 | 6A | Register Select (4-Bits) |
| RS 1 | 1 | 7 C f |  |
| RSO | 1 | 7A |  |
| CSO | 1 | 10 C | Chip Select for Bank 0 |
| CS1 | 1 | 9 C | Chip Select for Bank 1 |
| READ | 1 | 12 C | Read Enable |
| $\frac{\text { WRITE }}{\text { IRQ }}$ | 1 | 11A | Write Enable |
|  | OC | 11 C | Interrupt Request |
| C. V. 24 INTERFACE |  |  |  |
| XTCLK | 1 | 22A | External Transmit Clock |
| TDCLK | 0 | 23A | Transmit Data Clock |
| RDCLK | 0 | 21A | Receive Data Clock |
| CTS | 0 | 25 C | Clear-to-Send |
| TXD | 1 | 24 C | Transmit Data |
| RXD | 0 | 22 C | Receive Data |
| RLSD | 0 | 24A | Received Line Signal Detector |
| $\overline{\text { DTR }}$ | 1 | 21 C | Data Terminal Ready |
| $\overline{\text { DSR }}$ | 0 | 20A | Data Set Ready |
|  | 0 | 18A | Ring Indicator in |
| D. ANALOG SIGNALS (R1212M ONLY) |  |  |  |
| $\begin{aligned} & \text { RXA } \\ & \text { TXA } \end{aligned}$ | 0 | 32A | Receive Analog |
|  | $\bigcirc$ | 31A | Transmit Analog |
| E. SIGNALS TO DAA (R2424M ONLY) |  |  |  |
| $\begin{aligned} & \overline{\mathrm{RD}} \\ & \overline{\mathrm{RCCT}} \\ & \mathrm{CCT} \\ & \mathrm{OH} \end{aligned}$ | 1 | 27A | Ring Detect |
|  | 0 | 28A | Request Coupler Cut Through |
|  | 1 | 29 C | Coupler Cut Through |
|  | 0 | 29A | Off-Hook Relay Control |
| F. ANCILLARY FUNCTIONS |  |  |  |
| $\begin{aligned} & \hline \overline{\text { TBCLK }} \\ & \text { RBCLK } \\ & \overline{\text { TLK }} \end{aligned}$ | $\bigcirc$ | 27 C | Transmit Baud Clock |
|  | 0 | 26A | Receive Baud Clock |
|  | 1 | 28 C | Talk TLK = Data |
|  | , | 16C | Originate ORG $=$ Answer |
| B Bidirectional |  |  |  |
| 1 Input |  |  |  |
| O Output |  |  |  |
| OC Open Collector |  |  |  |
| P Po |  |  |  |
| G Gr |  |  |  |



Microprocessor Interface Timing Diagram

Critical Timing Requirements

| Characteristic | Symbol | Min | Max | Units |
| :--- | :---: | :---: | :---: | :---: |
| $\overline{\text { CSi, RSi setup time prior }}$ |  |  |  |  |
| to Read or Write | TCS | 30 | - | NS |
| Data Access time after Read | TDA | - | 140 | NS |
| Data hold time after Read | TDH | 10 | 50 | NS |
| $\overline{\text { CSi, RSi hold time after }}$ |  |  |  |  |
| Read or Write | TCH | 10 | - | NS |
| Write data setup time | TWDS | 75 | - | NS |
| Write data hold time | TWDH | 10 | - | NS |
| Write strobe pulse width | TWR | 75 | - | NS |

## INTERFACE MEMORY

The R1212 has two banks of 16 registers to which an external (host) microprocessor has access. Although these registers are within the modem, they may be addressed as part of the host processor's memory space. The host may read data out of or write data into these registers. These registers, as shown in the following table, are refered to as interface memory.

When information in these registers is being discussed, the format $Y: Z: Q$ is used. The bank is specified by $Y(0$ or 1$)$, the register by $Z(0-F)$, and the bit by $Q(0-7,0=L S B)$. $A$ bit is considered to be 'on' when set to a one.

| Bank | Reg No. (HEX) | Description | Bank | Reg No. (HEX) | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Do Not Use | 1 | 0 | Dial Digit Register |
| 0 | 1 | Do Not Use | 1 | 1 | Do Not Use |
| 0 | 2 | Diagnostic Data Real LSB's | 1 | 2 | Diagnostic Data Real LSB's |
| 0 | 3 | Diagnostic Data Real MSB's | 1 | 3 | Diagnostic Data Real MSB's |
| 0 | 4 | Diagnostic Data Imaginary LSB's | 1 | 4 | Diagnostic Data Imaginary LSB's |
| 0 | 5 | Diagnostic Data Imaginary MSB's | 1 | 5 | Diagnostic Data Imaginary MSB's |
| 0 | 6 | Do Not Use | 1 | 6 | Do Not Use |
| 0 | 7 | Do Not Use | 1 | 7 | Do Not Use |
| 0 | 8 | Receiver Status | 1 | 8 | Transmitter Status |
| 0 | 9 | Receiver Status | 1 | 9 | Configuration |
| 0 | A | Configuration | 1 | A | Configuration |
| 0 | B | Configuration | 1 | B | Configuration |
| 0 | C | Configuration | 1 | C | Configuration |
| 0 | D | Configuration | 1 | D | Configuration |
| 0 | E | Handshake Status | 1 | E | Handshake Status |
| 0 | F | Diagnostic Control Register | 1 | F | Diagnostic Control Register |

The interface memory bits are defined in the following table:
Interface Memory Definitions

| Name | Definltion | Memory Location | Description |
| :---: | :---: | :---: | :---: |
| AAE | Auto Answer Enable | 1:D:4 | When on, AAE causes the modem to automatically answer when a ringing signal is present on the line. |
| AL | Analog Loopback | (0,1) : B:0 | When on, AL places the modem in analog loopback. (See Software Diagnostic Circuits). |
| BUS | Bus Select | (0,1) :D:7 | When on, BUS places the modem in the parallel control mode. When off, the modem is configured for the serial control mode. Bus can be in either state to configure the modem. |
| CHAR | Character Length Select | $(0,1): C:(3,4)$ | These bits select either 8, 9, 10, or 11 bit characters. (See Character Length table). |
| CRQ | Call Request | $(0,1): D: 6$ | When on, CRQ places the transmitter in auto dial and the receiver in tone detect mode. The data placed in the dial digit buffer is then treated as digits to be dialed. After the last digit has been dialed, FF (Hex) should be loaded into the buffer to tell the modem to go to the data state. CRQ in the transmitter (Bank 1) when turned off causes the modem to go on-hook. Therefore, it should be on for the duration of the call and not turned off until it is desired to go onhook. CRQ in the receiver (Bank 0) must be turned off immediately after ringback is detected to put the modem in the data mode, otherwise no answerback tone will be detected. |
| CTS | Clear-to-Send | 1:8:6 | When on, CTS indicates to the terminal equipment that the modem will transmit any data which are present at TXD. |
| DATA | Talk/Data | 1:D:5 | When on, DATA places the modem in data state and when off in the talk state. |

Interface Memory Definitions (Continued)

| Name | Definition | Memory Location | Description |
| :---: | :---: | :---: | :---: |
| DDEI | Dial Digit Empty Interrupt | 1:E:2 | When on, DDEI causes an interrupt to occur when the dial digit register (1:0) is empty (DDRE $=1$ ). |
| DDRE | Dial Digit Register Empty | 1:E:0 | When on, DDRE indicates that the dial digit register is empty and can be loaded with new digits to be dialed. After the register is loaded, DDRE goes off. |
| DL | Digital Loopback (Manual) | $(0,1): A: 5$ | When on, DL manually places the modem in digital loopback. (See Software Diagnostic Circuits). |
| DLO | Data Line Occupied | 1:8:7 | When on, DLO indicates that the modem is in auto dial, i.e., CRQ is on and the modem is off-hook ready to dial. |
| DSR | Data Set Ready | 1:8:5 | When on, DSR indicates that the modem hanshake has begun and that the data state will follow. DSR alone should not be used to indicate that the communication channel has been completely established. DSR in conjunction with CTS and RLSD will determine this. DSR will be off in all test states (except optionally for analog loopback) and when the channel is being used for voice communication (talk). |
| DSRA | Data Set Ready In Analog Loopback | 1:C:7 | When on, DSRA causes DSR to be on during analog loopback. |
| DTMF | Touch Tones/ Pulse Dialing | 1:B:1 | When on, DTMF tells the modem to auto dial using tones. When off the modem should dial using pulses. |
| DTR | Data Terminal Ready | 1:D:3 | DTR must be on before the modem will enter the data state, either manually or automatically. DTR must also be on in order for the modem to automatically answer an incoming call. |
| ENSI | Enable New Status Interrupt | $(0,1): E: 6$ | When on, ENSI causes an interrupt to occur when the status bits in registers ( $0:[8,9]$ ) and ( $1: 8$ ) are updated. (NEWS $=1$ ) |
| ERDL | Enable Response to Remote Digital Loopback | $(0,1): A: 7$ | When on, ERDL enables the modem to respond to another modem's remote digital loopback request, thus going into loopback. |
| GTE | Guard Tone Enable | 1:B:4 | When on, GTE causes the specified guard tone to be transmitted (CCITT Configurations only). |
| GTS | Guard Tone Select | 1:B:3 | When off, GTS selects the 1800 Hz tone and when on the 550 Hz tone. |
| IRQ | Interrupt Request | $(0,1): E: 7$ | When on, IRQ indicates that an interrupt has been generated. |
| LCD | Enable Loss of Carrier Disconnect | 0:D:2 | When on, LCD causes the modem to terminate a call when a loss of received carrier energy is detected after approximately 350 msec . |
| MODE | Mode Select | $(0,1): A:(0-3)$ | These bits select the compatibility at which the modem is to operate. (See Mode Select table). |
| NEWC | New Configuration | $(0,1): E: 3$ | When on, NEWC tells the modem that a new configuration has been written into the configuration registers. The modem will then read the configuration registers and then reset NEWC. NEWC must be set after a new configuration has been written into the following registers: ( $0:[A-D]$ ) and (1:[9-D]). The remaining registers do not require the use of NEWC to tell the modem that new data was written into them. |
| NEWS | New Status | $(0,1): E: 5$ | When on, NEWS tells the user that there has been a change of status in the status registers. |


| Name | Definition | Memory Location | Description |
| :---: | :---: | :---: | :---: |
| ORG | Originate/Answer | 1:9:5 | When on, ORG tells the modem that it is originating a call and when low answering a call. This is only valid in manual originate/answer and analog loopback. |
| RDL | Initiate Remote Digital Loopback | (0,1): : A: 6 | When on, RDL causes the modem to initiate a request for the remote modem to go into digital loopback. |
| RDLI | Remote Digital Loopback Indicator | 0:8:1 | When on, RDLI indicates that the modem has received an RDL request and is in remote digital loopback. |
| RI | Ring Indicator | 1:8:4 | When on, R1 indicates that a ringing signal is being detected. |
| RLSD | Received Line Signal Detector | 0:8:0 | When on, RLSD indicates that the carrier has successfully been received. RLSD will not respond to the $550,1800,2100$, or 2225 Hz tones. |
| RSD | Enable Receive Space Disconnect | 0:D:1 | When on, RSD causes the modem to go on-hook after receiving approximately 1.6 seconds of continuous spaces. |
| SPEED | Speed Indication | 0:9:(4,5) | $\begin{aligned} & 00=300 \mathrm{bps} \quad 10=1200 \mathrm{bps} \\ & 01=600 \mathrm{bps} \end{aligned}$ |
| SSD | Enable Send Space Disconnect | 1:D:0 | When on, SSD causes the modem to transmit approximately 4 seconds of spaces before disconnecting, when DTR is turned off. |
| ST | Self Test | (0,1):A:4 | When on, ST activates self test. ST must be turned off to end the test. (See Software Diagnostic Circuits). |
| 3DB | 3 dB Loss to Receive Signal | 1:B:2 | When on, 3DB attenuates the received signal 3dB. This is only used if the R1212M will see OdBm or greater line signal at the receiver input. Insertion of the 3dB loss will then prevent saturation. This bit is not needed with the R1212DC. |
| TONE | Tone Detect | 0:8:7 | TONE follows the energy detected in the 340 to 645 Hz frequency band. The user must determine which tone is present on the line by determining the duty cycle. TONE is active only when CRQ in Bank 0 is on. |
| TXCLK | Transmit Clock Select | 1:C:(5,6) | TXCLK allows the user to designate the origin of the transmitter data clock. (See Transmit Clock table). |

## SOFTWARE SUPERVISORY CIRCUITS

The operation of the R1212 is affected by a number of software control inputs. These inputs are written into registers within the modem via a microprocessor bus under external control. Modem operation is monitored by various software flags that are read from modem registers using the same microprocessor bus.

The transmit and receive registers contain many bits which perform identical functions and are located in the same memory location only in different banks. Care must be taken to set these bits according to the desired function.

## CONFIGURATION REGISTER

The host processor configures the R1212 by writing a control word into the configuration registers in its interface memory space as shown in the following tables:


## Character Length

| Configuration | Configuration Word |
| :---: | :---: |
| 8 bits | 0 |
| 9 bits | 0 |
| 10 bits | 1 |
| 11 bits | 1 |
| 0 |  |

## Transmit Clock

| Configuration | Configuration Word |
| :---: | :---: |
| Internal | 0 |
| Not Used | 0 |
| External | 1 |
| Slave | 1 |
| 1 |  |

Receiver Interface Memory Bank 0 (CSO)

| Bit Register | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 |  |  |  |  |  |  |  |  |
| 1 |  |  |  |  |  |  |  |  |
| 2 | Diagnostic Data Real Low |  |  |  |  |  |  |  |
| 3 | Diagnostic Data Real High |  |  |  |  |  |  |  |
| 4 | Diagnostic Data Imaginary Low |  |  |  |  |  |  |  |
| 5 | Diagnostic Data Imaginary High |  |  |  |  |  |  |  |
| 6 |  |  |  |  |  |  |  |  |
| 7 |  |  |  |  |  |  |  |  |
| 8 | TONE |  |  |  |  |  | RDLI | RLSD |
| 9 |  |  | Speed |  |  |  |  |  |
| A | ERDL | RDL | DL | ST | Mode |  |  |  |
| B |  |  |  |  |  |  |  | AL |
| C |  | CHAR |  |  |  |  |  |  |
| D | BUS | CRQ |  |  |  | LCD | RSD |  |
| E | IRQ | ENSI | NEWS |  | NEWC |  |  |  |
| F | Diagnostic Control Register |  |  |  |  |  |  |  |

Transmitter Interface Memory Bank 1 (CSI)


## AUTO DIAL SEQUENCE

The following flow chart defines the auto dial sequence via the microprocessor interface memory.


## Auto Dial Sequence Flow Diagram

Note: The modem timing for the auto dialer accounts for interdigit delay for pulses and tones.

## DIAGNOSTIC CAPABILITIES

The R1212 provides the user with access to much of the data stored in the modems memories. This data is a useful tool in performing certain diagnostic functions.

## RAM ACCESS CODES

The RAM access codes defined in the table below allow the host processor to read diagnostic data from the modem receiver. The access codes should be loaded into the diagnostic control register ( $0: F$ ). The appropriate diagnostic data will then be available in the diagnostic data registers ( $0:[2-5]$ ).

## RAM Access Codes Bank 0

| Function | Access | Data Type |
| :--- | :---: | :--- |
| Scrambled Data (Imag. Reg.) | 00 | Real |
| Self Test Error Counter (Real Reg.) | 00 | Real |
| Equalizer Tap Coefficients | $01-09$ | Complex |
| Phase Error (Real Reg.) | 0 C | Real |
| Rotated Equalizer Output | 0 D | Complex |
| (Received Point Eye Pattern) | 0 E |  |
| Rotated Angle (Imag. Reg.) | 40 | Real |
| Low Pass Fiter Output | $41-49$ | Complex |
| Input Signal to Equalizer Tap Coefficients | 4 D | Complex |
| Decision Points (Ideal) | 4 E | Complex |
| Rotated Error | 4 F | Complex |
| Equalizer Output | 52 | Complex |
| Demodulator Output |  |  |

## TEST

The specifications for R1212 tests are defined as follows:
Self tests can be initiated by setting bits ( $[0,1]: A: 4$ ) to a 1 . It is possible to perform the tests with or without the DTE connected to the modem. During any self test TXD and RTS are ignored. Note that self tests do not test asynchronous-tosynchronous converter circuits in either the transmitter or receiver.

Error detection is accomplished by monitoring a counter in the RAM. If the counter increments during the self test, an error was made. The counter contents are available in the diagnostic registers when the RAM access code 00 is loaded in the diagnostic control register (0:F).

Self test end-to-end-Upon activation of self-test an internally generated data pattern of alternate binary ones and zeros (reversals) at the selected bit rate are applied to the scrambler. An error detector, capable of identifying errors in a stream of reversals are connected to the output of the descrambler.

Self test with loop 3-Loop 3 is applied to the modem as defined in recommendation V.54. Self-test is activated and DCE operation is as in the end-to-end test. In this test DTR is ignored.

Self test with loop 2-The modem is conditioned to instigate a loop 2 at the remote modem as specified in recommendation V.54. Self-test is activated and DCE operation is as in the end-to-end test.

Loopbacks-Remote digital loopback, digital loopback, and local analog loopback can be initiated via the interface memory, as follows:

1. Digital Loopback. The R1212 can be manually conditioned to loop the received data back to the transmitter by setting
the DL bits $([0,1]: A: 5)$. DL should be set during the data mode. DSR and CTS will be off. The local modem can then be tested from the far-end by using the terminal equipment at the far-end to transmit a test pattern and examine the looped data. At the far-end modem, all interface circuits behave normally as in the data mode. At the conclusion of the test, DL must be turned off. The local modem will then return to the normal data mode with control reverting the DTE's DTR.
2. Local Analog Loopback (V. 54 Loop 3). The R1212 is capable of entering into a local analog loopback (V. 54 Loop 3). In this loop, the transmitter's analog output is coupled to the receiver's analog input at a point near the modem's telephone line interface. An attenuator is introduced into the loop such that the signal level coupled into the receive path is approximately - 16 dBm attenuation.
3. Remote Digital Loopback (V. 54 Loop 2) (Bell 212A and CCITT V. 22 bis and V.22). The R1212 is capable of entering into a remote digital loopback. Remote digital loopback may be locally entered by the interface memory. Remote digital loopback cannot be performed simultaneously with local analog loopback.

## POWER-ON INITIALIZATION

When power is applied to the R1212, a period of 100 to 300 ms is required for initialization. The power-on-reset (POR) signal remains low during the initialization period. After the low to high transition of POR, the modem is ready to be configured.

The modem automatically defaults to Bell 212A 1200 bps, answer state using serial start-stop data, 10 bits per character.

POR can also be used to initialize the user's host processor. It may be connected to a user supplied power-on-reset signal in a wire-or configuration.


BER Performance Test Set-up

## PERFORMANCE

Whether functioning as a V.22, or Bell 212A type modem, and regardless of simulated line condition or introduced line impairment, the R1212 provides unexcelled high performance to the user.

## BIT ERROR RATES

The Bit Error Rate (BER) performance of the R1212 is specified for a test configuration conforming to that specified in CCITT Recommendation V.56, except with regard to the placement of the filter used to bandlimit the white noise source. Bit error rates are measured at a received line signal level of -43 dBm .

## INTERFACE CIRCUIT CHARACTERISTICS DIGITAL INTERFACE CIRCUITS

## Digital Input Characteristics

| Input Logic State | Allowed Input Voltage Levels |
| :---: | :---: |
| Low | 0.0 V to +0.8 V at $-2.5 \mu \mathrm{~A}$ |
| High | +2.0 V to +5.0 V at $+2.5 \mu \mathrm{~A}$ |

Notes:

1. The digital inputs are directly TTL/CMOS compatible. The capactive loading on each input is 25 pF (maximum).
2. Positive current is defined as current into the node.

| Digital Output Characteristics |
| :--- |
| Output Logic State Allowed Output Voltage Levels <br> Low  <br> High +0.4 V at +1.6 mA <br> +2.4 V at $-100 \mu \mathrm{~A}$  |
| Notes: |
| 1. The digital outputs are directly TTL/CMOS compatible. |
| The capactive loading on each output is 50 pF (maximum). |
| 2. Positive current is defined as current into the node. |

## ANALOG INTERFACE CIRCUITS TRANSMISSION LINE INTERFACE

The R1212DC interface to the telephone line is the Tip and Ring leads. Lightning induced surge voltages and other hazardous voltages which may appear on the telephone line are limited to approximately 7 V peak between the secondary leads of the line coupling transformer.

The DAA (R1212DC only) is bi-directional as required by 2-wire full-duplex circuits.

Connection to the telephone line interface pins of the R1212DC to the network are made via the RJ11, as shown in the table below:

R1212DC Network Interface

| Connection Type | Telco | Mnemonic | Function |
| :---: | :---: | :---: | :--- |
| VSOC | 1 |  |  |
| RJ11 | 2 |  |  |
| Jack | 3 | R | Ring-one side of <br> telephone line |
|  | 4 | T | Tip-one side of <br> telephone line |
|  | 5 |  |  |

## RING INDICATOR

The R1212 provides a ring indicator ( $\overline{\mathrm{RI})}$ output; its low state indicates the presence of a ring signal on the line. The low condition appears approximately coincident with the on segment of the ring cycle (during rings) on the communication channel. (The ring signal cycle is typically two seconds on, four seconds off.) The high condition of the indicator output is maintained during the off segment of the ring cycle (between rings) and at all other times when ringing is being received. The operation of $\overline{\mathrm{Rl}}$ is not disabled by an off condition on Data Terminal Ready.
$\overline{\text { RI }}$ will respond to ring signals in the frequency range of 15.3 Hz to 68 Hz with voltage amplitude levels of 40 to 150 Vrms (applied across Tip and Ring), with the response times given in the following table:

| RI Response Time |
| :--- |
| RI Transition Response Time <br> Off-to-On 125 ms to 400 ms <br> On-to-Off 75 ms to 250 ms |

This off-to-on (on-to-off) response time is defined as the time interval between the sudden connection (removal) of the ring signal across Tip and Ring and the subsequent on (off) transition $\overline{\mathrm{RI}}$.

## OH (OFF-HOOK)

The R1212M provides an output OH (Off-Hook) which indicates the state of the OH relay. A low condition on OH implies the OH relay is closed and the modem is connected to the telephone line. A high condition on OH implies the OH relay is open (i.e., the modem is on-hook). The delay between the low-to-high or high-to-low transition of OH and the subsequent close-to-open or open-to-close transition of the OH relay is 8 ms maximum.

## $\overline{\mathbf{R D}}$

$\overline{\mathrm{RD}}$ indicates to the R1212M by an on (low) condition that a ringing signal is present. The $\overline{\mathrm{RD}}$ signal should not respond to momentary bursts of ringing less than 125 ms in duration, or to less than 40 V rms, 15 to 68 Hz appearing across Tip and Ring with respect to ground.

## RCCT

RCCT is used to request that a data transmission path through the DAA be connected to the telephone line. When RCCT goes off (low), the cut-through buffers are disabled and CCT should go off (high) within 1 msec . RCCT should be off during dialing but on for tone address signaling.

## $\overline{C C T}$

An on (low) signal to the CCT lead indicates to the R1212M that the data transmission path through the DAA is connected.

## AUDIO INTERFACE INPUT IMPEDANCE

The specifications for the audio interface input impedance are given in the following table:

Audio Interface Input Impedance

| On/Off Hook | Measurement |
| :---: | :--- |
| On-Hook (DC) | The DC resistance between Tip and <br> Ring, and between either Tip or Ring <br> and signal ground is greater than <br> 10 megohms for DC voltages up to <br> 100 volts. |
| On-Hook (AC) | The on-hook AC impedance measured <br> between Tip and Ring is less than <br> 40K ohms (15.3 Hz minimum). |
| Off-Hook (DC) | Less than 200 ohms. |
| Off-Hook (AC) | 600 ohms nominal when measured <br> between Tip and Ring. |

## TRANSMITTER OUTPUT

Basic telephone company requirement is that the signal level received at the relevant local central office not exceed -12 dBm . Several different "connection arrangements" have been established (as documented in Part 68) to accomplish this goal.

When the permissive connection arrangement is used, the transmit output signal level appearing across Tip and Ring (with a 600 ohm resistive load across Tip and Ring) will not exceed -9 dBm . The output level is set at a fixed -10 dBm (nominal). The permissive wall jacks used for data connections are the same jacks used for standard voice installations. The permissive connection arrangement allows greater mobility for user equipment.

When the programmable connection arrangement is used, the maximum output transmit signal level allowed to appear across the Tip and Ring (again, terminated with 600 ohms) is set by a resistor installed by the telephone company in their wall jack at the customer location. The resistor (which is one of thirteen possible values) interacts with the modem through modem leads PR and PC to program the maximum output level, in one dB steps between -12 dBm and 0 dBm . (The resistor is selected by the telephone company jack installer after he has measured the line loss from the customer location to the local telephone company central office).

## INSTALLATION

## IMPORTANT NOTICE TO USER

The modem contains protective circuitry registered with the Federal Communications Commission (FCC) Part 68 to allow direct connection to the switched telephone network. To comply with the FCC is required:

1. All direct connections to the telephone lines shall be made through standard plugs and telephone company provided jacks.
2. It is prohibited to connect the modem to pay telephones or party lines.
3. You are required to notify the local telephone company prior to the connection and upon final disconnection of the modem. You must supply to the telephone company the make, model number, FCC registration number, ringer equivalence and particular line to which the connection is to be made. If the proper jacks are not available, you must order the type of jacks to be used from the telephone company.
4. You should disconnect the modem from the telephone line if it appears to be malfunctioning. Reconnect it only when it can be determined that the telephone line is the source of trouble. If the modem needs repair, return it to Rockwell International. This applies to equipment both in and out of warranty. Do not attempt to repair the unit as this will violate FCC rules.
5. The modem contains protective circuitry to prevent harmful voltages from being transmitted to the telephone network. If however such harmful voltages do occur, then the telephone company shall:

- Promptly notify you of the discontinuance.
- Afford you the opportunity to correct the situation which caused the discontinuance.
The FCC requires that the following label be prominently displayed on an outside surface of the OEM's end product.
- Unit contains Registered Protective Circuitry which complies with Part 68 of FCC Rules.
- FCC Registration Number: Applied For
- Ringer Equivalence: 0.5

Size of the label should be such that all the required information is legible without magnification.

## GENERAL SPECIFICATIONS

The general specifications for the R1212 are given in the following tables:

## Power Requirements

| Voltage* | Tolerance | Current (Max) |
| :---: | :---: | :---: |
| +5 Vdc | $\pm 5 \%$ | $<500 \mathrm{ma}$ |
| +12 Vdc | $\pm 5 \%$ | $<10 \mathrm{ma}$ |
| -12 Vdc | $\pm 5 \%$ | $<50 \mathrm{ma}$ |

*All voltages must have ripple $\leq 0.1$ volts peak-to-peak.
Environmental

| Parameter | Specification |
| :---: | :--- |
| Temperature: | $0^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}\left(32\right.$ to $\left.140^{\circ} \mathrm{F}\right)$ |
| Operating | $-40^{\circ} \mathrm{C}$ to $+80^{\circ} \mathrm{C}\left(-40\right.$ to $\left.176{ }^{\circ} \mathrm{F}\right)$ |
| Storage |  |
| Relative Humidity: | Up to $90 \%$ noncondensing, or a wet <br> bulb temperature up to $35^{\circ} \mathrm{C}$, <br> whichever is less. <br>  <br> Altitude: |

*PCB's are stored in heat sealed antistatic bags and shipping containers.

## Mechanical

| Board Structure: Mating Connector: | Single PC board with right angle male DIN connector. <br> Female 3 row 64 pin Euroconnector (DIN) with rows A and C populated: Recommended mating connector: Winchester 96S-6043-0531-1 or equivalent. |
| :---: | :---: |
| PCB Dimensions: DC Version | Width $3.94 \mathrm{in} .(100 \mathrm{~mm}) \times$ Length $4.725 \mathrm{in} .(120 \mathrm{~mm}) \times$ Height 0.75 in. ( 19 mm ) |
| M Version | Width 3.94 in . $(100 \mathrm{~mm}) \times$ Length $3.35 \mathrm{in} .(85 \mathrm{~mm}) \times$ Height 0.40 in . ( 10 mm ) |
| Weight: | Less than $0.45 \mathrm{lbs} .(0.20 \mathrm{~kg}$.) |



Printed Circuit Board Dimensions

## R2424 <br> 2400 BPS FULL-DUPLEX MODEM

## PRELIMINARY

## INTRODUCTION

The Rockwell R2424 is a high performance full-duplex 2400 bps modem. Using state-of-the-art VLSI and signal processing technology, the R2424 provides the user with enhanced performance and reliability on a single printed circuit board of less than 22 square-inches-overall size.

The R2424 modem is ideal for data transmission over the 2-wire dial-up telephone network. The direct-connect, auto dial/answer features are specifically designed for remote and central site computer applications. The bus interface allows easy integration into a personal computer, box modem, microcomputer, terminal or any other communications product that demands the utmost in reliability and performance.

The added test features, such as local analog loopback, remote digital loopback, and a self-test function, offer the user flexibility in creating a 2400 bps modem design customized for specific packaging and functional requirements.

Being CCITT V. 22 bis, V. 22 A, B compatible, as well as Bell 212A and 103 compatible, this modem fits most applications for fullduplex 2400 and 1200 bps fallback (synchronous and asynchronous) and 0 to 300 bps asynchronous data transmission over the general switched telephone network.

## FEATURES

- CCITT V. 22 bis, V. 22 A, B Compatible
- Bell 212A and 103 Compatible
- Synchronous: 2400 bps, 1200 bps, 600 bps $\pm 0.01 \%$
- Asynchronous: 2400 bps, 1200 bps, 600 bps $+1 \%,-2.5 \%$, $0-300 \mathrm{bps}$
-Character length 8, 9, 10, or 11 bits
- DTE Interface
-Functionally: Microprocessor Bus (Control) and RS-232-C Interface (Data/Control)
-Electrically: TTL Compatible
- Operation: 2-wire full-duplex
- Adaptive and Fixed Compromize Equalization
- Test Configurations:
-Local Analog Loopback
-Remote Digital Loopback
-Self Test
- Auto/Manual Answer
- Auto/Manual Dial:
-Tone or Pulse Dial
- Power Consumption: 3 Watts Typical
- Power Requirements: $+5 \mathrm{Vdc}, \pm 12 \mathrm{Vdc}$
- Plug-compatible member of new Rockwell modem line
- Two Versions: R2424DC (Direct Connect) with FCC approved DAA Part 68 Interface and R2424M (Module) without DAA


R2424 Full-Duplex Modem

## TECHNICAL SPECIFICATIONS

The following are the technical specifications for the R2424 modem.

## TRANSMITTER CARRIER AND SIGNALING FREQUENCIES

The transmitter carrier and signaling frequencies are given in the following table:

Transmitter Carrier and Signaling
Frequencies Specifications

| Frequency | Specification <br> $\mathbf{( H z} \pm \mathbf{0 . 0 1 \% )}$ |
| :--- | :---: |
| V.22 bis low channel, Originate Mode | 1200 |
| V.22 low channel, Originate Mode | 1200 |
| V.22 bis high channel, Answer Mode | 2400 |
| V.22 high channel, Answer Mode | 2400 |
| Bell 212A high channel Answer Mode | 2400 |
| Bell 212A low channel Originate Mode | 1200 |
| Bell 103/113 Originating Mark | 1270 |
| Bell 103/113 Originating Space | 1070 |
| Bell 103/113 Answer Mark | 2225 |
| Bell 103/113 Answer Space | 2025 |

## TONE GENERATION

The specifications for tone generation are as follows:

1. Answer Backtones: The R2424 is capable of generating echo disabling tones both of the CCITT and Bell versions, as follows:
a. CCITT: $2100 \mathrm{~Hz} \pm 15 \mathrm{~Hz}$.
b. Bell: $2225 \mathrm{~Hz} \pm 10 \mathrm{~Hz}$.
2. Guard Tones: If GTS is low, an 1800 Hz guard tone frequency is selected; if GTS if high, a 553.846 Hz tone is employed. In accordance with the CCITT V. 22 Recommen-
dation, the level of transmitted power for the 1800 Hz guard tone should be $6 \pm 1 \mathrm{~dB}$ below the level of the data power in the main channel. The total power transmitted to the line should be the same whether or not a guard tone is enabled. If a 553.846 Hz guard tone is used, its transmitted power should be $3 \pm 1 \mathrm{~dB}$ below the level of the main channel power, and again the overall power transmitted to the line should remain constant whether or not a guard tone is enabled. The device accomplishes this by reducing the main channel transmit path gain by .97 dB and 1.76 dB for the cases of the 1800 Hz and 553.846 Hz guard tones respectively.
3. DTMF Tones: The R2424 is capable of generating dual tone multi-frequency tones. When the transmission of DTMF tones are required, the CRQ and DTMF bits must be set to a 1 (see Interface Memory). When in this mode, the specific DTMF tones generated are decided by loading transmit register with the appropriate digit as shown in the following table:

Interface Memory Signals

| BCD |  |  |  | Dial <br> Digits |  | Tone Pairs |  |
| :--- | :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | 0 | 941 | 1336 |  |
| 0 | 0 | 0 | 1 | 1 | 697 | 1209 |  |
| 0 | 0 | 1 | 0 | 2 | 697 | 1336 |  |
| 0 | 0 | 1 | 1 | 3 | 697 | 1477 |  |
| 0 | 1 | 0 | 0 | 4 | 770 | 1209 |  |
| 0 | 1 | 0 | 1 | 5 | 770 | 1336 |  |
| 0 | 1 | 1 | 0 | 6 | 770 | 1477 |  |
| 0 | 1 | 1 | 1 | 7 | 852 | 1209 |  |
| 1 | 0 | 0 | 0 | 8 | 852 | 1336 |  |
| 1 | 0 | 0 | 1 | 9 | 852 | 1477 |  |
| 1 | 0 | 1 | 0 | $\star$ | 941 | 1209 |  |
| 1 | 0 | 1 | 1 | Spare (B) | 697 | 1633 |  |
| 1 | 1 | 0 | 0 | Spare (C) | 770 | 1633 |  |
| 1 | 1 | 0 | 1 | Spare (D) | 852 | 1633 |  |
| 1 | 1 | 1 | 0 | $\#$ | 941 | 1477 |  |
| 1 | 1 | 1 | 1 | Spare (F) | 941 | 1633 |  |

Signaling and Data Rates

| Operating Mode | Signaling Rate (Baud) | Data Rate |
| :---: | :---: | :---: |
| V. 22 bis: <br> V. 22 bis: | $600$ <br> 600 | Synchronous/Asynchronous $2400 \mathrm{bps} \pm 0.01 \%$ <br> Synchronous/Asynchronous $1200 \mathrm{bps} \pm 0.01 \%$ |
| V.22: <br> (Alternative A) <br> Mode i <br> Mode iii <br> (Alternative B) <br> Mode i <br> Mode iii <br> Mode ii <br> Mode iv | $\begin{aligned} & 600 \\ & 600 \end{aligned}$ | 1200 bps $\pm 0.01 \%$ Synchronous <br> 600 bps $\pm 0.01 \%$ Synchronous <br> 1200 bps $\pm 0.01 \%$ Synchronous <br> 600 bps $\pm 0.01 \%$ Synchronous <br> 1200 bps Asynchronous <br> 8, 9, 10, or 11 Bits Per Character <br> 600 bps Asynchronous <br> 8, 9, 10, or 11 Bits Per Character |
| Bell 212A: |  | $1200 \mathrm{bps} \pm 0.01 \%$ <br> Synchronous/Asynchronous 0 to 300 bps Asynchronous |

## TONE DETECTION

The R2424 can detect tones in the 340 to 645 Hz band.

## SIGNALING AND DATA RATES

The signaling and data rates for the R2424 are defined in the table below:

## DATA ENCODING

The specifications for data encoding are as follows:

1. 2400 bps ( V .22 bis ). The transmitted data is divided into groups of four consecutive bits (quad bits) forming a 16 -point signal structure.
2. 1200 bps (V. 22 and Bell 212A). The transmitted data is divided into groups of two consecutive bits (dibits) forming a four-point signal structure.
3. 600 bps (V.22). Each bit is encoded as a phase change relative to the phase preceding signal elements.

## EQUALIZERS

The R2424 provides equalization functions which can be used to improve performance when operating over poor lines.

Automatic Adaptive Equalizer-An automatic adaptive equalizer is provided in the receiver circuit for V. 22 bis, V. 22 and Bell 212A configurations.

Fixed Compromise Equalizer-Compromise equalizers are provided in the transmitter and receiver.

## TRANSMITTED DATA SPECTRUM

1. V. 22 bis. The transmitted line signals (excluding the characteristics of the fixed comromise equalizer) have a frequency amplitude spectrum shaped by the square root of 75 percent raised cosine filter. The group delay of the transmitter output is within $\pm 100$ microseconds over the frequency ranges 900 to 1500 Hz (low channel) and 2100 to 2700 Hz (hgh channel).
2. V.22. After making allowance for the nominal specified compromise equalizer characteristic, the transmitted line signal has a frequency spectrum shaped by the square root of a 75 percent raised cosine filter. Similarly, the group delay of the transmitter output is within $\pm 100$ microseconds over the frequency range 800 to 1600 Hz (low channel) and 2000 to 2800 Hz (high channel).

## SCRAMBLER/DESCRAMBLER

The R2424 incorporates a self-synchronizing scrambler/ descrambler. In accordance with the CCITT V. 22 bis, V. 22 and the Bell 212 A recommendations.

## RECEIVED SIGNAL FREQUENCY TOLERANCE

The receiver circuit of the R2424 can adapt to received frequency errors of up to $\pm 7 \mathrm{~Hz}$ with less than a 0.2 dBm degradation in BER performance.

## RECEIVE LEVEL

The receiver circuit of the R2424 satisfies all specified performance requirements for the received line signals from -12 dBm to -45 dBm . The received line signal is measured at the receiver analog input RXA.

## RECEIVE TIMING

The R2424 provides a Receive Data Clock (RDCLK) output in the form of a ( $50 \pm 1 \%$ duty cycle) squarewave. The low to high transitions of this output coincide with the center of received data bits. The timing recovery circuit is capable of tracking a $\pm 0.01 \%$ frequency error in the associated transmit timing source.

## TRANSMIT LEVEL

The R2424M output control circuitry contains a variable gain buffer which reduces the modem output level. The R2424M can be strapped via the host interface memory to accomplish this.

Transmit Level

| Configuration Word | Transmit Level |
| :---: | :---: |
| 000 | 0 dbm |
| 001 | -2 dbm |
| 010 | -4 dbm |
| 011 | -6 dbm |
| 100 | -8 dbm |
| 101 | $-10 \mathrm{dbm}$ |
| 110 | $-12 \mathrm{dbm}$ |
| 111 | -14 dbm |

## PERMISSIVE/PROGRAMMABLE CONFIGURATIONS

The R2424M transmit level is set to 0 dBm to allow a DAA to be used. The DAA would then determine the permissive or programmable configuration.

The R2424DC transmit level is strapped in the permissive mode so that the maximum output level is $-9.5 \mathrm{dBm} \pm 0.5 \mathrm{dBm}$.

## TRANSMIT TIMING

The R2424 provides a Transmit Data Clock (TDCLK) output with the following characteristics:

1. Frequency. Selected data rate of 2400,1200 or 600 Hz ( $\pm 0.01 \%$ ).
2. Duty Cycle. $50 \pm 1 \%$.

Transmit Data (TXD) must be stable during the one microsecond periods immediately preceding and following the rising edge of TDCLK.

## CLAMPING

The following clamp is provided with the R2424:

1. Receive Data (RXD). RXD is clamped to a constant mark (1) whenever RLSD is off.


R2424 Functional Interconnect Diagram

## RECEIVED LINE SIGNAL DETECTOR

The high and low channel thresholds are greater than -45 dBm (RLSD on) and less than -48 dBm (RLSD off) for V. 22 bis, V. 22 and Bell 212A configurations.

## DATA SET READY

The on condition of the R2424 output Data Set Ready (DSR) indicates that the modem is in the data transfer state. The off condition of DSR is an indication that the DTE is to disregard all signals appearing on the interchange circuits-except the calling indicator and the test signal. DSR will switch to the off state when in test state. The on condition of DSR indicates the following:

1. The modem is not in the talk state, i.e., an associated telephone handset is not in control of the line.
2. The modem is not in the process of automatically establishing a call via pulse or DTMF dialing.
3. The modem is generating an answer tone or detecting answer tone.
4. After ring indicate goes on, DSR waits at least two seconds before turning on to allow the bell equipment to be engaged.

DSR will go off 50 msec after DTR goes off or 50 msec plus a maximum of 4 sec when SSD is enabled.

## DATA TERMINAL READY

An on condition of DTR prepares the modem to be connected to the communications channel, and maintains the connection
established by the DTE (manual answering) or internal (automatic answering) means. The off condition places the modem in the disconnect state.

## MODES OF OPERATION

The R2424 is capable of being operated in either a serial or a parallel mode of operation.

## SERIAL MODE

The serial mode uses standard V. 24 (RS-232-C compatible) signals to transfer channel data. An optional USART device (shown in the diagram above) illustrates this capability.

## CONTROL SELECTION

Selection of either the serial or parallel control is by means of bits ( $[0,1]: \mathrm{D}: 7$ ). To enable the parallel control, the bits must be set to a one. In either mode, the R2424 is configured by the host processor via the microprocessor bus.

## INTERFACE CRITERIA

The modem interface comprises both hardware and software circuits. Hardware circuits are assigned to specific pins in a 64 -pin DIN connector. Software circuits are assigned to specific bits in a 32-byte interface memory.

R2424 Hardware Supervisory Circuits

| Name | Type | Pin No. | Description |
| :---: | :---: | :---: | :---: |
| A. OVERHEAD |  |  |  |
| DGND | G | 5A, 10A, 3C, 8C | Digital Ground |
| AGND | G | 31C, 32C | Analog Ground |
| + 5 VDC | P | 19C, 23C, | +5 Volt Supply |
|  |  | 26C, 30C |  |
| + 12 VDC | P | 15A | + 12 Volt Supply |
| $\frac{-12}{P O R} \mathrm{VDC}$ | P | 12A | -12 Volt Supply |
|  | OC | 13C | Power-On-Reset |
| B. MICROPROCESSOR INTERFACE |  |  |  |
| D7 | B | 1 C |  |
| D6 | B | 1 A |  |
| D5 | B | 2 C |  |
| D4 | B | 2 A | Data Bus (8-Bits) |
| D3 | B |  |  |
| D2 | B | 4 C |  |
| D1 | B | 4A |  |
| D0 | B | 5C |  |
| RS3 | 1 | 6 C |  |
| RS2 | I | 6 A | Register Select (4-Bits) |
| RS1 | 1 | 7 C |  |
| RS0 | 1 | 7A |  |
| CSO | 1 | 10 C | Chip Select for Bank 0 |
| CS1 | 1 | 9 C | Chip Select for Bank 1 |
| READ | 1 | 12 C | Read Enable |
| WRITE | 1 | 11A | Write Enable |
|  | OC | 11C | Interrupt Request |
| C. V. 24 INTERFACE |  |  |  |
| XTCLK | 1 | 22A | External Transmit Clock |
| TDCLK | 0 | 23A | Transmit Data Clock |
| $\frac{\text { RDCLK }}{\text { CTS }}$ | 0 | 21A | Receive Data Clock |
|  | 0 | 25 C | Clear-to-Send |
| TXD | 1 | 24C | Transmit Data |
| RXD | 0 | 22 C | Receive Data |
| RLSD | 0 | 24A | Received Line Signal Detector |
| $\overline{\text { DTR }}$ | 1 | 21 C | Data Terminal Ready |
| $\overline{\text { DSR }}$ | 0 | 20A | Data Set Ready |
|  | 0 | 18A | Ring Indicator In |
| D. ANALOG SIGNALS (R2424M ONLY) |  |  |  |
| $\begin{aligned} & \hline \text { RXA } \\ & \text { TXA } \end{aligned}$ | 1 | 32A | Receive Analog |
|  | 0 | 31A | Transmit Analog |
| E. SIGNALS TO DAA (R2424M ONLY) |  |  |  |
| $\overline{\text { RD }}$ <br> RCCT <br> $\overline{\text { CCT }}$ <br> OH | 1 | 27A | Ring Detect |
|  | 0 | 28A | Request Coupler Cut Through |
|  | 1 | 29C | Coupler Cut Through |
|  | 0 | 29A | Off-Hook Relay Control |
| F. ANCILLARY FUNCTIONS |  |  |  |
| $\overline{\text { TBCLK }}$ <br> RBCLK <br> TLK <br> ORG | 0 | 27 C | Transmit Baud Clock |
|  | 0 | 26A | Receive Baud Clock |
|  | I | 28 C | Talk TLK = Data |
|  | 1 | 16 C | Originate ORG $=$ Answer |
| B Bidirectional |  |  |  |
| 1 Input |  |  |  |
| O Output |  |  |  |
| OC Open Collector |  |  |  |
| P Power |  |  |  |
| G G |  |  |  |

## HARDWARE SUPERVISORY CIRCUITS

Signal names and descriptions of the hardware supervisory circuits, including the microprocessor interface, are given in the following table. The microprocessor interface was designed to be compatible with an $8080,6500,6800$, and 68000 microprocessor.


Microprocessor Interface Timing Diagram

Critical Timing Requirements

| Characteristic | Symbol | Min | Max | Units |
| :--- | :---: | :---: | :---: | :---: |
| $\overline{\text { CSi, RSi setup time prior }}$ |  |  |  |  |
| to Read or Write | TCS | 30 | - | NS |
| Data Access time after Read | TDA | - | 140 | NS |
| Data hold time after Read | TDH | 10 | 50 | NS |
| $\overline{\text { CSi, RSi hold time after }}$ |  |  |  |  |
| Read or Write | TCH | 10 | - | NS |
| Write data setup time | TWDS | 75 | - | NS |
| Write data hold time | TWDH | 10 | - | NS |
| Write strobe pulse width | TWR | 75 | - | NS |

## INTERFACE MEMORY

The R2424 has two banks of 16 registers to which an external (host) microprocessor has access. Although these registers are within the modem, they may be addressed as part of the host processor's memory space. The host may read data out of or write data into these registers. These registers, as shown in the following table, are refered to as interface memory.

When information in these registers is being discussed, the format $\mathrm{Y}: \mathrm{Z}: \mathrm{Q}$ is used. The bank is specified by $\mathrm{Y}(0$ or 1$)$, the register by $Z(0-F)$, and the bit by $Q(0-7,0=L S B)$. $A$ bit is considered to be 'on' when set to a one.

| Bank | Reg No. (HEX) | Description | Bank | Reg No. (HEX) | Description |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | Do Not Use | 1 | 0 | Dial Digit Register |
| 0 | 1 | Do Not Use | 1 | 1 | Do Not Use |
| 0 | 2 | Diagnostic Data Real LSB's | 1 | 2 | Diagnostic Data Real LSB's |
| 0 | 3 | Diagnostic Data Real MSB's | 1 | 3 | Diagnostic Data Real MSB's |
| 0 | 4 | Diagnostic Data Imaginary LSB's | 1 | 4 | Diagnostic Data Imaginary LSB's |
| 0 | 5 | Diagnostic Data Imaginary MSB's | 1 | 5 | Diagnostic Data Imaginary MSB's |
| 0 | 6 | Do Not Use | 1 | 6 | Do Not Use |
| 0 | 7 | Do Not Use | 1 | 7 | Do Not Use |
| 0 | 8 | Receiver Status | 1 | 8 | Transmitter Status |
| 0 | 9 | Receiver Status | 1 | 9 | Configuration |
| 0 | A | Configuration | 1 | A | Configuration |
| 0 | B | Configuration | 1 | B | Configuration |
| 0 | C | Configuration | 1 | C | Configuration |
| 0 | D | Configuration | 1 | D | Configuration |
| 0 | E | Handshake Status | 1 | E | Handshake Status |
| 0 | F | Diagnostic Control Register | 1 | F | Diagnostic Control Register |

The interface memory bits are defined in the following table:

| Interface Memory Definitions |  |  |  |
| :---: | :---: | :---: | :---: |
| Name | Definition | Memory Location | Description |
| AAE | Auto Answer Enable | 1:D:4 | When on, AAE causes the modem to automatically answer when a ringing signal is present on the line. |
| AL | Analog Loopback | $(0,1): B: 0$ | When on, AL places the modem in analog loopback. (See Software Diagnostic Circuits.) |
| BUS | Bus Select | $(0,1):$ D:7 | When on, BUS places the modem in the parallel control mode. When off, the modem is configured for the serial control mode. BUS can be in either state to configure the modem. |
| CHAR | Character Length Select | $(0,1): C:(3,4)$ | These bits select either 8, 9, 10, or 11 bit characters. (See Character Length table.) |
| CRQ | Call Request | $(0,1): \mathrm{D}: 6$ | When on, CRQ places the transmitter in auto dial and the receiver in tone detect mode. The data placed in the dial digit buffer is then treated as digits to be dialed. After the last digit has been dialed, FF (Hex) should be loaded into the buffer to tell the modem to go to the data state. CRQ in the transmitter (Bank 1) when turned off causes the modem to go on-hook. Therefore, it should be on for the duration of the call and not turned off until it is desired to go onhook. CRQ in the receiver (Bank 0) must be turned off immediately after ringback is detected to put the modem in the data mode, otherwise no answerback tone will be detected. |
| CTS | Clear-to-Send | 1:8:6 | When on, CTS indicates to the terminal equipment that the modem will transmit any data which are present at TXD. |
| DATA | Talk/Data | 1:D:5 | When on, DATA places the modem in data state and when off in the talk state. |
| DDEI | Dial Digit Empty Interrupt | 1:E:2 | When on, DDEI causes an interrupt to occur when the dial digit register ( $1: 0$ ) is empty (DDRE $=1$ ). |
| DDRE | Dial Digit Register Empty | 1:E:0 | When on, DDRE indicates that the dial digit register is empty and can be loaded with new digits to be dialed. After the register is loaded, DDRE goes off. |

Interface Memory Definitions (Continued)

| Name | Definition | Memory Location | Description |
| :---: | :---: | :---: | :---: |
| DL | Digital Loopback (Manual) | $(0,1): A: 5$ | When on, DL manually places the modem in digital loopback. (See Software Diagnostic Circuits.) |
| DLO | Data Line Occupied | 1:8:7 | When on, DLO indicates that the modem is in auto dial, i.e., CRQ is on and the modem is off-hook ready to dial. |
| DSR | Data Set Ready | 1:8:5 | When on, DSR indicates that the modem hanshake has begun and that the data state will follow. DSR alone should not be used to indicate that the communication channel has been completely established. DSR in conjunction with CTS and RLSD will determine this. DSR will be off in all test states (except optionally for analog loopback) and when the channel is being used for voice communication (talk). |
| DSRA | Data Set Ready In Analog Loopback | $1: C: 7$ | When on, DSRA causes DSR to be on during analog loopback. |
| DTMF | Touch Tones/ Pulse Dialing | 1:B:1 | When on, DTMF tells the modem to auto dial using tones. When off the modem should dial using pulses. |
| DTR | Data Terminal Ready | 1:D:3 | DTR must be on before the modem will enter the data state, either manually or automatically. DTR must also be on in order for the modem to automatically answer an incoming call. |
| ENSI | Enable New Status Interrupt | $(0,1): E: 6$ | When on, ENSI causes an interrupt to occur when the status bits in registers ( $0:[8,9]$ ) and (1:8) are updated. (NEWS = 1 ) |
| ERDL | Enable Response to Remote Digital Loopback | $(0,1): A: 7$ | When on, ERDL enables the modem to respond to another modem's remote digital loopback request, thus going into loopback. |
| GTE | Guard Tone Enable | 1:B:4 | When on, GTE causes the specified guard tone to be transmitted (CCITT Configurations only). |
| GTS | Guard Tone Select | 1:B:3 | When off, GTS selects the 1800 Hz tone and when on the 550 Hz tone. |
| IRQ | Interrupt Request | $(0,1): E: 7$ | When on, IRQ indicates that an interrupt has been generated. |
| LCD | Enable Loss of Carrier Disconnect | 0:D:2 | When on, LCD causes the modem to terminate a call when a loss of received carrier energy is detected after approximately 350 msec . |
| MODE | Mode Select | $(0,1): A:(0-3)$ | These bits select the compatibility at which the modem is to operate. (See Mode Select table). |
| NEWC | New Configuration | $(0,1): E: 3$ | When on, NEWC tells the modem that a new configuration has been written into the configuration registers. The modem will then read the configuration registers and then reset NEWC. NEWC must be set after a new configuration has been written into the following registers: ( $0:[A-D]$ ) and ( $1:[9-D]$ ). The remaining registers do not require the use of NEWC to tell the modem that new data was written into them. |
| NEWS | New Status | $(0,1)$ :E:5 | When on, NEWS tells the user that there has been a change of status in the status registers. |
| ORG | Originate/Answer | 1:9:5 | When on, ORG tells the modem that it is originating a call and when low answering a call. This is only valid in manual originate/answer and analog loopback. |
| RDL | Initiate Remote Digital Loopback | $(0,1):: A: 6$ | When on, RDL causes the modem to initiate a request for the remote modem to go into digital loopback. |

Interface Memory Definitions (Continued)

| Name | Definition | Memory Location | Description |
| :---: | :---: | :---: | :---: |
| RDLI | Remote Digital Loopback Indicator | 0:8:1 | When on, RDLI indicates that the modem has received an RDL request and is in remote digital loopback. |
| RI | Ring Indicator | 1:8:4 | When on, RI indicates that a ringing signal is being detected. |
| RLSD | Received Line Signal Detector | 0:8:0 | When on, RLSD indicates that the carrier has successfully been received. RLSD will not respond to the $550,1800,2100$, or 2225 Hz tones. |
| RSD | Enable Receive Space Disconnect | 0:D:1 | When on, RSD causes the modem to go on-hook after receiving approximately 1.6 seconds of continuous spaces. |
| SPEED | Speed Indication | 0:9:(4,5) | $\begin{aligned} & 00=300 \mathrm{bps} \quad 10=1200 \mathrm{bps} \\ & 01=600 \mathrm{bps} \quad 11=2400 \mathrm{bps} \end{aligned}$ |
| SSD | Enable Send Space Disconnect | 1:D:0 | When on, SSD causes the modem to transmit approximately 4 seconds of spaces before disconnecting, when DTR is turned off. |
| ST | Self Test | $(0,1): A: 4$ | When on, ST activates self test. ST must be turned off to end the test. (See Software Diagnostic Circuits.) |
| 3DB | 3 dB Loss to Receive Signal | 1:B:2 | When on, 3DB attenuates the received signal 3dB. This is only used if the R2424M will see OdBm or greater line signal at the receiver input. Insertion of the 3dB loss will then prevent saturation. This bit is not needed with the R2424DC. |
| TONE | Tone Detect | 0:8:7 | TONE follows the energy detected in the 340 to 645 Hz frequency band. The user must determine which tone is present on the line by determining the duty cycle. TONE is active only when CRQ in Bank 0 is on. |
| TXCLK | Transmit Clock Select | 1: $\mathrm{C}:(5,6)$ | TXCLK allows the user to designate the origin of the transmitter data clock. (See Transmit Clock table.) |

## SOFTWARE SUPERVISORY CIRCUITS

The operation of the R2424 is affected by a number of software control inputs. These inputs are written into registers within the modem via a microprocessor bus under external control. Modem operation is monitored by various software flags that are read from modem registers using the same microprocessor bus.

The transmit and receive registers contain many bits which perform identical functions and are located in the same memory location only in different banks. Care must be taken to set these bits according to the desired function.

## CONFIGURATION REGISTER

The host processor configures the R2424 by writing a control word into the configuration registers in its interface memory space as shown in the following tables:

| Configuration |  |  |  |  |  |  |  | Conflguration Word |  |  |  |
| :--- | :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Bell 212A | 1200 Sync. | 0 | 0 |  |  |  |  |  |  |  |  |

Character Length

| Configuration | Configuration Word |
| :---: | :---: |
| 8 bits | 0 |
| 9 bits | 0 |
| 10 bits | 1 |
| 11 bits | 1 |

## Transmit Clock

| Configuration | Configuration Word |
| :---: | :---: |
| Internal | $0 \quad 0$ |
| Not Used | 0 |
| External | 1 |
| Slave | 1 |

Receiver Interface Memory Bank 0 (CSO)


Transmitter Interface Memory Bank 1 (CSI)


## AUTO DIAL SEQUENCE

The following flow chart defines the auto dial sequence via the microprocessor interface memory.


Auto Dial Sequence Flow Diagram
Note: The modem timing for the auto dialer accounts for interdigit delay for pulses and tones.

## DIAGNOSTIC CAPABILITIES

The R2424 provides the user with access to much of the data stored in the modems memories. This data is a useful tool in performing certain diagnostic functions.

## RAM ACCESS CODES

The RAM access codes defined in the table below allow the host processor to read diagnostic data from the modem receiver. The access codes should be loaded into the diagnostic control register $(0: F)$. The appropriate diagnostic data will then be available in the diagnostic data registers (0:[2-5]).

RAM Access Codes Bank 0

| Function | Access | Data Type |
| :--- | :---: | :--- |
| Scrambled Data (Imag. Reg.) | 00 | Real |
| Self Test Error Counter (Real Reg.) | 00 | Real |
| Equalizer Tap Coefficients | $01-09$ | Complex |
| Phase Error (Real Reg.) | 0 C | Real |
| Rotated Equalizer Output | 0 D | Complex |
| (Received Point Eye Pattern) | 0 E | Real |
| Rotated Angle (Imag. Reg.) | 40 | Complex |
| Low Pass Filter Output | $41-49$ | Complex |
| Input Signal to Equalizer Tap Coefficients | 4 D | Complex |
| Decision Points (Ideal) | 4 E | Complex |
| Rotated Error | 4 F | Complex |
| Equalizer Output | 52 | Complex |

## TEST

The specifications for R2424 tests are defined as follows:
Self tests can be initiated by setting bits ([0,1]:A:4) to a 1 . It is possible to perform the tests with or without the DTE connected to the modem. During any self test TXD and RTS are ignored. Note that self tests do not test asynchronous-tosynchronous converter circuits in either the transmitter or receiver.

Error detection is accomplished by monitoring a counter in the RAM. If the counter increments during the self test, an error was made. The counter contents are available in the diagnostic registers when the RAM access code 00 is loaded in the diagnostic control register ( $0: \mathrm{F}$ ).

Self test end-to-end-Upon activation of self-test an internally generated data pattern of alternate binary ones and zeros (reversals) at the selected bit rate are applied to the scrambler. An error detector, capable of identifying errors in a stream of reversals are connected to the output of the descrambler.

Self test with loop 3-Loop 3 is applied to the modem as defined in recommendation V.54. Self-test is activated and DCE operation is as in the end-to-end test. In this test DTR is ignored.

Self test with loop 2-The modem is conditioned to instigate a loop 2 at the remote modem as specified in recommendation V.54. Self-test is activated and DCE operation is as in the end-to-end test.

Loopbacks-Remote digital loopback, digital loopback, and local analog loopback can be initiated via the interface memory, as follows:

1. Digital Loopback. The R2424 can be manually conditioned to loop the received data back to the transmitter by setting
the DL bits ( $[0,1]: A: 5$ ). DL should be set during the data mode. DSR and CTS will be off. The local modem can then be tested from the far-end by using the terminal equipment at the far-end to transmit a test pattern and examine the looped data. At the far-end modem, all interface circuits behave normally as in the data mode. At the conclusion of the test, DL must be turned off. The local modem will then return to the normal data mode with control reverting the DTE's DTR.
2. Local Analog Loopback (V. 54 Loop 3). The R2424 is capable of entering into a local analog loopback (V. 54 Loop 3). In this loop, the transmitter's analog output is coupled to the receiver's analog input at a point near the modem's telephone line interface. An attenuator is introduced into the loop such that the signal level coupled into the receive path is approximately - 16 dBm attenuation.
3. Remote Digital Loopback (V. 54 Loop 2) (Bell 212A and CCITT V. 22 bis and V.22). The R2424 is capable of entering into a remote digital loopback. Remote digital loopback may be locally entered by the interface memory. Remote digital loopback cannot be performed simultaneously with local analog loopback.

## POWER-ON INITIALIZATION

When power is applied to the R2424, a period of 100 to 300 ms is required for initialization. The power-on-reset (POR) signal remains low during the initialization period. After the low to high transition of POR, the modem is ready to be configured.

The modem automatically defaults to V .22 bis 2400 bps , answer state using serial start-stop data, 10 bits per character.

POR can also be used to initialize the user's host processor. It may be connected to a user supplied power-on-reset signal in a wire-or configuration.


## PERFORMANCE

Whether functioning as a V. 22 bis, V.22, or Bell 212A type modem, and regardless of simulated line condition or introduced line impairment, the R2424 provides unexcelled high performance to the user.

## BIT ERROR RATES

The Bit Error Rate (BER) performance of the R2424 is specified for a test configuration conforming to that specified in CCITT Recommendation V.56, except with regard to the placement of the filter used to bandlimit the white noise source. Bit error rates are measured at a received line signal level of -43 dBm .

## INTERFACE CIRCUIT CHARACTERISTICS

## DIGITAL INTERFACE CIRCUITS

Digital Input Characteristics

| Input Logic State | Allowed Input Voltage Levels |
| :---: | :---: |
| Low | 0.0 V to +0.8 V at $-2.5 \mu \mathrm{~A}$ |
| High | +2.0 V to +5.0 V at $+2.5 \mu \mathrm{~A}$ |
| Notes: |  |
| 1. The digital inputs are directly TTL/CMOS compatible. The |  |
| capactive loading on each input is 25 pF (maximum). |  |
| 2. Positive current is defined as current into the node. |  |

Digital Output Characteristics

| Output Logic State | Allowed Output Voltage Levels |
| :---: | ---: |
| Low | +0.4 V at +1.6 mA |
| High | +2.4 V at $-100 \mu \mathrm{~A}$ |
| Notes: |  |
| 1. The digital outputs are directly TTL/CMOS compatible. |  |
| The capactive loading on each output is 50 pF (maximum). |  |
| 2. Positive current is defined as current into the node. |  |

## ANALOG INTERFACE CIRCUITS

## TRANSMISSION LINE INTERFACE

The R2424DC interface to the telephone line is the Tip and Ring leads. Lightning induced surge voltages and other hazardous voltages which may appear on the telephone line are limited to approximately 7 V peak between the secondary leads of the line coupling transformer.

The DAA (R2424DC only) is bi-directional as required by 2-wire full-duplex circuits.

Connection to the telephone line interface pins of the R2424DC to the network are made via the RJ11, as shown in the table below:

R2424DC Network Interface

| Connection Type | Telco | Mnemonic | Function |
| :---: | :---: | :---: | :---: |
| VSOC | 1 |  |  |
| RJ11 | 2 |  | Ring-one side of <br> telephone line |
| Jack | 3 | R | T |
|  | 4 |  | Tip-one side of <br> telephone line |
|  | 5 |  |  |

## RING INDICATOR

The R2424 provides a ring indicator ( $\overline{\mathrm{RI})}$ ) output; its low state indicates the presence of a ring signal on the line. The low condition appears approximately coincident with the on segment of the ring cycle (during rings) on the communication channel. (The ring signal cycle is typically two seconds on, four seconds off.) The high condition of the indicator output is maintained during the off segment of the ring cycle (between rings) and at all other times when ringing is being received. The operation of $\overline{R I}$ is not disabled by an off condition on Data Terminal Ready.
$\overline{\mathrm{RI}}$ will respond to ring signals in the frequency range of 15.3 Hz to 68 Hz with voltage amplitude levels of 40 to 150 Vrms (applied across Tip and Ring), with the response times given in the following table:
RI Response Time

| RI Transition | Response Time |
| :---: | ---: |
| Off-to-On | 125 ms to 400 ms |
| On-to-Off | 75 ms to 250 ms |

This off-to-on (on-to-off) response time is defined as the time interval between the sudden connection (removal) of the ring signal across Tip and Ring and the subsequent on (off) transition $\overline{\mathrm{RI}}$.

## OH (OFF-HOOK)

The R2424M provides an output OH (Off-Hook) which indicates the state of the OH relay. A low condition on OH implies the OH relay is closed and the modem is connected to the telephone line. A high condition on OH implies the OH relay is open (i.e., the modem is on-hook). The delay between the low-to-high or high-to-low transition of OH and the subsequent close-to-open or open-to-close transition of the OH relay is 8 ms maximum.

## $\overline{R D}$

$\overline{\mathrm{RD}}$ indicates to the R2424M by an on (low) condition that a ringing signal is present. The $\overline{\mathrm{RD}}$ signal should not respond to momentary bursts of ringing less than 125 ms in duration, or to less than 40 V rms, 15 to 68 Hz appearing across Tip and Ring with respect to ground.

## RCCT

RCCT is used to request that a data transmission path through the DAA be connected to the telephone line. When RCCT goes off (low), the cut-through buffers are disabled and CCT should go off (high) within 1 msec . RCCT should be off during dialing but on for tone address signaling.

## $\overline{\text { CCT }}$

An on (low) signal to the CCT lead indicates to the R2424M that the data transmission path through the DAA is connected.

## AUDIO INTERFACE INPUT IMPEDANCE

The specifications for the audio interface input impedance are given in the following table:

Audio Interface Input Impedance

| On/Off Hook | Measurement |
| :--- | :--- |
| On-Hook (DC) | The DC resistance between Tip and <br> Ring, and between either Tip or Ring <br> and signal ground is greater than <br> 10 megohms for DC voltages up to <br> 100 volts. |
| On-Hook (AC) | The on-hook AC impedance measured <br> between Tip and Ring is less than <br> 40K ohms (15.3 Hz minimum). |
| Off-Hook (DC) | Less than 200 ohms. |
| Off-Hook (AC) | 600 ohms nominal when measured <br> between Tip and Ring. |

## TRANSMITTER OUTPUT

Basic telephone company requirement is that the signal level received at the relevant local central office not exceed -12 dBm . Several different "connection arrangements" have been established (as documented in Part 68) to accomplish this goal.

When the permissive connection arrangement is used, the transmit output signal level appearing across Tip and Ring (with a 600 ohm resistive load across Tip and Ring) will not exceed -9 dBm . The output level is set at a fixed -10 dBm (nominal). The permissive wall jacks used for data connections are the same jacks used for standard voice installations. The permissive connection arrangement allows greater mobility for user equipment.

When the programmable connection arrangement is used, the maximum output transmit signal level allowed to appear across the Tip and Ring (again, terminated with 600 ohms) is set by a resistor installed by the telephone company in their wall jack at the customer location. The resistor (which is one of thirteen possible values) interacts with the modem through modem leads PR and PC to program the maximum output level, in one $d B$ steps between -12 dBm and 0 dBm . (The resistor is selected by the telephone company jack installer after he has measured the line loss from the customer location to the local telephone company central office).

## INSTALLATION

## IMPORTANT NOTICE TO USER

The modem contains protective circuitry registered with the Federal Communications Commission (FCC) Part 68 to allow direct connection to the switched telephone network. To comply with the FCC regulations the following is required:

1. All direct connections to the telephone lines shall be made through standard plugs and telephone company provided jacks.
2. It is prohibited to connect the modem to pay telephones or party lines.
3. You are required to notify the local telephone company prior to the connection and upon final disconnection of the modem. You must supply to the telephone company the make, model number, FCC registration number, ringer equivalence and particular line to which the connection is to be made. If the proper jacks are not available, you must order the type of jacks to be used from the telephone company.
4. You should disconnect the modem from the telephone line if it appears to be malfunctioning. Reconnect it only when it can be determined that the telephone line is the source of trouble. If the modem needs repair, return it to Rockwell International. This applies to equipment both in and out of warranty. Do not attempt to repair the unit as this will violate FCC rules.
5. The modem contains protective circuitry to prevent harmful voltages from being transmitted to the telephone network. If however such harmful voltages do occur, then the telephone company shall:

- Promptly notify you of the discontinuance.
- Afford you the opportunity to correct the situation which caused the discontinuance.
The FCC requires that the following label be prominently displayed on an outside surface of the OEM's end product.
- Unit contains Registered Protective Circuitry which complies with Part 68 of FCC Rules.
- FCC Registration Number: Applied For
- Ringer Equivalence: 0.5

Size of the label should be such that all the required information is legible without magnification.

## GENERAL SPECIFICATIONS

## Power Requirements

| Voltage* | Tolerance | Current (Max) |
| :---: | :---: | :---: |
| +5 Vdc | $\pm 5 \%$ | $<500 \mathrm{ma}$ |
| +12 Vdc | $\pm 5 \%$ | $<10 \mathrm{ma}$ |
| -12 Vdc | $\pm 5 \%$ | $<50 \mathrm{ma}$ |

*All voltages must have ripple $\leq 0.1$ volts peak-to-peak.

## Environmental

| Parameter | Specification |
| :--- | :--- |
| Temperature: <br> Operating <br> Storage | $0^{\circ} \mathrm{C}$ to $+60^{\circ} \mathrm{C}\left(32\right.$ to $\left.140^{\circ} \mathrm{F}\right)$ <br> Relative Humidity: <br>  <br> Altitude: |
| Up to $90 \%$ noncondensing, or a wet <br> bulb temperature up to $35^{\circ} \mathrm{C}$, <br> whichever is less. <br> -200 to $+10,000$ feet |  |
| *PCB's are stored in heat sealed antistatic bags and shipping <br> Containers. |  |

## Mechanical

| Board Structure: Mating Connector: | Single PC board with right angle male DIN connector. <br> Female 3 row 64 pin Euroconnector (DIN) with rows A and C populated. Recommended mating connector: Winchester 96S-6043-0531-1 or equivalent. |
| :---: | :---: |
| PCB Dimensions: DC Version | Width 3.94 in . $(100 \mathrm{~mm}) \times$ Length $4.725 \mathrm{in} .(120 \mathrm{~mm}) \times$ Height 0.75 in. ( 19 mm ) |
| M Version | Width 3.94 in . $(100 \mathrm{~mm}) \times$ Length 3.35 in . $(85 \mathrm{~mm}) \times$ Height 0.40 in . ( 10 mm ) |
| Weight: | Less than 0.45 lbs . 0.20 kg .) |



Printed Circuit Board Dimensions

## 0 Rockwell

## R24DC <br> 2400 BPS DIRECT CONNECT MODEM

## INTRODUCTION

The Rockwell R24DC is a high performance synchronous serial 2400 bps DPSK modem. Extensively utilizing MOS/LSI technology with registered protective circuitry, the R24DC is ideally suitable for direct connection to the domestic switched network or two-wire private lines. Performance and versatility are enhanced while cost and size are reduced by the on-board Rockwell PPS-4/1 One Chip Microcomputer

Having Bell 201C and CCITT V. 26 bis compatibility, the R24DC offers the user a high performance 2400 bps modem that is FCC registered for direct connection to the dial-up network. No re-registration of OEM equipment is required when the simple installation instructions, supplied with the R24DC, are followed. OEM's can easily incorporate this single ( $5^{\prime \prime} \times 8^{\prime \prime}$ ) card into their computer terminals, communication networks, PABX equipment, data concentrators, stand-alone box modems or almost any application where reliable data communication is required.

## FEATURES

- High Performance; Low Cost
- LSI High Density; Low Power
- Microcomputer Controlled Line Connect/Disconnect Sequence; Low Component Count
- Bell 201 C, CCITT V. 26 bis Compatible
- Half Duplex (2-Wire) Operating Mode
- 2400 BPS Data Rate
- Auto or Manual Answer
- Auto or Manual Dial Through (Pulse Dialing)
- Automatic Answer Back Tone Generation upon Auto Answer
- Direct Connect to Switched 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 LSTTL/CMOS Compatible Levels. RS-232-C Functions
- External 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)


R24DC Modem

## FUNCTIONAL SPECIFICATIONS



R24DC Functional Block Diagram

Transmitter Carrier Frequency $-1800 \mathrm{~Hz} \pm 0.01 \%$
Echo Suppression and Answering Tone Frequencies $2100 \mathrm{~Hz} \pm 0.01 \%$ or $2025 \mathrm{~Hz} \pm 0.01 \%$.

Received Signal Frequency Tolerance - The receiver 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 - The normal signaling rate is 1200 baud $\pm 0.01 \%$, and a data rate of $2400 \mathrm{bps} \pm 0.01 \%$. The fallback signaling rate is 1200 baud $\pm 0.01 \%$, and a data rate of $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 4-phase modulation is employed. The data stream to be transmitted is

| 2400 BPS |  |  |
| :---: | :---: | :---: |
| DIBIT | PHASE CHANGE |  |
|  | V.26A | V.26B/Bell 201 |
|  | $0^{\circ}$ | $+45^{\circ}$ |
| 01 | $+90^{\circ}$ | $+135^{\circ}$ |
| 11 | $+180^{\circ}$ | $+225^{\circ}$ |
| 10 | $+270^{\circ}$ | $+315^{\circ}$ |

divided into pairs of consecutive bits (dibits). Each dibit is encoded as a phase change relative to the phase of the immediately preceding signal element. Two alternative arrangements of coding are possible (in accordance with CCITT Recommendations V. 26 and V. 26 bis) as shown in the following chart.


ALTERNATIVE


## Reference Line Signal Diagram (V. 26 A\&B)

At 1200 bps, differential 2-phase modulation is employed. Each bit to be transmitted is encoded as a phase change relative to the phase of the immediately preceding signal element. The encoding is in accordance with CCITT Recommendation V. 26 bis as shown in the following chart.

| 1200 BPS |  |
| :---: | :---: |
| BIT | PHASE CHANGE |
| 0 | $+90^{\circ}$ |
| 1 | $+270^{\circ}$ |

Turn On Sequences - A total of six selectable turn on sequences can be generated by the transmitter of the R24DC, as shown in the following chart.

| TYPE OF LINE SIGNAL | SEGMENT 1 | SEGMENT 2 | TOTAL OF SEGMENTS 1,2 |  |
| :---: | :---: | :---: | :---: | :---: |
| TURN-ON SEQUENCE NUMBER | CONTINUOUS UNSCRAMBLED ONES | CONTINUOUS SCRAMBLED ${ }^{1}$ ONES | NOMINAL TOTAL TURN ON SEQUENCE TIME2 | COMMENTS |
|  | $\begin{gathered} 90 \mathrm{~ms} \\ 8.33 \mathrm{~ms} \\ 148.3 \mathrm{~ms} \\ 8.33 \mathrm{~ms} \\ 220 \mathrm{~ms} \\ 8.33 \mathrm{~ms} \end{gathered}$ | $\begin{gathered} 0 \mathrm{~ms} \\ 81.67 \mathrm{~ms} \\ 0 \mathrm{~ms} \\ 140 \mathrm{~ms} \\ 0 \mathrm{~ms} \\ 211.7 \mathrm{~ms} \end{gathered}$ | 90 ms 90 ms 148.3 ms 148.3 ms 220 ms 220 ms | V.26, V. 26 bis (scrambler inserted) <br> Bell 201C <br> (scrambler inserted) <br> V. 26 bis <br> (scrambler inserted) |

As is evident from the above for those turn-on sequences for which the scrambler is inserted, the transmitted line signal corresponds to a continuous "one", unscrambled, for 8.33 ms -ten baud (symbol) intervals - followed by the transmission of a continuous "one", scrambled, for the remainder of the turn-on sequence.

Turn Off Sequence - When the R24DC transmitter has been sending data and Request-to-Send is turned off, any remaining data bit information is transmitted within 6 milliseconds.

Response Times of Clear-to-Send - The Clear-to-Send response times are determined by the selected configuration of the R24DC and its associated turn-on sequence, as shown in the following chart.

| TURN-ON sequence NUMBER | CLEAR-TOSEND RESPONSE TIMES ${ }^{1}$ |  | COMMENTS |
| :---: | :---: | :---: | :---: |
|  | OFF-TO-ON | ON-TO-OFF |  |
| 1 | 90 ms , | 0 ms | V. 26 bis |
| 2 | 90 ms | 0 ms | V. 26 bis w/scrambler |
| 3 | 148.3 ms | 0 ms | Bell 201C |
| 4 | 148.3 ms | 0 ms | Bell 201C w/scrambler |
| 5 | 220 ms | 0 ms | V. 26 bis |
| 6 | 220 ms | 0 ms | V. 26 bis w/scrambler |

The tolerance on each Off-to-On and On-to-Off response time is $(+3.4,-0.1) \mathrm{ms}$.

Scrambler/Descrambler - The R24DC incorporates a selfsynchronizing scrambler/descrambler. This feature is enabled by a discrete digital input.

Carrier Detection - The receiver circuit of the R24DC contains a received line signal detector which indicates the presence of energy at the receiver input above a certain threshold for a minimum amount of time.

Carrier Detect Thresholds

| Received Level | Carrier Detect |
| :--- | :--- |
| Greater than -43 dBm <br> Less than -48 dBm | On (Line signal present) <br> Off (Line signal not present) |

Carrier Detect Response Time

| Carrier Detect Transition | Response Time |
| :---: | :---: |
| Off-to-On | $14 \pm 1 \mathrm{~ms}$ |
| On-to-Off | $8 \pm 3 \mathrm{~ms}$ |

Clamping - The following clamps are provided:

1. Received Data. The Received Data output is clamped to a mark when Carrier Detect is off. This action prevents disturbances on the line from getting through the receiver circuit to the data output.
2. Carrier Detect Clamp. The Carrier Detect output is clamped off (squelched) during the time when Request-to-Send is on. An option extends this clamp for 148 ms beyond transitioning off; thus providing echo protection.
3. Receive Clock Clamp. The Receive Clock output is clamped off when Carrier Detect is off. This action prevents any disturbances from propagating through the receiver circuit to the receive clock output.

Equalizer - The R24DC contains a fixed compromise delay equalizer, which can be used to improve performance over the domestic switched network. The equalizer may optionally be positioned in the receiver, or removed entirely, by means of a jumper plug. The equalizer has a nominally flat 0.0 dB amplitude response.

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.

Receive Level - The R24DC receives line signals from 0 to -43 dBm .

Transmit Timing - The R24DC generates a Transmit Clock having the following characteristics: Frequency -2400 Hz $\pm 0.01 \%$ ( $1200 \mathrm{~Hz} \pm 0.01 \%$ in fallback mode), duty cycle - 50 $\pm 1 \%$. The R24DC is also optionally capable of tracking an External Transmit Clock supplied by the user. Both have similar characteristics.

Receive Timing - 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.

Transmit Level - The R24DC transmitted output line signal level may be regulated in either the permissive or programmable modes. In the permissive mode, the transmitted line signal level is -9 dBm maximum. In the programmable mode, the transmitted line signal level is set by an external resistor installed by the telephone company in the wall jack. Using this method, the transmitted line signal level can be controlled in increments of 1 dBm from 0.0 to -12 dBm , depending on the value of resistance installed.

Answering Tone Generation - When in the automatic answering mode, the R24DC generates a selectable answeririg tone of $2100 \mathrm{~Hz} \pm 0.01 \%$ or $2025 \mathrm{~Hz} \pm 0.01 \%$. It is also capable of optionally providing this tone when in the manual answer mode.

## Answering Tone Frequency

| INPUT |  |
| :---: | :---: |
| SELECT 1 |  |
| (P1-34) | ANSWERING TONE |
| FREQUENCY |  |

Satellite Option and DSR Selection

| Satellite <br> Option | DSR (P1-30) <br> During Analog <br> Loopback | AL-DSR Enable <br> (P1-12) |
| :---: | :---: | :---: |
| Yes <br> No <br> Yes <br> No | OFF (High) | ON (Low) |
| ON Low) | OFF (High) | Wired to Analog Loopback <br> Wired to Analog Loopback 1. |

1. Inverse of Signal applied to Analog Loopback Input.

Baud Clocks - Symbol or baud timing is available for both the transmitter and receiver functions. These signals have characteristics similar to the data clocks except that their frequency is equal to the signalling rate of $1200 \mathrm{~Hz} \pm 0.01 \%$.

Analog Loopback - The R24DC can be locally commanded into local analog loopback (CCITT Loop 3) via digital input Analog Loopback, when in the wait mode.

| Data Structure |  |  |
| :---: | :---: | :---: |
| INPUT |  |  |
| DATA SIGNALLING RATE SELECTOR (P1-16) | $\begin{gathered} \text { V. } 26 \mathrm{~A} / \mathrm{B} \\ \text { (P1-14) } \end{gathered}$ | DATA STRUCTURE |
| Low | Low | 2400 bps Alternate A |
| Low | High | 2400 bps V. 26 Alternate B (Bell 201C) |
| High | Low or High | 1200 bps |

Abort Timer - The R24DC contains a $15 \pm 1$ second abort timer, which may be enabled via the Abort Enable input.

Line Current Interrupt Disconnect - The R24DC contains a $475 \pm 125 \mathrm{~ms}$ line current interrupt abort timer, which may be enabled via the LCIS Enable input.

The digital interchange circuits provide control, status indicators, data clocks and data interface. Traditional RS232-type control functions and additional signals allow the user to access the inherent flexibility and monitoring capabilities of the R24DC.

## Carrier Detect Squelch

| INPUTS |  |  |  |
| :---: | :--- | :--- | :--- |
| ANALOG <br> LOOPBACK <br> (P1-33) | SELECT 2 <br> (P1-35) | REQUEST- <br> TOSEND <br> (P1-11) | SQUELCH STATUS ${ }^{1}$ |
| Low | Low or High | Low or High |  |
| High | Low or High | Low | Squelch |
| High | High | Low $\rightarrow$ High | Extended Squelch ${ }^{2}$ |
| High | Low | Low $\rightarrow$ High | No Extended Squelch |

"Squelch" means that Carrier Detect is clamped off (high) regardless of the level of received line signal. When "extended squelch" is enabled, squelch occurs both during the time when Request-to-Send is on (low) and for $148.3 \mathrm{~ms}(+3.4,-0.1 \mathrm{~ms}$ ) following the On-to-Off transition of Request-to-Send.

Selection Of Clear-To-Send Response Times

| TURN-ON SEQUENCE | INPUTS |  |  | CLEAR-TOSEND RESPONSE TIME1 (ms) |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} \text { SELECT } 1 \\ \text { (P1-34) } \end{gathered}$ | SCRAMBLER ENABLE (P1-15) | SELECT 2 (P1-35) |  |  |
|  |  |  |  | OFF-TO-ON | ON-TO-OFF |
| 1 | High | Low | Low | 90 | 0 |
| 2 | High | High | Low | 90 | 0 |
| 3 | Low | Low | Low or High | 148.3 | 0 |
| 4 | Low | High | Low or High | 148.3 | 0 |
| 5 | High | Low | High | 220 | 0 |
| 6 | High | High | High | 220 | 0 |
| The tolerance on each Off-to-On and On-to-Off response is ( $-3.4,-0.1 \mathrm{~ms}$ ). |  |  |  |  |  |

## OPERATING MODES

Line connect and disconnect sequences are controlled automatically by the R24DC which is at all times in one of the following modes:

Wait Mode - This is a hot-standby mode. The R24DC enters this mode upon a power-up, Reset, or whenever an operational mode is exited. The following diagrams illustrate the sequence of events for the Wait mode.


## Wait Mode Flow Diagram

Analog Loopback Mode - This mode provides the capability of diagnosing a problem in the communications link. In this mode, the transmitter's analog output is connected to the receiver's analog input through an attenuator.

Manual Originate Mode - This mode provides the capability of manual call origination. Calls may be originated in the usual manner by a telephone set. Signal sequence for this mode is shown in the following diagram.


Automatic Call Mode - This mode provides the capability of automatically originating calls by using the pulse dialing technique.

The R24DC allows the user to auto dial by controlling inputs DTR, C.O.P. and DP. To originate a call, DTR and C.O.P. must
be on. Then DP (normally off) is pulsed at a rate of $9.5 \pm 1.5$ pulses per second.

The pulse requirement is a uniform train with break intervals at 58\% to 64\%.

The interdigit time (i.e., the time between the end of the last pulse of a given digit and the beginning of the first pulse of a subsequent digit) should be between 700 ms and 3 seconds.
C.O.P. is turned off after the called modem answers. Signal sequence for this mode is shown in the following diagram.


## Automatic Call Mode Sequence

Manual Answer Mode - This mode provides the capability of manually answering calls with a telephone set. Signal sequence for this mode is shown in the following diagram.


Manual Answer Mode Sequence
Automatic Answer Mode - This mode provides the capability of automatically answering calls. Signal sequence for this mode is shown in the following diagram.


Automatic Answer Mode Sequence

## INTERFACE CRITERIA

The R24DC interface signals are classified as digital interchange signals and analog signals. These signals interface to the user through the board edge connector.
Digital Interchange Circuits - The characteristics of the R24DC digital inputs and outputs are given in the following charts.

Digital Input Characteristics

| Input Logic State | Allowed Input Voltage Levels |
| :---: | :--- |
| Low | 0.0 V to 0.8 V sinking $<10 \mu \mathrm{~A}$ <br> $+4.0 \mathrm{~V}(\mathrm{VSS}-1 \mathrm{~V})$ to $+5.0 \mathrm{~V}(\mathrm{VSS})$ <br> sourcing $<10 \mu \mathrm{~A}$ |

The digital inputs are directly CMOS compatible. The capacitive loading on each input is $\mathbf{2 5} \mathrm{pF}$ (maximum).

Digital Output Characteristics

| Ouput Logic State | Allowed Output Voltage Levals |
| :---: | :--- |
| Low | 0.0 V to 0.4 V sinking 0.36 mA <br> High$4.0 \mathrm{~V}(\mathrm{VSS}-1 \mathrm{~V}$ ) to 5.0 V (VSS) <br> sourcing $100 \mu \mathrm{~A}$ |

The digital outputs are directly CMOS or low-power Schottky TTL compatible.

## DIGITAL OUTPUT CHARACTERISTICS (EXCEPTIONS)

The exceptions to the above are outputs $\mathrm{OH}, \mathrm{RI}, \mathrm{SH}$ and A . Outputs $\mathrm{OH}, \mathrm{RI}$ and SH have the following characteristics:

| Output Logic State | Allowed Output Voltage Levels |
| :---: | :---: |
| Low | 0.0 V to 0.4 V sinking 0.36 mA <br> High |

Output A, useful in the generation of eye pattern and diagnostic information, switches from +5.0 V to -12.0 V .

Audio Interface Input Impedance

| Parameter | Specification |
| :---: | :--- |
| On-Hook DC | DC resistance between Tip and Ring, and <br> between either Tip or Ring and signal <br> ground is greater than 10 megohms for <br> DC voltages up to 100 volts. |
| On-Hook AC | On-hook AC impedance measured <br> between Tip and Ring is less than 40 K <br> ohms (15.3 Hz minimum) |
| Off-Hook DC | Less than 200 ohms <br> Off-Hook AC <br> Longitudinal <br> Balance |
| between Tip and Ring <br> betweasured <br> Meets requirements of FCC Rules, <br> Part 68 |  |

FCC Registration Number: AMQ9SQ-68813-DM-R
Ringer Equivalence: 0.9 B

Analog Interface Circuits - The analog interface circuits defined in the following charts provide power and switched network connections and a means for the user to monitor the incoming line signals.

## Analog Interface Circuits

| TERM | PIN <br> NUMBER | DESCRIPTION |
| :--- | :--- | :--- |
| +12 V | P1-40 | +12V Power Supply |
| -12 V | P1-38 | -12V Power Supply |
| +5V | P1-1 | +5V Power Supply |
| COMMON | P1-2, | Ground (signal and power return) |
|  | P1-4 |  |
| Receiver P1-32 | Low impedance output of R24DC <br> Analog |  |
|  |  | Ring to Receive filter. Gain from Tip and <br> inally 12.7 dB |
|  |  | TELEPHONE INTERFACE is nom- |



Typical R24DC to OEM Interconnections for Half-Duplex Applications


1. MI AND MIC ARE REQUIRED ONLY IF HANDSET IS EMPLOYED.
2. PR AND PC ARE REQUIRED FOR PROGRAMMABLE MODE ONLY
3. STANDARD TELEPHONE CO. PROVIDED JACK RJ16X, RJ45S OR RJ41S
4. RJ36X OR CONNECTING BLOCK IS REQUIRED ONLY IF TELEPHONE HANDSET IS EMPLOYED. WHEN THE R24DC IS IN THE PERMISSIVE MODE, THE RJA2X ADAPTER AND RJ11C JACK MAY BE EMPLOYED WITH THE ASSOCIATED TELEPHONE SET.

## Typical R24DC to Network Interconnection

Telephone Line and OEM Connections - Connection of the R24DC telephone interface pins to the network is made via standard jacks and plugs. A typical installation, including an optional telephone set, is illustrated.
Telephone Set - If it is desirable to have manual call origination or alternate voice capability, an exclusion key telephone set (configured as Modem Controls the Line) may be ordered from your local telephone company.

Mounting and Signal Routing - The R24DC may be physically incorporated into your OEM end product by using either the four corner ( 0.156 inch) diameter mounting holes or by using board guides. The electrical interface is via edge connector(s).

Interface Mating Connectors

| Type/ <br> Manufacturer | P1 (DTE) Connector | P2 (Telephone Line) <br> Connector |
| :--- | :--- | :--- |
| Type: | 40 pin <br> 0.100 in. spacing <br> 20 pins per side | 10 pin <br> 0.100 in. spacing <br> 20 pins per side |
| Winchester: | $53-40-0$ | $53-10-0$ |
| T\&B Ansley: | $609-4015 \mathrm{M}$ |  |
| Spectra-Strip: | $807-4005-001$ | $609-1015 \mathrm{M}$ |
|  | $80 \%-1005-001$ |  |

## PERFORMANCE DATA

The R24DC 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.

Timing Jitter - The maximum steady state timing jitter of Received Clock with respect to Transmit Clock is less than 10\% $\mathrm{p}-\mathrm{p}$ for an input signal-to-noise ratio of 12 dB .
Bit Error Rate - The following graph represents typical R24DC performance.


1. 1200 BPS, BACK-TO.BACK, SCRAMBLER, NO EQUALIZER
2. 2400 BPS V 26 OR OR BACK-TO-BACK SCRAIMBLER NO EQUALIZER
3. 2400 BPS, V . 26 A OR B, $15^{\circ} .150 \mathrm{HZ}$ PHASE JITTER, NO SCRAMBLER, NO EQUALIZER
4. 2400 BPE , .26 A OR B, $30^{\circ} \cdot 120 \mathrm{HZ}$ PHASE JITTER, NO SCRAMBLER, NO EOUALIZER
2400 BPS, V . 26 A OR B 3002 UNCONDITIONED LINE NO SCRAMBLER, EQUALIZER

Typical Bit Rate 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 microcomputer.
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.

## POWER REQUIREMENTS

| Voltage | Ripple | Maximum <br> Current |
| :---: | :---: | :---: |
| +5 VDC $\pm 5 \%$ | 100 mV p-p | 110 mA |
| +12 VDC $\pm 5 \%$ | $50 \mathrm{mV} p-\mathrm{p}$ | 70 mA |
| -12 VDC $\pm 5 \%$ | $50 \mathrm{mV}-\mathrm{p}$ | 140 mA |

## ENVIRONMENTAL SPECIFICATIONS

Operating Temperature: $0^{\circ} \mathrm{C}$ to $60^{\circ} \mathrm{C}$
Storage Temperature: $-40^{\circ} \mathrm{C}$ to $+90^{\circ} \mathrm{C}$
Relative Humidity: to $95 \%$ (non-condensing)
Altitude: -200 to 10,000 feet ( $\mathbf{- 6 1}$ meters to 3,049 meters) Burn-In: 96 hours at $70^{\circ} \mathrm{C}$

## MAXIMUM DIMENSIONS

Width: 4.988 in. ( 12.669 cm )
Length: $7,900 \mathrm{in} .(20.066 \mathrm{~cm})$
Height: 0.500 in. $(1.270 \mathrm{~cm})$

## R24LL <br> 2400 BPS MODEM

## INTRODUCTION

The Rockwell R24LL is a high-performance serial synchronous 2400 bps DPSK modem. By utilizing state-of-the-art MOS/LSI technology, the R24LL provides the user with enhanced performance and reliability in a small package. Implemented on a single printed circuit board, the R24LL is less than 26 square inches.

The R24LL operates in either the full-duplex (4-wire telephone connection) or half-duplex (2-wire telephone connection) mode. The R24LL is designed for easy integration into a user's system, e.g., a simple box or rack-mount modem, statistical multiplexor, error controller, terminal, PBX, or any other communications product that requires the utmost in reliability and performance for data transmission over voice-grade telephone lines.

The R24LL is ideal for data transmission applications over either 2 -wire or 4 -wire leased (dedicated) telephone lines or the dialup telephone network. Bell 201 B/C, CCITT V. 26 A/B and V. 26 bis A/B compatible, the R24LL modem offers the user flexibility in creating a 2400 bps modem design customized for specific packaging and functional requirements.

## FEATURES

- High Performance-Low Cost
- LSI High Density-Low Power
- Bell 201 B/C, CCITT V. 26 A/B Compatibility and V. 26 bis A/B Compátibility
- DTE Interface LSTTL/CMOS Compatibility
- External Transmit Data Clock Tracking
- Diagnostic Outputs Available for Eye Pattern Generation and Data Quality Monitoring
- Fixed Compromise Equalizer (Strap Selectable)
- 2400/1200 bps Modes
- Transmitter-Differential Phase Modulation
- Receiver-Coherent Phase Detection
- Operating Modes:
-Half-Duplex (2-wire)
-Full-Duplex (4-wire)
- Outstanding Performance Over Unconditioned Lines
- V. 27 Scrambler/Descrambler Compatibility
- Answer-Back Tone Generation
- Clear-to-Send Delay Options
- NSYNC Option for Rapid Resynchronization in Multi-Point Applications
- Small Size-Less than 26 sq. in.
- Typical Power Consumption-3 watts
- Power Requirements, +5 Vdc and $\pm 12$ Vdc




## FUNCTIONAL SPECIFICATIONS

Transmitter Carrier Frequency- $1800 \mathrm{~Hz} \pm 0.01 \%$
Echo Suppression and Answering Tone Frequencies-2100
$\mathrm{Hz} \pm 0.01 \%$ or $2025 \mathrm{~Hz} \pm 0.01 \%$
Received Signal Frequency Tolerance-The receiver 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-The normal signaling rate is 1200 baud $\pm 0.01 \%$ and a data rate of $2400 \mathrm{bps} \pm$ $0.01 \%$. The fallback signaling rate is 1200 baud $\pm 0.01 \%$ and a data rate of $1200 \mathrm{bps} \pm 0.01 \%$.

Transmitted Data Spectrum - The transmitted spectrum's bandwidth extends from 800 Hz to 2800 Hz . Phase distortion characteristics fall within the limits specified in CCITT Recommendation V. 26 bis. The out-of-band signal power limitations meet those specified by Part 68 of 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 4-phase modulation is employed. The data stream to be transmitted divides into pairs of consecutive bits (dibits). Each dibit is encoded as a phase change relative to the phase of the immediately preceding signal element. Two alternative arrangements of coding are possible (in accordance with CCITT Recommendations V. 26 and V. 26 bis) as shown in the following chart.

| Data Encoding |  |  |
| :---: | :---: | :---: |
| 2400 BPS |  |  |
|  | Phase Change |  |
| Dibit | V.26A | V.26B/Bell 201 |
| 00 | $0^{\circ}$ | $+45^{\circ}$ |
| 01 | $+90^{\circ}$ | $+135^{\circ}$ |
| 11 | $+180^{\circ}$ | $+225^{\circ}$ |
| 10 | $+270^{\circ}$ | $+315^{\circ}$ |



Reference Line Signal Diagram (V. 26 A\&B)

At 1200 bps, differential 2-phase modulation is employed. Each bit to be transmitted is encoded as a phase change relative to the phase of the immediately preceding signal element. The encoding is in accordance with CCITT Recommendation V. 26 bis as shown in the following chart.

Data Encoding

| 1200 BPS |  |
| :---: | :---: |
| Bit | Phase Change |
| 0 | $+90^{\circ}$ |
| 1 | $+270^{\circ}$ |

Turn On Sequences-The transmitter of the R24LL can generate a total of 13 selectable turn-on sequences, as shown in the following chart.

Turn Off Sequence-When the transmitter has been sending data and. "Request-to-Send" is turned off, any remaining data bit information transmits within 6 milliseconds.

Response Times of Clear-to-Send-The selected configuration of the R24LL and its associated turn-on sequence determine the Clear-to-Send response times, as shown in the following chart.

Scrambler/Descrambler-The R24LL incorporates a selfsynchronizing scrambler/descrambler enabled by a discrete digital input.

Carrier Detection-The R24LL contains a received line signal detector. This detector indicates the presence of energy at the receiver input above a certain threshold for a minimum amount of time.

Carrier Detect Thresholds

| Recelved Level | Carrier Detect |
| :--- | :--- |
| Greater than -43 dBm <br> Less than -48 dBm | On (line signal present) <br> Off (line signal not present) |

Carrier Detect Response Time

| Carrier Detect Transition | Response Time |
| :---: | :---: |
| Off-to-On | $14 \pm 1 \mathrm{~ms}$ |
| On-to-Off | $8 \pm 3 \mathrm{~ms}$ |

Turn-On Sequences

| Type of Line Signal | Segment 1 | Segment 2 | Total of Segments 1, 2 |  |
| :---: | :---: | :---: | :---: | :---: |
| Turn-On Sequence Number | Continuous Unscrambled Ones | Continuous Scrambled ${ }^{1}$ Ones | Nominal Total Turn On Sequence Time ${ }^{2}$ | - Comments |
| $\begin{array}{r} 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 10 \\ 11 \\ 12 \\ 13 \end{array}$ | 0 ms 6.67 ms 8.33 ms 30 ms 8.33 ms 90 ms 8.33 ms 148.3 ms 8.33 ms 220 ms 8.33 ms 800 ms 8.33 ms | 0 ms <br> 0 ms <br> 0 ms <br> 0 ms <br> 21.67 ms 0 ms 81.67 ms 0 ms 140 ms 0 ms 211.7 ms 0 ms 791.7 ms | 0 ms 6.67 ms 8.33 ms 30 ms 30 ms 90 ms 90 ms 148.3 ms 148.3 ms 220 ms 220 ms 800 ms 800 ms | V. 26 <br> (scrambler inserted) V.26, V. 26 bis (scrambler inserted) <br> (scrambler inserted) V. 26 bis (scrambler inserted) V. 26 bis (scrambler inserted) |
| 1. See paragraph titled Scrambler/Descrambler for a description of scrambler/descrambler facility. <br> 2. For those turn-on sequences in which the scrambler is inserted, the transmitted line signal corresponds to a continuous "one", unscrambled, for 8.33 ms -ten baud (symbol) intervals, followed by the transmission of a continuous "one", scrambled, for the remainder of the turn-on sequence. |  |  |  |  |


| Turn-On Sequence Number | Clear-To-Send Response Times* |  | Comments |
| :---: | :---: | :---: | :---: |
|  | Off-to-On | On-to-Off |  |
| 1 | 0 ms | 0 ms |  |
| 2 | 6.67 ms | 0 ms | switched carrier 4-wire (BELL 201) |
| 3 | 8.33 ms | 0 ms | switched carrier 4-wire |
| 4 | 30 ms | 0 ms | CCITT 4-wire |
| 5 | 30 ms | 0 ms | CCITT 4-wire with scrambler |
| 6 | 90 ms | 0 ms | CCITT 2-wire |
| 7 | 90 ms | 0 ms | CCITT 2-wire with scrambler |
| 8 | 143.3 ms | 0 ms | switched carrier 2-wire |
| 9 | 143.3 ms | 0 ms | switched carrier 2-wire with scrambler |
| 10 | 220 ms | 0 ms | CCITT 2-wire echo protection |
| 11 | 220 ms | 0 ms | switched 2-wire echo protection with scrambler |
| 12 | 800 ms | 0 ms | CCITT 2-wire auto call |
| 13 | 800 ms | 0 ms | CCITT 2-wire auto call with scrambler |
| *The toleran time is (+.9 | on each Off .1) ms . | to-On and | On-to-Off response |

Clamping Options-The following clamps are provided with the R24LL:

1. Received Data. The Received Data output is clamped to a mark when Carrier Detect is off. This action prevents disturbances on the line from getting through the receiver circuit to the data output.
2. Carrier Detect Clamp. The Carrier Detect output is clamped off (squelched) when Request-to-Send is on. An option extends this clamp for 148 milliseconds beyond transitioningoff, thus providing echo protection.
3. Receive Clock Clamp. The Receive Clock output is clamped off when Carrier Detect is off. This action prevents any disturbances from propagating through the receiver circuit to the receive clock output.

Equalizer - The R24LL contains a fixed compromise delay equalizer which improves performance over the domestic switched network. The equalizer may optionally be positioned in the receiver or removed entirely by means of a jumper plug. It has a nominally flat 0.0 dB amplitude response.

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.

Receive Level-The R24LL receives line signals from 0 to - 43 dBm .

Transmit Timing-The R24LL generates a Transmit Clock with the following characteristics: Frequency- $2400 \mathrm{~Hz} \pm 0.01 \%$ ( $1200 \mathrm{~Hz} \pm 0.01 \%$ in fall back mode), duty cycle- $50 \pm 1 \%$. The R24LL can also optionally track an External Transmit Clock supplied by the user. Both have similar characteristics.

Receive Timing-The R24LL provides a data derived Receive Clock output in the form of a nominal squarewave ( $50 \pm 1 \%$ duty cycle). The timing recovery function can track $a \pm 0.01 \%$ frequency error in the associated transmit timing source.

Secondary Channel-The R24LL provides the user sufficient flexibility to add an external secondary channel if desired. (A secondary channel is a data transmission channel having a lower signalling rate and occupying a different portion of the telephone line bandwidth than the primary channel. The primary and secondary channels share the same transmission facility, the telephone line.) Additional receive filtering to allow simultaneous operation of the secondary channel must be provided external to the R24LL.

Transmit Level-The transmitted output line signal level of the modem is $-1.0 \mathrm{dBm} \pm 1.0 \mathrm{dBm}$ when the transmitter output is terminated with a 600 ohm resistor in series. This applies to all possible transmitted data patterns both at 2400 bps and 1200 bps, as well as to answering tone generation.

Answering Tone Generation-The R24LL can generate an answering tone at $2100 \mathrm{~Hz} \pm 0.01 \%$ or $2025 \mathrm{~Hz} \pm 0.01 \%$ (selectable) for $3.4 \pm 0.2$ seconds under the control of an input logic signal (CAUTO). The R24LL also provides a digital output (TONA) indicating the conclusion of answering tone generation.

New Sync-Pulsing the New Sync (NSYNC) digital input forces Carrier Detect Off and causes the R24LL to resynchronize rapidly on sequences of incoming messages. This feature is necessary in some polling applications because the receiver maintains the timing information of the previou's message for some time after it has ended-this may interfere with resynchronization on receipt of the next message from a different remote transmitter.

Fast Energy Detector-A received line signal detector, the fast energy detector's output (RLSD) has the same threshold and hysteresis characteristics as the Carrier Detect. For RLSD the maximum turn-on time is 1.6 ms and the maximum turn-off time is 6.6 ms (both times for Equalizer not inserted). Furthermore, the RLSD output will respond to transient line conditions (no momentary dropout or momentary-on glitch protection).

Baud Clocks-Symbol or baud timing is available for both the transmitter and receiver functions. These signals have characteristics similar to the data clocks' except that their frequency is equal to the signalling rate ( $1200 \mathrm{~Hz} \pm 0.01 \%$ ). Transitions on Transmitter Baud Clock and Receiver Baud Clock coincide with Off-to-On transitions of Transmit Clock and Receive Clock, respectively. For 2400 bps operation both baud clocks are low for the first data bit in a baud and high for the second data bit.

Analog Loopback-The R24LL provides the flexibility to implement a variety of analog loopback schemes using a minimum amount of external circuitry.

Eye Pattern/Data Quality Detector-The R24LL outputs digital signals (RCVDS, SYC, A) which the user can decode to generate a quadrature eye pattern. The eye pattern is a visual (oscilloscope) display showing the received signal as groupings of dots in the baseband signal plane. It is useful as an incoming modem test and product evaluation tool and as an indication of a line condition in actual operation (useful for some network control applications).

The modem also outputs digital signals (PE, SYC, A) which the user can decode to generate a data signal quality detector. This indicates if a reasonable probability of errors is received on the data channel.

## CONFIGURATIONS

The R24LL modem provides the user with a wide range of modem functional configurations. Some of the possibilities are described below.

Half-Duplex (2-Wire)-In a half-duplex application, the user needs both transmit and receive capabilities (although not simultaneously) on a 2-wire connection.

If a hybrid (4-wire $\rightarrow$ 2-wire) transformer is not employed as a line interface device, REC IN would be strapped to T1 through an external resistor, the user perhaps selecting this resistor to produce a specific output impedance or to compensate for losses in any line interface circuitry.

Digital interface connections. In a typical application, the user controls basic modem operation through the digital signals T103, T105, T106, T114, T104, T115, T109, and perhaps RBCK, T113, or TBC. (T113 is used if transmit timing is to be locked to the customer's clock; TBC may be employed to minimize certain timing delays and is useful in some multiplexing operations). A number of digital inputs can either be fixed (tied directly and permanently to the +5 V supply [high] or to signal ground or the -12 V supply [low] in accordance with the specific requirements) or, if the user desires programmable flexibility, these signals can be interfaced with his equipment. Signals of this type include T111, V26A, 1, S8GR, K, Y, TC06, 800MS, E, T2W/4W, CP04,

CP15, RW/4W, TH09, FSYC, TC09, and PBS. If answerback or echo suppression tone generation capability is required, the input CAUTO (which should be strapped low if not used) and the output TONA are available. Implementation of the New Sync function requires any new sync pulses to be inputted to NSYNC. The outputs SYC, RCVDS, DCP, A , and PE can be used to generate eye pattern and phase error diagnostic information.

Analog interface connections. The GAIN-G1-G2 jumper (for threshold set selection) should be in the proper location as described in the table at the top of page 9 . Note that input impedance at REC IN is a resistive 15.8 K ohms. If a 600 ohm receiver input impedance is desired, an external resistor to signal ground must be added. Take care when routing to REC IN (for low level receive signal) from any telephone interface circuitry. Also note that it is possible to insert the equalizer into the receiver or not to insert it by use of the jumper on the board. Implementation of a local analog loopback scheme could be achieved in many ways. If the line interface connection as shown in the diagram below is employed, the user can create a local analog loopback simply by deactivating squelch. To isolate the telephone line during this loopback (no transmitted line signal), additional circuitry must be added.

Full-Duplex-In a full-duplex application, the user needs both transmit and receive capabilities simultaneously. A 4-wire line connection is required.

The only differences with half-duplex are that REC IN is no longer connected to T1 (the transmitter and receiver have independent transmission paths) and the squelch function would be deactivated (except during New Sync) by use of the input T2W/ $4 W$.

Digital interface connection is the same as for the half-duplex.
Analog interface connections. With the exception of the 4 -wire line interface, analog interface connections are the same as half-duplex. Implementation of a variety of local or remote analog or digital loopback schemes requires the addition of a minimal amount of external circuitry.


## INTERFACE CRITERIA

The R24LL interface signals are classified as digital interchange signals and analog signals. The signals interface to the modem user through the board edge connector.

Digital Interchange Circuits-The characteristics of the R24LL digital inputs and outputs are given in the following charts:

| Input Logic State | Allowed Input Voltage Levels |
| :---: | :---: |
| Low High | $\begin{aligned} & -12 \mathrm{~V}\left(\mathrm{~V}_{\mathrm{DD}}\right) \text { to } 0.8 \mathrm{~V} \text { sinking }<10 \mu \mathrm{~A} \\ & +4.0 \mathrm{~V}\left(\mathrm{~V}_{\mathrm{Ss}}-1 \mathrm{~V}\right) \text { to }+5.0 \mathrm{~V}\left(\mathrm{~V}_{\mathrm{ss}}\right) \text { sourcing } \\ & <10 \mu \mathrm{~A} \end{aligned}$ |
| The digital inputs are directly CMOS compatible. The capacitive loading on each input is 25 pF (maximum). |  |


| Digital Output Characteristics |
| :--- |
| Output Logic State Allowed Output Voltage Levels <br> Low 0.0 V to $0.4 \mathrm{~V}(-0.4 \mathrm{~V}$ to +0.4 V for RLSD $)$ <br> sinking 0.36 mA <br> $+4.0 \mathrm{~V}\left(\mathrm{~V}_{\mathrm{ss}}-1 \mathrm{~V}\right)$ to $+5.0 \mathrm{~V}\left(\mathrm{~V}_{\mathrm{ss}}\right)$ sourcing <br> $100 \mu \mathrm{~A}$ <br> High The digital outputs are directly CMOS or low-power Schottky TLL <br> compatible. |


|  | Digital Interchange Circuits |  |
| :--- | :--- | :--- |
| Term | Pin <br> Number | Description |

compatible.


| DCP | P1-A21 | Digital output enabling user to <br> generate eye pattern and phase <br> error diagnostic information. |
| :--- | :--- | :--- |
| R2W/4W | P1-A22 | Input affecting state of THRH <br> output. |
| Receiver Baud Clock <br> (RBCK) | P1-A23 | For 2400 bps operation. |
| PBS |  |  |$\quad$ P1-A24 | Input determining T109 On-to-Off |
| :--- |
| response time. | generate eye pattern and phase error diagnostic information. nput affecting state of THRH output.

For 2400 bps operation. response time.
Input affecting state of THRH output. transmitted. cept data for transmission.

Input determining whether transmitted data rate is 2400 bps or 1200 bps.

P-A33 Output providing received signal element timing information.
P1-B6 Inputs affecting Clear-to-Send re-
sponse time and T109 Squelch. Input affecting Ready-for-Sending response time and answering tone frequency.

| Data Structure |  |  |
| :---: | :---: | :---: |
| Input |  | Data Structure |
| Data Signalling Rate Selector (P1-A32) | V26 A/B (P1-B19) |  |
| Low | Low | 2400 bps Alternate A |
| Low | High | 2400 bps V. 26 Alternate B (Bell 201C) |
| High | Don't Care | 1200 bps |


| Tone Generation |  |  |  |
| :---: | :---: | :---: | :---: |
| Inputs |  | Outputs |  |
| CAUTO | Y |  | TONA |
| (P1-A10) | (P1-B8) | (P1-A5) | Transmitted Signal |
| Low | Don't Care | High | Normal Operation |
| High | High | High | 2100 Hz Answering Tone |
| High | Low | High | 2025 Hz Answering Tone |
| High | Don't Care | Low | Normal Operation |

Selection of Clear-To-Send Response Times

| Turn-On Sequence | Inputs |  |  |  |  |  |  | Clear-To-Send Response Times (ms) |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | $\begin{gathered} \mathbf{Y} \\ (\mathrm{P} 1-\mathrm{B} 8) \end{gathered}$ | $\begin{aligned} & \text { 800MS } \\ & \text { (P1-A6) } \end{aligned}$ | $\begin{gathered} \mathrm{K} \\ (\mathrm{P} 1-\mathrm{A} 8) \end{gathered}$ | $\begin{gathered} \text { TC06 } \\ \text { (P1-A7) } \end{gathered}$ | $\begin{aligned} & \text { T2W/4W } \\ & \text { (P1-B7) } \end{aligned}$ | $\begin{gathered} \mathrm{I} \\ \text { (P1-B15) } \end{gathered}$ | $\begin{gathered} E \\ (\mathrm{P} 1-\mathrm{B6}) \end{gathered}$ | Off-to-On | On-to-Off |
| 1 | Low | High | Don't Care | Don't Care | High | Low | Don't Care | 6.67 | 0 |
| 2 | High | High | Low | High | High | Low | Don't Care | 8.33 | 0 |
| 3 | High | High | Low | Low | High | Low | Don't Care | 30 | 0 |
| 4 | High | High | Low | Don't Care | High | High | Don't Care | 30 | 0 |
| 5 | High | High | Don't Care | High | Low | Low | Low | 90 | 0 |
| 5 | High | High | High | High | High | Low | Don't Care | 90 | 0 |
| 6 | High | High | Don't Care | High | Low | High | Low | 90 | 0 |
| 6 | High | High | High | High | High | High | Don't Care | 90 | 0 |
| 7 | Low | High | Don't Care | Don't Care | Low | Low | Don't Care | 148.3 | 0 |
| 8 | Low | High | Don't Care | Don't Care | Don't Care | High | Don't Care | 148.3 | 0 |
| 9 | High | High | High | Low | Don't Care | Low | Don't Care | 220 | 0 |
| 9 | High | High | Don't Care | Don't Care | Low | Low | High | 220 | 0 |
| 9 | High | High | Don't Care | Low | Low | Low | Don't Care | 220 | 0 |
| 10 | High | High | High | Low | Don't Care | High | Don't Care | 220 | 0 |
| 10 | High | High | Don't Care | Don't Care | Low | High | - High | 220 | 0 |
| 10 | High | High | Don't Care | Low | Low | High | Don't Care | 220 | 0 |
| 11 | High | Low | Don't Care | Don't Care | Don't Care | Low | Don't Care | 220 | 0 |
| 12 | High | Low | Don't Care | Don't Care | Don't Care | High | Don't Care | 800 | 0 |

Carrier Detect Squelch

| Inputs |  |  |  |  | Squelch Status |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{gathered} \mathrm{X} \\ \text { (P1-A9) } \end{gathered}$ | $\begin{aligned} & \text { T2W/4W } \\ & \text { (P1-B7) } \end{aligned}$ | $\begin{gathered} \mathrm{E} \\ (\mathrm{P} 1-\mathrm{B} 6) \end{gathered}$ | T105 (P1-B30) | $\begin{aligned} & \text { NSYNC } \\ & \text { (P1-A13) } \end{aligned}$ |  |
| Don't Care <br> Don't Care <br> Low <br> High <br> High <br> High | Don't Care <br> High <br> Low <br> Low <br> Low <br> Low | Don't Care <br> Don't Care <br> Don't Care <br> Don't Care <br> High <br> Low | Don't Care <br> Don't Care <br> Don't Care <br> High <br> High $\rightarrow$ Low <br> High $\rightarrow$ Low | Low <br> High <br> High <br> High <br> High <br> High | Squelch <br> No Squelch <br> No Squelch <br> Squelch <br> Extended Squelch <br> No Extended Squelch |
|  | means that C low impedan <br> nded squelc flowing the | ect (T109) is und. For no <br> bled, squelc (High to Low) | Notes: off regardle ation (no sq <br> both when R of T105. | vel of rece AMP (T-13) <br> Send (T10 | uring squelch, CLAMP edance ("open drain") <br> and for $148.3 \mathrm{~ms}(+0.9$, |


| THRH | Gain Strap | Selected Threshold Set |
| :---: | :---: | :---: |
| High Impedance | G1 | $-43 \mathrm{dBm},-48 \mathrm{dBm}$ |
| High Impedance | G2 | $-33 \mathrm{dBm},-38 \mathrm{dBm}$ |
| Low impedance to ground | G1 or G2 | -26dBm, -31 dBm |
| Gain must be shorted to either G1 or G2. |  |  |

THRH Operation

| Input |  | THRH |
| :---: | :---: | :---: |
| TH09 | R2W/4W |  |
| Low | Low | High Impedance <br> High |
| Low <br> Low | High | High Impedance |
| High | High | Low Impedance |

Scrambler/Descrambler

| Input |  | Scrambler/Descrambler Configuration |
| :---: | :---: | :---: |
| $\begin{gathered} 1 \\ (\mathrm{P} 1-\mathrm{B} 15) \end{gathered}$ | $\begin{gathered} \text { S8GR } \\ \text { (P1-A19) } \end{gathered}$ |  |
| Low <br> High <br> High | Don't Care Low <br> High | No Scrambler <br> Scrambler V. 27 bis, ter (modulo 8 pattern guard) (no modulo 8 pattern guard) |

Analog Interface Circults-The analog interface circuits of the R24LL defined in the following chart provide the power, the switched network connections, and a means for the user to monitor the incoming line signals.

| Term | Pin Number | Description |
| :---: | :---: | :---: |
| $+12 \mathrm{~V}$ | P1-B5, B9 | +12V Power Supply |
| $-12 \mathrm{~V}$ | P1-A1 | -12V Power Supply |
| +5V | P1-A2, B2 | +5V Power Supply |
| COMMON | P1-A3, A31, B3 | Ground (signal and power return) |
| T1 | P1-A34 | T1 is the low impedance transmitter analog output (line signal). The $T 1$ allows the user the flexibility needed to customize his output impedance (to compensate for transformer losses, for instance). |
| SECONDARY IN | $\mathrm{P} 1-\mathrm{B} 4$ | Secondary channel input from the DTE. |
| REC IN | P1-B36 | Receive filter input. Input impedance is a resistive 15.8 $K$ ohms $\pm 1 \%$. |

Audio Interface-The audio interface includes the R24LL's interface with the transmission network.

The receiver and transmitter line interfaces are single-ended (non-transformer coupled) signals with the following characteristics:

## Transmitter Voice Frequency Output T1

1. Output Impedance: Impedance of Op-Amp
2. Maximum Output Level: $\leqslant 0.0 \mathrm{dBm}$ as measured per the following diagram using a true RMS meter.


## Receiver Voice Frequency Input REC IN

1. Input Impedance: 15.8 K ohms $\pm 1 \%$ resistive
2. Maximum Input Level: $\leqslant 0.0 \mathrm{dBm}$

The output level at the R24LL line interface is less than -60 dBm in the frequency band of 1 Hz to 12 Hz when the modem is not transmitting. A period of 100 milliseconds is required for the line interfaces to stablize following power turn-on.

Low impedance voice frequency output T1 satisfies applications interfacing with lossy transformers or hybrids. The characteristics of T1 output are:
a. Output Impedance: Essentially zero ohms when loaded to ground with greater than 400 ohms (resistive). This is a direct output from an operational amplifier.
b. Minimum Load: $\geqslant 400$ ohms (resistive) as measured between T1 and signal ground.

## PERFORMANCE DATA

The R24LL is a high performance synchronous 2400 bps DPSK modem. It utilizes a coherent demodulation technique to achieve reliable operation over the switched network or unconditioned lines.

Timing Jitter-The maximum steady state timing jitter of Received Clock with respect to Transmit Clock is less than 10\% $\mathrm{p}-\mathrm{p}$ for an input signal-to-noise ratio of 12 dB .

Bit Error Rate-The following graph represents typical R24LL performance.


1. $\mathbf{1 2 0 0}$ BPS, BACK-TO-BACK, SCRAMBLER, NO EQUALIZER
2. $\mathbf{2 4 0 0}$ BPS, V.26A OR B, BACK-TO-BACK, SCRAMBLER NO EQUALIZER
3. 2400 BPS, V.26A OR B, $15^{\circ}-150$ HZ PHASE JITTER, NO SCRAMBLER, NO EQUALIZER
4. 2400 BPS, V.26A OR B, $30^{\circ}-120 \mathrm{HZ}$ PHASE JITTER, NO SCRAMBLER, NO EQUALIZER
5. 2400 BPS, V.26A OR B, 3002 UNCONDITIONED LINE, NO SCRAMBLER, EQUALIZER

Typical Bit Error Rate Performance

Phase Error-Phase error can be measured with 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 and then directly correlated to bit error rate performance. The required test circuit can be implemented with discrete circuitry or in software within a microcomputer.

Eye Pattern-By using the modem's 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: it is a graphic representation of modem performance.


Phase error and eye pattern can be extremely useful for modem acceptance testing, product evaluation, and observation of line signal quality under actual operation.

## RECOMMENDED MATING CONNECTORS

The R24LL connector mating contacts are not gold covered; therefore, a high quality gas-tight card edge connector should always be used to maintain reliable operation. Rockwell recommends the following in order of preference:

1. Burndy GTBH Series
2. Continental 6100-200 Series
3. Elco 00-6307 Series

## POWER REQUIREMENTS

| Voltage | Ripple | Maximum <br> Current |
| :---: | :---: | :---: |
| +5 VDC $\pm 5 \%$ | $100 \mathrm{mV} \mathrm{p-p}$ | 102 mA |
| $+12 \mathrm{VDC} \pm 5 \%$ | $50 \mathrm{mV} \mathrm{p-p}$ | 64 mA |
| $-12 \mathrm{VDC} \pm 5 \%$ | 50 mV p-p | 142 mA |

## 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 $90 \%$ (non-condensing) or a wet bulb temperature up to $35^{\circ} \mathrm{C}$, whichever is less.
Altitude: - 200 to 10,000 feet ( -61 meters to 3,049 meters)

## 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 B/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 and 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 a complete receiver function.

Half Duplex (2-Wire):

Full Duplex (4-Wire):
Requires both transmit and receive functions simultaneously, again all three modules are used.

## FEATURES:

- LSI high density; low power
- 2400/1200 bps modes
- Transmitter-Differential phase shift keying
- 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
- LSTTL/CMOS 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.


10

R24 Integral Modem


R24 Functional Diagram

## TECHNICAL DESCRIPTION

Transmitter carrier frequency $-1800 \mathrm{~Hz} \pm 0.01 \%$

Echo suppression and answer tone frequencies -2100 Hz $\pm 0.01 \%$ or $2025 \mathrm{~Hz} \pm 0.01 \%$

Received signal frequency tolerance - The receiver 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 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 | $0^{\circ}$ |
| 01 | $+90^{\circ}$ | $+45^{\circ}$ |
| 11 | $+180^{\circ}$ | $+135^{\circ}$ |
| 10 | $+270^{\circ}$ | $+225^{\circ}$ |
|  |  | $+315^{\circ}$ |



## ALTERNATIVE B



At 1200 bps , differential two-phase modulation is used. Each bit is transmitted at a relative phase change to preceding signal element in acordance 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 Carrier 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 |
| Response Time tolerance ( $+0.9, \cdot 0.1$ ) msec |  |  |

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 threshold levels.

Set 1 (V. 26 bis, switched network)
Set 2 (V. 26 bis, switched network)
Set 3 (V.26, leased line)

Greater than $-43 \mathrm{dBm}=\mathrm{ON}$ Less than $-48 \mathrm{dBm}=$ OFF
Greater than $-33 \mathrm{dBm}=\mathrm{ON}$ Less than $-38 \mathrm{dBm}=$ OFF
Greater than $-26 \mathrm{dBm}=\mathrm{ON}$
Less than $-31 \mathrm{dBm}=$ OFF

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.

| Carrier Detect Transition | Response Time |
| :---: | :---: |
| OFF to ON (connection) | $\left.\begin{array}{r}6 \pm 1 \mathrm{~ms} \\ 14 \pm 1 \mathrm{~ms}\end{array}\right\}$ Selectable |
| ON to OFF (removal) | $\left.\begin{array}{r}8 \pm 3 \mathrm{~ms} \\ 22 \pm 3 \mathrm{~ms}\end{array}\right\}$ Selectable |

Receive Level - The modem receives line signals from 0 to -43 dBm .

Transmit Timing - The modem generates a Transmit Clock (T114) having the following characteristics: Frequency $2400 \mathrm{~Hz} \pm 0.1 \%$ ( $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 (T115) - 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 \mathrm{~dB}$ steps from $-1 \mathrm{dBm} \pm 1 \mathrm{~dB}$ to -15 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 lines. 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 data output.
2) Carrier Detect (T109) Clamp - This output may be clamped OFF (squelched) in a 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 (R1,R2). These diagrams are applicable for any operation mode of the modemsimplex, half-duplex, or full-duplex.


Figure 1. Transmitter Interfaces


Figure 2. Receiver Interconnection

## MODEM OPERATION - <br> 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, 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.


Figure 3. Transmitter-Receiver Interconnection (Half Duplex)

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:


## DTE - Data Terminal Equipment

The modem modules provide the user with all the necessary interfaces connections to implement almost any loopback scheme desired. With a minimum amount of external circuitry, loopback testing can be controlled via a communications adapter/software approach or manually. For local analog, remote analog and remote digital loopback, the V. 27 scrambler within the modem can be used to generate a 127 -bit word.

## INTERFACE DESCRIPTION

STANDARD DIGITAL INTERCHANGE

| $\begin{gathered} \text { Term } \\ \text { (CCITTV. } 24 \\ \text { Equivalent) } \end{gathered}$ | EIA RS232C Equivalent | $\frac{\text { Module }}{\text { Input }}$ | $\begin{aligned} & \text { nterface } \\ & \text { Output } \end{aligned}$ | Description |
| :---: | :---: | :---: | :---: | :---: |
| 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 (Transmitted Signal Element Timing) |
| T115 | DD |  | R2-6 | Receive Clock (Receive Signal Element Timing) |

ANALOG LINE INTERFACES

| Term | Module Interface <br> Input <br> Output |  |  |
| :---: | :---: | :--- | :--- |
| REC IN | R1-12 |  | Analog Line Signal Input (Receive Filter <br> Input) |
| T1 |  | T-1 | Low Impedance Transmitter Output <br> T2 |
| T-2 | Standard Transmitter Output 600 ohms <br> Impedance |  |  |

COMMON MODEM DIGITAL CONTROLS

| Term | Module Interface |  | Description |
| :---: | :---: | :---: | :---: |
|  | Input | Output |  |
| V26A | $\begin{gathered} \mathrm{T}-16 \\ \mathrm{R} 2-13 \end{gathered}$ |  | Selects V.26A or V.26B Dibit Encoding |
| I S8GR | $\begin{aligned} & \left\{\begin{array}{c} T-15 \\ R 2-12 \\ T-17 \\ R 2-14 \end{array}\right\} \end{aligned}$ |  | Controls for Scramble Operation |
| NSYNC | $\begin{gathered} \text { T-14 } \\ \text { R2-11 } \end{gathered}$ |  | Controls T109 to Force Rapid Resynchronization of the Receiver |
| CLAMP | R2-10 | T. 13 | Implements Squelch for Carrier Detect (T109) |

TRANSMITTER DIGITAL CONTROLS

| Term | Module Interface |  | Description |
| :---: | :---: | :---: | :---: |
|  | Input | Output |  |
| 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 |
| $\stackrel{\text { Y }}{\text { Y }}$ | T-26 |  |  |
| TC06 | T-27 |  |  |
| 800 MS | T-29 |  |  |
| E | T-30 |  |  |

TRANSMITTER ANALOG CONTROLS

| Term | Module Interface <br> Input |  | Output |
| :---: | :---: | :---: | :---: |$\quad$| Description |
| :--- |
| DAC OUT |

RECEIVER DIGITAL CONTROLS

| Term | Module Interface <br> Input |  | Output |
| :---: | :---: | :---: | :--- |$\quad$ Description

RECEIVER DIGITAL DIAGNOSTICS

|  | Module $\operatorname{lnterface~}$ |  |  |
| :---: | :---: | :---: | :---: |
| Term | Input | Output |  |
| SYC |  | Description |  |
| RCVDS | R2-1 | Digital Outputs which Enable User to |  |
| DCP | R2-2 | Generate Eye Pattern and Phase Error |  |
| A | R2-4 | Information |  |
| PE | R2-3 |  |  |


| Term | $\begin{gathered} \text { Module } \\ \hline \text { Input } \\ \hline \end{gathered}$ | $\begin{gathered} \text { Interface } \\ \hline \text { Output } \\ \hline \end{gathered}$ | Description |
| :---: | :---: | :---: | :---: |
| REC OUT | R1.7 |  | Receive Filter Ouput |
| $\begin{aligned} & \text { EQIN } \\ & \text { EQOUT } \end{aligned}$ | $\begin{aligned} & \text { R1•8 } \\ & \text { R1.6 } \end{aligned}$ |  | Equalizer Input Equalizer Output |
| RLSDIN AGCIN AGC OUT | $\begin{aligned} & \text { R1-5 } \\ & \text { R2.21 } \end{aligned}$ | R2-26 | Carrier Detect Circuitry Input Automatic Gain Control Circuitry Input 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 \%$ p-p for an input signal-to-noise 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 microcomputer.

Eye Pattern - By using the modems digital output signals RCVDC, 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 | $+5 \mathrm{Vdc} \pm 5 \%$ | 100 mV p-p | 38 mA |
|  | +12 Vdc $\pm 5 \%$ | 50 mV p-p | 16 mA |
|  | $-12 \mathrm{Vdc} \pm 5 \%$ | 50 mV p-p | 48 mA |
| R1 | +12 Vdc $\pm 5 \%$ | 50 mV p-p | 23 mA |
|  | $-12 \mathrm{Vdc} \pm 5 \%$ | 50 mV p-p | 16 mA |
| R2 | +5 Vdc $\pm 5 \%$ | 100 mV p-p | 64 mA |
|  | +12 Vdc $\pm 5 \%$ | 50 mV p-p | 25 mA |
|  | -12 Vdc $\pm 5 \%$ | 50 mV p-p | 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 | Allowed Input Voltage Levels |
| :---: | :---: |
| Low | -12.0 V to +0.8 V Sinking $<10 \mu \mathrm{~A}$ <br> High |

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 |

Digital outputs are directly CMOS or low-power Schottky TTL compatible.

## 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 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-transformer coupled) signals with the following characteristics:

Transmitter Output (Normal)
Output Impedance: 600 ohms $\pm 2 \%$
Maximum output level: $\leq 0.0 \mathrm{dBm}$
Transmitter Output (Alternate) Low Impedance:
Output Impedance: 0 ohms (op amp output)
Maximum output level $\leq+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


NOTE: This cross-section is common to all modules.


Transmitter Module Package


Receiver - R1 Module Package


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 <br> Low Profile <br> Socket | Connectors (SAE Series <br> 3000 or Methode Series 1000) <br> These Sockets are Wave <br> Soldered Into Standard <br> PCB Eyelets | Plug-in Capa- <br> bility at Low <br> Cost |
| PCB Plug-in <br> 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: -200 to 10,000 feet ( -6.1 meters to 3,049 meters)
Burn-In: 96 hours at $70^{\circ} \mathrm{C}$

## Ordering Information

When ordering, specify products as follows:
R24 - Set of 3 modules (T, R1, R2)
R24MEB - Modem Evaluation Board

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

## R24MEB <br> MODEM EVALUATION BOARD

## INTRODUCTION

To aid the user in the design phase of leased line modems, Rockwell has made available the R24 Modem Evaluation Board (MEB). The R24MEB is a convenient cost effective means for evaluation and design-in of the R24 2400 bps Integral Modem.

The Modem Evaluation Board is equipped with pin receptacles for mounting and interfacing the three R24 receiver and transmitter modules (R1, R2 and T). In addition to all interconnections being etched on the back of the board, the R24MEB also provides telephone coupling transformers, transient protection circuits, DIP switches (for option selection and gain control) and a DIP socket for jumper selection of the transmitter output level. A 31-pin edge connector (with Industry standard 0.125 inch contact centers) provides pin-in/pin-out, as well as power connections for analog and digital interface signals.

These features allow full control of the modem interface circuitry. Also, the complete R24 modem 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.

## FEATURES

- Convenient evaluation method of R24 Integral Modem modules
- Exercises all R24 Integral Modem features
- Easily integrated into a prorotype system
- Cost effective for low-volume applications
- Will serve as incoming test vehicle
- Standard board edge connector
- Pin receptacles for easy mounting/interfacing R24 modules (R, R2, T)
- Complete option select switches
- Transmitter output level strap selectable
- Backed by complete customer support documentation package


R24MEB Modem Evaluation Board


R24MEB Functional Diagram

## ORDERING INFORMATION

When ordering, specify products as follows:
R24MEB - Modem Evaluation Board R24 - Set of 3 modules (T, R1, R2)

Width: 5.875 in . $(14.923 \mathrm{~cm})$
Depth: $6.813 \mathrm{in} .(17.305 \mathrm{~cm})$ RDAA ROCKWELL DATA ACCESS ARRANGEMENT MODULE

## PRELIMINARY

## SECTION 1 - INTRODUCTION

This document is an aide to customers installing, operating and troubleshooting the Rockwell Data Access Arrangement (RDAA) Module designed and manufactured by Rockwell International.

## THE RDAA MODULE

The RDAA Module enables the modem user to make direct connections of their modems to the domestic switched telephone network. The RDAA is completely registered with the Federal Communications Commission under Rules Part 68. Therefore, no user re-registration of OEM data communication equipment is necessary when used with the RDAA. This means a definite cost-savings for the OEM equipment designer.

In addition to establishing your desired data transmission path, the RDAA also features an automatic answering function, line surge and hazardous voltage protection, switch hook status indication, ringing indication and automatic signal level control. Automatic dialing can be performed by pulsing the OH relay or by transmitting tone pairs.

FEATURES

- Pre-registered (under FCC Rules, Part 68) for direct connection to dial telephone network
- Integral Data Access Arrangement (DAA)
- Automatic dialing-pulse or tone
- Establishes data transmission path
- Automatic answering function
- Surge and hazardous voltage protection
- Switch hook status indication
- Ringing indication
- Automatic line signal output limiting
- Programmable or Permissive (strap selectable) connection arrangements
- Small size (approximately 3.95" by 3.94") ( 100 mm . by 100 mm .)


RDAA Module

The RDAA is easily incorporated into the users end product by either using the provided mounting holes, and/or using the cardguides without card-edge connector. The small size of the RDAA makes it ideal for piggyback type mounting.

The Rockwell RDAA printed circuit board is 3.94 inches (100 mm .) in width and 3.94 inches ( 100 mm .) in depth.

## SELECTABLE CONFIGURATIONS

As a prerequisite, telephone companies require that the signal level received at their local central office not exceed -12 dBm . Several different connection arrangements have been established (as documented in the FCC Rules, Part 68) to meet this requirement.

By jumper selection (Figure 1) the RDAA can be configured to operate in either the Programmable (PG) or Permissive (PM) connection arrangement. This is accomplished by placing the jumper in either the W2 or W1 locations for the desired mode. W1 jumper in, W2 jumper out for the permissive mode. W2 jumper in, W1 jumper out for the programmable mode.


Figure 1. RDAA Module Jumper Selection Location

When using the Programmable connection arrangement, the maximum signal level allowed to be transmitted across T and $R$ is set by a resistor installed by the telephone company in their wall jack (RJ45S or RJ41S) at the customer location. The resistor interacts with the RDAA through the leads PR and PC to program the maximum output level in one dB steps between -12 dBm and 0 dBm . Selection of the resistor from thirteen possible values is based on loop loss measurements performed by the telephone jack installer. The Programmable arrangement provides for the transmission of the maximum allowable amount of power. Therefore, this arrangement offers optimum performance over long loops.

When the Permissive connection arrangement is employed, the maximum signal output level across $T$ and $R$ is fixed at -9 dBm . The Permissive jacks (RJ11C) used for line connections are the same jacks used for standard voice installations. Therefore, this arrangement provides for greater mobility of user equipment.

## RDAA DIMENSIONS

The dimensions for the RDAA Module are given in Figure 2.

## MATING CONNECTORS

The mating connectors of the RDAA are as follows:

1. Two row (14 pins) ribbon type connectors $.1^{\prime \prime}$ spacing between pins.


Figure 2. RDAA Module Dimensions

## SECTION 2 - INTERFACE DESCRIPTION

## INTERFACE CIRCUIT DESCRIPTION

The following paragraphs describe in detail the RDAA interface circuits shown in the block diagram (Figure 3) and the interface circuits listing (Table 2-1).


Figure 3. RDAA Functional Block Diagram

Table 2-1. RDAA Interface Circuits

| Lead Designation | Signal Direction To: |  |  | Function |
| :---: | :---: | :---: | :---: | :---: |
|  | User | RDAA | Both |  |
| R, T MI, MIC PR, PC |  |  | $\begin{aligned} & \mathrm{X} \\ & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | Transmission leads for data signals. Leads to telephone set switch hook. Leads to programming resistor. |
| $+5 \mathrm{~V},+12 \mathrm{~V},-12 \mathrm{~V}$ |  | X |  | DC power required. |
| $\begin{gathered} \text { SG } \\ \text { RD/ } \\ \text { RCCT } \\ \text { OH } \\ \text { SH } \\ \text { CCT/ } \\ \text { TXA } \\ \text { RXA } \end{gathered}$ | $\begin{aligned} & x \\ & x \\ & x \\ & x \end{aligned}$ | $\begin{aligned} & x \\ & x \\ & x \end{aligned}$ | X | Signal ground required. <br> Ringing signal present indication. <br> To request data transmission path cut through. <br> To control Off-Hook relay. <br> Status of telephone set switch hook. <br> Transmission path cut through indication. <br> Lead to modem output. <br> Lead to modem input. |

## SG

The SG (Signal Ground) is the common reference for all modem interface signals.

## RD/

RD/ (Ring Detect) indicates to the user by an ON (Low) condition that a ringing signal is present. The RD/ signal will not respond to momentary bursts of ringing less than 125 ms in duration, or to less than 40 V rms, 15 to 68 Hz appearing across Tip and Ring with respect to ground. RD/ is also used to disable the transmission path. The electrical characteristics of the RD/ signal are shown in Table 2-2.

Table 2-2. Output Signals RD/ SH and CCT/ Characteristics

| Output <br> Logic State | Output Levels |
| :---: | :---: |
| LOW | 0.0 to 0.4 V while sinking $<1.6 \mathrm{ma}$ |
| HIGH | 2.4 to 5.0 V while sourcing $<40 \mu \mathrm{~A}$ |

## RCCT

RCCT (Request Coupler Cut-Through) is used to request that a data transmission path through the RDAA be connected to the telephone line. When RCCT goes OFF (Low), the cut-through buffers are disabled and CCT will go OFF (High) within 1 millisecond. RCCT must be OFF (Low) during dial pulsing but ON (High) for tone address signaling. The electrical characteristics of the RCCT signal are shown in Table 2-3.

Table 2-3. Input Signals RCCT and OH Characteristics

| Input <br> Logic State | Input Levels |
| :---: | :---: |
| OFF or LOW | 0.0 to 0.8 V , load current $\leqslant 0.36 \mathrm{ma}$ |
| ON or HIGH | RCCT $=2.0$ to 5.0 V , load current $\leqslant 20 \mu \mathrm{a}$ |
|  | $\mathrm{OH}=2.0 \mathrm{~V}$, load current $\leqslant 100 \mu \mathrm{a}$ |
|  | 5.0 V , load current $\leqslant 250 \mu \mathrm{a}$ |

## OH

OH controls the OFF-HOOK relay. Applying an ON (High) signal to OH closes the OH relay and establishes a DC path between T and R. Maximum delay between the ON signal to OH and the close of the OH relay is 10 ms . When originating a call, an ON (High) signal is used to request dial tone. After detecting dial tone, OH can be pulsed to generate the dial pulses corresponding to the number of the called station (see Section 4.2). On incoming calls, an ON (High) signal to the OH lead initiates the answering sequence (see Section 4.1). The characteristics of the OH signal is shown in Table 2-3.

NOTE
WARNING. If OH is asserted to a logic high before the incoming call ring signal is completed, the OH reed relay switch contacts may suffer degradation.

## SH

An ON (High) signal on the SH lead indicates to the user that the associated telephone (if used) is in the talk mode i.e., a contact closure exists between MI and MIC. The characteristics of the SH signal are shown in Table 2-2.

## CCT/

CCT/ is the Coupler Cut Through. An ON (Low) signal to the CCT/ lead indicates to the user that the data transmission path through the RDAA is connected. The ON (Low) state does not indicate the status of the telephone line or connection. The characteristics of the CCT/ signal are shown in Table 2-2.

## TXA

TXA (Transmit Analog) is the lead from modem transmitter output. This lead should be tied to GND when the modem is in the receive only mode.

## RXA

RXA (Receive Analog) is the lead to modem receiver input. This lead may be left open when the modem is in the transmit-only mode.

## POWER REQUIREMENTS

The following power must be provided at the RDAA interface.
A. $+12 \mathrm{VDC} \pm 5 \%$ @ 15 ma with a maximum ripple of 50 mv peak-to-peak
B. $+5 \mathrm{VDC} \pm 5 \%$ @ 20 ma with a maximum ripple of 100 mv peak-to-peak
C. $-12 \mathrm{VDC} \pm 5 \%$ @ 15 ma with a maximum ripple of 50 mv peak-to-peak.

## haZARDOUS VOLTAGE PROTECTION

Lightning induced surge voltages and other hazardous voltages are limited to 10.0 volts peak between the secondary leads of the coupling transformer T1. The isolation between the relay contacts and coils provides the protection of the telephone line from hazardous voltages appearing on any control lead.

## RING DETECTOR AND TIMER

When the Ring Detector detects the presence of a ringing signal ranging from 15.3 to 68 Hz with voltage levels of 40 to 150 VRMS across Tip and Ring (T and R) leads, after a delay of 125 ms to 500 ms , it will send an RD/ (Ring Detect) signal to the user's data terminal equipment (DTE). If the DTE is conditioned for answering, the DTE will return an ON signal on OH and RCCT. The OH signal closes the OH relay and starts a timer. The timer is used to provide a quiet interval of more than two seconds between the closing of OH relay and the connection of data transmission path. This allows the telephone company to properly engage their billing equipment. After this delay the CCT/ interface lead goes ON (Low) and data transmission may begin.

RD/ will go OFF (High) in less than 400 MSEC after the ringing signal is stopped. The ring detector is disabled when OH is ON (High) or SH is ON (High).

## SIGNAL LEVEL LIMITER AND GAIN CONTROL CIRCUITRY

The limiter monitors the signal level applied to the RDAA input lead TXA and is unaffected by the level of receive signal. When the applied signal amplitude becomes greater than +7 dBm for a period of 1.3 to 3 seconds, the transmission path is disconnected via the transmit and receive buffers, and the output signal CCT/ will go OFF (High).

## NOTE

The off-hook relay is not affected by the limiting function, therefore, so triggering the limiting function need not result in call termination.

Reducing the input signal amplitude to less than +7 dBm will reset the limiter in less than 4 milliseconds, restore the data transmission path, and cause the signal CCT to go ON (Low).

In order not to activate the limiter during normal operation, care must be taken to ensure that the maximum signal amplitude into the RDAA input TXA never exceeds +6 dBm . If the modem output has a tolerance of $\pm 1 \mathrm{~dB}$, then it is recommended to set the modem output to $+5 \mathrm{dBm}( \pm 1 \mathrm{~dB})$, so that the maximum signal amplitude into TXA is 6 dBm .

The output control circuitry contains a variable gain buffer which reduces the RDAA output to the maximum allowed level across T and R. When the RDAA is jumpered to operate in the Programmable mode, the resistor in the telephone company wall jack sets the output level to one of thirteen possible values. If the RDAA is jumpered to operate in the Permissive mode, then an internal resistor will set the output to a fixed value. The relationship between the RDAA input amplitude (in dBm) across TXA and GND and the nominal RDAA output level across $T$ and $R$ is given below:
A. For Programmable mode: output level across $T$ and $R=$ (input amplitude at TXA -7dB + (Programmed level set by wall jack resistor).
B. For Permissive mode: output level across $T$ and $R=$ (input amplitude at TXA) - 16 dB .

## IMPEDANCE SPECIFICATIONS

| On-Hook DC: | The DC resistance between $T$ and $R$, and between either $T$ or $R$ and signal ground are greater than 10 megohms for DC voltages up to 100 volts. |
| :---: | :---: |
| On-Hook AC: | The on-hook AC impedance measured between $T$ and $R$ is less than 40 K ohms ( 15.3 Hz minimum). |
| Off-Hook DC: | Less than 100 ohms. |
| Off-Hook AC: | 600 ohms nominal when measured between $T$ and $R$. |
| TXA and GND: | 2 megohms typical (operational amplifier voltage follower input impedance). |
| RXA and GND: | 75 ohms typical (operational amplifier voltage follower output impedance). |

## INSERTION LOSS

There is no insertion loss for the RDAA. The RDAA contains a receive buffer which compensates for transformer insertion loss. For this reason, additional receive buffering is not necessary.

## SECTION 3 - INSTALLATION/CHECKOUT

## RDAA CONNECTION TO TELEPHONE LINE

Connection of the telephone line interface pins of the RDAA to the network shall be made via standard jacks and plugs as shown in Figure 4. Cable color codes are also shown in Figure 4. A number of telephone line cord manufacturers produce the standard plugs and cables (Meyer Wire Co., Hamden, CT; Virginia Plastics, Roanoke, VA, etc.)

## TELEPHONE SET AND JACK ORDERING INFORMATION

If it is desirable to have manual call origination or alternate voice capability, an exclusion key telephone set may be ordered from a local telephone company. The telephone line may be transferred to the telephone set by lifting both the handset and the exclusion key, if the telephone is configured as Data Set Controls Line. This operation is for manual origination or alternate voice transfer (refer to paragraph 4.4 for manual origination procedure): A call may be terminated by replacing the handset in its cradle and taking OH low if OH is not already low.


Figure 4. Standard Jacks, Plugs and Cable Color Codes

The ringer of the telephone set may be disconnected by the telephone company to prevent the bell from ringing.

The telephone company provides an exclusion key telephone under the Universal Service Order Code (USOC) RTC. This telephone set has the following customer options:
A. A1-Telephone set controls line
B. A2 - Data set controls line
C. B3-Aural monitoring not provided
D. B4 - Aural monitoring provided (See Note 1)
E. C5 - Touch tone dial
F. C6-Rotary dial
G. D7-Switch hook indication
H. D8 - Voice mode indication only (See Note 2)

## NOTES

1. The aural monitoring feature allows the telephone handset to be used for listening to line signals without interfering with data transmission.
2. In this option the make contact of the exclusion key and a make contact on the switchhook are connected in series and to the mode indication leads MI and MIC of the data jack. Therefore, the SH signal of the RDAA goes ON only when the exclusion key is lifted.

When ordering this telephone, specify the USOC number RTC and the following options:
A. A2 - Data set controls line
B. B3-Aural monitoring not provided or B4-Aural monitoring provided
C. C5-Touch tone dial telephone (503C) or
C6 - Rotary dial telephone (2503C)
D. D8 - Voice mode indication only

Another telephone set provided by the telephone company is the Model 502 with exclusion key. To order this telephone set, specify the following:
A. Modem 502 with exclusion key
B. Data set controls line

A summary of the information for ordering telephone and jacks is given in Table 3-1. Examples of typical installation are given in Figure 3-2.

Table 3-1. Telephones and Jacks Ordering Information

| Output Configuration | Optional Telephone Set | FCC <br> Reg. No. | Ringer Equivalent | Telephone Jack USOC No. | Telephone Set USOC No. |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Programmable | With <br> Telephone Set <br> Without <br> Telephone Set <br> With <br> Telephone Set <br> Without <br> Telephone Set | AMQ9SQ <br> 67943 <br> DP-E <br> AMQ9SQ <br> 67943 <br> DP-E <br> AMQ9SQ <br> 67943 <br> DP-E <br> AMQ9SQ <br> 67943 <br> DP-E | .8B <br> .8B <br> .8B <br> .8B | ```\({ }^{1}\) RJ36X and \({ }^{2.3}\) RJ45S \({ }^{2.3}\) RJ45S \({ }^{1}\) RJ36X and RJ16X 'or \({ }^{4}\) RJA2X and RJ11C RJ11C``` | RTC or 502 with exclusion key <br> N.A. <br> RTC or 502 with exclusion key <br> N.A. |
| Notes: <br> 1. RJ36X is an 8 position miniature jack into which the telephone plugs. Rather than using an RJ36X jack, the telephone company may use connecting block to connect the telephone set and data jack to the telephone line. <br> 2. RJ41S is a universal data jack. It may be used for either Programmable or Fixed-Loss Loop mode. The RJ45S jack is preferred, because costs less. <br> 3. For multiple connections, the RJ45M jack should be ordered. The letter $M$ indicates multiple single line jack for up to 8 lines. Specify the number of lines required when ordering. <br> 4. RJA2X is the adapter shown in Figure 3-1. The use of the RJ36X and RJ16X jacks is recommended. |  |  |  |  |  |



Figure 5. Transmit and Receive (Half Duplex) and (Full Duplex)

## MODEM INTERFACE

There are 4 possible two-wire modes of operation configurations: receive-only, transmit-only, and receive and transmit (half duplex) and full-duplex (using two different frequencies simultaneously) as described below:
A. For the half-duplex and full-duplex configurations, the interface connection circuitry could be as shown in Figure 5.
B. For the receive-only configuration, the connection circuitry is the same as that shown in Figure 5, except that the RDAA input lead TXA is grounded rather than connected to the modem transmitter output.
C. For the transmit-only configuration, the RDAA lead RXA is left open rather than connected to the modem receiver as shown in Figure 5.

For a 4 -wire full-duplex configuration, 2 RDAA modules and 2 telephone lines are required. The connection circuitry consists of one 2 -wire receive-only connection, and one 2 -wire transmitonly connection.

## MODULE MOUNTING AND SECURING

The RDAA may be physically incorporated into the OEM's end product by using the four corner ( 0.156 inch diameter) mounting holes and self-locking plastic standoffs, or by bolting the RDAA module to a rigid structure. The RDAA module may also be mounted using card guides without card edge connector.

A number of manufacturers such as Richlock Corporation, Chicago, IL., produce plastic standoffs (Part Number CBS-3N).

## ELECTRICAL INTERFACE

Electrical connection to the RDAA module is made through ribbon type connectors. The connector(s) interface pins (Figure 2) are contained on the component side of the board. There are two test points brought out to the interface connector of the board. Therefore care must be taken to prevent shorting test points with any of the other interface signals.

The RDAA telephone line interface connector pins are physically separated from the RDAA DTE interface connector pins, as shown in Figure 2 and described in Table 3-2.

Table 3-2. RDAA Telephone and Modem Interface

| Type <br> Interface <br> Circuit | RDAA <br> Connectors/ <br> Pin No. | Interface <br> Circuit/Signal |
| :--- | :---: | :---: |
|  | P2-1 | CCT/ |
|  | P2-2 | RXA |
|  | P2-3 | TXA |
|  | P2-4 | OH |
|  | P2-5 | RCCT |
| DTE | P2-6 | RD/ |
| Interface | P2-7 | $-12 V$ |
| Connections | P2-8 | SH |
|  | P2-10 | GND |
|  |  | TP2 EXCESSIVE |
|  | P2-11 | POWER DETECT |
|  | P2-12 | $+12 V$ |
|  | P2-13 | $+5 V$ |
|  | P2-14 | N/U |
|  |  | TP1 BILLING |
|  | P1-4 | DELAY TIME |
|  | P1-3 | PC |
| Telephone | P1-1 | PR |
| Line | P1-2 | MIC |
| Interface | P1-(5-8) \& (11-12) | MI |
| Connections | P1-9, 10 | (Not Used) |
|  | P1-13, 14 | R |
|  |  | T |

Care must be taken in routing the telephone interface pins to the telephone jack. The FCC (Rules, Part 68) requires that the telephone interface leads shall be separated from the leads or metallic paths connecting to power connections.

## NOTE

Power connections are those connections between commercial power and any transformer, power supply rectifier, converter, or other circuitry associated with the RDAA. The connection of the interface pins (including the $\pm 12 \mathrm{~V}$ and +5 V ) shown in Figure 2 are not power connections.

The telephone interface leads shall not be routed in the same cable (or use the same connector) as leads or metallic paths connecting to commercial power.

FCC (Rules, Part 68) also requires that the telephone leads $T$ and $R$ be separated from metallic paths to leads connecting to non-registered equipment, when specification details provided to FCC do not show that the interface voltages are less than non-hazardous voltage source limits in Part 68. $T$ and $R$ shall not be routed in the same cable (or use adjacent pins on the same connector) as metallic paths to leads which are not considered non-hazardous. All DTE interface connector signals shown in Table 3-2 have been established as non-hazardous.

Therefore, in routing the telephone interface leads from the RDAA P1 connector to the telephone jack, the following precautions must be strictly adhered to. The telephone jack interface routing path should be as direct as possible. Any cable used in establishing this path should contain no signal leads other than possibly the (previously established as non-hazardous) DTE interface signals shown in Table 3-2. Any connector used in establishing this path should contain no commercial power source signal leads, and adjacent pins to the T and R (Tip and Ring) pins in any such connector should not be utilized by any signals other than possibly those shown in Table 3-2. Also the DTE interface routing path should be made as short as possible.

## INSTALLATION PROCEDURE

A. Check the telephone line interface cable(s) plug(s) and jack(s) (Figure 4). If the USOC RJ41S jack is used for the Programmable mode, ensure that the jumper W2 is installed and W1 jumper is removed for the programmable mode of operation.
B. Make sure the telephone company installer has measured the loop loss correctly and has selected the proper programming resistor in the RJ45S or RJ41S jack.

## NOTE

You have the right to know the method used by the installer for measuring loop loss and selecting the programming resistor.
C. Check the power supplies to see if they meet the proper requirements specified in paragraph 2.2.
D. Insert the telephone cable plug into the jack, and make the DTE interface connection. Then switch on the power supplie's.

## OPERATIONAL CHECKOUT PROCEDURE

The following procedures check out the RDAA in association with a modem, a data terminal, a telephone set and an automatic dialer. The telephone set is required only in the manual origination mode (refer to paragraph 4.4) or if alternate voice communication is desired. The automatic dialer is required oilly in the automatic dial mode (refer to paragraph 4.3).

## AUTOMATIC ANSWER MODE

A. Set the modem transmitted output level to +5 dBm .
B. Call the local modem from a remote station.
C. Follow the instructions given in Figure 6.
D. Transmit data from the local terminal to the remote terminal and monitor the CCT/ signal. It should stay low.
$E$. Terminate the call sequence and verify the received data.

## AUTOMATIC ORIGINATE MODE

A. Set the modem transmitted output level to +5 dBm .
B. Follow the procedure of Figure 8 for touch tone origination or Figure 7 for pulse dial origination.
C. Transmit data from the local terminal and monitor the CCT/ signal. It should stay low.
D. Terminate the call sequence and verify the received data.

## MANUAL OPERATION MODE

A. Set the modem transmitted output level to +5 dBm .
B. Follow the instructions given in paragraph 4.4.
C. Transmit data from the local terminal. CCT should stay low.
D. Terminate the call sequence and verify the received data.

## SPECIAL INSTRUCTIONS TO USER

Your Rockwell Data Access Arrangement has been registered with the Federal Communications Commission (FCC). To comply with the FCC regulations you are requested to observe the following:
A. All direct connections to the telephone lines shall be made through standard plugs and jacks as specified in Figure 4 and Table 3-1.
B. It is prohibited to connect the RDAA to pay telephones or party lines.
C. You are required to notify the local telephone company of the connection or disconnection of the RDAA, the make, the modem number, the FCC registration number, the ringer equivalence number (refer to Table 3-1) and the particular line to which the connection is made. If the proper jacks are not available, you must order the type of jacks to be used from the telephone company. (Refer to Table 3-1 for the proper jacks and telephones.)
D. You should disconnect the RDAA from the telephone line if it appears to be malfunctioning. If the RDAA needs repair, return it to Rockwell International. This applies to equipment both in and out of warranty. Do not attempt to repair the unit as this will violate the FCC rules.
E. The RDAA contains protective circuitry to prevent harmful voltages being transmitted to the telephone network. If however, such harmful voltages do occur, then the telephone company has the right to temporarily discontinue your service. In this case, the telephone company shall:

1. Promptly notify you of the discontinuance.
2. Afford you the opportunity to correct the situation that caused the discontinuance.
3. Inform you of your right to bring a complaint to the FCC concerning the discontinuance.
F. The telephone company also has the right to make changes in their facilities and services which may affect the operation of your equipment. However, you shall be given notice in writing by the telephone company adequate to allow you to maintain uninterrupted service.
G. Labeling Requirements:
4. The FCC requires that the following label be prominently displayed on an outside surface of the OEM's end product:

Unit contains Registered Protective Circuitry
which complies with Part 68 FCC Rules
FCC Registration Number:
Ringer Equivalence: . 8 B
2. The size of the label should be such that all the required information is legible without magnification.

## SECTION 4 - OPERATING INSTRUCTIONS

## AUTOMATIC ANSWER

The connection of the data transmission path for automatic answer is as described in paragraph 2.4. To disconnect the data transmission path, just turn off OH and/or DA, as shown in Figure 6.

*DA MAY BE ON PERMANENTLY FOR AUTOMATIC ANSWER.
Figure 6. Automatic Answering Sequence

## AUTOMATIC DIAL

## DIAL PULSE ORIGINATION

The DTE must provide the logic to turn ON the OH and DA leads, detect dial tone (or time for 3 seconds to ensure dial tone present), then turn OFF the DA lead and generate the dial pulses corresponding to the called number (Figure 7). The 2-second delay period between OH and DA going ON and the response of CCT going ON will not be invoked in the origination mode. The DTE should monitor for call progress indication (dial tone, busy tone, answer tone, and call intercept).

Requirements for proper call establishment exist on the pulse repetition rate ( 8 to 11 pulses per second), off duty cycle ( 60 percent nominal), interdigital delay timing ( 600 ms to 2 seconds) and chatter and spurious makes and breaks. The RDAA off-hook relay is a Reed relay designed to long life. Bell System requirements for pulse and touch-tone dialing are described in their Communications reference "Electrical Characteristics of Bell System Network Facilities at the Inter-


NOTES:

1. Dial tone detection is not provided within the rdaa. ALTERNATIVELY, DTE MAY START FROM, IDLE, TURN ON OH, THEN TIME FOR 3 SECONDS TO ENSURE DIAL TONE PRESENT AND PULSE OH FOR NUMBER.
2. DA MUST BE OFF DURING DIAL PULSING. DA MAY BE ON AT ALL OTHER TIMES
3. THE DA TO CCT RESPONSE TIME IS LESS THAN 1 Ms.
4. ANSWER TONE DETECTION CIRCUITRY IS NOT PROVIDED WITHIN THE RDAA.

Figure 7. Dial Pulse Origination Sequence
face with Voiceband Ancillary and Data Equipment" (PUB 47001).

The following is an example for pulse dialing the digit \#2 through the OH lead.


10

The OH lead can be pulsed directly via microprocessor port, or a commercially available "binary to dial pulse". LSI device such as the Rockwell CRC 8000, the General Instrument AY-5-9151 series, or the Motorola MC 14408. These devices can accept 4-bit binary digital inputs, buffer these digits, and output the OH dial pulses upon command. Also available from numerous semiconductor manufacturers '(National, Mostek, General Instrument, Motorola, etc.) are LSI devices capable of interfacing directly to a key board and producing suitable dial pulses.

## TOUCH-TONE ORIGINATION

The user's terminal must provide the logic to turn ON the OH and RCCT signals, detect the dial tone (or time for 3 seconds to ensure dial tone present) and transmit the tone-address signals via the TXA lead (Figure 8). The 2-second delay period between $\mathrm{OH}^{-1}$ and RCCT going ON and CCT/ going ON is not invoked in the origination mode. The DTE should monitor for call progress indications (dial tone, busy tone, answer tone, and call intercept).

It should be noted that tone address signaling method is significantly more complicated in terms of hardware requirements than simple pulse dialing. The necessary tone pair generators must be added by the user. A number of semiconductor manufacturers produce monolithic. LSI tone generators (AMI, Mostek, Motorola, National, General Instrument, Intersil, etc.). These tone pair generators are designed to interface with keyboards or digital ports and may require varying degrees of additional low pass filtering to reduce harmonic distortion. Touch-tone dialing is significantly faster than pulse dialing, but it may not be available in some locations.


Figure 8. Touch-Tone Origination Sequence

Bell System requirements exist on minimum and maximum tone pair transmit power for proper call address signaling. When the RDAA is in the programmable mode, the gain of the RDAA transmit leg is set by a programming resistor in the telephone jack (over thirteen possible values). This makes establishment of the tone pair signal level to be input to the RDAA (at TXA) which meets the Bell System requirements difficult. It is therefore necessary to operate the RDAA in the Permissive mode for touch-tone origination. In this event the proper input power level (per frequency pair) to the RDAA (at TXA) would be +15 dBM (nominal). This level is well above the RDAA automatic limiter threshold. But the RDAA limiter activates (cuts off transmission path) only if threshold power level is continuously exceeded for about one second minimum, and quickly resets itself if the power level drops below threshold, If the tone pair duration time is restricted to significantly under one second (the minimum duration requirement is only 50 milliseconds) and the minimum interdigital time requirement ( 45 milliseconds) is observed, the limiter will not be activated. These requirements are easily met if the tone pair generation is under logic control. If the generation is controlled via keyboard input, the limiter will be activated if a key is depressed and held for more than a second, but will recover during the interval between key closures. However, the possibility exists that transients occurring at limiter activation and resetting may endanger proper call origination.

## AUTOMATIC CALLING UNIT

Automatic dialing capability may also be added to a data transmission system simply by purchasing or leasing a separate box termed an "Automatic Calling Unit" (ACU). Such units are available from a variety of manufacturers. ACU's are available utilizing pulse or tone dialing. Connections of $A C U$ to the data transmission system may be different for different ACUs. The standard protocol involved in interfacing between the user's data terminal equipment and an ACU is documented in CCITT Recommendation V. 25 and also in EIA Standard RS-366. "Interface Between Data Terminal Equipment and Automatic Calling Equipment for Data Communication." It should be reemphasized that a separate ACU is not necessarily required for automatic dial capability. The RDAA and some external hardware and/or software (as previously described) can suffice.

## MANUAL ORIGINATION

For manual origination a telephone set with an exclusion key must be ordered from the local telephone company (refer to Table 3-1). After lifting both the handset and the exclusion key, a call may be originated or answered in the same manner as normal telephone service. When the handset and the exclusion key are lifted (MI is shorted to MIC), the signal SH is turned ON. If the user's data terminal is ready, it may respond with OH and RCCT. The RDAA will then turn ON the CCT/ signal. When answer tone is heard, the operator replaces the handset in its cradle. the SH signal will go Low and the data transmission path is connected. When data transmission is completed, the terminal turns OFF the OH signal and returns to the idle state.

## SECTION 5 - FAULT ISOLATION

## CUSTOMER REPAIR LIMITATIONS

Under the FCC Rules, no customer is authorized to repair an RDAA module. In the event of an RDAA malfunction, return the faulty RDAA to Rockwell International. It is recommended that the following fault isolation instructions provided in this section be performed prior to returning a suspected RDAA module. A periodic check of the DC power supplies is aiso recommended.

## FAULT ISOLATION

The fault isolation flow chart (Figure 9) has been prepared specifically as an aid to the user for locating possible network and/ or RDAA module malfunctions.


Figure 9. RDAA Fault Isolation Flow Chart

## 保

## SECTION 11 <br> T-1 AND T-1/CEPT PULSE CODE MODULATION PROTOCOL DEVICES

Page
Product Family Overview ..... 11-2
R8040 Tri-Port Memory ..... 11-3
R8050 T-1 Serial Transmitter ..... 11-9
R8060 T-1 Serial Receiver ..... 11-17
R8070 T-1/CEPT Pulse Code Modulation Transceiver ..... 11-23

# T-1 AND T-1/CEPT PCM (PULSE CODE MODULATION) PROTOCOL DEVICES Meet AT\&T and CCITT Standards 

Rockwell International is the first company producing LSI devices for supporting the commercial digital switched network. The 24 or 32 digitized channels meet AT\&T and CCITT standards.
This means it is now possible to design T-1/CEPT systems using LSI instead of discrete devices. This results in a much lower parts count, lower power requirements, smaller size and significant cost reductions. It also means an increase in reliability.

Using our LSI devices, the 24 or 32 channels of 64 K bps information and signaling are multiplexed over a single pair of wires. All data are transmitted serially, along with framing bits, at 1.544 to 2.048 M bps. At the receiving end frame, superframe, and channel synchronization is accomplished,
with signaling information outputted and the 24 or 32 channels uniquely identifiable.
Transmission in digital format instead of analog has inherent ability to perfectly regenerate the signal even after noise in the phone network. The TTL compatible devices operate from a single 5 V power supply.
For specialized memory for digital PBX and other telecommunication applications, tri-port memory devices are also available. These allow random read and sequential read simultaneously, and, allow addressing sequentially or randomly. They support either time or space division switching as well as elastic storage applications when transmission and write speeds differ.

Rockwell LSI Devices Provide-- Parts Count Reduction

- Cabling Reduction
- Cost Reduction
- Increased Reliability
- Increased Performance


# R8040 <br> 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 1 state, WSEL selects the internal 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{\mathrm{RST}}$ has been set to logic 0 when the positive transition of SCLK occurs.

The Sequential Read Enable signal, $\overline{\text { SRE }}$, enables sequentiallyaddressed read operations. If $\overline{\text { 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 SRE. The sequential read data will cease to be valid 100 ns after the negative transition of SRE or 20 ns after the next positive transition of SCLK, becoming valid with the content of the next sequential location within 430 ns of that SCLK transition.

The Random Read Enable signal, $\overline{R R E}$, enables randomaccessed read operations. If 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 RRE is logic 1, and 300 ns have elapsed since the random address lines have stabilized, the random accessed data outputs will

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


## APPLICATIONS

Time-division Multiplex (TDM) digital switching data and control stores

- TDM sequential machines
- Elastic stores
- Hardware/Software control interfaces
- I/O Buffers

Pin Configuration
become valid 80 ns after the negative transition of $\overline{\operatorname{RRE}}$. The random accessed data outputs will cease to be valid 100 ns after a positive transition of RRE or 20 ns after the random address input lines change, becoming valid with the contents of the newly-addressed location within 380 ns after the random address inputs have stabilized.

In the case of a same location read/write cycle, the sequential and/or random data outputs will cease to be valid after a negative transition of WE, and will become valid with the newly-written contents within 340 ns of that transition. Control of this parameter minimizes external circuitry required for resolution of read-write contention.

## RECOMMENDED OPERATING CONDITIONS

| Signal | Setup |  | Hold |  |
| :---: | :---: | :---: | :---: | :---: |
|  | Measure to | ns | Measure to | ns |
| SCLK $\dagger$ | WE ! | - 300 | WE $\dagger$ | 0 |
| WSEL | WE $\downarrow$ | 280 | WE $\uparrow$ | 0 |
| R01-R32 | WE $\downarrow$ | 250 | $\overline{W E} \uparrow$ | $=0$ |
| A.H | WE $\uparrow$ | 150 | WE $\uparrow$ | 100 |
| RST | SCLK $\downarrow$ | 180 | SCLK $\dagger$ | 0 |

Minimum Pulse Widths

| Signal | Minimum Pulse Width |
| :---: | :---: |
| $\overline{\text { WE }(=0)}$ | 170 ns |
| SCLK | 220 ns |

SEQUENTIAL COUNTER RESET SETUP AND HOLD TIMING


READ OUTPUTS AT SAME LOCATION AS WRITE
(ALL OTHER INPUTS STABLE)


NOTE: RANDOM WRITE ALWAYS AFFECTS RANDOM READ OUTPUTS; SEQUENTIAL WRITE ALWAYS AFFECTS SEQUENTIAL READ OUTPUTS. EITHER WRITE WILL AFFECT THE OPPOSITE READ OUTPUT. IF, AND ONLY IF, THE RANDOM ADDRESS AND SEQUENTIAL ADDRESS ARE EQUAL.

WRITE SETUP AND HOLD TIMING


RANDOM READ ( $\overline{\operatorname{RRE}}=0, \overline{\mathrm{WE}}=1)$


SEQUENTIAL READ $(\overline{S R E}=0, \overline{W E}=1)$


READ PORT ENABLE/DISABLE (ADDRESS STABLE, $\overline{\mathrm{WE}}=1$ )


Propagation Delays



## MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{DD}}$ | +4.75 to +5.25 | V |
| Operating Temperature | $\mathrm{T}_{\text {OP }}$ | 0 to +70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

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

## ELECTRICAL CHARACTERISTICS

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

| Parameter | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Input Logic "1" Voitage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 |  | V |
| Input Logic " 0 " Voltage | $\mathrm{V}_{\mathrm{IL}}$ |  | 0.8 | V |
| Input Logic "1" Voltage | $\mathrm{V}_{\mathrm{OL}}$ | 2.4 |  | V |
| Output Logic ' 0 " Voltage | $\mathrm{V}_{\mathrm{OL}}$ |  | 0.4 | V |
| Output Source Current | $\mathrm{IOH}^{\text {O }}$ | -100 |  | $\mu \mathrm{A}$ |
| Output Sink Current | $\mathrm{IOL}^{\text {L }}$ | 400 |  | $\mu \mathrm{A}$ |
| Input Capacitance | $\mathrm{C}_{1}$ |  | 5 | pF |
| Output Capacitance | $\mathrm{C}_{0}$ |  | 25 | pF |
| Power Dissipation (at $25^{\circ} \mathrm{C}$ ) | $\mathrm{P}_{\text {DS }}$ |  | 300 | mW |

## PACKAGE DIMENSIONS



NOTE: Pin No. 1 is in lower left corner when symbolization is in normal orientation

# R8050 T-1 SERIAL TRANSMITTER 

## 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 $\left(F_{\mathrm{s}}\right)$ modification method.

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 8th 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 to be transmitted as a "one" if the channel data sample is all "zeros." Input INH provides a means to inhibit the zero channel monitor function. Input B7OPTN controls the particulars of the insertion method.

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 Conflguration

## FEATURES

- Single 5V supply, low power Schottky TTL compatible.
- Accepts 8 bits of parallel data as input.
- Generates output as 193 bit serial data stream in T-1, D2, D3 or D4 Mode 3 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.


## T-1 TRANSMITTER INPUTS

Any input $\leqslant 0.8 \mathrm{~V}=$ logic 0 , low. Any input $\geqslant 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.


Figure 1. T-1 Serial Transmitter

## FRSYNC: Frame Synchronization

Frame sync allows external synchronization of the transmitter's internal frame counter. When FRSYNC becomes high, the frame counter is directly set to frame 1 , the first of the twelve frames. If FRSYNC is held high and does not return to zero before a rising edge of CLOCK, the subsequent states of BINOUT, UNPLRA and UNPLRB are high, high and low, respectively, regardless of the states of any other inputs. The latter mechanism is useful for device and/ or board testing only and will cause bit errors and/or bipolar violations if used during field operations. See Figures 6 and 7.

## SYNCIN: Synchronization Input

SYNCIN allows external synchronization of the internal Modulo 193 bit/channel counter. When SYNCIN becomes high, the Modulo 193 counter is directly set to the state corresponding to the output of the framing ( $F_{T}$ or $F_{S}$ ) bit. The first bit of channel one will be output on BINOUT (and UNPLRA or UNPLRB) as a result of the first rising edge of CLOCK following the return of SYNCIN to logic 0 . See Figures 5 and 7.

## 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 $=275$ ns
The $\mathrm{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 channels in signalling frames (6 or 12) in which the first six data bits and the signalling highway are all "zero," BIT 7 will be forced to one if INH is low. For any frame except a signalling frame Bit 8 or Bit 7 as selected by B7OPTN will be transmitted as a "one" if the channel input data is "zero" and $\mathbb{N H}$ is low.

## BITS 1-8: Parallel 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 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 Figure 4.

## BCH: "B" Channel Highway Signalling

BCH allows the user to transmit 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{F}_{\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 transmitting as a zero. This is commonly called remote alarm signalling. ALARM is clocked into the input register at 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, while BINOUT continues to provide normal data outputs. Refer to Figure 3.

## CCIS: Common Channel Interoffice Signalling Strap

Provides optional control for replacing the automatic $F_{S}$ pattern with a 4 -kilobit common channel signalling path. When CCIS is high, the SBIT input replaces the $F_{S}$ pattern and the insertion of ACH and BCH is suspended. The CCIS input may also be used to provide the alternate method of alarm reporting. See Figure 4.

## B7OPTN: 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

$V_{D D}=+5 \pm 0.25 \mathrm{Vdc}$
$\mathrm{V}_{\mathrm{ss}}=$ Ground, 0 Vdc

## T-1 Transmitter Outputs

Low power TTL Schottky compatible. " 1 " $\geqslant 2.4 \mathrm{Vdc}$, " 0 " $\leqslant$ $0.4 \mathrm{Vdc}, \mathrm{CMOS}-12 \mathrm{~K} \Omega$ pullup to $\mathrm{V}_{\mathrm{DD}}$ required.

## SSTB: 4 kHz 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 $\left(F_{T}\right)$ is serially transmitted, and will return low as each multiframe alignment signal $\left(F_{s}\right)$ 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. SYNOUT is the only output determined by the falling edge of CLOCK.

## 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 foliows Tables 1 and 2.

BINOUT is synchronously transmitted as a high level if FRSYNC remains high during the rising edge of CLOCK. Refer to Figures 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 Channel Sample Output Data Truth Table

| Inputs $\mathrm{X}=$ don't care |  |  |  |  |  |  |  |  |  |  |  |  | Current <br> Frame Number | Binout Serial Output <br> Channel Bit Position |  |  |  |  |  |  |  | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & \frac{\Sigma}{x} \\ & \frac{1}{4} \end{aligned}$ | 플 | $\begin{aligned} & z \\ & \mathbf{z} \\ & 0 \\ & 0 \\ & \hline 0 \end{aligned}$ | $\stackrel{\Sigma}{\bar{\omega}}$ | $\stackrel{N}{\mathbf{N}}$ | $\stackrel{m}{\infty}$ | $\stackrel{\rightharpoonup}{\mathbf{D}}$ | $\stackrel{n}{\frac{1}{\infty}}$ | $\stackrel{\circ}{\stackrel{6}{\omega}}$ | $\stackrel{N}{\text { © }}$ | $\stackrel{\infty}{\stackrel{5}{\infty}}$ | 工 | $\begin{aligned} & \text { I } \\ & \text { O } \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 |  |
| 1 | x | $x$ | x | $x$ | x | x | $x$ | x | x | $x$ | $x$ | $x$ | X | X | 0 | $x$ | $x$ | x | $x$ | x | $x$ | 1 |
| x | $x$ | $x$ | x | 0 | $x$ | x | $x$ | x | $x$ | X | X | X | X | X | 0 | X | X | X | X | X | X | 1 |
| 0 | x | X | P | Q | $R$ | S | $T$ | U | V | x | A | X | 6 | P | Q | R | S | T | U | $v$ | A | 2 |
| 0 | x | X | P | Q | R | S | T | U | V | X | X | B | 12 | P | Q | R | 5 | T | U | V | B | 2 |
| 0 | X | X | P | Q | R | S | T | $\cup$ | V | W | X | X | Y | P | Q | R | S | T | U | V | W | 2,3 |
| 0 | 1 | X | 0 | 0 | 0 | 0 | 0 | 0 | 0 | x | A | X | 6 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | A |  |
| 0 | 1 | x | 0 | 0 | 0 | 0 | 0 | 0 | 0 | X | x | B | 12 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | B |  |
| 0 | 1 | X | 0 | 0 | 0 | 0 | 0 | 0 | 0 | w | X | x | $Y$ | 0 | 0 | 0 | 0 | 0 | 0 | 0 | W | 3 |
| 0 | 0 | X | 0 | 0 | 0 | 0 | 0 | 0 | 0 | x | 0 | X | 6 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |  |
| 0 | 0 | x | 0 | 0 | 0 | 0 | 0 | 0 | 0 | x | x | 0 | 12 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |  |
| 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | X | X | $Y$ | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 3 |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | X | X | Y | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 3 |

NOTES: (1) ALARM $=1$ has the same effect as BIT $2=0$
(2) $\mathrm{P}, \mathrm{Q}, \mathrm{R}, \mathrm{S}, \mathrm{T}, \mathrm{U}$ and V may not simultaneously be zero, unles $\mathrm{A}, \mathrm{B}$ or W is 1
(3) $Y$ is any frame $\neq 6$ and $\neq 12$ with $\mathrm{CCIS}=0$, or all frames with $\mathrm{CCIS}=1$

Table 2. Framing Bit ( $F_{T}$ \& $F_{S}$ ) Output Data

| Frame <br> Number | Processed <br> Bit | Binout |  |
| :---: | :---: | :---: | :---: |
|  |  | $F_{T}$ | $\mathbf{C C I S}=\mathbf{0}$ |
| 1 | $F_{S}$ | 0 | $\mathbf{C C I S}=\mathbf{1}$ |
| 2 | $F_{T}$ | 0 | SBIT |
| 3 | $F_{S}$ | 0 | 0 |
| 4 | $F_{T}$ | 1 | SBIT |
| 5 | $F_{S}$ | 1 | 1 |
| 6 | $F_{T}$ | 0 | SBIT |
| 7 | $F_{S}$ | 1 | 0 |
| 8 | $F_{T}$ | 1 | SBIT |
| 9 | $F_{S}$ | 1 | 1 |
| 10 | $F_{T}$ | 0 | SBIT |
| 11 | $F_{S}$ | $0($ NOTE 1$)$ | 0 |
| 12 |  |  | SBIT |

Notes: (1) Alternate remote alarm reporting may be accomplished by holding SBIT and CCIS both high just prior to initiation of Frame 12.
(2) $F_{T}$ bit insertion is automatic and no optional control is provided.


Figure 2. Transmitter Input-Output Signal Relationships


Figure 3. Transmitter Binary, Unipolar Outputs


Figure 4 (a). Channel Input Timing


Figure 4 (b). LOOP Input Timing


NOTE: CCIS WAVEFORM SHOWN FOR ALTERNATE ALARM REPORTING METHOD. CCIS SHOULD BE ACTIVE JUST PRIOR TO FRAME 12. UNDER THESE CONDITIONS, SBIT HIGH WOULD REPORT THE REMOTE ALARM.

Figure 4 (c). Control Input Timing


Figure 5. SYNCIN Timing Relationship


Figure 6. Non-return-to-zero FRSYNC Timing


Figure 7. Transmitter External Synchronization (Return-to-zero FRSYNC)

## Table 3. Input Timing

|  |  | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{1}$ | Buffered Data Setup Time | 450 |  | ns |
| $t_{1+}$ | Buffered Data Hold Time | 0 |  | ns |
| $\mathrm{t}_{2 \mathrm{~S}}$ | Control Input Setup Time | 400 |  | ns |
| $\mathrm{t}_{2 \mathrm{H}}$ | Control Input Hold Time | 20 |  | ns |
| $\mathrm{t}_{3}$ | Asynchronous Control Input Setup Time | 350 |  | ns |
| $\mathrm{t}_{3 \mathrm{H}}$ | Asynchronous Control Input Hold Time | 20 |  | ns |
| $\mathrm{t}_{4 \mathrm{~S}}$ | SYNCIN Setup Time | 200 |  | ns |
| $\mathrm{t}_{4 \mathrm{H}}$ | SYNCIN Hold Time | 20 |  | ns |
|  | SYNCIN Pulse Width | 100 |  | ns |
| $\mathrm{t}_{5 s}$ | Frame Sync Setup Time (Return to Zero) | 250 |  | ns |
| $\mathrm{t}_{5 \mathrm{H}}$ | Frame Sync Hold Time (Return to Zero) | 20 |  | ns |
|  | Frame Sync Pulse Width | 200 |  | ns |
| $\mathrm{t}_{5 S}$ | Frame Sync Setup Time (Non-Return to Zero) | 525 |  | ns |
| $\mathrm{t}_{5 \mathrm{H}}$ | Frame Sync Hold Time (Non-Return to Zero) | 20 |  | ns |

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 |

## MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{DD}}$ | +4.75 to +5.25 | Vdc |
| Operating Temperature | $\mathrm{T}_{\mathrm{OP}}$ | 0 to 70 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature | $\mathrm{T}_{\text {STG }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

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

## ELECTRICAL CHARACTERISTICS

$\left(V_{D D}=5.0 \pm 5 \%\right)$

| Parameter | Symbol | Min | Max | Unit |
| :--- | :--- | :---: | :---: | :---: |
| Logical "1" Input Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.0 | $\mathrm{~V}_{\mathrm{DD}}+0.3$ | V |
| Logicical " 0 " Input Voltage | $\mathrm{V}_{\mathrm{L}}$ | -0.3 | 0.8 | V |
| Logicical "1" Output Voltage | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | V |
| Logic " 0 " Output Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | V |
| Output Source Current | $\mathrm{I}_{\mathrm{OH}}$ | -100 | - | $\mu \mathrm{A}$ |
| Output Sink Current | $\mathrm{I}_{\mathrm{OL}}$ | 400 | - | $\mu \mathrm{A}$ |
| Capacitance Load (any output) | C | - | 25 | pF |
| Input Capacitance (any input) | $\mathrm{C}_{\mathrm{IN}}$ | - | 5 | pF |
| Clock Frequency |  | - | 1.6 | MHz |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | - | 250 | mW |

## PACKAGE DIMENSIONS



## 0 Rockwell

# R8060 and R8060A <br> T-1 SERIAL RECEIVER 

## DESCRIPTION

The Rockwell 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 ( FT ) 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 yield "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, with 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
$\mathrm{VDD}=+5.0 \pm 0.25 \mathrm{VDC}$
VSS $=$ Ground, 0 VDC

## T-1 RECEIVER OUTPUTS

[^22]
## 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 high 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.

## CHCLK - CHANNEL CLOCK

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. $\overline{\text { 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 $\mathbf{3 8 6}$ MODULUS

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

## 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 1X001 (left to right, as received), 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. 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 the 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 chaninel 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 level 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 two-frame period CHCLK, CHSYNC, and WIHBT are held 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


Figure 3. Signal Relationships at Beginning of Fs Frame (S-BIT)


Figure 4. Signal Relationship at Beginning of FT 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 |



## MAXIMUM RATINGS*

| Parameter | Symbol | Value | 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}_{\mathrm{STG}}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

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

## ELECTRICAL CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{DD}}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\right)$

| Parameter | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Input Logic " 1 " Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.0 | $V_{D D}+0.3$ | V |
| Input Logic ' 0 ' ' Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | 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 | $\mathrm{IOH}^{\text {O}}$ | -100 |  | $\mu \mathrm{A}$ |
| Output Sink Current | 1 OL | 400 |  | $\mu \mathrm{A}$ |
| Clock Frequency | $\mathrm{T}_{\text {cLK }}$ |  | 1.85 | MHz |
| Input Capacitance | $\mathrm{C}_{1}$ |  | 5 | pF |
| Output Capacitance | $\mathrm{C}_{0}$ |  | 25 | pF |
| Power Dissipation | $\mathrm{P}_{\text {DSS }}$ |  | 550 | mW |

# R8070 <br> T-1/CEPT PCM TRANSCEIVER 

## PRELIMINARY

## INTRODUCTION

The R8070 T-1/CEPT Transceiver is a new generation PCM (Pulse Code Modulation) protocol device designed and manufactured by Rockwell International. The new device utilizes CMOS technology providing a higher level of component integration than its predecessors; low power dissipation and many features and capabilities. The device is designed to meet AT\&T and CCITT specifications, including EXTENDED FRAME and CLEAR CHANNEL and/or CEPT applications using T-1, T-1C or CEPT specifications.

Product availability of R8070 T-1/CEPT PCM Transceiver is Winter, 1984.


R8070 T-1/CEPT PCM Transceiver

## FEATURES

- PCM format transceiver (transmitter and receiver in one chip)
- CMOS technology design
- 5-volt single supply voltage
- 64-pin QUIP package
- Meets CCITT G. 732 , G. 733 and G. 703 (applicable parts) specifications, and AT\&T advisories
- Operates with EXTENDED FRAMING, CLEAR CHANNEL and/or CEPT formats
- Uses a clock of 1.544 (T-1), 1.576 ( $1 / 2 \mathrm{~T}-1 \mathrm{C}$ ), or 2.048 (CEPT) MHz depending on operation mode
- Supports multiplex/demultiplex T-1C, mode 1 (synchronous) operation
- Formats data to be serially transmitted/received according to CCITT and AT\&T specifications
- Mode Selectable - provides 17 different data format and zero suppression mode combinations
- Selectable serial or parallel digital data interface
- Provides status and alarm information to peripheral equipments for control and status reporting
- Allows external synchronization of the transmitter's internal circuitry
- Generates signals for external processing of data
- Interfaces between multiplexed digital signals and the PCM highway


## APPLICATIONS

- Channel Banks - add signalling and framing information to the multiplexed 24 -voice channels
- CPI and DMI - provides bidirectional data communication between systems
- PBX - interfaces between transmission medium and trunk side of PBX
- Time and Space Division Switching - provides interface between PCM highway and dedicated time slot interchange circuitry
- Can be used in virtually any voice/data system designed to AT\&T or CCITT specifications for primary rate interface


## CUSTOMER BENEFITS

Use of the R8070 will:

- Reduce board layout area
- Save power - CMOS low power dissipation
- Provide higher design reliability - replaces 100 MSI with one chip
- Provide cost reduction
- Meet AT\&T and CCITT specifications in a single device
- Provide ease of signal processing on a digital data


## SELECTABLE R8070 MODES




[^0]:    Note
    During an active bus cycle, $\overline{\mathrm{VPA}}$ and $\overline{\mathrm{BERR}}$ are sampled on every falling edge of the clock starting with SO. DTACK is sampled on every falling edge of the clock starting with S4 and data is latched on the falling edge of S 6 during a read. The bus cycle will then be terminated in $S 7$ except when BERR is asserted in the absence of DTACK, in which case it will terminate one clock cycle later in S9.

[^1]:    *With external pullup resistor of $1.1 \mathrm{k} \Omega$

[^2]:    Notes:

    1. Accessible register of the four word RxFIFO. The data is not initialized, however, $\overline{\operatorname{RES}}$ resets the RxFIFO pointer to the start of the first word.
    2. Accessible register of the four word TxFIFO. The data is not initialized, however, $\overline{\text { RES }}$ resets the TxFIFO pointer to the start of the first word.
    3. Reserved registers may contain random bit values.
[^3]:    - Enhanced R6502 CPU
    -Four new bit manipulation instructions
    Set Memory Bit (SMB)
    Reset Memory Bit (RMB)
    Branch on Bit Set (BBS)
    Branch on Bit Reset (BBR)
    -Decimal and binary arithmetic modes
    -13 Addressing modes
    -True indexing

[^4]:    Notes:
    **RESET = Register contents upon power up or $\overline{\text { RES }}$.

[^5]:    *These addressing modes are not available to the NMOS CPU family (e.g., the R6502).

[^6]:    Notes:

    1. R65C02 and R65C102 minimum operating frequency is limited by $\emptyset 2$ low pulse width. All processors can be stopped with $\emptyset 2$ held high.
    2. R65C02 only.
    3. R65C02 and R65C102 only.
    4. R65C102 only.
    5. R65C102 and R65C112 only.
    6. R65C112 only.
    7. Voltage levels shown are $\mathrm{V}_{\mathrm{L}} \leq 0.4 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{H}} \geq 2.4 \mathrm{~V}$ unless otherwise stated.
    8. Measurement points shown are 0.8 V (low) and 2.0 V (high) for inputs and 1.5 V (low and high) for outputs, unless otherwise specified.
    9. BE signal is asynchronous.
[^7]:    Note: All pins except pin under test tied to ground.

[^8]:    (1) Resistive pull-up, active buffer pull down
    (2) Input data is stored in port B latch by PAO pulse

[^9]:    *Add 1 to N if page boundary is crossed.
    **Add 1 to N if branch occurs to same page; add 2 to N if branch occurs to different page.

[^10]:    (1) Resistive pull-up, active buffer pull down
    (2) Input data is stored in port B latch by PAO pulse

[^11]:    NOTE: *R6500/12Q Only

[^12]:    (1) RESISTIVE PULL-UP, ACTIVE BUFFER PULL-DOWN

[^13]:    (1) POSITIVE EDGE DETECT
    (2) NEGATIVE EDGE DETECT
    (3) HARDWARE BUFFER FLOAT

[^14]:    \# OPTIONAL PC6
    \#\# NOT AVAILABLE WITH BOOTSTRAP ROM OPTION

    * EMS VALID @ 0100 THRU OFFF

[^15]:    *Also Controls Bar Graph Displays

[^16]:    NOTES: 1. Designates characteristics for both 10938 and 10939.
    2. Designates characteristics for 10938.
    3. Designates characteristics for 10939.

[^17]:    ${ }^{\text {TM }}$ Instant Pascal is a trademark of Melvin E. Conway.

[^18]:    *Characters with no indicated function are acknowledged, but do not otherwise affect display operation.

[^19]:    *Requires AIM 65/40 FORTH ROMs be resident.

[^20]:    *Requires AIM 65 FORTH or RM 65 Run-Time FORTH be resident.

[^21]:    NOTE UNLESS OTMERWISE SPECIFIED
    (1) PINS 12, BIa ON EURO CONUECTOR MiND DIUS
    -
    
    3) ALL EVEN NUMBER PINS ( 2 TURU 40) SNALL BE

    ALL EVEN NUMB
    TIED TO GND.
    4. ILL CAPACITORS ARE . IO UF $\times 20 \%$, SOV

[^22]:    Low Power TTL Schottky - compatible
    " 1 " $\geq 2.4 \mathrm{Vdc}$; " 0 " $\leq 0.4 \mathrm{Vdc}$
    CMOS $-12 \mathrm{~K} \Omega$ pullup to VDD required.

