# ROCKWELL 1985 DATA BOOK 

## Semiconductor Products Division

Rockwell International

# 1985 DATA BOOK 

## Rockwell International



Semiconductor Products Division

Rockwell Semiconductor Products Division is headquartered in Newport Beach, California with Field Sales Offices located throughout the United States, Canada Europe and the Far East. Their listings, plus those of domestic and international representatives and distributors, appear 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
Part Number/Data Book Page Index ..... 3
Index by Product Family ..... 5
1 R68000 Microprocessor and Peripherals. ..... 1-1
Product Family Overview ..... 1-1
R68000 16-Bit Microprocessing Unit (MPU) ..... 1-3
R68265 Double-Density Floppy Disk Controller (DDFDC) ..... 1-60
R68465 Double-Density Floppy Disk Controller (DDFDC) ..... 1-60
R68560 Multi-Protocol Communications Controller (MPCC) ..... $1-86$
R68561 Multi-Protocol Communications Controller (MPCC) ..... 1-86
R68802 Local Network Controller (LNET) ..... 1-118
R68C552 Dual Asynchronous Communications Interface Adapter (DACIA) ..... 1-138
2 8-Bit Microprocessors and Peripherals ..... 2-1
Product Family Overview ..... 2-2
R6500 Family Products
R650X Microprocessors (CPU) ..... 2-3
R651X Microprocessors (CPU) ..... 2-3
R6501Q One-Chip Microprocessor ..... 2-18
R6511Q One-Chip Microprocessor ..... 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 One-Chip Intelligent Peripheral Controller ..... 2-92
R6500/41 One-Chip Intelligent Peripheral Controller. ..... $2-92$
R6500/42 One-Chip Intelligent Peripheral Controller. ..... 2-92
R6500/43 One-Chip Intelligent Peripheral Controller ..... 2-92
R6545 CRT Controller (CRTC) ..... 2-100
R6545-1 CRT Controller (CRTC) ..... 2-118
R6549 Color Video Display Generator (CVDG) ..... 2-134
R6551 Asynchronous Communications Interface Adapter (ACIA) ..... 2-165
R6592 Single Chip Printer Controller ..... 2-185
R65560 Multi-Protocol Communications Controller (MPCC) ..... 2-196
R65C02 CMOS Microprocessor (CPU) ..... 2-226
R65C102 CMOS Microprocessor (CPU) ..... 2-226
R65C112 CMOS Microprocessor (CPU) ..... 2-226
R65C21 CMOS Peripheral Interface Adapter (PIA). ..... 2-242
R65C22 Versatile Interface Adapter (VIA). ..... 2-254
R65C24 CMOS Peripheral Interface Adapter Timer (PIAT) ..... 2-276
R65C51 CMOS Asynchronous Communications Interface Adapter (ACIA) ..... 2-296
R65C52 CMOS Dual Asynchronous Communications Interface Adapter (DACIA) ..... 2-316
Z80/8080 Bus Compatible Products R6265 Double-Density Floppy Disk Controller (DDFDC) ..... 2-335
R6765 Double-Density Floppy Disk Controller (DDFDC) ..... 2-335
3 R6500/* Microcomputers ..... 3-1
Product Family Overview ..... 3-2
R65C00/21 Dual CMOS Microcomputer ..... 3-3
R65C29 Dual CMOS Microprocessor ..... 3-3
R65F11 FORTH One-Chip Microcomputer ..... 3-36
R65F12 FORTH One-Chip Microcomputer ..... 3-36
R65FRX RSC FORTH Development and Kernel ROMs ..... 3-68
R65FKX RSC FORTH Development and Kernel ROMs ..... 3-68
R6501Q One-Chip Microprocessor. ..... 3-76
R6500/1 One-Chip Microcomputer ..... 3-105
R6500/1E Emulator Device ..... 3-136
R6500/1EB Backpack Emulator ..... 3-143
R6500/1EAB Backpack Emulator ..... 3-143
R6500/11 One-Chip Microcomputer ..... 3-149
R6500/12 One-Chip Microcomputer ..... 3-149
R6500/15 One-Chip Microcomputer ..... 3-149
R6500/16 One-Chip Microcomputer ..... 3-149
R65/11EB Backpack Emulator ..... 3-184
R65/11EAB Backpack Emulator ..... 3-184
R6511Q One-Chip Microprocessor ..... 3-189
R6500/13 One-Chip Microcomputer ..... 3-189
R6500/41 One-Chip Intelligent Peripheral Controller. ..... 3-224
R6500/42 One-Chip Intelligent Peripheral Controller ..... 3-224
R65/41EB Backpack Emulator ..... 3-253
R65/41EAB Backpack Emulator ..... 3-253
R6541Q One-Chip Intelligent Peripheral Controller. ..... 3-258
R6500/43 One-Chip Intelligent Peripheral
Controller. ..... 3-258

## TABLE OF CONTENTS (Continued)

4 Memory Products ..... 4-1
Product Family Overview ..... 4-2
Masked ROMs
R2332A 32K NMOS Static ROM ..... 4-3
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
R23C128 128K CMOS ROM ..... 4-23
R23256 256K Static ROMs ..... 4-27
R23257 256K Static ROMs ..... 4-27
UV Erasable PROMs
R87C64 64K CMOS UV EPROM ..... 4-31
EPROM Pinouts Guide ..... 4-37
5 Intelligent Display Controllers. ..... 5-1
Product Family Overview ..... 5-2
10937 Alphanumeric Display Controller ..... 5-3
10957 Alphanumeric Display Controller ..... 5-3
10938 Dot Matrix Display Controller ..... 5-11
10939 Dot Matrix Display Controller ..... 5-11
10939 Dot Matrix Display Controller ..... 5-21
10942 Dot Matrix Display Controller ..... 5-21
10943 Dot Matrix Display Controller ..... 5-21
10941 Alphanumeric and Bargraph Display Controller ..... 5-31
10939 Alphanumeric and Bargraph Display Controller ..... 5-31
10951 Bargraph and Numeric Display Controller ..... 5-41
10955 Segmented Display Controller/Driver ..... 5-51
6 Microcomputer Development Systems ..... 6-1
Product Family Overview ..... 6-2
RDC-1001/2 Multiple Target Development System (MTDS) ..... 6-3
RDC-3101/2 Low Cost Emulator (LCE) ..... 6-9
RDC-3XX Rockwell Design Center R6500/* Personality Set ..... 6-14
RDC-502 Rockwell Design Center R6502-R65C02 Personality Set ..... 6-18
RDC-504 Rockwell Design Center R6502-R65C02 Personality Set ..... 6-18
RDC-509 Rockwell Design Center R6502-R65C02 Personality Set ..... 6-18
RDC-2000 R6500 Cross Assembler for Intel Development System ..... 6-22
RDC-2005 R6500 Cross Assembler for Intel Personal Development System ..... 6-24
RDC-1020 Rockwell Design Center 8K/32K/64K Target RAM Module. ..... 6-26
RDC-1022 Rockwell Design Center 8K/32K/64K Target RAM Module. ..... 6-26
RDC-1024 Rockwell Design Center 8K/32K/64K Target RAM Module. ..... 6-26
RDC-1030 Multiple Target Development System PROM Programmer Module ..... 6-30
Software Preparation System
SPS-200 Software Preparation System PeripheralConnector Module6-36
7 Integral Modems ..... 7-1
Product Family Overview ..... 7-2
Product Preview-High Speed Modems R96FT/SEC 9600 BPS Fast Train Modem with Secondary Channel. ..... $7-3$
R144 Synchronous 14.4 KBPS Modem ..... 7-4
R4875 $4800 / 75$ BPS Modem. ..... 7-5
R208A/B 4800 BPS Modem ..... 7-6
High Speed
R96FAX 9600 BPS Facsimile Modem ..... 7.7
R96DP 9600 BPS Data Pump Modem ..... 7-20
R96FT 9600 BPS Fast Train Modem. ..... 7-34
V96P/1 9600 BPS Modem ..... 7-47
R48DP 4800 BPS Data Pump Modem ..... 7-55
V27P/1 4800 BPS Modem ..... 7-69
Product Preview—Low to Medium Speed
Modems
R1212DS Modem Device Set(212A Compatible)7-76
R2424DS Modem Device Set ..... $7-77$
R2่4DP 2400 BPS Modem
(201C Compatible) ..... $7-78$
Low to Medium Speed
R1212 1200 BPS Full Duplex Modem ..... $7-79$
R1212/U 1200 BPS Full Duplex Modem with Internal USART ..... 7-94
R2424 2400 BPS Full Duplex Modem ..... 7-110
R24DC 2400 BPS Direct Connect Modem ..... 7-126
R24LL 2400 BPS Leased Line Modem. ..... 7-134
R24 2400 BPS Integral Modem. ..... 7-143
Modem Interfacing Products
RDAA Rockwell Data Access Arrangement Module ..... 7-151
8 T-1 and T-1/CEPT Pulse Code Modulation Protocol Devices ..... 8-1
Product Family Overview ..... 8-2
R8040 Tri-Port Memory ..... 8-3
R8050 T-1 Serial Transmitter ..... 8-9
R8060 T-1 Serial Receiver ..... 8-17
R8070 T-1/CEPT Pulse Code Modulation
Transceiver ..... 8-23
Sales Offices, Representatives and Distributors ..... A-1

## ROCKWELL SEMICONDUCTORS CROSS-REFERENCE GUIDE



## APPLICATION NOTE INDEX

| Order No. | Title | Order No. | Title |
| :---: | :---: | :---: | :---: |
| R6500 Microprocessors and Peripherals |  | Microcomputer Development Systems |  |
| 223 296 256 226 227 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 <br> 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 ACIA (Asynchronous Communication Interface Adapter) | 224 <br> 240 <br> 246 <br> 2129 <br> 2158 <br> 2166 | System 65 to AIM 65 Microcomputer Interface User 65 Emulation with less than 512 Bytes of RAM System 65 Bus Interface <br> 0S3.1 Monitor ROM \& Macro Assembler/Linking Loader CMOS User 65 System 65 Development System R6500 Software Preparation System Development Configurations |
| 208 | Low-Cost Crystal Oscillator for Clock Input Frequency Generator | Integral Modems |  |
| 231 276 287 | Interfacing R6500 Microprocessors to a FDC (Floppy Disk Controller) <br> Crystal Considerations for R6500 Family Devices <br> Using R65XX Family Peripheral Devices with Z80 CPU | 607 608 619 | R24 Modem Options <br> Quality of Received Data for R24 Modem <br> R24DC Interface to EIA RS-232-C |
| R6500/* Microcomputers |  | 624 | R24DC Modem Options |
| 239 | Interfacing R6500/1 to SIDC (Serial Input Display Controller) | 634 | R24LL and R24DC Modem Control Signal To LED Interface |
| 237 | R6500/1 Microcomputer-Based Printer Controller A Logical Tester for R6500/1 One-Chip Microcomp | 632 | R24LL Modem Interface to EIA RS-232-C |
| 2163 |  | 635 | R24LL Modem Options |
|  | 10938/10939 Display Drivers and R6500/1EB Microcomputer | 617 637 | 4800/9600 BPS Modem Interfacing <br> Picture Plotter Data Transmission System |
| 2162 | A Low Cost Development Module for the R65F11/R65F12 FORTH Microcomputer | 654 |  |
| 2178 | Design Considerations for Conversion to Rockwell R6500/11 and R6501Q from Intel 8051/8031 | 655 | R96FAX Modem Recommended Receive Sequence for Group 2 Facsimile |
| 2182 | R6500/41 Based Stepper Motor Controller | 656 | R96FAX Modem Scrambled Ones Work-Around for R5300-18 and R5300-19 <br> R96DP and R48DP Modems RAM Write Control <br> High Speed Modems Filter Characteristics |
| Intelligent Display Controllers |  | $\begin{aligned} & 657 \\ & 658 \end{aligned}$ |  |
| 2163 | A Dot Matrix Controller System Design Using the 10938/10939 Display Drivers and R6500/1EB Microcomputer <br> Display Controller Designer Notes |  |  |

## PART NO./DATA BOOK PAGE INDEX

10937 Alphanumeric Display Controller ..... 5-3
10938 Dot Matrix Display Controller ..... 5-11
10939 Display Controller ..... 5-11, 5-21, 5-31
10941 Alphanumeric and Bargraph Display Controller. ..... 5-31
10942 Dot Matrix Display Controller ..... 5-21
10943 Dot Matrix Display Controller ..... 5-21
10951 Bargraph and Numeric Display Controller ..... 5-41
10955 Segmented Display Controller/Driver ..... 5-51
10957 Alphanumeric Display Controller ..... 5-3
R1212 1200 BPS Full Duplex Modem ..... 7-79
R1212DS Modem Device Set (212A Compatible) ..... $7-76$
R1212/U 1200 BPS Full Duplex Modem with Internal USART ..... 7-94
R144 Synchronous 14.4 KBPS Modem ..... 7-4
R208A/B 4800 BPS Modem ..... 7-6
R23128 128K NMOS Static ROM ..... 4-19
R23256 256K Static ROMs ..... 4-27
R23257 256K Static ROMs. ..... 4-27
R2332A 32K NMOS Static ROM ..... 4-3
R2332B 32K NMOS Static ROM ..... 4-3
R2364A 64K NMOS Static ROM ..... 4-7
R2364B 64K NMOS Static ROM ..... 4-11
R23C128 128K CMOS ROM ..... 4-23
R23C64 64K CMOS Static ROM ..... 4-15
R24 2400 BPS Integral Modem. ..... 7-143
R24DC 2400 BPS Direct Connect Modem ..... 7-126
R24DP 2400 BPS Modem (201C Compatible) ..... 7-78
R24LL 2400 BPS Leased Line Modem ..... 7-134
R2424 2400 BPS Full Duplex Modem. ..... 7-110
R2424DS Modem Device Set ..... 7-77
R4875 4800/75 BPS Modem ..... 7-5
R48DP 4800 BPS Data Pump Modem ..... 7-55
R6265 Double-Density Floppy Disk Controller (DDFDC) ..... 2-335
R6500/1 One-Chip Microcomputer. ..... 3-105
R6500/11 One-Chip Microcomputer. ..... 3-149
R6500/12 One-Chip Microcomputer. ..... 3-149
R6500/13 One-Chip Microcomputer. ..... 3-189
R6500/15 One-Chip Microcomputer. ..... 3-149
R6500/16 One-Chip Microcomputer. ..... 3-149
R6500/1E Emulator Device. ..... 3-136
R6500/1EAB Backpack Emulator ..... 3-143
R6500/1EB Backpack Emulator ..... 3-143
R6500/41 One-Chip Intelligent Peripheral Controller. ..... 3-224
R6500/42 One-Chip Intelligent Peripheral Controller ..... 2-92, 3-224
R6500/43 One-Chip Intelligent Peripheral Controller ..... 2-92, 3-258
R6501Q One-Chip Microprocessor ..... 2-18, 3-76
R650X Microprocessors (CPU). ..... 2-3
R6502 Microprocessor (CPU) ..... 2-3
R6503 Microprocessor (CPU) ..... 2-3
R6504 Microprocessor (CPU) ..... 2-3
R6505 Microprocessor (CPU) ..... 2-3
R6506 Microprocessor (CPU) ..... 2-3
R6507 Microprocessor (CPU) ..... 2-3
R6511Q One-Chip Microprocessor ..... 2-18, 3-189
R651X Microprocessors (CPU) ..... 2-3
R6512 Microprocessor (CPU) ..... 2-3
R6513 Microprocessor (CPU) ..... 2-3
R6514 Microprocessor (CPU) ..... 2-3
R6515 Microprocessor (CPU) ..... 2-3
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 One-Chip Intelligent Peripheral Controller ..... 2-92, 3-258
R6545 CRT Controller (CRTC) ..... 2-100
R6545-1 CRT Controller (CRTC). ..... 2-118
R6549 Color Video Display Generator (CVDG) ..... 2-134
R6551 Asynchronous Communications Interface Adapter (ACIA). ..... 2-165
R65560 Multi-Protocol Communications Controller (MPCC) ..... 2-196
R6592 Single Chip Printer Controller ..... 2-185
R65C00/21 Dual CMOS Microcomputer ..... 3-3
R65C02 CMOS Microprocessor (CPU). ..... 2-226
R65C102 CMOS Microprocessor (CPU). ..... 2-226
R65C112 CMOS Microprocessor (CPU). ..... 2-226
R65C21 CMOS Peripheral Interface Adapter (PIA). ..... 2-242
R65C22 Versatile Interface Adapter (VIA). ..... 2-254
R65C24 CMOS Peripheral Interface Adapter Timer (PIAT). ..... 2-276
R65C29 Dual CMOS Microprocessor. ..... 3-3
R65C51 CMOS Asynchronous Communications Interface Adapter (ACIA) ..... 2-296
R65C52 CMOS Dual Asynchronous Communications Interface Adapter (DACIA) ..... 2-316
R65F11 FORTH One-Chip Microcomputer. ..... 3-36
R65F12 FORTH One-Chip Microcomputer ..... 3-36
R65FKX RSC FORTH Development and Kernel ROMs ..... 3-68
R65FRX RSC FORTH Development and Kernel ROMs ..... 3-68
R65/11EAB Backpack Emulator ..... 3-184
R65/11EB Backpack Emulator ..... 3-184
R65/41EAB Backpack Emulator ..... 3-253
R65/41EB Backpack Emulator ..... 3-253

## PART NO./DATA BOOK PAGE INDEX (Continued)

R6765 Double-Density Floppy Disk Controller (DDFDC) ..... 2-335
R68000 16-Bit Microprocessing Unit (MPU). ..... 1-3
R68265 Double-Density Floppy Disk Controller (DDFDC) ..... 1-60
R68465 Double-Density Floppy Disk Controller (DDFDC) ..... 1-60
R68560 Multi-Protocol Communications Controller (MPCC) ..... 1-86
R68561 Multi-Protocol Communications Controller (MPCC) ..... 1-86
R68802 Local Network Controller (LNET) ..... 1-118
R68C552 Dual Asynchronous Communications Interface Adapter (DACIA) ..... 1-138
R8040 Tri-Port Memory ..... 8-3
R8050 T-1 Serial Transmitter ..... 8-9
R8060 T-1 Serial Receiver. ..... 8-17
R8070 T-1/CEPT Pulse Code Modulation Transceiver ..... 8-23
R87C64 64K CMOS UV EPROM ..... 4-31
R96DP 9600 BPS Data Pump Modem ..... 7-20
R96FAX 9600 BPS Facsimile Modem ..... 7-7
R96FT 9600 BPS Fast Train Modem. ..... 7-34
R96FT/SEC 9600 BPS Fast Train Modem with
Secondary Channel ..... 7-3
RDAA Rockwell Data Access Arrangement Module ..... 7-151
RDC-1001/2 Multiple Target Development System (MTDS) ..... 6-3
RDC-1020 Rockwell Design Center 8K/32K/64K Target RAM Module ..... 6-26
RDC-1022 Rockwell Design Center 8K/32K/64K Target RAM Module ..... 6-26
RDC-1024 Rockwell Design Center 8K/32K/64K Target RAM Module ..... 6-26
RDC-1030 Multiple Target Development System PROM Programmer Module ..... 6-30
RDC-2000 R6500 Cross Assembler for Intel Development System ..... 6-22
RDC-2005 R6500 Cross Assembler for Intel Personal Development System. ..... 6-24
RDC-3101/2 Low Cost Emulator (LCE). ..... 6-9
RDC-3XX Rockwell Design Center R6500/* Personality Set ..... 6-14
RDC-502 Rockwell Design Center R6502-R65C02 Personality Set ..... 6-18
RDC-504 Rockwell Design Center R6502-R65C02 Personality Set ..... 6-18
RDC-509 Rockwell Design Center R6502-R65C02 Personality Set ..... 6-18
SPS-200 Software Preparation System Peripheral Connector Module ..... 6-36
V27P/1 4800 BPS Modem ..... 7-69
V96P/1 9600 BPS Modem ..... $7-47$

## PRODUCT INDEX

## R68000 Microprocessor and Peripherals

## 8-Bit Microprocessors and Peripherals

## R6500/* Microcomputers

## Memory Products

## Intelligent Display Controllers

Microcomputer Development Systems

## 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
R68265, R68465 Double-Density Floppy Disk Controller (DDFDC) ..... 1-60
R68560 and R68561 Multi-Protocol Communications Controller (MPCC) ..... 1-86
R68802 Local Network Controller (LNET) ..... 1-118
R68C552 Dual Asynchronous Communications Interface Adapter (DACIA) ..... 1-138

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

The R68C552 provides an easily implemented, program controlled interface between 16-bit microprocessor-based systems and serial communication data sets and modems. This device is the first CMOS.ACIA in the industry.

Rockwell lets you build efficient and economical 16-bit systems through families of 16 -bit and 8 -bit peripherals, all compatible. No other 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

## R68000 <br> 16-BIT MICROPROCESSING UNIT (MPU)

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


R68000 Registers

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

## FEATURES

- 16M byte (8M word) Linear Addessing Range
- 14 Operand Addressing Modes
- 56 Powerful Instruction Types
- Instruction Set Supports Structured High-Level Languages
- Pipelining Instruction Execution
- 32-Bit Program Counter
- 16-Bit Data Bus
- 23-Line Address Bus
- 32-Bit Data and Address Registers Including:
- Eight General Purpose Data Registers
- Seven Address Registers
- Two Stack Pointers (User, Supervisory)
- All 17 Registers Can Be Index Registers
- Memory Mapped Peripheral Devices
- Vector Generated Exception Processing
- Seven Unique Autovectors for Interrupt Service Routines
- Trace Mode for Software Debugging
- Operations Occur on Five Main Data Types
— Bit
- BCD
- Byte
- Word
- Long Word
- Asynchronous and Synchronous Peripheral Interface Capability
- Many Peripheral Chips Available
- R68560 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

| Part <br> Number | Package <br> Type | Frequency <br> (MHz) | Temperature <br> Range $\left({ }^{\circ}\right.$ C $)$ |
| :--- | :--- | ---: | :---: |
| R68000C4 | Ceramic DIP | 4 | 0 to +70 |
| R68000C6 | Ceramic DIP | 6 | 0 to +70 |
| R68000C8 | Ceramic DIP | 8 | 0 to +70 |
| R68000C10 | Ceramic DIP | 10 | 0 to +70 |
| R68000C12 | Ceramic DIP | 12.5 | 0 to +70 |
| R68000J6 | Plastic CC | 6 | 0 to +55 |
| R6800088 | Plastic CC | 8 | 0 to +55 |
| R6800010 | Plastic CC | 10 | 0 to +55 |
| R68000J12 | Plastic CC | 12.5 | 0 to +55 |
| R68000P6 | Plastic DIP | 6 | 0 to +55 |
| R68000P8 | Plastic DIP | 8 | 0 to +55 |
| R68000P10 | Plastic DIP | 10 | 0 to +55 |
| R68000P12 | Plastic DIP | 12.5 | 0 to +55 |
| R6800006 | Plastic QUIP | 6 | 0 to +55 |
| R68000Q8 | Plastic QUIP | 8 | 0 to +55 |
| R68000Q10 | Plastic QUIP | 10 | 0 to +55 |
| R68000Q12 | Plastic QUIP | 12.5 | 0 to +55 |




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

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


Figure 1. Input and Output Signals

Address Strobe ( $\overline{\mathbf{A S}}$ ). The $\overline{\mathrm{AS}}$ output indicates that there is a valid address on the address bus.

Read/Write (R/W). The 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{\text { UDS }}, \overline{\text { LDS }}$ ). The $\overline{\text { UDS }}$ and $\overline{\text { LDS }}$ outputs control the data on the data bus, as shown in Table 1. When the $R \bar{W}$ line is high, the processor reads from the data bus as indicated. When the $R \bar{W}$ line is low, the processor writes to the data bus as shown.
Data Transfer Acknowledge ( $\overline{\text { DTACK }}$ ). The $\overline{\text { DTACK }}$ input indicates that the data transfer is completed. When the processor recognizes $\overline{\text { DTACK }}$ during a read cycle, data is latched and the bus cycle terminated. When DTACK is recognized during a write cycle, the bus cycle terminates. Refer to ASYNCHRONOUS VERSUS SYNCHRONOUS OPERATION.

BUS ARBITRATION CONTROL. These three signals form a bus arbitration circuit to determine which device will be the bus master device.

Bus Request ( $\overline{\mathbf{B R}}$ ). The $\overline{\mathrm{BR}}$ input indicates to the processor that some other device desires to become the bus master. This input can be externally ORed with all other devices that could be bus masters.
Bus Grant ( $\overline{\mathbf{B G}}$ ). 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{\mathrm{BGACK}}$ input indicates that some other device has become the bus master. This signal cannot be asserted until the following four conditions are met:

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

Table 1. Data Strobe Control of Data Bus

| $\overline{\text { UDS }}$ | $\overline{\text { LDS }}$ | R/W | D8-D15 | D0-D7 |
| :--- | :--- | :---: | :---: | :---: |
| Hıgh | Hıgh | - | No valıd data | No valid data |
| Low | Low | High | Valid data bits <br> $8-15$ | Valıd data bits <br> $0-7$ |
| High | Low | Hıgh | No valid data | Valid data bits <br> $0-7$ |
| Low | High | High | Valid data bits <br> $8-15$ | No valid data |
| Low | Low | Low | Valid data bits <br> $8-15$ | Valid data bits <br> $0-7$ |
| Hıgh | Low | Low | Valid data bits <br> $0-7 *$ | Valid data bits <br> $0-7$ |
| Low | Hıgh | Low | Valid data bits <br> $8-15$ | Valid data bits <br> $8-15^{*}$ |
| *These condıtıons are a result of current implementation and may not |  |  |  |  |
| appear on future devices. |  |  |  |  |

3. data transfer acknowledge ( $\overline{\text { DTACK }})$ is inactive which indicates that neither memory nor peripherals are using the bus, and
4. bus grant acknowledge ( $\overline{\text { BGACK }}$ ) 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 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{\text { 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 gotinactive 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{\mathrm{HALT}}$ and $\overline{\mathrm{BERR}}$ 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 ( $\overline{\mathrm{VPA}}$ ) input which indicates that the peripheral is a R6500 family device.

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

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

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

Table 2. Function Code Outputs

| 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) |
| Hıgh | Low | High | Supervisor Data |
| Hıgh | Hıgh | Low | Supervisor Program |
| High | High | High | Interrupt Acknowledge |

Table 3. Signal Summary

| Signal Name | Mnemonic | Input/Output | Active State | $\mathrm{Hi}-\mathrm{Z}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | On HALT | On $\overline{\text { BGACK }}$ |
| Address Bus | A1-A23 | Output | Hıgh | 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{B G}$ | Output | Low | No | No |
| Bus Grant Acknowledge | $\overline{\text { BGACK }}$ | Input | Low | No | No |
| Interrupt Priority Level | $\overline{\mathrm{PLL}}, \overline{\mathrm{IPL}}, \overline{\mathrm{IPL}}$ | 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{\mathrm{VMA}}$ | Output | Low | No | Yes |
| Valid Peripheral Address | $\overline{\text { VPA }}$ | Input | Low | No | No |
| Function Code Output | FC0, FC1, FC2 | Output | Hıgh | No | Yes |
| Clock | CLK | Input | High | No | No |
| Power Input | VCC | 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.


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

Status Register


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 AO bit equals one, the lower data strobe is issued. The processor correctly positions the received data internally.

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

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



DECIMAL DATA
2 BINARY CODED DECIMAL DIGITS = 1 BYTE

| 15 | $14 \quad 13$ | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSD | BCD 0 |  |  |  |  | LSD |  |  |  |  |  |  |  |  |
|  | BCD 4 |  |  |  |  |  |  |  |  |  |  |  |  |  |

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{B G})$ 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 13. Bus Arbitration Cycle Flow Chart

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

The bus request from the granted device should be dropped after bus grant acknowledge is asserted. If a bus request is still penaing, anotner bus grant wil 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{A S}$ is negated. All signals are shown in positive logic (active high) regardless of their true active voltage level.

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

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

If a bus request $(\overline{\mathrm{BR}})$ is made at a time when the MPU has already begun a bus cycle but $\overline{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 untıl the second rising edge following its internal assertion. This sequence is shown in Figure 19.

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

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


Figure 14. Bus Arbitration Cycle Timing Diagram


Figure 15. State Diagram of R68000 Bus Arbitration Unit

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

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

Bus Error Operation. When $\overline{\mathrm{BERR}}$ is asserted, the current bus cycle is terminated. If $\overline{B E R R}$ is asserted before the falling edge of S2, $\overline{A S}$ 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 BERR, and HALT is being driven by an external device, the processor enters the re-run sequence. Figure 21 is a timing diagram for re-running the bus cycle.

The processor terminates the bus cycle, then puts the address and data output lines in the high-impedance state. The processor remains 'halted"' and will not run another bus cycle until external logic negates $\overline{\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. $\overline{B E R R}$ 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{\mathrm{AS}}$. If BERR and HALT are asserted during a read-modify-write bus cycle, a bus error operation results.

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

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

Figure 22 details the timing required for correct single-step operations. Some care must be exercised to avoid harmful interactions between BERR and HALT when using the single cycle mode as a debugging tool. This is also true of interactions between the $\overline{\text { 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{\mathrm{BERR}}$ ) pin also has an effect on processor operation after the processor receives an external reset input. The processor reads the vector table after a reset to determine the address to start program execution. If a bus error occurs while reading the vector table (or at any time before the first instruction is executed), the processor reacts as if a double bus fault has occurred and it halts. Only an external reset will start a halted processor.

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

When the RESET and 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 RESET and 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 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{\mathrm{BERR}}$, and $\overline{\text { HALT }}$ should be asserted and negated on the rising edge of R68000 clock. This will assure that when two signals are asserted simultaneously, the required setup time (\#47) for both of them will be met during the same bus state.

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

The preferred bus cycle terminations may be summarized as follows (case numbers refer to Table 4):
Normal Termination: $\overline{\text { DTACK }}$ occurs first (case 1).
Halt Termination: $\overline{\text { HALT }}$ is asserted at same time, or precedes $\overline{\text { DTACK }}$ (no $\overline{B E R R}$ ) 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 $\overline{\text { 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 BERR should be negated when address strobe is negated).

Example A: A system uses a watch-dog timer to terminate accesses to unpopulated address space. The timer asserts $\overline{\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.

X $\times$ X 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 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 $\overline{B E R R}$ at same time as $\overline{\text { 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{\mathrm{BERR}}, \overline{\mathrm{HALT}}$, and $\overline{\mathrm{VPA}}$ ) to control the data transfer. Using this method, $\overline{A S}$ signals the start of a bus cycle and the data strobes are used as a condition for valid data on a write cycle, The slave device (memory or peripheral) then responds by placing the requested data on the data bus for a read cycle or latching data on a write cycle and asserting the data transfer acknowledge signal (DTACK) to terminate the bus cycle. If no slave reponds or the access is invalid, external control logic asserts the BERR, or $\overline{B E R R}$ and $\overline{\text { HALT}}$, signal to abort or rerun the bus cycle.

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

The $\overline{B E R R}$ signal is allowed to be asserted after the $\overline{\text { DTACK }}$ signal is asserted. BERR must be asserted within the time given as parameter \#48 after $\overline{\text { 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 $\overline{\text { 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 $\overline{\text { DTACK }}$ is recognized on a falling edge, valid data will be latched into the processor (on a read cycle) on the next falling edge provided that the data meets the setup time given as parameter \#27. Given this, parameter \#31 may be ignored. Note that if $\overline{D T A C K}$ is asserted, with the required setup time, before the falling edge of $S 4$, no wait states will be incurred and the bus cycle will run at its maximum speed of four clock periods.

In order to assure proper operation in a synchronous system when $\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.

## Note

During an active bus cycle, $\overline{\mathrm{VPA}}$ and $\overline{\mathrm{BERR}}$ are sampled on every falling edge of the clock starting with SO. DTACK is sampled on every falling edge of the clock starting with S4 and data is latched on the falling edge of S6 during a read. The bus cycle will then be terminated in $\mathrm{S7}$ except when $\overline{B E R R}$ is asserted in the absence of $\overline{\text { DTACK }}$, in which case it will terminate one clock cycle later in S9.

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

| Case No. | Control Signal | Asserted on Rising Edge of State |  | Result |
| :---: | :---: | :---: | :---: | :---: |
|  |  | N | $\mathrm{N}+2$ |  |
| 1 | $\frac{\overline{\text { DTACK }}}{\frac{\text { BERR }}{\text { HALT }}}$ | $\begin{aligned} & \text { A } \\ & \text { NA } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & \mathrm{S} \\ & \mathrm{X} \\ & \mathrm{X} \end{aligned}$ | Normal cycle terminate and contınue. |
| 2 | $\begin{aligned} & \overline{\overline{D T A C K}} \\ & \overline{B E R R} \end{aligned}$ $\overline{\text { 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} & \overline{\overline{\text { DTACK }}} \\ & \frac{\text { BERR }}{\text { HALT }} \end{aligned}$ | $\begin{aligned} & \text { NA } \\ & \text { NA } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & \text { A } \\ & \text { NA } \\ & S \end{aligned}$ | Normal cycle termınate and halt Contınue when HALT removed |
| 4 | $\frac{\overline{\text { DTACK }}}{\frac{\text { BERR }}{\text { HALT }}}$ | $\begin{aligned} & X \\ & \text { A } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{~S} \\ & \mathrm{NA} \\ & \hline \end{aligned}$ | Terminate and take bus error trap |
| 5 | $\begin{aligned} & \frac{\overline{\text { DTACK }}}{\frac{\text { BERR }}{\text { HALT }}} \end{aligned}$ | $\begin{aligned} & \text { NA } \\ & \text { A } \\ & \text { NA } \end{aligned}$ | $\begin{aligned} & X \\ & \text { S } \\ & \text { A } \end{aligned}$ | Terminate and re-run |
| 6 | $\frac{\overline{\text { DTACK }}}{\frac{\text { BERR }}{\text { HALT }}}$ | $\begin{aligned} & \text { X } \\ & \text { A } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & X \\ & S \\ & S \end{aligned}$ | Terminate and re-run when HALT removed |
| 7 | $\overline{\text { DTACK }}$ 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 |

Legend.
N - the number of the current even bus state (e g., S4, S6, etc.)
A - signal is asserted in this bus state
NA - signal is not asserted in this state
X - don't care
S - signal was asserted in previous state and remains asserted in this state

Table 5. $\overline{\text { BERR }}$ AND $\overline{\text { HALT }}$ Negation Results

| 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 <br> or | $\bullet$ | Takes bus error trap. |
| Re-run | $\frac{\overline{\text { BERR }}}{\text { HALT }}$ |  |  | - | Illegal sequence; usually traps to vector number 0 |
| Re-run | $\frac{\overline{\text { BERR }}}{\text { HALT }}$ | $\bullet$ |  | - | Re-runs the bus cycle. |
| Normal | $\frac{\overline{\text { BERR }}}{\text { HALT }}$ | $\bullet$ |  | $\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{IRQ}}$ ), 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: Initıal SSP |
| - | 4 | 004 | SP | Reset: Initial PC |
| 2 | 8 | 008 | SD | Bus Error |
| 3 | 12 | 00C | 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 | Uninitialızed Interrupt Vector |
| 16-23* | 64 | 04C | SD | (Unassıgned, 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 | 0 CO | SD | (Unassıgned, 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 oxcoptions have highest priority, while Group ? excentions 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 |

The priority relation between two exceptions determines which is taken first if the conditions for both arise simultaneously. Therefore, if a bus error occurs during a TRAP instruction, the bus error takes precedence, and the TRAP instruction processing is aborted. In another example, if an interrupt request occurs during the execution of an instruction while the T-bit is asserted, the trace exception has priority, and is processed first. Before instruction processing resumes, however, the interrupt exception is also processed, and instruction processing commences finally in the interrupt handler routine. Table 8 gives a summary of exception grouping and priority.

## 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 lasi 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 eninter The nowerup/restart code should be pointed to bv the initial program counter.

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

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

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

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

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

UNINITIALIZED INTERRUPT. An interrupting device asserts $\overline{\text { 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. Illegal instruction refers to any of the word bit patterns which are not the bit pattern of the first word of a legal instruction. During instruction execution, if such an instruction is fetched, an illegal instruction exception occurs. Rockwell reserves the right to define instructions whose opcodes may be any of the illegal instructions. Three bit patterns will always force an illegal instruction trap on all R68000 Family compatible microprocessors. They are: \$4AFA, \$4AFB, and \$4AFC. Two of the patterns, \$4AFA and \$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 unimpiemented 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 $\overline{\mathrm{VPA}}$ accesses on successive $E$ pulses.

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

During state 2 , the address strobe ( $\overline{\mathrm{AS}}$ ) is asserted to indicate that there is a valid address on the address bus. If the bus cycle is a read cycle, the upper and/or lower data strobes are also asserted in state 2. If the bus cycle is a write cycle, the read/write $(R / \bar{W})$ signal is switched to a low (write) during state 2. One-half clock later, in state 3, the write data is placed on the data bus, and in state 4 the data strobes are issued to indicate valid data on the data bus. The processor now inserts wait states until it recognizes the assertion of VPA.

The $\overline{\mathrm{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 ( $\overline{\mathrm{VPA})}$ is derived by decoding the address bus, conditioned by address strobe ( $\overline{\mathrm{AS}}$ ). Chip select for the R6500 peripherals should be derived by decoding the address bus conditioned by $\overline{\mathrm{VMA}}$.

After the recognition of $\overline{\mathrm{VPA}}$, 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{\mathrm{AS}}$, then $\overline{\mathrm{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{\mathrm{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 $\overline{\mathrm{VPA}}$ within one clock after address strobe is negated.
$\overline{\text { DTACK }}$ should not be asserted while $\overline{\text { 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 $\overline{\mathrm{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 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 | Program Counter Relative |
| :--- | :--- |
| Register Indirect | Implied |
| Absolute | Immediate |

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} & E A=\text { (Next Word }) \\ & E A=\text { (Next Two Words) } \end{aligned}$ |
| Program Counter Relative Addressing <br> Relatıve 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> Postıncrement Regıster Indırect <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-E A=(A n) \\ & E A=(A n)+d_{16} \\ & E A=(A n)+(X n)+d_{8} \end{aligned}$ |
| Immediate Data Addressing Immediate Quick Immediate | DATA $=$ Next Word(s) Inherent Data |
| Implied Addressing Implied Register | $E A=S R, U S P, S P, P C$ |
| NOTES: <br> EA = Effective Address <br> An = Address Register <br> Dn = Data Register <br> Xn = Address or Data Register used as Index Register <br> SR = Status Register <br> PC = Program Counter <br> ( ) = Contents of <br> $\mathrm{d}_{8}=$ Eight-bit Offset (displacement) <br> $\mathrm{d}_{16}=$ SIxteen-bit Offset (displacement) | $\mathrm{N}=1$ for Byte, 2 for <br> Words and 4 for Long Word. If An is the stack pointer and the operand size is byte, $\mathrm{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 vina. 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 |
| ASR |  | JMP <br> JSR | Jump <br> Jump to Subroutine |  |  |
| Bcc BCHG BCLR BRA | 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 } \end{aligned}$ | Load Effective Address Link Stack Logical Shift Left |  |  |
| BSER |  | LSR | Logical Shift Right | SBCD SCC STOP SUB SWAP | Subtract Decimal with Extend <br> Set Conditional <br> Stop <br> Subtract <br> Swap Data Register Halves |
| BTST |  | MOVE | Move |  |  |
| CHK | Check Register Against Bounds Clear Operand Compare | MULU | Unsigned Multiply |  |  |
| $\begin{aligned} & \text { CLR } \\ & \text { CMP } \end{aligned}$ |  | NBCD NEG NOP | Negate Decimal with Extend Negate <br> No Operation | TAS TRAP | Test and Set Operand Trap |
| DBCC | Test Condition, Decrement and Branch Signed Divide Unsigned Divide | NOT | One's Complement | TRAPV TST | Trap on Overflow Test |
| DIVS DIVU |  | OR | Logical Or | UNLK | Unlink |

Table 11. Variations of Instruction Types

| Instruction Type | Variation | Description | Instruction Type | Varlation | 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 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 | NEG NEGX | 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 Exclusive Or Immediate ro Condition Codes Exclusive Or Immediate to Status Register | SUB | SUB <br> SUBA <br> SUB! <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 \rightarrow A n$ |
| LINK | - | $\mathrm{An} \rightarrow-(\mathrm{SP})$ <br> $\mathrm{SP} \rightarrow \mathrm{An}$ <br> $\mathrm{SP}+$ displacement $\rightarrow$ SP |
| MOVE | $8,16,32$ | $\mathrm{~s} \rightarrow \mathrm{~d}$ |
| MOVEM | 16,32 | $(E A) \rightarrow \mathrm{An}, \mathrm{Dn}$ <br> $\mathrm{An}, \mathrm{Dn} \rightarrow \mathrm{EA}$ |
| MOVEP | 16,32 | $(E A) \rightarrow \mathrm{Dn}$ <br> $\mathrm{Dn} \rightarrow(E A)$ |
| MOVEQ | 8 | $\# x x x \rightarrow \mathrm{Dn}$ |
| PEA | 32 | $\mathrm{EA} \rightarrow-(\mathrm{SP})$ |
| SWAP | 32 | $\mathrm{Dn}[31.16] \rightarrow \mathrm{Dn}[15: 0]$ |
| UNLK | $\mathrm{An} \rightarrow \mathrm{Sp}$ |  |
| $(\mathrm{SP})+\rightarrow \mathrm{An}$ |  |  |

NOTES:
s = source $\quad-(\quad)=$ indirect with predecrement
$\mathrm{d}=$ destination $\quad(\quad)+=$ indirect with postdecrement
[ ] = bit number $\quad \#=1 m m e d i a t e ~ d a t a ~$
operand sizes. Address operatıons 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 dafa 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 | $8,16,32$ $16,32$ | $\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 \mathrm{C} \rightarrow(E A) \rightarrow$ Dn |
| DIVU | $32 \div 16$ | $D \mathrm{C} \div(E A) \rightarrow$ Dn |
| EXT | $\begin{aligned} & 8 \rightarrow 16 \\ & 16 \rightarrow 32 \end{aligned}$ | $\begin{aligned} & (D n)_{8} \rightarrow D n_{16} \\ & (D n)_{16} \rightarrow n_{32} \\ & \hline \end{aligned}$ |
| MULS | $16 \times 16 \rightarrow 32$ | $\mathrm{Dn} \times(E A) \rightarrow$ Dn |
| MULU | $16 \times 16 \rightarrow 32$ | Dn $\times(E A) \rightarrow$ Dn |
| NEG | 8, 16, 32 | $0-(E A) \rightarrow$ (EA) |
| NEGX | 8, 16, 32 | $0-(E A)-X \rightarrow(E A)$ |
| 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 \(-(\quad)=\) 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 | EFFECTIVE ADDRESS |
| :---: |
| $X$ |

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-
Word Operation - operand is extension word
Long Word Operation - operand is in the two extension words, high-order 16 bits are in the first extension word, low-order 16 bits are in the second extension word.

## 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 | 111 | 011 |
| Program Counter with Index | 111 | 100 |
| Immediate |  |  |

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$ | Dn $\Lambda(E A) \rightarrow$ Dn <br> $(E A) \Lambda D n \rightarrow(E A)$ <br> $(E A) \Lambda \# x x x \rightarrow(E A)$ |
| OR | $8,16,32$ | Dn $\nu(E A) \rightarrow$ Dn <br> $(E A) \nu D n \rightarrow(E A)$ <br> $(E A) \nu \# x x x \rightarrow(E A)$ |
| EOR | $8,16,32$ | (EA) $\oplus D y \rightarrow(E A)$ <br> $(E A) \oplus \# x x x \rightarrow(E A)$ |
| NOT | $8,16,32$ | $\sim(E A) \rightarrow(E A)$ |

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 \rightarrow-$ |
| ASR | 8, 16, 32 | $\longrightarrow \longrightarrow \mathrm{x} / \mathrm{C}$ |
| LSL | 8, 16, 32 | $x / C-\square-0$ |
| LSR | 8, 16, 32 | $0 \rightarrow \longrightarrow \mathrm{x} / \mathrm{C}$ |
| ROL | 8, 16, 32 |  |
| ROP | 8, 16, 32 | $\rightarrow \longrightarrow \mathrm{C}$ |
| ROXL | 8, 16, 32 | $c \sqrt{4}$ |
| ROXR | 8, 16, 32 |  |

Table 17. Bit Manipulation Operations

| Instruction | Operand Size | Operation |
| :---: | :---: | :---: |
| BTST | 8,32 | $\sim$ bit of (EA) $\rightarrow$ Z |
| BSET | 8,32 | $\sim$ bit of $(E A) \rightarrow Z$ <br> $1 \rightarrow$ bit of EA |
| BCLR | 8,32 | $\sim$ bit of (EA) $\rightarrow Z$ <br> $0 \rightarrow$ bit of EA |
| BCHG | 8,32 | $\sim$ bit of (EA) $\rightarrow Z$ <br> $\sim$ bit of $(E A) \rightarrow$ bit of EA |
| NOTE: $\sim=$ invert |  |  |

## 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
Ml - 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}+\mathrm{Dy}_{10}+\mathrm{X} \rightarrow \mathrm{Dx}$ <br> $-(\mathrm{Ax})_{10}+-(\mathrm{Ay})_{10}+\mathrm{x} \rightarrow(\mathrm{Ax})$ |
| SBCD | 8 | $\mathrm{D} x_{10}-\mathrm{D} \mathrm{y}_{10}-\mathrm{X} \rightarrow \mathrm{Dx}$ <br> $-(\mathrm{Ax})_{10}--(\mathrm{Ay})_{10}-\mathrm{X} \rightarrow(\mathrm{Ax})$ |
| NBCD | 8 | $0-(\mathrm{EA})_{10}-\mathrm{X} \rightarrow(\mathrm{EA})$ |
| NOTE: $-(\quad)=$ indırect 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 |
| DBCC | Set byte conditionally (16 conditions) |
| SCC | Branch always <br> 8- and 16-bit displacement <br> Branch to subroutine <br> 8- and 16-bit displacement |
| Bnconditional <br> BRA | 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 enclosed in parenthesis following the execution periods and is shown as ( $r / w$ ) where $r$ is the number of read cycles and $w$ is the number of write cycles.

Table 21. Effective Addressing Mode Categories

| Effective <br> Address Modes | Mode | Register | Addressing Categories |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Data | Memory | Control | Alterable |
| Dn <br> An <br> (An) | $\begin{aligned} & 000 \\ & 001 \\ & 010 \end{aligned}$ | Register Number Register Number Register Number | $\frac{x}{x}$ | $\overline{-}$ | $\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} & X \\ & X \\ & X \end{aligned}$ | $\begin{aligned} & X \\ & X \\ & X \end{aligned}$ | $\overline{-}$ | $\begin{aligned} & X \\ & X \\ & X \end{aligned}$ |
| $\begin{aligned} & d(A n, i x) \\ & x x x \cdot W \\ & x x x . 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} & X \\ & X \\ & X \end{aligned}$ | $\begin{aligned} & X \\ & X \\ & 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}$ | 010 <br> 011 <br> X | $\begin{aligned} & X \\ & X \\ & X \end{aligned}$ | $\begin{aligned} & X \\ & X \\ & X \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & \mathrm{x} \end{aligned}$ | - |

Table 22. Instruction Set

| Mnemonic | Description | Operation | Condition Codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | X | N | z | v | C |
| ABCD | Add Decimal with Extend | (Destination) $10+$ (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) $+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 | * | * | * | * | * |
| $B_{C C}$ | 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$ <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{DBCC}^{\text {c }}$ | Test Condition, Decrement and Branch | If $\sim$ CC then $\mathrm{Dn}-1 \rightarrow \mathrm{Dn}$; if $\mathrm{Dn} \neq-1$ then 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:

```
\Lambda = logical AND
* = affected
\nu = logical OR
= logical exclusive OR
~ = logical complement
- = unaffected
O = cleared
1 = set
U = undefined
```

Table 22. Instruction Set (Continued)

| Mnemonic | Description | Operation | Condition Codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | X | N | 2 | v | c |
| EORI to SR | Exclusive OR Immediate to Status Register | (Source) $\oplus$ SR $\rightarrow$ SR | * | * | * | * | * |
| EXG | Exchange Register | $\mathrm{R} x \rightarrow \mathrm{Ry}$ | - | - | - | - | - |
| EXT | Sign Extend | (Destination) Sign-Extended $\rightarrow$ Destination | - | * | * | 0 | 0 |
| JMP | Jump | Destination $\rightarrow$ PC | - | - | - | - | - |
| JSR | Jump to Subroutine | $P C \rightarrow-(S P)$; Destination $\rightarrow P C$ | - | - | - | - | - |
| LEA | Load Effective Address | $\langle\theta a>\rightarrow A n$ | - | - | - | - | - |
| 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 | $S R \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) $\rightarrow$ Destination | - | - | - | - | - |
| MOVEQ | Move Quick | Immediate Data $\rightarrow$ Destination | - | * | * | 0 | 0 |
| MULS | Signed Mulkiply | (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-\mathrm{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 \mathrm{CCR} \rightarrow$ CCR | * | * | * | * | * |
| ORI to SR | Inclusive OR Immediate to Status Register | (Source) $\nu \mathrm{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: |  |  |  |  |  |  |  |

## NOTES:

Table 22. Instruction Set (Continued)

| Mnemonic | Description | Operation | Condition Codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | x | N | z | $V$ | C |
| ROXL, ROXR | Rotate with Extend | (Destınation) Rotated by <count> $\rightarrow$ Destination | * | * | * | 0 | * |
| RTE | Return from Exception | $(S P)+\rightarrow S R ; ~(S P)+\rightarrow P C$ | * | * | * | * | * |
| RTR | Return and Restore Condition Codes | $(\mathrm{SP})+\rightarrow \mathrm{CC} ;(\mathrm{SP})+\rightarrow \mathrm{PC}$ | * | * | * | * | * |
| RTS | Return from Subroutine | (SP) $+\rightarrow \mathrm{PC}$ | - | - | - | - | - |
| SBCD | Subtract Decimal with Extend | (Destination) $10-(\text { Source })_{10} 0-X \rightarrow$ Destination | * | $\cup$ | * | $\cup$ | * |
| SCC | Set Accordıng to Condition | If CC then 1's $\rightarrow$ Destınation else 0's $\rightarrow$ Destınation | - | - | - | - | - |
| STOP | Load Status Register and Stop | Immediate Data $\rightarrow$ SR; STOP | * | * | * | * | * |
| SUB | Subtract Bınary | (Destination) - (Source) $\rightarrow$ Destination | * | * | * | * | * |
| SUBA | Subtract Address | (Destınation) - (Source) $\rightarrow$ Destınation | - | - | - | - | - |
| SUBI | Subtract Immediate | (Destınation) - Immediate Data $\rightarrow$ Destınation | * | * | * | * | * |
| SUBQ | Subtract Quick | (Destınatıon) - Immedıate Data $\rightarrow$ Destınatıon | * | * | * | * | * |
| SUBX | Subtract with Extend | (Destination) - (Source) - X 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); SR $\rightarrow$ - (SSP); (Vector) $\rightarrow$ PC | - | - | - | - | - |
| TRAPV | Trap on Overflow | If $\nu$ then TRAP | - | - | - | - | - |
| TST | Test and Operand | (Destınation) Tested $\rightarrow$ CC | - | * | * | 0 | 0 |
| UNLK | Unlınk | $A n \rightarrow S P ;(S P)+\rightarrow A n$ | - | - | - | - | - |

## NOTES:

| $[\mathrm{l}$ | $=$ bit number |  | $=$ affected |
| ---: | :--- | ---: | :--- |
| $\Lambda$ | $=$ logical AND |  | $-=$ unaffected |
| $\nu$ | $=$ logical OR |  | $=$ cleared |
|  |  | $=$ logical exclusive OR |  |
| $\sim$ | $=$ set |  |  |
| $\sim$ | $=$ logical complement | $U$ | $=$ undefined |

## 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{A} n=$ 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}$ | Register <br> 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} \hline 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 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{gathered} 14(3 / 0) \\ 8(2 / 0) \end{gathered}$ |
| *The size of the index register ( I ) 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{lx})^{*}$ | 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 ihose of the effective adress calculation where indicated.

In Table 27, the headings have the following meanings: \# = immediate operand, $\mathrm{Dn}=$ data register operand, A $n=$ address register operand, $M=$ memory operand, and 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 (r/w). The number of clock periods and the number of read and write cycles must be added respectively to those of the effective address calculation where indicated.

Table 25. Move Long Instruction Clock Periods

| Source | Destination |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Dn | An | (An) | (An) + | -(An) | d(An) | d(An, ix)* | 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) |

*The size of the index register (ix) does not affect execution tıme.

Table 26. Standard Instruction Clock Periods

| Instruction | Size | op<ea>, An $\dagger$ | 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) ${ }^{\star * *}$ | 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 maxımum 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: $\mathrm{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

| Instruction | Size | op \#, Dn | op \#, An | op \#, M |
| :---: | :---: | :---: | :---: | :---: |
| ADDI | Byte, Word | 8(2/0) | - | 12(2/1) + |
|  | Long | 16(3/0) | - | 20(3/2) + |
| ADDQ | Byte, Word | 4(1/0) | 8(1/0)* | $8(1 / 1)+$ |
|  | Long | 8(1/0) | 8(1/0) | 12(1/2) + |
| ANDI | Byte, Word | 8(2/0) | - | 12(2/1) + |
|  | Long | 16(3/0) | - | 20(3/1) + |
| CMPI | Byte, Word | 8(2/0) | - | $8(2 / 0)+$ |
|  | Long | 14(3/0) | - | 12(3/0) + |
| EORI | Byte, Word | 8(2/0) | - | 12(2/1) + |
|  | Long | 16(3/0) | - | 20(3/2) + |
| MOVEQ | Long | 4(1/0) | - | - |
| ORI | Byte, Word | 8(2/0) | - | 12(2/1) + |
|  | Long | 16(3/0) | - | 20(3/2) + |
| SUBI | Byte, Word | 8(2/0) | - | 12(2/1) + |
|  | Long | 16(3/0) | - | 20(3/2) + |
| SUBQ | Byte, Word | 4(1/0) | 8(1/0)* | $8(1 / 1)+$ |
|  | Long | 8(1/0) | 8(1/0) | 12(1/2) + |

+ add effective address calculation tıme
* word only

Table 28. Single Operand Instruction Clock Periods

| Instruction | Size | Register | Memory |
| :---: | :---: | :---: | :---: |
| CLR | Byte, Word | 4(1/0) | 8(1/1) + |
|  | Long | 6(1/0) | 12(1/2)+ |
| NBCD | Byte | 6(1/0) | $8(1 / 1)+$ |
| NEG | Byte, Word | 4(1/0) | $8(1 / 1)+$ |
|  | Long | 6(1/0) | 12(1/2)+ |
| NEGX | Byte, Word | 4(1/0) | $8(1 / 1)+$ |
|  | Long | 6(1/0) | 12(1/2)+ |
| NOT | Byte, Word | 4(1/0) | $8(1 / 1)+$ |
|  | Long | 6(1/0) | 12(1/2)+ |
| $\mathrm{S}_{\mathrm{CC}}$ | Byte, False | 4(1/0) | $8(1 / 1)+$ |
|  | 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) + |
|  | 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: ( $\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.

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

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

Table 29. Shift/Rotate Instruction Clock Periods

| Instruction | Size | Register | Memory |
| :---: | :---: | :---: | :---: |
| ASR, ASL | Byte, Word | $6+2 n(1 / 0)$ | $8(1 / 1)+$ |
|  | Long | $8+2 n(1 / 0)$ | - |
| LSR, LSL | Byte, Word | $6+2 n(1 / 0)$ | $8(1 / 1)+$ |
|  | Long | $8+2 \mathrm{n}(1 / 0)$ | - |
| ROR, ROL | Byte, Word | $6+2 n(1 / 0)$ | $8(1 / 1)+$ |
|  | Long | $8+2 \mathrm{n}(1 / 0)$ | - |
| ROXR, ROXL | Byte, Word | $6+2 n(1 / 0)$ | $8(1 / 1)+$ |
|  | Long | $8+2 n(1 / 0)$ | - |
| + add effective address calculation time <br> n is shift 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)$ | $\mathbf{8 ( 1 / 0 )}$ |
|  | Word | $10(2 / 0)$ | $12(2 / 0)$ |
| BSR | Byte | $10(2 / 0)$ | - |
|  | Word | $10(2 / 0)$ | - |
|  | Byte | $18(2 / 2)$ | - |

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(2/0) | 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) \\ & \hline \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{gathered} 8+4 n \\ (2 / n) \end{gathered}$ | - | $\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 n \\ & (2 / 2 n) \end{aligned}$ | I | $\begin{aligned} & 8+\mathbf{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 periode includes the time to fetch both operands, perform the operations, store the results, and read the next instructions. The number of read and write cycles is shown in parenthesis as: (r/w).

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

Table 33. Multi-Precision Instruction Clock Periods

| Instruction | Size | op Dn, Dn | op $\mathbf{M}, \mathbf{M}$ |
| :---: | :--- | :---: | :---: |
| ADDX | Byte, Word | $\mathbf{4}(1 / 0)$ | $18(3 / 1)$ |
|  | Long | $8(1 / 0)$ | $30(5 / 2)$ |
| CMPM | Byte, Word | - | $12(3 / 0)$ |
|  | Lorg |  | $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: $(\mathrm{r} / \mathrm{w})$. The number of clock periods plus the number of read and write cycles must be added to those of the effective address calculation where indicated.

## EXCEPTION PROCESSING CLOCK PERIODS

Table 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 | 4(1/0) | - | UNLK | - | 12(3/0) | - |
| + add effectıve address calculation tıme |  |  |  |  |  |  |  |

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{\text { 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{TSTG}^{\mathrm{C}}$ | -56 to 150 | ${ }^{\circ} \mathrm{C}$ |

## THERMAL CHARACTERISTICS

| Characteristic | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Thermal Resistance | $\theta_{\mathrm{JA}}$ |  |  |
| 64-Pın Ceramic |  | 30 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| 64-Pın Plastıc 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 hıgher than maxımum-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 VSS or VCC.

## 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 & \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{P}_{I N T}+\mathrm{P}_{\mathrm{I} / \mathrm{O}} \\
\mathrm{P}_{I N T} \equiv & \mathrm{ICC} \cdot \mathrm{~V}_{\mathrm{CC}}, \text { Watts-Chip Internal Power } \\
\mathrm{P}_{\mathrm{I} / \mathrm{O}} \equiv & \text { Power Dissipation on Input and Output Pins- } \\
& \text { User Determined }
\end{aligned}
$$

For most applications $\mathrm{P}_{\mathrm{I} / \mathrm{O}}<\mathrm{P}_{\mathrm{INT}}$ and can be neglected.
An approximate relationship between $\mathrm{PD}_{\mathrm{D}}$ and $\mathrm{TJ}_{\mathrm{J}}$ (if $\mathrm{P}_{\mathrm{l}} / \mathrm{O}$ is neglected) is:

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

Solving equations 1 and 2 for $K$ gives:

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

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

## DC ELECTRICAL CHARACTERISTICS

$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}_{\mathrm{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 }}$ | VSS - 03 | 0.8 | V |  |
| Input Leakage Current <br> $\overline{B E R R}, \overline{B G A C K}, \overline{B R}, \overline{D T A C K}, C L K, \overline{\text { PLO }}-\overline{\mathrm{P} L 2}$ $\overline{\mathrm{VPA}}, \mathrm{HALT}, \overline{R E S E T}$ | IN | - | $\begin{aligned} & 2.5 \\ & 20 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mu \mathrm{A} \\ & \mu \mathrm{~A} \end{aligned}$ | $\begin{aligned} & V_{I N}=525 \\ & V_{C C}=O V \end{aligned}$ |
| Three-State (Off State) Input Current AS, A1-A23, D0-D15, FC0-FC2, $\overline{L D S}, R \bar{W}, \overline{U D S}, \overline{V M A}$ | ITSI | - | 20 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=04 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage <br> E* <br> E, $\overline{A S}, \mathrm{~A} 1-\mathrm{A} 23, \overline{\mathrm{BG}}, \mathrm{D} 0-\mathrm{D} 15, \mathrm{FC} 0-\mathrm{FC} 2, \overline{\mathrm{LDS}}, \mathrm{R} / \overline{\mathrm{W}}, \overline{\mathrm{UDS}}, \overline{\mathrm{VMA}}$ | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{gathered} \mathrm{V}_{\mathrm{CC}}-0.75 \\ 2.4 \\ \hline \end{gathered}$ | - | $\begin{aligned} & \mathrm{V} \\ & \mathrm{v} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{IOH}=-400 \mu \mathrm{~A} \end{aligned}$ |
| Output Low Voltage HALT $\overline{B G}$, FC0-FC2, A1-A23 RESET $\overline{A S}, ~ D 0-D 15, \overline{L D S}, R / \bar{W} \overline{U D S}, \overline{V M A}$ | VOL | $\begin{aligned} & - \\ & \text { - } \\ & \text { - } \end{aligned}$ | $\begin{aligned} & 06 \\ & 0.5 \\ & 0.5 \\ & 0.5 \\ & \hline \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \\ & v \end{aligned}$ | $\begin{aligned} & \mathrm{VCC}=475 \mathrm{~V} \\ & (\mathrm{IOL}=16 \mathrm{~mA}) \\ & (\mathrm{IOL}=3.2 \mathrm{~mA}) \\ & (\mathrm{lOL}=5.0 \mathrm{~mA}) \\ & (\mathrm{lOL}=5.3 \mathrm{~mA}) \\ & \hline \end{aligned}$ |
| Power Dissipation | $\mathrm{PD}^{* * *}$ | - | 1.5 | W |  |
| Input Capacitance | $\mathrm{ClN}^{\text {N }}$ | - | 20.0 | pF | $\begin{aligned} & V_{C C}=5.0 \mathrm{~V}, V_{I N}=O \mathrm{~V} \\ & f=1 \mathrm{MHz}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |

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


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 | $t_{\text {cyc }}$ | 250 | 500 | 167 | 500 | 125 | 500 | 100 | 500 | 80 | 250 | ns |
| Clock Pulse Width | $\begin{aligned} & { }^{\mathrm{t} \mathrm{CL}} \\ & \mathrm{t} \mathrm{CH} \end{aligned}$ | $\begin{aligned} & 115 \\ & 115 \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} & \mathrm{t}_{\mathrm{Cr}} \\ & \mathrm{t}_{\mathrm{f}} \end{aligned}$ | - | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | - | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | - | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | - | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | - | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | ns |



Figure 44. Input Clock Waveform

AC ELECTRICAL SPECIFICATIONS - READ AND WRITE CYCLES
$\left(V_{C C}=5.0 \mathrm{Vdc} \pm 5 \%, V_{S S}=0 \mathrm{Vdc} ; \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}\right.$ to $\mathrm{T}_{\mathrm{H}}$, 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 | tCL | 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 Tıme | ${ }^{\text {t }} \mathrm{Cf}$ | - | 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 | tclav | - | 90 | - | 80 | - | 70 | - | 60 | - | 55 | ns |
| 6A | Clock High to FC Valid | tCHFCV | - | 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 (Minımum) | tchazn | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 91 | Clock High to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low (Maxımum) | ${ }^{\text {t CHSLx }}$ | - | 80 | - | 70 | - | 60 | - | 55 | - | 55 | ns |
| 10 | Clock High to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ Low (Mınımum) | tCHSLn | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| $11^{2}$ | Address to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ (Read) Low/AS Write | ${ }^{\text {t }}$ AVSL | 55 | - | 35 | - | 30 | - | 20 | - | 0 | - | ns |
| $11 \mathrm{~A}^{2}$ | FC Valid to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ (Read) Low/AS Write | tFCVSL | 80 | - | 70 | - | 60 | - | 50 | - | 40 | - | ns |
| $12^{1}$ | Clock Low to $\overline{\text { AS, }} \overline{\text { DS }}$ High | tCLSH | - | 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{\mathrm{AS}}$ Write | tSL | 535 | - | 337 | - | 240 | - | 195 | - | 160 | - | ns |
| $14 \mathrm{~A}^{2}$ | $\overline{\text { DS }}$ Width Low (Write) | tDWPW | 285 | - | 170 | - | 115 | - | 95 | - | 80 | - | ns |
| $15^{2}$ | $\overline{\text { AS, }} \overline{\text { DS }}$ Width High | ${ }_{\text {tS }}$ | 285 | - | 180 | - | 150 | - | 105 | - | 65 | - | ns |
| 16 | Clock High to $\overline{\mathrm{AS}}, \overline{\mathrm{DS}}$ High | ${ }^{\text {t }} \mathrm{CHSZ}$ | - | 120 | - | 100 | - | 80 | - | 70 | - | 60 | ns |
| $17^{2}$ | $\overline{\text { AS, }} \overline{\text { DS }}$ High to R/W High | ${ }^{\text {t }}$ SHRH | 60 | - | 50 | - | 40 | - | 20 | - | 10 | - | ns |
| 181 | Clock High to R/W High (Maxımum) | ${ }^{\text {t CHRHK }}$ | - | 90 | - | 80 | - | 70 | - | 60 | - | 60 | ns |
| 19 | Clock High to R/W High (Minımum) | ${ }^{\text {t }} \mathrm{CHRHn}$ | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 201 | Clock High to R/W Low | tchRL | - | 90 | - | 80 | - | 70 | - | 60 | - | 60 | ns |
| 20A ${ }^{6}$ | $\overline{\mathrm{AS}}$ Low to R/W Valid | tASRV | - | 20 | - | 20 | - | 20 | - | 20 | - | 20 | ns |
| $21^{2}$ | Address Valid to R/W Low | ${ }^{\text {t }}$ AVRL | 45 | - | 25 | - | 20 | - | 0 | - | 0 | - | ns |
| $21 \mathrm{~A}^{2}$ | FC Valid to R/W Low | tFCVRL | 80 | - | 70 | - | 60 | - | 50 | - | 30 | - | ns |
| $22^{2}$ | R/W Low to $\overline{\mathrm{DS}}$ Low (Write) | trLSL | 200 | - | 140 | - | 80 | - | 50 | - | 30 | - | ns |
| 23 | Clock Low to Data Out Valid | tCLDO | - | 90 | - | 80 | - | 70 | - | 55 | - | 55 | ns |
| 24 | Clock High to R/ $\bar{W}$, $\overline{\mathrm{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) | toosl | 55 | - | 35 | - | 30 | - | 20 | - | 15 | - | ns |
| 275 | Data In to Clock Low (Setup Time) | ${ }^{\text {t }}$ ICL | 30 | - | 25 | - | 15 | - | 10 | - | 10 | - | ns |
| 27A | Late $\overline{B E R R}$ Low to Clock Low (Setup Time) | ${ }_{\text {t }}$ BELCL | 45 | - | 45 | - | 45 | - | 45 | - | 45 | - | ns |
| $28^{2}$ | $\overline{\text { AS, }} \overline{\text { DS }}$ High to $\overline{\text { DTACK }}$ High | ${ }^{\text {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) | tSHDI | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 30 | $\overline{\text { AS, }} \overline{\text { DS }}$ High to $\overline{B E R R}$ High | ${ }^{\text {t SHBEH }}$ | 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 Tıme | ${ }^{\text {tr }}$ Hr,f | 0 | 200 | 0 | 200 | 0 | 200 | 0 | 200 | 0 | 200 | ns |
| 33 | Clock High to $\overline{\mathrm{BG}}$ Low | ${ }^{\text {t }}$ CHGL | - | 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{B R}$ High to $\overline{B G}$ High | $\mathrm{t}_{\text {BRHGH }}$ | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | 1.5 | 3.5 | Clk. Per. |
| 37 | $\overline{\text { BGACK Low to } \overline{\text { BG }} \text { High }}$ | tGALGH | 15 | 3.0 | 1.5 | 3.0 | 15 | 30 | 15 | 3.0 | 15 | 30 | Clk. Per. |
| 37A | $\overline{B G A C K}$ Low to $\overline{B R}$ High (to Prevent Rearbitration) | ${ }^{\text {t BGKBR }}$ | 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 GH }}$ | 15 | - | 15 | - | 15 | - | 15 | - | 1.5 | - | Clk. Per. |
| 40 | Clock Low to $\overline{\text { VMA }}$ Low | t CLVML | - | 90 | - | 80 | - | 70 | - | 70 | - | 70 | ns |
| 41 | Clock Low to E Transition | tcle | - | 100 | - | 85 | - | 70 | - | 55 | - | 45 | ns |
| 42 | E Output Rise and Fall Tıme | tEr,f | - | 25 | - | 25 | - | 25 | - | 25 | - | 25 | ns |
| 43 | $\overline{\text { VMA }}$ Low to E High | tVmLEH | 325 | - | 240 | - | 200 | - | 150 | - | 90 | - | ns |
| 44 | $\overline{\mathrm{AS}}$, $\overline{\mathrm{DS}}$ High to $\overline{\mathrm{VPA}}$ High | tSHVPH | 0 | 240 | 0 | 160 | 0 | 120 | 0 | 90 | 0 | 70 | ns |
| 45 | E Low to Address/VMA/FC Invalid | telal | 55 | - | 35 | - | 30 | - | 10 | - | 10 | - | ns |
| 46 | BGACK Width | ${ }^{\text {t BGL }}$ | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | 1.5 | - | Clk. Per |
| $47^{5}$ | Asynchronous Input Setup Time | ${ }^{\text {t }}$ ASI | 30 | - | 25 | - | 20 | - | 20 | - | 20 | - | ns |
| $48^{3}$ | 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 | ${ }_{\text {teH }}$ | 900 | - | 600 | - | 450 | - | 350 | - | 280 | - | ns |
| 51 | E Width Low | ${ }_{\text {tel }}$ | 1400 | - | 900 | - | 700 | - | 550 | - | 440 | - | ns |
| 52 | E Extended Rise Tıme | ${ }^{\text {t CIEHX }}$ | - | 80 | - | 80 | - | 80 | - | 80 | - | 80 | ns |
| 53 | Data Hold from Clock Hıgh | tCHDO | 0 | - | 0 | - | 0 | - | 0 | - | 0 | - | ns |
| 54 | Data Hold from E Low (Write) | teldoz | 60 | - | 40 | - | 30 | - | 20 | - | 15 | - | ns |
| 55 | R/W to Data Bus Impedance Change | trloo | 55 | - | 35 | - | 30 | - | 20 | - | 10 | - | ns |
| $56^{4}$ | HALT/RESET Pulse Width | thRPW | 10 | - | 10 | - | 10 | - | 10 | - | 10 | - | Clk. Per. |
| Notes: <br> 1. For a loadıng capacitance of less than or equal to 50 picofarads, subtract 5 nanoseconds from the value given in these columns. <br> 2. Actual value depends on clock period. <br> 3. If \#47 is satisfied for both $\overline{\mathrm{DTACK}}$ and $\overline{\mathrm{BERR}}, \# 48$ may be 0 nanoseconds. <br> 4. For power up, the MPU must be held in $\overline{R E S E T}$ 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. <br> 5 If the asynchronous setup tıme (\#47) requirements are satısfied the $\overline{\mathrm{TTACK}}$ 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. <br> 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} 2}$, AND $\overline{\mathrm{VPA}}$ GUARANTEES their recognition at the NEXT FALLING EDGE OF THE CLOCK.
2. $\overline{B R}$ needs fall at this time only in order to insure being recognized at the end of this bus cycle.
3. TIMING MEASUREMENTS ARE REFERENCED TO AND FROM A LOW VOLTAGE OF 0.8 VOLTS AND A HIGH VOLTAGE OF 2.0 VOLTS, UNLESS OTHERWISE NOTED.

Figure 45. Read Cycle Timing


NOTES:

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

Figure 46. Write Cycle Timing

AC ELECTRICAL SPECIFICATIONS - BUS ARBITRATION
$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ}\right.$ 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 | ${ }^{\text {t }} \mathrm{CHGL}$ | - | 90 | - | 80 | - | 70 | - | 60 | - | 50 | ns |
| 34 | Clock Hıgh to $\overline{B G}$ Hıgh | ${ }^{\text {t }} \mathrm{CHGH}$ | - | 90 | - | 80 | - | 70 | - | 60 | - | 50 | ns |
| 35 | $\overline{\mathrm{BR}}$ Low to $\overline{\mathrm{BG}}$ Low | ${ }^{\text {t }}$ BRLGL | 1.5 | 3.5 | 15 | 3.5 | 1.5 | 35 | 1.5 | 35 | 15 | 3.5 | Clk. Per |
| 36 | $\overline{B R}$ High to $\overline{B G}$ Hıgh | tBRHGH | 15 | 35 | 1.5 | 35 | 1.5 | 35 | 15 | 35 | 15 | 3.5 | Clk Per |
| 37 | $\overline{\text { BGACK }}$ Low to $\overline{\mathrm{BG}}$ Hıgh | tGALGH | 1.5 | 3.0 | 15 | 30 | 15 | 3.0 | 15 | 30 | 1.5 | 30 | Clk Per |
| 37A | $\overline{\text { BGACK Low to } \overline{B R} \text { High }}$ (to Prevent Rearbitration) | tBGKBR | 30 | - | 25 | - | 20 | - | 20 | - | 20 | - | ns |
| 38 | $\overline{\mathrm{BG}}$ Low to Bus High Impedance (with $\overline{\mathrm{AS}}$ High) | ${ }^{\text {t }} \mathrm{GLZ}$ | - | 120 | - | 100 | - | 80 | - | 70 | - | 60 | ns |
| 39 | $\overline{\text { BG Width Hıgh }}$ | ${ }^{\mathrm{t}} \mathrm{GH}$ | 15 | - | 15 | - | 1.5 | - | 15 | - | 15 | - | Clk Per |
| 46 | BGACK Width | ${ }^{\text {t }}$ BGL | 1.5 | - | 1.5 | - | 15 | - | 15 | - | 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. SETUṔ TIME FOR THE ASYNCHRONOUS INPUTS $\overline{B E R R}, \overline{B G A C K}, \overline{B R}, \overline{\text { DTACK, }} \overline{\mathrm{IPLO}}-\overline{\mathrm{IPL} 2}$, AND $\overline{\mathrm{VPA}}$ GUARANTEES THEIR RECOGNITION AT THE NEXT FALLING EDGE OF THE CLOCK.
2. WAVEFORM MEASUREMENTS FOR ALL INPUTS AND OUTPUTS ARE SPECIFIED AT: LOGIC HIGH=2.0 VOLTS, LOGIC LOW = 0.8 VOLTS

Figure 47. AC ELECTRICAL Waveforms - Bus Arbitration

## 64-PIN CERAMIC DUAL IN-LINE PACKAGE (DIP)



| DIM | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
| $\mathbf{A}$ | 80.52 | 82.04 | 3.170 | 3.230 |
| $\mathbf{B}$ | 22.25 | 2296 | 0.876 | 0904 |
| $\mathbf{C}$ | 305 | 432 | 0120 | 0170 |
| $\mathbf{D}$ | 038 | 053 | 0015 | 0021 |
| F | 076 |  | 140 | 0030 |
| $\mathbf{G}$ | 2.54 |  | BSC | 055 |
| $\mathbf{J}$ | 0.20 | 0.33 | 0.008 |  |
| $\mathbf{K}$ | 254 | 4.19 | 0.100 | 0.013 |
| $\mathbf{L}$ | 2261 | 23.11 | 0.890 | 0910 |
| $\mathbf{M}$ | - | $10^{\circ}$ | - | $10^{\circ}$ |
| $\mathbf{N}$ | 102 | 152 | 0040 | 0.060 |

## 64-PIN PLASTIC QUAD IN-LINE PACKAGE (QUIP)

| DIM | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
| A | 4110 | 41.61 | 1618 | 1638 |
| B | 17.02 | 1723 | 0.670 | 0690 |
| C | 356 | 4.58 | 0140 | 0180 |
| D | 0.48 | 056 | 0018 | 0022 |
| E1 | 1905 BSC |  | 0750 BSC |  |
| E2 | 23.50 BSC |  | 0925 BSC |  |
| G | 127 BSC |  | 0050 BSC |  |
| J | 018 | 033 | 0007 | 0013 |
| K1 | 292 | 318 | 0115 | 0125 |
| K2 | 483 | 534 | 0190 | 0210 |



## PACKAGE DIMENSIONS

## 68-PIN PLASTIC CHIP CARRIER (PCC)



| DIM | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
| A | 3683 | 3785 | 145 | 149 |
| A1 | 1829 | 1930 | 072 | 076 |
| A2 | 1803 | 1905 | 071 | 075 |
| A3 | 1372 | 1473 | 054 | 058 |
| A4 | 2311 | 2464 | 091 | 097 |
| A5 | 0203 | 0305 | 008 | 012 |
| b | 0457 TYP |  | 018 TYP |  |
| D | 2502 | 2527 | 985 | 995 |
| D1 | 2400 | 2426 | 945 | 955 |
| D2 | 2019 | 2045 | 795 | 805 |
| D3 | 2324 | 2350 | 915 | 925 |
| D4 | 2096 | 2121 | 825 | 835 |
| D5 | 2223 | 2248 | 875 | 885 |
| e | 127 BSC |  | 050 BSC |  |
| h | 143 TYP |  | 045 TYP |  |
| J | 0254 TYP | 010 TYP |  |  |
| $\alpha$ | $4^{\circ}$ TYP |  | $4^{\circ}$ TYP |  |
| $\alpha 1$ | $10^{\circ}$ TYP |  | $10^{\circ}$ TYP |  |
| $\alpha 2$ | $45^{\circ}$ TYP |  | $45^{\circ}$ TYP |  |
| R | 0889 TYP | 035 TYP |  |  |
| R1 | 0254 TYP | 010 TYP |  |  |

# R68265, R68465 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 R68265 interfaces to the $31 / 2^{\prime \prime}$ Sony Micro Floppy disk drive as well as $51 / 4^{\prime \prime}$ and $8^{\prime \prime}$ drives. The R68265 writes in the $31 / 2^{\prime \prime}$ Sony compatible format and can also read from disks formatted in IBM compatible format. Any combination of up to four $31 / 2^{\prime \prime}$, $51 / 4^{\prime \prime}$ and $8^{\prime \prime}$ drives can be interfaced to and controlled by the R68265. The R68265 is pin-compatible with, and electrically identical to, the R68465.

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 R68265/R68465 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 DDFDC 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>\section*{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

## FEATURES

- Address mark detection circuitry
- Software control of
-Track stepping rate
-Head load time
-Head unload time
- Writes in:
-IBM compatible (single- and double-density format (R68465)
-Sony compatible (EMCA) format (R68265)
- Reads
-IBM compatible format (R68265 and R68465)
-Sony compatible format (R68265)
- 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 68000 16-bit and 68008 8-bit asynchronous microprocessor bus
- Single phase 8 MHz clock
- Single +5 volt power supply

ORDERING INFORMATION

| Part Number | CLK Frequency | Temperature Range |
| :---: | :---: | :---: |
| R68265 _ |  |  |
| R68465 | 8 MHz | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
|  | age: $\mathrm{C}=$ Ceram |  |
|  | $\mathrm{P}=$ 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 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 low input places the DDFDC in the idle state and resets the output lines to the floppy disk drives to the low state. RESETdoes not affect the Step Rate Time (SRT), Head Unload Time (HUT) or Head Load Time (HLT) set by a specify command. If RDY goes high while RESET is low, the DDFDC will assert $\overline{R Q Q}$ within 1.024 ms . This interrupt can be cleared by issuing a Sense Interrupt Status command.
$\overline{\mathbf{C S}}$-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 $(\mathrm{R} / \overline{\mathrm{W}}=$ high $)$ or a write $(R \bar{W}=$ low $)$ operation. when $R S=$ low, the Status Register is selected. This register may only be read ( $R \bar{W}=$ high $)$; the state $R \bar{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{RQ}}$ 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{\text { DTACK }}$ 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 $\overline{\text { 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).

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 $\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—Voltage Controlled 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 CONTROL/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} /$ SEEK — Read Write/Seek. Mode selection signal to the FDD which controls the multiplexer from the multiplexed signals. When $\overline{\mathrm{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, 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.


Pin Diagram

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 Dlsk <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}}$ ).


Figure 2. R68265/R68465 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} / \overline{\mathrm{W}}$ and RS signals is shown below.

| RS | $\mathbf{R} / \overline{\mathbf{W}}$ | Function |
| :---: | :---: | :--- |
| 0 | 0 | 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 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.
$\overline{0} \quad$ Data Register is not ready.
1 Data Register is ready.
MSR
6 DIO -Data Input/Output.
$\overline{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. FDD 3 is not busy, DDFDC will accept read or write command.
FDD 3 is busy, DDFDC will not accept read or write command.

MSR
D2B -FDD 2 Busy.
$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

$\frac{1}{0}$ D1B -FDD 1 Busy. FDD 1 is not busy, DDFDC will accept read or write command.
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 | EC | NR | HD | US |  |
|  |  |  |  |  |  | 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.

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. |
| 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 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}, \mathrm{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

## 76 IC -Interrupt Code.

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.
    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).
STO
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 singlesided drive, this bit is also set.

STO
HD -Head Address. (At Interrupt).
Head Select 0.
Head Select 1.

STO
O US -Unit Selected. (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$ | $O R$ | 0 | $N D$ | $N W$ | $M A$ |

```
ST1
    7 EN -End of Track.
    0}\quad\mathrm{ No error.
    1 DDFDC attempted to access a sector beyond the last
        sector of a track.
ST1
    6}\quad\mathrm{ -Not Used. Always Zero.
ST1
    5 DE -Data Error.
        No error.
        DDFDC detected a CRC error in ID field or the Data field.
```


## ST1

4 OR -Overrun.
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 the Internal Data Register (IDR) 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.

DDFDC detected a write protect signal from FDD during execution of Write Data, Write Deleted Data or Format a Track commands.

## ST1

O MA $\quad$-Missing Address Mark.
$\frac{\text { 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} \quad$ 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.
$\overline{0}$ No "equal" condition during a scan command.
1 "Equal" condition satisfied during a scan command.
ST2
2 SN -Scan Not Satisfied.
No error.
1 DDFDC 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.
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 | US0 |

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

ST3
$\begin{array}{ll}\frac{7}{0} & \text { FLT } \\ 0 & \text { Fault (FLT) signal from the FDD is low. }\end{array}$
1 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

4 TRKO -Track 0.
$\overline{0} \quad$ Track 0 (TRKO) signal from the FDD is low.
1 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
2 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=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 $\overline{D O N E}$ signal. DONE 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 $\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 $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$.

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{aligned} & 1 \\ & 1 \end{aligned}$ | $0$ | $\begin{aligned} & 01 \\ & 02 \end{aligned}$ | $\begin{array}{lr} (256)(30)= & 7,680 \\ (512)(30)= & 15,360 \end{array}$ | 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 |
| $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & 02 \\ & 03 \end{aligned}$ | $\begin{array}{rr} (512)(16) & =8,192 \\ (1024)(16) & =16,384 \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 \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) |  |  |  |  |  |  |  |

## 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$, $\mathrm{H}, \mathrm{R}, \mathrm{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{\mathrm{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 ST0 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$

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

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 (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 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 ${ }^{\text { }}$ | 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 (MF $=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 ( N ) | No. of Sectors/Track (ST) | Gap Length (GPL) ${ }^{4}$ |  | Remarks |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  | Read/Write Command 1 | Format Command ${ }^{2}$ |  |
| 8" | FM | $\begin{array}{r} 128 \\ 256 \\ 512 \\ 1024 \\ 2048 \\ 4096 \\ \hline \end{array}$ | $\begin{aligned} & 00 \\ & 01 \\ & 02 \\ & 03 \\ & 04 \\ & 05 \end{aligned}$ | $\begin{aligned} & \hline \text { 1A } \\ & 0 \mathrm{~F} \\ & 08 \\ & 04 \\ & 02 \\ & 01 \\ & \hline \end{aligned}$ | 07 $0 E$ $1 B$ 47 $C 8$ $C 8$ | 1B <br> 2A <br> 3A <br> 8A <br> FF- <br> FF |  |
|  | MFM ${ }^{3}$ | $\begin{array}{r} 256 \\ 512 \\ 1024 \\ 2048 \\ 4096 \\ 8192 \end{array}$ | $\begin{aligned} & \hline 01 \\ & 02 \\ & 03 \\ & 04 \\ & 05 \\ & 06 \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \mathrm{~A} \\ & 0 \mathrm{~F} \\ & 08 \\ & 04 \\ & 02 \\ & 01 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline O E \\ & 1 B \\ & 35 \\ & 99 \\ & C 8 \\ & C 8 \\ & \hline \end{aligned}$ | $\begin{aligned} & 36 \\ & 54 \\ & 74 \\ & \mathrm{FF} \\ & \mathrm{FF} \\ & \mathrm{FF} \\ & \hline \end{aligned}$ | , |
| $51 / 4{ }^{\prime \prime}$ | 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 C8 C8 | $\begin{aligned} & 09 \\ & 19 \\ & 30 \\ & 87 \\ & \mathrm{FF} \\ & \mathrm{FF} \end{aligned}$ |  |
|  | MFM ${ }^{3}$ | $\begin{array}{r} 256 \\ 256 \\ 512 \\ 1024 \\ 2048 \\ 4096 \end{array}$ | $\begin{aligned} & \hline 01 \\ & 01 \\ & 02 \\ & 03 \\ & 04 \\ & 05 \\ & \hline \end{aligned}$ | $\begin{aligned} & 12 \\ & 10 \\ & 08 \\ & 04 \\ & 02 \\ & 01 \end{aligned}$ | OA 20 $2 A$ 80 $C 8$ $C 8$ | $\begin{aligned} & \text { OC } \\ & 32 \\ & 50 \\ & \text { FO } \\ & \text { FF } \\ & \text { FF } \end{aligned}$ |  |
| $31 / 2^{\prime \prime}$ | FM | $\begin{aligned} & 128 \\ & 256 \\ & 512 \end{aligned}$ | $\begin{aligned} & 00 \\ & 01 \\ & 02 \end{aligned}$ | $\begin{aligned} & 0 F \\ & 09 \\ & 05 \end{aligned}$ | $\begin{aligned} & 07 \\ & 0 E \\ & 1 B \end{aligned}$ | $\begin{aligned} & 1 B \\ & 2 A \\ & 3 A \end{aligned}$ |  |
|  | MFM ${ }^{3}$ | $\begin{array}{r} 256 \\ 512 \\ 1024 \end{array}$ | $\begin{aligned} & 01 \\ & 02 \\ & 03 \end{aligned}$ | $\begin{aligned} & 0 \mathrm{~F} \\ & 09 \\ & 05 \end{aligned}$ | $\begin{aligned} & O E \\ & 1 B \\ & 35 \end{aligned}$ | $\begin{aligned} & 36 \\ & 54 \\ & 74 \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.

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_{\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.

Table 6. Scan Status Codes

| Command | Status Register 2 |  | Comments |
| :--- | :---: | :---: | :---: |
|  | Bit 2 = SN | Bit 3 = SH |  |
| Scan Equal | 0 | 1 | $D_{\text {FDD }}=D_{\text {BUS }}$ |
|  | 1 | 0 | $D_{F D D} \neq D_{\text {BUS }}$ |
| Scan Low or Equal | 0 | 1 | $D_{\text {FDD }}=D_{\text {BUS }}$ |
|  | 0 | 0 | $D_{F D D}<D_{\text {BUS }}$ |
|  | 1 | 0 | $D_{F D D}>D_{\text {BUS }}$ |
| Scan High or Equal | 0 | 1 | $D_{\text {FDD }}=D_{\text {BUS }}$ |
|  | 0 | 0 | $D_{\text {FDD }}>D_{\text {BUS }}$ |
|  | 1 | 0 | $D_{\text {FDD }}<D_{\text {BUS }}$ |

If $\mathrm{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 Regıster 0 (ST0) |
| :---: | :---: | :--- |
|  | 2 | Status Register 1 (ST1) |
|  | 3 | Status Register 2 (ST2) |
| 4 | Track Number (T) |  |
| 2 | 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 four 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 $\overline{\mathrm{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 | 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 | US 1 | US0 |

Result Phase: None.

## SENSE INTERRUPT STATUS

Interrupt request $(\overline{\mathrm{RQ}})$ 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{IRQ}}$ 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.

The Sense Interrupt Status command is used in conjunction with the Seek and Recalibrate commands which have no result phase. When the disk drive has reached the desired head position the DDFDC asserts interrupt output. The host CPU must thenissue a Sense Interrupt Status command to determine the actual cause of the interrupt, which could be Seek End or a change in ready status from one of the drives (see example in Figure 3).

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

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

| Status Register 0 (ST0) Bits |  |  | Cause |
| :---: | :---: | :---: | :---: |
| Interrupt Code <br> (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 |

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


Figure 3. Sense Interrupt Status

## 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 | $\mathbf{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:

| $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:

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


NOTES

Figure 4. DDFDC and System Data Transfer Timing

## 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{IRQ}}$ low on pin 18. When the DDFDC is in Non-DMA mode, $\overline{\mathrm{RQ}}$ is asserted during the execution phase. When the DDFDC is in the DMA mode, $\overline{\mathrm{RQ}}$ is asserted at the result phase. The $\overline{\mathrm{IRQ}}$ signal is reset by a read ( $\mathrm{R} / \overline{\mathrm{W}}$ high) or write ( $\mathrm{R} / \overline{\mathrm{W}}$ low) of data to the DDFDC. A further explanation of the $\overline{\operatorname{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 (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 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{\operatorname{REQ}}$ as each byte of data is available to be read. The DMA controller responds to this request with both $\overline{\text { DACK }}$ low (DMA Acknowledge) and R $\bar{W}$ high (read). When DACK goes low the DMA Request is reset ( $\overline{R E Q}$ high). After the execution phase has been completed
$\overline{\mathrm{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{IRQ}}$ is reset high.

During a write command, the DDFDC asserts $\overline{\operatorname{REQ}}$ as each byte of data is required. The DMA controller responds to this request with $\overline{D A C K}$ low (DMA Acknowledge) and R $\bar{W}$ low (write). When $\overline{\mathrm{DACK}}$ goes low the DMA Request is reset ( $\overline{\mathrm{REQ}}$ 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{R} Q}$ 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 ( $N R=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.

## R68465 (FM MODE)

| FIELD | GAP 4a | sync | IAM | GAP 1 | sYnc | IDAM | CYL | HD | SEC | No | CRC | GAP 2 | SYNC | data am | DATA |  | GAP 3 | GAP 4b |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NO. OF BYTES | 40x | 6x |  | 26x | 6x |  |  |  |  |  |  | 11x | 6x |  | (1) | CRC | (1) |  |
| data | FF | 00 | FC | FF | 00 | FE |  |  |  |  |  | FF | 00 | FB OR F8 |  |  |  |  |

INDEX $\qquad$ REPEAT N TIMES $\qquad$
R68265 (FM MODE)

| FIELD | GAP 1 | SYNC | IDAM | CYL | HD | SEC | NO | CRC | GAP 2 | SYNC | DATA AM | DATA |  | GAP 3 | GAP 4 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NO OF BYTES | $16 \times$ | $6 \times$ |  |  |  |  |  |  | $11 \times$ | $6 \times$ |  | (1) | CRC | (1) |  |
| DATA | FF | 00 | FC |  |  |  |  |  | FF | 00 | FB OR F8 |  |  |  |  |

INDEX $\qquad$ REPEAT N TIMES

R68465 (MFM MODE)

| GAP 4a | SYNC | IAM |  | GAP 1 | SYNC | IDAM |  | CYL | HD | SEC | NO | CRC | GAP 2 | SYNC | DATA AM |  | DATA |  | GAP 3 | GAP 4b |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $80 \times$ | $12 \times$ | 3× |  | $50 \times$ | 12× | $3 \times$ |  |  |  |  |  |  | 22x | 12× | $3 \times$ | FB | (1) | CRC | (1) |  |
| 4E | 00 | C2 | FC | 4 E | 00 | A1 | FE |  |  |  |  |  | 4E | 00 | A1 | F8 |  |  |  |  |

INDEX $\qquad$ -_ REPEAT $N$ times

R68265 (MFM MODE)

| FIELD | GAP 1 | SYNC | 15904 |  | CYL | HD | SEC | No | CRC | GAP 2 | SYNC | DATA AM |  | DATA |  | GAP 3 | GAP 4 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NO. OF BYTES | $32 \times$ | 12× | 3× |  |  |  |  |  |  | 22x | $12 \times$ | 3× | FB | (1) | CRC | (1) |  |
| DATA | 4E | 00 | A1 | FE |  |  |  |  |  | 4 E | 00 | A1 | F8 |  |  |  |  |

INDEX $\qquad$ - REPEAT N TIMES $\qquad$

Figure 5. DDFDC Formats


Figure 6. DDFDC Formats


Figure 7. R68265/R68465 DDFDC Interface to R68000


CLK


Figure 8. Clock Timing


Figure 9. DDFDC Read Cycle Timing


Figure 10. DDFDC Write Cycle Timing


Figure 11. DMA Operation Timing


Figure 12. FDD Write Operation Timing


NOTE:
EITHER POLARITY DATA WINDOW IS VALID

Figure 13. FDD Read Operation Timing


Figure 14. Seek Operation Timing


Figure 15. Fault Reset Timing


Figure 17. Terminal Count Timing


Figure 16. Index Timing


Figure 18. 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 19. 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 | （817 or 3－1／2＂${ }^{\prime \prime}$ FDD） | ${ }_{\text {t }}^{\text {Cr }}$ | $\phi_{C Y}$ | 120 | 125 | 500 | ns | CLK $=8 \mathrm{MHz}$ |
|  |  |  | （5－1／4＂FDD） |  |  | － | 250 | － | ns | CLK $=4 \mathrm{MHz}$ |
|  | 2 | Clock High |  | $\mathrm{t}_{\text {ca }}$ | $\phi_{0}$ | 40 | － | － | ns | CLK $=8 \mathrm{MHz}$ |
|  | 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 }}$ | $\mathrm{t}_{\mathrm{RA}}$ | 0 | － | － | ns |  |
|  | 7 | $\overline{\text { CS }}$ High to Address Invalid |  | $\mathrm{t}_{\text {SHAX }}$ | $\mathrm{t}_{\text {AH }}$ | 0 | － | － | ns |  |
|  | 8 | $\overline{\text { CS High }}$ |  | $\mathrm{t}_{\text {SHSL }}$ | $\mathrm{t}_{\text {SH }}$ | 150 | － | － | ns |  |
|  | 9 | $\overline{\text { DTACK }}$ Low to Data Valid |  | tolov | $\mathrm{t}_{\text {RD }}$ | － | － | 90 | ns | $C_{L}=100$ |
|  | 10 | $\overline{\text { CS }}$ High to Output High Z |  | $\mathrm{t}_{\text {SHDZ }}$ | $\mathrm{t}_{\mathrm{DF}}$ | 20 | － | － | ns | $C_{L}=100$ |
|  | 11 | $\overline{\text { CS High to } \overline{\text { DTACK }} \text { High }}$ |  | $\mathrm{t}_{\text {SHOH }}$ | $\mathrm{t}_{\text {DTK }}$ | － | － | 120 | ns |  |
|  | 12 | Address Valid to R／W Low |  | $t_{\text {AVAL }}$ | $\mathrm{t}_{\text {ws }}$ | 20 | － | － | ns |  |
|  | 13 | R／̄W Low to $\overline{C S}$ Low |  | $t_{\text {RLSL }}$ | ${ }_{\text {twh }}$ | 80 | － | － | ns |  |
|  | 14 | $\overline{\text { CS Low Pulse Width }}$ |  | $\mathrm{t}_{\text {SLSH }}$ | $\mathrm{t}_{\text {SL }}$ | 250 | － | － | ns |  |
|  | 15 | Data Valid to $\overline{\mathrm{CS}}$ High |  | $\mathrm{t}_{\text {DVSH }}$ | $\mathrm{t}_{\text {DSU }}$ | 150 | － | － | ns |  |
|  | 16 | $\overline{\mathrm{CS}}$ High to Data Invalid |  | $\mathrm{t}_{\text {SHOZ }}$ | $\mathrm{t}_{\text {DHW }}$ | 5 | － | － | ns |  |
| 8 | 17 | $\overline{\mathrm{IRQ}}$ Delay from $\overline{\mathrm{CS}}$ High |  | $\mathrm{t}_{\text {LLSH }}$ | $\mathrm{t}_{\text {IRQ }}$ | － | － | 500 | $\mu \mathrm{S}$ | CLK $=8 \mathrm{MHz}$ |
|  | 18 | TXRQ Cycle Period |  | $\mathrm{t}_{\text {TaCY }}$ | $\mathrm{t}_{\text {TCY }}$ | 13 | － | － | ns |  |
|  | 19 | $\overline{\text { ACK }}$ Low to TXRQ Low |  | $\mathrm{t}_{\text {AKTH }}$ | $\mathrm{t}_{\text {ACK }}$ | － | － | 200 | $\mathrm{t}_{\mathrm{Cr}}$ |  |
|  | 19a | TXRQ High to $\overline{\text { ACK }}$ Low（Delay） |  | $\mathrm{t}_{\text {OHAL }}$ | $\mathrm{t}_{\text {MA }}$ | 200 | － | － | ns | $\mathrm{t}_{\mathrm{cy}}=125 \mathrm{~ns}$ |
|  | 20 | DONE Low Width |  | $\mathrm{t}_{\mathrm{NLNH}}$ | $\mathrm{t}_{\text {DONE }}$ | 1 | － | － | ns | CLK $=8 \mathrm{MHz}$ |
| 9 | 21 | WCK Cycle Time | （81 or 3－1／2＂${ }^{\prime \prime}$ FDD） | $\mathrm{t}_{\text {KCY }}$ | $\mathrm{t}_{\text {cr }}$ | 二 | 2 | － | ${ }_{\mu \mathrm{S}}^{\mu \mathrm{S}}$ | $\begin{aligned} & \text { MFM }=0 \\ & \text { MFM }=1 \end{aligned}$ |
|  |  |  | （5－1／4＂${ }^{\text {／}}$ FDD） |  |  | 二 | 4 | － | $\mu \mathrm{s}$ | $M F M=0$ |
|  | 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 }}$ | $\mathrm{t}_{\mathrm{f}}$ | － | － | 20 | ns |  |
|  | 25 | WCK High to PSO，PS1 Valid（Delay） |  | $\mathrm{t}_{\mathrm{KHPV}}$ | $\mathrm{t}_{\mathrm{CP}}$ | 20 | － | 100 | ns |  |
|  | 25a | WCK High to WE High（Delay） |  | t DHEN | $\mathrm{t}_{\text {cwe }}$ | 20 | － | 100 | ns |  |
|  | 26 | PSO，PS1 Valid to WDA High（Delay） |  | $\mathrm{t}_{\text {PVOH }}$ | $\mathrm{t}_{\mathrm{CD}}$ | 20 | － | － | ns |  |
|  | 27 | WDA High Width |  | $\mathrm{t}_{\text {DHDL }}$ | ${ }^{\text {w WD }}$ | $\mathrm{t}_{\mathrm{WCH}}-50$ | － | 100 | 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 | （87 ${ }^{\prime \prime}$ or 3－1／2＂${ }^{\prime \prime}$ FDD） | ${ }^{\text {tw }}$ WY ${ }^{\text {r }}$ | ${ }^{\text {t }}$ WCY | 二 | 2 | 二 | $\mu \mathrm{s}$ | $\begin{aligned} & \text { MFM }=0 \\ & \text { MRM }=1 \end{aligned}$ |
|  |  |  | （5－1／4＂FDD） |  |  | 二 | 4 <br> 2 | 二 | $\mu \mathrm{S}$ $\mu \mathrm{S}$ $\mu \mathrm{S}$ | $\begin{aligned} & \text { MFM }=0 \\ & \text { MFM }=1 \end{aligned}$ |
|  | 31 | RDW Valid to RDD High（Setup） |  | ${ }^{\text {t }}$ WVRH | ${ }^{\text {W }}$ WRD | 15 | － | － | ns |  |
|  | 32 | RDD Low to RDW Invalid（Hold） |  | $\mathrm{t}_{\text {RLWI }}$ | $\mathrm{t}_{\text {RDW }}$ | 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 }}$ | ${ }^{\text {t }}$ STD | 24 | － | － | $\mu \mathrm{S}$ |  |
|  | 41 | STP Low to US0，US1 Invalid（Hold） |  | $\mathrm{t}_{\text {TLux }}$ | $\mathrm{t}_{\text {STU }}$ | 5 | － | － | $\mu \mathrm{S}$ |  |
|  | 42 | STP High Width |  | $\mathrm{t}_{\text {THTL }}$ | ${ }^{\text {t }}$ STP | 6 | 7 | 8 | $\mu \mathrm{S}$ |  |
|  | 43 | STP Cycle Time |  | $\mathrm{t}_{\text {TCY }}$ | ${ }^{\text {ts }}$ | $33^{3}$ | － | note 1 | $\mu \mathrm{S}$ |  |
| 12 | 44 | FR High Width |  | $\mathrm{t}_{\text {FHFL }}$ | $\mathrm{t}_{\text {FR }}$ | 8 | － | 10 | $\mu \mathrm{S}$ |  |
| 13 | 45 | IDX High Width |  | $\mathrm{t}_{\mathrm{IHIL}}$ | $\mathrm{t}_{10 \mathrm{X}}$ | 10 | － | － | $\mathrm{t}_{\mathrm{Cr}}$ |  |
| 14 | 46 | DONE Low Width |  | $\mathrm{t}_{\text {THTL }}$ | $\mathrm{t}_{\text {TC }}$ | 1 | － | － | $\mathrm{t}_{\mathrm{Cr}}$ |  |
| 15 | 47 | RESET Low Width |  | $\mathrm{t}_{\text {RHRL }}$ | $\mathrm{t}_{\text {gST }}$ | 14 | － | － | $\mathrm{t}_{\mathrm{Cr}}$ |  |
| Notes： <br> 1． $\mathrm{t}_{\mathrm{SC}}=33 \mu \mathrm{smin}$ ．is for different drive units．In the case of the same unit， $\mathrm{t}_{\mathrm{sc}}$ 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}_{\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 |
| :---: | :---: |
| $\mathrm{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 |
| :--- | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{c}\text { Input Low Voltage } \\ \text { Logic } \\ \text { CLK and WCK }\end{array}$ | $\mathrm{V}_{\mathrm{IL}}$ | -0.5 | V |  |  |
| $\begin{array}{c}\text { Input HIgh Voltage } \\ \text { Logic } \\ \text { CLK and WCK }\end{array}$ | -05 |  |  |  |  |$)$

## 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}_{\mathrm{IN}(\mathrm{C})}$ | 20 | pF |
| Input | $\mathrm{C}_{\mathrm{IN}}$ | 10 | pF |
| Output | $\mathrm{C}_{\mathrm{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 |  |
| 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 |


|  | 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 |  |
| 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 | 0.020 | 0.040 |

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

| Part Number | Frequency | Temperature Range |
| :---: | :---: | :---: |
| R6856 |  |  |
| 4 MHz | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |  |
| Package: $\mathrm{C}=$ Ceramic |  |  |
| $\mathrm{P}=$ Plastic |  |  |
| Number of pins: 0 | $=40$ |  |
| 1 | $=48$ |  |



## NOTES:

1. R68560 ONLY.
2. R68561 ONLY.
3. $\overline{\text { 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{C S}$ input to access the internal registers. The address map for these registers is shown in Table 1.

D0 - D15-Data Lines. The bidirectional data lines transfer data between the MPCC and the MPU, memory or other peripheral device. D0 - D15 are used when connected to the 16-bit 68000 bus and operating in the MPCC word mode. D0 - D7 are used when connected to the 16 -bit 68000 bus or the 8 -bit 68008 bus and operating in the MPCC byte mode. The data bus is threestated when $\overline{\mathrm{CS}}$ is inactive. (See exceptions in DMA mode.)
$\overline{\mathbf{C S}}$-Chip Select. $\overline{\mathrm{CS}}$ low selects the MPCC for programmed transfers with the host. The MPCC is deselected when the $\overline{C S}$ input is inactive in non-DMA mode. $\overline{\mathrm{CS}}$ must be decoded from the address bus and gated with address strobe ( $\overline{\mathrm{AS}}$ ).
$\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.
$\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 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{\overline{D S}}$-Data Strobe (R68560). During a write (R/W low), the $\overline{\mathrm{DS}}$ positive transition latches data on data bus lines D0-D7 into the MPCC. During a read (R/W high), $\overline{\mathrm{DS}}$ low enables data from the MPCC to data bus lines D0-D7.
$\overline{\text { LDS }}$-Lower Data Strobe (R68561). During a write (R $\bar{W}$ low), the positive transition latches data on the data bus lines D0 - D7 (and on D8 - D15 if UDS is low) into the MPCC. During a read ( $\mathrm{R} / \overline{\mathrm{W}}$ high), $\overline{\text { LDS }}$ low enables data from the MPCC to D0 - D7 (and to D8-D15 if UDS 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.
$\overline{\text { UDS}}-$ Upper Data Strobe (R68561). When interfacing to a 16-bit data bus system such as the 68000, a low on control bus signal UDS enables access to the upper data byte on D8 - D15. A high on UDS disables access to D8-D15. Data is latched and enabled in conjunction with $\overline{\text { LDS }}$.
$\overline{\operatorname{IRQ}}$-Interrupt Request. The active low $\overline{\mathrm{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{\mathrm{IACK}}$ input indicates that the current bus cycle is an interrupt acknowledge cycle. When $\overline{\text { IACK }}$ is asserted the MPCC places an interrupt vector on the lower byte ( $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 $\overline{\text { RDSR }}$ output requests DMA service.
$\overline{\text { DACK }}-$ DMA Acknowledge. The $\overline{\text { DACK }}$ low input indicates that the data bus has been acquired by the DMAC and that the requested bus cycle is beginning.
$\overline{\text { DTC }}$-Data Transfer Complete. The $\overline{\text { DTC }}$ low input indicates that a DMA data transfer is complete. $\overline{\mathrm{DTC}}$ in response to a RDSR indicates that the data has been successfully stored in memory. $\overline{\mathrm{DTC}}$ in response to a $\overline{\mathrm{TDSR}}$ indicates that the data is present on the data bus for strobing into the MPCC. $\overline{\text { DTC }}$ is used in conjunction with $R \bar{W}$ to increment the TxFIFO or RxFIFO pointer.
$\overline{\text { DONE-Done. } \overline{\text { DONE }} \text { 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 $\overline{\text { TDSR }}$ will be stored to track with the data byte (lower byte for word transfer) through the TxFIFO.
$\overline{\text { RESET}}-$ Reset. $\overline{R E S E T}$ is an active low, high impedance input that initializes all MPCC functions. RESET must be asserted for at least 500 ns to initialize the MPCC.

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 purpose in nature, and is controlled by the RTSLVL bit in the SICR.
$\overline{\text { CTS }}-C l e a r ~ t o ~ S e n d . ~ T h e ~ C T S ~ a c t i v e ~ l o w ~ i n p u t ~ p o s i t i v e ~ t r a n s i-~$ tion and level are reported in the CTST and CTSLVL bits in the Serial Interface Status Register (SISR), respectively.
$\overline{\text { DSR-Data Set Ready. The } \overline{\mathrm{DSR}} \text { active low input negative }}$ transition and level are reported in the DSRT and DSRLVL bits in the SISR, respectively. $\overline{\mathrm{DSR}}$ is also an output for RSYN.
$\overline{\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.


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

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

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)


| Transmitter Control Register (TCR) | Transmitter Status Register (TSR) | R/W | 08 | 0 | 1 | 0 | 0 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Transmitter Data Register (TDR)-16 bits |  |  |  |  |  |  |  |
| Transmitter Interrupt Enable Register (TIER) |  | Transmitter Interrupt Vector Number Register (TIVNR) | R/W | OA | 0 | 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 | 1 A | 1 | 1 | 0 | 1 |
| Band Rate Divider Register 2 (BRDR2) | Baud Rate Divider Register 1 (BRDR1) | R/W | 1 C | 1 | 1 | 1 | 0 |
| Error Control Register (ECR) | Clock Control Register (CCR) | R/W | 1 E | 1 | 1 | 1 | 1 |

## Notes:

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

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) | RM | 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)²-8 bits | W | OA | 0 | 1 | 0 | 1 |
| Reserved ${ }^{3}$ |  | $0 B$ | 0 | 1 | 0 | 1 |
| Transmitter Interrupt Vector Number Register (TIVNR) | R/W | OC | 0 | 1 |  |  |
| Transmitter Interrupt Enable Register (TIER) | R/W | OD | 0 | 1 | 0 | 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 |  |
| 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 |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Protocol Select Register 2 (PSR2) | R/W | 19 | 1 | 1 | 0 | 0 | 1 |
| 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 C | 1 | 1 | 1 | 0 | 0 |
| Baud Rate Divider Register 2 (BRDR2) | R/W | 1 D | 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{\operatorname{RES}}$ resets the TXFIFO pointer to the start of the first byte.
3. Reserved registers may contain random bit values.

Table 2. MPCC Register Bit Assignments

| R/W Access | Bit Number |  |  |  |  |  |  |  | Reset ${ }^{(1)}$ Value | Receiver Status Register (RSR) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | 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 | 0 | 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} \hline \text { RDA } \\ \text { IE } \\ \hline \end{gathered}$ | $\begin{gathered} \mathrm{EOF} \\ \mathrm{IE} \\ \hline \end{gathered}$ | 0 | $\begin{array}{\|c} \hline \text { C/PERR } \\ \text { IE } \end{array}$ | $\begin{gathered} \hline \text { FRERR } \\ \text { IE } \\ \hline \end{gathered}$ | $\begin{array}{c\|} \hline \text { ROVRN } \\ \text { IE } \\ \hline \end{array}$ | $\begin{gathered} \mathrm{RA} / \mathrm{B} \\ \mathrm{IE} \\ \hline \end{gathered}$ | 0 | 00 | Receiver Interrupt Enable Register (RIER) |


| R/W | TDRA | TFC | 0 | 0 | 0 | TUNRN | TFERR | 0 | $\mathbf{8 0}$ |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W | TEN | TDSREN | TICS | THW | TLAST | TSYN | TABT | TRES | 01 | Transmitter Status <br> Register (TSR) <br> Transmitter Control <br> Register (TCR) |
| W | TRANSMITTED DATA (TXFIFO) |  |  |  |  |  |  |  |  |  |
| Transmitter Data |  |  |  |  |  |  |  |  |  |  |
| Register (TDR) |  |  |  |  |  |  |  |  |  |  |
| Transmitter Interrupt Vector |  |  |  |  |  |  |  |  |  |  |


| R/W | CTST | DSRT | DCDT | CTSLVL | DSRLVL | DCDLVL | 0 | 0 | 00 |  |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W | RTSLVL | DTRLVL | 0 | 0 | 0 | ECHO | TEST | 0 | 00 | Serial Interface Status <br> Register (SISR) <br> Serial Interface Control <br> Register (SICR) |
| (reserved) |  |  |  |  |  |  |  |  |  |  |


| R/W | 0 | 0 | 0 | 0 | 0 | 0 | CTLEX | ADDEX | 00 | Protocol Select Register 1 (PSR1) |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W | WD/BYT | STOP BIT SEL |  | CHAR LEN SEL |  | PROTOCOL SEL |  |  | 00 | Protocol Select Register 2 (PSR2) |
|  |  | SB2 | SB1 | CL2 | CL1 | PS3 | PS2 | PS1 |  |  |
| R/W | BOP ADDRESS/BSC \& COP PAD |  |  |  |  |  |  |  | 00 | Address Register 1 (AR1) |
| R/W | BOP ADDRESS/BSC \& COP SYN |  |  |  |  |  |  |  | 00 | Address Regıster 2 (AR2) |
| R/W | BAUD RATE DIVIDER (LSH) |  |  |  |  |  |  |  | 01 | Baud Rate Divider Register 1 (BRDR1) |
| R/W | BAUD RATE DIVIDER (MSH) |  |  |  |  |  |  |  | 00 | Baud Rate Divider Register 2 (BRDR2) |
| R/W | 0 | 0 | 0 | PSCDIV | TCLKO | RCLKIN | CLK SEL |  | 00 | Clock Control <br> Register (CCR) |
|  |  |  |  |  |  |  | CK2 | CK1 |  |  |
| R/W | PAREN | ODDPAR | 0 | 0 | CFCRC | CRCPRE | CRC SEL |  | 04 | Error Control Register (ECR) |
|  |  |  |  |  |  |  | CR2 | CR1 |  |  |

## Notes:

1. RESET $=$ Register contents upon power up or $\overline{\text { 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 | 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 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 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). 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

EOF -End of Frame.
$0 \quad$ 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 (D0-D7) of the data bus.
1 The lower half of the data bus (D0 - D7) contains the frame status but the upper half (D8 - D15) is blank or invalid.

## RSR

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

RSR
FRERR -Frame Error.
No frame error detected.
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.
Normal Operation.
ABORT detected after an opening flag (BOP), ENQ detected in a block of text data (BSC), or BREAK ended (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. 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

| D15 | D8 | D7 |
| :---: | :---: | :---: |
| $N$ | DATA | STATUS |
| $N+1$ | NEXT | FRAME |
| (RHW $=0)$ |  |  |


| WORD |
| :--- |
| D15 |
| $\mathbf{N}$ DATA D7 <br> DATA   <br> $\mathbf{N}+1$ BLANK STATUS <br> $\mathbf{N}+2$ NEXT FRAME |

(RHW = 1)

BYTE D7 DO

| $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 | 0 | RABEN | RRES |

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

RCR

| $\underline{7}$ | -Not used. |
| :---: | :---: |
| RCR |  |
| $\frac{6}{6}$ | RDSREN |
| R | -Receiver Data Service Request Enable. |
| 1 | Enable receiver DMA mode. |

RCR

| 4 | $\begin{array}{rr}\text { RSYNEN } & \text { RSYNEN Output Enable. Selects then } \\ \text { DSR signal input or the RSYN SYN }\end{array}$ signal output on the $\overline{\mathrm{DSR}}$ pin. |
| :---: | :---: |
| 0 | Input DSR on $\overline{\text { DSR }}$. |
| 1 | Output RSYN on $\overline{\text { DSR }}$. |
| RCR |  |
| 3 | STRSYN - Strip SYN Character (COP only). |
| 0 | Do not strip SYN character. |
| 1 | Strip SYN character. |

RCR
$\frac{2}{0}$ MUST BE ZERO

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 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 $\overline{\text { 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 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MSB |  |  | Byte 0 |  |  | LSB |  |

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 \mathrm{~F}$
If a receiver interrupt condition occurs (as reported by status bits in the RSR that correspond to interrupt enable bits in the RIER) and the corresponding bit is set in the RIER, $\overline{\mathrm{R} Q}$ output is asserted to request MPU receiver interrupt service. When the IACK input is asserted from the bus, the Receiver Interrupt Vector Number (RIVN) from the Receiver Interrupt Vector Number Register (RIVNR) is placed on the data bus.

Receiver Interrupt Enable Register (RIER)

| 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

| $\mathbf{6}$ | EOF IE |
| :--- | :--- |
| 0 | Disable EOF Interrupt. |
| 1 | Enable EOF Interrupt Enable. |

RIER

| $\underline{5}$ | -Not used. |
| :---: | :---: |
| RIER |  |
| $\frac{4}{0}$ | C/PERR IE -CRC/Parity Error Interrupt Enable. |
| $\mathbf{1}$ | Disable C/PERR Interrupt. |
| 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.
Disable ROVRN Interrupt.
Enable ROVRN Interrupt.
RIER
$\frac{1}{0}$ RA/B IE -Receiver Abort/Break Interrupt Enable.
Disable RA/B Interrupt.
Enable RA/B Interrupt.

## RIER

$0 \quad$-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 $\overline{\operatorname{RQ} Q}$ 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 $\quad$ Transmitter Data Register Available. |
| :--- | :--- |
| 1 | The TxFIFO is full. |
|  | Trant is not full (i.e., available) and data to |

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

| 7 | TEN | -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

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

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

## TCR

2 TSYN -Transmit SYN (BSC and COP only).

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.
$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 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| Byte 0 |  |  |  |  |  |  |  |

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 $\overline{\mathrm{RQ}}$ output is asserted to request MPU transmitter interrupt service. When the $\overline{\mathrm{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{IRQ}}$ output is asserted when the corresponding condition is detected and reported in the TSR.

## TIER

7 TDRA IE -Transmitter Data Register (TDR) Available Interrupt Enable.
Disable TDRA Interrupt.
1 Enable TDRA Interrupt.

## TIER

| 6 | TFC IE | -Transmit Frame Complete (TFC) Interrupt Enable. |
| :---: | :---: | :---: |
| 0 | Disable TFC Interrupt. <br> Enable TFC Interrupt. |  |
| 1 |  |  |
| TIER |  |  |
| 5-3 |  | -Not used. |
| TIER |  |  |
| 2 | TUNRN | -Transmitter Underrun (TUNRN) Interrupt Enable. |
| 0 | Disab | TUNRN Interrupt. |
| 1 | Enab | TUNRN Interrupt. |

TIER

| 1 | TFERR IE-Transmit Frame Error (TFERR) Interrupt <br> 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.

\section*{SISR <br> 7 CTST -Clear to Send Transition Status. <br> $\overline{\mathrm{CTS}}$ has transitioned positive (from active to inactive). (TRES must be zero). <br> $0 \quad$ CTS has not transitioned positive. <br> SISR <br> 6 DSRT -Data Set Ready Transition Status. <br> $1 \quad \overline{\mathrm{DSR}}$ has transitioned negative (from inactive to active). <br> $0 \quad \overline{\mathrm{DSR}}$ has not transitioned negative. <br> | SISR |  |  |
| :---: | :---: | :---: |
| $\frac{5}{1}$ | DCDT | -Data Carrier Detect Transition Status. |
| 0 | $\overline{\mathrm{DCD}}$ has transitioned positive (from active to inactive). |  |}

[^1]
## SISR

3 DSRLVL -Data Set Ready Level.
$\overline{0} \quad \overline{\mathrm{DSR}}$ input level is negated (high).
$1 \quad \overline{D S R}$ input level is asserted (low).
SISR
2 DCDLVL -Data Carrier Detect Level. $\overline{D C D}$ input level is negated (high). $\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 | 0 |

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. Negate RTS output (high). Assert $\overline{\mathrm{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{R T S}$ output is negated within two bit times.

SICR
6 DTRLVL -Data Terminal Ready Level.
$\overline{0} \quad$ Negate $\overline{\text { 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.
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).
Enable self-test. The transmitted data (TxD) and ciock (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 must be a 1.

## SICR

$\frac{0}{0}$ MUST bE ZERO

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{\text { IRQ output is asserted to request MPU serial interface interrupt }}$ service. When the 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{\mathrm{RQ}}$ output is asserted when the corresponding condition occurs as reported in the SISR.

| SIER |  |
| :---: | :---: |
| 7 | CTS IE -Clear to Send (CTS) Interrupt Enable. Disable CTS Interrupt. <br> Enable CTS Interrupt. |
| 0 |  |
| 1 |  |
| SIER |  |
| $\frac{6}{0}$ | DSR IE —Data Set Ready (DSR) Interrupt Enable. Disable DSR Interrupt. |
| 1 | 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.

## PSR1

7-2 -Not used.

## PSR1

$\frac{1}{0}$ CTLEX -Control Field Extend (BOP only).
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 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.

|  |  | No. of Stop Bits |  |
| :---: | :---: | :---: | :---: |
| $\mathbf{6}$ | 5 |  | $\frac{\text { ISOC }}{1}$ |
| $\frac{\text { SB2 }}{0}$ | $\frac{\text { SB1 }}{}$ | 0 |  |
| 0 | 1 |  | 1 |
| 0 | 0 | $1-1 / 2$ | 2 |
| 1 |  | 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 <br> CL2 | 3 <br> CL1 | Character Length <br> 0 |
| :---: | :---: | :---: |
| 0 | 1 | 5 bits |
| 1 | 0 | 6 bits |
| 1 | 1 | 7 bits |
|  |  | 8 bits |

## PSR2

2-0
PROTOCOL SEL-Protocol Select. Selects protocol and defines the protocol dependent control bits.

| 2 <br> PS3 <br> 0 | $\frac{1}{\text { PS2 }}$ | 0 <br> PS1 | Protocol |
| :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | BOP (Primary) |
| 0 | 1 | 1 | BOP (Secondary) |
| 0 | 1 | 0 | Reserved |
| 1 | 0 | 1 | COP |
| 1 | 0 | 1 | BSC EBCDIC |
| 1 | 1 | 0 | BSC ASCII |
| 1 | 1 | 1 | ASYNC |
| 1 | 1 |  |  |

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 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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 AR1 is used for address matching. In BSC and COP, AR1 and AR2 contain programmable leading PAD and programmable SYN characters, respectively.

Address Register (AR) Contents

| Protocol Selected | AR1 | AR2 |
| :--- | :---: | :---: |
| BOP (Primary) | $X$ | $\times$ |
| BOP (Secondary) | Address | $\times$ |
| BSC EBCDIC | Leading PAD | SYN |
| BSC ASCII | leading PAD | SYN |
| COP | Leading PAD | SYN |
| $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=1$ for isochronous or synchronous 2 for asynchronous

Clock Control Register (CCR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 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 fre-
        quency to a value for use by the internal
        Baud Rate Generator.
        Divide by }2
    1 Divide by 3.
CCR
\begin{tabular}{ll}
\(\frac{3}{0}\) & TCLKO -Transmitter Clock Output Seiect. \\
1 & Select TxC to be an input. \\
1 & Select TxC to be an output. (1X clock)
\end{tabular}
```

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 \text { ) } \end{aligned}$ | Decimal Value | Hexadecimal Value |  | Decimal Value | Hexadecimal Value |  |
|  |  |  |  | BRDR2 (MSH) | BRDR1 <br> (LSH) |  | 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 | 1 A | 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 | 8C | 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 | - | - | CFCRC | 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 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.
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. Preset CRC Generator to 0.
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
$\frac{\text { CR2 }}{0} \frac{\text { CR1 }}{0}$
$\frac{\text { Polynominal }}{x^{16}+x^{12}+x^{5}+1 \text { (CCITT V.41) }}$
$01 x^{16}+x^{15}+x^{2}+1$ (CRC-16)
$10 \quad x^{8}+1 \quad$ (VRC/LRC)*
11 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 | DTACK |
| Chip Select | $\overline{C S}$ | $\overline{\mathrm{CS}}$ |
| Data Strobes | $\overline{U D S}$ and $\overline{L D S}$ | $\overline{\text { DS }}$ |

Figures 10 and 11 show typical interface connections.

## 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 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{C S}$ must be decoded from the address bus and gated with address strobe ( $\overline{\mathrm{AS}}$ ).

When the R68561 is connected to the 16-bit bus for operation in the word mode (WD/BYT = 1 in the PSR2), address lines A1-A4 select the internal register(s) (the 8-bit control/status registers are accesed two at a time and the 16-bit data registers are accessed on even address boundaries). When the MPCC is selected ( $\overline{\mathrm{CS}}$ low) during a read ( $\mathrm{R} / \overline{\mathrm{W}}$ high), 16 bits of register data are placed on the data bus when the data strobes (LDS and $\overline{U D S}$ ) are asserted. $\overline{\text { LDS }}$ strobes the eight data bits from the even numbered registers to the lower data bus lines (D0-D7) and UDS strobes the eight data bits from the odd numbered registers to the upper data bus lines (D8-D15). The MPCC asserts Data Transfer Acknowledge (DTACK prior to placing data on the data bus. Conversely, when the MPCC is selected ( $\overline{\mathrm{CS}}$ low) during a write (R/W low) $\overline{L D S}$ and $\overline{U D S}$ strobe data from the D0-D7 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 (CS low) during a read ( $\mathrm{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 afserted. When the MPCC is selected ( $\overline{C S}$ low) for a write ( $R / \bar{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 ( $\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 (BOP and BSC) to initiate the MPCC to memory DMA transfer. For asynchronous operation, $\overline{\mathrm{RDSR}}$ is asserted for 2-3 periods of the system clock depending on prescale factor. The next $\overline{\text { RDSR }}$ cycle may be initiated as soon as the current $\overline{\text { RDSR }}$ cycle is completed (i.e., a full sequence of $\overline{\mathrm{DACK}}, \overline{\mathrm{DS}}$, and $\overline{\mathrm{DTC}}$ ).

In response to $\overline{\operatorname{RDSR}}$ assertion, the DMAC sets the $\bar{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 $\overline{\text { 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 ether 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. For asynchronous operation, $\overline{\text { TDSR }}$ is asserted for a period of one-half the transmitter baud rate. The next TDSR cycle may be initiated as soon as the current TDSR cycle is completed.
In the transmitter DMA mode, the TxFIFO Is implicitly addressed. That is, when the transfer is from memory to the TxFIFO, only the memory is addressed. In response to $\overline{\text { 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{T D S R}$ is inhibited when either TDSREN is reset to 0 or TRES is set to 1 (both in the TCR), or when RESET is asserted.

## DONE Signal

When the DMA transfer count is exhausted in transmitter DMA mode, the DMAC asserts DONE which sets the TLAST bit in the TCR to indicate that the last word/byte has been transferred. In the receiver DMA mode, $\overline{\text { DONE }}$ is asserted by the MPCC coincident with DACK 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.

## CAUTION

$\overline{\mathrm{DONE}}$ is reasserted with each occurrence of $\overline{\mathrm{DACK}}$ until EOF is cleared in the RSR.

## INTERRUPTS

If an interrupt generating status occurs and the interrupt is enabled, the MPCC asserts the $\overline{\mathrm{IRQ}}$ output. Upon receiving $\overline{\mathrm{IACK}}$ for the pending interrupt request, the MPCC places an interrupt vector on D0-D7 data bus and asserts DTACK.

The MPCC has three vector registers: Receiver Interrupt Vector Number Register (RIVNR), Transmitter Interrupt Vector Number Register (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 D0-D7 when acknowledged by the MPU. Upon completion of the first interrupt request cycle (which clears the receiver interrupt), $\overline{\mathrm{IRQ}}$ 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.

## CAUTION

A higher priority interrupt occurring while $\overline{\mathrm{IACK}}$ is low during transfer of a lower priority interrupt vector to the MPU will cause the lower priority interrupt vector on the data bus to be invalid if there are any 1 's in the higher priority interrupt vector in the same bit positions as any 0's in the lower priority interrupt vector. To prevent this problem from occurring, ensure that the higher priority interrupt vectors contain 1's only in bit positions where there are 1's in the lower priority interrupt vectors, e.g.:

| Vector | Vector Value (Hex) | Vector Value (Binary) |
| :---: | :---: | :---: |
| Receiver Interrupt Vector Number (RIVN) | 44 | 01000100 |
| Transmitter Interrupt Vector Number (TIVN) | 4 C | 01001100 |
| Serial Interrupt Vector Number (SIVN) | 5C | 01011100 |

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{R T S}$ 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 $\overline{R T S}$ 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{\mathrm{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{\mathrm{CTS}}$ input signal is normally generated by the DCE to indicate whether or not the data set is ready to receive data. The CTST bit in the SISR reflects the transition status of the CTS input while the CTSLVL bit in the SISR reflects the current level. A positive transition on the $\overline{\mathrm{CTS}}$ pin asserts $\overline{\mathrm{RQ}}$ if the CTS IE bit in the SIER is set. The CTS input in an inactive state disables the start of transmission of each frame.

## $\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{R R Q}$ output if the DCD IE bit in the SIER is set. A negated $\overline{\mathrm{DCD}}$ input disables the start of the receiver but does not stop the operation of an incoming message already in progress.

## $\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{D S R}$ input while the DSRLVL bit in the SISR reports the current level. A negative transition on the $\overline{\operatorname{DSR}}$ 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 $\overline{D S R}$ pin. In this mode, $\overline{\text { DSR }}$ output low indicates detection of SYN in BSC or COP, or an address match in BOP.

## $\overline{\text { 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 (†ransmitter 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 negativegoing edge of $T \times C$ and the received data on $R \times D$ 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 100K 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


Figure 4. Asynchronous and Isochronous Frame Format
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 $R \times D$ and the serial data bit is latched on the falling edge of each clock pulse. The requirement for the detection of a valid start bit, or the beginning of a break, is satisfied by the detection of a high-to-low transition on the serial data input line. Error detection and status indication are the same as the asynchronous mode.

## Asynchronous and Isochronous Transmit

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

## 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 . The first byte of the address field is automatically checked when the MPCC is programmed to be a secondary station in BOP. An automatic check for global (11111111) or null (00000000) address is also
made. The control field of one or two bytes is transparent to the MPCC and sent directly to the host without interpretation.

The optional information field consists of 8-bit characters. Cyclic redundancy checking is used for error detection and the CRC remainder resulting from the calculation is transmitted as the frame check sequence field. For BOP, the polynomial $X^{16}+X^{12}$ $+X^{5}+1$ (CRC-CCITT) should be used, i.e., selected in the CRC SEL bits in the ECR. The registers representing the CRC-CCITT polynomial are generally preset to all 1 s , and the 1 s complement of the resulting remainder is transmitted. (See X. 25 Recommendation.)

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

| FLAG | ADDRESS | CONTROL | INFORMATION | FCS |
| :--- | :--- | :--- | :--- | :--- |
| 01111110 | 1 OR N |  |  |  |
|  | BYTES |  |  |  |

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

| FLAG | ADDRESS | CONTROL | INFORMATION | FCS |  |
| :--- | :--- | :--- | :--- | :--- | :--- |
| 01111110 | 1 BYTE | 1 BYTE | N BYTES | 2 BYTES | 01111110 |

ADCCP/HDLC FRAME FORMAT

| FLAG | ADDRESS | CONTROL | INFORMATION | FCS |
| :--- | :--- | :--- | :--- | :--- |
| 01111110 | N BYTES | N OR | BYTES | 2 BYTES |

Figure 6. Implemented Bit Oriented Protocols

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 the first byte. 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 Flags or marks until a new sequence is initiated.

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

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

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

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

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

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

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 | 1F | - |  |
| EOT | 04 | - | EOT | 37 | - |  |
| ACK N* | 10 | $30-37$ | ACK 0 | 10 | 70 |  |
| NAK | 15 | - | ACK 1 | 10 | 61 |  |
| WACK | 10 | 3B | NAK | $3 D$ | - |  |
| RVI | 10 | 3C | WACK | 10 | $6 B$ |  |
|  |  |  | RVI | 10 | $7 C$ |  |

Note: *Programmable

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 <br> PAD <br> 11111111 |
| :--- | :--- | :--- | :--- | :--- | :--- |

Figure 7. BSC Block Format


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 pairs in non-transparent mode and DLE-SYN pairs in transparent mode are discarded.

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

## 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. DLEETB, 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 (DLESYN 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.

## DMA CONSIDERATIONS

When the R68561, in the word mode, is used with a DMAC, high throughput of bit-oriented protocols is achieved. However, problems can arise when trying to DMA byte-oriented data in the word mode.

BOP and BSC have well-defined message boundaries and the MPCC can detect the end of message, determine if there is an odd (single) byte at the end of a message, and so inform the host MPU by setting the Received Half Word (RHW) bit in the Frame Status byte.

In byte-oriented protocols (such as ASYNC and COP) there is no defined message length. In the word mode, received bytes are grouped in pairs. In the byte mode, each byte is available through the RxFIFO as it is received. Thus, the MPCC in the word mode has no way of knowing when an odd (single) byte has been received at an end of a transmission to be passed onto the host MPU.

For transmission of data by the MPCC in the word mode, the MPCC provides a Transmit Half Word (THW) bit in the Transmit Control Register. When set, this bit informs the MPCC that the last word in the TxFIFO (marked by setting the TLAST bit with $\overline{\mathrm{DONE}}$ ) contains only the upper byte as valid data. However, the current available DMACs have no method to inform the MPCC that the last word of the message contains a single byte and MPU intervention is unrealistic.

Therefore, for bit-oriented protocols, the R68561 in the word mode can be efficiently used with a DMAC. To handle byteoriented protocols with DMAC, an R68561 in the byte mode or the R68560 (byte mode only) should be used.

| LEADING PAD <br> 5-8 BITS <br> (AR1) | SYN <br> 5-8 BITS <br> (AR2) | SYN <br> $5-8$ BITS <br> (AR2) |  | MESSAGE |  |
| :--- | :--- | :--- | :--- | :--- | :--- |

Figure 9. Character Oriented Protocol Format


NOTE: $\overline{U D S}$ MAY BE TIED LOW (GROUND).


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


Figure 12. MPCC Read Cycle Timing


Figure 13. MPCC Write 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 14. MPCC to Memory DMA Transfer Cycle Timing (Receiver DMA Mode)


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


Figure 16. Interrupt Request Cycle Timing


HIGH SPEED INTERFACE


LOW SPEED (RS-232) INTERFACE

Figure 17. Serial Interface

HIGH SPEED APPLICATION


LOW SPEED APPLICATION (RS-232 COMPATIBLE)


Figure 18. Serial Interface Timing


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

Figure 19. Serial Interface Echo Mode Timing

## AC CHARACTERISTICS

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

| Number | Parameter | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | R/W High to $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ Low | $t_{\text {RHSL }}$ | 0 | - | ns |
| 2 | Address Valid to CS, $\overline{\mathrm{DS}}$ Low | $t_{\text {AVSL }}$ | 30 | - | ns |
| 31 | $\overline{\mathrm{CS}}$ Low to $\overline{\text { DTACK }}$ Low | $\mathrm{t}_{\text {CLDAL }}$ | 0 | 60 | ns |
| 41 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ Low to Data Valid | tsLDV | 0 | 140 | ns |
| 5 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High to Data Invalid | $\mathrm{t}_{\text {SHDXR }}$ | 10 | 150 | ns |
| 6 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High to $\overline{\mathrm{DTACK}}$ High | $\mathrm{t}_{\text {SHDAT }}$ | 0 | 40 | ns |
| 7 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High to Address Invalid | $\mathrm{t}_{\text {SHAI }}$ | 20 | - | ns |
| 8 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High to R/ $\bar{W}$ Low | $\mathrm{t}_{\text {SHRL }}$ | 20 | - | ns |
| 9 | R/产 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{\mathrm{CS}}, \overline{\mathrm{DS}}$ Hıgh to Data Invalıd | $\mathrm{t}_{\text {SHDXW }}$ | 0 | - | ns |
| 17 | $\overline{\text { DTC Low to } \overline{\mathrm{DS}} \text { High }}$ | $\mathrm{t}_{\text {CLSH }}$ | 60 | - | ns |
| 18 | $\overline{\text { DACK }}$ Low to Data Valid, $\overline{\text { DONE }}$ Low | $\mathrm{t}_{\text {ALDV }}$ | 0 | 140 | ns |
| 19 | $\overline{\mathrm{DS}}$ High to Data Invalid | $\mathrm{t}_{\text {SHDXDR }}$ | 10 | 150 | ns |
| 21 | Data Valid to $\overline{\mathrm{DS}}$ Hıgh | $\mathrm{t}_{\text {DVSH }}$ | 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 | $\mathrm{t}_{\text {IALAL }}$ | 0 | 40 | ns |
| 26 | $\overline{\mathrm{IACK}}$, $\overline{\mathrm{DS}}$ Low to Data Valid | $\mathrm{t}_{\text {IALDV }}$ | 0 | 140 | ns |
| 27 | $\overline{\mathrm{DS}}$ Hıgh to Data Invalıd | $\mathrm{I}_{\text {ISHDI }}$ | 10 | 150 | ns |
| 28 | $\overline{\text { IACK }}$ High to $\overline{\text { 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 | $\mathrm{t}_{\text {TCLTD }}$ | 0 | 200 | ns |
| 32 | RxC Low to RxD Transition (Hold) | $\mathrm{t}_{\text {RCLRD }}$ | 0 | - | ns |
| 33 | RxD Transitıon to RxC Low (Setup) | $\mathrm{t}_{\text {RDRCL }}$ | 30 | - | ns |
| 34 | RxD to TxD Delay (Echo Mode) | $\mathrm{t}_{\text {RDTD }}$ | - | 200 | ns |
| 35 | R/̄W Low to DTTACK Low (Setup) | $\mathrm{t}_{\text {RLAL }}$ | 0 | - | ns |
| 36 | $\overline{\text { DACK }}$ High to $\overline{\text { DONE }}$ High | $t_{\text {AHDH }}$ | 0 | - | ns |
| 372, 3 | $\overline{\text { RDSR }}$ Pulse Width | $t_{\text {RPW }}$ | 1 | - | clock period |
| 382, 4 | TDSR Pulse Width | $\mathrm{t}_{\text {TPW }}$ | 1 | - | clock period |

## Notes:

1. For read cycle timing, the MPCC asserts $\overline{\text { DTACK }}$ withın the MPU S4 clock low setup time requirement and establishes valid data (Data In) within the MPU S6 clock low setup time requirement.
2. For synchronous protocols, this is one full serial clock period of RxC for $\overline{\operatorname{RDSR}}$ and TxC for TDSR.
3. For asynchronous protocols, $\overline{\operatorname{RDSR}}$ is asserted for two system clock periods for a prescale factor of 2 and for three system clock periods for a prescale factor of 3.
4. For asynchronous protocols, TDSR is asserted for a period of one-half the baud rate.

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

## 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}_{\mathrm{IL}}$ | -03 | +08 | V |  |
| Input Leakage Current R $\bar{W}, \bar{R}, \overline{R E T}, \overline{C S}$ | 1 N | - | 10.0 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0 \text { to } 5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=525 \mathrm{~V} \end{aligned}$ |
| Three-State (Off State) Input Current $\overline{\mathrm{IRQ}}, \overline{\mathrm{DTACK}}, \mathrm{DO}-\mathrm{D} 15$ | $\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}}=525 \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}_{\mathrm{ss}}+2.4$ | - | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=475 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-400 \mu \mathrm{~A} \\ & \mathrm{C}_{\text {LOAD }}=130 \mathrm{pF} \end{aligned}$ |
| BCLK | $\mathrm{V}_{\mathrm{OH}}$ | $V_{S S}+24$ | - | V | $\begin{aligned} & \mathrm{V}_{C C}=475 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=0 \\ & \mathrm{C}_{\text {LOAD }}=30 \mathrm{pF} \end{aligned}$ |
| Output Low Voltage <br> $\overline{\mathrm{RDSR}}, \overline{\mathrm{TDSR}}, \overline{\mathrm{IRQ}}, \overline{\mathrm{DTACK}} \mathrm{DO}-\mathrm{D} 15, \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}}=475 \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}}=0 \mathrm{~V} \\ & T_{A}=25^{\circ} \mathrm{C} \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |

## PACKAGE DIMENSIONS

## 48-PIN CERAMIC DIP



|  | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
|  | 6035 | 6157 | 2376 | 2424 |
|  | 1463 | 1534 | 0576 | 0604 |
| C | 305 | 432 | 0120 | 0160 |
| D | 0381 | 0533 | 0015 | 0021 |
| F | 0762 | 1397 | 0030 | 0055 |
| G | 254 | BSC | 0100 | $05 C$ |
| J | 0203 | 0330 | 0008 | 0013 |
| K | 254 | 419 | 0100 | 0165 |
| L | 1499 | 1565 | 0590 | 0616 |
| M | $0^{\circ}$ | $10^{\circ}$ | $0^{\circ}$ | $10^{\circ}$ |
| N | 1016 | 1524 | 0040 | 0606 |



|  | MILLIMETERS |  | INCHES |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |  |
| A | 5128 | 5232 | 2040 | 2060 |  |
| B | 1372 | 1422 | 0540 | 0560 |  |
| C | 355 | 508 | 0140 | 0200 |  |
| D | 036 | 051 | 0014 | 0020 |  |
| F | 102 | 152 | 0040 | 0060 |  |
| G | 254 BSC | 0100 BSC |  |  |  |
| H | 165 | 216 | 0065 | 0085 |  |
| J | 020 | 030 | 0008 | 0012 |  |
| K | 305 | 356 | 0120 | 0140 |  |
| L | 1524 BSC | 0600 BSC |  |  |  |
| M | 7 | 100 | $7^{\circ}$ |  | 10 |
| N | 051 | 102 | 0020 |  | 0040 |

## 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.310 M 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 (CSMACD), which allows multiple Data Terminal Equipment to share the same communication medium without the need for a central arbiter of medium utilization.

Ethernet nodes needıng 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



## 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 compatıble I/O
- 40-pin DIP
- Single 5V power supply
*R68802 is a trademark of the Rockwell International Corporation
*Ethernet is a trademark of the Xerox Corporation



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


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. D0-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{\mathrm{CS}}$ must be decoded from the address bus and gated with address strobe ( $\overline{\mathrm{AS}}$ ).

R/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.

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 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.
 transition latches data from the external data bus lines into the LNET. During a read ( $\mathrm{R} / \overline{\mathrm{W}}$ high), $\overline{\mathrm{DS}}$ low enables data from the LNET onto data bus lines.
$\overline{\text { IRQ }}$-Interrupt Request. The active low $\overline{\mathrm{IRQ}}$ output requests interrupt service by the MPU.

IACK-Interrupt Acknowledge. The active low $\overline{\mathrm{ACK}}$ 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.

DACK-DMA Acknowledge. The $\overline{\text { DACK }}$ low input indicates that the data bus has been acquired by the DMAC and that the requested bus cycle is beginning.
$\overline{\text { DONE-Done. } \overline{D O N E}}$ is a bidirectional active low signal. The $\overline{\text { DONE signal is asserted by the DMAC when the DMA transfer }}$ count is exhausted and there is no more data to be transferred, or 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{\operatorname{RESET}}$ input initializes all LNET functions. $\overline{\text { RESET }}$ must be asserted for at least 500 TXCLKs to initialize the LNET.
$\overline{\text { RXREQ}}$-Receive DMA Request. When receive data becomes available in the RXFIFO, $\overline{\text { RXREQ output is asserted and held }}$ low for 16 (single address burst mode) DMAC cycles (16 sequential $\overline{\text { 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, $\overline{\text { TXREQ output is }}$ asserted and held low for 16 (single address burst mode) DMAC cycles ( 16 sequential $\overline{\text { 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.
$\overline{\text { 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 transmıssion if MAUAVAIL is not asserted.
$\mathrm{V}_{\mathrm{Cc}}$ —Power. $5 \mathrm{~V} \pm 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 ether 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 initializatıon 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 Regıster, Station Address Register, Command Registers and Status Regısters. 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 intialization 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 DO-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 | Size <br> (No. Bytes) | Reset <br> Value | Mode |
| :---: | :--- | :---: | :--- | :--- | :--- |

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 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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.

| MR | 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 $\overline{\mathrm{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 |
| $\overline{0}$ | Use length count in packet format. |
| 1 | Do not use length count in packet format. |
| MR |  |
| 0 | SAS -Station Address Size |
| $\overline{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 (D0-D7). The IVN must be the second byte inıtialized durıng LNET initialization. The IVN is set to $\$ 0 \mathrm{~F}$ 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

| $\mathbf{7}$ | RESET -Reset |
| :--- | :--- |
| 0 | 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 |  |
| 4 | NOISOL - No Isolate |
| 0 | 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 |
| 0 | Negate MILOOP to command MI normal operation. |
| 1 | Assert MILOOP to command MI loopback operation. |
| CR1 |  |
| $\underline{2}$ | INLOOP - Internal LNET Loopback Test |
| 0 | Enable LNET normal operation. |
| 1 | Enable LNET internal loopback operation. |
| CR1 |  |
| 1 | ODDNO -Odd Number of Bytes |
| 0 | Transmit even number of bytes in a block. |
| 1 | Transmit odd number of bytes in a block. |
| CR1 |  |
| $\underline{0}$ | ENMAU -Enable MAUREQ |
| 0 | Negate MAUREQ. |
| 1 | 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
$\overline{0}$ 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{RQ}}$, 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 $\overline{\mathrm{RQ}}$ 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 MAUAVAIL changed state during transmission.

## SR1

3 ODD —Odd Number of Receive Bytes
$\overline{0}$ 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 Minımum 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 DONE has not been asserted. This state does not set the IRQ bit in SR2 nor cause IRQ 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{\mathbf{7}}{\mathbf{7}}$| IRQ interrupt condition has not occurred and $\overline{\text { IRQ }}$ has not |
| :--- |
| been asserted. |


$1 \quad$| An interrupt condition has occurred and $\overline{\text { IRQ }}$ has been |
| :--- |
| asserted. |

Note: This bit is cleared when SR2 is read and there is no pending interrupt condition.

```
SR2
    6
    Always reads zero.
```


## SR2

5 INIT -LNET Initialized
0 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{\text { RESET }}$ or RESET bit set in Command Register 1.

## SR2 <br> 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{M A U R E Q}$ 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{RQ}}$ 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 $R \bar{W}, \overline{D T A C K}, \overline{C S}, \overline{I A C K}$, 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{C}}$ (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{C S}$ 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 ( $\mathrm{R} / \overline{\mathrm{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{\mathrm{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 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{\text { DACK. }}$

## DONE

$\overline{\mathrm{DONE}}$ is a bidirectional signal line to or from the DMAC. With the AMZ8016 and the AMZ9516, $\overline{\text { 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{IRQ}}$ 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 acknowiedge (IACK) signal and reads the interrupt vector when the LNET asserts data transfer acknowledge (DTACK). The subsequent negation of $\overline{\mathrm{IACK}}$ and $\overline{\mathrm{IRQ}}$ 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.

## $\overline{\text { 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{M A U R E Q}$ 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. MAUAVAIL 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 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{\mathrm{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{R X R E Q}$ and to flag an overrun of the receive DMA service.

| PREAMBLE | START <br> FIELD <br> DELIMITER <br> (SFD) | DESTINATION <br> ADDRESS | SOURCE <br> ADDRESS | LENGTH <br> COUNT | DATA |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

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 DONE concurrent with the last $\overline{\text { 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{\operatorname{RXREQ}}$ 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{\mathrm{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 TXFIFO.

As the TXFIFO Output Pointer (TOP) advances to the first byte of the most recently filled half of the buffer, 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{\mathrm{DONE}}$ 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{RQ}}$ is asserted and the Transmitter Status field in Status Register 2 is set to 011 .

Figure 4. Typical Interface to 68000-Based System


Figure 5. Typical Interface to 68008-Based System





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 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 $\left.70^{\circ} \mathrm{C}\right)$

| Number | Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | Clock Period | $t_{\text {c }}$ | 90 |  | 1000 | ns |
| 2 | Receive Clock Pulse Width | $\mathrm{t}_{\text {cFR }}$ | 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 | $t_{\text {MOD }}$ | 0 |  | 80 | ns |
| 11 | $\mathrm{R} / \overline{\mathrm{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 }} \text { Low }}$ | $\mathrm{t}_{\text {cldal }}$ | 20 | 40 | 80 | ns |
| 13 | $\overline{C S}$, $\overline{\mathrm{DS}}$ High to R/W Low | $\mathrm{t}_{\text {SHRL }}$ | 20 |  | - | ns |
| 14 | $\overline{\text { CS High to DTACK Tristate }}$ | $\mathrm{t}_{\text {SHDAT }}$ | 20 | 40 | 80 | ns |
| 15 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ Low to Data Valid | $\mathrm{t}_{\text {sLDV }}$ | 0 |  | 140 | ns |
| 16 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High to Data Invalid | $t_{\text {SHDI }}$ | 10 |  | 150 | ns |
| 17 | $\mathrm{R} \overline{\mathrm{W}}$ Low to $\overline{\mathrm{CS}}$, $\overline{\mathrm{DS}}$ Low | $\mathrm{t}_{\text {RLSL }}$ | 0 |  | - | ns |
| 18 | $\overline{\mathrm{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 | $\mathrm{t}_{\text {DVSH }}$ | 100 |  | - | ns |
| 20 | $\overline{\mathrm{CS}}, \overline{\mathrm{DS}}$ High to Data Invalid | $t_{\text {SHDI }}$ | 10 |  | - | ns |
| 21 | $\overline{\text { IACK }}$ Low to $\overline{\text { DTACK }}$ Low | $t_{\text {IALAL }}$ | 20 | 40 | 80 | ns |
| 22 | $\overline{\text { IACK }}$ High to $\overline{\text { DTACK }}$ Tristate | $t_{\text {IAHDAT }}$ | 20 | 40 | 80 | ns |
| 23 | $\overline{\text { IACK }}$ Low to Data Valid | $\mathrm{t}_{\text {aldov }}$ | 0 |  | 140 | ns |
| 24 | $\overline{\text { DS }}$ High to Data Invalid | $\mathrm{t}_{\text {ISHDI }}$ | 10 |  | 50 | ns |
| 25 | $\overline{\mathrm{DACK}}$ Low to $\overline{\mathrm{DONE}} /$ Data Valid | t DLDV | 0 |  | 50 | ns |
| 26 | $\overline{\text { DTACK High to } \overline{\text { DONE }} \text { Invalid/Data }{ }^{\text {a }} \text { ( }{ }^{\text {a }} \text { ( }}$ | $t_{\text {DHDV }}$ | 0 |  | 40 | ns |
| 27 | $\overline{\text { DS }}$ Low to $\overline{\text { DACK }}$ High | $t_{\text {DLDH }}$ | 0 |  | 50 | ns |
| 28 | $\overline{\text { DS }}$ High to Data Invalid | $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 {cLoL }}$ | 0 |  | 100 | ns |
| 31 | External $\overline{\text { DONE }}$ Pulse Width | $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{\mathrm{DS}}$ High to $\overline{\mathrm{IRQ}}$ High | $\mathrm{t}_{\text {DSHIH }}$ |  | 2 |  | RXCLK |

Note:

* $\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}_{I \mathrm{~N}}$ | -0.3 to +7.0 V |
| Operating Temperatures | $\mathrm{T}_{\mathrm{A}}$ | 0 to $70^{\circ} \mathrm{C}$ |
| Storage Temperatures | $\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 or electric fields; however, normal precautions should be taken to avoid application of any voltage higher than maximum-rated voltages to this high-impedance circult. Reliability of operaton is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either $\mathrm{V}_{\mathrm{SS}}$ or $V_{C C}$ ).

## 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 $\overline{\mathrm{R} / \mathrm{W},} \overline{\mathrm{RESET}}, \overline{\mathrm{CS}}$ | IN | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=0 \text { to } 5.25 \mathrm{~V} \\ & V_{C C}=0 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State (Off) DTACK, D0-D15 | ${ }_{\text {ITSI }}$ | - | 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, }}$, TXREQ, $\overline{\mathrm{DTACK}}$, <br> D0-D15, MILOOP, MAUREQ, $\overline{\text { ISOLATE }}$ TXEN, TXDATA | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & +2.4 \\ & +2.4 \\ & +2.4 \end{aligned}$ | $\begin{aligned} & - \\ & - \\ & - \end{aligned}$ | $\begin{aligned} & v \\ & v \\ & v \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{~A}, \mathrm{C}_{\text {LOAD }}=32 \mathrm{pF} \\ & I_{\text {LOAD }}=0, C_{\text {LOAD }}=30 \mathrm{pF} \end{aligned}$ |
| Output Low Voltage <br> RXREQ, TXREQ, TXEN, TXDATA, $\overline{\text { DTACK, }}$ D0-D15 MILOOP, MAUREQ, ISOLATE $\overline{\mathrm{IRQ}}, \overline{\mathrm{DONE}}$ | $\mathrm{V}_{\text {OL }}$ | - | $\begin{aligned} & 0.5 \\ & 0.5 \end{aligned}$ | 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 Dissipatıon | $\mathrm{P}_{\text {Int }}$ | - | 1.0 | W | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| Input Capacitance | $\mathrm{C}_{\text {IN }}$ | - | 13 | 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}$ |

## PACKAGE DIMENSIONS

40-PIN CERAMIC DIP


|  | MILLIMETERS |  |  | INCHES |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |  |
| A | 5029 | 5131 | 1980 | 2.020 |  |
| B | 1486 | 1562 | 0585 | 0615 |  |
| C | 254 | 419 | 0100 | 0.165 |  |
| D | 038 | 053 | 0015 | 0021 |  |
| F | 076 | 140 | 0030 | 0055 |  |
| G | 254 | BSC | 0100 | BSC |  |
| H | 076 | 178 | 0030 | 0070 |  |
| J | 020 | 0.33 | 0008 | 0013 |  |
| K | 254 | 419 | 0100 | 0165 |  |
| L | 1460 | 1537 | 0575 | 0605 |  |
| M | $0^{\circ}$ | $10^{\circ}$ | $0^{\circ}$ | $10^{\circ}$ |  |
| N | 051 | 152 | 0020 | 0060 |  |

## 40-PIN PLASTIC DIP




|  | MILLIMETERS |  | INCHES |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 5128 | 5232 | 2040 | 2060 |  |
| B | 1372 | 1422 | 0540 | 0560 |  |
| C | 355 | 508 | 0140 | 0200 |  |
| D | 036 | 051 | 0014 | 0020 |  |
| F | 102 | 152 | 0040 |  | 0060 |
| G | 254 |  | BSC | 0100 BSC |  |
| H | 165 | 2.16 | 0065 | 0085 |  |
| J | 020 | 030 | 0008 | 0012 |  |
| K | 305 | 356 | 0120 | 0140 |  |
| L | 1524 | BSC | 0600 |  | BSC |
| M | $7^{\circ}$ |  | $10^{\circ}$ | $7^{\circ}$ | $10^{\circ}$ |
| N | 051 | 102 | 0020 | 0040 |  |

# 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

```
Part Number:
R68C552
T Package:
    C = Ceramic
    P = Plastic
```


## 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 DO-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{\mathrm{CS}}$.

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

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 $\overline{D T R}$ and $\overline{\mathrm{RTS}}$ lines go to the high state, the RDR register is cleared, the IVR is set to \$OF, the compare mode is disabled, and the $\overline{\mathrm{CTS}}$, $\overline{D C D}, \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{\text { CTS1 }}, \overline{\text { 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 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 SR reflects the current high or low state of CTS.

DATA CARRIER DETECT ( $\overline{\text { DCD1 }}, \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 SR reflects the current state of the $\overline{\mathrm{DCD}}$ line.


Figure 2. DACIA Interface Signals

## 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{\operatorname{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{\mathrm{RTS} 1}, \overline{\mathrm{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{\mathrm{DTR1}}, \overline{\mathrm{DTR2}}$ )

These two lines may be used as general purpose outputs. They are set high upon reset. Theirstate may be programmed by setting the appropriate bits in the CFR high or low. The state of the $\overline{D T R}$ line is reflected by the $\overline{D T R}$ bit in the SR.

## INTERRUPT REQUEST ( $\overline{\mathrm{IRQ1}}, \overline{\mathrm{IRQ2}})$

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.

## 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 ( $R x C$ ) 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 generated clock in which case the XTALO pin must float.

## 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{\mathrm{CS}}$ 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{C S}$ 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

| Control Signals |  |  |  | Data Bus Buffer State |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| R/W | $\overline{\text { CS }}$ | $\overline{\text { IACK1 }}$ | $\overline{\text { 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 | 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 \$OF |  |
| H | L | H | H | READ MODE - OUTPUT DATA |  |
| H | H | L | L | ILLEGAL MODE - OUTPUT \$OF |  |
| H | H | L | H | OUTPUT IRQ VECTOR 1 |  |
| H | H | H | L | OUTPUT IRQ VECTOR 2 |  |
| H | H | H | H | TRI STATE |  |

## 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{RQ}}$ 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 $\$ F F$ 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}$ | TDR EMPTY IE | $\begin{gathered} \overline{\mathrm{CTS}} \\ \mathrm{IE} \end{gathered}$ | $\overline{\mathrm{DCD}}$ | $\overline{\mathrm{DSR}}$ <br> IE | PARITY ERROR IE | FRM OVR BRK CPR 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 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | WRITE | READ |  |
| 00 | L | L | L |  |  | - | - | IER1 <br> 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 <br> VECTOR 1 | INVALID |
| 03 | L | H | H | - | - | TDR1 RDR1 | TRANSMIT DATA REGISTER 1 | RECEIVE DATA REGISTER 1 |
| 04 | H | L | L | - | - | IER2 ISR2 | INTERRUPT ENABLE REGISTER 2 | INTERRUPT STATUS REGISTER 2 |
| 05 | H | L | H | 0 | - | CFR2 SR2 | 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 | $\begin{gathered} \text { IRQ } \\ \text { VECTOR } 2 \end{gathered}$ | 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}$ | $\begin{gathered} \overline{\mathrm{DCD}} \\ \mathrm{IE} \end{gathered}$ | $\begin{gathered} \overline{\text { DSR }} \\ \mathrm{IE} \end{gathered}$ | PARITY ERROR IE | FRM, OVR BRK, CPR IE | $\begin{aligned} & \text { RDR } \\ & \text { FULL } \\ & \text { IE } \end{aligned}$ |  |  |
| ANY <br> BIT <br> SET | $\begin{gathered} \text { TDR } \\ \text { EMPTY } \end{gathered}$ | $\overline{\mathrm{CTS}}$ TRANS | $\begin{aligned} & \overline{D C D} \\ & \text { TRANS } \end{aligned}$ | $\begin{aligned} & \overline{\text { DSR }} \\ & \text { TRANS } \end{aligned}$ | PARITY ERROR | FRM, OVR BRK, CPR | RDR | INTERRUPT STATUS REGISTERS | - |
| FRAMING ERROR | TRANS UNDR | $\begin{aligned} & \overline{\text { CTS }} \\ & \text { STATUS } \end{aligned}$ | $\begin{aligned} & \overline{D C D} \\ & \text { STATUS } \end{aligned}$ | $\begin{aligned} & \overline{\overline{D S R}} \\ & \text { STATUS } \end{aligned}$ | $\begin{aligned} & \text { REC } \\ & \text { BREAK } \end{aligned}$ | $\overline{\text { DTR }}$ STATUS | $\overline{\text { RTS }}$ STATUS | STATUS REGISTERS | - |
| 0 | IVR/CDR REG | NO. STOP BITS | ECHO | BAUD RATE SELECTION |  |  |  | CONTROL REGISTERS |  |
| 1 | $\begin{gathered} \text { NUMI } \\ \text { DAT } \end{gathered}$ |  | PARITY SELECTION |  | PARITY ENABLE | $\begin{gathered} \overline{\text { DTR }} \\ \text { CONTROL } \end{gathered}$ | $\begin{gathered} \overline{\text { RTS }} \\ \text { CONTROL } \end{gathered}$ | FORMAT REGISTERS |  |
| COMPARE BITS (ADDRESS RECOGNITION) |  |  |  |  |  |  |  | $\begin{aligned} & \text { COMPARE } \\ & \text { DATA } \\ & \text { REGISTER } \end{aligned}$ | - |
| IRQ VECTOR ADDRESS |  |  |  |  |  | IRQ SOURCE |  | IA MODE |  |
| NOT USED |  |  |  |  |  | TRANS BRK | PAR/ ADDR | REGISTER <br> T/R MODE |  |

## 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 | TDR | $\overline{\text { CTS }}$ | $\overline{\text { DCD }}$ | $\overline{\text { DSR }}$ |  | PARITY | FRM |
| BIT | RDR |  |  |  |  |  |  |
| SET | EMPTY | TRANS | TRANS | TRANS | ERROR |  |  |
| ORRK | FULL |  |  |  |  |  |  |
| FPR |  |  |  |  |  |  |  |


| 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{\mathbf{C T S}}$ 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 |
| Bit 4 | Transition On $\overline{\mathrm{DCD}}$ Line ( $\overline{\mathrm{DCD}}$ TRANS) |
| 1 | A positive or negative transition has occurred on $\overline{D C D}$ |
| 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, CPR) |
| 1 | A framing error, receive overrun, or receive break has occurred or, in Compare Mode |
| 0 | No error, overrun, break has occurred or RDR has been read, or not in Compare Mode |
| 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 placed on the bus, bit 6 of the Control/Format Register (CFR1, CFR2) 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{\text { 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 | PAR/ <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 | IRQ Source |
| 1 | Other IRQ (CTS, DCD, DSR, Parity, Break, OV) |
| 0 | Transmit or Receive IRQ |

Transmit/Receive Mode (T/R Mode)<br>Bits 7-2 Not used (don't care)<br>Bit 1 Transmit Break (TRANS BRK)<br>1 Transmit continuous Break until disabled<br>0 Resume normal transmission<br>Bit $0 \quad$ Parity/Address Recognition (PAR/ADDR)<br>1 Send value of parity to ISR bit 2 (Address Recognition mode)<br>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 and the FRM/OVR/BRK/CPR bit (bit 1) of the ISR is set 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 | TRANS | CTS | $\overline{\text { DCD }}$ | $\overline{\text { DSR }}$ | REC | $\overline{\text { DTR }}$ | RTS |
| ERROR | UNDR | Status | Status | STATUS | BREAK | StATUS | STATUS |


| 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 and ISR are set |
| 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 |
| 1 | RTS line high |
| 0 | 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$ )

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

## Bit 6 <br> 1

0 Access the Compare Data Register (CDR)


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 |
| :---: | :---: |
| $\underline{6} 5$ | No. Bits |
| 00 | 5 |
| 01 | 6 |
| 10 | 7 |
| 11 | 8 |
| Bits 4-3 | Parity Mode Selection |
| 4 3 | 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 | 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{\operatorname{RQQ}}$ 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 $\overline{\mathrm{RQ}}$ and TxD for the Transmit Underrun Condition.


Figure 8. Transmit Underrun Condition Relationship

## EFFECTS OF CTS ON TRANSMITTER

The $\overline{C T S}$ control line controls the transmission of data or the handshaking of data to a "busy" device (such as a printer). When the $\overline{\mathrm{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{\mathrm{CTS}}$ 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{C T S}$ on the transmitter.


Figure 9. Effects of 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 IRQ 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 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 IRQ and TxD for a Transmit Break character.


Figure 13. Transmit Break Character

Table 4. Divisor Selection

| Control Register Bits |  |  |  | Divisor Selected For The Internal Counter | Baud Rate Generated With 3.6864 MHz 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^{9}\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^{\circ}\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^{\circ}\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^{\circ}\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^{\rho}\right) / 1,024=3,600$ | f/1,024 |
| 1 | 0 | 1 | 0 | 768 | $\left(3.6864 \times 10^{\circ}\right) 7768=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^{\circ}\right) / 384=9,600$ | f/384 |
| 1 | 1 | 0 | 1 | 192 | $\left(3.6864 \times 10^{\circ}\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

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


DACIA Read Cycle Timing


DACIA Write Cycle Timing


DACIA Transmit/Receiver Timing


DACIA Interrupt Acknowledge 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}}+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}}$ | 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 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{R E S}, R S 0, R S 1, R S 2, R \times D, \overline{C T S}, \overline{D C D}, \overline{D S R}, \overline{R \times C}$, $\overline{T X C}, \overline{C S}$, IACK | 1 IN | - | 10 | 50 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=0 \mathrm{~V} \text { to } 5.0 \mathrm{~V} \\ & V_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State Off D0-D7 | $\mathrm{I}_{\text {TSI }}$ | - | $\pm 2$ | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\text {IN }}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage D0-D7, TxD, 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 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}_{\text {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}_{\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} & \mathrm{V}_{\mathrm{cC}}=5.0 \mathrm{~V} \\ & \mathrm{~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}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## SPECIFICATIONS

## AC CHARACTERISTICS

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

| Number | Characteristic | Symbol | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| READ/WRITE TIMING |  |  |  |  |  |
| 1 | R/̄W, RS0-RS2 Valid to $\overline{\mathrm{CS}}$ Low (Setup) | $\mathrm{t}_{\mathrm{RVCL}}$ | 0 | - | ns |
| 2 | CS Low to R/ $\bar{W}$, RSO-RS2 Read (Hold Time) | $t_{\text {clav }}$ | 65 | - | ns |
| 3 | CS Low to Data Valid | $\mathrm{t}_{\text {CLDV }}$ | - | 100 | ns |
| 4 | $\overline{\mathrm{CS}}$ High to $\overline{\text { DTACK }}$ High | $\mathrm{t}_{\text {CHTH }}$ | 0 | 40 | ns |
| 5 | Data Valid to $\overline{C S}$ High | $\mathrm{t}_{\text {DVCH }}$ | 20 | - | ns |
| 6 | $\overline{\mathrm{CS}}$ High to Data Invalid (Read) | $\mathrm{t}_{\text {CHDZ }}$ | 10 | 30 | ns |
| 7 | CS High to Data Invalid (Write) | ${ }^{\text {t }}$ (HDZ | 0 | 40 | ns |
| 8 | CS Low to $\overline{\text { DTACK Low (Write) }}$ | $\mathrm{t}_{\text {CLTL }}$ | 0 | - | ns |
| 9 | Data Valid to DTACK Low (Read) | $t_{\text {DVTL }}$ | 0 | - | ns |


| TRANSMIT/RECEIVE TIMING |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 10 | Transmit/Receive Clock Rate | $\mathrm{tcr}^{\text {cr }}$ | 250 | - | ns |
| 11 | Transmit/Receive Clock High | $\mathrm{t}_{\mathrm{CH}}$ | 100 | - | ns |
| 12 | Transmit/Receive Clock Low | $t_{L L}$ | 100 | - | ns |
| 13 | XTALI to TXD Propagation Delay | $\mathrm{t}_{\text {CLTo }}$ | - | 250 | ns |
| 14 | XTALI to $\mathbb{R} \bar{Q}$ Propagation Delay | $\mathrm{t}_{\text {c.uid }}$ | - | 250 | ns |
| 15 | $\overline{C T S}$, $\overline{\text { CCD }}$, $\overline{\text { SSR }}$ Vald 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{\mathrm{RTS}}$, DTR Propagation Delay | $\mathrm{t}_{\text {ROPD }}$ | - | 150 | ns |


| INTERRUPT ACKNOWLEDGE TIMING |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 18 | IACK Low to Data Valid | $\mathrm{t}_{\text {LLOV }}$ | - | 100 | ns |
| 19 | $\overline{\text { IACK Low to DTACK Low }}$ | tilt | 0 | - | ns |
| 20 | $\overline{\text { IACK High to DTACK High }}$ | $\mathrm{t}_{\text {HTTH }}$ | 0 | - | ns |
| 21 | $\overline{\text { IACK High to Data Invalid }}$ | $\mathrm{t}_{\text {IHOZ }}$ | 10 | 30 | ns |

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



|  | MILLIMETERS |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| 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 | 0013 |
| K | 2.54 | 4.19 | 0100 | 0165 |
| L | 14.60 | 15.37 | 0.575 | 0.605 |
| M | $0^{\circ}$ | $10^{\circ}$ | $0^{\circ}$ | $10^{\circ}$ |
| N | 0.51 | 1.52 | 0020 | 0.060 |

40-PIN PLASTIC DIP


|  | MILLIMETERS | INCHES |  |  |
| :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |
| A | 51.28 | 52.32 | 2040 | 2.060 |
| V | 13.72 | 14.22 | 0.540 | 0.560 |
| C | 3.55 | 5.08 | 0140 | 0.200 |
| D | 0.36 | 0.51 | 0.014 | 0.020 |
| F | 1.02 | 1.52 | 0.040 | 0.060 |
| G | 2.54 | BSC | 0100 BSC |  |
| H | 1.65 | 2.16 | 0.065 | 0085 |
| J | 0.20 | 0.30 | 0.008 | 0.012 |
| K | 305 | 356 | 0.120 | 0.140 |
| L | 15.24 BSC | 0600 BSC |  |  |
| M | $7^{\circ}$ | $10^{\circ}$ | $7^{\circ}$ | $10^{\circ}$ |
| N | 0.51 | 102 | 0020 | 0040 |

## SECTION 2 8-BIT MICROPROCESSORS AND PERIPHERALS

Product Family Overview ..... 2-2
R6500 Family Products
R650X and R651X Microprocessors (CPU) ..... 2-3
FS5501Q 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 CRT Controller (CRTC) ..... 2-100
R6545-1 CRT Controller (CRTC) ..... 2-118
R6549 Color Video Display Generator (CVDG) ..... 2-134
R6551 Asynchronous Communications Interface Adapter (ACIA) ..... 2-165
R6592 Single Chip Printer Controller ..... 2-185
R65560 Multi-Protocol Communications Controller (MPCC) ..... 2-196
R65C02, R65C102 and R65C112 CMOS Microprocessors (CPU) ..... 2-226
R65C21 CMOS Peripheral Interface Adapter (PIA) ..... 2-242
R65C22 Versatile Interface Adapter (VIA) ..... 2-254
R65C24 CMOS Peripheral Interface Adapter Timer (PIAT) ..... 2-276
R65C51 CMOS Asynchronous Communications Interface Adapter (ACIA) ..... 2-296
R65C52 CMOS Dual Asynchronous Communications Interface Adapter (DACIA) ..... 2-316
Z80/8080 Bus Compatible Products
R6265, R6765 Double-Density Floppy Disk Controller (DDFDC) ..... 2-335

# 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 and available in NMOS and CMOS versions. It has a wide variety of CPUs and peripheral controllers and versatile memory-I/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 for a wide range of system applications. There's no wonder it's one of the world's largest selling families of microprocessors.


## 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 avalable in a variety of packaging (ceramic and plastic), operating frequency ( $1 \mathrm{MHz}, 2 \mathrm{MHz}$ and 3 MHz ) and temperature (commercial and industrial) versions.

## ORDERING INFORMATION



## FEATURES

- N-channel, silicon gate, depletion load technology
- 8 -bit parallel processing
- 56 instructions
- Decimal and binary arithmetic
- Thirteen addressing modes
- True indexing capability
- Programmable stack pointer
- Variable length stack
- Interrupt request
- Non-maskable interrupt
- Use with any type of speed memory
- 8-bit bidirectional data bus
- Addressable memory range of up to 64 K bytes
- "Ready" input
- Direct Memory Access capability
- Bus compatible with M6800
- $1 \mathrm{MHz}, 2 \mathrm{MHz}$, and 3 MHz versions
- Chorce of external or on-chip clocks
- On-chip clock optıons
-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 | 4K Bytes |  |
| R6507 | 28 | 8K Bytes |
|  | 28 |  |
| Microprocessors with External Two Phase Clock Input |  |  |
|  |  |  |
| Model | No. Pins | Addressable Memory |
| R6512 | 40 | 64K Bytes |
| R6513 | 28 | 4K Bytes |
| R6514 | 28 | 8K Bytes |
| R6515 | 28 | 4K Bytes |

Microprocessors with External Two Phase Clock Input

| 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 | 4K Bytes |  |
| R6507 | 28 | 8K Bytes |
|  | 28 |  |
| Microprocessors with External Two Phase Clock Input |  |  |
|  |  |  |
| Model | No. Pins | Addressable Memory |
| R6512 | 40 | 64K Bytes |
| R6513 | 28 | 4K Bytes |
| R6514 | 28 | 8K Bytes |
| R6515 | 28 | 4K Bytes |

## INTERFACE SIGNAL DESCRIPTIONS

## CLOCKS (ø1, ø2)

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

## ADDRESS BUS (A0-A15, 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 64 K bytes with a 16 -bit address bus (A0-A15); the R6504, R6507, and the R6514 can address 8 K bytes with a 13 -bit address bus (A0-A12); and the R6503, R6505, R6506, R6513, and R6515 can address 4 K bytes with a 12-bit address bus (A0-A11). These outputs are TTL-compatible and are capable of driving one standard TTL load and 130 pF .

## DATA BUS (D0-D7)

The data lines (D0-D7) form an 8 -bit bidirectional data bus which transfers data between the CPU and memory or peripheral devices. The outputs are tri-state buffers capable of driving one standard TTL load and 130 pF .

## DATA BUS ENABLE (DBE, R6512 ONLY)

The TTL-compatible DBE input allows external control of the tristate data output buffers and will enable the microprocessor bus driver when in the high state. In normal operation DBE is driven by the phase two ( $\varnothing 2$ ) clock, thus allowing data output from microprocessor only during $\emptyset 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 Q 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 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 I}$ input requests that a nonmaskable interrupt sequence be generated within the microprocessor.
$\overline{N M I}$ is an unconditional interrupt. Following completion of the current instruction, the sequence of operations defined for $\overline{\mathrm{RQ}}$ will be performed, regardless of the state interrupt mask flag. The vector address loaded into the program counter, low and high, are locations FFFA and FFFB respectively, thereby transferring program control to the memory vector located at these addresses. The instructions loaded at these locations cause the microprocessor to branch to a non-maskable interrupt routine in memory.
$\overline{\mathrm{NMI}}$ also requires an external $3 \mathrm{~K} \Omega$ register to $\mathrm{V}_{\mathrm{CC}}$ for proper wire-OR operations.

Inputs $\overline{\mathrm{RQ}}$ and $\overline{\mathrm{NMI}}$ are hardware interrupts lines that are sampled during $\varnothing 2$ (phase 2 ) and will begin the appropriate interrupt routine on the $\varnothing 1$ (phase 1) following the completion of the current instruction.

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

A negative going edge on the $\overline{\mathrm{SO}}$ input sets the overflow bit in the Processor Status Register. This signal is sampled on the trailing edge of $\emptyset 1$ and must be externally synchronized.

## SYNC

The SYNC output line identifies those cycles in which the microprocessor is doing an OP CODE fetch. The SYNC line goes high during $\varnothing_{1}$ of an OP CODE fetch and stays high for the remainder of that cycle. If the RDY line is pulled low during the $\varnothing 1$ clock pulse in which SYNC went high, the processor will stop in its current state and will remain in the state until the RDY line goes high. In this manner, the SYNC signal can be used to control RDY to cause single instruction execution.

## RESET ( $\overline{\operatorname{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 $\mathrm{V}_{\mathrm{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} \bar{W}$ and SYNC signals become valid.

## R6502 FEATURES

- 64 K addressable bytes of memory (A0-A15)
- $\overline{R Q}$ 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{\text { NMI }}$ interrupt
- 40-pin DIP



## R6503 FEATURES

- 4 K addressable bytes of memory (A0-A11)
- On-chip clock
- $\overline{\operatorname{RQ}}$ interrupt
- NMI interrupt
- 8-bit bidirectional data bus
- 28-pin DIP



## R6504 FEATURES

- 8 K addressable bytes of memory (AO-A12)
- On-chip clock
- $\overline{R Q}$ interrupt
- 8-bit bidirectional data bus
- 28-pin DIP



## R6505 FEATURES

- 4K addressable bytes of memory (A0-A11)
- On-chip clock
- $\overline{R Q}$ interrupt
- RDY signal
- 8-bit bidirectional data bus
- 28-pin DIP


| R6506 FEATURES <br> - 4 K addressable bytes of memory (A0-A11) <br> - On-chip clock <br> - $\overline{\mathrm{RQ}}$ interrupt <br> - Two phase output clock for timing of support chips <br> - 8-bit bidirectional data bus <br> - 28-pin DIP |  |
| :---: | :---: |
| R6507 FEATURES <br> - 8 K addressable bytes of memory (A0-A12) <br> - On-chip clock <br> - RDY signal <br> - 8-bit bidirectional data bus <br> - 28-pin DIP |  |
| R6512 FEATURES <br> - 64 K addressable bytes of memory (A0-A15) <br> - $\overline{\mathrm{RQ}}$ interrupt <br> - $\overline{\mathrm{NMI}}$ interrupt <br> - RDY signal <br> - 8-bit bidirectional data bus <br> - SYNC signal <br> - Two phase clock input <br> - Data Bus Enable <br> - 40-pin DIP |  |

## R6513 FEATURES

- 4 K addressable bytes of memory (A0-A11)
- Two phase clock input
- $\overline{\mathrm{RQ}}$ interrupt
- $\overline{\mathrm{NMI}}$ interrupt
- 8-bit bidirectional data bus
- 28-pin DIP



## R6514 FEATURES

- 8 K addressable bytes of memory (A0-A12)
- Two phase clock input
- $\overline{\mathrm{RQ}}$ interrupt
- 8-bit bidirectional data bus



## R6515 FEATURES

- 4K addressable bytes of memory (A0-A11)
- Two phase clock input
- $\overline{\mathrm{RQ}}$ interrupt
- RDY signal
- 8-bit bidirectional data bus



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


1. CLOCK GENERATOR IS NOT INCLUDED ON R6512, R6513, R6514 AND R6515.
2. ADDRESSING CAPABILITY AND CONTROL OPTIONS VARY WITH EACH OF THE CPUs.
3. R6502, R6503, R6504, R6505, R6506 AND R6507.
4. R6512, R6513, R6514 AND R6515.
5. R6512 ONLY.
6. R6502 ONLY.

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



Programming Model

## ADDRESSING MODES

The R6500 CPU family has 13 addressing modes. In the following discussion of these addressing modes, a bracketed expression follows the title of the mode. This expression is the term used in the Instruction Set Op Code Matrix table (later in this product description) to make it 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]-ln ımmedıate addressing, the second byte of the instruction contains the operand, with no further memory addressing required.

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

IMPLIED ADDRESSING [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 destınation 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)]—ln 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 indırect 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 |  |  | 2 EROPAGE |  |  |  |  | 1 Implieo |  | (INO, X) |  | ${ }^{\text {INOO }}$, y |  |  | 2 Page. x |  | ABS x |  |  |  | relative |  | INORECT |  | 2 Page. $Y$ |  | ${ }^{\text {process }}$ Coots status |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MNEMONIC | operation | OP | $n$ | $\bigcirc$ | OP | $n$ " | - OP | P 0 | $n$ | OP | In | " OP | $n$ | " | OP | $\bigcirc \times$ | OP | $\square$ | $\cdots$ | OP $n$ | $n$ " | OP | $\bigcirc$ | $1{ }^{1}$ OP | OP $n$ | OP | $n{ }^{\prime}$ | OP | n. ${ }^{\text {n }}$ | OP $n$ | , |  | NEMONIC |
| $\begin{aligned} & \hline A D C \\ & A N D \\ & A S L \\ & B C C \\ & B C S \\ & \hline \end{aligned}$ | $\begin{array}{\|cc\|} \hline A+M+C=A & (4)(1) \\ A A M-A & \\ C-C & 11 \\ B R A N C H O N C=0 & \\ \text { BRANCHONC }-1 & (2) \\ \hline \end{array}$ | 69 |  |  | 60 6 | 4 3 <br> 4 3 <br> 6 3 | 3 65 <br> 3 25 <br> 3 06 <br>   | 5 3 <br> 25 3 <br>  5 | 3 2 <br> 3 2 <br> 5 2 | OA | 2 | 1 |  |  |  | 6 | 2  <br> 2 71 <br>  31 | 5 | 2 |  | 4 2 <br> 4 2 <br> 6 2 | (10 | 4 | 3 79 <br> 3 39 <br> 3  | 79 4 <br> 39 4 | 3  <br> 3  <br>   <br>   <br>  90 <br>  80 |  |  |  |  |  |  | $\begin{aligned} & A D C \\ & A N D \\ & A S L \\ & B C C \\ & B C S \\ & \hline \end{aligned}$ |
| $\begin{aligned} & \text { BEO } \\ & B 1 T \\ & B M 1 \\ & B N E \\ & B O L \end{aligned}$ | BRANCH ON Z-1 AAM BRANCH ON N - 1 BRANCH ON $Z-0$ (2) (2) BRANCH ON N $=0$ (2) |  |  |  | 22.4 | 43 | 324 | 4 | 3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | F0 | 2 | 2 |  |  |  |  | $\begin{aligned} & \hline B E O \\ & B \\ & B M \\ & B M \\ & B N E \\ & B P C \end{aligned}$ |
| $\begin{aligned} & \hline B K K \\ & B V C \\ & B V S \\ & C L C \\ & C L D \end{aligned}$ | $\begin{array}{ll} \hline \text { BREAK } & \\ \text { BRANCH ONV }=0 & \text { (2) } \\ \text { BRANCH ONV }=1 & \text { (2) } \\ 0 \cdot C & \\ 0 \cdot D & \\ \hline \end{array}$ |  |  |  |  |  |  |  |  |  |  | 00 18 08 | $\begin{aligned} & 7 \\ & 2 \\ & 2 \\ & 2 \end{aligned}$ | 1 |  |  |  |  |  |  |  |  |  |  |  | 50 |  |  |  |  |  | . . . . . . . . . . | $\begin{aligned} & \hline 8 K \\ & B V C \\ & B \vee S \\ & C L C \\ & C L D \end{aligned}$ |
| $\begin{aligned} & \hline \text { CLI } \\ & \text { CLV } \\ & \text { CMP } \\ & \text { CPX } \\ & \text { CPY } \\ & \hline \end{aligned}$ | $\begin{aligned} & 0 \cdot 1 \\ & 0 \cdot V \\ & A-M \\ & X-M \\ & Y-M \\ & \hline \end{aligned}$ | $\left\lvert\, \begin{array}{l\|} \mathrm{cg} \\ \mathrm{EO} \\ \mathrm{co} \\ \hline \end{array}\right.$ | 2 2 2 | $\begin{array}{l\|l} 2 & C \\ 2 & E \\ 2 & C \\ \hline \end{array}$ | CO 4 <br> EC 4 <br> CC 4 | 4 3 <br> 4 3 <br> 4 3 | 3 $C 5$ <br> 3 E4 <br> 3  | 5 3 <br> 4 3 <br> 8  | 3 2 <br> 3 2 <br> 3 2 |  |  |  | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $1 \begin{aligned} & 1 \\ & 1 \end{aligned}$ | $C^{1}$ | $6{ }^{2}$ | 0. | 5 | 2 | D5 4 | 42 | 200 | 4 | 309 | 094 | 3 |  |  |  |  |  |  | $\begin{aligned} & \hline \text { CLI } \\ & \text { CLV } \\ & \text { CMP } \\ & \text { CPX } \\ & \text { CPY } \\ & \hline \end{aligned}$ |
| $\begin{aligned} & \text { OEG } \\ & \text { DEX } \\ & \text { OEY } \\ & \text { EOR } \\ & \text { ING } \\ & \hline \end{aligned}$ | $\begin{aligned} & M-1 \not C \\ & X=1 \rightarrow X \\ & Y \quad 1 \rightarrow Y \\ & A \forall M \rightarrow A \\ & M+M \rightarrow M \end{aligned}$ | 49 | 2 |  | $\begin{array}{cc} \hline \mathrm{CE} \\ \hline & 6 \\ \hline \mathrm{ADE} & \\ \hline \mathrm{EE} \end{array}$ | 6 3 <br> 4  <br> 6 3 <br> 6 3 |  | 6 5 <br>   <br>   <br> 5 3 <br> 6 5 | 5 2 <br>   <br> 3 2 <br> 5 2 | , |  |  | 2 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | 41 | 62 | 251 | 5 |  |  | 6 2 <br> 4  <br> 4 2 <br> 6 2 |  | 7 | $\begin{array}{\|l\|l\|} \hline 3 & \\ \hline & \\ 3 & 59 \\ 3 & 59 \\ \hline \end{array}$ | 594 | 3 |  |  |  |  |  |  | $\begin{aligned} & \hline \text { DEC } \\ & \text { OEX } \\ & \text { OEY } \\ & \text { EOR } \\ & \text { INC } \\ & \hline \end{aligned}$ |
| $\begin{aligned} & \hline N X \\ & 1 N Y \\ & \text { JMP } \\ & \text { NSR } \\ & \text { LOA } \\ & \hline \end{aligned}$ | $\begin{aligned} & x+1-x \\ & y+1-y \end{aligned}$ <br> JuMP TO NEW LOC <br> Jump Sub $M \rightarrow A$ | A9 | 2 |  | $4 C$ 3 <br> 20 6 <br> $A D$ 4 | 3 3 <br> 6 3 <br> 4 3 | 3 <br> 3 <br> 3${ }^{\text {A }}$ | 53 | 3 |  |  |  | 2 | 1 | A | 6 | B1 | 15 | 2 | B5 4 | 4.2 | 2 BD | ${ }_{4}$ | 389 | 89.4 | 3 |  | 6 C | 53 |  |  |  | $\begin{aligned} & \text { INX } \\ & \text { NY } \\ & \text { JMR } \\ & \text { JSR } \\ & \text { LDA } \\ & \hline \end{aligned}$ |
| $\begin{aligned} & \text { LDX } \\ & \text { LDY } \\ & \text { LSA } \\ & \text { NOR } \\ & \text { ORA } \\ & \hline \end{aligned}$ | $\qquad$ | ${ }^{\text {A2 } 201}$ | $2$ |  | $\begin{array}{\|c\|c} \hline A E & 4 \\ A C & 4 \\ A E & 6 \\ & 4 \\ \hline 0 D & 4 \\ \hline \end{array}$ | $\begin{array}{l\|l} 4 & 3 \\ 4 & 3 \\ 6 & 3 \\ 4 & 3 \\ 4 & 3 \end{array}$ | $\begin{array}{c\|c\|} 3 & A 6 \\ 3 & A 4 \\ 3 & 46 \\ 3 & 05 \\ \hline \end{array}$ | $\begin{array}{c\|c} \hline 6 & 3 \\ 4 & 3 \\ 46 & 5 \\ 58 & 3 \\ \hline 5 & 3 \end{array}$ | $\begin{array}{l\|l} \hline & 2 \\ 3 & 2 \\ 5 & 2 \\ 3 & 2 \\ 3 & 2 \end{array}$ | AA |  | $1{ }^{1}$ EA | 2 | , |  |  | 211 | 5 | 2 |  |  | $\begin{array}{l\|l\|} \hline 2 & \mathrm{BC} \\ 2 & 5 \mathrm{E} \\ 2 & 10 \\ 2 \end{array}$ | $4$ |  |  | 3 3 4 |  |  |  | 86 | 4 |  | $\begin{aligned} & \text { LOX } \\ & \text { LOY } \\ & \text { LSR } \\ & \text { NOP } \\ & \text { ORA } \\ & \hline \end{aligned}$ |
| PHA <br> PHP <br> PLA <br> PLP <br> ROL <br> ORA |  |  |  |  | 28 |  | 326 | 6.5 | 5.2 | 2 A |  | [ 48 | 3 4 4 |  |  |  |  |  |  | 36 | 6. 2 | 23 E | , | 3 |  |  |  |  |  |  |  | (RESTORED) <br> N . . . . . 2 C | $\begin{aligned} & \hline \text { PHA } \\ & \text { PHP } \\ & \text { PLA } \\ & \text { PLP } \\ & \text { ROL } \\ & \hline \end{aligned}$ |
| $\begin{align*} & \text { ROR }  \tag{1}\\ & \text { RT } \\ & \text { RTS } \\ & S B C \\ & S E C \\ & \text { SED } \end{align*}$ | - C- <br> RTRNINT <br> RTRN SUB $\begin{aligned} & A-M-\bar{C} \cdot A \\ & 1 \cdot C \\ & 1 \cdot D \end{aligned}$ | E9 | 2 |  | $\begin{array}{\|c\|} \hline 6 E \\ \hline E 0 \end{array}$ |  | $3{ }_{3}{ }^{66}$ | 6 5 <br>  5 | 5 2 <br> 3 2 | 6 A | , | 60 38 78 | 6 6 2 2 2 |  | E1 6 | 6 | 2 F | , | 2 |  | 6 2 <br> 4 2 | $2_{2}^{2} 90$ | ${ }^{7}$ | $\begin{array}{\|l\|l\|} \hline 3 & \\ 3 & \\ \hline \end{array}$ | F9 4 | 3 |  |  |  |  |  |  | $\begin{aligned} & \hline \text { ROR } \\ & \text { RTA } \\ & \text { RTS } \\ & \text { SBC } \\ & \text { SEC } \\ & \text { SED } \end{aligned}$ |
| SEE <br> STA <br> STA <br> STX <br> STY <br> TAX <br> S | $\begin{aligned} & 1 \rightarrow 1 \\ & A \rightarrow M \\ & X \rightarrow M \\ & Y \rightarrow M \\ & A \rightarrow X \\ & \hline \end{aligned}$ |  |  |  | 88 4 <br> 88 4 <br> $8 C$ 4 | 4 3 <br> 4 3 <br> 4 3 | 3 85 <br> 3 86 <br> 3 84 <br>  84 | 5 3 <br> 6 3 | 3 2 <br> 3 2 <br> 3 2 |  |  | 78 | $\begin{array}{\|c\|} \hline 2 \\ 4 \\ 4 \\ \hline \end{array}$ |  | 31.6 | 6 | 291 | 6 | 2 | ${ }^{95} 4.4$ | $4{ }^{4} 2$ | $22^{20}$ | 5 | 399 | 995 | 3 |  |  |  | 96 | 42 |  |  |
|  | $\begin{aligned} & A \rightarrow Y \\ & S \rightarrow x \\ & x \rightarrow A \\ & x \rightarrow S \\ & Y \rightarrow A \\ & \hline \end{aligned}$ |  |  |  |  |  |  |  |  |  |  | A 8 <br> BA <br> 8 A <br> 9 A <br> 98 <br> 98 |  | (1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | TAX <br> TAY <br> TSX <br> TXA <br> TXS <br> TYA <br> Tr |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | M M |  | NEX <br> CCX EMOR emor |  | $\begin{aligned} & \text { HOR } \\ & \text { EREFF } \\ & \text { ERSTA } \end{aligned}$ |  | TIVE AD pointer | DDRESS <br> ER |  | $\checkmark$ |  | BTRAC | IVE OR | M MEMORY <br> $M_{r}$ MEMORY <br> $n$ NO CYCL <br> * no byte | $\begin{aligned} & \text { BIT } 7 \\ & \text { BiT } \\ & \text { Es } \\ & \text { s } \end{aligned}$ |

## R650X CLOCK TIMING



R651X CLOCK TIMING


## R65XX READ WRITE TIMING



## AC CHARACTERISTICS

| Characteristic | Symbol | $\begin{aligned} & \hline \text { R65XX } \\ & \text { (1 MHz) } \end{aligned}$ |  | $\begin{aligned} & \hline \text { R65XXA } \\ & (2 \mathrm{MHz}) \end{aligned}$ |  | $\begin{aligned} & \text { R65XXB } \\ & \text { (3 MHz) } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |

R650X CLOCK TIMING

| Clock Cycle Time | T ${ }_{\text {cre }}$ | 1.0 | 10 | 0.5 | 10 | 0.33 | 10 | $\mu \mathrm{s}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ¢0 (IN) Low Pulse Width | TLoo | 480 | - | 240 | - | 160 | - | ns |
| ¢0 (IN) High Pulse Width | $\mathrm{T}_{\text {нøо }}$ | 460 | - | 240 | - | 160 | - | ns |
| 00 (IN) Rise and Fall Time ${ }^{1,2}$ | $\mathrm{T}_{\text {RO }}, \mathrm{T}_{\text {FO }}$ | - | 10 | - | 10 | - | 10 | ns |
| 01 (OUT) High Pulse Width | $\mathrm{T}_{\text {PWH01 }}$ | 460 | - | 235 | - | 155 | - | ns |
| $\emptyset 2$ (OUT) High Pulse Width | $\mathrm{T}_{\text {PWH02 }}$ | 460 | - | 240 | - | 160 | - | ns |
| Delay Between $\$ 1$ (OUT) and $\dagger 2$ (OUT) | To | 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 | $T_{\text {CYC }}$ | 1.0 | 10 | 0.5 | 10 | 0.33 | 10 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| $\emptyset 1$ (IN) High Pulse Width | $T_{\text {PWH01 }}$ | 430 | - | 215 | - | 150 | - |
| $\emptyset 2(\mathbb{N})$ High Pulse Width | $T_{\text {PWH02 }}$ | 470 | - | 235 | - | 160 | - |
| Delay Between $\emptyset 1$ and $\emptyset 2$ | $T_{\mathrm{D}}$ | 0 | - | 0 | - | 0 | - |
| $\emptyset 1(\mathbb{N}), \emptyset 2(\mathbb{N})$ Rise and Fall Time 1,3 | $T_{R}, T_{F}$ | - | 25 | - | 20 | - | 15 |

R65XX READ/WRITE TIMING

| $\mathbf{R} \bar{W}$ Setup Time | $\mathrm{T}_{\text {Rws }}$ | - | 225 | - | 140 | - | 110 | ns |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| 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}_{\mathrm{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 {RDY }}$ | 100 | - | 50 | - | 35 | - | ns |
| $\overline{\text { SO Setup Time }}$ | $\mathrm{T}_{\text {so }}$ | 100 | - | 50 | - | 35 | - | ns |
| SYNC Setup Time | $\mathrm{T}_{\text {SYN }}$ | - | 225 | - | 140 | - | 110 | ns |

## Notes:

1. Loads: All output except clocks $=1 \mathrm{TTL}+130 \mathrm{pF}$. Clock outputs $=1 \mathrm{TTL}+30 \mathrm{pF}$.
2. Measured between 0.8 and 2.0 points on waveform load.
3. Measured between $10 \%$ and $90 \%$ points on waveforms.
4. *RDY must never switch states within $\mathrm{R}_{\mathrm{FDY}}$ to end of $\emptyset 2$.

## EXAMPLE OF 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 | $\mathrm{T}_{\mathrm{STG}}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

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

## OPERATING CONDITIONS

| Parameter | Symbol | Value |
| :--- | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{~V} \pm 5 \%$ |
| Temperature Range <br> Commercial <br> Industrial | $\mathrm{T}_{\mathrm{A}}$ |  |

## 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, $\varnothing 0$ (IN) $\$ 1$ (IN), $\varnothing 2$ (IN) | $\mathrm{V}_{\mathrm{IH}}$ | $\begin{gathered} 2.0 \\ v_{c c}-0.3 \\ \hline \end{gathered}$ | - | $\begin{gathered} v_{\mathrm{CC}} \\ \mathrm{v}_{\mathrm{CC}}+0.25 \\ \hline \end{gathered}$ | V |  |
| Input Low Voltage Logic, $\varnothing 0$ (IN) $\$ 1(\mathbb{N}), \phi 2(\mathrm{IN})$ | $\mathrm{V}_{\mathrm{IL}}$ | $\begin{aligned} & -0.3 \\ & -0.3 \end{aligned}$ | - | $\begin{aligned} & 0.8 \\ & 0.4 \end{aligned}$ | V |  |
| ```Input Leakage Current Logic (Excl. RDY, S.O.) \1 (IN), }\mp@subsup{\emptyset}{2}{(IN) 00 (IN)``` | $\mathrm{I}_{\mathrm{N}}$ | $-$ | $-$ | $\begin{gathered} 2.5 \\ 100 \\ 10 \end{gathered}$ | $\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}$ |
| Input Leakage Current for Three State Off DO-D7 | ${ }_{1}^{\text {TSI }}$ | - | - | 10 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{\text {IN }}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & 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} & \mathrm{I}_{\mathrm{LOAD}}=-100 \mu \mathrm{~A} \\ & \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \end{aligned}$ |
| Output Low Voltage SYNC, DO-D7, AO-A15, R/ $\bar{W}, ~ \emptyset 1$ (OUT), $\emptyset 2$ (OUT) | $\mathrm{V}_{\mathrm{OL}}$ |  |  | +0.4 | V | $\begin{aligned} & \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \\ & \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \end{aligned}$ |
| Power Dissipation 1 and 2 MHz <br> 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 \(\emptyset 0\) (IN) \(\emptyset 1\) (IN) \(\emptyset 2\) (IN)``` | C $\mathrm{C}_{\text {IN }}$ <br> $\mathrm{C}_{\text {out }}$ $\mathrm{C} \emptyset_{0(\mathbb{N})}$ Cø1 <br> C 12 | - | $\begin{aligned} & \overline{30} \\ & 50 \end{aligned}$ | $\begin{aligned} & 10 \\ & 15 \\ & 12 \\ & 15 \\ & 50 \\ & 80 \end{aligned}$ | pF | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\ & \mathrm{f}^{2}=1 \mathrm{MHz} \\ & \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \end{aligned}$ |

## Notes:

1. All units are direct current (dc) except for capacitance.
2. Negative sign indicates outward current flow, positive indicates inward flow.
3. $\overline{\mathrm{IRQ}}$ and $\overline{\mathrm{NMI}}$ require 3 K pull-up resistor.
4. $\emptyset 1(\mathrm{IN})$ and $\emptyset 2(\mathrm{IN})$ apply to R6512, 13, 14, and 15 ; $\emptyset 0(\mathrm{IN})$ applies to R6502, 03, 04, 05,06 and 07.
5. Typical values shown for $\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}$ and $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$.

## R6501Q AND R6511Q 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 | Plastıc (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 | Plastıc (QUIP) | 1 MHz | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
| R6511AQ | Plastıc (QUIP) | 2 MHz | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |

## FEATURES

- 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
- 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 $/ \mathrm{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
- 64-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 $\left(\mathrm{V}_{\mathrm{RR}}\right)$ 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 $\emptyset 2$ pin. The XTLI pin may be used as an undivided clock input by connectıng XTLO to $\mathrm{V}_{\mathrm{SS}}$, in which case the internal division circuitry is bypassed and the device operates at the reference frequency.

## Parallel 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 $/ \mathrm{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.


# KEY REGISTER SUMMARY 



CPU Registers


Mode 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}_{\text {RR }}$ | 3.0 | - | $\mathrm{V}_{\mathrm{Cc}}$ | Vdc |
| RAM Standby Current (Retention Mode) Commercial at $25^{\circ} \mathrm{C}$ | $I_{\text {RR }}$ | - | 4 | - | mAdc |
| Input High Voltage Except XTLI | $\mathrm{V}_{\mathrm{IH}}$ | +2.0 | - | $\mathrm{V}_{C C}$ | Vdc |
| Input High Voltage (XTLI) | $\mathrm{V}_{\mathrm{IH}}$ | +4.0 | - | $\mathrm{V}_{\mathrm{Cc}}$ | Vdc |
| Input Low Voitage | $\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 \mathrm{Adc}$ |
| Input Low Current $\left(\mathrm{V}_{\mathrm{lL}}=0.4 \mathrm{Vdc}\right)$ | IIL | - | -1.0 | -1.6 | mAdc |
| Output High Voltage Except XTLO $\left(\mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{Adc}\right)$ | $\mathrm{V}_{\mathrm{OH}}$ | +2.4 | - | $\mathrm{V}_{\mathrm{CC}}$ | Vdc |
| Output Low Voltage $\left(l_{\text {LOAD }}=1.5 \mathrm{mAdc}\right)$ | $\mathrm{V}_{\text {OL }}$ | - | - | $+0.4$ | Vdc |
| Input Capacitance $\begin{aligned} & \left(\mathrm{V}_{\mathbb{N}}-0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right) \\ & \text { XTLL, XTLO } \\ & \text { All Others } \end{aligned}$ | $\mathrm{C}_{\text {IN }}$ | - | - | $\begin{aligned} & 50 \\ & 10 \end{aligned}$ | pF |
| I/O Port Pull-Up Resistance PA0-PA7, PB0-PB7, PC0-PC7 R6501Q only | $\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

$\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}_{\mathrm{CYC}}$ | 1.0 | 10.0 | 0.500 | 10.0 | $\mu \mathrm{sec}$ |
| Internal Write to Peripheral Data Valid (TTL) | $T_{\text {pow }}$ | 1.0 |  | 0.5 |  | $\mu \mathrm{Sec}$ |
| Peripheral Data Setup Time | $\mathrm{T}_{\text {PDSU }}$ | 500 |  | 500 |  | nsec |
| Count and Edge Detect Pulse Width | $\mathrm{T}_{\text {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 $\mathrm{R} / \overline{\mathrm{W}}$ control circuitry interface to the processor bus control lines. Figure 2 is a block diagram of the R6520 PIA.


Figure 2. R6520 PIA Block Diagram

## DATA INPUT REGISTER (DIR)

When the microprocessor writes data into the PIA, the data which appears on the data bus during the $\emptyset 2$ clock pulse is latched into the Data Input Register (DIR). The data is then transferred into one of six internal registers of the PIA after the trailing edge of the $\emptyset 2$ clock. This assures that the data on the peripheral output lines will make smooth transitoons 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 regıster (ORA, ORB) is selected, and if bit 2 is a " 0 ," a Data Direction Register (DDRA, DDRB) is selected. The Data Direction Register Access Control bit, together with the Register Select lines (RSO, RS1) selects the various internal registers as shown in Table 2.

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

## 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 correspondıng 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 Perıpheral 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 Directıon Regıster 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 l/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 interfacıng.

Table 1. Control Registers Bit Designations


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

Another difference between the PAO-PA7 lines and the PBO through PB7 lines is that they have three-state capability which allows them to enter a high impedance state when programmed to be used as input lines. In addition, data on these lines will be read properly, when programmed as output lines, even if the data signals fall below 2.0 volts for a "high" state or are above 0.8 volts for a "low" state. When programmed as output, each line can drive at least 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 (CS0, CS1, $\overline{\text { 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, RS0, and RS1 lines and the contents of Control Registers A and B.

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

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

## CLOCK SIGNAL (02)

The Phase 2 Clock Signal ( $\downarrow 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 $(\mathrm{R} / \overline{\mathrm{W}})$ controls the direction of data transfers between the PIA and the data lines associated with the CPU and the peripheral devices. A high on the $R / \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 Registes (CRA, CRB) DAta Direction Register access bits (see Table 1, bit 2) select the various R6520 registers to be accessed by the CPU, RS0 and RS1 are normally connected to the microprocessor (CPU) address output lines. Through control of these lines, the CPU can write directly into the Control


Figure 3. Interface Signals Relationship

Regısters (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{gathered} \hline \text { CRA } \\ \text { (Bit 2) } \end{gathered}$ | $\begin{array}{\|c\|} \hline \text { CRB } \\ \text { (Bit 2) } \end{array}$ | $\mathrm{R} / \bar{W}=\mathrm{H}$ | $\mathbf{R} / \bar{W}=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{\mathrm{IRQA}}, \overline{\mathrm{IRQB}})$

The active low Interrupt Request lines ( $\overline{\mathrm{RQA}}$ and $\overline{\mathrm{IRQB}}$ ) act to interrupt the microprocessor either directly or through external interrupt prority 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{IRQA}}$ 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 $\widehat{\text { IRQA }}$ can be disabled by setting bit 3 in CRA to a 0 .

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

Control of $\overline{\mathrm{RQQ}}$ is performed in exactly the same manner as that described above for IRQA. Bit 7 in CRB (IRQB1) is set by an active transition on CB1 and $\overline{\mathrm{RQB}}$ from this flag is controlled
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{\text { IRQA }}$ and $\overline{\text { 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{\mathrm{RQB}}$ goes low (Active) |
| CRB- $6=1$ and CRB-3 $=1$ | $\overline{\mathrm{RQB}}$ goes low (Active) |
| Note: |  |

The flags act as the link between the peripheral interrupt signals and the processor interrupt inputs The interrupt disable bits allow the processor to control the interrupt function

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

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

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

## Note:

A negative transition is defined as a transition from a high to a low, and a positive transition is defined as a transition from a low to a high voltage.

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

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

In the output mode (CRA, bit $5=1$ ), CA2 can operate independently to generate a simple pulse each tıme 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 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IRQA1 FLAG | $\begin{gathered} \text { IRQA2 } \\ \text { FLAG } \end{gathered}$ | CA2 INPUT MODE SELECT (=0) | $\begin{gathered} \text { IRQA2 } \\ \text { POSITIVE } \\ \text { TRANSITION } \end{gathered}$ | $\begin{gathered} \overline{\mathrm{IRQA}} \\ \text { ENABLE } \\ \text { FOR IRQA2 } \end{gathered}$ | ORA SELECT | $\begin{gathered} \text { IRQA1 } \\ \text { POSITIVE } \\ \text { TRANSITION } \end{gathered}$ | $\begin{gathered} \overline{\mathrm{IRQA}} \\ \text { ENABLE } \\ \text { FOR IRQA1 } \end{gathered}$ |
|  |  |  | IRQAIRQA2 CONTROL |  |  | IRQA $/$ RQA $^{2}$ CONTROL |  |

CA2 OUTPUT MODE (BIT 5 = 1)

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

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

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

CA2 OUTPUT MODE (BIT $5=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) $\emptyset 2$ clock transition following a read of Output Register A CA2 returns high as specified by bit 3.

Bit 3 CA2 READ STROBE RESTORE CONTROL (4 = 0)
1 CA2 returns high on the next $\emptyset 2$ clock negative transition following a read of Output Register A.

- CA2 reiurns high on the nexi active CA1 transition following a read of Output Register A as specified by bit 1.

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

## CONTROL REGISTER B (CRB)

CB2 INPUT MODE (BIT $5=0$ )

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

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 | ORB SELECT | $\begin{array}{\|c\|} \hline \text { IRQB1 } \\ \text { POSITIVE } \\ \text { TRANSITION } \end{array}$ | $\begin{gathered} \overline{\mathrm{IRQB}} \\ \text { ENABLE } \\ \text { FOR IRQB1 } \end{gathered}$ |
|  |  |  | CB2 CONTROL |  |  | $\overline{\text { IRQB/IRQB1 }}$ CONTROL |  |

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

```
Bit }7\mathrm{ 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{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.
    O 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 IRQB when IRQB1 Flag (bit 7) is set.
    0 Disable assertion of \}\overline{\textrm{RQB}}\mathrm{ 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 \quad$ Set IRQB2 Flag (bit 6) on a negative (high-to-low) transition of CB2.

Bit 3 IRQB ENABLE FOR IRQB2
1 Enable assertion of IRQB when IRQB2 Flag (bit 6) is set.
0 Disable assertion of $\overline{\mathrm{IRQB}}$ when IRQB2 Flag (bit 6 ) is set.

## CB2 OUTPUT MODE (BIT 5 = 1)

```
Bit 6 NOT USED
    O 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.
    O CB2 goes low on the first negative (high-to-low) }0
    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 02 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 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$, 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 $1 / 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 | ${ }^{\text {tayc }}$ | 1.0 | - | 0.5 | - | $\mu \mathrm{S}$ |
| $\emptyset 2$ Pulse Width | $\mathrm{t}_{\mathrm{C}}$ | 470 | 25 | 235 | 25 | ns |
| $\emptyset 2$ Rise and Fall Time | $\mathrm{trc}_{\text {c }}, \mathrm{t}_{\mathrm{fc}}$ | - | 25 | - | 15 | ns |

READ TIMING

| Address Set-Up Time | $\mathrm{t}_{\text {ACR }}$ | 150 | - | 90 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address Hold Time | $\mathrm{t}_{\text {CAR }}$ | 0 | - | 0 | - | ns |
| Peripheral Data Set-Up Time | $t_{\text {PCR }}$ | 300 | - | 150 | - | ns |
| Data Bus Delay Time | $\mathrm{t}_{\text {CDR }}$ | - | 395 | - | 190 | ns |
| Data Bus Hold Time | $\mathrm{t}_{\mathrm{HR}}$ | 10 | - | 10 | - | ns |

## WRITE TIMING

| Address Set-Up Time | $\mathrm{t}_{\text {ACW }}$ | 180 | - | 90 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Address Hold Time | $\mathrm{t}_{\text {caw }}$ | 0 | - | 0 | - | ns |
| R/W Set-Up Time | $t_{\text {WCW }}$ | 130 | - | 65 | - | ns |
| R/ $\bar{W}$ Hold Time | $t_{\text {cww }}$ | 50 | - | 25 | - | ns |
| Data Bus Set-Up Time | $\mathrm{t}_{\text {DCW }}$ | 300 | - | 150 | - | ns |
| Data Bus Hold Time | $\mathrm{t}_{\text {HW }}$ | 10 | - | 10 | - | ns |
| Peripheral Data Delay Time | $\mathrm{t}_{\text {CPW }}$ | - | 1.0 | - | 0.5 | $\mu \mathrm{S}$ |
| Peripheral Data Delay Time to CMOS Level | $\mathrm{t}_{\text {CMOS }}$ | - | 2.0 | - | 1.0 | $\mu \mathrm{S}$ |

## PERIPHERAL INTERFACE TIMING

| Peripheral Data Set-Up <br> $\emptyset 2$ Low to CA2 Low Delay <br> Ø2 Low to CA2 High Delay <br> CA1 Active to CA2 High Delay <br> ф2 High to CB2 Low Delay <br> Peripheral Data Valid to CB2 Low Delay <br> Ø2 High to CB2 High Delay <br> CB1 Active to CB2 High Delay <br> CA1, CA2, CB1 and CB2 <br> Input Rise and Fall Time | $\begin{aligned} & t_{\mathrm{PCR}} \\ & \mathrm{t}_{\mathrm{CA} 2} \\ & \mathrm{t}_{\mathrm{RS} 1} \\ & \mathrm{t}_{\mathrm{RS} 2} \\ & \mathrm{t}_{\mathrm{CB} 2} \\ & \mathrm{t}_{\mathrm{DC}} \\ & \mathrm{t}_{\mathrm{RS} 1} \\ & \mathrm{t}_{\mathrm{RS} 2} \\ & \mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}} \end{aligned}$ | $\begin{gathered} 300 \\ - \\ - \\ - \\ 0 \\ - \\ - \end{gathered}$ | 1.0 1.0 2.0 1.0 1.5 1.0 2.0 1.0 | 150 - - - 0 | 0.5 <br> 0.5 <br> 1.0 <br> 0.5 <br> 0.75 <br> 05 <br> 1.0 <br> 1.0 | nS <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ <br> $\mu \mathrm{S}$ <br> $\boldsymbol{S}$ <br> $\mu \mathrm{S}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |

## ABSOLUTE MAXIMUM RATINGS*

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

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

## OPERATING CONDITIONS

| Parameter | Symbol | Value |
| :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | $5 \mathrm{~V} \pm 5 \%$ |
| Temperature Range | $\mathrm{T}_{\mathrm{A}}$ |  |
| Commercial <br> Industrial |  | $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 ${ }^{1}$ | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{iH}}$ | +2.0 | - | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | -0.3 | - | +0.8 | V |  |
| Input Leakage Current R $\bar{W}, \overline{R E S}, R S 0, R S 1, C S 0, C S 1, \overline{C S 2}$, CA1, CB1, $\emptyset 2$ | $\mathrm{I}_{\mathrm{N}}$ | - | $\pm 1$ | $\pm 2.5$ | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=0 \mathrm{~V} \text { to } 5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~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 PAO-PA7, CA2 | $\mathrm{I}_{\mathrm{H}}$ | -100 | -250 | - | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}$ |
| Input Low Current PA0-PA7, CA2 | IIL | - | -1 | -1.6 | mA | $\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}$ |
| Output High Voltage <br> All outputs <br> PB0-PB7, CB2 (Darlington Drive) | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 2.4 \\ & 1.5 \\ & \hline \end{aligned}$ | - |  | $\begin{aligned} & \text { v } \\ & \text { v } \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\text {LOAD }}=-1.0 \mathrm{~mA} \end{aligned}$ |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | - | +0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing) Logic PB0-PB7, CB2 (Darlington Drive) | ІО | $\begin{array}{r} -100 \\ -1.0 \end{array}$ | $\begin{gathered} -1000 \\ -2.5 \end{gathered}$ | $\overline{-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{I}_{\mathrm{L}}$ | 1.6 | - | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Output Leakage Current (Off State) $\overline{\mathrm{IRQA}}, \overline{\mathrm{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 | $P_{\text {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, $\emptyset 2$ | $\mathrm{C}_{\text {IN }}$ | - | - | $\begin{array}{r} 10 \\ 7.0 \\ 20 \\ \hline \end{array}$ | pF | $\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{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$. |  |  |  |  |  |  |

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



|  | MILLIMETERS |  |  | INCHES |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |  |
| A | 5029 | 5131 | 1980 | 2020 |  |
| B | 1486 | 1562 | 0585 | 0615 |  |
| C | 254 | 419 | 0100 | 0165 |  |
| D | 038 | 053 | 0015 | 0021 |  |
| F | 076 | 140 | 0030 | 0055 |  |
| G | 254 | BSC | 0100 |  | BSC |
| H | 076 | 178 | 0030 | 0070 |  |
| J | 020 | 033 | 0008 | 0013 |  |
| K | 254 | 419 | 0100 | 0165 |  |
| L | 1460 | 1537 | 0575 | 0605 |  |
| M | 0 | 10 | 0 | 10 |  |
| N | 051 | 152 | 0020 | 0060 |  |

40-PIN PLASTIC DIP


|  | MILLIMETERS |  |  | INCHES |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |  |
| A | 5128 | 5232 | 2040 | 2060 |  |
| B | 1372 | 1422 | 0540 | 0560 |  |
| C | 355 | 508 | 0140 | 0200 |  |
| D | 036 | 051 | 0014 | 0020 |  |
| F | 102 | 152 | 0040 | 0060 |  |
| G | 254 | BSC | 0100 BSC |  |  |
| H | 165 | 216 | 0065 | 0085 |  |
| J | 020 | 030 | 0008 | 0012 |  |
| K | 305 | 356 | 0120 | 0140 |  |
| L | 1524 BSC | 0600 |  | BSC |  |
| M | 7 | 10 | 7 | 10 |  |
| $\mathbf{N}$ | 051 | 102 | 0020 | 0040 |  |

# R6522 <br> VERSATILE INTERFACE ADAPTER (VIA) 

## DESCRIPTION

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

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

|  <br> R6522 Pin Configuration |
| :---: |

## 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 $\overline{\mathrm{CS} 2}$ inputs. When $\mathrm{R} \overline{\mathrm{W}}$ is low, (write operation) and the R6522 is selected, data is transferred from the processor bus into the selected R6522 register. When $\mathrm{R} / \overline{\mathrm{W}}$ is high, (read operation) and the R6522 is selected, data is transferred from the selected R6422 register to the processor bus.

## DATA BUS (D0-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-ımpedance.

## 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 ( $\overline{\mathrm{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

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


Figure 9. Read Handshake Timing (Port A Only)

## Write Handshake

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

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 $\overline{\mathrm{RQ}}$ goes low if the T1 interrupt is enabled. Timer 1 then
disables any further interrupts, automatically transers the contents of the latches into the counter and continues to decrement. In addition, the timer may be programmed to invert the output signal on peripheral pin PB7 each time it "times-out." Each of these modes is discussed separaely below.

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

REG 6-TIMER 1 LOW-ORDER LATCH


WRITE - 8 BITS LOADED INTO T1 LOW-ORDER LATCHES. THIS OPERATION IS NO DIFFERENT THAN A WRITE INTO REG 4
READ - 8 BITS FROM T1 LOW-ORDER LATCHES TRANSFERRED TO MPU UNLIKE REG 4 operation, this does not cause RESET OF T1 INTERRUPT FLAG

REG 7-TIMER 1 HIGH-ORDER LATCH


COUNT VALUE

WRITE - 8 BITS LOADED INTO T1 HIGH-ORDER LATCHES UNLIKE REG 4 OPERATION NO LATCH-TO-COUNTER TRANSFERS TAKE PLACE
READ - 8 BITS FROM T1 HIGH-ORDER LATCHES TRANSFERRED TO MPU

Figure 12. Timer 1 (T1) Latch Registers

REG 4-TIMER 1 LOW-ORDER COUNTER


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

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 TI INTERRUPT FLAG ALSO IS RESET
READ - 8 IBTS FROM T1 HIGH-ORDER COUNTER TRANSFERRED TO MPU

Figure 13. Timer 1 (T1) Counter Registers

REG 11—AUXILIARY CONTROL REGISTER


## Timer 1 One-Shot Mode

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

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

In the one-shot mode, writing into the T1L-H has no effect on the operation of Timer 1. However, it will be necessary to assure that the low order latch contains the proper data before initiating the count-down with a "write T1C-H" operation. When the processor writes into the high order counter (T1C-H), the T1 interrupt flag will be cleared, the contents of the low order latch will be transferred into the low order counter, and the timer will begin to decrement at system clock rate. If the PB7 output is enabled, this signal will go low on the $\emptyset 2$ following the write operation. When the counter reaches zero, the T1 interrupt flag will be set, the $\overline{\mathrm{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 toproduce a square wave on PB7 whose frequency is not affected by variations in the processor interrupt response time This is accomplished in the "free-running" mode.

In the free-running mode, the interrupt flag is set and the signal on PB7 is inverted each time the counter reaches zero, at which time the timer automatically transfers the contents of the latch into the counter ( 16 bits) and continues to decrement from there. The interrupt flag can be cleared by writing T1C-H, 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 freerunning mode with the output enabled. In this mode, the signal on PB7 is inverted and the interrupt flag is set with each timeout. By responding to the interrupts with new data for the latches, the processor can determine the period of the next half cycle during each half cycle of the output signal on PB7. In this manner, very complex waveforms can be generated.

A precaution to take in the use of PB7 as the timer output concerns the Data Direction Register contents for PB7. Both DDRB bit 7 and ACR bit 7 must be 1 for PB7 to function as the timer output. If one is 1 and 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, T2 provides a single interrupt for each "write T2C-H" operation. After timing out, the counter will continue to decrement. However, setting of the interrupt flag is disabled after initial time-out so that it will not be set by the counter
decrementing again through zero. The processor must rewrite T2C-H to enable setting of the interrupt flag. The interrupt flag is cleared by reading T2C-L or by writing T2C-H. Timing for this operation is shown in Figure 18.

## Timer 2 Pulse Counting Mode

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

REG 8-TIMER 2 LOW-ORDER LATCH/COUNTER


WRITE - 8 BITS LOADED INTO T2 LOW-ORDER LATCH
READ - 8 BITS FROM T2 LOW ORDER COUNTER TRANSFERRED TO MPU T2 INTERRUPT FLAG IS RESET

REG 9-TIMER 2 HIGH-ORDER LATCH/COUNTER


WRITE - 8 BITS LOADED INTO T? HIGH ORDER
COUNTER ALSO LOW ORDER LATCH TRANSFERRED TO LOW ORDER COUNTER IN ADDITION, T2 INTERRUPT FLAG IS RESET
READ - 8 BITS FROM T2 HIGH ORDER COUNTER TRANSFERRED TO MPU

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


Figure 20. Shift Registers

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 $\varnothing 2$ clock cycle following the positive-going edge of the CB1 clock pulse. After 8 CB1 clock pulses, the shift register interrupt flag will set and $\overline{\mathrm{RQ}}$ will go low.

## SR Mode 2 - Shift In Under 02 Control

In mode 2, the shift rate is a direct function of the system clock frequency (Figure 23). CB1 becomes an output which generates shift pulses for controlling external devices. Timer 2 operates as an independent interval timer and has no effect on SR. The shifting operation is triggered by reading or writing the Shift Register. Data is shifted, first into bit 0 and is then shifted into the next higher order bit of the shift register on the trailing edge of each $\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.

REG 11-AUXILIARY CONTROL REGISTER


| 4 | 3 | 2 | OPERATION |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | DISABLED |
| 0 | 0 | 1 | SHIFT IN UNDER CONTROL OF T2 |
| 0 | 1 | 0 | SHIFT IN UNDER CONTROL OF ' $/ 2$ |
| 0 | 1 | 1 | SHIFT IN UNDER CONTROL OF EXT CLK |
| 1 | 0 | 0 | SHIFT OUT FREE RUNNING AT T2 RATE |
| 1 | 0 | 1 | SHIFT OUT UNDER CONTROL OF T2 |
| 1 | 1 | 0 | SHIFT OUT UNDER CONTROL OF $\boldsymbol{~}_{2}$ |
| 1 | 1 | 1 | SHIFT OUT UNDER CONTROL OF EXT CLK |

Figure 21. Shift Register Modes


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

## SR Mode 3 - Shift In Under CB1 Control

In mode 3, external pin CB1 becomes an input (Figure 24). This allows an external device to load the shift register at its own pace. The shift register counter will interrupt the processor each time 8 bits have been shifted in. The shift register stops after 8 counts and must be reset to start again. Reading or writing the Shift Register resets the Interrrupt 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 posiive 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 triggerd 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 02 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 02 Control
In mode 6 , the shift rate is controlled by the $\emptyset 2$ system clock (Figure 27).

## SR Mode 7 - Shift Out Under CB1 Control

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

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


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


Figure 27. SR Mode 6 - Shift Out Under $\boldsymbol{\$ 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{RQ}}$ ) 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 IRQ output. This bit corresponds to the logic function: $\overline{\mathrm{RQ}}=\mathrm{IFR} 6 \times$ IER6 + IFR5 $\times$ IER5 + IFR4 $\times$ IER4 + IFR3 $\times$ IER3 + IFR2 $\times I E R 2+I F R 1 \times I E R 1+I F R 0 \times I E R 0$.

Note:
$x=\operatorname{logic} A N D,+=$ Logic OR.
The IFR bit 7 is not a flag. Therefore, this bit is not directly cleared by writing a logic 1 into it. It can only be cleared by clearing all the flags in the register or by disabling all the active interrupts as discussed in the next section.

## Interrupt Enable Register (IER)

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

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

REG 14-INTERRUPT ENABLE REGISTER


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

Figure 30. Interrupt Enable Register (IER)

## PERIPHERAL INTERFACE CHARACTERISTICS

| Symbol | Characteristic | Min. | Max. | Unit | Figure |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{r}}, \mathrm{t}_{\mathrm{f}}$ | Rise and Fall Time for CA1, CB1, CA2 and CB2 Input Signals | - | 10 | $\mu \mathrm{S}$ | - |
| $\mathrm{t}_{\text {cA2 }}$ | Delay Time, Clock Negative Transition to CA2 Negative Transition (read handshake or pulse mode) | - | 1.0 | $\mu \mathrm{S}$ | 31a, 31b |
| $\mathrm{t}_{\mathrm{RS} 1}$ | Delay Time, Clock Negative Transition to CA2 Positive Transition (pulse mode) | - | 1.0 | $\mu \mathrm{S}$ | 31a |
| $\mathrm{t}_{\text {RS2 }}$ | 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 | 020 | 1.5 | $\mu \mathrm{S}$ | 31c, 31d |
| $\mathrm{t}_{\text {RS3 }}$ | Delay Time, Clock Positive Transition to CA2 or CB2 Positive Transition (pulse mode) | - | 1.0 | $\mu \mathrm{S}$ | 31 c |
| $\mathrm{t}_{\mathrm{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 |
| $\mathrm{t}_{\mathrm{LL}}$ | Setup Time, Peripheral Data Valid to CA1 or CB1 Active Transition (input latching) | 300 | - | ns | 31 e |
| $\mathrm{t}_{\mathrm{AL}}$ | CA1, CB1 Setup Prior to Transition to Arm Latch | 300 | - | ns | 31 e |
| $t_{\text {PDH }}$ | Peripheral Data Hold After CA1, CB1 Transition | 150 | - | ns | 31 e |
| $\mathrm{t}_{\text {SR1 }}$ | Shift-Out Delay Time - Time from $\phi_{2}$ Falling Edge to CB2 Data Out | - | 300 | ns | 319 |
| $\mathrm{t}_{\text {SR2 }}$ | Shift-In Setup Tıme - Time from CB2 Data In to $\phi_{2}$ Rising Edge | 300 | - | ns | 31 g |
| $\mathrm{t}_{\text {SR } 3}$ | External Shift Clock (CB1) Setup Time Relative to $\phi_{2}$ Traling Edge | 100 | $\mathrm{T}_{\mathrm{Cr}}$ | ns | 31 g |
| $\mathrm{t}_{\text {IPW }}$ | Pulse Width - PB6 Input Pulse | $2 \times T_{C Y}$ | - |  | 311 |
| ticw | Pulse Width - CB1 Input Clock | $2 \times T_{C Y}$ | - |  | 31h |
| $\mathrm{t}_{\text {IPS }}$ | Pulse Spacing - PB6 Input Pulse | $2 \times \mathrm{T}_{C Y}$ | - |  | 311 |
| $\mathrm{t}_{\text {c }}$ | 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
 INPUT


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 | $T_{A C R}$ | 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}_{C Y}$ | 1 | 10 | 0.50 | 10 | $\mu \mathrm{s}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\emptyset 2$ Puise Width | $\mathrm{T}_{\mathrm{C}}$ | 470 | - | 235 | - | ns |
| Address Set-Up Time | $\mathrm{T}_{\text {ACW }}$ | 180 | - | 90 | - | ns |
| Address Hold Time | T ${ }_{\text {caw }}$ | 0 | - | 0 | - | ns |
| R/ $\bar{W}$ Set-Up Time | TwCw | 180 | - | 90 | - | ns |
| $\mathrm{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}_{\mathrm{HW}}$ | 10 | - | 10 | - | ns |
| Peripheral Data Delay Time | $\mathrm{T}_{\text {CPW }}$ | - | 1.0 | - | 0.5 | $\mu \mathrm{S}$ |
| Peripheral Data Delay Time to CMOS Levels | $\mathrm{T}_{\text {cmos }}$ | - | 2.0 | - | 1.0 | $\mu \mathrm{S}$ |
| Note: $\mathrm{t}_{\mathrm{R}}$ and $\mathrm{t}_{\mathrm{F}}=10$ to 30 ns . |  |  |  |  |  |  |

## BUS TIMING WAVEFORMS



Read Timing Waveforms


Write Timing Waveforms

## ABSOLUTE MAXIMUM RATINGS*

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

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

## OPERATING CONDITIONS

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

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min. | Typ. ${ }^{3}$ | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.4 | - | $\mathrm{V}_{\mathrm{CC}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | - | 0.4 | V |  |
| Input Leakage Current <br> R $\bar{W}, \overline{\text { RES }}, \mathrm{RS} 0, \mathrm{RS} 1, \mathrm{RS} 2, \mathrm{RS} 3, \mathrm{CS} 1, \overline{\mathrm{CS} 2}, \mathrm{CA} 1, ~ \emptyset 2$ | $\mathrm{I}_{\mathrm{IN}}$ | - | $\pm 1$ | $\pm 2.5$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V} \text { to } 5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State Off D0-D07 | $\mathrm{I}_{\text {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 <br> PAO-PA7, CA2, PB0-PB7, CB1, CBS | $\mathrm{I}_{\mathrm{H}}$ | -100 | -200 | - | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{iN}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Input Low Current <br> PAO-PA7, CA2, PB0-PB7, CB1, CB2 | ILI | - | -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 <br> All outputs <br> PB0-PB7, CB2 (Darlington Drive) | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 2.4 \\ & 1.5 \end{aligned}$ | - | - |  | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\text {LOAD }}=-1.0 \mathrm{~mA} \end{aligned}$ |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ | - | - | 0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing) 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} \\ & \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) $\overline{\mathrm{IRQ}}$ | 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 R/\overline{W},\overline{RES}, RS0, RS1, RS2, RS3, CS1, \overline{CS2,} D0-D7, PAO-PA7, CA1, CA2, PB0-PB7 CB1, CB2 \|2 Input``` | $\mathrm{C}_{\text {IN }}$ | - | - | $\begin{gathered} 7 \\ 10 \\ 20 \end{gathered}$ | 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 | $\mathrm{C}_{\text {OUt }}$ | - | - | 10 | pF |  |
| Notes: <br> 1. All units are direct current (DC) except for capacitance. <br> 2. Negative sign indicates outward current flow, positive indicates inward flow. <br> 3. Typical values shown for $\mathrm{V}_{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 | 5029 | 5131 | 1980 | 2020 |
| B | 1486 | 1562 | 0585 | 0615 |
| C | 254 | 419 | 0100 | 0165 |
| D | 038 | 053 | 0015 | 0021 |
| F | 076 | 140 | 0030 | 0055 |
| G | 254 BSC | 0100 |  | BSC |
| H | 076 | 178 | 0030 | 0070 |
| J | 020 | 033 | 0008 | 0013 |
| K | 254 | 419 | 0100 | 0165 |
| L | 1460 | 1537 | 0575 | 0605 |
| M | $0^{\circ}$ | $10^{\circ}$ | $0^{\circ}$ | $10^{\circ}$ |
| N | 051 | 152 | 0020 | 0060 |

## 40-PIN PLASTIC DIP



|  | MILLIMETERS |  | INCHES |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |  |
| A | 5128 | 5232 | 2040 | 2060 |  |
| B | 1372 | 1422 | 0540 | 0560 |  |
| C | 355 | 508 | 0140 | 0200 |  |
| D | 036 | 051 | 0014 | 0020 |  |
| F | 102 | 152 | 0040 | 0060 |  |
| G | 254 |  | BSC | 0100 BSC |  |
| H | 165 | 216 | 0065 | 0085 |  |
| J | 020 | 030 | 0008 | 0012 |  |
| K | 305 | 356 | 0120 | 0140 |  |
| L | 1524 | BSC | 060 | BSC |  |
| M | $7^{\circ}$ |  | $10^{\circ}$ | 7 | 10 |
| N | 051 |  | 102 | 0020 | 0040 |

## R6530 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 perıpheral 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

| Part Number: R6530 <br> Package: <br> C = Ceramic DIP <br> $P=$ Plastic DIP <br> Temperature Range: $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ <br> Frequency: <br> 1 MHz |
| :---: |
| Note: A custom part number will be assigned by Rockwell. ROM codes should be submitted using ROM Code Order Form, Order No. 2137. |

## 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 tımer
- 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 7 K contiguous bytes of ROM with no external decoding


R6530 Pin Configuration

## INTERFACE SIGNALS

## RESET (RES)

During system initalization, a $\overline{\text { RES }}$ input causes 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{\text { RES }}$ signal. The $\overline{\mathrm{RES}}$ signal must be held low for at least one clock period when reset is required.

## READ/WRITE (R/ $\overline{\mathbf{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 (I(RQ)

The $\overline{\mathrm{RQ}}$ pin is an interrupt pin from the interval tımer. This same pin, if not used as an interrupt, can be used as a perıpheral I/O pin (PB7). When used as an interrupt, the pın 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 (A0-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 operatıons. 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 (CSO, CS1)

Pins 18 and 19 are individually selectable at mask tıme as either chip selects CS1 and CS2, respectively, or port B functions PB6 and PB5, respectively.


Interface Signals

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


R6530 Block Diagram

## INTERVAL TIMER

The Timer section of the R6530 contains three basic parts: prescale divide down register, programmable 8-bit regıster 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 255 T .

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

At the same time that data is being written to the Interval Timer, the counting interval ( $1,8,64$, or 1024 T ) is decoded from address lines A0 and A1. During a Read or Write operation address line A3 controls the interrupt capability of PB7, i.e., A3 = 1 enables $\overline{\mathrm{RQ}}$ on PB7, A3 $=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 tımer is read prior to the interrupt flag being set, the number of time intervals remaining will be read, i.e., $51,50,49$, etc.

When the timer has counted down to 00000000 on the next count time an interrupt will occur and the counter will read $\begin{array}{lllllll}1 & 1 & 1 & 1 & 1 & 1 & \text {. After interrupt, the Timer Register decre- }\end{array}$ ments 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 27T. The value read is in one's complement.

$$
\begin{array}{ll}
\text { Value read }=\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{array}
$$

Thus, to arrive at the total elapsed time, merely do a one's complement and add to the original time written into the timer. Again, assume time written as $00110100(=52)$. With a divide by 8 , total time to interrupt is $(52 \times 8)+1=417 \mathrm{~T}$. Total elapsed time would be $417 \mathrm{~T}+27 \mathrm{~T}=444 \mathrm{~T}$, assuming the value read after interrupt was 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 RSO. The R6502 and R6530 in a 2-chip system would use RSO to distinguish between ROM and non-ROM sections of the R6530. With the addressing pins available, a total of 7 K contiguous ROM may be addressed with no external decode. 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 7K 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 A0 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{gathered} \text { CS1 } \\ \text { All } \end{gathered}$ | $\begin{aligned} & \text { RSO } \\ & \text { A10 } \end{aligned}$ | A9 | A8 | A7 | A6 |
| R6530 \#1 | ROM Select RAM Select I/O 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}$ | $X$ 0 0 | $X$ 0 0 |
| R6530 \#2 | ROM Select RAM Select //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} & \mathrm{X} \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & X \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & X \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & x \\ & 1 \\ & 1 \end{aligned}$ |
| R6530 \#3 | ROM Select RAM Select I/O Timer | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \mathrm{x} \\ & 0 \\ & 1 \end{aligned}$ | $\begin{aligned} & x \\ & 0 \\ & 0 \end{aligned}$ | X 1 1 | X 0 0 |
| R6530 \#4 | ROM Select RAM Select I/O Timer | $\begin{aligned} & 1 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & 0 \\ & 0 \\ & 0 \end{aligned}$ | X 0 1 | $\begin{aligned} & \hline X \\ & 0 \\ & 0 \end{aligned}$ | X 1 1 | $X$ 1 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 \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & 0 \\ & 0 \end{aligned}$ | $X$ 0 0 |
| R6530 \#6 | ROM Select FAM Select I/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 \\ & u \\ & 1 \end{aligned}$ | $\begin{aligned} & \hline x \\ & y \\ & 1 \end{aligned}$ | $\begin{aligned} & \mathrm{X} \\ & 0 \\ & 0 \end{aligned}$ | $\begin{aligned} & \hline x \\ & 1 \\ & 1 \end{aligned}$ |
| 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} & \mathrm{X} \\ & 0 \\ & 1 \end{aligned}$ | $X$ 1 1 | X 1 1 | X 0 0 |
| Note: * RAM select for R6530 \#5 would read $=\overline{\mathrm{A} 12} \bullet \overline{\mathrm{~A} 11} \bullet \overline{\mathrm{~A} 10} \bullet \overline{\mathrm{~A} 9} \bullet \mathrm{~A} 8 \bullet \overline{\mathrm{~A} 7} \bullet \overline{\mathrm{~A} 6}$ |  |  |  |  |  |  |  |  |

A X indicates mask programming, i.e..
ROM select $=$ CS1•RSO
RAM select $=\overline{\mathrm{CS} 1} \bullet \overline{\mathrm{RSO}} \bullet \overline{\mathrm{Ag}} \bullet \mathrm{A} 7 \bullet \mathrm{~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 | I/O 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 |  | X | 0 | 1 | 0 |
| Write Timer |  |  |  |  |  |  |  |  |
| -IT | 0 | 0 | 1 | 0 | * | 1 | 0 | 0 |
| -8T | 0 | 0 | 1 | 0 | * | 1 | 0 | 1 |
| -64T | 0 | 0 | 1 | 0 | * | 1 | 1 | 0 |
| -1024T | 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: ${ }^{*} \mathrm{~A} 3=1$ Enables $\overline{\mathrm{RQ}}$ to PB7 <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 | TWCR | 180 | - | ns |
| Address valid before positive transition of clock | TACR | 180 | - | ns |
| Peripheral data valid before positive transition of clock | TPCR | 300 | - | ns |
| Data Bus valid after positive transition of clock | TCDR | - | 395 | ns |
| Data Bus Hold Time | THR | 10 | - | ns |
| $\overline{\mathrm{RQQ}}$ (Interval Timer Interrupt) valid before positive transition of clock | TIC | 200 | - | ns |

Note: Loadıng $=30 \mathrm{pF}+1$ TTL load for PA0-PA7, PB0-PB7
$=130 \mathrm{pF}+1$ TTL load for D0-D7

Write Timing

| Characteristic | Symbol | Min | Max | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Clock Perıod | $\mathrm{T}_{\mathrm{CYC}}$ | 1 | 10 | $\mu \mathrm{S}$ |
| Rise \& Fall Times | $\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}$ | - | 25 | ns |
| Clock Pulse Width | T | 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 transitıon of clock | TCPW | - | 1 | $\mu \mathrm{S}$ |
| Peripheral data valid after negative transition of clock driving CMOS (Level $=$ VCC $-30 \%$ ) | TCMOS | - | 2 | $\mu \mathrm{S}$ |

READ TIMING WAVEFORMS


## 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 |
| Operatıng 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(\mathrm{V}_{\mathrm{cc}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{ss}}=0 \mathrm{~V}, 0^{\circ} \mathrm{C}\right.$ to $70^{\circ} \mathrm{C}$, unless otherwise noted)

| Characteristic | Symbol | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\text {IH }}$ | +2.4 |  | $\mathrm{V}_{\mathrm{Cc}}$ | V |  |
| Input Low Voltage | $V_{\text {IL }}$ | -0.3 |  | + 0.4 | V |  |
| Input Leakage Current A0-A9, RSO, R $\bar{W}, \overline{\mathrm{RES}}, 02, \mathrm{PB6}^{(3)}, \mathrm{PBS}^{(3)}$ | 1 IN |  | 1.0 | 2.5 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0 \text { to }+5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \end{aligned}$ |
| Input Leakage Current for Three State Off DO-D7 | $I_{\text {TSI }}$ |  | $\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 PA0-PA7, PB0-PB7 | $I_{\text {IH }}$ | -100 | -300 |  | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {IN }}=2.4 \mathrm{~V}$ |
| Input Low Current; PAO-PA7 PB0-PB7 | $I_{\text {IL }}$ |  | -1.0 | -1.6 | mA | $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ |
| Output High Voltage <br> PAO-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{aligned} & \mathrm{V}_{C C}=4.25 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\text {LOAD }}=3.0 \mathrm{~mA} \end{aligned}$ |
| Output Low Voltage | $\mathrm{V}_{\mathrm{OL}}$ |  |  | +04 | 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) <br> PAO-PA7, PB0-PB7 (TTL drive), D0-D7 <br> PB0-PB7 (other drive) | IOH | $\begin{aligned} & -100 \\ & -30 \end{aligned}$ | $\begin{gathered} -1000 \\ -5.0 \\ \hline \end{gathered}$ |  | $\begin{aligned} & \mu \mathrm{A} \\ & \mathrm{~mA} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{OH}}=15 \mathrm{~V} \end{aligned}$ |
| Output Low Current (Sinkıng) PAO-PA7, PB0-PB7 | IOL | 1.6 |  |  | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Power Dissipation | $P_{\text {D }}$ |  | 500 | 1000 | mW |  |
| Input Capacitance ø2 Logic | $\begin{aligned} & \mathrm{C}_{\mathrm{CLK}} \\ & \mathrm{C}_{\mathrm{IN}} \end{aligned}$ |  |  | $\begin{aligned} & 30 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & V_{\mathrm{IN}}=0, \mathrm{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

## 40-PIN CERAMIC DIP



|  | MILLIMETERS |  |  | INCHES |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |  |
| A | 5029 | 5131 | 1980 | 2020 |  |
| B | 1486 | 1562 | 0585 | 0615 |  |
| C | 254 | 419 | 0100 | 0165 |  |
| D | 038 | 053 | 0015 | 0021 |  |
| F | 076 | 140 | 0030 | 0055 |  |
| G | 254 | BSC | 0100 |  | BSC |
| H | 076 | 178 | 0030 | 0070 |  |
| J | 020 | 033 | 0008 | 0013 |  |
| K | 254 | 419 | 0100 | 0165 |  |
| L | 1460 | 1537 | 0575 | 0605 |  |
| M | $0^{\circ}$ | $10^{\circ}$ | $0^{\circ}$ | $10^{\circ}$ |  |
| N | 051 | 152 | 0020 | 0060 |  |

40-PIN PLASTIC DIP


| DIM | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
| A | 5128 | 523 | 2040 | 060 |
| B | 1372 | 1422 | 0540 | 0560 |
| C | 355 | 508 | 0140 | 0200 |
| D | 036 | 051 | 0014 | 0020 |
| F | 102 | 152 | 0040 | 0060 |
| G | 254 BSC |  | 0100 BSC |  |
| H | 165 | 216 | 0065 | 0085 |
| J | 020 | 030 | 0008 | 0012 |
| K | 305 | 356 | 0120 | 0140 |
| L | 1524 BSC |  | 0600 BSC |  |
| M | 7 | $10^{\circ}$ | 7 | 10 |
| N | 051 | 102 | 0020 | 0040 |

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


NOTE: Contact your local Rockwell representative for availability.

## 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 ( $\overline{\text { 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{\operatorname{RES}}$ signal must be low for at least four clock periods when reset is required.

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

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

## DATA BUS (D0-D7)

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

## READ/WRITE ( $\mathrm{R} / \overline{\mathbf{W}}$ )

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

## PHASE 2 CLOCK ( $\phi \mathbf{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, PCO-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.


NOTE: *52-PIN VERSION ONLY


R6531 40-Pin DIP Configurations

| Vss ${ }^{1}$ |  | PB3/SDI0 | VSS 1 | 52 | PB3/SDIO |
| :---: | :---: | :---: | :---: | :---: | :---: |
| (CS2) PB4/CNTO ${ }^{2}$ | 51 | R//W | (CS2) PB4/CNTO 2 | 51 | R/W |
| (CS1) PB5/CNT1 ${ }^{-1}$ | 50 | - PC6 | (CS1) PB5/CNT1 - 3 | 50 | $\square \mathrm{PC6}$ |
| PB6/IRQ ${ }^{4}$ | 49 | PB2/SCLK | PB6/RQ - 4 | 49 | PB2/SCLK |
| PC7 ${ }^{-1}$ | 48 | PB1/CA2 | PC7 - 5 | 48 | PB1/CA2 |
| RES $\square^{6}$ | 47 | PB0/CA1 | RES 6 | 47 | PBo/CA1 |
| D7 ${ }^{1}$ | 46 | - PC5 | D7 7 | 46 | Pr5 |
| D6 8 | 45 | P PA7 | D6 8 | 45 | - PA7 |
| D5 ${ }^{-1}$ | 44 | PPA6 | D5 9 | 44 | ص PA6 |
| PD3 10 | 43 | PPA5 | (CS3) PD2 10 | 43 | ص PA5 |
| (CS3) PD2 11 | 42 | PPA4 | A8 11 | 42 | P PA4 |
| A8 ${ }^{12}$ | 41 | PPC4 | A7 12 | 41 | $\square \mathrm{PC} 4$ |
| A7 ${ }^{13}$ | 40 | A 4 | ¢2 ${ }^{\text {d }}$ | 40 | - ${ }^{\text {a }}$ |
| ¢2 ${ }^{\text {a }} 14$ | 39 | ص A6 | PD1 14 | 39 | ®A6 |
| PD1 ${ }^{15}$ | 38 | صPC3 | D4 ${ }^{15}$ | 38 | صPC3 |
| D4 ${ }^{16}$ | 37 | РPA3 | D3 ${ }^{16}$ | 37 | P PA3 |
| D3 ${ }^{17}$ | 36 | $\square \mathrm{PA} 2$ | PDO 17 | 36 | $\square \mathrm{PA2}$ |
| PDO 18 | 35 | PPA1 | D2 18 | 35 | صPA1 |
| D2 ${ }^{19}$ | 34 | PPAO | D1 $1^{19}$ | 34 | P PAO |
| D1 ${ }^{20}$ | 33 | صA2 | D0 ${ }^{20}$ | 33 | صA2 |
| D0 $\mathrm{S}^{21}$ | 32 | صA4 | A0 ${ }^{21}$ | 32 | ®A4 |
| AO - 22 | 31 | P PC2 | A11 - 22 | 31 | - PC2 |
| A11 ${ }^{-13}$ | 30 | $ص \mathrm{PC} 1$ | PCO - 23 | 30 | $\square \mathrm{PC} 1$ |
| PCO -24 | 29 | ص A1 | A9 $\square^{24}$ | 29 | صA1 |
| A9 $\square^{25}$ | 28 | A3 | A10 ${ }^{25}$ | 28 | ®A3 |
| A10 [26 |  | $\square \mathrm{VCC}$ | VRR 26 | 27 | $ص$ vcc |
| PD3 OPTION |  |  | VRR OPTION |  |  |

## INTERNAL ORGANIZATION

The R6531 is divided into three basic functions: ROM, RAM, and $\mathrm{I} / \mathrm{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 16 K 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 14 K bytes of ROM without the need for external decoding.

## RAM-128 BYTES (1024 BITS)

The $128 \times 8$ static RAM of a given R6531 is addressed by lines 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

| R6531 <br> Function | Chip Selects |  |  |
| :---: | :---: | :---: | :---: |
|  | CS3 | CS2 | CS1 |
| ROM | X | X | $x$ |
| RAM | Y | Y | Y |
| I/O | Z | Z | Z |


| Address Inputs (A0-A11) |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| x | 2K ROM Decode |  |  |  |  |  |  |  |  |  |  |
| Y | Y | Y | Y | Y | 128 RAM Decode |  |  |  |  |  |  |
| Z | Z | Z | Z | Z | Z | Z | Z | I/O Decode |  |  |  |

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 <br> Selects |  | Address Inputs (A0-A11) |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | CS2 | CS1 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| RAM | N | N | L | L | L | N | L | 128 RAM Decode |  |  |  |  |  |  |
| 1/O | N | N | L | H | H | H | L | L | L | L | 1/ | D | co |  |
| 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 <br> 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 | 1/O | eco | de |

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 / \bar{W}$ state is shown in Table 4.

Table 4. Register Selection

| Hex <br> Addr | Address Line |  |  |  | Operation |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | A3 | A2 | A1 | AO | 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 IRQ Request Output, then PB6 will be set low to request the R6502 CPU to service $\overline{\mathrm{IRQ}}$.

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 PB0, and cleared by a Read or Write to Port PA; see Handshake Timing Diagram for timing details.


R6531 Timing for Handshake Mode


R6531 Timing for Interrupt 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 $\phi 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.


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

$$
\begin{array}{cc}
\text { Mode } 3 & \text { - External Trigger - counts } \phi 2 \text { system clock } \\
& \text { pulses starting with a negative transition on } \\
& \text { PB5. }
\end{array}
$$

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

| Characteristic | Symbol | $\begin{gathered} \text { R6531 } \\ (1 \mathrm{MHz}) \\ \hline \end{gathered}$ |  | R6531A <br> ( 2 MHz ) |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | MIn | Max | Min | Max |  |
| Clock Period | Tcrc | 1.0 | 10 | 0.5 | 10 | $\mu \mathrm{s}$ |
| Clock Pulse Width | Tc | 470 | - | 235 | - | ns |
| Rise \& Fall Times | $\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}$ | - | 25 | - | 15 | ns |

READ TIMING

| $\mathrm{R} \overline{\mathrm{W}}$ valid before positive transition of clock | $\mathrm{T}_{\mathrm{WCR}}$ | 180 | - | 120 | - | ns |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| Address valid before positive transition of clock | $\mathrm{T}_{\mathrm{ACR}}$ | 180 | - | 120 | - | ns |
| Peripheral data valid before positive transition of clock | $\mathrm{T}_{\mathrm{PCR}}$ | 270 | - | 135 | - | ns |
| Data Bus valid after positive transition of clock | $\mathrm{T}_{\mathrm{CDR}}$ | - | 350 | - | 180 | ns |
| Data Bus Hold Time | $\mathrm{T}_{\mathrm{HR}}$ | 10 | - | 10 | - | ns |
| $\overline{\mathrm{RQ}}$ valid after negative transition of clock | $\mathrm{T}_{\mathrm{CC}}$ | - | 900 | - | 450 | ns |

WRITE TIMING

| $\mathrm{R} \bar{W}$ valid before positive transition of clock | Twow | 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{TLL} \text { for PAO-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 TIMING WAVEFORMS


## MAXIMUM RATINGS*

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

*Note: This device contaıns 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{IH}}$ | 2.0 | $V_{C C}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\text {IL }}$ | -0.3 | +0.8 | V |  |
| Input Leakage Current A0-A11, CS1-CS3, R/W, $\overline{\text { RES }}, \phi 2$, PDO-PD3 | $\mathrm{I}_{\mathrm{N}}$ | - | 2.5 | $\mu \mathrm{A}$ | $\begin{aligned} & V_{I N}=0 \mathrm{~V} \text { to } 5.0 \mathrm{~V} \\ & V_{C C}=0 \mathrm{~V} \end{aligned}$ |
| Leakage Current for Three-State Off (Three State) D0-D7, PA0-PA7, PB0-PB6 | $I_{\text {TSI }}$ | - | $\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 PAO-PA7, PB0-PB6, PD0-PD3 | $I_{1 H}$ | -100 | - | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=2.4 \mathrm{~V}$ |
| Input Low Current PAO-PA7, PB0-PB6, PD0-PD3 | IIL | 1.6 | - | mA | $\mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V}$ |
| $\begin{aligned} & \text { Output High Voltage } \\ & \text { D0-D7, PA0-PA7, PB0-PB6, PC0-PC7 } \end{aligned}$ | $\mathrm{V}_{\mathrm{OH}}$ | +2.4 | - | V | $\begin{aligned} & V_{C C}=4.75 \mathrm{~V} \\ & I_{\text {LOAD }}=-200 \mu \mathrm{~A} \end{aligned}$ |
| Output Low Voltage D0-D7, PA0-PA7, PB0-PB6, PC0-PC7 | $\mathrm{V}_{\mathrm{OL}}$ |  | +04 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=25 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing), PAO-PA7, PB0-PB6, PC0-PC7 | $\mathrm{I}_{\mathrm{OH}}$ | -200 | - | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{OH}}=24 \mathrm{~V}$ |
| Output Low Current (Sinkıng) PAO-PA7, PB0-PB7, PC0-PC7 | $\mathrm{I}_{\mathrm{OL}}$ | 21 | - | mA | $\mathrm{V}_{\mathrm{OL}}=04 \mathrm{~V}$ |
| Input Capacitance $\phi 2$ <br> Logic | $\mathrm{C}_{\text {CIk }}$ <br> $\mathrm{C}_{\mathrm{IN}}$ |  | $\begin{aligned} & 20 \\ & 10 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=50 \mathrm{~V}, \\ & \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ |  | 10 | pF | $\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}$ |
| Power Dissipation | $P_{D}$ |  | 10 | W |  |
| NOTES: <br> 1 All units are direct current (DC) <br> 2 Negative sign indicates current flow, positive indicates inward flow |  |  |  |  |  |

## PACKAGE DIMENSIONS



## R6532 <br> RAM-I/O-TIMER (RIOT)

## DESCRIPTION

The R6532 RAM-I/O-Timer (RIOT) integrates random access memory (RAM), parallel I/O data ports and timer functions into a single peripheral device which operates in conjunction with any CPU in the R6500 microprocessor family. It is comprised of a $128 \times 8$ static RAM, two software-controlled, 8 -bit bidirectional data ports allowing direct interfacing between the microcomputer and peripheral devices, a software programmable interval timer with interrupt, capable of timing in various intervals from 1 to 262,144 clock periods, and a programmable edgedetect circuit.

## ORDERING INFORMATION



## 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{\mathrm{RES}}$ input causes a zeroing of all four I/O registers. This in turn causes all I/O buses to act as inputs thus protecting external components from possible damage and erroneous data while the system is being configured under software control. The Data Bus Buffers are put into an OFF-STATE during Reset. Interrupt capability is disabled with the $\overline{\operatorname{RES}}$ signal. The $\overline{\mathrm{RES}}$ signal must be held low for at least two clock perıods 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{\mathrm{RAM} \text { SELECT }}(\overline{\mathrm{RS}})$ pin. The pins A0-A6 and $\overline{\mathrm{RS}}$ are always used as addressing pins. There are two additional pins which are used as CHIP SELECTS. They are pins CS1 and CS2. Tables 1 and 2 identify the functions selected and registers addressed depending upon the address line and $\overline{R S}$ inputs in conjunction with the $R \bar{W}$ level.

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

The R6532 has 16 pins available for perıpheral I/O operations. Each pin is individually software programmable to act as etther an input or an output. The 16 pins are divided into two 8 -bit ports, PAO-PA7 and PB0-PB7. (PA7 also has another use which is discussed later.) Each is set up as an input by writing a " 0 " into the corresponding bit of the data direction register. A "1" written into the data direction register causes its corresponding bit to be an output. When in the input mode, the peripheral output buffers are in the " 1 " state and the internal pull-up device acts as less than one TTL load to the peripheral data lines. On a Read operation, the microprocessor reads the peripheral pin. When the peripheral device gets information from the R6532 it receives data stored in the data register. The microprocessor reads valid pin information if the peripheral lines are greater than 2.0 volts for a " 1 " and less than 0.8 volt for a " 0 " as the peripheral pins are all TTL compatible. Pins PB0PB7 are also capable of sourcing 3 ma at 1.5 V , thus makıng them capable of Darlington drive.


Table 1. Address Decoding

| Operation | $\overline{\mathbf{R S}}$ | $\mathbf{R} \overline{\mathbf{W}}$ | $\mathbf{A 4}$ | $\mathbf{A 3}$ | $\mathbf{A 2}$ | A1 | A0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Write RAM | 0 | 0 | - | - | - | - | - |
| Read RAM | 0 | 1 | - | - | - | - | - |
| Write Output Reg A | 1 | 0 | - | - | 0 | 0 | 0 |
| Read Output Reg A | 1 | 1 | - | - | 0 | 0 | 0 |
| Write DDRA | 1 | 0 | - | - | 0 | 0 | 1 |
| Read DDRA | 1 | 1 | - | - | 0 | 0 | 1 |
| Write Output Reg B | 1 | 0 | - | - | 0 | 1 | 0 |
| Read Output Reg B | 1 | 1 | - | - | 0 | 1 | 0 |
| Write DDRB | 1 | 0 | - | - | 0 | 1 | 1 |
| Read DDRB | 1 | 1 | - | - | 0 | 1 | 1 |
| Write Timer |  |  |  |  |  |  |  |
| -1T | 1 | 0 | 1 | (a) | 1 | 0 | 0 |
| -8T | 1 | 0 | 1 | 1 | 0 | 1 | 0 |
| -64T | 1 | 0 | 1 | 1 | 1 |  |  |
| Read Timer | 1 | 0 | 1 | (a) | 1 | 1 | 1 |
| Read Interrupt Flag | 1 | 1 | - | (a) | 1 | - | 0 |
| Write Edge Detect Control | 1 | 1 | 1 | - | - | 1 | - |

Notes:
$-=$ Don't Care, " 1 " $=$ High level $(\geqslant 2.4 \mathrm{~V}$ ), " 0 " = Low level ( $\leqslant 0.4 \mathrm{~V}$ )
(a) A3 $=0$ to disable interrupt from timer to $\overline{I R Q}$
(c) $A 0=0$ for negative edge-detect
$\mathrm{A} 3=1$ to enable interrupt from timer to $\overline{\mathrm{R} \bar{Q}}$
$A 0=1$ for positive edge-detect
(b) A1 $=0$ to disable interrupt from PA7 to $\overline{\mathrm{RQ}}$
$\mathrm{A} 1=1$ to enable interrupt from PA7 to $\overline{\mathrm{IRQ}}$

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 regıster) | \$C | Read timer (enable interrupt) |
| \$3 | DDRB (' B ' side data direction register) | \$14 | Write tımer (divide by 1 , disable interrupt) |
| \$4 | Read tımer (disable interrupt) | \$15 | Write tımer (divide by 8 , disable interrupt) |
| \$4 | Write edge-detect control (negative edge-detect, disable interrupt) | $\begin{aligned} & \$ 16 \\ & \$ 17 \end{aligned}$ | Write timer (divide by 64, disable interrupt) Write timer (divide by 1024, disable interrupt) |
| \$5 | Read interrupt flag register (bit $7=$ timer, bit $6=$ | \$10 | 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 (postive 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 dıvided ınto four basıc sectıons, 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 contaned 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 ether 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 Regıster (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-pu!l 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 readıng the perıpheral pin as on Port $A$.


## EDGE DETECTING WITH PA7

In addition to acting as a peripheral I/O line, the PA7 line can be used as an edge-detecting input. In this mode, an active transition sets the internal interrupt flag (bit 6 of the Interrupt Flag register). Setting the interrupt flag causes $\overline{\mathrm{RQ}}$ output to go low if the PA7 interrupt has been enabled.

Control of the PA7 edge detecting mode is accomplished by writing to one of four addresses. In this operation, AO controls the polarity of the active transition and A1 acts to enable or disable interrupting of the processor. The data which is placed on the Data Bus during this operation is discarded and has no effect on the control of PA7.

The PA7 interrupt flag is set on an active transition, even if the pin is being used as a normal input or as a peripheral control output. The flag is also set by an active transition if the PA7 interrupt is disabled. The reset signal ( $\overline{\mathrm{RES}}$ ) disables the PA7 interrupt and enables negative (high-to-low) edge detection on PA7. The PA7 edge detect logic can be set to detect either a positive or negative transition and to either enable or disable interrupt ( $\overline{\mathrm{RQ}}$ ) generation upon detection.

During system initialization, the interrupt flag may inadvertently be set by an unexpected transition on the PA7. It is therefore recommended that the interrupt flag be cleared before enabling interrupting from PA7. To clear PA7 interrupt flag, simply read the interrupt Flag Register.

## INTERVAL TIMER

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

The Timer can be programmed to count up to 255 time intervals. Each time interval can be either $1 \mathrm{~T}, 8 \mathrm{~T}, 64 \mathrm{~T}$ or 1024 T increments, where $T$ is the system clock period. When a full count is reached, an interrupt flag is set to 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 0001100100 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 A3 controls the interrupt capability of PB7, i.e., A3 $=1$ enables $\overline{\mathrm{IRQ}}, \mathrm{A} 3=0$ disables $\overline{\mathrm{RQ}}$. 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}{lllllll}1 & 1 & 1 & 1 & 1 & 1 & 1 \text {. After the interrupt flag is set, the timer reg- }\end{array}$ ister 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 tıme since interrupt is 27T. The value read is in two's complement, but remember that interrupt occurred on count number one. Therefore, we must subtract 1 .
Value read \(\left.=1 \begin{array}{lllllllll}1 \& 1 \& 1 \& 0 \& 0 \& 1 \& 0 \& 0 <br>
Complement \& =0 \& 0 \& 0 \& 1 \& 1 \& 0 \& 1 \& 1 <br>

ADD 1 \& = \& 0 \& 0 \& 1 \& 1 \& 1 \& 0 \& 0\end{array}\right) \quad\)| 28 Equals two's com- |
| :--- |
| plement of register |

SUB 1

Thus, to arrive at the total elapsed time, merely do a two's complement add to the original time written into the timer. Again, assume time written as $00110100(=52)$. With a divide by 8 , total time to interrupt is $(52 \times 8)+1=417 \mathrm{~T}$. Total elapsed time would be $416 \mathrm{~T}+27 \mathrm{~T}=443 \mathrm{~T}$, assuming the value read after interrupt was 11100100 .

The interrupt flag will be reset whenever the Timer is accessed by a read or a write. However, the reading of the timer at the same time the interrupt occurs will not reset the interrupt flag. When the interrupt flags are read (D7 for the timer, D6 for the edge detect) data bus lines D0-D5 go to 0 .

When reading the timer after an interrupt, A3 should be low so as to disable the IRQ pin. This is done so as to avoid future interrupts untll after another Write timer operation.


Interval Time Example Waveforms

## BUS AND PERIPHERAL TIMING WAVEFORMS

READ TIMING


## WRITE TIMING



## AC CHARACTERISTICS

| Characteristic | Symbol | $\begin{gathered} \text { R6532 } \\ (1 \mathrm{MHz}) \end{gathered}$ |  | $\begin{aligned} & \text { R6532A } \\ & \text { ( } 2 \mathrm{MHz} \text { ) } \end{aligned}$ |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Clock Cycle Time | $\mathrm{T}_{\text {CrC }}$ | 1 | 10 | 0.5 | 10 | $\mu \mathrm{s}$ |
| Clock Pulse Width | $\mathrm{T}_{\mathrm{c}}$ | 470 | - | 240 | - | ns |
| Rise \& Fall Times | $T_{R}, T_{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 |
| Perıpheral Data Set Up Time | $\mathrm{T}_{\text {PCR }}$ | 300 | - | 150 | - | ns |

WRITE TIMING

| $\emptyset 2$ Cycle Tıme | $\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 / \bar{W}$ Set Up Time | T WCW | 180 | - | 90 | - | ns |
| R/W Hold Time | $\mathrm{T}_{\text {CWH }}$ | 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 Tıme | $\mathrm{T}_{\text {CPW }}$ | - | 1 | - | 0.5 | $\mu \mathrm{S}$ |
| Perıpheral Data Delay Time CMOS | $\mathrm{T}_{\text {CMOS }}$ | - | 2 | - | 1 | $\mu \mathrm{S}$ |

MAXIMUM RATINGS*

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

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

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min | Max | Unit ${ }^{(1)}$ | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\text {IH }}$ | 2.4 | $\mathrm{V}_{\mathrm{cc}}$ | V |  |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | 0 | 0.4 | V |  |
| Input Leakage Current: <br> A0-A6, RS, R $\bar{W}, \overline{\text { RES }}, \emptyset 2, C S 1, \overline{C S 2}$ | $\mathrm{I}_{\mathrm{N}}$ | - | 2.5 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V} \text { to } 5.0 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{cc}}=0 \mathrm{~V} \end{aligned}$ |
| Input Leakage Current for Three-State Off D0-D7 | $\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, PB0-PB7 | $\mathrm{I}_{\mathrm{H}}$ | -100 | - | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{HH}}=2.4 \mathrm{~V}$ |
| Input Low Current PAO-PA7, PB0-PB7 | ILL | - | -16 | mA | $\mathrm{V}_{\text {IN }}=0.4 \mathrm{~V}$ |
| ```Output High Voltage PAO-PA7, PB0-PB7 (TTL drive), D0-D7 PBO-PB7 (other than TTL drive, e.g., Darlington)``` | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & 2.4 \\ & 1.5 \end{aligned}$ | - | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \\ & \mathrm{I}_{\text {LOAD }}=3 \mathrm{~mA} \end{aligned}$ |
| Output Low Voitage D0-D7 | $\mathrm{V}_{\text {OL }}$ | - | 0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing) PAO-PA7, PB0-PB7 (TTL drive), D0-D7 PBO-PB7 (other drive, e.g., Darlington) | $\mathrm{IOH}^{\text {r }}$ | $\begin{aligned} & -100 \\ & -3.0 \end{aligned}$ | - | $\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 | loL | 1.6 | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Input Capacitance $\emptyset 2$ Other | $\begin{aligned} & \mathrm{C}_{\mathrm{CLK}} \\ & \mathrm{C}_{\text {IN }} \\ & \hline \end{aligned}$ | - | $\begin{aligned} & 30 \\ & 10 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ | $\begin{aligned} & V_{c \mathrm{CC}}=5.0 \mathrm{~V} \\ & V_{\mathrm{IN}}=0 \mathrm{~V} \\ & \mathrm{f}=1 \mathrm{MHz} \end{aligned}$ |
| Other Capacitance | $\mathrm{C}_{\text {OUT }}$ | - | 10 | pF |  |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | - | 1000 | mW | $\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}$ |

## Notes:

1. All units are direct current (DC).
2. Negative sign indicates outward current flow, positive indicates inward flow.

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



|  | MILLIMETERS |  | INCHES |  |  |
| :--- | :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |  |
| A | 50.29 | 51.31 | 1980 | 2020 |  |
| B | 14.86 | 15.62 | 0.585 | 0.615 |  |
| C | 2.54 | 4.19 | 0100 | 0.165 |  |
| D | 038 | 053 | 0.015 | 0.021 |  |
| F | 076 | 140 | 0.030 | 0055 |  |
| G | 254 | BSC | 0100 |  | BSC |
| $H$ | 076 | 178 | 0030 | 0070 |  |
| J | 020 | 033 | 0008 | 0013 |  |
| K | 254 | 419 | 0.100 | 0165 |  |
| L | 1460 | 1537 | 0575 | 0605 |  |
| M | $0^{\circ}$ | $10^{\circ}$ | $0^{\circ}$ | $10^{\circ}$ |  |
| N | 051 | 152 | 0020 | 0060 |  |

## 40-PIN PLASTIC DIP



| DIM | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
| A | 5128 | 5232 | 2040 | 2060 |
| B | 1372 | 1422 | 0540 | 0560 |
| C | 355 | 508 | 0140 | 0200 |
| D | 036 | 051 | 0014 | 0020 |
| F | 102 | 152 | 0040 | 0060 |
| G | 254 BSC |  | 0100 BSC |  |
| H | 165 | 216 | 0065 | 0085 |
| J | 020 | 030 | 0008 | 0012 |
| K | 305 | 356 | 0120 | 0140 |
| L | 1524 BSC |  | 0600 BSC |  |
| M | $7{ }^{\circ}$ | $10^{\circ}$ | $7{ }^{\circ}$ | $10^{\prime}$ |
| N | 051 | 102 | 0020 | 0040 |

## 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 I/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 I/O ports with multiplexed special functions, and a multi-function timer all contaıned 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 $Z 80$ 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.5 \mathrm{~K}, 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, depletıon 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.

R6500/41 and R6500/42. The R6500/43 has an optional 256 bytes of ROM at address space OF00 to 0FFF. 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.

## 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 manıpulator instructions form an enhanced R6502 instruction set and improve memory utilizatıon 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 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 (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 addresis space from FA00 to FFFF for the

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


## MEMORY MAP




## KEY REGISTER SUMMARY




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}}$ | -03 to +7.0 | Vdc |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -03 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 $\left(\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{ss}}=0\right)$

| CHARACTERISTIC | SYMBOL | MIN | TYP | MAX | UNITS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Power Dissipatıon (Outputs High) Commercial $0 . \mathrm{C}$ to -70 C | $P_{\text {o }}$ | - | 500 | - | mW |
| Input High Voltage (Normal Operating Levels) | $\mathrm{V}_{\text {IH }}$ | . 20 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Input Low Voltage (Normal Operating Levels) | $\mathrm{V}_{\mathrm{IL}}$ | 03 | - | 08 | Vdc |
| Input Leakage Current $V_{\text {in }}=0 \text { to } 525 \mathrm{Vdc}$ | 1 IN | 100 |  | 100 | $\mu \mathrm{Adc}$ |
| Input Low Current $\left(\mathrm{V}_{\mathrm{it}}-04 \mathrm{Vdc}\right)$ | 11. |  | 10 | 16 | mAdc |
| Output High Voltage $\left(V_{c c}=m i n, L_{\text {Load }}=-100 \mu \mathrm{Adc}\right)$ | $\mathrm{V}_{\mathrm{OH}}$ | 24 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Output High Voltage $\left(\mathrm{V}_{\mathrm{cc}}=\mathrm{min}\right)$ | $\mathrm{V}_{\text {cmos }}$ | $V_{\text {cc }} 30^{\circ}$ 。 | - | $\mathrm{V}_{\mathrm{cc}}$ | Vdc |
| Output Low Voltage $\left(V_{c c}=\min , I_{\text {Load }}=16 \mathrm{mAdc}\right)$ | $\mathrm{V}_{0}$ | - | - | 04 | Vdc |
| Output High Current (Sourcing) $\left(\mathrm{V}_{O H}=24 \mathrm{Vdc}\right)$ | $\mathrm{IOH}_{\mathrm{OH}}$ | 100 | - | - | $\mu$ Adc |
| Output Low Current (Sinkıng) $\left(\mathrm{V}_{\mathrm{ot}}=04 \mathrm{Vdc}\right)$ | 10. | 16 | - | - | mAdc |
| Darlington Current Drive, PE* $\left(\mathrm{V}_{\mathrm{OH}}=15 \mathrm{Vdc}\right)$ | $\mathrm{l}_{\mathrm{OH}}$ | 10 | - | - | mAdc |
| Output Low Current, PE* $\left(V_{0 L}=04 \mathrm{Vdc}\right)$ | 10. | 16 | - | - | mAdc |
| Input Capacitance $\begin{aligned} & \left(V_{\text {in }}-0, T_{A}=25^{\circ} \mathrm{C}, f=10 \mathrm{MHz}\right) \\ & \mathrm{PA}, \mathrm{~PB}, \mathrm{PC}, \mathrm{PF}^{*}, \mathrm{PG}^{*} \end{aligned}$ | C ${ }_{\text {n }}$ | - | - | 10 | pF |
| Output Capacitance $\left(\mathrm{V}_{\mathrm{in}}-0, \mathrm{~T}_{\mathrm{A}}=25 \mathrm{C}, \mathrm{f}=10 \mathrm{MHz}\right)$ | $\mathrm{C}_{\text {Out }}$ | - | - | 10 | pF |
| 1/O Port Resistance PAO-PA7, PC0-PC6 PF0-PF7, PG0-PG7 | R | 30 | 60 | 115 | K! |

NOTE: Negative sign indicates outward current flow, positive indicates inward flow $\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 5 \%$ *R6500/42 only

## R6545 <br> CRT CONTROLLER (CRTC)

## DESCRIPTION

The R6545 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 provides refresh memory addresses and character generator row addresses which allow up to 16K characters with 32 scan lines per character to be addressed. A major advantage of the R6545 is that the refresh memory may be addressed in either straight binary or by row/column.

Other functions in the R6545 include an internal cursor register which generates a cursor output when its contents are equal to the current refresh address. Programmable cursor start and end registers allow a cursor of up to the full character scan in height to be placed on any scan lines of the character. Variable cursor display blink rates are provided. A light pen strobe input allows capture of the current refresh address in an internal light pen register. The refresh address lines are configured to provide direct dynamic memory refresh.

All timing for the video refresh memory signals is derived from the character clock input. Shift register, latch, and multiplex control signals (when needed) are provided by external high-speed timing. The mode control register allows noninterlaced video display modes at 50 or 60 Hz refresh rate. The internal status register may be used to monitor the R6545 operation. The RES input allows the CRTC-generated field rate to be dynamicallysynchronized with line frequency jitter.

ORDERING INFORMATION

| Part Number: R6545 |  |  |
| :---: | :---: | :---: |

## FEATURES

- Compatible with 8 -bit microprocessors
- 3.7 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 (Transparent Addressing)
- Interlaced or non-interlaced scan
- $50 / 60 \mathrm{~Hz}$ operation
- Fully programmable cursor
- Light pen register
- Addresses refresh RAM to 16K characters
- No external DMA required
- Internal status register
- 40-pin ceramic or plastic DIP
- Pin-compatible with MC6845R
- Single $+5 \pm 5 \%$ volt power supply



## INTERFACE SIGNAL DESCRIPTION

Figure 1 illustrates the interface between the CPU, the R6545, and the video circuitry. Figure 2 shows typical tıming waveforms at the video interface.


Figure 1. R6545 Interface Diagram

## CPU INTERFACE

## 02 (Phase 2 Clock)

The Phase 2 ( $\emptyset 2$ ) input clock triggers all data transfers between the system processor (CPU) and the R6545. Since there is no maximum limit to the allowable $\emptyset 2$ clock tıme, it is not necessary for it to be a continuous clock. This capability permits the R6545 to be easily interfaced to non-6500 compatible microprocessors.

## R/W (Read/Write)

The $R / \bar{W}$ input signal generated by the processor controls the direction of data transfers. A high on the R/W pin allows the processor to read the data supplied by the R6545, a low on the R/W pin allows data on data lines D0-D7 to be written into the R6545.

## $\overline{\mathbf{C S}}$ (Chip Select)

The Chip Select input is normally connected to the processor address bus either directly or through a decoder. The R6545 is selected when $\overline{\mathrm{CS}}$ is low.

## RS (Register Select)

The Register Select input allows access to internal registers. A low on this pin permits writing ( $\mathrm{R} / \overline{\mathrm{W}}=$ low) into the Address Register and reading ( $\mathrm{R} / \overline{\mathrm{W}}=$ high ) from the Status Register. The 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. These lines are bidirectional and are normally high-impedance except during read cycles when the chip is selected (CS = low).

## VIDEO INTERFACE

## HSYNC (Horizontal Sync)

The HSYNC active-hıgh output signal determines the start of the horizontal raster line. It may drive a CRT monitor directly or may be used for composite video generation. HSYNC time position and width are fully programmable.

## VSYNC (Vertical Sync)

The VSYNC active-high output signal determines the start of the vertical frame. Like HSYNC, VSYNC may drive a CRT monitor or composite video generation circuits. VSYNC time position and width are both programmable.

## DISPLAY ENABLE (Display Enable)

The DISPLAY ENABLE active-high output signal indicates when the R6545 is generatıng 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 tıme by settıng 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 tımıng clock input signal is the time base for all internal count/control functions.

[^2]
## REFRESH RAM AND CHARACTER ROM INTERFACE

## MA0-MA13 (Refresh RAM Address Lines)

These 14 active-high output signals address the refresh RAM for character storage and display operations. The starting scan address is fully programmable and the ending scan address is determined by the total number of characters displayed, which is also programmable, in terms of characters/line and lines/ frame.

There are two selectable address modes for MA0-MA13:
In the straight binary mode (R8, Mode Control, bit $2=0$ ), characters are stored in successive memory locations. Thus, the software design must translate row and column character coordinates into sequentially-numbered addresses for Refresh memory operations.

In the row/column mode (R8, Mode Control, bit $2=1$ ), MA0MA7 become column addresses CCO-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 CCO-CC7 and CRO-CR5 addresses into a memoryefficient binary address scheme.

## RA0-RA4 (Raster Address Lines)

These five active-high output signals select each raster scan within an individual character row. The number of raster scan lines is programmable and determines the character height, including spaces between character rows.

The high-order line, RA4, is unique in that it can also function as a strobe output pin when the R6545 is programmed to operate in the "Transparent Address Mode." In this case the strobe is an active-high output and is true at the time the Refresh RAM update address gates on to the address lines, MAO-MA13. In this way, updates and readouts of the Refresh RAM can be made under control of the R6545 with only a small amount of external circuitry.


Figure 2. Vertical and Horizontal Timing

## INTERNAL REGISTER DESCRIPTION

Table 1 summarizes the internal registers and indicates their address selection and read/write capabilities.

## ADDRESS REGISTER

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | $\mathrm{A}_{4}$ | $\mathrm{~A}_{3}$ | $\mathrm{~A}_{2}$ | $\mathrm{~A}_{1}$ | $\mathrm{~A}_{0}$ |

This 5-bit write-only register is used as a "pointer" to direct CRTC/CPU data transfers within the CRTC. It contains the number of the desired register ( $0-31$ ). When RS is low, this register may be loaded; when RS is high, the selected register is the one whose identity is stored in this address register.

## STATUS REGISTER (SR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| UR | LRF | VRT | - | - | - | - | - |

This 3-bit register contains the status of the CRTC.

## SR

## UR -Update Ready

Register R31 has been either read or written by the CPU.
An update strobe has occurred.

SR
6
1

SR

SR

## VRF -Vertical Re-Trace

Scan is not currently in the vertical re-trace time. Scan currently in its vertical re-trace time. Note that this bit actually goes to a 1 when vertical re-trace starts, but goes to a 0 five character clock times before vertical re-trace ends to ensure that critical timings for refresh RAM operations are avoided.

4-0 -Not used.

## LRF -LPEN Register Full

Register R16 or R17 has been read by the CPU. LPEN strobe has been received.

Table 1. Internal Register Summary


RO-HORIZONTAL TOTAL CHARACTERS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| NUMBER OF CHARACTERS -1 |  |  |  |  |  |  |  |

This 8-bit write-only register contains the total of displayed and non-displayed characters, minus one, per horizontal line. This register determines the frequency of HSYNC.

R1-HORIZONTAL DISPLAYED CHARACTERS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NUMBER OF CHARACTERS |  |  |  |  |  |  |  |

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

## R2-HORIZONTAL SYNC POSITION

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| HORIZONTAL SYNC POSITION |  |  |  |  |  |  |  |

This 8-bit write-only register contains the position of HSYŃC 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 to interface with a variety of CRT monitors, since the HSYNC and VSNYC 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 $\overline{\mathrm{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 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $U M(T)$ | US(T) | CSK | DES | RRA | RAD | - | 0 |

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

| MC |  |
| :---: | :---: |
| 7 | UM(T)-Update/Read Mode (Transparent Mode) |
| 0 | Update occurs during horizontal and vertical blanking times with update strobe. |
| 1 | Update interleaves during $\emptyset 2$ portion of cycle. |
| MC |  |
| 6 | US(T) -Update Strobe (Transparent 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 RRA -Refresh RAM Access

Shared memory access

Transparent memory access

MC

$\begin{array}{ll}2 & \text { RAD -Refresh RAM Addressing Mode } \\ & \text { Straight binary addressing }\end{array}$

MC1-MCO IMC -Interlace Mode Control

| MC | MC |  |
| :--- | :--- | :--- |
| 1 | 0 | Operation |
| $X$ | 0 |  |
| 0 | 1 | Interlace SYNC raster scan |
| 1 | 1 | Interlace SYNC and video raster scan |

## R9—ROW SCAN LINES

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | SCAN LINES -1 |  |  |  |  |

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

## R10-CURSOR START LINE

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | $\mathrm{B}_{1}$ | $\mathrm{~B}_{0}$ | START SCAN LINE |  |  |  |  |

## R11-CURSOR END LINE

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | END SCAN LINE |  |  |  |  |

These 5-bit write-only registers select the starting and ending scan lines for the cursor. In addition, bits 5 and 6 of R10 are used to select the cursor blink mode, as follows:

| $\mathbf{B}_{1}$ | $\mathbf{B}_{\mathbf{0}}$ | Cursor Operating Mode |
| :--- | :--- | :--- |
| 0 | 0 | Display Cursor Continuously |
| 0 | 1 | Blank Cursor |
| 1 | 0 | Blink cursor at 1/16 Field Rate |
| 1 | 1 | Blink Cursor at 1/32 Field Rate |

A one character wide cursor can be controlled by storing values into the Cursor Start Line (R10) and Cursor End Line (R11) registers and into the Cursor Position Address High (R14) and Cursor Position Low (R15) registers.

## R12-DISPLAY START ADDRESS HIGH

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | DISPLAY START ADDRESS HIGH |  |  |  |  |  |

## R13-DISPLAY START ADDRESS LOW

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DISPLAY START ADDRESS LOW |  |  |  |  |  |  |  |

These registers together form a 14-bit register whose contents 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 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 together form a 14-bit regıster 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 together 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 and the resulant video display.

Non-displayed areas of the Video Display are for horizontal and vertical retrace functions of the CRT monitor. The horizontal and vertical sync signals, HSYNC and VSYNC, are programmed to occur during these intervals and trigger the retrace in the CRT monitor. The pulse widths are constrained by the monitor requirements. The time position of the pulses inay 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 MA0-MA7 become character column addresses (CC0-CC7) and MA8-MA13 become character row addresses (CR0-CR5). Figure 5 illustrates the system configuration.

## Transparent Memory Addressing

For this mode, the display RAM is not directly accessible by the CPU, but is controlled entirely by the R6545. All CPU accesses are made via the R6545 and a small amount of external 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 (MA0-MA13) generates as 8 column (MA0-MA7) and 6 row (MA8-MA13) addresses. Extra hardware is needed to compress this addressing into a straight binary sequence in order to conserve memory in the refresh RAM (register R8, bit 2 is a 1 ).

## Binary

In this mode, the CRTC address lines are straight binary and no compression circuits are needed. However, software complexity increases since the CRT characters cannot be stored in terms of their row and column locations, but must be sequential (register R8, bit 2 is a 0 ).

## USE OF DYNAMIC RAM FOR REFRESH MEMORY

The R6545 permits use of dynamıc 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.



ROW/COLUMN ADDRESSING SEQUENCE

Figure 7. Display Address Sequences (with Start Address $=0$ ) for $80 \times 24$ Example

## MEMORY CONTENTION SCHEMES FOR SHARED MEMORY ADDRESSING

From the diagram of Figure 5, it is clear that both the R6545 and the system CPU must address the video display memory. The R6545 repetitively fetches character information to generate the video signals in order to keep the screen display active. The CPU occasionally accesses the memory to change the displayed information or to read out current data characters. Three ways of resolving this dual-contention requirement are apparent:

## - CPU Priority

In this technique, the address lines to the video display memory are normally driven by the R6545 unless the CPU needs access, in which case the CPU addresses immediately override those from the R6545 giving the CPU immediate access.

## - $\$ 1$ and 02 Memory Interleaving

This method permits both the R6545 and the CPU access to the video display memory by time-sharing via the system $\emptyset 1$ and $\emptyset 2$ clocks. During the $\emptyset 1$ portion of each cycle (the time when $\emptyset 2$ is low), the R6545 address outputs are gated to the video display memory. In the $\emptyset 2$ time, the CPU address lines are switched in. In this way, both the R6545 and the CPU have unimpeded access to the memory. Figure 8 illustrates the timings.


Figure 8. $\$ 1$ and $\$ 2$ Interleaving

## - Vertical Blanking

With this approach, the address circuitry is identical to the case for CPU Priority updates. The only difference is that the Vertical Retrace status bit (bit 5 of the Status Register) is used by the CPU so that access to the video display memory is only made during vertical blanking time (when bit 5 is a 1). In this way, no visible screen perturbations result. See Figure 10 for details.

## TRANSPARENT MEMORY ADDRESSING

In this mode of operation, the video display memory address lines are not switched by contention circuits, but are generated by the R6545. In effect, the contention is handled by the R6545. As a result, the schemes for accomplishing CPU memory access are different:

## - $\$ 1$ and $\emptyset 2$ Interleaving

This mode is similar to the Interleave mode used with shared memory. In this case, however, the $\emptyset 2$ address is generated from the Update Address Register (R18 and R19) in the R6545. 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 $\emptyset 2$. Figure 9 shows the timing.


Figure 9. 01 and $\mathbf{~} \mathbf{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 Bit


Figure 11. Retrace Update Timing


Figure 12. Cursor and Display Enable Skew

WRITE TIMING CHARACTERISTICS $\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Symbol | Characteristic | R6545 |  | R6545A |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Unit |
| $\mathrm{t}_{\mathrm{CYC}}$ | Cycle Time | 1.0 | - | 05 | - | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{C}}$ | $\emptyset 2$ Pulse Width | 440 | - | 200 | - | ns |
| $\mathrm{t}_{\text {ACW }}$ | Address Set-Up Time | 80 | - | 40 | - | ns |
| $\mathrm{t}_{\text {CAH }}$ | Address Hold Tıme | 0 | - | 0 | - | ns |
| $t_{\text {wCW }}$ | R/W Set-Up Time | 80 | - | 40 | - | ns |
| $\mathrm{t}_{\text {CWH }}$ | R/W Hold Time | 0 | - | 0 | - | ns |
| $t_{\text {DCW }}$ | Data Bus Set-Up Tıme | 165 | - | 60 | - | ns |
| $t_{\text {HW }}$ | Data Bus Hold Tıme | 10 | - | 10 | - | ns |
| ( $\mathrm{t}_{\mathrm{R}}$ and $\mathrm{t}_{\mathrm{F}}=10$ to 30 ns ) |  |  |  |  |  |  |

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

| Symbol | Characteristic | R6545 |  | R6545A |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{CYC}}$ | Cycle Time | 1.0 | - | 05 | - | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{c}}$ | $\emptyset 2$ Pulse Width | 440 | - | 200 | - | ns |
| $\mathrm{t}_{\text {ACR }}$ | Address Set-Up Time | 80 | - | 40 | - | ns |
| $t_{\text {CAR }}$ | Address Hold Tıme | 0 | - | 0 | - | ns |
| $t_{\text {WCR }}$ | R/WW Set-Up Time | 80 | - | 40 | - | ns |
| $\mathrm{t}_{\mathrm{CDR}}$ | Read Access Time (Valıd Data) | - | 290 | - | 150 | ns |
| $t_{\text {HR }}$ | Read Hold Time | 10 | - | 10 | - | ns |
| $t_{\text {CDA }}$ | Data Bus Actıve Time (Invalıd Data) | 40 | - | 40 | - | ns |
| ( $t_{R}$ and $t_{F}=10$ to 30 ns ) |  |  |  |  |  |  |



## MEMORY AND VIDEO INTERFACE CHARACTERISTICS

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

| Symbol | Parameter | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{CCH}}$ | Minimum Clock Pulse Width, Hıgh | 130 |  |  | ns |
| $\mathrm{t}_{\mathrm{CCV}}$ | Clock Frequency |  |  | 3.7 | MHz |
| $t_{R}, t_{F}$ | Rise and Fall Time for Clock Input |  |  | 20 | ns |
| $t_{\text {MAD }}$ | Memory Address Delay Time |  | 100 | 160 | ns |
| $t_{\text {RAD }}$ | Raster Address Delay Tıme |  | 100 | 160 | ns |
| $t_{\text {DTD }}$ | Display Tıming Delay Tıme |  | 160 | 300 | ns |
| $t_{\text {HSD }}$ | Horizontal Sync Delay Time |  | 160 | 300 | ns |
| $t_{\text {VSD }}$ | Vertical Sync Delay Tıme |  | 160 | 300 | ns |
| $\mathrm{t}_{\mathrm{CDD}}$ | Cursor Display Timing Delay Time |  | 160 | 300 | ns |



TRANSPARENT ADDRESSING
WAVEFORMS ( $\dagger 1 / \emptyset 2$ INTERLEAVING)


## LIGHT PEN STROBE TIMING CHARACTERISTICS

| Symbol | Characteristic | R6545 |  | R6545A |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\text {LPH }}$ | LPEN Hold Time | 100 | - | 100 | - | ns |
| $\mathrm{t}_{\text {LP1 }}$ | LPEN Setup Time | 120 | - | 120 | - | ns |
| $t_{\text {LP2 }}$ | CCLK to LPEN Delay | 0 | - | 0 | - | ns |
| Note: $\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}=20 \mathrm{~ns}(\max )$ |  |  |  |  |  |  |

LIGHT PEN STROBE TIMING WAVEFORMS

CCLK


MAO-MA13


NOTE: "Safe" time position for LPEN positive edge to cause address $\mathbf{n + 2}$ to load into Light Pen Register. $t_{\text {LP2 }}$ and $t_{\text {LP1 }}$ are time positions causing uncertain results.

## CRTC Register Comparison

| NON-INTERLACE |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| REGISTER | SY6545R | SY6845 | $\begin{aligned} & \text { MC6845R } \\ & \text { HD6845R } \end{aligned}$ | HD6845S | $\begin{aligned} & \text { R6545-1 } \\ & \text { SY6545-1 } \end{aligned}$ | R6545 SY6545E |
| RO HORIZONTAL TOT | TOT-1 | TOT-1 | TOT-1 | TOT-1 | TOT-1 | TOT-1 |
| R1 HORIZONAL DISP | ACTUAL | ACTUAL | ACTUAL | ACTUAL | ACTUAL | ACTUAL |
| R2 HORIZONTAL SYNC | ACTUAL | ACTUAL | ACTUAL | ACTUAL | ACTUAL | ACTUAL |
| R3 HORIZ AND VERT SYNC WIDTH | HORIZONTAL | HORIZONTAL | HORIZONTAL | HORIZONTAL AND VERTICAL | HORIZONTAL AND VERTICAL | HORIZONTAL AND VERTICAL |
| R4 VERTICAL TOT | TOT-1 | TOT-1 | TOT-1 | TOT-1 | TOT-1 | TOT-1 |
| R5 VERTICAL TOT ADJ | ANY VALUE | ANY VALUE | ANY VALUE | ANY VALUE | any Value EXCEPT $R 5=\mathrm{R} 9 \mathrm{H} \cdot \mathrm{X}$ | ANY VALUE |
| R6 VERTICAL DISP | ANY VALUE $<R 4$ | $\begin{aligned} & \text { ANY VALUE } \\ & <\mathrm{R} 4 \end{aligned}$ | ANY VALUE | ANY VALUE $<R 4$ | ANY VALUE $<R 4$ | $\begin{aligned} & \text { ANY VALUE } \\ & <R 4 \end{aligned}$ |
| R7 VERTICAL SYNC POS | ACTUAL | ACTUAL | ACTUAL | ACTUAL | ACTUAL | ACTUAL |
| R8 MODE REG BITS 0 and 1 | INTERLACE MODE SELECT | INTERLACE MODE SELECT | INTERLACE MODE SELECT | INTERLACE MODE SELECT | INTERLACE MODE SELECT | INTERLACE MODE SELECT |
| BITS 2 | - | - | - | - | ROWICOLUMN OR STRAIGHT BINARY ADDRESSING | ROW/COLUMN OR STRAIGHT BINARY ADDRESSING |
| BITS 3 | - | - | - | - | SHARED OR TRANSPARENT ADDR | SHARED OR TRANSPARENT ADDR |
| BITS 4 | - | - | - | DISPEN SKEW | DISPEN SKEW | DISPEN SKEW |
| BITS 5 | - | - | - | DISPEN SKEW | CURSOR SKEW | CURSOR SKEW |
| BITS 6 | - | - | - | CURSOR SKEW | RA4/UPSTB | RA4/UPSTB |
| BITS 7 | - | - | - | CURSOR SKEW | TRANSPARENT MODE SELECT | TRANSPARENT MODE SELECT |
| R9 SCAN LINES | TOT-1 | TOT-1 | TOT-1 | TOT-1 | TOT-1 | TOT-1 |
| R10 CURSOR START | ACTUAL | ACTUAL | ACTUAL | ACTUAL | ACTUAL | ACTUAL |
| R11 CURSOR END | ACTUAL | ACTUAL | ACTUAL | ACTUAL | ACTUAL | ACTUAL |
| R12/R13 DISP ADDR | WRITE ONLY | WRITE ONLY | WRITE ONLY | READ/WRITE | WRITE ONLY | WRITE ONLY |
| R14/R15 CURSOR POS | READ/WRITE | READ/WRITE | WRITE ONLY | READ/WRITE | READ/WRITE | READ/WRITE |
| R16/R17 LPEN REG | READ ONLY | READ ONLY | READ ONLY | READ ONLY | READ ONLY | READ ONLY |
| R18/R19 UPDATE ADDR REG | N/A | N/A | N/A | N/A | TRANSPARENT MODE ONLY | TRANSPARENT MODE ONLY |
| R31 DUMMY REG | N/A | N/A | N/A | N/A | TRANSPARENT MODE ONLY | TRANSPARENT MODE ONLY |
| STATUS REG | YES | NO | NO | NO | YES | YES |
| INTERLACE SYNC |  |  |  |  |  |  |
| Ro | TOT-1 = ODD OR EVEN | TOT-1 = ODD OR EVEN | TOT-1 = ODD | TOT-1 = ODD | TOT-1 = ODD | TOT-1 = ODD OR EVEN |
| INTERLACE SYNC AND VIDEO |  |  |  |  |  |  |
| R4 VERTICAL | TOT-1 | TOT-1 | TOT-1 | TOT-2 | TOT/2-1 | TOT-1 |
| R6 VERT DISP | TOT | TOT | TOT/2 | TOT | TOT/2 | TOT |
| R7 VERT SYNC | ACTUAL | ACTUAL | ACTUAL | ACTUAL | ACTUAL/2 | ACTUAL |
| R10 CURSOR START R11 CURSOR END | ODD/EVEN ODD/EVEN | ODD/EVEN ODD/EVEN | BOTH ODD OR BOTH EVEN | ODD/EVEN ODD/EVEN | ODD/EVEN ODD/EVEN | ODD/EVEN ODD/EVEN |
| CCLK | 37 MHz | 2.5 MHz | 25 MHz | 3.7 MHz | 2.5 MHz | 3.7 MHz |

## ABSOLUTO: 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 Range <br> Commercial <br> Industral | $\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 under "Absolute Maxımum Ratings' may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min. | Typ. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\text {IH }}$ | 20 |  | $\mathrm{V}_{\text {c }}$ | Vdc |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 |  | 0.8 | Vdc |
| Input Leakage ( $\emptyset 2$, R $\overline{\mathrm{W}}$, $\overline{\mathrm{RES}}, \overline{\mathrm{CS}}, \mathrm{RS}$, LPEN, CCLK) | IN | - |  | 2.25 | $\mu \mathrm{Adc}$ |
| Three-State Input Leakage (D0-D7) $\left(\mathrm{V}_{\mathrm{IN}}=0.4 \text { to } 24 \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}$ | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 |  | - | Vdc |
| Output Low Voltage $\mathrm{I}_{\text {LOAD }}=1.6 \mathrm{mAdc}$ | $\mathrm{V}_{\mathrm{OL}}$ | - |  | 0.4 | Vdc |
| Power Dissipation ( $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ ) | $\mathrm{P}_{\mathrm{D}}$ | - | 260 | 525 | mW |
| Input Capacitance <br> Ø2, R/ $\bar{W}, \overline{R E S}, \overline{C S}$, RS, LPEN, 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{C}_{\text {OUt }}$ | - |  | 10.0 | pF |

TEST LOAD


$$
\begin{aligned}
\mathrm{R} & =11 \mathrm{~K} \Omega \text { FOR DO-D7 } \\
& =24 \mathrm{~K} \Omega \text { FOR ALL OTHER OUTPUTS } \\
\mathrm{C} & =130 \mathrm{pF} \text { TOTAL FOR DO-D7 } \\
& =30 \mathrm{pF} \text { ALL OTHER OUTPUTS }
\end{aligned}
$$

## PACKAGE DIMENSIONS

40-PIN CERAMIC DIP


| DIM | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |
|  | $5029^{\circ}$ | 5156 | 1980 | 2030 |
| B | 1473 | 1549 | 0580 | 0610 |
| C | 178 | 305 | 0070 | 0120 |
| D | 038 | 058 | 0015 | 0023 |
| F | 102 | 165 | 0040 | 0065 |
| G | 229 | 280 | 0090 | 0110 |
| J | 020 | 038 | 0008 | 0015 |
| K | 318 | 381 | 0125 | 0150 |
| L | 1499 | 1651 | 0590 | 0650 |
| M | $0^{\circ}$ | $10^{\circ}$ | $0^{\circ}$ | $10^{\circ}$ |
| N | 058 | $\mathbf{1 7 8}$ | 0020 | 0070 |

## 40-PIN PLASTIC DIP



|  | MILLIMETERS |  | INCHES |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
|  | 5128 | 5232 | 2040 | 2060 |  |
| B | 1372 | 1422 | 0540 | 0560 |  |
| C | 355 | 508 | 0140 | 0200 |  |
| D | 036 | 051 | 0014 | 0020 |  |
| F | 102 | 152 | 0040 | 0060 |  |
| G | 2544 BSC | 0100 BSC |  |  |  |
| H | 165 | 216 | 0065 | 0085 |  |
| J | 020 | 030 | 0008 | 0012 |  |
| K | 305 | 356 | 0120 | 0140 |  |
| L | 1524 BSC | 0600 | 065 |  |  |
| M | T | $10^{\circ}$ | $7^{\circ}$ |  | $10^{\circ}$ |
| N | 051 | 102 | 0020 | 0040 |  |

# R6545-1 <br> 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{R E S}$ 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}$ |
| Package |
| $\mathrm{P}=$ Plastıc |
| $\mathrm{C}=$ Ceramic |
| Operating Frequency |
| No Letter $=1 \mathrm{MHz}$ |
| $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 16K 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 ( $(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 contınuous clock. This capability permits the R6545-1 to be easily interfaced to non-6500 compatible microprocessors.

## R/W (Read/Write)

The $\mathrm{R} / \overline{\mathrm{W}}$ input signal generated by the processor 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 R6545-1, a low on the $R / \bar{W}$ pin allows data on data lines DO-D7 to be written into the R6545-1.

## $\overline{\mathbf{C S}}$ (Chip Select)

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

## RS (Register Select)

The Register Select input allows access to internal registers. A low on this pin permits writing ( $\mathrm{R} / \overline{\mathbf{W}}=$ low) into the Address Register and reading ( $\mathrm{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-impedance 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 start of the horizontal raster line. It may drive a CRT monitor directly or may be used for composite video generation. HSYNC time position and width are fully programmable.

## VSYNC (Vertical Sync)

The VSYNC active-high output signal determines the start of the vertical frame. Like HSYNC, VSYNC may drive a CRT monitor or composite video generation circuits. VSYNC time position and width are both programmable.

## DISPLAY ENABLE (Display Enable)

The DISPLAY ENABLE active-high output signal indicates when the R6545-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, sunce 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 tıming clock input signal is the time base for all internal count/control functions.

## $\overline{\text { RES }}$

The $\overline{R E S}$ active-low input signal initializes all internal scan counter circuits. When $\overline{\mathrm{RES}}$ is low, all internai counters stop and clear, all scan and video outputs go low and control registers are unaffected. $\overline{\operatorname{RES}}$ must stay low for at least one CCLK period. All scan timing initiates when RES goes high. In this way, $\overline{\text { RES }}$ can synchronize display frame timing with line frequency. $\overline{\text { RES }}$ may also synchronize multiple CRTC's in horizontal and/or vertical split screen operation.

## REFRESH RAM AND CHARACTER ROM INTERFACE

## MAC-MA13 (Refresh RAM Address Lines)

These 14 active-high output signals address the refresh RAM for character storage and display operations. The starting scan address is fully programmable and the ending scan address is determined by the total number of characters displayed, which is also programmable, in terms of characters/line and lines/ frame.

There are two selectable address modes for 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 for Refresh memory operations.

In the row/column mode (R8, Mode Control, bit $2=1$ ), MAOMA7 become column addresses CCO-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 CCO-CC7 and CRO-CR5 addresses into a memoryefficient binary address scheme.

## RA0-RA4 (Raster Address Lines)

These five active-high output signals select each raster scan within an individual character row. The number of raster scan lines is programmable and determines the character height, including spaces between character rows.

The high-order line, RA4, is unique in that it can also function as a strobe output pin when the R6545-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, MA0-MA13. In this way, updates and readouts of the Refresh 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$ ). When RS is low, this register may be loaded; when RS is high, the selected register is the one whose identity is stored in this address register.

STATUS REGISTER (SR)

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| UR | LRF | VRT | - | - | - | - | - |

## SR

UR -Update Ready
Register R31 has been either read or written by the CPU.
An update strobe has occurred.

SR

1
-Not used.

This 3-bit register contains the status of the CRTC.

Table 1. Internal Register Summary


RO-HORIZONTAL TOTAL CHARACTERS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| NUMBER OF CHARACTERS -1 |  |  |  |  |  |  |  |

This 8 -bit write-only register contains the total of displayed and non-displayed characters, minus one, per horizontal line. This register determines the frequency of HSYNC.

## R1-HORIZONTAL DISPLAYED CHARACTERS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| NUMBER OF CHARACTERS |  |  |  |  |  |  |  |

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

## R2-HORIZONTAL SYNC POSITION

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: |
| HORIZONTAL SYNC POSITION |  |  |  |  |  |  |  |

This 8-bit write-only register contains the position of HSYNC on the horizontal line, in terms of the character location number on the line. The position of the HSYNC determines the left to right location of the displayed text on the video screen. In this way, the side margins are adjusted.

## R3-HORIZONTAL AND VERTICAL SYNC WIDTHS

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{~V}_{3}$ | $\mathrm{~V}_{2}$ | $\mathrm{~V}_{1}$ | $\mathrm{~V}_{0}$ | $\mathrm{H}_{3}$ | $\mathrm{H}_{2}$ | $\mathrm{H}_{1}$ | $\mathrm{H}_{0}$ |

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

## HVSW

7-4 VSYNC Pulse Width
The width of the vertical sync pulse (VSYNC) 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, positıons 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:

[^3]MC

| 3 |
| :--- |
| 1 |

## RRA -Refresh RAM Access

Shared memory access
Transparent memory access

## MC

2 RAD -Refresh RAM Addressing Mode
Straight binary addressing
1 Row/column addressing
MC
1
MC
$0 \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 contans the number of scan lines, minus one, per character row, including spacıng.

## 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 Contınuously |
| 0 | 1 | Blank Cursor |
| 1 | 0 | Blink Cursor at 1/16 Field Rate |
| 1 | 1 | Blınk 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 : $!$ GA |  |  |  |  |  |

## R13-DISPLAY START ADDRESS LOW

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DISPLAY START ADDRESS LOW |  |  |  |  |  |  |  |

These registers together form a 14-bit register whose contents 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 together 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 Hıgh (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 together 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 positıon 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 MA0-MA7 become character column addresses (CC0-CC7) and MA8-MA13 become character row addresses (CR0-CR5). Figure 5 illustrates the system configuration.

## Transparent Memory Addressing

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.


Figure 7. Display Address Sequences (with Start Address $=0$ ) for $80 \times 24$ 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.

- \$1 and 02 Memory Interleaving

This method permits both the R6545-1 and the CPU access to the video display memory by time-sharing via the system $\emptyset 1$ and $\emptyset 2$ clocks. During the $\emptyset 1$ portion of each cycle (the time when $\emptyset 2$ is low), the R6545-1 address outputs are gated to the video display memory. In the $\emptyset 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. $\$ 1$ and 02 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 visibie 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:

## - $\quad 1$ and $\$ 2$ Interleaving

This mode is similar to the Interleave mode used with shared memory. In this case, however, the $\emptyset 2$ address is generated from the Update Address Register (R18 and R19) in the R6545-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 $\emptyset 2$. Figure 9 shows the timing.


Figure 9. $\quad 1$ and 02 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 Bit


Figure 11. Retrace Update Timing


Figure 12. Cursor and Display Enable Skew

WRITE TIMING CHARACTERISTICS $\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Symbol | Characteristic | R6545-1 |  | R6545A-1 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{CrC}}$ | Cycle Time | 1.0 | - | 0.5 | - | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{C}}$ | $\emptyset 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 |
| ${ }^{\text {w }}$ WCW | R/ $\bar{W}$ Set-Up Time | 180 | - | 90 | - | ns |
| $\mathrm{t}_{\text {cWh }}$ | R/V̄ Hold Time | 0 | - | 0 | - | ns |
| $t_{\text {dCW }}$ | Data Bus Set-Up Time | 265 | - | 100 | - | ns |
| $\mathrm{t}_{\mathrm{HW}}$ | Data Bus Hold Time | 10 | - | 10 | - | ns |
| ( $\mathrm{t}_{\mathrm{R}}$ and $\mathrm{t}_{\mathrm{F}}=10$ to 30 ns ) |  |  |  |  |  |  |

READ TIMING CHARACTERISTICS $\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Symbol | Characteristic | R6545-1 |  | R6545A-1 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\mathrm{CrC}}$ | Cycle Time | 1.0 | - | 05 | - | $\mu \mathrm{S}$ |
| $\mathrm{t}_{\mathrm{c}}$ | $\emptyset 2$ Pulse Width | 440 | - | 200 | - | ns |
| $t_{\text {ACR }}$ | Address Set-Up Time | 180 | - | 90 | - | ns |
| $t_{\text {car }}$ | Address Hold Time | 0 | - | 0 | - | ns |
| $\mathrm{t}_{\text {WCR }}$ | R/W Set-Up Time | 180 | - | 90 | - | ns |
| $\mathrm{t}_{\text {CDR }}$ | Read Access Time (Valid Data) | - | 340 | - | 150 | ns |
| $\mathrm{t}_{\mathrm{HR}}$ | Read Hold Time | 10 | - | 10 | - | ns |
| $\mathrm{t}_{\text {CDA }}$ | Data Bus Active Tıme (Invalid Data) | 40 | - | 40 | - | ns |
| ( $\mathrm{t}_{\mathrm{R}}$ and $\mathrm{t}_{\mathrm{F}}=10$ to 30 ns ) |  |  |  |  |  |  |



## READ TIMING WAVEFORMS



## MEMORY AND VIDEO INTERFACE CHARACTERISTICS

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

| Symbol | Characteristic | R6545-1 |  | R6545A-1 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| ${ }^{\text {cher }}$ | Character Clock Cycle Time | 0.40 | - | 040 | - | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\mathrm{CCH}}$ | Character Clock Pulse Width | 200 | - | 200 | - | ns |
| (X) $\mathrm{m}_{\text {MAD }}$ | MA0-MA13 Propagation Delay | - | 300 | - | 300 | ns |
| (X) $\mathrm{t}_{\text {RAD }}$ | RA0-RA4 Propagation Delay | - | 300 | - | 300 | ns |
| $(\mathrm{X})_{\text {dTD }}$ | DISPLAY ENABLE Propagation Delay | - | 450 | - | 450 | ns |
| $(X) t_{\text {HSD }}$ | HSYNC Propagation Delay | - | 450 | - | 450 | ns |
| $(\mathrm{X}) \mathrm{t}_{\mathrm{VSD}}$ | VSYNC Propagation Delay | - | 450 | - | 450 | ns |
| $(\mathrm{X}) \mathrm{t}_{\text {CDD }}$ | CURSOR Propagation Delay | - | 450 | - | 450 | ns |
| $t_{\text {TAD }}$ | MA0-MA13 Switching Delay | - | 200 | - | 200 | ns |
| Note $\left.\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}=20 \mathrm{~ns} \mathrm{(max}\right)$. |  |  |  |  |  |  |

SYSTEM TIMING WAVEFORMS

CCLK
OUTPUTS
(SEE TABLE)


TRANSPARENT ADDRESSING WAVEFORMS ( $\dagger 1 / \emptyset 2$ INTERLEAVING)

LIGHT PEN STROBE TIMING CHARACTERISTICS

| Symbol | Characteristic | R6545-1 |  | R6545A-1 |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\text {LPH }}$ | LPEN Hold Tıme | 150 | - | 150 | - | ns |
| $\mathrm{t}_{\text {LP1 }}$ | LPEN Setup Time | 20 | - | 20 | - | ns |
| $\mathrm{t}_{\mathrm{LP} 2}$ | CCLK to LPEN Delay | 0 | - | 0 | - | ns |
| Note: $\left.\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}=20 \mathrm{~ns} \mathrm{(max}\right)$ |  |  |  |  |  |  |

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*

| 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}}$ | 0 to +70 <br> -4 C 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 the operational 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 \%, T_{A}=T_{L}\right.$ to $T_{H}$, unless otherwise noted)

| Parameter | Symbol | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\mathrm{V}_{\mathrm{IH}}$ | 2.4 | $\mathrm{V}_{\mathrm{CC}}$ | Vdc |
| Input Low Voltage | $\mathrm{V}_{\mathrm{IL}}$ | -0.3 | 0.4 | Vdc |
| Input Leakage ( $\emptyset 2$, R/ $\overline{\mathrm{W}}$, $\overline{\mathrm{RES}}, \overline{\mathrm{CS}}, \mathrm{RS}$, LPEN, CCLK) | 1 IN | - | 2.25 | $\mu \mathrm{Adc}$ |
| Three-State Input Leakage (D0-D7) $\left(\mathrm{V}_{\mathrm{IN}}=0.4 \text { to } 2.4 \mathrm{~V}\right)$ | $\mathrm{I}_{\text {TSI }}$ | - | $\pm 10.0$ | $\mu \mathrm{Adc}$ |
| Output High Voltage $\begin{aligned} & 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}$ | $\mathrm{V}_{\mathrm{OH}}$ | 24 | - | Vdc |
| Output Low Voltage $\mathrm{I}_{\text {LOAD }}=16 \mathrm{mAdc}$ | $\mathrm{V}_{\mathrm{OL}}$ | - | 0.4 | Vdc |
| Power Dissipation | $\mathrm{P}_{\mathrm{D}}$ | - | 900 | mW |
| Input Capacitance <br> $\emptyset 2, R / \bar{W}, \overline{R E S}, \overline{C S}, R S$, LPEN, CCLK DO-D7 | $\mathrm{C}_{\text {IN }}$ | - | $\begin{aligned} & 10.0 \\ & 125 \end{aligned}$ | $\begin{aligned} & \mathrm{pF} \\ & \mathrm{pF} \end{aligned}$ |
| Output Capacitance | $\mathrm{C}_{\text {OUT }}$ | - | 100 | pF |

TEST LOAD


$$
\begin{aligned}
\mathrm{R} & =11 \mathrm{~K} \Omega \text { FOR DO-D7 } \\
& =24 \mathrm{~K} \Omega \text { FOR ALL OTHER OUTPUTS } \\
\mathrm{C} & =130 \mathrm{pF} \text { TOTAL FOR DO-D7 } \\
& =30 \mathrm{pF} \text { ALL OTHER OUTPUTS }
\end{aligned}
$$

## PACKAGE DIMENSIONS

## 40-PIN CERAMIC DIP



|  | MILLIMETERS |  | INCHES |  |
| :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |
| A | 5029 | 5156 |  | 1980 |
| 2030 |  |  |  |  |
| B | 1473 | 1549 | 0580 | 0610 |
| C | 178 | 305 | 0070 | 0120 |
| D | 038 | 058 | 0015 | 0023 |
| F | 102 | 165 | 0010 | 0065 |
| G | 229 | 280 | 0090 | 0110 |
| J | 020 | 038 | 0008 | 0015 |
| K | 318 | 381 | 0125 | 0150 |
| L | 1499 | 1651 | 0590 | 0650 |
| M | $0^{\circ}$ | $10^{\circ}$ | $0^{\circ}$ | $10^{\circ}$ |
| N | 058 | 178 | 0020 | 0070 |

## 40-PIN PLASTIC DIP



|  | MILLIMETERS |  | INCHES |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
|  | 5128 | 5232 | 2040 | 2060 |  |
| B | 1372 | 1422 | 0540 | 0560 |  |
| C | 355 | 508 | 0140 | 0200 |  |
| D | 036 | 051 | 0014 | 0020 |  |
| F | 102 | 152 | 0040 | 0060 |  |
| G | 2544 BSC | 0100 BSC |  |  |  |
| H | 165 | 216 | 0065 | 0085 |  |
| J | 020 | 030 | 0008 | 0012 |  |
| K | 305 | 356 | 0120 | 0140 |  |
| L | 1524 BSC | 0600 |  | BSC |  |
| M | 7 | 10 | $7^{\circ}$ |  | $10^{\circ}$ |
| N | 051 | 102 | 0020 | 0040 |  |

## DESCRIPTION

The Rockwell R6549 Color Video Display Generator (CVDG) integrates video raster control; color lookup table (LUT) update and access; color generation and display refresh; teletext data DMA addressing, data routing and handshake; dynamic RAM (DRAM) control and refresh; and MPU/CVDG/DMA access to DRAM into a single device. Internal horizontal and vertical state machines generate video synchronization signals and control access of video color data from DRAM. A 16-entry color lookup table (LUT) supports 4-bit encoded color levels for red, green and blue (RGB) colors allowing 4096 color combinations to be generated. Each color code is converted to a 16 -level analog signal by a dedicated DAC, combined with a blanking signal, and output in sync with a pixel clock.
Control registers allow MPU selection of CVDG operating mode and options while data registers allow MPU update of LUT data, current drawing pointer (CDP) graphics, Y scroll pointer and teletext pointer. The data registers can also be monitored by the MPU as can mode and raster scan status.

The R6549 is the first display generator to be designed exclusively in support of North American Presentation Level Protocol Syntax (NAPLPS) videotex (VTX) and teletext (TTX).
Replacing over 30 conventional MSI/LSI devices, the R6549 simplifies system design and layout, reduces printed circuit size, and minimizes required support circuits to speed system prototyping and greatly reduce both development and production costs.


R6549 CVDG Pin Assignments

PRELIMINARY
FEATURES

- High performance video generator
$-2: 1$ or $1: 1$ interlace
- Analog red, green, blue (RGB) outputs
- 16 levels per color plus blanking
- 4096 color combinations
- RS-170 sync and color subcarrier generation
- 16 entry color look-up table (LUT)
- RS-170 composite sync output with equalization and serration pulses
- Internal/external video synchronization
- Color subcarrier generation with line, field and pixel phase lock
- Compatible with MC1377 color encoder
- Videotex (VTX)/Teletext (TTX) graphics
$-256 \times 210 \times 4$ bit-mapped video image buffer
- Programmable border color
- Transparent video overlay signal
- Fast X CDP and Y CDP nibble or byte graphics I/O
- NAPLPS X-Y origin with smooth Y vertical scroll
- Fast horizontal drawing support with $X$ auto increment byte write
- Dynamic RAM interface
- Direct 48k-byte DRAM support, with auto inherent refresh for interfacing to six 16k $\times 4$ DRAMS (4416-150 ns)
- Supports three methods of DRAM access:
- Video refresh 26.9k-byte DRAM—port or address mapped
- Teletext/program 5.9k-byte DRAM—port or address mapped
- Optional program 16k-byte DRAM extension-address mapped
- Interleaving of MPU and CVDG DRAM access for uninterrupted read/write memory access without memory contention
- On-chip refresh timing and control
- MPU Interface
- Direct timing and cycle stealing for 1.4 MHz 68A09E MPU
- Direct interface to R6512 CPU
- Teletext support
- DMA interface and handshake to external NABTS teletext prefix processor
-5.72 Mbps effective data rate
- 8k-byte teletext buffer DRAM interface


## ORDERING INFORMATION

| Part Number | Temperature Range |
| :---: | :---: |
| R6549 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |
|  |  |
| Package: $\mathrm{P}=$ Plastic |  |



Figure 1. R6549 CVDG Interface Signals

## PIN DESCRIPTION

Throughout this document signals are described logically using the terms active (or asserted) representing the true state, or inactive (or negated) representing the false state, regardless of whether the signal is active at a high or low voltage level.

The R6549 CVDG signals can be categorized into several different functional interfaces: MPU control and address bus, address/data (A/D) bus, DRAM control, color video output, teletext prefix processor and system clock input. Figure 1 identifies the signals within each group.

## DMAC INTERFACE

TTXREQ-Teletext DMA Request. An asynchronous falling edge-triggered request for direct memory access (DMA) transfer of data from a teletext prefix processor connected to the address/data (A/D) bus to DRAM. This TTL compatible input
causes the CVDG to stop generating the E and Q clocks for one A/D bus cycle, output a 13 -bit address (AO - A12) to the DRAM during the processor portion of the $A / D$ bus cycle, assert the TTXOE signal, and assert the $\bar{W}$ output to enable writing the data into DRAM.

TTXOE-Teletext DMA Output Enable. An active LOW TTL compatible output pulse asserted within one A/D bus cycle after TTXREQ is asserted to acknowledge TTXREQ receipt and to enable data transfer from the teletext prefix processor onto the A/D bus (ADO-AD7).

## MPU CONTROL AND ADDRESS BUS

E-E Clock. A TTL compatible 1.43 MHz output clock that synchronizes data transfers over the MPU bus. This output drives the E clock input to the 6809E MPU. The E clock has special $\mathrm{V}_{\mathrm{OH}}$ and $\mathrm{V}_{\mathrm{OL}}$ output levels, $\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{SS}}+0.3 \mathrm{~V}$, respectively.

Q-Q Clock. A TTL compatible 1.43 MHz output clock that leads the E clock output for use by the 6809E.

R/W-Read/Write. The TTL compatible Read/Write input controls the direction of data transfer between the MPU and the CVDG (HIGH = read from the CVDG; LOW = write to the CVDG). The $\mathrm{R} / \overline{\mathrm{W}}$ line should be connected to external data bus transceivers to also control the data direction between the MPU bus and the $A / D$ bus.

A0, A1-MPU Address Line A0 and A1 Inputs. When $\overline{\mathrm{OCS}}$ is active, the encoded A0 and A1 inputs select the register in the CVDG to be accessed during a read or write operation (see Table 1). An exception is when A0 and A1 are both high during Mode 0 , in which case DRAM is CDP accessed directly by the MPU at addresses generated by the CVDG.

When $\overline{\text { DRCS }}$ is active and program DRAM is selected ( $P=1$ in the DRAM Page Register), A0 is passed through the CVDG to drive the AD6 output during DRAM column address generation in the processor portion of the A/D bus cycle (see MPU DRAM Access Description).

A13-MPU Address Line A13 Input. When $\overline{\mathrm{DRCS}}$ is active, A13 input HIGH causes program DRAM to be accessed ( $\overline{\mathrm{CASP}}$ asserted) during the processor portion of the $A / D$ bus cycle independent of the $P$ bit value in the DRAM Page Register. When program DRAM is selected in the DRAM Page Register ( $P=1$ ) or when $A 13=1, A 13$ is passed through the CVDG to drive the AD5 output during DRAM column address generation in the processor portion of the A/D bus cycle (see MPU DRAM Access Description).
$\overline{\text { OCS }}-1 / O$ Chip Select. The active LOW, TTL compatible, $\overline{\text { IOCS }}$ input selects CVDG I/O port operation. The CVDG internal registers addressed by the A0 and A1 inputs are accessed as enabled by the mode selected in the Mode Register. Data direction is controlled by the R/W input as appropriate for each register and mode.

Table 1. CVDG Register Select Logic ( $\overline{\mathbf{I O C S}}=$ LOW $)$

| A1 | A0 | Mode | Read (R/ $\overline{\mathbf{W}}=\mathbf{H})$ | Write (R/ $\overline{\mathbf{W}}=\mathbf{L})$ |
| :--- | :--- | :--- | :--- | :--- |
| L | L | - | Status Register | Mode Register |
| L | H | 0 | X CDP Register | X CDP Register |
| H | L | 0 | Y CDP Register | Y CDP Register |
| H | H | 0 | DRAM ${ }^{2}$ | DRAM |
| H | H | 1 | - | LUT Address Register |
| H | H | 2 | LUT $^{3}$ | LUT Data Register |
| H | H | 3 | - | Switch Register |
| H | H | 4 | - | Y Scroll Register |
| H | L | 5 | TTX Pointer Register | TTX Pointer Register |
| H | H | 6 | - | DRAM Page Register |

## Notes:

1. The mode is selected in Mode Register.
2. DRAM is accessed directly by the MPU at DRAM addresses determined by the CVDG X CDP and Y CDP register contents
3 The LUT is accessed as enabled and addressed in the LUT Address Register.
$\overline{\text { DRCS——DRAM Chip Select. } \overline{\text { DRCS }} \text { is a TTL compatible, active }}$ LOW, input that enables MPU access to the DRAM. CTIME, RTIME and DTIME outputs are asserted by the CVDG at the proper times to enable external buffers which drive the MPU generated address onto the A/D bus and drive data between the MPU bus data lines and the A/D bus in the direction controlled by R $\bar{W}$ (HIGH = read from DRAM; LOW = write to DRAM). Note that DRCS configurations are advanced and optional for many configurations.

## ADDRESS/DATA BUS

AD0-AD7-Address/Data Lines. Eight TTL compatible, bidirectional, multiplexed address/data lines (AD0 - AD7) interface the CVDG directly to the video/program DRAM, through external buffers to the MPU address bus (A1-A12), and through external transceivers to the MPU data bus (DO - D7). These lines transfer both address and data between the DRAM and the CVDG and between the MPU bus and the CVDG/DRAM during one 698 ns A/D bus cycle.
$\overline{\text { RASL }}, \overline{\text { RASH-Row Address Strobe Low and High. TTL com- }}$ patible outputs strobe the upper eight bits of the address on $A / D$ bus lines ADO-AD7 into DRAM (as DRAM addresses A6-A13) on the falling edge. $\overline{\text { RASL }}$ strobes the address into the DRAM containing the lower four data bits (D0-D3) and $\overline{\text { RASH }}$ strobes the address into the DRAM containing the upper four data bits (D4-D7).
CAS1, CAS2, $\overline{\text { CASP-Column Address Strobes 1, } 2 \text { and P. }}$ The TTL compatible CAS outputs strobe the six lower bits of the address on A/D bus lines (AD1-AD6) into DRAM (as DRAM addresses AO-A5) on the falling edge. CAS1 and CAS2 connect to the video DRAM containing the LUT addresses. Four 4-bit LUT addresses packed into two bytes are accessed during the video portion of each A/D bus cycle. $\overline{\mathrm{CAS} 1}$ strobes the DRAM containing the LUT addresses for the first two pixel positions while $\overline{\text { CAS2 }}$ strobes the DRAM devices containing the LUT addresses for the second two pixel positions. $\overline{C A S P}$ connects to the program DRAM containing the program instructions/data.
$\overline{\mathbf{O E 1}}, \overline{\mathrm{OE}}-\mathrm{DRAM}$ Output Enable. These active LOW, TTL compatible, outputs enable DRAM device data output lines during a read. $\overline{\mathrm{OE}} 1$ connects to the two video DRAM devices containing byte 1 (LUT addresses for pixels 1 and 2 ) and is asserted first during a video refresh cycle. $\overline{\mathrm{OE} 2}$ connects to the two DRAM devices containing byte 2 (LUT addresses for pixels 3 and 4) and is asserted following $\overline{\mathrm{OE} 1}$. $\overline{\mathrm{OE} 2}$ is also connected to the program DRAM devices and enables their data outputs during the processor portion of the A/D bus cycle.
$\bar{W}$-DRAM Write Enable. The TTL compatible, active LOW, $\bar{W}$ output strobes data from the A/D bus into DRAM during a write in the processor portion of the A/D bus cycle. $\bar{W}$ is held HIGH during a read from DRAM.

RTIME—Row Address Time. The active LOW, TTL compatible, RTIME output enables DRAM row address lines from the MPU onto the A/D bus through external buffers when $\overline{\mathrm{DRCS}}$ is active. (Required for DRCS configurations only.)

CTIME-Column Address Time. The active LOW, TTL compatible, CTIME output enables DRAM column address lines from the MPU onto the A/D bus through external buffers when $\overline{\mathrm{DRCS}}$ is active. (Required for $\overline{\mathrm{DRCS}}$ configurations only.)

DTIME-Data Time. The active LOW, TTL compatible, DTIME output enables data transfer between the MPU data bus and the A/D bus through external transceivers when DRCS or $\overline{\text { OCS }}$ is active.

## SYSTEM CLOCK

SYSCLK-System Clock. A clock input with a duty cycle of $40 / 60$ to $50 / 50$. The clock frequency should be 28.63636 MHz $\pm 80 \mathrm{~Hz}$ for proper operation of the colorburst frequency. This input clock may be stopped in either state for up to $1 \mu$ s to allow for external digital phase lock techniques.

## VIDEO/COLOR OUTPUTS

CSUBC-Color Subcarrier Clock Output. A TTL compatible $3.579545 \mathrm{MHz} \pm 10 \%$ color subcarrier clock. The clock rate complies with the North American Color Burst Clock Output Standard. The rate is the SYSCLK divided by eight and is phase keyed to the horizontal sync ( $\overline{\text { HSYNC }}$ ) output on C/HSYNC (as either a component of CSYNC or pure HSYNC). Vertical blanking interval (VBI) color gating by VSYNC must be done externally (since some modems require an uninterrupted 3.579 MHz clock).

When the color outputs are connected to an MC1377 color encoder, the CSUBC output can be connected to the MC1377 CLK input, typically through a 500 pF capacitor $/ 150 \mu \mathrm{H}$ inductor filter network.

C/HSYNC-Composite/Horizontal Sync Output. Either a composite sync (CSYNC) or a horizontal sync (HSYNC) output at TTL levels, asserted "tips down", is selected by the External Sync (EXT) bit in the Switch Register.

In internal sync (EXT $=0$ ), an RS-170 composite sync with full serration and equalization is output in either 2:1 or 1:1 interlace as selected by the 2:1 Interlace Select (S21) bit in the Switch Register (S21 = 1 for 2:1; S21 = 0 for 1:1).

In external sync (EXT = 1), a pure HSYNC is output in either normal or early timing as selected by the Normal Horizontal Sync (NHS) bit in the Switch Register. In normal timing (NHS = 1), a 15.7 kHz signal is output; in advance timing ( $\mathrm{NHS}=0$ ), a 15.9 kHz stop clock signal is output.

When the color outputs are connected to an MC1377 color encoder, the C/HSYNC output can be connected directly to the MC1377 SYNC input pin.
$\overline{\text { VSYNC-Vertical Sync Input/Output. A TTL compatible }}$ vertical sync ( $\overline{\mathrm{VSYNC}}$ ) input or output signal depending on the state of the External Sync (EXT) bit in the Switch Register (see Mode 3). VSYNC is an externally generated input at power up or when EXT $=1$. VSYNC is an internally generated output when EXT $=0$.

The VSYNC output can be used to disable the color subcarrier at the chroma modulator during VBI. Videotex decoders can also use $\overline{\text { VSYNC }}$ to interrupt the MPU at a 60 Hz rate for blink, task and timekeeping operations.

PIXCLK—Pixel Clock Output. A 5.7272 MHz pixel output clock running synchronously with the RGB color outputs.

R, G, B-Red, Green and Blue Color Outputs. Three separate color analog output voltages. Each output provides a 1.0 Vpp video signal at high impedance with a 1.8 Vdc offset. Each color level is controlled by a 4-bit color code accessed from the LUT for each pixel position. A digital-to-analog converter (DAC) converts the 4 -bit code to one of 16 output voltage levels (black level $=1.875 \mathrm{Vdc}$; white level $=2.800 \mathrm{Vdc})$. The three outputs allow 4096 color level combinations. A composite blanking signal ( 1.800 Vdc ) is included in each output.

The output signals include high frequency clock components which may require low pass filtering in some applications. The outputs can be connected to the RIN, GIN, and B IN inputs to a MC1377 color encoder through $15 \mu \mathrm{~F}$ (typical) AC coupling capacitors.

The color outputs, through external buffers, can also drive 75 ohm loads, e.g., the inputs to an RGB color monitor/TV.

XPAR-Transparent Output. A TTL compatible, active HIGH, output controlled by one bit in a 4-bit code (three bits are don't care) in the LUT. A LUT value of 1XXX in DRAM asserts XPAR (HIGH); LUT value of OXXX in DRAM negates XPAR (LOW). This output can be used to indicate which video source to select. When XPAR output is HIGH, external video signals should be selected to display background video; when XPAR output is LOW, CVDG outputs should be selected to display graphics. The XPAR output is always HIGH during composite blanking to pass external vertical blanking interval (VBI) signals, external sync, color burst, etc.

## POWER/GROUND

VCC-Primary Power. 5.0 Vdc.
VSS-Ground. Power and signal ground.

## FUNCTIONAL DESCRIPTION

The R6549 CVDG operation is controlled by three free-running synchronous state machines with the following cycle rates:

$$
\begin{array}{ll}
\text { Address/Data (A/D) Bus Cycle } & 698 \mathrm{~ns} / \text { cycle }(1.43 \mathrm{MHz}) \\
\text { Horizontal Raster Line Cycle } & 63.5 \mu \mathrm{~s} / \text { cycle }(15.74 \mathrm{kHz})^{*} \\
\text { Vertical Raster Frame Cycle } & 33.3 \mathrm{~ms} / \text { cycle }(30 \mathrm{~Hz})
\end{array}
$$

The CVDG also includes timing shift registers and sample flipflops to generate internal and external timing signals; programmed logic arrays (PLAs) to perform I/O decoding, generate DRAM control signals and determine state machine outputs; registers to hold command/status and data; an internal 16-bit row/column bus in display X-Y coordinates; internal input and output 8 -bit data busses; and input/output buffers to isolate internal circuits from external interfaces and to drive outputs. Figure 2 illustrates the main CVDG components.
*A 15.9 kHz stop-clock early sync is selectable.
Figure 2. R6549 CVDG Block Diagram



## SYSTEM TIMING

## System Clock

Internal and output timing signals are derived from the 28.636363 MHz crystal frequency on the SYSCLK input pin. A two-phase non-overlapping 14.318181 MHz (SYSCLK/2) clock is generated to sequence high speed data transfer within the CVDG.

## Timing Shift Register

The Timing Shift Register generates internal timing pulses as internal timing references at frequencies from 14.318 MHz down to 13.98 kHz . Flip-flops sample the various timing pulses to generate derivative timing reference signals for use by other CVDG circuits.

A two-phase non-overlapping 1.431818 MHz (SYSCLK/20) clock is generated for low speed sequencing within the CVDG and is also the external microprocessor bus and A/D bus timing reference. One phase of the 1.43 MHz clock drives the E clock output pin. A quadrature 1.431818 MHz clock leading the E clock is output on the Q output pin.

## Pixel Clock

A 5.72 MHz pixel clock is output on the PIXCK output pin. Four pixel output clocks occur each 698 ns (one clock pulse coincident with each of the red, green and blue color level outputs and the transparent bit output for each pixel location).

## VIDEO RASTER CONTROL

## Horizontal Raster Line Cycle

An internal horizontal state machine (HSM) controls the horizontal raster line cycle. The HSM is incremented at the E clock rate, nominally every 698 ns . When normal horizontal sync timing is selected in the Switch Register (NHS $=1$ ), 91 horizontal counts (HSO - HS90), or states, comprise the $63.56 \mu \mathrm{~S}$ line raster. When early horizontal sync timing is selected ( $\mathrm{NHS}=0$ ), typically to support external synchronization, 90 horizontal counts (HSO - HS89) provide a $62.86 \mu$ s line raster. The first 64 counts clock the 256 displayed pixels (at four pixels per count). Figure 3 illustrates the horizontal and vertical raster count reference.

The HSM generates the horizontal raster timing pulses for internal logic and/or external output. These signals are the horizontal sync (HSYNC), horizontal border and blanking, horizontal blanking, serration and equalization timing pulses.

The horizontal border and blanking pulse identifies the time that a border color is output (see LUT Data Register description) outside of the 256 pixel locations except during actual horizontal blanking. This signal is reported in bit $6(\overline{\mathrm{HB}})$ of the Status Register.

An increment vertical count signal is also generated to increment the vertical state machine.

## Vertical Raster Frame Cycle

An internal vertical state machine (VSM) controls the 33.3 ms vertical raster frame cycle. The VSM is incremented twice each horizontal raster line cycle. The VSM count (VSO - VS523 or VS0 - VS524), or state, supports two frames per 30 ms vertical raster cycle. The upper count depends on the interlace mode (S21) switch position selected in the Switch Register. When 2:1 interlace mode is selected ( $\mathrm{S} 21=1$ ), the upper VSM count supports a $2621 / 2$ line frame. When $1: 1$ interlace is selected $(S 21=0)$, the upper VSM count supports a 262 line frame.

A VSM clear sign is normally generated when the VSM upper count is reached to restart the VSM at 0 ; however, when external sync is selected (EXT $=1$ ) the VSM clear signal is generated from the external sync signal input on the VSYNC pin. Internal vertical state timing signals are generated for internal logic and/or external output. These signals include vertical sync (VSYNC), vertical border and blanking, vertical blanking, and equalization enable pulses and the load $Y$ scroll pointer time.

An internal vertical sync pulse, a vertical blanking pulse, and an equalization pulse are generated for combining with the HSYNC serration and equalization pulses when internal sync is selected ( $E X T=0$ ) to output composite sync on the $\overline{\mathrm{C} / \mathrm{HSYNC}}$ pin.

The vertical blanking pulse is also buffered and output on the VSYNC pin when internal sync is selected in the Switch Register ( $E X T=0$ ).

The internal vertical border and blanking pulse is generated and reported in bit $7(\overline{\mathrm{VB}})$ of the Status Register. The pulse width is 3.302 ms for $2: 1$ interlace $(\mathrm{S} 21=1)$ or 3.333 ms for $1: 1$ interlace $(\mathrm{S} 21=0)$. This duration identifies the time the border color determined from the LUT Data Register is output, except during actual vertical blanking.

An internal load $Y$ offset pointer signal is generated and routed to the $Y$ Scroll Counter to cause the $Y$ offset to load during the non-visible portion of the display raster.

## Composite Sync and Color Subcarrier Clock Generation

$\overline{\text { HSYNC }}$ is output in one of two forms on the $\overline{\text { C/HSYNC }}$ pin depending upon the EXT bit state in the Switch Register. If internal sync is selected (EXT $=0$ ), $\overline{\text { HSYNC }}$ is combined with horizontal blanking serration, equalization and vertical sync ( $\overline{\text { VSYNC }}$ ) pulses to output as composite sync (CSYNC). If external sync is selected (EXT $=1$ ), the $\overline{\text { HSYNC signal is output }}$ on C/HSYNC.

A 3.58 MHz color subcarrier clock (SYSCLK/8 and phase keyed to horizontal sync) is generated from composite sync and horizontal sync signals then is output on the CSUBC pin.


Figure 3. CVDG Video Raster Count Reference

## ADDRESS/DATA BUS CONTROL

The Address/Data Bus state machine controls the operation of the 698 ns A/D bus cycle. The A/D bus cycle contains a 2-byte video data access cycle and a 1-byte I/O data access cycle (Figure 4). The addresses and data transferred on the A/D bus depend on the phase of the A/D bus cycle (i.e., the E clock level) and the type of operation in the I/O data access cycle. Table 2 identifies the source of the addresses for each type of DRAM access.

## Video Data Access Cycle

The video data access cycle (also referred to as the video portion of the A/D bus cycle) occurs during the first half of the A/D bus cycle (when the E clock is LOW). Two bytes of video data (containing four LUT addresses corresponding to four pixel locations on the display) are read each cycle from DRAM at the DRAM address generated by the CVDG. The DRAM address is generated corresponding to the first of four pixel column locations in the horizontal raster and the pixel row location in the vertical raster. The video column ( X ) address of 0 to 64 is controlled by the horizontal state machine. The video row ( Y ) address of 209 to 0 is controlled by the $Y$ Address Counter, which is in turn controlled by the vertical state machine and the Y Scroll Register. The two data bytes are loaded into the CVDG Video Data Register for subsequent serialization and LUT access (see the Pixel Color Generation description).

Up to 48k-bytes of Dynamic RAM (DRAM) can be connected to the A/D bus to store video data (LUT addresses) for video refresh, program instructions/data and received teletext data. The DRAM is segmented into six 8 k -byte blocks with page selection of one block at a time during access (Figure 5). Four pages are required for video refresh (V00-V11); three pages (V00, V01 and V10) hold video data exclusively, and one page (V11) holds video and program/teletext data. Two other pages hold program data. During the video data access cycle, and some modes of the I/O data access cycle, paging is handled automatically by the CVDG. The A13 and A0 input lines and the P, V1 and V0 bits in the CVDG DRAM Page Register select the page for MPU DRAM access during the I/O data access cycle (see MPU DRAM Access description).

## I/O Data Access Cycle

The I/O data access cycle (also referred to as the processor portion of the A/D bus cycle) occurs during the second half of the A/D bus cycle (when E clock is HIGH). A/D bus address source and data source/destination depends upon CVDG chip select ( $\overline{\overline{O C S}}$ and $\overline{\mathrm{DRCS}}$ ) and Teletext Request (TTXREQ) input levels, the selected CVDG mode, and the register select (A0 and A1) input levels. Refer to the description of each I/O access cycle function for details.

## A/D Bus Control Line Buffers and Logic

The A/D Bus Control Line Buffers and Logic condition input and output $A / D$ Bus control signals. Six input signals (R $\bar{W}, A 0, A 1$, A13, IOCS and DRCS) are buffered and routed to the DRAM Control PLA.

The E and Q output clocks are suppressed during a teletext DMA transfer. When TTXREQ input goes LOW, the Q and E clock outputs are held LOW to disable the clocks for one MPU bus cycle. In addition, the increment TTX address count goes HIGH to increment the modulo 32 TTX Counter. When TTXREQ goes HIGH at the completion of the DMA data transfer, the E and Q output clocks are enabled, the TTXOE output is negated (reset HIGH), and the increment TTX address count signal is reset.

Internal reset and initialization signals are generated when both $\overline{\text { IOCS }}$ and DRCS inputs are LOW for test purposes.

## A/D Bus Control PLA

The A/D Bus Control PLA decodes CVDG and A/D Bus operation commands from buffered A/D bus control input signals and encoded mode bits in the Mode Register. Outputs from the PLA are buffered and routed to other circuits in the CVDG as internal enable signals.

## A/D Bus Input/Output Buffers

The A/D Bus Input/Output Buffers isolate the internal CVDG data bus lines from the external A/D bus lines (ADO - AD7). Input buffers continuously copy ADO - AD7 onto the internal input data bus. Output buffers drive the states of the internal output data bus lines onto ADO - AD7 when enabled by a CVDG output function and clocked by the 14.3 MHz internal clock. Two of these output buffers drive AD5 and AD6 during MPU DRAM access ( $\overline{\mathrm{DRCS}}=\mathrm{L}$ ) with the DRAM page signals, i.e., VO and V1, respectively, or A13 and AO inputs, respectively, depending on the state of the A13 input and the $P$ bit in the DRAM Page Register.

## A/D Bus Output Control Logic

The A/D Bus Output Control Logic drives data onto the internal output bus from the internal row and column bus lines, from the LUT, and from other internal CVDG circuits when enabled by outputs from the A/D Bus Control PLA.

## DRAM Control PLA and Buffers

The DRAM Control PLA and Buffers generate and drive control and timing output signals to the DRAM; the row, column and data time output control signals for use by external line buffers and data line transceivers; and internal signals to control input/output data direction and to enable the internal row and column bus.

Timing pulses from the Timing Shift Registers; control signals from the Mode and Page registers, A/D Bus Control Buffers and Logic, and A/D Bus Control PLA; and control signals generated and derived from other sections of the CVDG are input to the PLA.

Output control states from the PLA are buffered and routed to external DRAM control signal pins ( $\overline{\mathrm{RASL}}, \overline{\mathrm{RASH}}, \overline{\mathrm{CAS} 1}, \overline{\mathrm{CAS}}$, $\overline{\mathrm{CASP}}, \overline{\mathrm{OE}}, \overline{\mathrm{OE} 2}$, and $\overline{\mathrm{W}}$ ) and to external A/D bus control signal pins ( $\overline{C T I M E}, \overline{R T I M E}$ and $\overline{\mathrm{DTIME}}$ ). Other output signals are inverted and routed to internal logic.


Figure 4. DRAM Address/Data (A/D) Bus Cycle

Table 2. Address/Data Bus Address Sources

| DRAM Row/Column | - | CA5 | CA4 | CA3 | CA2 | CA1 | CAO | - | RA7 | RA6 | RA5 | RA4 | RA3 | RA2 | RA1 | RAO |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CVDG Display Row/Column Bus | C7 | C6 | C5 | C4 | C3 | C2 | C1 | C0 | R7 | R6 | R5 | R4 | R3 | R2 | R1 | Ro |
| A/D Bus | AD7 | AD6 | AD5 | AD4 | AD3 | AD2 | AD1 | ADO | AD7 | AD6 | AD5 | AD4 | AD3 | AD2 | AD1 | ADO |
| Video Cycle ${ }^{1}$ | 0 | V7 | V6 | V5 | V4 | V3 | V2 | 0 | V1 | vo | H6 | H5 | H4 | H3 | H2 | H1 |
| Processor Cycle <br> CDP Graphics ${ }^{2}$ $(\overline{\mathrm{IOCS}}=\mathrm{L}, \text { Mode 0) }$ | $\mathrm{X} 1^{3}$ | Y7 | Y6 | Y5 | Y4 | Y3 | Y2 | X04 | Y1 | YO | X7 | X6 | X5 | X4 | X3 | X2 |
| MPU Video DRAM Access ${ }^{5}$ $(\overline{\mathrm{DRCS}}=\mathrm{L}, \mathrm{P}=0)$ | A0 ${ }^{6}$ | V17 ${ }^{7}$ | V02 | A12 | A11 | A10 | A9 | 0 | A8 | A7 | A6 | A5 | A4 | A3 | A2 | A1 |
| MPU Program DRAM Access ${ }^{8}$ $(\overline{\mathrm{DRCS}}=\mathrm{L}, \mathrm{P}=1)$ | 0 | $\mathrm{A}^{\circ} 9$ | A13 ${ }^{9}$ | A12 | A11 | A10 | A9 | 0 | A8 | A7 | A6 | A5 | A4 | A3 | A2 | A1 |
| Teletext DMA Access ${ }^{10}$ $(\overline{\mathrm{TTXREQ}}=\mathrm{L})$ | то | $1{ }^{11}$ | 111 | T12 | T11 | T10 | T9 | 0 | T8 | T7 | T6 | T5 | T4 | T3 | T2 | T1 |

## Notes:

1. Video Cycle:

H1-H6 = HSM Output = 0 to 64 ( $=0$ to 255 pixel LUT addresses @ 4 addresses per access); V0-V7 $=$ Y Scroll Counter Output $=209$ to 0
2. CDP Graphics:

X0-X7 $=\mathrm{X}$ CDP Register/Counter contents $=0$ to 255;
Y0-Y7 = Y CDP Register contents $=0$ to 255 ( 0 to 209 for displayable data)
3. X1 controls the $\overline{\mathrm{CAS}} 1$ and $\overline{\mathrm{CAS} 2}$ outputs:
$0=$ Assert CAS1
$1=$ Assert CAS2
4. XO controls the $\overline{\text { RASL }}$ and $\overline{\text { RASH outputs: }}$
$0=$ Assert RASL
$1=$ Assert RASH
5. MPU Video DRAM Access: A0-A12 $=$ MPU Address $=0$ to 4096.
6. AO input controls the $\overline{\mathrm{CAS} 1}$ and $\overline{\mathrm{CAS} 2}$ outputs:
$\mathrm{L}=$ Assert CAS1
$\mathrm{H}=$ Assert CAS2
7. V0 and V1 bits in the DRAM Page Register control assertion of AD6 and AD5 outputs, respectively:
$0=$ Negate output
1 = Assert output
8. MPU Program DRAM Access: A0-A13 $=$ MPU Address $=0$ to 8192
9. A0 and A13 inputs control the AD6 and AD5 outputs, respectively:

L = Negate output
H = Assert output
10. Teletext Access:

T1 - T4 = Modulo 32 counter incremented by each DMA byte transfer
T5-T12 = Teletext Pointer Register contents incremented by T1-T4 overflow
11. AD6 and AD5 asserted to select program DRAM.


## Notes:

1. 26,880 bytes of video memory are required to support video refresh, i.e., to supply 53,7604 -bit LUT addresses in support of the $210 \times 256$ pixel display area. With 32,768 bytes supplied in four 4416 DRAM devices, 5888 bytes are available for general program/TTX message use in the upper part of video memory page 3 (V11).
2. Nibbles shown correspond to beginning and ending data for $210 \times 256$ pixel display area in $X(c o l u m n), Y(r o w)$ coordinates.

Figure 5. DRAM Memory Map

## PIXEL COLOR GENERATION

## LUT Address Generation

The 16-bit Video Data Register latches the four LUT addresses contained in the two data bytes acquired during the video data access cycle. Two 4-bit color lookup table (LUT) addresses are packed into each byte. The Video Shift Register serializes the four LUT addresses and transfers them one byte at a time to the LUT Address Generator. The LUT Address Generator latches the 4-bit coded LUT addresses from the Video Shift Register, converts the coded address to 16 binary signals and latches the binary address $(0-15)$ for routing to the LUT.

## LUT Operation

The color look-up table (LUT) is a $16 \times 13$ bit memory holding 16 entries of R, G and B color codes and corresponding trans-
parent state (see Table 3). Each entry holds three 4-bit encoded color levels ( $0000=$ lowest voltage level, $1111=$ highest voltage level) and a 1 -bit transparent state ( $0=0$ ff, $1=0 n$ ). For each pixel location the three color level codes (R, G and B) are sampled from the LUT, latched and routed through three separate digital-to-analog converters. The transparent bit corresponding to each pixel location is also accessed from the LUT, latched, buffered and output on the XPAR pin.

## Digital-To-Analog Conversion (DACs)

The 4-bit color code for each color ( $\mathrm{R}, \mathrm{G}$ and B ) at a pixel position is converted to a corresponding analog voltage through a 16 -level digital-to-analog converter (DAC). Four lines from the four color code lines and their four complements are decoded to one of 16 levels, sampled and latched. The latched outputs are in turn connected to the color output pin (R, G and B) through a voltage divider ladder network.

Table 3. LUT Structure

| LUT ADDR (HEX) | LUT FORMAT |  |  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | XPAR ${ }^{1}$ |  | GREEN ${ }^{2}$ |  |  |  | BLUE ${ }^{2}$ |  |  |  | RED ${ }^{2}$ |  |  |  |
|  | 3 | $2+0$ | 3 | 2 | 1 | 0 | 3 | 2 | 1 | 0 | 3 | 2 | 1 | 0 |
| F |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| E |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| D |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| C | 0 |  | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 1 | 1 | 1 |
| B |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| A |  | $\mathrm{NO}$ |  |  |  |  |  |  |  |  |  |  |  |  |
| 9 | 1 | ACTUAL | 1 | 0 | 0 | 0 | 1 | 1 | 0 | 0 | 1 | 1 | 1 | 1 |
| 8 |  | DATA |  |  |  |  |  |  |  |  |  |  |  |  |
| 7 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 6 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Example $1^{3}$

Example $2^{4}$

Notes:

1. XPAR is a single bit in the LUT, the format shown corresponds to the LUT Data Register format:
$0 X X X=$ XPAR output LOW
$1 X X X=$ XPAR output HIGH

## 2. Color Data Level:

$0000=$ lowest output voltage $=1.875 \mathrm{Vdc}$
$1111=$ highest output voltage $=2.800 \mathrm{Vdc}$
3. Example 1-LUT Address C Data

XPAR output $=$ LOW
G output $=1.875+0(0.0617)=1.875 \mathrm{Vdc}$
B output $=1.875+4(0.0617)=2.122 \mathrm{Vdc}$
R output $=1.875+7(0.0617)=2.307 \mathrm{Vdc}$
4. Example 2-LUT Address 9 Data'

XPAR output $=\mathrm{HIGH}$
G output $=1875+8(0.0617)=2.369 \mathrm{Vdc}$
$B$ output $=1.875+12(0.0617)=2.615 \mathrm{Vdc}$
R output $=1.875+15(0.0617)=2.800 \mathrm{Vdc}$

## I/O DATA ACCESS CYCLE FUNCTIONS

The I/O access cycle operates in one of five ways:

1. CVDG Mode/Status Register Access (enabled by $\overline{\mathrm{OCS}}$ LOW)
2. CVDG Graphics Access (enabled by IOCS LOW)
3. CVDG Parameter I/O Access (enabled by $\overline{\mathrm{IOCS}}$ LOW)
4. MPU DRAM I/O Access (enabled by DRCS LOW)
5. Teletext Byte DMA (enabled by TTXREQ LOW)

The basic type of I/O access cycle is determined by the chip select ( $\overline{\mathrm{IOCS}}$ or $\overline{\mathrm{DRCS}}$ ) and Teletext Request ( $\overline{\mathrm{TTXREQ}}$ ) inputs. When neither of the chip select inputs are LOW, nor has a TTX DMA transfer been initiated by TTXREQ LOW, the I/O access cycle is idle with no data transfer occurring during the processor portion of the A/D bus cycle.

When $\overline{O C S}$ is LOW, the register address inputs (A0 and A1) and the mode selected in the CVDG Mode Register define the specific CVDG I/O operation, i.e., Mode/Status Register Access, CVDG Graphics Access (Mode 0 ), or one of the six CVDG Parameter Access modes (Modes 1-6). Table 4 shows the CVDG registers accessible during the I/O access cycle and the bit assignments. When A1 and A0 are both HIGH, the register bits are defined with reference to a pseudo Data Register (DR). The actual internal CVDG register accessed depends on the selected mode (see Table 4). The bits are defined in the following text.

## CVDG Mode/Status Register Access

When $\overline{\mathrm{OCS}}$ is LOW and the register address is zero (AO and A1 inputs are both LOW), the Mode Register (MR) or the Status Register (SR) is accessed depending upon the $R \bar{W}$ input level. When $R / \bar{W}$ is LOW, the Mode Register is written; when $R / \bar{W}$ is HIGH, the Status Register is read.

Table 4. CVDG Register Summary

| Internal CVDG Register | Mode | Register Select Lines |  | R/W ${ }^{4}$ | Register Bit No. |  |  |  |  |  |  |  | Reset ${ }^{3}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | A1 | A0 |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| Mode Register | - | 0 | 0 | W | - | - | - | - | S | M2 | M1 | Mo | OF |
| Status Register | - | 0 | 0 | R | $\overline{\mathrm{VB}}$ | $\overline{\mathrm{HB}}$ | M2 | M1 | M0 | P | V1 | vo | -- |
| X CDP Register | 0 | 0 | 1 | R/W | X7 | X6 | X5 | X4 | X3 | X2 | X1 | X0 | 00 |
| Y CDP Register | 0 | 1 | 0 | R/W | Y7 | Y6 | Y5 | Y4 | Y3 | Y2 | Y1 | Y0 | 00 |
| DRAM ${ }^{1}$ | 0 | 1 | 1 | R/W | P3 | P2 | P1 | PO | Q3 | Q2 | Q1 | Q0 | - |
| LUT Address Register | 1 | 1 | 1 | W | XPE | RE | GE | BE | A3 | A2 | A1 | AO | 00 |
| LUT ${ }^{2}$ | 2 | 1 | 1 | R | - | - | - | - | D3 | D2 | D1 | D0 | - |
| LUT Data Register | 2 | 1 | 1 | W | - | - | - | - | D3 | D2 | D1 | D0 | -- |
| Switch Register | 3 | 1 | 1 | W | NHS | S21 | EXT | LS | TST | - | - | - | F8 |
| Y Scroll Register | 4 | 1 | 1 | W | Y7 | Y6 | Y5 | Y4 | Y3 | Y2 | Y1 | Yo | 00 |
| TTX Pointer Register | 5 | 1 | 0 | R/W | A12 | A11 | A10 | A9 | A8 | A7 | A6 | A5 | 00 |
| DRAM Page Register | 6 | 1 | 1 | W | - | - | - | - | - | P | V1 | vo | 07 |
| Notes: <br> 1. The DRAM is directly <br> 2. Data is transferred $f$ <br> 3. Reset state upon po <br> 4. $\mathrm{R} / \mathrm{W}=$ Read/write | ccesse <br> the L <br> up. <br> = read | and $n$ onto ly; | the e A = wr | DG. <br> bus wi <br> only; | ut goin $V=r e s$ | hroug or writ | he LUT | ata | ster. |  |  |  |  |

## Mode Register

The write-only Mode Register selects the CVDG mode for next read from, or write to, the CVDG. In addition, the Mode Register contains a submode flag applicable only to Mode 0 . The Mode Register may be written at any time regardless of the current CVDG mode. The mode and submode bits are initialized to ones upon power up.

|  |  |  |  | Bit Position |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Register | A1 | A0 | R/W | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Mode | 0 | 0 | W | - | - | - | - | $S$ | $M 2$ | $M 1$ | $M 0$ |

## MR7-MR4 Not used (no effect)



Note that the mode must be written into the Mode Register before the desired mode can be executed.

## Status Register

The read-only Status Register reports the selected CVDG mode, the selected DRAM page and the status of the horizontal and vertical raster blanking signals. The Status Register may be read at anytime regardless of the CVDG mode.

The horizontal blanking $(\overline{\mathrm{HB}})$ and vertical blanking $(\overline{\mathrm{VB}})$ signals report the state of the video raster at the time of access. The states of these two signals can be used for 15 kHz poll-driven timing, vertical blanking interval (VBI) identification, LUT loading, etc. These blanking times reflect the non-pixel display time including the time actual horizontal and vertical blanking signals are generated (for inclusion in composite sync output).


## SR7 Vertical Blanking ( $\overline{\mathrm{VB}}$ )

0 Vertical blanking is asserted.
1 Vertical blanking is not asserted.

## SR6 Horizontal Blanking ( $\overline{\mathrm{HB}}$ )

0 Horizontal blanking is asserted.
1 Horizontal blanking is not asserted.

SR5-SR3 Mode Selected (M2-M0)
Reports the current CVDG mode as selected in bits 2-0 of the Mode Register.

SR5 SR4 SR3
(M2) (M1) (M0)

| 0 | 0 | 0 | Mode 0 - Port CDP Graphics |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | Mode 1 - LUT Address |
| 0 | 1 | 0 | Mode 2 - LUT Data |
| 0 | 1 | 1 | Mode 3- Switch Register |
| 1 | 0 | 0 | Mode 4 - Y Scroll Offset Register |
| 1 | 0 | 1 | Mode 5 - Teletext DMA Pointer |
| 1 | 1 | 0 | Mode 6- DRAM Page |
| 1 | 1 | 1 | Not used - no effect |

SR2-SRO DRAM Page Selected (P, V1, V0)
Reports the current DRAM Page selected in bits 2-0 of the Page Register (see Mode 6 - Write DRAM Page). $P$ is the program RAM page indicator. V0 and V1 are the video page indicators.

| SR2 <br> (P) SR1 <br> (V1) $)$ SR0 <br> (V0) | Selected DRAM Page |  |  |  |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | Video Page 0: 8k-byte video RAM |  |
| 0 | 0 | 1 | Video Page 1: 8k-byte video RAM |  |
| 0 | 1 | 0 | Video Page 2: 8k-byte video RAM <br> 0 | 1 |
| 1 | 1 | Video Page 3: 2.3k-byte video RAM; <br> 5.9 k -byte program RAM |  |  |
| 1 | 0 | 0 | Program Page: 16k-byte optional program <br> RAM accessed via $\overline{\text { DRCS }}$ (additionally paged <br> by A13 and A0 inputs) |  |

## Mode 0 - Port CDP Graphics

When $\overline{O D C S}$ is LOW and Mode 0 is selected in the Mode Register, the Port Current Drawing Pointer (CDP) Mode is active. In this mode display column and row addresses can be written to the CVDG Current Drawing Pointer (CDP) $X$ and $Y$ registers, respectively, and pixel data accessed in DRAM. This mode is primarily used to update LUT addresses (i.e., the CDPs) in the video pages of DRAM. These LUT addresses are the video data read from the DRAM by the CVDG during the video portion of the A/D bus cycle.

This mode can be used to write or read data in any of the four 8 k -byte video pages of DRAM defined by the V0 and V1 bits in the CVDG DRAM Page Register. The first three pages (V00, V01 and V10) are used exclusively for video data. 2304 bytes (addresses 0-8FF) of the fourth page (V11) are used for video data while the rest of the DRAM can be used for program or teletext message storage.

In mode 0 , the MPU writes the address of the data in display coordinates into the CVDG X CDP and Y CDP registers. The X CDP contains the pixel position in the horizontal axis (i.e., the display column number) and varies from 0 to 255 (hex FF). Each pixel data nibble corresponds to a location (0 to 15) in the color look-up table (LUT) from which the corresponding R, G and B color levels and transparent bit data are retrieved for color generation. The Y CDP contains the pixel position in the vertical axis (i.e., the display row number) and varies from 0 to 255 (hex FF). Only values of 0 to 209 are used by the CVDG during the video portion of the A/D bus cycle to access video data. Y addresses 210-255 identify DRAM address on video DRAM page V11 that can contain non-displayable data, i.e., program or teletext data.

The registers accessible (besides in Mode and Status registers) in this mode are:

| Register | A1 | A0 | R/W | Bit Position |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| X CDP | 0 | 1 | R/W | X7 | X6 | X5 | X4 | X3 | X2 | X1 | X0 |
| Y CDP | 1 | 0 | R/W | Y7 | Y6 | Y5 | Y4 | Y3 | Y2 | Y1 | Yo |
| DRAM* | 1 | 1 | R/W | P3 | P2 | P1 | PO | Q3 | Q2 | Q1 | Q0 |
| *Not CVDG Access |  |  |  |  |  |  |  |  |  |  |  |

The X CDP Register is accessed at register address 1 ( $\mathrm{A} 1=0$ and $A O=1$ ) and the $Y$ CDP Register is accessed at register address $2(A 1=1$ and $A 0=0)$. When register address $3(A 1=1$ and $A O=1$ ) is detected, the CVDG generates DRAM row and column addresses corresponding to the display coordinates loaded in the X CDP and Y CDP registers. Data is then written from the A/D bus to the DRAM (R/W = low) or read from the DRAM to the A/D bus (R/W = high).

There are two submodes in Mode 0 that allow accessing of DRAM data at either the nibble (4-bit) or byte ( 8 -bit) level. The submode is selected by the $S$ bit (bit 3 ) in the Mode Register:

$$
\begin{array}{ll}
S=0 & \text { CDP Nibble Submode } \\
S=1 & \text { CDP Byte Submode }
\end{array}
$$

## CDP Nibble Submode

The CDP Nibble Submode $(S=0)$ reads or writes DRAM data one nibble at a time. Eight bits of data corresponding to two 4-bit LUT addresses (P3-P0 and Q3-Q0) are on the A/D data bus, but only one nibble is read or written during each access.

When writing the data, the Q nibble should contain the same pixel data as the $P$ nibble. Only one of the nibble values is strobed into DRAM according to the X0 value in the X CDP Register which enables the RASL or RASH signal to DRAM during the write. If $\mathrm{XO}=0$, the Q nibble (data bits $3-0$ ) is written
into the DRAM (row address strobed by $\overline{\text { RASL }}$ ); if $X 0=1$, the $P$ nibble (data bits 7-4) is written into the DRAM (row address strobed by $\overline{\text { RASH }}$ ).

When reading the data, only one nibble is read depending on the state of $X 0$ in the $X$ CDP. If $X 0=0$, the $Q$ nibble is read (row address strobed by $\overline{\text { RASL }}$ ); if $X 0=1$, the $P$ nibble is read (row address strobed by $\overline{\mathrm{RASH}}$ ).

Reading or writing the data in this submode has no effect on the $X$ CDP or Y CDP register values.

## CDP Byte Access Submode

The CDP Byte Submode $(S=1)$ reads or writes two 4-bit LUT addresses at a time (in one byte) with an automatic increment of the X CDP value in the X CDP Register during write. Each write of the DRAM data writes the eight data bits on AD0-AD7 into DRAM and increments the X CDP by two upon the completion of the write cycle. (The new $X$ CDP count can be read from the X CDP Register at any time.) As writing of the data continues, the $X$ CDP value eventually wraps around to zero and continues incrementing. The Y CDP Register value must be incremented by writing a new Y CDP value. The automatic increment of $X$ CDP value allows fast horizontal drawing for filling of polygon and rectangle type shapes (i.e., no intervening $X$ CDP update is required). Note that the filled boundaries must be addressed by the horizontal line software since the X0 value has no effect in this submode.

This feature is useful for fast non-modulo 210 Y scrolling with quick reads/writes interleaved by old/new Y address updates. Note that when $S=1$ in the Mode Register, the XO value has no effect (the P nibble corresponds to $\mathrm{XO}=1$ and the Q nibble corresponds to $\mathrm{XO}=0$ ).

Reading of the DRAM data in this submode does not effect the X CDP count.

## CVDG PARAMETER I/O ACCESS

Six CVDG Parameter Access modes allow the MPU to load control parameters into CVDG internal registers. Two of the modes also allow the MPU to read the parameter values from registers. The exact mode and access is controlled by the selected mode in the Mode Register and the register select input lines (A1 and $A O$ ).

## Mode 1 - LUT Address

In Mode 1, data written to register address 3 ( $\mathrm{A} 1=1$ and AO = 1) is loaded into the LUT Address Register. Four bits control LUT write and read and the other four bits contain the actual LUT address. Bits 7-4 (XPE, RE, GE and BE) enable writing into, or reading from, corresponding sections of the LUT (i.e., XPAR, R, G and B) during Mode 2 access. Bits 3-0 in the register contain the LUT address ( $0-15$ ) accessed during Mode 2.

|  |  |  | Bit Position |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Register | A1 | A0 | R/W | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| LUT Address | 1 | 1 | W | XPE | RE | GE | BE | A 3 | A 2 | A 1 | A 0 |



The LUT address in the LUT Address Register, rather than the LUT addresses read from DRAM, is also used to lookup the color level code in the LUT during the active display time (border and/or pixel) in two circumstances:

1. Outside the $256 \times 210$ graphics area, i.e., to generate the border color. Note that programs loading the LUT during the vertical blanking interval (VBI) must restore the address of the border color in the LUT into the LUT Address Register prior to unblanking.
2. Within the $256 \times 210$ graphics area when the LS bit $=0$ in the Switch Register.

## Mode 2 - LUT Data

In Mode 2, LUT data (i.e., color levels and transparent state) written to, or read from, register address $3(A 1=1, A 0=1)$ is loaded into, or read from the LUT at the LUT address contained in the LUT Address Register. Only the section (R, G, B and/or XPAR codes) of the LUT entry enabled by bits 7-4 in the LUT Address Register are accessed. Normally only one enable bit at a time is set to a 1 . During a write, data will be written into each LUT section enabled. During a read, ambiguous data will be accessed if more than one enable bit is set.

The transparent state (XPAR) is only one bit (D3). The other three data bits (D2-DO) are don't care.

During a write, the data on the A/D bus is written into the CVDG LUT Data Register. The LUT Address Generator latches the 4-bit LUT address from the LUT Data Register rather than from the Video Shift Register. The LUT Address Generator then generates the 16 -bit binary address for routing to the LUT. The LUT is loaded in a similar manner as described for pixel color generation.

During a read, data is transferred from the LUT directly to the A/D bus without going through the LUT Data Register. XPAR is not availabe for readback.

|  |  |  | Bit Position |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Register | A1 | A0 | R/W | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ |
| $\mathbf{0}$ |  |  |  |  |  |  |  |  |  |  |  |
| LUT Data* | $\mathbf{1}$ | $\mathbf{1}$ | R/W | - | - | - | - | D3 | D2 | D1 | D 0 |

*During a read, data is transferred directly from LUT to A/D bus without going through LUT Data Register.

## DR7-DR4 Not used (no effect)

DR3-DR0 Color Level Code or Transparent Bit State

## Mode 3 - Switch Register

In Mode 3, switch position data (represented by bit states) written to register address $3(A 1=1, A 0=1)$ is loaded into the CVDG Switch Register. Three bits control video raster operation, one bit controls the LUT address access source, and one bit enables the CVDG test mode. All five bits are set to a 1 by power up.

|  |  |  |  | Bit Position |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Register | A1 | A0 | R/W | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |
| Switch | $\mathbf{1}$ | $\mathbf{1}$ | W | NHS | S21 | EXT | LS | TST | - | - | - |

DR7 Normal Horizontal Sync (NHS) Select
0 Early 15.9 kHz ( $\overline{\mathrm{HSYNC}}$ ) Output
1 Normal 15.7 kHz HSYNC Output
DR6 2:1 Interlace Select (S21)
$0 \quad 1: 1$ interlace
$1 \quad 2: 1$ interlace

## DR5 External Sync Select (EXT)

0 Internal sync output on VSYNC (C/HSYNC output enabled.
1 External sync input on VSYNC ( $\overline{\mathrm{C} / \mathrm{HSYNC}}$ output disabled)

DR4 LUT Address Select (LS)
0 Select the LUT Address Register as the LUT address source
1 Select Video Shift Register data as LUT address source

## DR3 Test Mode Select (TST)

0 Normal mode; Vertical state machine (VSM) and $Y$ address counter (YAC) run at normal rate
1 Test mode; VSM and YAC run at 1.413 MHz (used for factory test only)

## Mode 4 - Y Scroll Register

In Mode 4, a $Y$ scroll offset value written to register address 3 ( $A 1=1, A 0=1$ ) is loaded into the $Y$ Scroll Register. The $Y$ scroll offset may vary from 0 to 209 (decimal). The value written defines the first horizontal row to be displayed at the top of the $256 \times 210$ graphics image area.

|  |  |  |  | Bit Position |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Register | A1 | A0 | R/W | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | $\mathbf{0}$ |  |
| Y Scroll | $\mathbf{1}$ | $\mathbf{1}$ | W | Y 7 | Y 6 | Y 5 | Y 4 | Y 3 | Y 2 | Y 1 | Y 0 |  |

DR7-DR0 Y Scroll Offset

```
0000000 Offset = 0
0000001 Offset = 1
11010001 Offset = 209 (maximum allowed)
```


## Mode 5 - Teletext DMA Pointer

In Mode 5, an 8-bit Teletext pointer written to register address 2 ( $A 1=1, A 0=0$ ) is loaded into the TTX Pointer Register and Counter. The pointer, consisting of address bits A12-A5 specifies the starting address on a 32-byte boundary for the DMA transfer of teletext data into video page 3 of DRAM. During a teletext DMA data transfer, the Modulo 32 Teletext Counter is incremented by one upon each DMA byte transfer. The TTX Pointer Register is incremented by one every 32 bytes. The value of the Teletext Pointer can be read at any time in Mode 5.

|  |  |  |  |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Register | A1 | A0 | R/W | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ |
| $\mathbf{n}$ | $\mathbf{0}$ |  |  |  |  |  |  |  |  |  |  |
| Teletext Pointer | 1 | 0 | R/W | A12 | A11 | A10 | A9 | A8 | A7 | A6 | A5 |

The status of the P, V1 and V0 in the Mode/Status Register are unchanged during a Teletext DMA data transfer.

## Mode 6 - Set DRAM Page

In Mode 6, data written to register address 3 ( $\mathrm{A} 1=1, A 0=1$ ) is loaded into the DRAM Page Register. The data contains a 3-bit DRAM page select code and five unused bits (don't care). These DRAM page select bits specify the 8 k -byte DRAM page accessed during a MPU DRAM access ( $\overline{\text { DRCS }}=$ low) when A13 input is LOW. The DRAM page bits can be read from the Status Register at any time.

|  |  |  |  | Bit Position |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Register | A1 | A0 | R/W | $\mathbf{7}$ | $\mathbf{6}$ | $\mathbf{5}$ | $\mathbf{4}$ | $\mathbf{3}$ | $\mathbf{2}$ | $\mathbf{1}$ | 0 |  |
| DRAM Page | 1 | 1 | W | - | - | - | - | - | P | V 1 | V0 |  |

## DR7-DR3 Not Used (no effect)

DR2-DRO Selected DRAM Page

| DR2 | DR1 | DR0 |
| :---: | :---: | :---: |
| $\underline{\text { (P) }}$ | $\underline{\text { (V1) }}$ | (V0) |


| 0 | 0 | 0 | Video Page 0: 8k-byte video RAM |
| :--- | :--- | :--- | :--- |
| 0 | 0 | 1 | Video Page 1: 8k-byte video RAM |
| 0 | 1 | 0 | Video Page 2: 8k-byte video RAM <br> 0 |
| 1 | 1 | Video Page 3: 2.3k-byte video RAM; <br> 5.9k-byte program RAM |  |
| 1 | 0 | 0 | Program Page 0: 16k-byte optional program <br> RAM accessed via $\overline{\text { DRCS }}$ (additionally paged <br> by A13 and AO inputs) |

## MPU DRAM I/O ACCESS

When $\overline{\mathrm{DRCS}}$ is LOW, the MPU directly accesses the DRAM in an address map manner. The MPU generates the DRAM row and column addresses (except for two column address lines which are driven by the CVDG). The CVDG drives the AD5 and AD6 lines during DRAM column address time and also outputs control signals ( $\overline{R T I M E}, \overline{\text { CTIME }}$ and $\overline{\text { DTIME }}$ ) to enable external A/D bus buffers. MPU address line A1-A8 are enabled onto A/D bus lines AD0-AD7, respectively, by RTIME to drive the DRAM row address. MPU address line A9-A12 are enabled onto A/D bus lines AD1-AD4, respectively, by CTIME to drive the DRAM column address. The CVDG drives AD5 and AD6 with one of two sets of signals during CTIME. External bidirectional data line buffers are enabled by DTIME in the direction controlled by the MPU R/ $\bar{W}$ output to transfer data between the MPU data bus lines D0-D7 and A/D bus lines AD0-AD7.

A13 input high causes program DRAM to be accessed during the processor portion of the A/D bus independent of the $P$ bit value in the DRAM Page Register. CASP is asserted in response to the A13 HIGH to strobe the column address lines into program DRAM.

When A13 input is LOW, the section of DRAM accessed depends on the $P$ bit value in the DRAM Page Register and the AO input. If $P=0$, video DRAM is accessed; $\overline{\text { CAS1 }}$ is generated when $A 0$ is LOW and CAS2 is generated when AO is HIGH. If $P=1$, program DRAM is accessed since $\overline{\text { CASP }}$ is generated instead of CAS1 or CAS2 to strobe the DRAM column address.

The AD5 and AD6 outputs are driven by the CVDG during DRAM column address generation in the processor portion of the A/D bus cycle as controlled by the $P$ bit in the DRAM Page Register. If video DRAM is selected ( $P=0$ ), the V0 and V1 bits in the DRAM Page Register are output on AD5 and AD6, respectively. If program DRAM is selected $(P=1)$, the AO and A13 inputs are output on AD5 and AD6, respectively.

Note that the DRAM requires assertion of all three control signals for a valid access (i.e., $\overline{R A S}, \overline{\mathrm{CAS}}$ and $\overline{\mathrm{OE}}$ for a read and RAS, $\overline{\mathrm{CAS}}$ and $\overline{\mathrm{W}}$ for a write). The CVDG sometimes outputs one or two of these signals but not all three control signals in "no access" situations.

## TELETEXT DMA I/O ACCESS

Teletext data can be DMA transferred from a teletext prefix processor connected to the A/D bus to DRAM locations addressed by the CVDG. A 13-bit TTX Latch/Counter determines the DRAM address. The upper 8 -bits of the TTX Counter is a latch. The value of the latch is defined by the TTX Pointer Register which can be loaded in Mode 5 by writing to register address 2 ( $\mathrm{A} 1=1$ and $\mathrm{AO}=0$ ). The TTX Pointer Register value therefore defines the TTX DMA starting address on a 32-byte boundary. The lower 5 -bits of the TTX Latch/Counter is a modulo 32 counter. This counter increments by one after each TTX byte transfer. When the counter overflows (i.e., from 31 to 0 )
the upper count is incremented by one to increment the total address. The address is reset to zero during horizontal blanking. The upper count may be read from the TTX Pointer Register at any time in Mode 5.

TTX DMA transfer is initiated by asserting TTXREQ to the CVDG. The CVDG asserts TTX Output Enable (TTXOE) to acknowledge TTXREQ receipt, suspends outputting the E and Q clocks for one cycle, outputs the 13 -bit DRAM address and asserts DRAM Write Enable ( $\overline{\mathrm{W}}$ ) to enable writing into DRAM.

Note that DMA must be used only when the horizontal sync is genlocked to the external teletext raster.


Figure 6. CVDG Connection to A/D Bus and DRAM

## 





## AC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0\right)$

## MPU CLOCK AND CONTROL LINE TIMING

| Ref. Fig. 8 No. | Symbol | Parameter | Min. | Typ. | Max. | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $\mathrm{t}_{\text {ECYC }}$ | E Cycle Time | 700 | 698 |  | ns | 1 |
| 2 | $t_{r}, t_{f}$ | $E$ and Q Rise and Fall |  | 25 |  | ns |  |
| 3 | $t_{\text {ELEH }}$ | E Low to E High |  | 350 |  | ns |  |
| 4 | $\mathrm{t}_{\text {EHEL }}$ | E High to E Low |  | 350 |  | ns |  |
| 5 | $\mathrm{t}_{\mathrm{ELQH}}$ | E Low to Q Rising |  | 175 |  | ns |  |
| 6 | $t_{\text {QHEH }}$ | Q High to E Rising |  | 175 |  | ns |  |
| 7 | ${ }^{\text {tehal }}$ | E High to Q Falling |  | 175 |  | ns |  |
| 8 | $\mathrm{t}_{\text {QLEL }}$ | Q Low to E Falling |  | 175 |  | ns |  |
| 9 | $\mathrm{t}_{\text {SLEH }}$ | Chip Select Low to E Rising (Setup) |  | 70 |  | ns |  |
| 10 | ${ }^{\text {tSHEH }}$ | Chip Select High to E Rising (Hold) |  | 0 |  | ns |  |
| 11 | $\mathrm{t}_{\text {EHQV }}$ | E High to Data Valid (Read) |  |  | 240 | ns |  |
| 12 | $\mathrm{t}_{\text {ELQ }}$ | E Low to Output High Z (Read) |  | 10 |  | ns |  |
| 13 | $t_{\text {dVEL }}$ | Data Valid to E Falling (Write) | 100 |  |  | ns |  |
| 14 | $\mathrm{t}_{\text {ELDZ }}$ | E Falling to Data Invalid (Write) |  | 30 |  | ns |  |

## Note:

1. Based on 28.636363 MHz SYSCLK input.


Figure 8. CVDG-MPU A/D Bus Timing Waveforms

DRAM TIMING - VIDEO ACCESS CYCLE

| Ref. Fig. 9 No. | Symbol | Parameter | Min. | Typ. | Max. | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $t_{\text {RLRTL }}$ | $\overline{\text { RAS }}$ Low to $\overline{\text { RTIME Low (Delay) }}$ |  | 315 |  | ns |  |
| 2 | $t_{\text {RTLRTH }}$ | RTIME Low to RTIME High |  | 70 |  | ns |  |
| 3 | $\mathrm{t}_{\text {RLCTL }}$ | $\overline{\text { RAS Low to CTIME Low (Delay) }}$ |  | 35 |  | ns |  |
| 4 | $\mathrm{t}_{\text {cticth }}$ | CTIME Low to CTIME High |  | 87 |  | ns |  |
| 5 | $\mathrm{t}_{\text {RLDTL }}$ | $\overline{\text { RAS Low to DTIME Low (Delay) }}$ |  | 122 |  | ns |  |
| 6 | $\mathrm{t}_{\text {DTLDTH }}$ | DTIME Low to DTIME Hıgh |  | 157 |  | ns |  |
| 7 | $\mathrm{t}_{\mathrm{RC}}$ | RAM Read/Write Cycle |  | 350 |  | ns |  |
| 8 | $\mathrm{t}_{\mathrm{RP}}$ | RAS High Width |  | 105 |  | ns |  |
| 9 | $\mathrm{t}_{\text {RAS }}$ | RAS Low Width |  | 245 |  | ns |  |
| 10 | $t_{\text {RCD }}$ | $\overline{\text { RAS }}$ Low to CAS Low (Delay) |  | 70 |  | ns |  |
| 11 | $\mathrm{t}_{\text {CAS }}$ | CAS Low Width |  | 245 |  | ns |  |
| 12 | ${ }^{\text {t }}$ CSH | $\overline{\text { RAS }}$ Low to CAS Rising (Delay) |  | 315 |  | ns |  |
| 13 | $\mathrm{t}_{\text {RSH }}$ | $\overline{\text { CAS }}$ Low to RAS Rising (Delay) |  | 175 |  | ns |  |
| 14 | $\mathrm{t}_{\text {CPN }}$ | $\overline{\text { CAS }}$ High Width |  | 105 |  | ns |  |
| 15 | $\mathrm{t}_{\text {CRP }}$ | $\overline{\text { CAS }}$ High to $\overline{\text { RAS }}$ Falling (Delay) |  | 35 |  | ns |  |
| 16 | $t_{t}$ | $\overline{R A S}$ and CAS Transition Times |  | 5 |  | ns |  |
| 17 | $\mathrm{t}_{\text {RCS }}$ | Read Command Setup |  | 105 |  | ns |  |
| 18 | $t_{\text {ASR }}$ | Row Address Setup |  | 35 |  | ns |  |
| 19 | $t_{\text {RAH }}$ | Row Address Hold |  | 35 |  | ns |  |
| 20 | $\mathrm{t}_{\text {ASC }}$ | Column Address Setup |  | 35 |  | ns |  |
| 21 | $\mathrm{t}_{\text {CAH }}$ | Column Address Hold |  | 70 |  | ns |  |
| 22 | $\mathrm{t}_{\text {AR }}$ | RAS Low to Column Hold |  | 140 |  | ns |  |
| 23 | $\mathrm{t}_{\text {RAC }}$ | $\overline{\text { RAS }}$ Low to Data Valıd (Setup) |  |  | 150 | ns |  |
| 24 | ${ }^{\text {t }}$ CAC | $\overline{\text { CAS }}$ Low to Data Valid (Setup) |  |  | 80 | ns |  |
| 25 | $t_{\text {RLG1L }}$ | $\overline{\text { RAS }}$ Low to OE1 Low (Delay) |  | 140 |  | ns |  |
| 26 | $\mathrm{t}_{\text {GLGHr }}$ | $\overline{\mathrm{OE}}$ Low to $\overline{\mathrm{OE}}$ High |  | 70 |  | ns |  |
| 27 | $t_{\text {OEA }}$ | $\overline{\mathrm{OE}}$ Low to Data Valid (Setup) | 0 |  | 40 | ns |  |
| 28 | $\mathrm{t}_{\text {OEZ }}$ | $\overline{O E}$ High to Output High Z (Hold) | 0 |  | 35 | ns |  |
| 29 | $\mathrm{t}_{\text {RLG2L }}$ | $\overline{\text { RAS }}$ Low to $\overline{\mathrm{OE} 2}$ Low (Delay) |  | 210 |  | ns |  |

DRAM TIMING - MPU DRAM ACCESS CYCLE

| Ref. Fig. 9 No. | Symbol | Parameter | Min. | Typ. | Max. | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 30 | $t_{\text {RRH }}$ | Read Command Hold After $\overline{\text { RAS }}$ High |  | 280 |  | ns |  |
| 31 | $\mathrm{t}_{\mathrm{RCH}}$ | Read Command Hold After $\overline{\mathrm{CAS}} \mathrm{High}$ |  | 210 |  | ns |  |
| 33 | $\mathrm{t}_{\text {GLGH }}$ | $\overline{\mathrm{OE}}, \overline{\mathrm{OE} 2}$ Low to $\overline{\mathrm{OE} 1}, \overline{\mathrm{OE} 2} \mathrm{High}$ |  | 140 |  | ns |  |
| 36 | $\mathrm{t}_{\mathrm{DS}}$ | Data Setup |  | 12 |  | ns |  |
| 37 | $t_{\text {WP }}$ | $\bar{W}$ Low to $\bar{W}$ High |  | 140 |  | ns |  |
| 38 | $\mathrm{t}_{\mathrm{DH}}$ | Data Hold After $\bar{W}$ Low |  | 70 |  | ns |  |
| 39 | $t_{\text {DHC }}$ | Data Hold After $\overline{\text { CAS }}$ Low |  | 175 |  | ns |  |
| 40 | $t_{\text {DHR }}$ | Data Hold After $\overline{\text { RAS }}$ Low |  | 245 |  | ns |  |
| 41 | $t_{\text {WCR }}$ | Write Command Hold After $\overline{\text { RAS }}$ Low |  | 315 |  | ns |  |
| 42 | $\mathrm{t}_{\text {WCH }}$ | Write Command Hold After CASP Low |  | 245 |  | ns |  |
| 43 | $t_{\text {RWL }}$ | Write Command Setup before $\overline{\text { RAS }}$ Rising |  | 70 |  | ns |  |
| 44 | $\mathrm{t}_{\mathrm{CWL}}$ | Write Command Setup before $\overline{\text { CAS Rising }}$ |  | 140 |  | ns |  |



Figure 9. CVDG-DRAM A/D Bus Timing Waveforms

TELETEXT DMA CYCLE TIMING

| Ref. Fig. 10 No. | Symbol | Parameter | Min. | Typ. | Max. | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $\mathrm{t}_{\text {RLEL }}$ | TTXREQ Low to E Low (Setup) |  | 80 |  | ns |  |
| 2 | $t_{\text {ELRH }}$ | E Low to TTXREQ High (Hold) |  | 10 |  | ns |  |
| 3 | $\mathrm{t}_{\text {ELGL }}$ | E Low to TTXOE Low |  | 595 |  | ns |  |
| 4 | $\mathrm{t}_{\text {GLGH }}$ | TTXOE Low to TTXOE High |  | 140 |  | ns |  |



Figure 10. Teletext Prefix Processor - CVDG Timing Waveforms

HORIZONTAL VIDEO TIMING

| Ref. Fig. 11 No. | Symbol | Parameter | Min. | Typ. | Max. | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 |  | H Sync to Setup | 9.3 | 9.4 | 9.5 | $\mu \mathrm{S}$ | 1 |
| 2 |  | H Front Porch | 1.4 | 1.5 | 1.6 | $\mu \mathrm{S}$ | 1 |
| 3 |  | H Sync to XPAR | - | 10.16 | - | $\mu \mathrm{S}$ | 2 |
| 4 |  | XPAR Front Porch | - | 2.79 | - | $\mu \mathrm{S}$ | 2 |
| 5 |  | H Sync to Border 1 | - | 8.38 | - | $\mu \mathrm{S}$ | 2 |
| 6 |  | H Sync to Graphics | - | 1257 | - | $\mu \mathrm{S}$ | 2 |
| 7 |  | H Sync to Border 2 | - | 57.27 | - | $\mu \mathrm{S}$ | 2 |
| 8 |  | Border Front Porch | - | 2.79 | - | $\mu \mathrm{S}$ | 2 |
| 9 |  | H Sync Tip | - | 4.81 | - | $\mu \mathrm{S}$ | 2 |
| 10 |  | H Period (Normai) | - | 63556 | - | $\mu \mathrm{S}$ | 2 |
| 11 |  | H Perıod (Early) | - | 62.857 | - | $\mu \mathrm{S}$ | 2 |

Notes: 1. RS-170A Specifiçation (shown for reference only).
$2 \pm 0.1 \mu \mathrm{~s}$, based on 28.636363 MHz SYSCLK input.


Figure 11. Horizontal Video Output Timing Waveforms

## Vertical Cycle Timing

| Ref. Fig. 12 No. | Symbol | Parameter | Min. | Typ. | Max. | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $\mathrm{V}_{\text {SU }}$ | $\overline{\text { VSYNC }}$ Low Input to First Serration Setup | 20 | - | - | ns | 3 |
| 2 | $\mathrm{V}_{\mathrm{H}}$ | VSYNC Low Input Pulse Duration | 63.5 | - | - | $\mu \mathrm{S}$ | 3 |
| - |  |  | 19 | - | - | H | 1 |
| - |  | $\checkmark$ Blank Duration | 52 | - | - | H | 1 |
| - |  | V Unblank to Graphics Duration (Top Border) | 21 | - | - | H | 1 |
| - |  | Graphics to V Blank Duration (Bottom Border) | 31 | - | - | H | 1, 2 |

Notes: 1. $\mathrm{H}=\overline{\mathrm{HSYNC}}$ pulse width $(63.5 \mu \mathrm{~s})$
2. 21 interlace mode
3. Shown for reference only-not an R6549 requirement

a. Vertical Synchronization

b. RS-170A Composite Sync VBI Timing Specifications

Figure 12. Vertical Cycle Waveforms-2:1 Interlace

## teletext dma cycle timing

| Ref. Fig. 13 <br> No. | Symbol | Parameter | Min. | Typ. | Max. | Unit | Notes |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | $t_{\text {ELPL }}$ | E Low to PIXCK High |  | 0 |  | ns |  |
| 2 | $t_{\text {PHPL }}$ | PIXCK High to PIXCK Low |  | 70 |  | ns |  |
| 3 | t PPLH $^{2}$ | PIXCK Low to PIXCK High |  | 105 |  | ns |  |
| 4 | tPCYC | PIXCK Cycle |  | 175 |  | ns |  |



Figure 13. Video Output Waveforms

## DC CHARACTERISTICS

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

| Parameter | Symbol | Min. | Typ. | Max. | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage SYSCLK <br> $\overline{\text { IOCS }}, \overline{\mathrm{DRCS}}, \overline{\text { TTXREQ }}, \mathrm{A} 0, ~ A 1, ~ A 13, ~ R / \bar{W}$, VSYNC, ADO-AD7 | $\begin{aligned} & \mathrm{V}_{\mathrm{IHC}} \\ & \mathrm{~V}_{\mathrm{IH}} \end{aligned}$ | $\begin{aligned} & \mathrm{v}_{\mathrm{cc}}-0.75 \\ & \mathrm{v}_{\mathrm{ss}}+2.0 \end{aligned}$ |  | $\begin{aligned} & \mathrm{v}_{\mathrm{cc}} \\ & \mathrm{v}_{\mathrm{cc}} \end{aligned}$ | V |  |
| Input Low Voltage <br> SYSCLK <br> IOCS, $\overline{\text { DRCS }}, \overline{T T X R E Q}, ~ A 0, ~ A 1, ~ A 13, ~ R / \bar{W}$ VSYNC, ADO-AD7 | $\begin{aligned} & \mathrm{V}_{\mathrm{ILC}} \\ & \mathrm{v}_{\mathrm{IL}} \end{aligned}$ | $\begin{aligned} & v_{s s}-0.3 \\ & v_{s s}-0.3 \end{aligned}$ |  | $\begin{aligned} & \mathrm{v}_{\mathrm{Ss}}+0.4 \\ & \mathrm{v}_{\mathrm{SS}}+0.8 \end{aligned}$ | V |  |
| Input Leakage Current | IL | - | - | $\pm 10$ | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V} \text { to } 5.25 \mathrm{~V} \\ & \mathrm{~V}_{\mathrm{CC}}=0 \end{aligned}$ |
| Output High Voltage <br> E <br> Q, $\overline{\text { RTIME }}$ CTIME, $\overline{\text { DTIME }}$ <br> $\overline{\text { RASL, }} \overline{\text { RASH, }} \overline{\text { W }}$ <br> CAS1, $\overline{\text { CAS } 2}, \overline{\mathrm{CASP}}, \overline{\mathrm{OE} 1}, \overline{\mathrm{OE2}}, \overline{\mathrm{TTXOE}}$, C/HSYNC, VSYNC, CSUBC, PIXCK, XPAR AD0-AD7 | $\mathrm{V}_{\mathrm{OH}}$ | $\begin{aligned} & V_{\mathrm{CC}}-0.75 \\ & \mathrm{~V}_{\mathrm{SS}}+2.4 \\ & \mathrm{~V}_{\mathrm{SS}}+2.4 \end{aligned}$ |  |  | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{OH}}=-0.14 \mathrm{~mA} \\ & \text { Note } 1 \\ & \mathrm{I}_{\mathrm{OH}}=-80 \mu \mathrm{~A} \\ & \text { Note } 2 \end{aligned}$ |
| Output Low Voltage <br> E <br> Q, $\overline{\text { RTIME }} \overline{\text { CTIME }} \overline{\text { DTIME }}$ <br> $\overline{\text { RASL }}, \overline{\text { RASH }}, \bar{W}$, <br> CAS1, CAS2, $\overline{\mathrm{CASP}}, \overline{\mathrm{OE} 1}, \overline{\mathrm{OE} 2}, \overline{\mathrm{TTXOE}}$, C/HSYNC, VSYNC, CSUBC, PIXCK, XPAR ADO-AD7 | $\mathrm{V}_{\text {OL }}$ |  |  | $\begin{aligned} & v_{\mathrm{Ss}}+0.4 \\ & \mathrm{v}_{\mathrm{Ss}}+0.4 \\ & \mathrm{v}_{\mathrm{Ss}}+0.4 \end{aligned}$ | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\mathrm{LL}}=1.7 \mathrm{~mA} \\ & \text { Note } 1 \\ & \mathrm{I}_{\mathrm{OL}}=1.6 \mathrm{~mA} \end{aligned}$ <br> Note 2 $\mathrm{I}_{\mathrm{OL}}=3.0 \mathrm{~mA}$ $\text { Note } 3$ |
| Output Leakage Current (Off-State) <br> ADO-AD7 | loff | - | - | $\pm 20$ | $\mu \mathrm{A}$ | $\mathrm{V}_{\mathrm{IN}}=0$ to 5.25 V |
| Output High Voltage R, G, B | $\mathrm{V}_{\mathrm{VH}}$ | - | +2.800 | - | V | $\begin{aligned} & \mathrm{C}_{\mathrm{L}}=30 \mathrm{pF} \\ & \mathrm{R}_{\mathrm{L}}=10 \mathrm{~K} \mathrm{Onms} \\ & \mathrm{t}_{\mathrm{r}} / \mathrm{t}_{\mathrm{f}}=50 \mathrm{~ns} \end{aligned}$ |
| Output Low Voltage R, G, B | $\mathrm{V}_{\mathrm{VL}}$ | - | +1.875 | - | V |  |
| Output Blanking Voltage R, G, B | $\mathrm{V}_{\mathrm{VB}}$ | - | +1.800 | - | V |  |
| ```Input Capacitance4 SYSCLK \overline{OCS},\overline{DRCS},\overline{TTXREQ}, A0, A1, A13, R/\overline{W} VSYNC, ADO-AD7``` | $\mathrm{C}_{\text {IN }}$ | $-$ | - | $\begin{array}{r} 10 \\ 5 \end{array}$ | pF | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \text {, chip } \\ & \text { deselected, pin } \\ & \text { Under test at } \mathrm{OV} \text {, } \\ & \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \\ & \mathrm{f}=0.986 \mathrm{MHz} \\ & \text { (SYSCLK } \\ & =28.6363 \mathrm{MHz} \text { ) } \end{aligned}$ |

## Notes:

1. Output Load: 1 TTL gate; $\mathrm{C}_{\mathrm{L}}=140 \mathrm{pF}$

2 Output Load: 1 TTL gate; $C_{L}=100 \mathrm{pF}$
3. Output Load: 6 DRAM, 2 LS244 buffers and 1 LS245 transceiver; $C_{L}=180 \mathrm{pF}$
4. This parameter is periodically sampled and is not $100 \%$ tested.

## ABSOLUTE MAXIMUM RATINGS*

| Parameter | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
| Input Voltages | $\mathrm{V}_{\text {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 the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## PACKAGE DIMENSIONS

## 40-PIN PLASTIC DIP



| DIM | MILLIMETERS |  | INCHES |  |  |  |
| :---: | ---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |  |
| A | 51.28 | 52.32 | 2.040 | 2060 |  |  |
| B | 13.72 | 14.22 | 0.540 | 0560 |  |  |
| C | 3.55 | 5.08 | 0.140 | 0200 |  |  |
| D | 0.36 | 051 | 0.014 | 0.020 |  |  |
| F | 1.02 | 152 | 0040 | 0.060 |  |  |
| G | 2.54 |  | BSC | 0.100 |  | BSC |
| H | 1.65 | 216 | 0.065 | 0.085 |  |  |
| J | 0.20 | 0.30 | 0.008 | 0.012 |  |  |
| K | 305 | 3.56 | 0.120 | 0.140 |  |  |
| L | 15 | 15 | BSC | 0.600 |  | BSC |
| M | $7^{\circ}$ | $10^{\circ}$ | $7^{\circ}$ | $10^{\circ}$ |  |  |
| N | 0.51 | 1.02 | 0.020 | 0040 |  |  |

# R6551 <br> 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 $\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 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 |
| :---: |

## FEATURES

- Compatible with 8-bit microprocessors
- Full duplex operation with buffered receiver and transmitter
- Data set/modern control functions
- Internal baud rate generator with 15 programmable baud rates (50 to 19,200)
- Program-selectable internally or externally controlled receiver rate
- Programmable word lengths, number of stop bits, and parity bit generation and detection
- Programmable interrupt control
- Program reset
- Program-selectable serial echo mode
- Two chip selects
- 2 or 1 MHz operation
- $5.0 \mathrm{Vdc} \pm 5 \%$ supply requirements
- 28-pin plastic or ceramic DIP
- Full TTL compatibility
- Compatible with R6500, R6500/* and R65C00 microprocessors


Figure 1. R6551 ACIA Pin Configuration


Figure 2. ACIA Internal Organization

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

## INTERRUPT LOGIC

The Interrupt Logic will cause the $\overline{\mathrm{RQ}}$ line to the microprocessor to go low when conditions are met that require the attention of the microprocessor. The conditions which can cause an interrupt will set bit 7 and the appropriate bit of bits 3 through 6 in the Status Register, if enabled. Bits 5 and 6 correspond to the Data Carrier Detect ( $\overline{\mathrm{DCD}}$ ) logic and the Data Set Ready ( $\overline{\mathrm{DSR}}$ ) logic. Bits 3 and 4 correspond to the 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 | DSR | DCD | 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 |  | DSR high (not ready) |  |  |  |  |  |
| Bit 5 |  | Data Carrier Detect ( $\overline{\mathrm{DCD}})$ |  |  |  |  |  |
| 0 |  | $\overline{D C D}$ low (detected) |  |  |  |  |  |
| 1 |  | $\overline{\mathrm{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{D S R}$ inputs to the ACIA. A 0 indicates a low level (true condition) and a 1 indicates a high level (false). Whenever either of these inputs change state, an immediate processor interrupt (IRQ) occurs, 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.


Bit $7 \quad$ Stop Bit Number (SBN)
01 Stop bit
12 Stop bits
$1 \quad 11 / 2$ Stop bits
For WL = 5 and no parity
11 Stop bit
For WL = 8 and parity
Bits 6 6-5

| $\frac{6}{0}$ | $\frac{5}{0}$ | Word Length (WL) |
| :--- | :--- | :--- |
| 0 | 0 | 8 |
| 0 | 1 | 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)
$\begin{array}{lllll}\frac{3}{0} & \frac{2}{0} & \frac{1}{0} & \frac{0}{0} \quad \frac{\text { Baud }}{16 x \text { External Clock }}\end{array}$
$\begin{array}{lllll}0 & 0 & 0 & 1 & 50\end{array}$
$\begin{array}{lllll}0 & 0 & 1 & 0 & 75\end{array}$
$\begin{array}{lllll}0 & 0 & 1 & 1 & 109.92\end{array}$
$\begin{array}{lllll}0 & 1 & 0 & 0 & 134.58\end{array}$
$\begin{array}{lllll}0 & 1 & 0 & 1 & 150\end{array}$
$\begin{array}{lllll}0 & 1 & 1 & 0 & 300\end{array}$
$\begin{array}{lllll}0 & 1 & 1 & 1 & 600\end{array}$
$\begin{array}{lllll}1 & 0 & 0 & 0 & 1200\end{array}$
100001800
1003002400
$\begin{array}{lllll}1 & 0 & 1 & 1 & 3600\end{array}$
$\begin{array}{lllll}1 & 1 & 0 & 0 & 4800\end{array}$
$\begin{array}{lllll}1 & 1 & 0 & 1 & 7200 \\ 1 & 1 & 1 & 0 & 9600\end{array}$
$1111 \begin{array}{llll}19,200\end{array}$

## Reset Initialization

| 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| - | - | - | - | - | - | - | - |
| Hardware reset (RES) |  |  |  |  |  |  |  |

## 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) |
| :---: | :---: |
| 76 |  |
| 00 | Odd parity transmitted/received |
| 0 | Even parity transmitted/received |
| 0 | 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, $\overline{\text { RTS }}$ will be low. |

Bits 3-2 Transmitter Interrupt Control (TIC)
$\begin{array}{lll}\frac{3}{0} & \frac{2}{0} \quad \overline{R T S} & =\text { High, transmitter disabled }\end{array}$
$0 \quad 1 \quad \overline{R T S}=$ Low, transmit interrupt enabled
$10 \quad \overline{\text { RTS }}=$ Low, transmit interrupt disabled
$11 \quad \overline{R T S}=$ Low, transmit interrupt disabled transmit break on TxD

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

## NOTE

*The transmitter is disabled immediately. The receiver is disabled but will first complete receiving a byte in process of being received.

## 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{\mathrm{DTR}}$ line high. A 1 indicates the microcomputer system is ready by setting the $\overline{\text { DTR }}$ line low. $\overline{\text { DTR }}$ also enables and disables the transmitter and receiver.

## 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{\text { RTS }}$ ) line and the Transmitter interrupt

## Receiver Echo Mode (Bit 4)

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

## Parity Mode Enable (Bit 5)

This bit enables parity bit generation and checking. A 0 disables parity bit generatıon by the Transmitter and parity bit checkıng 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



## 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{\mathrm{RES}}$ )

During system initıalizatıon 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 ( $\varnothing \mathbf{2}$ )

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

## Read/Write (R/W)

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

## Interrupt Request (IRQ)

The $\overline{\mathrm{RQ}}$ 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 (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 $\overline{\mathrm{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 | R $\overline{\mathbf{W}}=$ Low | R/ $\overline{\mathbf{W}}=$ High |
| L | L | Write Transmit Data <br> Register | Read Receiver <br> Data Regıster |
| 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 parallel mode external crystal $(1.8432 \mathrm{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 etther 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 $\overline{\text { RTS }}$ output pin controls the modem from the processor. The state of the RTS pin is determined by the contents of the Command Register.

## Clear to Send (CTS)

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

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

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

## 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{\mathrm{DCD}}$ input pin indicates to the ACIA the status of the carrierdetect output of the modem. A low indicates that the modem carrier signal is present and a high, that it is not.

## TRANSMITTER AND RECEIVER OPERATION

## Continuous Data Transmit

In the normal operating mode, the interrupt request output ( $\overline{\mathrm{IRQ}}$ ) 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 relatonship.


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 tıming relatıonship 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 immediately goes to the "MARK" condition. Interrupts continue at the same rate, but the Status Register does not indicate that the Transmit

Data Register is empty. Since there is no status bit for CTS, the processor must deduce that CTS has gone to the FALSE (high) state. CTS is a transmit control line only, and has no effect on the R6551 Receiver Operation. Figure 8 shows the timing relationship for this operation.


Figure 8. Effect of CTS on Transmitter

## Effect of Overrun on Receiver

If the processor does not read the Receiver data Regıster 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 $\overline{\mathrm{CTS}}$ on Echo Mode Operation

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


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

## 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{RQQ}}$, 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{D C D}$ on Receiver

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

Once such a change of state occurs, subsequent transitions will not cause interrupts or changes in the Status Register until the first interrupt is serviced. When the Status Register is read by the processor, the ACIA automatically checks the level of the $\overline{D C D}$ line, and if it has changed, another $\overline{\mathrm{RQ}}$ occurs (see Figure 14).


Figure 14. Effect of DCD on Receiver

## 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 Contınuous "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 contınuous "BREAK" 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{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 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{\mathrm{RES}} \mathrm{pin}$ ) and is described as follows:

1. Internal registers are not completely cleared. Check register formats for the effect of a program reset on internal registers.
2. The $\overline{D T R}$ line goes high immediately.
3. Receiver and transmitter interrupts are disabled immediately. If $\overline{\mathrm{RQ}}$ is low when the reset occurs, it stays low until serviced, unless interrupt was caused by $\overline{\mathrm{DCD}}$ or $\overline{\mathrm{DSR}}$ transition.
4. $\overline{D C D}$ and $\overline{D S R}$ interrupts are disabled immediately. If $\overline{\operatorname{RQ}}$ is low and was caused by $\overline{\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{R T S}$ goes low.
2. If Bit 0 of Command Register ( $\overline{\mathrm{DTR}}$ ) is 0 (disabled), then:
a) All interrupts are disabled, including those caused by $\overline{D C D}$ and $\overline{\mathrm{DSR}}$ transitions.
b) Transmitter is disabled immediately.
c) Receiver is disabled, but a character currently being received will be completed first.
3. Odd parity occurs when the sum of all the 1 bits in the data word (Including the parity bit) is odd.
4. In the receive mode, the received parity bit does not go into the Receiver Data Register, but generates parity error or no parity error for the Status Register.
5. Transmitter and Receiver may be in full operation simultaneously. This is "full-duplex" mode.
6. If the RXD line inadvertently goes low and then high right after a Stop Bit, the ACIA does not interpret this as a Start Bit, but samples the line again halfway into the bit 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 approprıate 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 <br> 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 Pın 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{18432 \times 10^{6}}{16,769}=109.92$ | $\frac{F}{16,769}$ |
| 0 | 1 | 0 | 0 | 13,704 | $\frac{18432 \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{18432 \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{18432 \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$ | $\begin{gathered} F \\ \hline 768 \\ \hline \end{gathered}$ |
| 1 | 0 | 1 | 1 | 512 | $\frac{1.8432 \times 10^{6}}{512}=3,600$ | $\begin{gathered} F \\ \hline 512 \\ \hline \end{gathered}$ |
| 1 | 1 | 0 | 0 | 384 | $\frac{1.8432 \times 10^{6}}{384}=4,800$ | $\begin{gathered} F \\ \hline 384 \\ \hline \end{gathered}$ |
| 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$ | $F$ <br> 192 |
| 1 | 1 | 1 | 1 | 96 | $\frac{18432 \times 10^{6}}{96}=19,200$ | $\begin{gathered} F \\ \hline 96 \\ \hline \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" testıng, 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 (..e., TxD to RxD, $\overline{D T R}$ to $\overline{D C D}, \overline{R T S}$ to $\overline{C T S}$ ).

LLB may be tied to a peripheral control pin (from an 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 Regıster 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{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

| Characteristic | Symbol | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Transmit/Receive Clock Rate | ${ }^{\text {teCy }}$ | 400* | - | 400* | - | ns |
| Transmit/Receive Clock High Time | ${ }^{\text {t }}$ CH | 175 | - | 175 | - | ns |
| Transmit/Receive Clock Low Time | ${ }^{\text {t }} \mathrm{CL}$ | 175 | - | 175 | - | ns |
| XTLI to TxD <br> Propagation Delay | $t_{\text {D }}$ | - | 500 | - | 500 | ns |
| RTS Propagation Delay | ${ }_{\text {t }}^{\text {DLY }}$ | - | 500 | - | 500 | ns |
| $\overline{\mathrm{RQ}}$ Propagation Delay (Clear) | $\mathrm{t}_{\text {IRQ }}$ | - | 500 | - | 500 | ns |
| Load Capacitance $\overline{\text { DTR, }}$ RTS TxD | $\mathrm{C}_{\mathrm{L}}$ | - | 130 30 | - | $\begin{array}{r}130 \\ 30 \\ \hline\end{array}$ | pF pF |

## Notes:

$\left(\mathrm{t}_{\mathrm{R}}, \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(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 | 1 MHz |  | 2 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Cycle Time | $\mathrm{t}_{\mathrm{CYC}}$ | 1.0 | 40 | 0.5 | 40 | $\mu \mathrm{s}$ |
| $\emptyset 2$ Pulse Width | $\mathrm{t}_{\mathrm{C}}$ | 400 | - | 200 | - | ns |
| Address Set-Up Time | $t_{\text {ACW }}$ | 120 | - | 70 | - | ns |
| Address Hold Time | $\mathrm{t}_{\mathrm{CAH}}$ | 0 | - | 0 | - | ns |
| R/W Set-Up Time | $t_{\text {wcw }}$ | 120 | - | 70 | - | ns |
| R/W Hold Time | $\mathrm{t}_{\text {cWh }}$ | 0 | - | 0 | - | ns |
| Data•Bus Set-Up Time | $t_{\text {DCW }}$ | 150 | - | 60 | - | ns |
| Data Bus Hold Time | $t_{\text {HW }}$ | 20 | - | 20 | - | ns |
| Read Access Time (Valid Data) | $t_{\text {cDR }}$ | - | 200 | - | 150 | ns |
| Read Hold Time | $t_{\text {HR }}$ | 20 | - | 20 | - | ns |
| Bus Active Time (Invalid Data) | $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. $\mathrm{D} 0-\mathrm{D} 7$ load capacitance $=130 \mathrm{pF}$.


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}}$ | 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}_{\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 | $\mathrm{T}_{\mathrm{A}}$ |  |
| Commercial <br> Industrial |  | $0^{\circ}$ 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 | Max | Unit | Test Conditions |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage <br> Except XTLI and XTLO <br> XTLI and XTLO | $\mathrm{V}_{1 H}$ | $\begin{aligned} & 2.0 \\ & 2.4 \end{aligned}$ | - | $\begin{aligned} & \mathrm{V}_{\mathrm{cc}} \\ & \mathrm{~V}_{\mathrm{cc}} \end{aligned}$ | V |  |
| Input Low Voltage <br> Except XTLI and XTLO <br> XTLI and XTLO | $V_{\text {IL }}$ | $\begin{aligned} & V_{S S} \\ & V_{S S} \end{aligned}$ | - | $\begin{aligned} & 0.8 \\ & 0.4 \end{aligned}$ | V |  |
| Input Leakage Current申2, R/W $, \overline{R E S}, C S 0, C S 1, R S O, R S 1, \overline{C T S}, R \times D, \overline{D C D}, \overline{D S R}$ | 1 IN | - | - | 2.5 | $\mu \mathrm{A}$ | $\begin{aligned} & \mathrm{V}_{\text {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} & V_{\text {IN }}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\ & V_{\mathrm{CC}}=5.25 \mathrm{~V} \end{aligned}$ |
| Output High Voltage D0-D7, TxD, RxC, $\overline{R T S}, \overline{D T R}$ | $\mathrm{V}_{\mathrm{OH}}$ | 2.4 | - | - | V | $\begin{aligned} & \mathrm{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}_{\mathrm{OL}}$ | - | - | 0.4 | V | $\begin{aligned} & \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\ & \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA} \end{aligned}$ |
| Output High Current (Sourcing) D0-D7, TxD, RxC, $\overline{R T S}, \overline{D T R}$ | IOH | -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}$ | loL | 1.6 | - | - | mA | $\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}$ |
| Output Leakage Current (off state) IRQ | loff | - | - | 10.0 | $\mu \mathrm{A}$ | $\mathrm{V}_{\text {OUT }}=5 \mathrm{~V}$ |
| Clock Capacitance (ф2) | $\mathrm{C}_{\text {CLK }}$ | - | - | 20 | pF | $\mathrm{V}_{C C}=5 \mathrm{~V}$ |
| 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 | $\mathrm{C}_{\text {out }}$ | - | - | 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



## R6592 <br> SINGLE-CHIP PRINTER CONTROLLER

## 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 ( $\overline{\text { PS1 }}$ )
PRINTER SOLENOID 2 ( $\overline{\text { PS2 }}$ )
PRINTER SOLENOID 3 (PS3)
PRINTER SOLENOID 4 (ㅍS4)
PRINTER SOLENOID 5 (ㅍS5)
PRINTER SOLENOID 6 (포6)
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} 1}$ corresponds to the top dot and 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 ( $\overline{\text { PCL2 }})$
PRINTER CONTROL LINE 3 (ㅍCL3)

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 | R6592 Signal Name |  |  |
| :--- | :--- | :--- | :--- |
|  | 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 L | NA | Paper Feed | Paper Release |
| 542 | NA | Paper Feed | Paper Release |

[^4]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{\mathrm{RR}}$ and $\overline{\mathrm{RL}}$ ) and are active high for the 200 series (RL). The printer timing and reset lines are assigned as follows:

| Printer <br> Model | R6592 Signal |  |  |
| :---: | :---: | :---: | :---: |
|  | TIM | $\overline{\mathbf{R L} / \text { RL }}$ | $\overline{\text { RR }}$ |
| 210 | T Detector | R Detector (RL) | NA |
| 220 | T Detector | R Detector (RL) | NA |
| 240 | T Detector | R Detector (RL) | NA |
| 511L | Timing Signal | Reset Signal R-L ( $\overline{\mathrm{RL}}$ ) | NA |
| 512 | Timing Signal | Reset Signal R-L ( $\overline{\mathrm{RL}})$ | Reset Signal R-R ( $\overline{\mathrm{RR}}$ ) |
| 522 | Timing Signal | Reset Signal R-L ( $\overline{\mathrm{RL}}$ ) | Reset Signal R-R ( $\overline{\mathrm{RR}})$ |
| 541L | Timing 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 (PM1)
PRINTER MODEL 2 (피2)
PRINTER MODEL 3 ( $\overline{\text { PM3 }}$ )
Encoded input lines used to determine which printer model is connected to the R6592. A connection to GND (low) causes " 0 " to be read. An open input (high) causes logic " 1 " to be read. The encoding for the printer model is:

| Printer <br> Model | Printer Model Line |  |  |
| :--- | :---: | :---: | :---: |
|  | PM3 | PM2 | PM1 |
| 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 ( $\overline{\text { PRT }}$ )

Active low input line used to command R6592 to print a line. When low (GND) print commands will continue to be issued. If the print buffer is partially filled, a line will be printed. Line feeds will subsequently be issued while $\overline{\text { 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) DATA LINE 2/BAUD RATE 2 (DL2/BR2) DATA LINE 3/BAUD RATE 3 (DL3/BR3) DATA LINE 4/BAUD RATE 4 (DL4/BR4)

Active high input signals used as parallel data lines if parallel data transfer mode is selected, or used as baud rate select lines if serial data transfer mode is selected.

If 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 (IP). When $\overline{\mathbb{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. This line can, therefore, be used as a print disable line to selected printers in a multiprinter system.

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

## $\overline{\text { DATA STROBE }}$ ( $\overline{\mathrm{DS}}) / \overline{\text { RECEIVED SERIAL DATA }}$ ( $\overline{\mathrm{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 ( $\overline{\mathrm{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 (DTR). When high, $\overline{\mathrm{DTR}}$ indicates that the R6592 cannot
receive data. When low, $\overline{\text { DTR }}$ indicates that the R6592 is ready to receive data. $\overline{D T R}$ is switched high during character print and while non-print commands are being processed.

## ACKNOWLEDGE (즉)

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

## SERIAL CLOCK (SER CLK)

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

## SERIAL DETECT ENABLE (DET ENA)

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

## PRIMARY POWER (VCC)

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

## RAM POWER (VRR)

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

## SIGNAL GROUND (VSS)

R6592 power and signal ground.

## XTLI

Input from 2 MHz crystal.

## XTLO

Output to 2 MHz crystal.

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

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

|  |  | 吅硈 ه0000 |  |  |  |  |  |  |  | gopgog暗品器㗊名 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  |  |  |  | 品品品品别㗊㗊㗊㗊 $\qquad$ |  |  |  |
|  |  |  |  |  |  | 昭影别部趷命 <br>  |  |  |  | 品品品品品年品品影品帤 ロ00ロ00 | pogasp <br> 0 <br>  |


| $\begin{aligned} & \text { 㗊品㗊 } \\ & \text { 品品㗊 } \end{aligned}$ |  | 㗊品㗊品。 | 鲥蹋㗊。 |  |  | 鲾㗊㗊㗊 |  |  |  | 䟮㗊㗊 | 路䟚品 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 噩㗊㗊 |  |  | 品最最品 － $0^{2} 0_{0}$ 0080000 |  | 㗊品㗊 <br>  |  |  | 暺躇品 |  | 㗊䎪㗊品㗊品 |  |
|  |  | 嘆璟品。 |  |  |  |  |  |  |  |  |  |
|  |  |  |  |  | 蹋躡㗊v |  |  |  |  | 啚㗊㗊㗊 | 㗊噩㗊㗊品 |

Speciai 6 Character 5x7 Matrix Dot Patterns

| 5A | 58 | 5C | 5D | 5 E | 5 F |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 90008080 | 搹㗊品 | 8080品 | 㗊品品 |  |  |
| 品品 | 噳郘 | 品硣 | 品 | － |  |
| 㗊昭 | － 8 品 | 煰品 | 昭吅 | 最䊍昭 | 枵硈 |
|  | 舓硈 |  | 㗊喑 | 吅枵 | 碱硈 |
| YEN | POUND | ONE．HALF | CENT | NO TAX | TAX |

## R6592 Internal Data Format for 7-Bit ASCII Table Character Look-Up



ASCII 7-Bit Code Character Set Table


Note: Valid control commands are dependent upon printer model.


PARALLEL DATA TIMING

$\overline{\text { DATA STROBE }}(\overline{\mathrm{DS}})$

$\overline{A C K N O W I E D G E}(\overline{A C K})$


Busy

*OR UNTIL $\overline{\text { ACK IS RECEIVED. }}$


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}_{\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.

## STATIC DC CHARACTERISTICS

$\left(\mathrm{V}_{\mathrm{CC}}=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}_{\text {IL }}$ | -0.3 | - | +0.8 | Vdc |
| Input Threshold Voltage | $\mathrm{V}_{\text {IT }}$ | 0.8 | - | 2.0 | Vdc |
| Input Leakage Current $\mathrm{V}_{\mathrm{tn}}=0 \text { to } 5.0 \mathrm{Vdc}$ <br> 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 ( $\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{Vdc}$ ) | ILL | - | -1.0 | -1.6 | mAdc |
| Output High Voltage $\left(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)$ | $\mathrm{IOH}^{\text {O}}$ | -100 |  | - | ${ }_{\mu}$ Adc |
| Output Low Current (Sinking) $\left(\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{Vdc}\right)$ | lOL | 1.6 | - | - | mAdc |
| Input Capacitance $\begin{aligned} & \left(\mathrm{V}_{\mathrm{n}}-0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1.0 \mathrm{MHz}\right) \\ & \text { Pins 2-9,13-29 and } 31-38 \\ & \text { XTLI, XTLO } \end{aligned}$ | $\mathrm{C}_{\text {In }}$ | - | - | $\begin{aligned} & 10 \\ & 50 \\ & \hline \end{aligned}$ | pF |
| Output Capacitance $\left(\mathrm{V}_{\mathrm{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.

## 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 $D C$ to 4 MHz .

## ORDERING INFORMATION

| Part Number | Frequency | Temperature Range |
| :---: | :---: | :---: |
| R65560 | $\begin{aligned} & 4 \mathrm{MHz} \\ = & \text { Ceramic } \\ = & \text { Plastic } \end{aligned}$ | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ |

## 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. $\mathrm{R} \overline{\mathrm{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} / \overline{\mathbf{W}}$-Read/Write. $\mathrm{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 ( $\mathrm{R} \overline{\mathrm{W}}$ low), the $\emptyset 2$ negative transition latches data on data bus lines D0 - D7 into the MPCC. During a read $(R / \bar{W}), 02$ high enables data from the MPCC to data bus
$\overline{\mathbf{I R Q}}$-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.

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{\mathrm{DTS}}$ low input causes a DMA transfer to occur on the next $\emptyset 2$ cycle. When $\mathrm{R} \bar{W}$ is high, data is transferred into the TxFIFO; when R $\bar{W}$ is low, data is transferred from the RxFIFO.

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 DONE signal asserted by the DMAC in response to a TDSR will be stored to track with the data byte through the TxFIFO.
$\overline{\operatorname{RES}}-$ Reset. $\overline{\mathrm{RES}}$ is an active low, high impedance input that initializes all MPCC functions. $\overline{R E S}$ must be asserted for at least 500 ns to initialize the MPCC.

DTR-Data Terminal Ready. The 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{\mathrm{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 transition and level are reported in the CTS and CTSLVL bits in the Serial Interface Status Register (SISR), respectively.


Figure 2. MPCC Input and Output Signals
$\overline{\text { DSR-Data Set Ready. The } \overline{\mathrm{DSR}} \text { active low input negative }}$ transition and level are reported in the DSRT and DSRLVL bits in the SISR, respectively. $\overline{\mathrm{DSR}}$ is also an output for RSYN.
$\overline{\mathrm{DCD}}$-Data Carrier Detect. The $\overline{\mathrm{DCD}}$ active low input positive transition and level are reported in the DCDT and DCDLVL bits in the the SISR, respectively.

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

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

TxC-Transmitter Clock. TxC can be programmed to be an input or an output. When TxC is selected to be an input, the transmitter clock must be provided externally. When TxC is programmed to be an output, a clock is generated by the MPCC's internal baud rate generator. 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 (Vss).

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

|  |  <br> *Must be connected to $\mathbf{V}_{\text {cc }}$. |
| :---: | :---: |

Pin Configuration

Table 1. R65560 Accessible Registers

| 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) ${ }^{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 O | 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 1B | 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 | $1 E$ | 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{\operatorname{RES}}$ resets the TxFIFO pointer to the start of the first byte.
3. Reserved registers may contain random bit values.

Table 2. MPCC Register Bit Assignments

| R/W <br> 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 | 0 | RABTEN | RRES | 01 |
| R | RECEIVED DATA (RxFIFO) |  |  |  |  |  |  |  | - - |
| R/W | $\begin{aligned} & \text { RDA } \\ & \text { IE } \end{aligned}$ | $\begin{gathered} \mathrm{EOF} \\ \mathrm{IE} \end{gathered}$ | 0 | C/PERR IE | FRERR <br> IE | $\begin{gathered} \hline \text { ROVRN } \\ \text { IE } \\ \hline \end{gathered}$ | $\begin{gathered} \text { RA/B } \\ \text { IE } \\ \hline \end{gathered}$ | 0 | 00 |

Receiver Status Register (RSR)
Receiver Control
Register (RCR)
Register (RCR)
Receiver Data
Register (RDR)
Receiver Interrupt Enable
Register (RIER)

| R/W | TDRA | TFC | 0 | 0 | 0 | TUNRN | TFERR | 0 | $\mathbf{8 0}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| R/W | TEN | TDSREN | TICS | 0 | 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 | 0 | 00 |
| R/W | CTS <br> IE | DSR <br> IE | DCD <br> IE | 0 | 0 | 0 | 0 | 0 | 00 |

Serial Interface Status Register (SISR)
Serial Interface Control Register (SICR)
Serial Interrupt Enable 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 |
| R/W | 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 | CFCRC | 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)

[^5]
## 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.

[^6]\quad-Not used

```

\section*{TRANSMITTER REGISTERS}

Transmitter Status Register (TSR)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline TDRA & TFC & 0 & 0 & 0 & TUNRN & TFERR & 0 \\
\hline
\end{tabular}

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 \(\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 TIER is set.

\section*{TSR}

7 TDRA -Transmitter Data Register Available.
\(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).
Frame not complete.
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.
No transmitter underrun occurred. Transmitter underrun occurred.

TSR
1 TFERR -Transmit Frame Error (BOP only). No frame error has occurred.
1 No control field was present (short frame).
Transmitter Control Register (TCR)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline TEN & TDSREN & TICS & 0 & TLAST & TSYN & TABT & TRES \\
\hline
\end{tabular}

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

\section*{TCR}

7 TEN -Transmitter Enable.
\(\overline{0}\) Disable transmitter. TxD output is idled. The TxFIFO may be loaded while the transmitter is disabled.
1 Enable transmitter.

TCR
\begin{tabular}{ccc}
6 & TDSREN & \begin{tabular}{c}
-Transmitter Data Service Request \\
Enable.
\end{tabular} \\
0 & Disable transmitter DMA mode. \\
1 & Enable transmitter DMA mode.
\end{tabular}
 (ASYNC and ISOC), or FLAG character (BOP).

TCR
\(4 \quad\)-Not Used. This bit is initialized to 0 by \(\overline{R E S}\) and must not be set to 1 .

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

TCR
2 TSYN -Transmit SYN (BSC and COP only).
0 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. 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.

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.

TRES -Transmitter Reset Command. Enable normal transmitter operation. Reset transmitter. Clears the transmitter section including the TxFIFO and the TSR (but not the TCR). The TxD output is held in "Mark"' condition. TRES is set by \(\overline{\text { RES }}\) 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 RES.

\section*{Transmit Data Register (TDR)}
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline MSB & \multicolumn{5}{|c|}{ Transmitted Data (TxFIFO) } \\
\hline
\end{tabular}

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)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \begin{tabular}{c} 
TDRA \\
IE
\end{tabular} & \begin{tabular}{c} 
TFC \\
IE
\end{tabular} & 0 & 0 & 0 & \begin{tabular}{c} 
TUNRN \\
IE
\end{tabular} & \begin{tabular}{c} 
TFERR \\
IE
\end{tabular} & - \\
\hline
\end{tabular}

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.
Disable TDRA Interrupt.
Enable TDRA Interrupt.
TIER
6 TFC IE -Transmit Frame Complete (TFC) Interrupt
Enable.
Disable TFC Interrupt.
Enable TFC Interrupt.
TIER
5-3
-Not used.
TIER
2 TUNRN IE -Transmitter Underrun (TUNRN) Interrupt
Enable.
Disable TUNRN Interrupt.
Enable TUNRN Interrupt.
TIER
1 TFERR IE -Transmit Frame Error (TFERR) Interrupt
Enable.
0 Disable TFERR Interrupt.
1
TIER
0 -Not used.

```

\section*{SERIAL INTERFACE REGISTERS}

\section*{Serial Interface Status Register (SISR)}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline CTST & DSRT & DCDT & CTSLVL & DSRLVL & DCDLVL & 0 & 0 \\
\hline
\end{tabular}

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{R} Q}\) 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.
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{8}{|l|}{} \\
\hline 7 CTS & \multicolumn{7}{|l|}{\multirow[t]{3}{*}{\begin{tabular}{l}
CTST -Clear to Send Transition Status. \\
\(\overline{\mathrm{CTS}}\) has transitioned positive (from active to inactive) (TRES must be a zero). \\
\(\overline{\text { CTS }}\) has not transitioned positive.
\end{tabular}}} \\
\hline \(\frac{7}{1}\) & & & & & & & \\
\hline C & & & & & & & \\
\hline \multicolumn{8}{|l|}{SISR} \\
\hline 6 DSR & \multicolumn{7}{|l|}{DSRT -Data Set Ready Transition Status.} \\
\hline 1 & \multicolumn{7}{|l|}{DSR has transitioned negative (from inactive to active).} \\
\hline 0 & SR has not & tra & sitio & d & gative. & & \\
\hline \multicolumn{8}{|l|}{SISR} \\
\hline 5 DCD & DCDT - & ata & arrie & De & ect Tra & sition & tus. \\
\hline 1 & \multicolumn{7}{|l|}{\(\overline{\mathrm{DCD}}\) has transitioned positive (from active to inactive).} \\
\hline 0 & \multicolumn{7}{|l|}{\(\overline{\mathrm{DCD}}\) has not transitioned positive.} \\
\hline \multicolumn{8}{|l|}{SISR} \\
\hline 4 CTS & \multicolumn{7}{|l|}{CTSLVL -Clear to Send Level.} \\
\hline 0 & \multicolumn{7}{|l|}{CTS input level is negated (high).} \\
\hline 1 C & \multicolumn{7}{|l|}{CTS input level is asserted (low).} \\
\hline \multicolumn{8}{|l|}{SISR} \\
\hline 3 DSR & \multicolumn{7}{|l|}{DSRLVL -Data Set Ready Level.} \\
\hline 0 & \multicolumn{7}{|l|}{DSR input level is negated (high).} \\
\hline 1 & \multicolumn{7}{|l|}{\(\overline{\text { DSR }}\) input level is asserted (low).} \\
\hline \multicolumn{8}{|l|}{SISR} \\
\hline 2 DC & \multicolumn{7}{|l|}{DCDLVL -Data Carrier Detect Level.} \\
\hline 0 & \multicolumn{7}{|l|}{\(\overline{\mathrm{DCD}}\) input level is negated (high).} \\
\hline 1 & \multicolumn{7}{|l|}{\(\overline{\mathrm{DCD}}\) input level is asserted (low).} \\
\hline \multicolumn{8}{|l|}{SISR} \\
\hline 1-0 & \multicolumn{7}{|c|}{-Not used.} \\
\hline \multicolumn{8}{|l|}{Serial Interface Control Register (SICR)} \\
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline RTSLVL & DTRLVL & - & - & - & ECHO & TEST & 0 \\
\hline
\end{tabular}

Reset value \(=\$ 00\)

The Serial Interface Control Register (SICR) controls various serial interface signals and test functions.

\section*{SICR}

\section*{7 RTSLVL -Request to Send Level.} Negate RTS output (high). 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 RTS output is negated within two bit times.

\section*{SICR}

6 DTRLVL -Data Terminal Ready Level. Negate DTR output (high). Assert DTR output (low).

SICR
-Not used. These bits are initialized to 0 by RESET and must not be set to 1 .

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

SICR
\(\frac{1}{0} \quad\) TEST \(\quad\) 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

Serial Interrupt Enable Register (SIER)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \begin{tabular}{c} 
CTS \\
IE
\end{tabular} & \begin{tabular}{c} 
DSR \\
IE
\end{tabular} & \begin{tabular}{c} 
DCD \\
IE
\end{tabular} & - & - & - & - & - \\
\hline
\end{tabular}

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{\mathrm{RQ}}\) output is asserted when the corresponding condition occurs as reported in the SISR.
SIER
\begin{tabular}{lll}
\(\mathbf{7}\) & CTS IE \(\quad\) Clear to Send (CTS) Interrupt Enable. \\
\hline 0 & Disable CTS Interrupt. \\
1 & Enable CTS Interrupt.
\end{tabular}
\begin{tabular}{ccc} 
SIER & & \\
\(\mathbf{6}\) & DSR IE & -Data Set Ready (DSR) Interrupt Enable. \\
\hline 0 & Disable DSR Interrupt. \\
1 & Enable DSR Interrupt.
\end{tabular}


SIER
4-0 -Not used.

\section*{GLOBAL REGISTERS}

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

Protocol Select Register 1 (PSR1)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline- & - & - & - & - & - & CTLEX & ADDEX \\
\hline
\end{tabular}

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

PSR1
7-2 -Not used.
\begin{tabular}{|c|c|}
\hline PSR1 & \\
\hline 1 & CTLEX -Control Field Extend (BOP only). \\
\hline 0 & Select 8-bit control field. \\
\hline 1 & Select 16-bit control field. \\
\hline PSR1 & \\
\hline 0 & ADDEX -Address Extend (BOP only). \\
\hline 0 & Disable address extension. All eight bits of the address byte are utilized for addressing. \\
\hline 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). \\
\hline
\end{tabular}

Protocol Select Register 2 (PSR2)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline WD/BYT & STOP BIT SEL & \multicolumn{2}{|c|}{ CHAR LEN SEL } & \multicolumn{2}{|c|}{ PROTOCOL SEL } \\
\hline & SB2 & SB1 & CL2 & CL1 & PS3 & PS2 & PS1 \\
\hline
\end{tabular}

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{R E S}\) and must not be changed to 1 .

PSR2
\begin{tabular}{lccl}
\begin{tabular}{c}
2 \\
PS3
\end{tabular} & \(\frac{1}{1}\) & \begin{tabular}{c}
0 \\
PS2
\end{tabular} & \(\frac{\text { PS1 }}{0}\)
\end{tabular}\(\quad\)\begin{tabular}{l}
\multicolumn{1}{c}{ Protocol } \\
\hline 0
\end{tabular}

6-5 STOP BIT SEL -Number of Stop Bits Select. Selects the number of stop bits transmitted at the end of the data transmitted at the end of the data
bins in ASYNC and ISOC modes.
\begin{tabular}{|c|c|c|c|}
\hline 6 & 5 & \multicolumn{2}{|l|}{No. of Stop Bits} \\
\hline SB2 & SB1 & ASYNC & ISOC \\
\hline 0 & 0 & 1 & 1 \\
\hline 0 & 1 & 1-1/2 & 2 \\
\hline 1 & 0 & 2 & 2 \\
\hline
\end{tabular}

\section*{PSR2}

4-3 CHAR LEN SEL - Character Length Select. Selects
4-3 CHAR LEN SEL - Character Length Select. Selects and BSC where the character length and BSC where the character length
is always eight bits. Parity is not included in the character length.
\begin{tabular}{ccc}
\begin{tabular}{c}
4 \\
CL2 \\
0
\end{tabular} & \(\frac{3}{\text { CL1 }}\) & Character Length \\
0 & 0 & 5 bits \\
1 & 1 & 6 bits \\
1 & 0 & 7 bits \\
& 1 & 8 bits
\end{tabular}

PSR2
2-0 PROTOCOL SEL—Protocol Select. Selects protocol
2-0 PROTOCOL SEL—Protocol Select. Selects protocol control bits.

\section*{Character Length \\ 5 bits \\ 7 bits \\ 8 bits}

Address Register 1 (AR1)
\begin{tabular}{|l|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{7}{|c|}{ BOP ADDRESS/BSC \& COP PAD } \\
\hline
\end{tabular}

Reset value \(=\$ 00\)

Address Register 2 (AR2)
\begin{tabular}{|l|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{7}{|c|}{ BSC \& COP SYN } \\
\hline
\end{tabular}

Reset value \(=\$ 00\)
The protocol selected in PSR2 (BOP, BSC and COP only) determines the function of the two 8-bit Address Registers (AR1 and AR2). As a secondary station in BOP, the contents of AR1 is used for address matching. In BSC and COP, AR1 and AR2 contain programmable leading PAD and programmable SYN characters, respectively.
Address Register (AR) Contents
\begin{tabular}{|l|c|c|}
\hline Protocol Selected & AR1 & AR2 \\
\hline BOP (Primary) & X & X \\
BOP (Secondary) & Address & X \\
BSC EBCDIC & Leading PAD & SYN \\
BSC ASCII & Leading PAD & SYN \\
COP & Leading PAD & SYN \\
\hline\({ }^{*} X=\) Not used & \\
\hline
\end{tabular}

Baud Rate Divider Register 1 (BRDR1)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{7}{|c|}{ BAUD RATE DIVIDER (LSH) } \\
\hline
\end{tabular}

Reset value \(=\$ 01\)
Baud Rate Divider Register 2 (BRDR2)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{7}{|c|}{ BAUD RATE DIVIDER (MSH) } \\
\hline
\end{tabular}

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: \(K=1\) for isochronous or synchronous 2 for asynchronous

Clock Control Register (CCR)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline- & - & - & PSCDIV & TCLKO & RCLKIN & \multicolumn{2}{|c|}{ CLK SEL } \\
\cline { 7 - 9 } & & & & & & CK2 & CK1 \\
\hline
\end{tabular}

Reset value \(=\$ 00\)
The CCR selects various clock options.

\section*{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.

\section*{CCR}
\begin{tabular}{ll}
\(\mathbf{3}\) & TCLKO \\
\(\frac{\text { Select Transmitter Clock Output Select. }}{}\) TxC to be an input. \\
1 & Select TxC to be an output. ( \(1 \times\) clock)
\end{tabular}

\section*{CCR}
\begin{tabular}{cc} 
2 & RCLKIN \\
\begin{tabular}{c}
-Receiver Clock Internal Select (ASYNC \\
only).
\end{tabular} \\
0 & Select External RxC. \\
1 & Select Internal RxC.
\end{tabular}

CCR
1-0 CLK DIV -External Receiver Clock Divider. Selects the divider of the external RxC to determine the receiver data rate.
\begin{tabular}{ccc} 
CK2 & CK1 & Divider \\
\hline 0 & 0 & 1 (ISOC) \\
0 & 1 & 16 \\
1 & 0 & 32 \\
1 & 1 & 64
\end{tabular}

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

\section*{Error Control Register (ECR)}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline PAREN & ODDPAR & - & - & CFCRC & CRCPRE & \multicolumn{2}{|c|}{ CRCSEL } \\
\cline { 7 - 9 } & & & & & & CR2 & CR1 \\
\hline
\end{tabular}

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

ECR
7 PAREN -Parity Enable. (ASYNC, ISOC and COP only).
0 Disable parity generation/checking.
1 Enable parity generation/checking.
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.
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
\(\begin{array}{llll}\frac{\text { CR2 }}{0} & \frac{\text { CR1 }}{} & & \text { Polynominal } \\ 0 & 0 & & \\ 0 & 1 & x^{16}+x^{12}+x^{15}+x^{5}+1 & \text { (CCITT V.41) } \\ 1 & 0 & x^{8}+1 & \text { (CRC-16) } \\ 1 & 1 & \text { Not used. } & \end{array}\)
*VRC: Odd-parity check is performed on each character including the LRC character.

\section*{INPUT/OUTPUT FUNCTIONS}

\section*{MPU INTERFACE}

Transfer of data between the MPCC and the system bus involves the following signals: Address lines A0 through A4, Data Bus Lines D0 through D7, and control signals consisting of R/ \(\bar{W}, \overline{C S}\), and Ø2. Figures 10 and 11 show typical interface connections.

\section*{Read/Write Operation}

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

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 DO - D7 when \(\emptyset 2\) is asserted. When the MPCC is selected (CS low) for a write ( \(\mathrm{R} / \overline{\mathrm{W}}\) low), \(\emptyset 2\) strobes data from the D0-D7 data lines into the selected register. Figures 12 and 13 show the read and write timing relationships.

\section*{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 singla 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 \bar{W}\) input to distinguish between the Transmitter Data Service Request (TDSR acknowiedge and the Receiver Data Service Request (RDSR) acknowledge.

\section*{Receiver DMA Mode}

The receiver DMA mode is enabled when the RDSREN bit in the RCR is set to 1 . When data is available in the RxFIFO, Receiver Data Service Request ( \(\overline{\mathrm{RDSR}}\) ) is asserted for one receiver clock period (BOP and BSC) to initiate the MPCC to memory DMA transfer. For asynchronous operation, \(\overline{\operatorname{RDSR}}\) is asserted for 2-3 periods of the system clock depending on prescale factor. The next \(\overline{\text { RDSR }}\) cycle may be initiated as soon as the current \(\overline{\text { RDSR }}\) cycle is completed (i.e., a full sequence of \(\overline{\mathrm{DACK}}, \emptyset 2\), and \(\overline{\mathrm{DTS}}\) ).

In response to \(\overline{\operatorname{RDSR}}\) assertion, the DMAC sets the \(R / \bar{W}\) line to write and asserts the memory address, DMA transfer strobe ( \(\overline{\mathrm{DTS}}\) ), and DMA acknowledge ( \(\overline{\mathrm{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{\operatorname{RES}}\) is asserted.

\section*{Transmitter DMA Mode}

The transmitter DMA mode is enabled when the TDSREN bit in the TCR is set to 1 . When the TxFIFO is available, Transmitter Data Service Request (TDSR) is asserted for one transmitter clock period to initiate the memory to MPCC DMA transfer. For asynchronous operation, \(\overline{\text { TDSR }}\) is asserted for a period of one-half the transmitter baud rate. The next TDSR cycle may be initiated as soon as the current TDSR cycle is completed.

In the transmitter DMA mode, the TxFIFO Is implicitly addressed. That is, when the transfer is from memory to the TxFIFO, only the memory is addressed. In response to TDSR assertion, the DMAC sets the \(R \bar{W}\) line to read 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 \(\overline{\mathrm{RES}}\) is asserted.

\section*{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, \(\overline{\text { 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.

\section*{CAUTION}
\(\overline{\mathrm{DONE}}\) is reasserted for each occurence of \(\overline{\mathrm{DACK}}\) until EOF is cleared in the RSR.

\section*{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{\mathrm{RQ}}\) will remain asserted until all interrupt causing conditions reported in status registers have been cleared.

\section*{SERIAL INTERFACE}

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

\section*{\(\overline{\text { RTS }}\) (Request to Send) Output}

The \(\overline{R T S}\) output to the DCE is controlled by the RTSLVL bit in the SICR 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 \(\overline{R T S}\) 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{\mathrm{RTS}}\) also is negated when the RTSLVL bit is reset during transmitter idle, or when the \(\overline{\text { RES }}\) input is asserted.

\section*{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 receive data. The \(\overline{\mathrm{CTST}}\) bit in the SISR reflects the transition status of the \(\overline{\mathrm{CTS}}\) input while the CTSLVL bit in the SISR reflects the current level. A positive transition on the \(\overline{\mathrm{CTS}}\) pin asserts \(\overline{\mathrm{RQ}}\) if the CTS IE bit in the SIER is set. The \(\overline{\mathrm{CTS}}\) input in an inactive state disables the start of transmission of each new frame.

\section*{\(\overline{\mathrm{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 \(\overline{D C D T}\) bit in the SISR reports the transition status of the \(\overline{\mathrm{DCD}}\) 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{RQ}}\) output if the DCD IE bit in the SIER is set. A negated DCD input disables the start of the receiver but does not stop the operation of an incoming message already in progress.

\section*{\(\overline{\text { DSR (Data Set Ready) Input/RSYN Output }}\)}

The \(\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{\text { 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{RQ}}\) 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{D S R}\) output low indicates detection of SYN in BSC or COP, or an address match in BOP.

\section*{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.

\section*{TxC (Transmitter Clock) Input/Output}

The transmitter clock (TxC) may be programmed to be input or an output. When the TCLKO control bit in the CCR is set to a 1, the TxC pin becomes an output and provides the DCE with a. clock whose frequency is determined by the internal baud rate generator. When the 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.

\section*{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.

\section*{RxC (Receiver Clock) Input}

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

\section*{RxD (Received Data) Input}

The serial data received by the MPCC 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.

\section*{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 .

\section*{SERIAL COMMUNICATION MODES AND PROTOCOLS}

\section*{ASYNCHRONOUS AND ISOCHRONOUS MODES}

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

\section*{Asynchronous Receive}

In the asynchronous (ASYNC) mode, data 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.


ISOCHRONOUS FRAME FORMAT


Figure 4. Asynchronous and Isochronous Frame Format

\section*{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.

\section*{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.

\section*{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.

\section*{BIT ORIENTED PROTOCOLS (BOP)}

In bit oriented protocols (BOP), messages (data) are transmitted and received in frames. Each frame contains an opening flag, address field, control field, frame check sequence, and a closing flag. A frame may also contain an information field. (See Figure 5).

The opening flag is a special character whose bit pattern is 01111110 . It marks the frame boundaries and is the interframe fill character. The address field of a frame contains the address of the secondary station which is receiving or responding to a command. The address field may be one or more bytes long. The address field can be extended by setting the ADDEX bit to a 1 in PSR1. In this case, the address field will be extended until the occurrence of an address byte with a 1 in bit 0 . The first byte of the address field is automatically checked when the MPCC is programmed to be a secondary station in BOP. An automatic check for global (11111111) or null (00000000) address is also made. The control field of one or two bytes is transparent to the MPCC and sent directly to the host without interpretation.

The optional information field consists of 8-bit characters. Cyclic redundancy checking is used for error detection and the CRC remainder resulting from the calculation is transmitted as the frame check sequence field. For BOP, the polynomial \(\mathrm{X}^{16}+\) \(X^{12}+X^{5}+1\) (CRC-CCITT) should be used, i.e., selected in the CRC SEL bits in the ECR. The registers representing the CRC-CCITT polynomial are generally preset to all 1 s , and the 1s 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.

\section*{BOP Receiver Operation}

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

\section*{BOP Transmitter Operation}

In BOP, the TxFIFO can be preloaded through the TDR while the transmitter is disabled (TEN = 0 in the TCR). When the transmitter is enabled (TEN = 1 in the TCR), the leading FLAG is automatically sent prior to transmitting data from the TxFIFO. The TDRA bit is set to 1 in the TSR as long as TxFIFO is not full. If an underrun occurs, the TUNRN bit in the TSR is set to a 1 and an ABORT (11111111) is transmitted followed by continuous 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.
\begin{tabular}{|l|l|l|l|l|l|}
\hline \begin{tabular}{l} 
FLAG \\
01111110
\end{tabular} & \begin{tabular}{l} 
ADDRESS \\
1 OR N \\
BYTES
\end{tabular} & \begin{tabular}{l} 
CONTROL \\
1 OR \\
2 BYTES
\end{tabular} & \begin{tabular}{l} 
INFORMATION \\
N BYTES \\
(OPTIONAL)
\end{tabular} & \begin{tabular}{l} 
FCS \\
2 BYTES
\end{tabular} & \begin{tabular}{l} 
FLAG \\
01111110
\end{tabular} \\
\hline
\end{tabular}

Figure 5. Bit Oriented Protocol (BOP) Frame Format

IBM SDLS FRAME FORMAT
\begin{tabular}{|l|l|l|l|l|l|}
\hline \begin{tabular}{l} 
FLAG \\
01111110
\end{tabular} & \begin{tabular}{l} 
ADDRESS \\
1 BYTE
\end{tabular} & \begin{tabular}{l} 
CONTROL \\
1 BYTE
\end{tabular} & \begin{tabular}{l} 
INFORMATION \\
N BYTES
\end{tabular} & \begin{tabular}{l} 
FCS \\
2 BYTES
\end{tabular} & \begin{tabular}{l} 
FLAG \\
01111110
\end{tabular} \\
\hline
\end{tabular}

\section*{ADCCP/HDLC FRAME FORMAT}
\(\left.\begin{array}{|l|l|l|l|l|l|}\hline \begin{array}{l}\text { FLAG } \\
01111110\end{array} & \begin{array}{l}\text { ADDRESS } \\
\text { N BYTES }\end{array} & \begin{array}{l}\text { CONTROL } \\
1 \text { OR } \\
2 \text { BYTES }\end{array} & \begin{array}{l}\text { INFORMATION } \\
\text { N BYTES }\end{array} & \begin{array}{l}\text { FCS } \\
2\end{array} & \text { BYTES }\end{array}\right]\)\begin{tabular}{l} 
FLAG \\
01111110
\end{tabular}

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.

\section*{BISYNC (BSC)}

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

Table 4. BSC Data-Link Control Characters
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{3}{|c|}{ASCII} & \multicolumn{3}{|c|}{EBCDIC} \\
\hline Command & Byte 1 & Byte 2 & Command & Byte 1 & Byte 2 \\
\hline SYN & 16* & - & SYN & 32* & - \\
\hline SOH & 01 & - & SOH & 01 & - \\
\hline STX & 02 & - & STX & 02 & - \\
\hline ETB & 17 & - & EOB (ETB) & 26 & - \\
\hline ETX & 03 & - & ETX & 03 & - \\
\hline ENQ & 05 & - & ENQ & 2D & - \\
\hline DLE & 10 & - & DLE & 10 & - \\
\hline ITB & 1F & - & ITB & 1F & - \\
\hline EOT & 04 & - & EOT & 37 & - \\
\hline ACK \({ }^{*}\) & 10 & 30-37 & ACK 0 & 10 & 70 \\
\hline NAK & 15 & - & ACK 1 & 10 & 61 \\
\hline WACK & 10 & 3B & NAK & 3D & - \\
\hline RVI & 10 & 3 C & WACK & 10 & 6B \\
\hline & & & RVI & 10 & 7 C \\
\hline
\end{tabular}

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

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

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

Table 5. BSC Control Sequences - Inclusion in CRC Accumulation
\begin{tabular}{|c|c|c|}
\hline \multirow{3}{*}{ Character of Sequence } & \multicolumn{2}{|c|}{ Included In CRC Accumulation } \\
\cline { 2 - 3 } TSYN & Yes & No \\
\hline TSOH & - & DLESYN \\
TSTX* & - & DLESOH \\
TETB & - & DLESTX \\
TETX & ETB & DLE \\
TDLE & ETX & DLE \\
& (DLE)DLE & DLE(DLE) \\
\hline
\end{tabular}
*If not preceded within the same block by transparent heading information.
\begin{tabular}{|l|l|l|l|l|l|}
\hline \begin{tabular}{l} 
LEADING PAD \\
1 BYTE \\
(AR1)
\end{tabular} & \begin{tabular}{l} 
SYN \\
1 BYTE \\
(AR2)
\end{tabular} & \begin{tabular}{l} 
SYN \\
1 BYTE \\
(AR2)
\end{tabular} & BODY & BCC & \begin{tabular}{l} 
TRAILING \\
PAD \\
1111111
\end{tabular} \\
\hline
\end{tabular}

Figure 7. BSC Block Format


Figure 8. BSC Message Format Examples

\section*{BSC Receiver Operation}

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

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

\section*{BSC Transmitter Operation}

BSC transmission begins with the sending of an opening pad (PAD) and two sync (SYN) characters. These characters are programmable and stored in AR1(PAD) and AR2(SYN). 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 DLE-STX 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 norinal mode. BCC generation is not used for messages beginning with characters other than SOH, STX, DLE-SOH, or DLE-STX. On all message types, if the TSYN bit is set to 1 in the TCR, a SYN-SYN (DLE-SYN sequence on transparent messages) sequence is transmitted before the next character is fetched from the TxFIFO.

\section*{CHARACTER ORIENTED PROTOCOLS}

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

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


Figure 9. Character Oriented Protocol Format



Figure 11. Typical Interface to 6800-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

\section*{AC CHARACTERISTICS}
\(\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.\) to \(\left.70^{\circ} \mathrm{C}\right)\)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Number & Parameter & Symbol & Min & Max & Unit \\
\hline 1 & R/ \(\bar{W}\) High to \(\emptyset 2\) High & \(t_{\text {RH2H }}\) & 0 & - & ns \\
\hline 2 & Address Valid to \(\overline{\mathrm{CS}}\) Low & \(\mathrm{t}_{\text {AVSL }}\) & 30 & - & ns \\
\hline 3 & \(\overline{\mathrm{CS}}\) Low to 02 High & \(\mathrm{t}_{\text {SL2H }}\) & 30 & - & ns \\
\hline 4 & 02 High to Data Valid & \(\mathrm{t}_{\text {2HDV }}\) & 0 & 140 & ns \\
\hline 5 & 02 Low to Data Invalid & \(\mathrm{t}_{\text {2LDXR }}\) & 10 & 150 & ns \\
\hline 6 & Ø2 Low to R/̄W Low & \(\mathrm{t}_{\text {LLRL }}\) & 20 & - & ns \\
\hline 7 & 02 Low to Address Invalid & \(\mathrm{t}_{\text {LLAI }}\) & 20 & - & ns \\
\hline 8 & R/ \(\bar{W}\) Low to \(\emptyset 2\) High & \(t_{\text {RL2H }}\) & 0 & - & ns \\
\hline
\end{tabular}

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|l|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & V \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +70 & V \\
\hline Operating Temperature & \(\mathrm{T}_{\mathrm{A}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{THERMAL CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|}
\hline Parameter & Symbol & Value & Rating \\
\hline Thermal Resıstance & \(\theta_{\mathrm{JA}}\) & & \({ }^{\circ} \mathrm{C} / \mathrm{W}\) \\
Ceramıc & & 50 & \\
Plastıc & & 68 & \\
\hline
\end{tabular}

\section*{DC CHARACTERISTICS}
\(\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.\) to \(70^{\circ} \mathrm{C}\) unless otherwise noted)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Max & Unit & Test Conditions \\
\hline Input High Voltage All Inputs & \(\mathrm{V}_{\mathrm{IH}}\) & \(+20\) & \(\mathrm{V}_{\mathrm{CC}}\) & V & \\
\hline Input Low Voltage All Inputs & \(\mathrm{V}_{\text {IL }}\) & \(-0.3\) & +08 & V & \\
\hline Input Leakage Current R/W, \(\overline{\text { RES }}, \overline{\mathrm{CS}}\) & \(\mathrm{I}_{\mathrm{IN}}\) & - & 10.0 & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IN}}=0 \text { to } 5.25 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Three-State (Off State) Input Current \(\overline{\mathrm{RQQ}}, \mathrm{DO} 0 \mathrm{D7}\) & \(\mathrm{T}_{\text {TSI }}\) & - & 10.0 & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IN}}=04 \text { to } 2.4 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{CC}}=525 \mathrm{~V}
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Output High Voltage \\
\(\overline{R D S R}, \overline{T D S R}, \overline{\mathrm{IRQ}}, \mathrm{DO}-\mathrm{D} 7, \overline{\mathrm{DSR}}, \overline{\mathrm{DTR}}, \overline{\mathrm{RTS}}\), TxD, TxC
\end{tabular} & \(\mathrm{V}_{\mathrm{OH}}\) & \(V_{S S}+2.4\) & - & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\text {LOAD }}=-400 \mu \mathrm{~A}, \\
& \mathrm{C}_{\text {LOAD }}=130 \mathrm{pF}
\end{aligned}
\] \\
\hline BCLK & \(\mathrm{V}_{\mathrm{OH}}\) & \(V_{S S}+2.4\) & - & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=475 \mathrm{~V} \\
& \mathrm{I}_{\mathrm{LOAD}}=0 \\
& \mathrm{C}_{\mathrm{LOAD}}=30 \mathrm{pF}
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Output Low Voltage \\
\(\overline{R D S R}, \overline{T D S R}, \overline{I R Q}, D 0-D 7, \overline{D S R}, \overline{D T R}, \overline{R T S}\), TxD, TxC, \(\overline{\text { BCLK }}\)
\end{tabular} & V OL & - & 0.5 & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\mathrm{LOAD}}=3.2 \mathrm{~mA}
\end{aligned}
\] \\
\hline \(\overline{\text { DONE }}\) & & & & & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\mathrm{LOAD}}=8.8 \mathrm{~mA}
\end{aligned}
\] \\
\hline Internal Power Dissipation & \(\mathrm{P}_{\text {INT }}\) & - & 1 & W & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline Input Capacitance & \(\mathrm{C}_{\text {IN }}\) & - & 13 & pF & \[
\begin{aligned}
& V_{I N}=0 V \\
& T_{A}=25^{\circ} \mathrm{C} \\
& \mathrm{f}=1 \mathrm{MHz}
\end{aligned}
\] \\
\hline
\end{tabular}

\section*{PACKAGE DIMENSIONS}

40-PIN CERAMIC DIP

\begin{tabular}{|c|c|c|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{2}{|c|}{ MLLLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 5029 & 5156 & 1980 & 2030 \\
\hline B & 1473 & 1549 & 0580 & 0610 \\
\hline C & 178 & 305 & 0070 & 0120 \\
\hline D & 038 & 058 & 0015 & 0023 \\
\hline F & 102 & 165 & 0040 & 0065 \\
\hline G & 229 & 280 & 0090 & 0110 \\
\hline J & 020 & 038 & 0008 & 0015 \\
\hline K & 318 & 381 & 0125 & 0150 \\
\hline L & 1499 & 1651 & 0590 & 0650 \\
\hline M & 0 & \(0^{\circ}\) & \(10^{\circ}\) & \(0^{\circ}\) \\
\hline N & 058 & 178 & \(10^{\circ}\) \\
\hline
\end{tabular}

\section*{40-PIN PLASTIC DIP}

\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{DIM} & \multicolumn{2}{|l|}{MILLIMETERS} & \multicolumn{2}{|l|}{INCHES} \\
\hline & MIN & max & MIN & MAX \\
\hline A & 5128 & 5232 & 2040 & 2060 \\
\hline B & 1372 & 1422 & 0540 & 0560 \\
\hline C & 355 & 508 & 0140 & 0200 \\
\hline D & 036 & 051 & 0014 & 0020 \\
\hline F & 102 & 152 & 0040 & 0060 \\
\hline G & \multicolumn{2}{|l|}{254 BSC} & \multicolumn{2}{|l|}{0100 BSC} \\
\hline H & 165 & 216 & 0065 & 0085 \\
\hline \(J\) & 020 & 030 & 0008 & 0012 \\
\hline K & 305 & 356 & 0120 & 0140 \\
\hline L & \multicolumn{2}{|l|}{1524 BSC} & \multicolumn{2}{|l|}{0600 BSC} \\
\hline M & 7 & \(10^{\circ}\) & 7 & \(10^{\circ}\) \\
\hline N & 051 & 102 & 0020 & 0040 \\
\hline
\end{tabular}

\title{
R65C02, R65C102, AND R65C112 \\ R65C00 MICROPROCESSORS (CPU)
}

\section*{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.

\section*{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

\section*{FEATURES}
- CMOS silicon gate technology
- Low Power ( \(4 \mathrm{~mA} / \mathrm{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)

\section*{ORDERING INFORMATION}

\section*{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.


\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{ARITHMETIC AND LOGIC UNIT (ALU)}

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

\section*{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.

\section*{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).

\section*{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.

\section*{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.

\section*{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{\operatorname{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).

\section*{MAJOR FEATURES AND DIFFERENCES}

The functional aspects of and differences between the microprocessor configurations are shown in Table 1.

Table 1. Family Comparison Chart
\begin{tabular}{|c|c|c|c|}
\hline Feature & \% & 응 & N \\
\hline Pin compatible with NMOS R6502 & X & & \\
\hline 64 K addressable bytes of memory & X & x & x \\
\hline \(\overline{\mathrm{IRQ}}\) interrupt & X & X & X \\
\hline On-chip clock oscillator & X & x & \\
\hline External clock only & & & X \\
\hline TTL level single phase clock input & x & X & \\
\hline RC time base clock input & x & X & \\
\hline Crystal time base clock input & x & X & \\
\hline Single phase clock input & & & x \\
\hline Two phase output clock & X & \(x\) & \\
\hline SYNC and RDY signals & x & X & X \\
\hline Bus Enable (BE) signal & & x & X \\
\hline Memory Lock ( \(\overline{\mathrm{ML}}\) ) output signal & & X & X \\
\hline Direct Memory Access (DMA) capacity & & X & x \\
\hline \(\overline{\text { NMI }}\) interrupt signal & x & X & X \\
\hline
\end{tabular}

\section*{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 Assianments

\section*{SIGNAL DESCRIPTIONS}

Reference the timing diagrams (Figures 3, 4 and 5) for the particular device in the following discussion.

\section*{CLOCK SIGNALS (R65C02)}

The R65C02 requires an external \(\emptyset 0\) clock. See Figure 6 for an example clock circuit. \(\varnothing 0\) is a TTL level input that is used to generate the internal clocks of the R65C02. Two full level output clocks are generated by the R65C02. The \(\emptyset 2\) clock is in phase with \(\emptyset 0\). The \(\emptyset 1\) clock output is \(180^{\circ}\) out of phase with \(\emptyset 0\). When the input clock is stopped, the CPU is in the standby mode. See Figure 8 for special standby mode considerations.

For non-critical timing configurations, a simple RC or crystal network may be strapped between \(\emptyset 0\) (IN) and \(\emptyset 1\) (OUT).

\section*{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 ( -4 ) using the XTLO and XTLI input pins. See Figure 7 for an example of a crystal time base circuit. Two full level output clocks are generated by the R65C102. The \(\emptyset 2\) clock output provides timing for external \(\mathrm{R} / \overline{\mathrm{W}}\) operations. Addresses are valid after the address setup time ( \(t_{\text {ADS }}\) ) referenced to the falling edge of \(\emptyset_{1}\) (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\).

\section*{CLOCK SIGNALS (R65C112)}

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

\section*{ADDRESS BUS (A0-A15)}

A0-A15 forms a 16 -bit address bus for memory and \(1 / \mathrm{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 .

\section*{DATA BUS (D0-D7)}

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

\section*{BUS ENABLE (BE)}

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

\section*{INTERRUPT REQUEST (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.

\section*{MEMORY LOCK (ML)}

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

\section*{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{\mathrm{NMI}}\) 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.

\section*{NOTE}

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

\section*{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 \(\phi 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).

\section*{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.

\section*{SET OVERFLOW ( \(\overline{\mathbf{S O}}\) )}

A negative transition on this line sets the overflow bit \((\mathrm{V})\) in the processor status register. The signal is sampled prior to the leading edge of \(\emptyset 2\) by the processor control time (tsos).

\section*{RESET ( \(\overline{\text { 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.

\section*{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.

\section*{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
\begin{tabular}{|l|l|l|}
\hline \multicolumn{1}{|c|}{ Function } & \multicolumn{1}{|c|}{ NMOS R6502 Microprocessor } & CMOS R65C00 Family Microprocessor \\
\hline Indexed addressing across page boundary. & Extra read of invalid address. & Extra read of last instruction byte. \\
\hline Execution of invalid op codes. & \begin{tabular}{l} 
Some terminate only by reset. Results are \\
undefined.
\end{tabular} & All are NOPs (reserved for future use). \\
\hline Jump indirect, operand = XXFF. & Page address does not increment. & \begin{tabular}{l} 
Page address increments and adds one ad- \\
ditional cycle.
\end{tabular} \\
\hline \begin{tabular}{l} 
Read/modify/write instructions at effective \\
address.
\end{tabular} & One read and two write cycles. & Two read and one write cycle. \\
\hline Decimal flag. & Indeterminate after reset. & \begin{tabular}{l} 
Initialized to binary mode ( \(\mathrm{D}=0\) ) after reset \\
and interrupts.
\end{tabular} \\
\hline Flags after decimal operation. & Invalid N, V and Z flags. & Valid flag adds one additional cycle. \\
\hline Interrupt after fetch of BRK instruction. & \begin{tabular}{l} 
Interrupt vector is loaded, BRK vector is \\
ignored.
\end{tabular} & BRK is executed, then interrupt is executed. \\
\hline
\end{tabular}

\section*{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 64 K bytes of addressable memory.

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

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

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

\section*{INDEXED ABSOLUTE INDIRECT [(ABS, X)]*}

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

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

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

The second byte of the instruction becomes the operand which is an "Offset" added to the contents of the lower eight bits of the program counter when the counter is set at the next instruction. The range of the offset is -128 to +127 bytes from the next instruction.
ZERO PAGE RELATIVE ADDRESSING [ZP REL]*-This mode bit tests the zero page location specified for bit set/reset per the mask and performs a conditional relative branch based on the results of the bit test.

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

INDIRECT INDEXED ADDRESSING [(IND), Y]—In indirect indexed addressing (referred to as (Indirect), Y), the second byte of the instruction points to a memory location in page zero. The contents of this memory location are added to the contents of the Y index register, the result being the low order eight bits of the effective address. The carry from this addition is added to the contents of the next page zero memory location, the result being the high order eight bits of the effective address.
ABSOLUTE INDIRECT [(ABS)]-The second byte of the instruction contains the low order eight bits of a memory location. The high order eight bits of that memory location are contained in the third byte of the instruction. The contents of the fully specified memory location are the low order byte of the effective address. The next memory location contains the high order byte of the effective address which is loaded into the sixteen bits of the program counter. (JMP (ABS) only.)

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

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

Table 4. Hexadecimal Codes For New Instructions in The CMOS Family
\begin{tabular}{|c|c|c|}
\hline Hex & Mnemonic & Description \\
\hline 80 & BRA & Branch relative always [Relative] \\
\hline 3A & DEC & Decrement accumulator [Accum] \\
\hline 1A & INC & Increment accumulator [Accum] \\
\hline DA & PHX & Push X on stack [Implied] \\
\hline 5A & PHY & Push Y on stack [Implied] \\
\hline FA & PLX & Pull X from stack [Implied] \\
\hline 7A & PLY & Pull Y from stack [limplied] \\
\hline 9 C & STZ & Store zero [Absolute] \\
\hline 9 E & STZ & Store zero [ABS, X] \\
\hline 64 & STZ & Store zero [ZP] \\
\hline 74 & STZ & Store zero [ZP, X] \\
\hline 1 C & TRB & Test and reset memory bits with accumulator [ABS] \\
\hline 14 & TRB & Test and reset memory bits with accumulator [ZP] \\
\hline OC & TSB & Test and set memory bits with accumulator [ABS] \\
\hline 04 & TSB & Test and set memory bits with accumulator [ZP] \\
\hline 89 & BIT & Test Immediate with accumulator [IMM] \\
\hline 0F-7F \({ }^{(1)}\) & BBR & Branch on bit reset [Bit Manipulation, ZP, REL] \\
\hline \(8 \mathrm{~F}-\mathrm{FF}^{(1)}\) & BBS & Branch on bit set [Bit Manipulation, ZP, REL] \\
\hline 07-77 \({ }^{(1)}\) & RMB & Reset memory bit [Bit Manipulation, ZP] \\
\hline \(87-7^{(1)}\) & SMB & Set memory bit [Bit Manipulation, ZP] \\
\hline \multicolumn{3}{|l|}{\begin{tabular}{l}
Note: \\
1. Most significant digit change only.
\end{tabular}} \\
\hline
\end{tabular}

Table 5. Hexadecimal Codes For Instructions With New CMOS Addressing Modes
\begin{tabular}{|c|c|c|}
\hline Hex & Mnemonic & Description \\
\hline 72 & ADC & Add memory to accumulator with carry [(IND)] \\
\hline 32 & AND & AND memory with accumulator [(IND)] \\
\hline 3 C & BIT & Test memory bits with accumulator [ABS, X] \\
\hline 34 & BIT & Test memory bits with accumulator [ZP, X] \\
\hline D2 & CMP & Compare memory and accumulator [(IND)] \\
\hline 52 & EOR & Exclusive Or memory with accumulator [(IND)] \\
\hline 7 C & JMP & Jump (New addressing mode) [(ABS, X)] \\
\hline B2 & LDA & Load accumulator with memory [(IND)] \\
\hline 12 & ORA & OR memory with accumulator [(IND)] \\
\hline F2 & SBC & Subtract Memory from accumulator with borrow [(IND)] \\
\hline 92 & STA & Store accumulator in memory [(IND)] \\
\hline
\end{tabular}

\section*{INSTRUCTION SET OP CODE MATRIX}

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



\section*{AC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multicolumn{2}{|c|}{3 MHz} & \multicolumn{2}{|c|}{4 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min & Max & Min & Max & Min & Max & Min & Max & \\
\hline
\end{tabular}

\section*{CLOCK TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline 02 Cycle Time & \(\mathrm{t}_{\mathrm{CYC}}\) & 1000 & Note 1 & 500 & Note 1 & 333 & Note 1 & 250 & Note 1 & ns \\
\hline 02 Low Pulse Width & \(\mathrm{t}_{\mathrm{CL}}\) & 430 & 5000 & 210 & 5000 & 150 & 5000 & 100 & 5000 & ns \\
\hline ¢2 High Pulse Width & \(\mathrm{t}_{\mathrm{CH}}\) & 450 & - & 220 & - & 160 & - & 110 & - & ns \\
\hline \(\emptyset 0\) Low to \(\emptyset 2\) Low Skew \({ }^{(2)}\) & \(t_{\text {DLY }}\) & - & 50 & - & 50 & & 40 & - & 30 & ns \\
\hline \(\emptyset 2\) Low to \(\emptyset 1\) High Skew \({ }^{(3)}\) & \(\mathrm{t}_{\text {DLY }}\) & -20 & 20 & -20 & 20 & -20 & 20 & -20 & 20 & ns \\
\hline XTLI High to \(\emptyset 2\) Low \({ }^{(4)}\) & \(t_{\text {DXI }}\) & - & 100 & - & 100 & - & 100 & - & 100 & ns \\
\hline XTLO Low to \(\emptyset 2\) Low \({ }^{(4)}\) & \(\mathrm{t}_{\mathrm{DxO}}\) & - & 75 & - & 75 & - & 75 & - & 75 & ns \\
\hline \(\emptyset 2\) Low to \(\emptyset 4\) High Delay \({ }^{(4)}\) & \(\mathrm{t}_{\text {Avs }}\) & 250 & - & 125 & - & 85 & - & 65 & ns & \\
\hline \(\emptyset 4\) Low Pulse Width \({ }^{(4)}\) & \(t_{\text {¢4L }}\) & 430 & - & 210 & - & 150 & - & 100 & - & ns \\
\hline 04 High Pulse Width \({ }^{(4)}\) & \(t_{\text {¢ }}{ }_{\text {a }}\) & 450 & 5000 & 220 & 5000 & 160 & 5000 & 110 & 5000 & ns \\
\hline Clock Rise and Fall Times & \(t_{R}, t_{F}\) & - & 25 & - & 20 & - & 15 & - & 12 & ns \\
\hline
\end{tabular}

READ/WRITE TIMING
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline R/W Setup Time & \(t_{\text {RWS }}\) & - & 125 & - & 100 & - & 75 & - & 60 & ns \\
\hline R/ \(\bar{W}\) Hold Time & \(t_{\text {HRW }}\) & 15 & - & 15 & - & 15 & - & 15 & - & ns \\
\hline Address Setup Time & \(\mathrm{t}_{\text {ADS }}\) & - & 125 & - & 100 & - & 85 & - & 70 & ns \\
\hline Address Valid to \(\emptyset 4 \mathrm{High}^{(4)}\) & \(t_{\text {A } 04}\) & 100 & - & 25 & - & 10 & - & 0 & - & ns \\
\hline Address Hold Time & \(t_{H A}\) & 15 & - & 15 & - & 15 & - & 15 & - & ns \\
\hline Read Access Time & \(\mathrm{t}_{\text {ACC }}\) & 775 & - & 340 & - & 215 & - & 160 & - & ns \\
\hline Read Data Setup Time & \(\mathrm{t}_{\text {DSU }}\) & 100 & - & 60 & - & 40 & - & 30 & - & ns \\
\hline Read Data Hold Time & \(t_{\text {HR }}\) & 10 & - & 10 & - & 10 & - & 10 & - & ns \\
\hline Write Data Delay Time \({ }^{(2)}\) & \(t_{\text {WDS }}\) & - & 200 & - & 110 & - & 85 & - & 55 & ns \\
\hline Write Data Delay Time \({ }^{(4)}\) & \(t_{\text {DDW }}\) & - & 200 & - & 110 & - & 85 & - & 55 & ns \\
\hline Write Data Delay Time \({ }^{(6)}\) & \(t_{\text {DD12 }}\) & - & 450 & - & 235 & - & 170 & - & 120 & ns \\
\hline Write Data Hold Time & \(\mathrm{t}_{\mathrm{HW}}\) & 30 & - & 30 & - & 30 & - & 30 & - & ns \\
\hline
\end{tabular}

\section*{CONTROL LINE TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline SYNC Delay & \(\mathrm{t}_{\mathrm{SYS}}\) & - & 125 & - & 100 & - & 85 & - & 70 & ns \\
\hline RDY Setup Time & \(\mathrm{t}_{\text {RDS }}\) & 200 & - & 110 & - & 80 & - & 60 & - & ns \\
\hline \(\overline{\mathrm{SO}}\) Setup Time & \(\mathrm{t}_{\text {SOS }}\) & 75 & - & 50 & - & 40 & - & 30 & - & ns \\
\hline ML Delay Time \({ }^{(5)}\) & \(\mathrm{t}_{\text {MLS }}\) & - & 125 & - & 100 & - & 75 & - & 60 & ns \\
\hline ML Hold Time \({ }^{(4)}\) & \(t_{\text {MLH }}\) & 10 & - & 10 & - & 10 & - & 10 & - & ns \\
\hline ML Hold Time \({ }^{(6)}\) & \(t_{\text {MLH }}\) & 15 & - & 15 & - & 15 & - & 15 & - & ns \\
\hline BE Delay Tıme \({ }^{(5)(9)}\) & \(\mathrm{t}_{\mathrm{BE}}\) & - & 40 & - & 40 & & 40 & & 40 & ns \\
\hline \(\overline{\mathrm{IRQ}}, \overline{\mathrm{RES}}\) Setup Time & \(\mathrm{t}_{\text {IS }}\) & 200 & - & 110 & - & 80 & - & 60 & - & ns \\
\hline \(\overline{\mathrm{NMI}}\) Setup Tıme & \(\mathrm{t}_{\text {NMI }}\) & 300 & - & 200 & - & 170 & - & 150 & - & ns \\
\hline
\end{tabular}

\section*{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.


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


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

Figure 5. Timing Diagram for Bus Enable (BE)

\section*{CLOCK/CRYSTAL CONSIDERATIONS}

A crystal controlled time base generator circuit should be used to drive \(\emptyset \mathrm{O}\) (IN) (R65C02) or the XTLI and XTLO (R65C102) inputs.

Figure 6 shows a time base generation scheme, for a 4 MHz operation of the R65C02, that has been tested and proven reliable for normal environments.

Figure 7 shows a possible external clock scheme for a R65C102 and R65C112 master/slave configuration. Table 6 identifies the typical values for external capacitors at various crystal frequencies.

\section*{NOTE}

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

Table 6 identifies nominal crystal parameters for five crystal frequencies.


Notes: 1. Crystal CTS Knight MP Series.
2. See STOPPING THE CLOCK CAUTION.

Figure 6. Example of R65C02 External Time Base Generator Circuit.


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

Table 6. Typical R65C102/R65C112 Master/Slave Clock Circuit Component Values
\begin{tabular}{|c|c|c|c|}
\hline \begin{tabular}{c} 
XTAL \\
FREQ \\
\((\mathbf{M H z})\)
\end{tabular} & \begin{tabular}{c}
\(\mathbf{C}_{\text {IN }}\) \\
\((\mathbf{p F})\)
\end{tabular} & \begin{tabular}{c}
\(\mathbf{C}_{\text {OUT }}\) \\
\((\mathbf{p F})\)
\end{tabular} & \begin{tabular}{c} 
02 \\
FREQ \\
\(\left.\mathbf{( M H}_{3}\right)\)
\end{tabular} \\
\hline 16.0 & 16 & 16 & 4 \\
\hline 8.0 & 18 & 18 & 2 \\
\hline 6.0 & 20 & 20 & 1.5 \\
\hline 4.0 & 24 & 24 & 1 \\
\hline
\end{tabular}

Table 7. Nominal Crystal Parameters
\begin{tabular}{|c|c|c|c|c|}
\hline \begin{tabular}{c} 
KTAL \\
FREQ \\
(MHz)
\end{tabular} & \begin{tabular}{c}
\(\mathbf{R}_{\mathbf{S}}\) \\
(ohms)
\end{tabular} & \begin{tabular}{c}
\(\mathbf{C}_{\mathbf{0}}\) \\
(pF)
\end{tabular} & \begin{tabular}{c}
\(\mathbf{C}_{\mathbf{1}}\) \\
(pF)
\end{tabular} & \begin{tabular}{c}
\(\mathbf{Q}\) \\
(K)
\end{tabular} \\
\hline 16.0 & \(10-30\) & \(3-5\) & \(0.01-0.02\) & 720 K \\
\hline 8.0 & \(20-40\) & \(4-6\) & \(0.01-0.02\) & 720 K \\
\hline 6.0 & \(30-50\) & \(4-6\) & \(001-0.02\) & 720 K \\
\hline 4.0 & 50 & 65 & 0025 & 730 K \\
\hline 3.58 & 60 & 3.5 & 0.015 & 740 K \\
\hline
\end{tabular}

Note: These represent cut crystal parameters only. Others may be used.

\section*{STOPPING THE CLOCK-STANDBY MODE}

Caution must be exercised when configuring the R65C02 or R65C112 in the standby mode (i.e., \(\emptyset 0\) IN or \(\emptyset 2 \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 8 shows a circuit that will stop the \(\emptyset 0\) IN (R65C02) or \(\emptyset 2\) IN R65C112) clock in the high state during standby mode.


Figure 8. Stopping the Clock (Standby Mode) Circuit

MAXIMUM RATINGS*
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & Vdc \\
\hline Output Voltage & \(\mathrm{V}_{\mathrm{OUT}}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
0 to +70 \\
-40 to +85
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{*Note}

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

\section*{OPERATING CONDITIONS}
\begin{tabular}{|c|c|c|}
\hline Parameter & Symbol & Value \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & \(5 \mathrm{~V} \pm 5 \%\) \\
\hline \begin{tabular}{c} 
Temperature Range \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \\
\(0^{\circ}\) to \(70^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{DC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max & Unit & Test Conditions \\
\hline ```
Input High Voltage
    All Other Input Pins
    \emptyset0 on R65C02
    02 on R65C112
``` & \(\mathrm{V}_{\mathrm{HH}}\) & \[
\begin{gathered}
2.0 \\
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 & \\
\hline \begin{tabular}{l}
Input Low Voltage \\
All Other Input Pins Ø0 on R65C02 02 on R65C112
\end{tabular} & \(\mathrm{V}_{\mathrm{IL}}\) & \[
\begin{aligned}
& -03 \\
& -0.3 \\
& -0.3
\end{aligned}
\] & & \[
\begin{aligned}
& +0.8 \\
& +0.4 \\
& +0.4
\end{aligned}
\] & V & \\
\hline Input Leakage Current \(\overline{\mathrm{NM}}, \overline{\mathrm{RQ}}, \mathrm{BE}, \mathrm{RDY}, \overline{\mathrm{RES}}, \overline{\mathrm{SO}}\) \(\emptyset 2 \mathrm{IN}, \emptyset 0 \mathrm{IN}, \mathrm{XTLI}\) & \(\mathrm{I}_{\mathrm{N}}\) & - & & \[
\begin{array}{r}
-50 \\
1.0
\end{array}
\] & \(\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}
\] \\
\hline Three-State (Off State) Input Current Data Lines & \({ }^{\text {TSSI }}\) & - & & 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}
\] \\
\hline \begin{tabular}{l}
Output High Voltage \\
SYNC, Data, A0-A15, R/ \(\bar{W}, \emptyset 1, \emptyset 2, ~ \emptyset 4, \overline{M L}\)
\end{tabular} & \(\mathrm{V}_{\mathrm{OH}}\) & 2.4 & & - & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A}
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Output Low Voltage \\
SYNC, Data, A0-A15, R/ \(\bar{W}, ~ \emptyset 1, ~ \emptyset 2, ~ \emptyset 4, \overline{M L}\)
\end{tabular} & - \(\mathrm{V}_{\mathrm{OL}}\) & - & & +0.4 & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}
\end{aligned}
\] \\
\hline Supply Current Standby \({ }^{4}\) Active (R65C02) Active (R65C102) Active (R65C112) Low Power (R65C02) Low Power (R65C102) Low Power (R65C112) & \(\mathrm{I}_{\mathrm{Cc}}\) & - & \[
\begin{aligned}
& 2 \\
& 2.6 \\
& 5 \\
& 2 \\
& 1.1 \\
& 3 \\
& 0.7
\end{aligned}
\] & \[
\begin{array}{r}
10 \\
4 \\
7 \\
4 \\
2 \\
4 \\
1
\end{array}
\] & \(\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}\) & \[
V_{C C}=5.0 \mathrm{~V}
\]
\[
\begin{aligned}
& \mathrm{RDY}=0 \\
& \mathrm{RDY}=0
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Capacitance \\
\(\overline{\mathrm{NMI}}, \overline{\mathrm{IRQ}}, \overline{\mathrm{SO}}, \mathrm{BE}\), RDY \\
Data, \(\emptyset 1, \emptyset 2, \emptyset 4, \overline{M L}, ~ X T L O\) \\
A0-A15, R \(\bar{W}\), SYNC \\
Ø0 (IN), XTLI \\
02 (IN)
\end{tabular} & \[
\begin{aligned}
& \mathrm{C} \\
& \mathrm{C}_{\mathrm{IN}} \\
& \mathrm{C}_{\mathrm{OUT}} \\
& \mathrm{C}_{0} \\
& \mathrm{C}_{2} \\
& \hline
\end{aligned}
\] &  & & \[
\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 \mathrm{MHz} \\
& T_{A}=25^{\circ} \mathrm{C}
\end{aligned}
\] \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. All units are direct current (dc). \\
2. Negative sign indicates outward current flow, positive indicates inward flow. \\
3. \(\overline{\mathrm{RQ}}\) and \(\overline{\mathrm{NMI}}\) require external pull-up resistor. \\
4. Typical values are shown for \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) and \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\)
\end{tabular}} \\
\hline
\end{tabular}

\section*{PACKAGE DIMENSIONS}

\section*{40-PIN CERAMIC DIP}


\section*{40-PIN PLASTIC DIP}

\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{DIM} & \multicolumn{2}{|l|}{MILLIMETERS} & \multicolumn{2}{|l|}{INCHES} \\
\hline & MIN & MAX & MIN & MAX \\
\hline A & 5128 & 5232 & 2040 & 2060 \\
\hline B & 1372 & 1422 & 0540 & 0560 \\
\hline C & 355 & 508 & 0140 & 0200 \\
\hline D & 036 & 051 & 0014 & 0020 \\
\hline F & 102 & 152 & 0040 & 0060 \\
\hline G & \multicolumn{2}{|r|}{254 BSC} & \multicolumn{2}{|l|}{0100 BSC} \\
\hline H & 165 & 216 & 0065 & 0085 \\
\hline \(J\) & 020 & 030 & 0008 & 0012 \\
\hline K & 305 & 356 & 0120 & 0140 \\
\hline L & \multicolumn{2}{|l|}{1524 BSC} & \multicolumn{2}{|l|}{0600 BSC} \\
\hline M & \(7^{\circ}\) & \(10^{\circ}\) & \(7{ }^{\circ}\) & \(10^{\circ}\) \\
\hline N & 051 & 102 & 0020 & 0040 \\
\hline
\end{tabular}

\section*{PRELIMINARY}

\section*{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 bidirectınal 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

\section*{ORDERING INFORMATION}

The R65C21 is available in both a ceramic and a plastic 40-pin package, a commercial or industrial operating temperature range, and operatıng frequencies of \(1,2,3\), or 4 MHz These versions are coded into the part number as follows:

Part Number:
R65C21


\section*{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
\begin{tabular}{|c|c|c|}
\hline VSS \(\square^{1}\) & 40 & \(\square \mathrm{CA1}\) \\
\hline PAO \(\square^{2}\) & 39 & CA2 \\
\hline PA1 3 & 38 & \(\square \overline{\text { IRQA }}\) \\
\hline PA2 54 & 37 & \(\square \overline{\text { IRQB }}\) \\
\hline PA3 5 & 36 & \(\square\) RSO \\
\hline PA4 6 & 35 & \(\square \mathrm{RS} 1\) \\
\hline PA5 7 & 34 & \(\square \overline{\text { RES }}\) \\
\hline PA6 8 & 33 & D Do \\
\hline PA7 9 & 32 & \(\square \mathrm{D} 1\) \\
\hline PB0 10 & 31 & \(\square \mathrm{D} 2\) \\
\hline PB1 11 & 30 & \(\square\) D3 \\
\hline PB2 12 & 29 & \(\square \mathrm{D} 4\) \\
\hline PB3 13 & 28 & D \({ }^{\text {D }}\) \\
\hline PB4 14 & 27 & D6 \\
\hline PB5 15 & 26 & D7 \\
\hline PB6 16 & 25 & \(\square \square^{\square}\) \\
\hline PB7 \({ }^{17}\) & 24 & \(\square \mathrm{CS} 1\) \\
\hline CB1 18 & 23 & \(\square \overline{\mathrm{CS2}}\) \\
\hline CB2-19 & 22 & \(\square \mathrm{CSO}\) \\
\hline vcc 20 & & \(\mathrm{R} / \overline{\mathrm{W}}\) \\
\hline
\end{tabular}

Figure 1. R65C21 Pin Configuration

\section*{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/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

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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 contan "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|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) \\
\hline IRQA1 & IRQA2 & & CA2 Control & \begin{tabular}{c} 
DDRA \\
Access
\end{tabular} & CA1 Control \\
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) \\
\hline IRQB1 & IRQB2 & & CB2 Control & \begin{tabular}{c} 
DDRB \\
Access
\end{tabular} & \(\mathbf{1}\) \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|}
\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.

\section*{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).

\section*{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.

\section*{CHIP SELECT (CS0, CS1, \(\overline{\mathbf{C S} 2)}\)}

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.

\section*{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.

\section*{CLOCK SIGNAL (ø2)}

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

\section*{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 / \bar{W}\) line permits the peripheral devices to transfer data to the CPU from the PIA. A low on the \(\mathrm{R} / \overline{\mathrm{W}}\) line allows data to be transfered from the CPU to the peripheral devices from the PIA.

\section*{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
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Register Address (Hex)} & \multicolumn{2}{|l|}{Register Select Lines} & \multicolumn{2}{|l|}{Data Direction Control} & \multicolumn{2}{|l|}{Register Operation} \\
\hline & RS1 & RSO & \[
\begin{aligned}
& \text { CRA } \\
& \text { (Bit 2) }
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { CRB } \\
\text { (Bit 2) }
\end{array}
\] & \(\mathrm{R} / \bar{W}=\mathrm{H}\) & \(\mathbf{R} / \bar{W}=L\) \\
\hline 0 & L & L & 1 & - & Read PIBA & Write ORA \\
\hline 0 & L & L & 0 & - & Read DDRA & Write DDRA \\
\hline 1 & L & H & - & - & Read CRA & Write CRA \\
\hline 2 & H & L & - & 1 & Read PIBB & Write ORB \\
\hline 2 & H & L & - & 0 & Read DDRB & Write DDRB \\
\hline 3 & H & H & - & - & Read CRB & Write CRB \\
\hline
\end{tabular}

\section*{INTERRUPT REQUEST LINES ( \(\overline{(\mathrm{IQA}}, \overline{\mathrm{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{\operatorname{RQA}}\) can be disabled by setting bit 0 in CRA to a 0 . Likewise, CRA bit 6 (IRQA2) can be set by an active transition of the CA2 interrupt input signal and \(\overline{\text { IRQA }}\) can be disabled by setting bit 3 in CRA to a 0.

Both bit 6 and bit 7 in CRA are reset by a "Read Peripheral Output Register A" operation. This is defined as an operation in which the read/write, proper data direction register and register select signals are provided to allow the processor to read the Peripheral A I/O port. A summary of IRQA 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 \(\overline{\mathrm{RQB}}\) 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{\text { IRQA }}\) and \(\overline{\text { IRQB }}\) Control Summary
\begin{tabular}{|c|c|}
\hline Control Register Bits & Action \\
\hline CRA- \(7=1\) and CRA- \(0=1\) & \(\overline{\mathrm{RQA}}\) goes low (Active) \\
\hline CRA- \(6=1\) and CRA \(-3=1\) & \(\overline{\mathrm{RQA}}\) goes low (Active) \\
\hline CRB-7 \(=1\) and CRB- \(0=1\) & \(\overline{\mathrm{RQB}}\) goes low (Active) \\
\hline CRB- \(6=1\) and CRB-3 \(=1\) & \(\overline{\mathrm{RQB}}\) goes low (Active) \\
\hline \multicolumn{2}{|c|}{ Note: } \\
\hline
\end{tabular}

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.

\section*{INTERRUPT INPUT/PERIPHERAL CONTROL LINES (CA1, CA2, CB1, CB2)}

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

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

\section*{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\) )
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{2}{*}{\[
\begin{gathered}
\text { IRQA1 } \\
\text { FLAG }
\end{gathered}
\]} & \multirow[t]{2}{*}{IRQA2 FLAG} & \multirow[t]{2}{*}{CA2 INPUT
MODE SELECT
\((=0)\)} & IRQA2
POSITIVE
TRANSITION & \(\overline{\mathrm{IRQA}}\)
ENABLE
FOR IRQA2 & \multirow[t]{2}{*}{ORA SELECT} & \[
\begin{gathered}
\text { IRQA1 } \\
\text { POSITIVE } \\
\text { TRANSITION }
\end{gathered}
\] & \(\overline{\text { IRQA }}\)
ENABLE
FOR IRQA1 \\
\hline & & & \[
\begin{aligned}
& \text { IRQA } \\
& \text { CON }
\end{aligned}
\] & & & IRQA
CON & QA1
OL \\
\hline
\end{tabular}

CA2 OUTPUT MODE (BIT \(5=1\) )
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 43 & 2 & 1 & 0 \\
\hline \multirow[t]{2}{*}{\[
\begin{gathered}
\hline \text { IRQA1 } \\
\text { FLAG }
\end{gathered}
\]} & \multirow[t]{2}{*}{0} & \multirow[t]{2}{*}{CA2 OUTPUT MODE SELECT
\[
(=1)
\]} & \begin{tabular}{cc} 
CA2 & CA2 \\
OUTPUT & RESTORE \\
CONTROL & CONTROL
\end{tabular} & \multirow[t]{2}{*}{\[
\begin{gathered}
\text { ORA } \\
\text { SELECT }
\end{gathered}
\]} & \[
\begin{gathered}
\text { IRQA1 } \\
\text { POSITIVE } \\
\text { TRANSITION }
\end{gathered}
\] & \[
\begin{gathered}
\overline{\mathrm{IRQA}} \\
\text { ENABLE } \\
\text { FOR IRQA1 }
\end{gathered}
\] \\
\hline & & & CA2 CONTROL & & TRQA
CON & \\
\hline
\end{tabular}

CA2 INPUT OR OUTPUT MODE (BIT \(5=0\) or 1)
\begin{tabular}{|c|c|}
\hline Bit 7 & IRQA1 FLAG \\
\hline 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{\mathrm{RES}}\). \\
\hline 0 & No transition has occurred on CA1 that satisfies the bit 1 IRQA1 transition polarity criteria. \\
\hline Bit 2 & OUTPUT REGISTER A SELECT \\
\hline 1 & Select Output Register A. \\
\hline 0 & Select Data Direction Register A. \\
\hline Bit 1 & IRQA1 POSITIVE TRANSITION \\
\hline 1 & Set IRQA1 Flag (bit 7) on a positive (low-to-high) transition of CA1. \\
\hline 0 & Set IRQA1 Flag (bit 7) on a negative (high-to-low) transition of CA1. \\
\hline Bit 0 & IRQA ENABLE FOR IRQA1 \\
\hline 1 & Enable assertion of IRQA when IRQA1 Flag (bit 7) is set. \\
\hline 0 & Disable assertion of IRQA when IRQA1 Flag (bit 7) is set. \\
\hline
\end{tabular}

\section*{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.

Sit 3 IRQA ENABLE FOR IRQA2
1 Enable assertion of IRQA when IRQA2 Flag (bit 6) is set.
0 Disable assertion of \(\overline{\mathrm{IRQA}}\) when IRQA2 Flag (bit 6 ) is set.

\section*{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

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) \(\emptyset 2\) clock transition following a read of Output Register A. CA2 returns high as specified by bit 3 .

Bit 3 CA2 READ STROBE RESTORE CONTROL ( \(4=0\) )
1 CA2 returns high on the next \(\emptyset 2\) clock negative transition following a read of Output Register A.
- CA22 returns high on the next acive CA1 transition following a read of Output Register A as specified by bit 1 .

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

\section*{CONTROL REGISTER B (CRB)}

CB2 INPUT MODE (BIT \(5=0\) )
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{2}{*}{\[
\begin{aligned}
& \hline \text { IRQB1 } \\
& \text { FLAG }
\end{aligned}
\]} & \multirow[t]{2}{*}{\[
\begin{gathered}
\text { IRQB2 } \\
\text { FLAG }
\end{gathered}
\]} & \multirow[t]{2}{*}{CB2 INPUT
MODE SELECT
\((=0)\)} & \[
\begin{array}{|c|}
\hline \text { IRQB2 } \\
\text { POSITIVE } \\
\text { TRANSITION }
\end{array}
\] & \(\overline{\mathrm{IRQB}}\)
ENABLE
FOR IRQB2 & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { ORB } \\
& \text { SELECT }
\end{aligned}
\]} & IRQB1
POSITIVE
TRANSITION & \(\overline{\mathrm{TRQB}}\)
ENABLE
FOR IRQB1 \\
\hline & & & \multicolumn{2}{|c|}{\(\overline{\mathrm{IRQB}} / / \mathrm{RQB} 2\) CONTROL} & & \multicolumn{2}{|c|}{\(\overline{\text { IRQB } / / R Q B 1 ~}\) CONTROL} \\
\hline
\end{tabular}

\section*{CB2 OUTPUT MODE (BIT 5 = 1)}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{2}{*}{IRQB1 FLAG} & \multirow[t]{2}{*}{0} & \multirow[t]{2}{*}{CB2 OUTPUT MODE SELECT (=1)} & CB2 OUTPUT CONTROL & CB2 RESTORE CONTROL & \multirow[t]{2}{*}{ORB SELECT} & IRQB1
POSITIVE
TRANSITION & \(\overline{\mathrm{IRQB}}\)
ENABLE
FOR IRQB1 \\
\hline & & & \multicolumn{2}{|c|}{\[
\begin{gathered}
\text { CB2 } \\
\text { CONTROL }
\end{gathered}
\]} & & \multicolumn{2}{|c|}{\(\overline{\mathrm{RQB}} / / \mathrm{RQB} 1\) CONTROL} \\
\hline
\end{tabular}

\section*{CB2 INPUT OR OUTPUT MODE (BIT 5 = 0 or 1)}
```

Bit }7\mathrm{ 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{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 /RQB when IRQB1 Flag (bit 7) is set.
0 Disable assertion of \overline{IRQB}}\mathrm{ 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 }
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{RQB}\mathrm{ when IRQB2 Flag (bit 6) is
set.
0 Disable assertion of }\overline{\textrm{IRQB}}\mathrm{ when IRQB2 Flag (bit 6) is
set.

```

CB2 OUTPUT MODE (BIT 5 = 1)
```

Bit }6\mathrm{ 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) 02
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 \emptyset2 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.

\section*{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 regıster 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.

\section*{READING THE PERIPHERAL B I/O PORT}

Readıng the Perıpheral B I/O port yields a combination of input and output data in a manner similar to the Perıpheral 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

\section*{BUS TIMING CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multicolumn{2}{|c|}{3 MHz} & \multicolumn{2}{|c|}{4 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min. & Max. & Min. & Max. & Min. & Max. & Min. & Max. & \\
\hline 02 Cycle & \(\mathrm{t}_{\mathrm{cyc}}\) & 1.0 & - & 0.5 & - & 0.33 & - & 0.25 & - & \(\mu \mathrm{S}\) \\
\hline 02 Pulse Width & \(t_{c}\) & 450 & - & 220 & - & 160 & - & 110 & - & ns \\
\hline 02 Rise and Fall Time & \(t_{\text {rc }}, \mathrm{t}_{\text {cc }}\) & - & 25 & - & 15 & - & 12 & - & 10 & ns \\
\hline
\end{tabular}

\section*{READ TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline Address Set-Up Time & \(t_{\text {ACR }}\) & 140 & - & 70 & - & 53 & - & 35 & - & ns \\
\hline Address Hold Time & \(t_{\text {car }}\) & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline Peripheral Data Set-Up Time & \(t_{\text {PCR }}\) & 300 & - & 150 & - & 110 & - & 75 & - & ns \\
\hline Data Bus Delay Time & \(t_{\text {cDR }}\) & - & 335 & - & 145 & - & 105 & - & 80 & ns \\
\hline Data Bus Hold Time & \(t_{\text {HR }}\) & 20 & - & 20 & - & 20 & - & 20 & - & ns \\
\hline
\end{tabular}

\section*{WRITE TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline Address Set-Up Time & \(t_{\text {ACW }}\) & 140 & - & 70 & - & 53 & - & 35 & - & ns \\
\hline Address Hold Time & \(t_{\text {caw }}\) & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline R/WW Set-Up Time & \(t_{\text {wCW }}\) & 180 & - & 90 & - & 67 & - & 45 & - & ns \\
\hline R/W Hold Time & toww & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline Data Bus Set-Up Time & \(t_{\text {dCW }}\) & 180 & - & 90 & - & 67 & - & 45 & - & ns \\
\hline Data Bus Hold Time & \(\mathrm{t}_{\mathrm{HW}}\) & 10 & - & 10 & - & 10 & - & 10 & - & ns \\
\hline Peripheral Data Delay Time & \(t_{\text {cPW }}\) & - & 1.0 & - & 0.5 & - & 0.33 & - & 0.25 & \(\mu \mathrm{S}\) \\
\hline Peripheral Data Delay Time to CMOS Level & \(\mathrm{t}_{\text {CMOS }}\) & - & 2.0 & - & 1.0 & - & 0.7 & - & 0.5 & \(\mu \mathrm{S}\) \\
\hline
\end{tabular}

\section*{PERIPHERAL INTERFACE TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline Peripheral Data Set-Up & \(t_{\text {PCR }}\) & 300 & - & 150 & - & 110 & - & 75 & - & ns \\
\hline ¢2 Low to CA2 Low Delay & \(t_{\text {CA2 }}\) & - & 1.0 & - & 0.5 & - & 0.33 & - & 0.25 & \(\mu \mathrm{S}\) \\
\hline 02 Low to CA2 High Delay & \(t_{\text {RS1 }}\) & - & 1.0 & - & 0.5 & - & 0.33 & - & 0.25 & \(\mu \mathrm{S}\) \\
\hline CA1 Active to CA2 High Delay & \(\mathrm{t}_{\text {RS2 }}\) & - & 2.0 & - & 1.0 & - & 0.67 & - & 0.5 & \(\mu \mathrm{S}\) \\
\hline 02 High to CB2 Low Delay & \({ }^{\text {che }}\) & - & 1.0 & - & 0.5 & - & 0.33 & - & 0.25 & \(\mu \mathrm{S}\) \\
\hline 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}\) \\
\hline 02 High to CB2 High Delay & \(\mathrm{t}_{\text {RS } 1}\) & - & 1.0 & - & 0.5 & - & 0.33 & - & 0.25 & \(\mu \mathrm{S}\) \\
\hline CB1 Active to CB2 High Delay & \(\mathrm{t}_{\text {RS2 }}\) & - & 2.0 & - & 1.0 & - & 0.67 & - & 0.5 & \(\mu \mathrm{S}\) \\
\hline CA1, CA2, CB1 and CB2 Input Rise and Fall Time & \(t_{r}, t_{4}\) & - & 1.0 & - & 1.0 & - & 1.0 & - & 1.0 & \(\mu \mathrm{S}\) \\
\hline
\end{tabular}

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|l|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & \multicolumn{1}{c|}{ Value } & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\text {IN }}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & Vdc \\
\hline Output Voltage & \(\mathrm{V}_{\mathrm{OUT}}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & \(\mathrm{Vdc}^{\circ}\) \\
\hline \begin{tabular}{l} 
Operating Temperature Range \\
Commercial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
0 to +70 \\
Industrial
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -50 to +85 & \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{OPERATING CONDITIONS}
\begin{tabular}{|c|c|c|}
\hline Parameter & Symbol & Value \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & \(5 \mathrm{~V} \pm 5 \%\) \\
\hline Temperature Range & \(\mathrm{T}_{\mathrm{A}}\) & \\
\begin{tabular}{c} 
Commercial \\
Industrial
\end{tabular} & & \begin{tabular}{c}
\(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
\(-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\)
\end{tabular} \\
\hline
\end{tabular}

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.\) to \(T_{H}\), unless otherwise noted)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min. & Typ. \({ }^{3}\) & Max. & Unit \({ }^{2}\) & Test Conditions \\
\hline Input High Voltage All except PB0-PB7, \(\overline{\text { RES }}\) PB0-PB7, \(\overline{\text { RES }}\) & \(\mathrm{V}_{\mathrm{H}}\) & \[
\begin{aligned}
& +2.0 \\
& +2.4 \\
& \hline
\end{aligned}
\] & - & \[
\begin{aligned}
& V_{C C} \\
& V_{C C}
\end{aligned}
\] & \[
\begin{aligned}
& \text { v } \\
& \text { v }
\end{aligned}
\] & \\
\hline Input Low Voltage & \(\mathrm{V}_{\mathrm{IL}}\) & -0.3 & - & +0.8 & V & \\
\hline Input Leakage Current R/W, \(\overline{\text { RES }}, \mathrm{RSO}, \mathrm{RS} 1, \mathrm{CSO}, \mathrm{CS} 1, \overline{\mathrm{CS} 2}, \mathrm{CA} 1\), CB1, \(0_{2}\) & \(\mathrm{I}_{\mathrm{N}}\) & - & \(\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}
\] \\
\hline Input 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}
\] \\
\hline Input High Current PA0-PA7, CA2 & \(\mathrm{I}_{\mathrm{H}}\) & -200 & -300 & - & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}\) \\
\hline Input Low Current PA0-PA7, CA2 & IIL & - & -2 & -3.2 & mA & \(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage Logic PB0-PB7, CB2 (Darlington Drive) & \(\mathrm{V}_{\mathrm{OH}}\) & \[
\begin{aligned}
& 2.4 \\
& 1.5
\end{aligned}
\] & - & - & & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{C}_{\text {LOAD }}=-200 \mu \mathrm{~A} \\
& \mathrm{~L}_{\text {LOAD }}=-3.2 \mathrm{~mA}
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { Output Low Voltage } \\
& \text { PAO-PA7, CA2, PB0-PB7, CB2 } \\
& \text { D0-D7, IRQA, IRQB }
\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}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \\
& \hline
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Output High Current (Sourcing Logic \\
PB0-PB7, CB2 (Darlington Drive)
\end{tabular} & \({ }^{1} \mathrm{OH}\) & \[
\begin{aligned}
& -200 \\
& -3.2
\end{aligned}
\] & \[
\begin{gathered}
-1500 \\
-6
\end{gathered}
\] & - & \[
\begin{aligned}
& { }_{\mathrm{mA}}^{\mathrm{A}}
\end{aligned}
\] & \[
\begin{aligned}
\mathrm{V}_{\mathrm{OH}} & =2.4 \mathrm{~V} \\
\mathrm{~V}_{\mathrm{OH}} & =1.5 \mathrm{~V}
\end{aligned}
\] \\
\hline Output Low Current (Sinking) PAO-PA7, PB0-PB7, CB2, CA2 DO-D7, \(\overline{\mathrm{IRQA}}, \overline{\mathrm{IRQB}}\) & \({ }_{102}\) & \[
\begin{aligned}
& 3.2 \\
& 1.6
\end{aligned}
\] & - & - & \[
\begin{aligned}
& \mathrm{mA} \\
& \mathrm{~mA}
\end{aligned}
\] & \(\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}\) \\
\hline Output Leakage Current (Off State) IRQA, IRQB & loff & - & 1 & \(\pm 10\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& V_{\mathrm{OH}}=2.4 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Power Dissipation & \(\mathrm{P}_{\mathrm{D}}\) & & 7 & 10 & & \(\mathrm{mW} / \mathrm{MHz}\) \\
\hline Input Capacitance D0-D7, PAO-PA7, PB0-PB7, CA2, CB2 R/W, \(\overline{\text { RES }}\), RSO, RS1, CS0, CS1, 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} \\
& f^{2}=2 \mathrm{MHz} \\
& T_{A}=25^{\circ} \mathrm{C}
\end{aligned}
\] \\
\hline Output Capacitance & \(\mathrm{C}_{\text {OUt }}\) & - & - & 10 & pF & \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. All units are direct current (dc) except capacitance. \\
2. Negative sign indicates outward current flow, positive indicates inward flow. \\
3. Typical values are shown for \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) and \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\).
\end{tabular}} \\
\hline
\end{tabular}

\section*{PACKAGE DIMENSIONS}

\section*{40-PIN CERAMIC DIP}

\begin{tabular}{|l|c|c|c|c|c|}
\hline & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{|c|}{ INCHES } \\
\cline { 2 - 5 } DIM & \multicolumn{1}{|c|}{ MIN } & MAX & MIN & MAX \\
\hline A & 5029 & 5131 & 1980 & 2020 \\
\hline B & 1486 & 1562 & 0585 & 0615 \\
\hline C & 254 & 419 & 0100 & 0165 \\
\hline D & 038 & 053 & 0015 & 0021 \\
\hline F & 076 & 140 & 0030 & 0055 \\
\hline G & 254 BSC & \multicolumn{2}{|c|}{0100 BSC } \\
\hline H & 076 & 178 & 0030 & 0070 \\
\hline J & 020 & 033 & 0008 & 0013 \\
\hline K & 254 & 419 & 0100 & 0165 \\
\hline L & 1460 & 1537 & 0575 & 0605 \\
\hline M & 0 & \(10^{\circ}\) & \(0^{\circ}\) & 10 \\
\hline N & 051 & 152 & 0020 & 0060 \\
\hline
\end{tabular}

\section*{40-PIN PLASTIC DIP}

\begin{tabular}{|l|c|c|c|c|c|}
\hline & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } DIM & MIN & MAX & MIN & MAX \\
\hline A & 5128 & 5232 & 2040 & 2060 \\
\hline B & 1372 & 1422 & 0540 & 0560 \\
\hline C & 355 & 508 & 0140 & 0200 \\
\hline D & 036 & 051 & 0014 & 0020 \\
\hline F & 102 & 152 & 0040 & 0060 \\
\hline G & 254 & BSC & \multicolumn{2}{|c|}{0100} & BSC \\
\hline H & 165 & 216 & 0065 & 0085 \\
\hline J & 020 & 030 & 0008 & 0012 \\
\hline K & 305 & 356 & 0120 & 0140 \\
\hline L & 1524 BSC & 0600 BSC \\
\hline M & 7 & 10 & \multicolumn{2}{|c|}{7} & 10 \\
\hline N & 051 & 102 & 0020 & 0040 \\
\hline
\end{tabular}

\section*{R65C22 \\ VERSATILE INTERFACE ADAPTER (VIA)}

\section*{PRELIMINARY}

\section*{DESCRIPTION}

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

The R65C22 includes functions for programmed control of up to two peripheral devices (Ports A and B). These two program controlled 8-bit bidirectional peripheral I/O ports allow direct interfacing between the microprocessor and selected peripheral units. Each port has input data latching capability. Two programmable Data Direction Registers (A and B) allow selection of data direction (input or output) on an individual line basis. The R65C22 also has two programmable 16-bit Interval Timer/Counters with latches. Timer 1 may be operated in a One-Shot Interrupt Mode with interrupts on each count-to-zero, or in a Free-Run Mode with a continuous series of evenly spaced interrupts. Timer 2 functions as both an interval and pulse counter. Serial data transfers are provided by a serial-to-parallel/parallel-to-serial shift register. Application versatility is further increased by various control registers, including-the Interrupt Flag Register, the Interrupt Enable Register, the Auxiliary Control Register and the Peripheral Control Register.

\section*{ORDERING INFORMATION}


\section*{FEATURES}
- Low power CMOS N -well silicon gate technology
- Fully compatible with NMOS 6522 devices
- Two 8-bit bidirectional I/O ports
- Two 16-bit programmable timer/counters
- Serial bidirectional peripheral I/O
- TTL compatible peripheral control lines
- Expanded "handshake" capability allows positive control of data transfers between processor and peripheral devices.
- Latched output and input registers on both I/O ports
- 1, 2, 3, and 4 MHz operation
- Single +5 V power supply
- 40-pin ceramic or plastic DIP


R65C22 Pin Configuration

\section*{INTERFACE SIGNALS}

Figure 1 shows the relationship of R65C22 interface signals to the microprocessor and peripheral devices.

\section*{RESET ( \(\overline{\text { RES }}\) )}

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

\section*{INPUT CLOCK (PHASE 2)}

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

\section*{READ/WRITE (R/W)}

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

\section*{DATA BUS (D0-D7)}

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

\section*{CHIP SELECTS (CS1, \(\overline{\mathbf{C S 2}}\) )}

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

\section*{REGISTER SELECTS (RSO-RS3)}

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

\section*{INTERRUPT REQUEST ( \(\overline{\text { IRQ }}\) )}

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

\section*{PERIPHERAL PORT A (PAO-PA7)}

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


Figure 1. R65C22 VIA Interface Signals

\section*{PORT A CONTROL LINES (CA1, CA2)}

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

\section*{PORT B (PB0-PB7)}

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

\section*{PORT B CONTROL LINES (CB1, CB2)}

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

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


Figure 2. Port A Output Circuit


Figure 3. Port B Output Circuit

\section*{FUNCTIONA}

The internal org.
Figure 4.
VIA is illustrated in

\section*{PORT A AND}

The R65C22 VIAr. \(\quad, \quad, \quad 1 / O\) ports (Port A and Port B) and each d control lines.

Each 8-bit periphe DDRB) for specify: inputs or outputs. . causes the corresp causes the pin to

Each peripheral pt: ... .. . כy a bit in the Output Register (ORA, OF the pin is prograr: controlled by the cor in the Output Registe, . Ie output to go high, and a " 0 ' causes the output to go Iow. 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 selected by the Auxiliary Control Register are shown in Figure 14.


Figure 4. R65C22 VIA Block Diagram

\section*{HANDSHAKE CONTROL OF DATA TRANSFERS}

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

\section*{Read Handshake}

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


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


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

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


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


Figure 8. Data Direction Register A (DDRA)


Figure 9. Read Handshake Timing (Port A Only)

\section*{Write Handshake}

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

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

\section*{COUNTER/TIMERS}

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

\section*{Timer 1 Operation}

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

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

REG 6-TIMER 1 LOW-ORDER LATCH


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

REG 7-TIMER 1 HIGH-ORDER LATCH


WRITE - 8 BITS LOADED INTO T1 HIGH-ORDER LATCHES UNLIKE REG 4 OPERATION NO LATCH-TO-COUNTER TRANSFERS TAKE PLACE
READ - 8 BITS FROM T1 HIGH-ORDER LATCHES TRANSFERRED TO MPU

Figure 12. Timer 1 (T1) Latch Registers

REG 4-TIMER 1 LOW-ORDER COUNTER


WRITE - 8 BITS LOADED INTO T1 LOW-ORDER LATCHES LATCH CONTENTS ARE TRANSFERRED INTO LOW-ORDER ORDER COUNTER IS LOADED (REG 5)
READ - 8 BITS FROM T1 LOW-ORDER COUNTER RANSFERRED TO MPU IN ADDITION 1 INTERRUPT FLAG IS RESET (BI N INTERRUPT FLAG REGISTER)

REG 5-TIMER 1 HIGH-ORDER COUNTER


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

Figure 13. Timer 1 (T1) Counter Registers

REG 11-AUXILIARY CONTROL REGISTER


Figure 14. Auxiliary Control Register (ACR)

\section*{Timer 1 One-Shot Mode}

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

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

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


Figure 15. Timer 1 One-Shot Mode Timing

\section*{Timer 1 Free-Run Mode}

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

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

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

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


Figure 16. Timer 1 Free-Run Mode Timing

\section*{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.

\section*{Timer 2 One-Shot Mode}

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

\section*{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 \(\emptyset 2\).

REG 8-TIMER 2 LOW-ORDER LATCH/COUNTER


WRITE - 8 BITS LOADED INTO T2 LOW ORDER LATCH

READ - 8 BITS FROM T2 LOW ORDER COUNTER
TRANSFERRED TO MPU T2 INTERRUPT
FLAG IS RESET

REG 9-TIMER 2 HIGH-ORDER LATCH/COUNTER


WRITE - 8 BITS LOADED INTO T? HIGH ORDER
COUNTER ALSO, LOW ORDER LATCH
TRANSFERRED TO LOW ORDER
COUNTER IN ADDITION, T2 INTERRUPT FLAG IS RESET

READ - 8 BITS FROM T2 HIGH ORDER COUNTER
TRANSFERRED TO MPU

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


Figure 18. Timer 2 One-Shot Mode Timing


Figure 19. Timer 2 Pulse Counting Mode

\section*{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.

\section*{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 ).

\section*{SR Mode 1 - Shift In Under Control of T2}

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


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

The shifting operation is triggered by the read or write of the SR if the SR flag is set in the IFR. Otherwise the first shift will occur at the next time-out of T2 after a read or write of the SR. 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 CB1 clock pulse. This data is shifted into the shift register during the \(\emptyset 2\) clock cycle following the positive-going edge of the CB1 clock pulse. After 8 CB1 clock pulses, the shift register interrupt flag will set and \(\overline{\mathrm{IRQ}}\) will go low.

\section*{SR Mode 2 - Shift In Under 02 Control}

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


Figure 21. Shift Register Modes


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

\section*{SR Mode 3 - Shift in Under CB1 Control}

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

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

SR Mode 4 - Shift Out Under T2 Control (Free-Run) Mode 4 is very similar to mode 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.

\section*{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 Under 02 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 02 Control
In mode 6, the shift rate is controlled by the \(\emptyset 2\) system clock (Figure 27).

\section*{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 \(\mathbf{5}\) - Shift Out Under T2 Control


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


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

\section*{Interrupt Operation}

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

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

\section*{Interrupt Flag Register (IRF)}

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

The Interrupt Flag Register (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 applied to the chip, the contents of this register are placed on the data bus. Bit 7 indicates the status of the \(\overline{\mathrm{IRQ}}\) output. This bit corresponds to the logic


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

\section*{Note:}
\[
x=\operatorname{logic} A N D,+=\text { Logic OR. }
\]

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

\section*{Interrupt Enable Register (IER)}

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

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

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

REG 14-INTERRUPT ENABLE REGISTER


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

Figure 30. Interrupt Enable Register (IER)

\section*{PERIPHERAL INTERFACE CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|}
\hline Symbol & Characteristic & Min. & Max. & Unit & Figure \\
\hline \(t_{r}, t_{f}\) & Rise and Fall Time for CA1, CB1, CA2 and CB2 Input Signals & - & 1.0 & \(\mu \mathrm{s}\) & - \\
\hline \(\mathrm{t}_{\text {cA2 }}\) & Delay Time, Clock Negative Transition to CA2 Negative Transition (read handshake or pulse mode) & - & 1.0 & \(\mu \mathrm{S}\) & 31a, 31b \\
\hline \(\mathrm{t}_{\text {RS } 1}\) & Delay Time, Clock Negative Transition to CA2 Positive Transition (pulse mode) & - & 1.0 & \(\mu \mathrm{s}\) & 31a \\
\hline \(\mathrm{t}_{\text {RS2 }}\) & Delay Time, CA1 Active Transition to CA2 Positive Transition (handshake mode) & - & 2.0 & \(\mu \mathrm{s}\) & 31b \\
\hline \({ }^{\text {twhs }}\) & Delay Time, Clock Positive Transition to CA2 or CB2 Negative Transition (write handshake) & 0.05 & 1.0 & \(\mu \mathrm{S}\) & 31c, 31d \\
\hline \(t_{\text {ds }}\) & Delay Time, Periphral Data Valid to CB2 Negative Transition & 0.20 & 1.5 & \(\mu \mathrm{s}\) & 31c, 31d \\
\hline \(\mathrm{t}_{\text {RS3 }}\) & Delay Time, Clock Positive Transition to CA2 or CB2 Positive Transition (pulse mode) & - & 1.0 & \(\mu \mathrm{S}\) & 31 c \\
\hline \(\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 \\
\hline \(\mathrm{t}_{21}\) & Delay Time Required from CA2 Output to CA1 Active Transition (handshake mode) & 400 & - & ns & 31d \\
\hline \(t_{\text {lL }}\) & Setup Time, Peripheral Data Valid to CA1 or CB1 Active Transition (input latching) & 300 & - & ns & 319 \\
\hline \(t_{\text {AL }}\) & CA1, CB1 Setup Prior to Transition to Arm Latch & 300 & - & ns & 319 \\
\hline \(t_{\text {PDH }}\) & Peripheral Data Hold After CA1, CB1 Transition & 150 & - & ns & 319 \\
\hline \(\mathrm{t}_{\text {SR1 }}\) & Shitt-Out Delay Time - Time from \(\emptyset_{2}\) Falling Edge to CB2 Data Out & - & 300 & ns & 31 f \\
\hline \(\mathrm{t}_{\text {SR2 }}\) & Shift-In Setup Time - Time from CB2 Data In to \(\emptyset_{2}\) Rising Edge & 300 & - & ns & 31 g \\
\hline \(\mathrm{t}_{\text {SR } 3}\) & External Shift Clock (CB1) Setup Time Relative to \(\emptyset_{2}\) Trailing Edge & 100 & \(\mathrm{T}_{\mathrm{Cr}}\) & ns & 31 g \\
\hline \(\mathrm{t}_{\text {IPW }}\) & Pulse Width - PB6 Input Pulse & \(2 \times \mathrm{T}_{C Y}\) & - & & 311 \\
\hline \(\mathrm{t}_{\mathrm{ICW}}\) & Pulse Width - CB1 Input Clock & \(2 \times \mathrm{T}_{C Y}\) & - & & 31h \\
\hline \(\mathrm{t}_{\text {IPS }}\) & Pulse Spacing - PB6 Input Pulse & \(2 \times \mathrm{T}_{C Y}\) & - & & 31i \\
\hline \(\mathrm{t}_{\text {ICs }}\) & Pulse Spacing - CB1 Input Pulse & \(2 \times \mathrm{T}_{C Y}\) & - & & 31h \\
\hline
\end{tabular}

Notes:
1. \(\mathrm{V}_{\mathrm{Cc}}=5.0 \mathrm{Vdc} \pm 5 \%\)
2. \(T_{A}=T_{L}\) to \(T_{H}\)

PERIPHERAL INTERFACE WAVEFORMS


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


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


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


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


Figure 31e. Peripheral Data Input Latching Timing


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


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


Figure 31h. External Shift Clock Timing


Figure 31i. Pulse Count Input Timing

\section*{BUS TIMING CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline & & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multicolumn{2}{|c|}{3 MHz} & \multicolumn{2}{|c|}{4 MHz} & \\
\hline Parameter & Symbol & Min & Max & Min & Max & Min & Max & Min & Max & Unit \\
\hline Cycle Time & \(t_{C r}\) & 1000 & - & 500 & - & 330 & - & 250 & - & ns \\
\hline Phase 2 Pulse Width High & \(\mathrm{t}_{\text {PWH }}\) & 470 & - & 240 & - & 160 & - & 120 & - & ns \\
\hline Phase 2 Pulse Width Low & \(\mathrm{t}_{\text {PWL }}\) & 470 & - & 240 & - & 160 & - & 120 & - & ns \\
\hline Phase 2 Transition & \(t_{\text {R,F }}\) & - & 30 & - & 30 & - & 30 & - & 30 & ns \\
\hline
\end{tabular}

READ TIMING
\begin{tabular}{|l|c|c|c|c|c|c|c|c|c|c|}
\hline Select, \(\mathrm{R} \bar{W}\) Setup & \(\mathrm{t}_{\mathrm{ACR}}\) & 160 & - & 90 & - & 65 & - & 45 & - & ns \\
\hline Select, \(\mathrm{R} \bar{W}\) Hold & \(\mathrm{t}_{\mathrm{CAR}}\) & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline Data Bus Delay & \(\mathrm{t}_{\mathrm{CDR}}\) & - & 320 & - & 190 & - & 130 & - & 90 & ns \\
\hline Data Bus Hold & \(\mathrm{t}_{\mathrm{HR}}\) & 10 & - & 10 & - & 10 & - & 10 & - & ns \\
\hline Peripheral Data Setup & \(\mathrm{t}_{\mathrm{PCR}}\) & 300 & - & 150 & - & 110 & - & 75 & - & ns \\
\hline
\end{tabular}

WRITE TIMING
\begin{tabular}{|l|c|c|c|c|c|c|c|c|c|c|}
\hline Select \(R / \bar{W}\) Setup & \(\mathrm{t}_{\text {ACW }}\) & 160 & - & 90 & - & 65 & - & 45 & - & ns \\
\hline Select, \(\mathrm{R} \overline{/}\) Hold & \(\mathrm{t}_{\mathrm{CAW}}\) & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline Data Bus Setup & \(\mathrm{t}_{\mathrm{DCW}}\) & 195 & - & 90 & - & 65 & - & 45 & - & ns \\
\hline Data Bus Hold & \(\mathrm{t}_{\mathrm{HW}}\) & 10 & - & 10 & - & 10 & - & 10 & - & ns \\
\hline Peripheral Data Delay & \(\mathrm{t}_{\mathrm{CPW}}\) & - & 1000 & - & 500 & - & 330 & - & 250 & ns \\
\hline
\end{tabular}

\section*{Notes:}
1. \(\mathrm{V}_{\mathrm{Cc}}=5.0 \mathrm{Vdc} \pm 5 \%\)
2. \(T_{A}=T_{L}\) to \(T_{H}\)

\section*{bus timing waveforms}

\section*{Read Timing Waveforms}


Write Timing Waveforms


\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to -7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperatare \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{r}
0 to +70 \\
-40 to +85
\end{tabular} & \({ }^{\circ}{ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{OPERATING CONDITIONS}
\begin{tabular}{|c|c|c|}
\hline Parameter & Symbol & Value \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & \(5 \mathrm{~V} \pm 5 \%\) \\
\hline \begin{tabular}{c} 
Temperature Range \\
Commercial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{l}
\(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
\(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
\hline
\end{tabular} \\
\hline
\end{tabular}

\section*{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 \()\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min. & Typ. \({ }^{3}\) & Max. & Unit \({ }^{1}\) & Test Conditions \\
\hline Input High Voltage & \(\mathrm{V}_{1 \mathrm{H}}\) & +2.0 & - & \(\mathrm{V}_{\mathrm{cc}}\) & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\mathrm{IL}}\) & -0.3 & - & +0.8 & V & \\
\hline \begin{tabular}{l}
Input Leakage Current \\
R/ \(\bar{W}, \overline{R E S}, R S 0, R S 1, R S 2, R S 3, C S 1, \overline{C S 2}, C A 1, ~ \emptyset 2\)
\end{tabular} & \({ }^{\text {IN }}\) & - & \(\pm 1\) & \(\pm 2.5\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{1 \mathrm{~N}}=0 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{Cc}} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Input Leakage Current for Three-State Off D0-D07 & \(\mathrm{I}_{\text {TS }}\) & - & \(\pm 2\) & \(\pm 10\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\
& \mathrm{VCC}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Input High Current \\
PAO-PA7, CA2, PB0-PB7, CB1, CBS
\end{tabular} & \(\mathrm{I}_{\mathbf{H}}\) & -200 & -400 & - & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IN}}=2.4 \mathrm{~V}\) \\
\hline Input Low Current PA0-PA7, CA2, PB0-PB7, CB1, CB2 & IL & - & -2 & -3.2 & mA & \(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}\) \\
\hline \begin{tabular}{l}
Output High Voltage \\
All outputs \\
PB0-PB7, CB2 (Darlington Drive)
\end{tabular} & \(\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} \\
& \mathrm{I}_{\text {LOAD }}=200 \mu \mathrm{~A} \\
& \mathrm{I}_{\text {LOAD }}=-3.2 \mathrm{~mA}
\end{aligned}
\] \\
\hline Output Low Voltage & \(\mathrm{V}_{\text {OL }}\) & - & - & +0.4 & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\mathrm{LOAD}}=3.2 \mathrm{~mA} \\
& \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \\
& \hline
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Output High Current (Sourcing) Logic \\
PB0-PB7, CB2 (Darlington Drive)
\end{tabular} & \({ }^{1} \mathrm{OH}\) & \[
\begin{array}{r}
-200 \\
-3.2 \\
\hline
\end{array}
\] & \[
\begin{gathered}
-1500 \\
-6 \\
\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}
\] \\
\hline Output Low Current (Sinking) & \(\mathrm{l}_{\mathrm{OL}}\) & 3.2 & - & - & mA & \(\mathrm{V}_{\mathrm{OL}}=0.4\) \\
\hline Output Leakage Current (Off State) \(\overline{\text { IRQ }}\) & 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}
\] \\
\hline Power Dissipation & \(P_{\text {D }}\) & - & 7 & 10 & mW/MHz & \\
\hline ```
Input Capacitance
    R/\overline{W},\overline{RES}, RS0, RS1, RS2, RS3, CS1, \overline{CS2,}
    D0-D7, PA0-PA7, CA1, CA2, PB0-PB7
    CB1, CB2, \emptyset2
``` & \(\mathrm{C}_{\text {IN }}\) & - & - & \[
\begin{gathered}
10 \\
7 \\
20 \\
\hline
\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 \mathrm{MHz} \\
& \mathrm{~T}_{\mathrm{A}}=25 / \mathrm{C} \\
& \hline
\end{aligned}
\] \\
\hline Output Capacitance & \(\mathrm{C}_{\text {OUt }}\) & - & - & 10 & pF & \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
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}\).
\end{tabular}} \\
\hline
\end{tabular}

\section*{PACKAGE DIMENSIONS}

\section*{40-PIN CERAMIC DIP}

\begin{tabular}{|l|c|c|c|c|c|}
\hline & \multicolumn{3}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } DIM & MIN & MAX & MIN & MAX \\
\hline A & 5029 & 5131 & 1980 & 2020 \\
\hline B & 1486 & 1562 & 0585 & 0615 \\
\hline C & 254 & 419 & 0100 & 0165 \\
\hline D & 038 & 053 & 0015 & 0021 \\
\hline F & 076 & 140 & 0030 & 0055 \\
\hline G & 254 BSC & 0100 BSC \\
\hline H & 076 & 178 & 0030 & 0070 \\
\hline J & 020 & 033 & 0008 & 0013 \\
\hline K & 254 & 419 & 0100 & 0165 \\
\hline L & 1460 & 1537 & 0575 & 0.605 \\
\hline M & 0 & 10 & 0 & 10 \\
\hline N & 051 & 152 & 0020 & 0060 \\
\hline
\end{tabular}

40-PIN PLASTIC DIP

\begin{tabular}{|l|c|c|c|c|c|}
\hline & \multicolumn{3}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } DIM & MIN & MAX & MIN & MAX \\
\hline A & 5128 & 5232 & 2040 & 2060 \\
\hline B & 1372 & 1422 & 0540 & 0560 \\
\hline C & 355 & 508 & 0140 & 0200 \\
\hline D & 036 & 051 & 0014 & 0020 \\
\hline F & 102 & 152 & 0040 & 0060 \\
\hline G & \multicolumn{2}{|c|}{254} & BSC & \multicolumn{2}{|c|}{0100} \\
\hline\(H\) & 165 & 216 & 0065 & 0085 \\
\hline J & 020 & 030 & 0008 & 0012 \\
\hline K & 305 & 356 & 0120 & 0140 \\
\hline L & 1524 BSC & \multicolumn{2}{|c|}{0600} & BSC \\
\hline M & 7 & 10 & 7 & 10 \\
\hline N & \multicolumn{2}{|c|}{051} & 102 & 0020 & 0040 \\
\hline
\end{tabular}

\section*{R65C24 \\ PERIPHERAL INTERFACE ADAPTER/TIMER (PIAT)}

\section*{PRELIMINARY}

\section*{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.

\section*{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
$P=$ Plastic

```

R65C24
TTemperature Range:
\[
\text { Blank }=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C}
\]
\[
\mathrm{E}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}
\]

Frequency Range:
\(1=1 \mathrm{MHz}\)
\(2=2 \mathrm{MHz}\)
\(4=4 \mathrm{MHz}\)
\[
C=\text { Ceramic }
\]
\[
P=\text { Plastic }
\]

\section*{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
\begin{tabular}{|c|c|c|}
\hline VSS 1 & 40 & \(\square\) CA1 \\
\hline PAO 2 & 39 & CA2 \\
\hline PA1 3 & 38 & IRQ \\
\hline PA2 4 & 37 & CNTR \\
\hline PA3 5 & 36 & RSO \\
\hline PA4 6 & 35 & RS1 \\
\hline PA5 7 & 34 & RES \\
\hline PA6 8 & 33 & D0 \\
\hline PA7 9 & 32 & D1 \\
\hline PBO 10 & 31 & D2 \\
\hline PB1 11 & 30 & D3 \\
\hline PB2 12 & 29 & D4 \\
\hline PB3 13 & 28 & D5 \\
\hline PB4 14 & 27 & D6 \\
\hline PB5 15 & 26 & D7 \\
\hline PB6 16 & 25 & ¢2 \\
\hline PB7 17 & 24 & RS2 \\
\hline CB1 18 & 23 & CS2 \\
\hline CB2 19 & 22 & CSO \\
\hline VCC 20 & 21 & R/W \\
\hline
\end{tabular}

Figure 1. R65C24 Pin Configuration

\section*{FUNCTIONAL DESCRIPTION}

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


Figure 2. R65C24 PIAT Block Diagram

\section*{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.

\section*{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.

\section*{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 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.

\section*{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.

\section*{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.

\section*{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
CRA
\begin{tabular}{|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) \\
\hline IRQA1 & IRQA2 & & CA2 Control & \(\mathbf{1}\) \\
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{0}\) \\
Access
\end{tabular}
\begin{tabular}{|c|c|c|c|c|}
\hline CRB & CB2 Control & \(\mathbf{2}\) & \(\mathbf{1}\) \\
\hline IRQB1 & IRQB2 & & CA1 Control \\
\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 .

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 I/O lines are programmed to act as inputs, the output buffer enters the high impedance state.

\section*{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 operatıng in an input mode).

\section*{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 Regıster 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 \(\varnothing 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 One-Shot Interval Timer
Free-Run Interval Timer
Pulse Width Measurement
Event Counter
One-Shot Pulse Width Generation
Free-Run Pulse Generation
Retriggerable Interval Timer

```

Bit 7 of the CMCR determines whether the IRQT 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 , IRQT 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{RQT}}\) is disabled.

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

Status Register-Bit 7 of the Status Register (SR) reports the Counter Underflow Status. This underflow (UF) bit is set to 1 when the counter decrements past \(\$ 0000\). When this bit is set, the \(\overline{\operatorname{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{RQB}}\) ) are reported in bits 6 and 5, respectively, in addition to being reported in the ISCA and ISCB registers.

\section*{INTERFACE SIGNALS}

The PIAT interfaces to the R6500, R6500/* or the R65C00 microprocessor family with a reset line, a \(\varnothing 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.

\section*{CHIP SELECT (CSO, \(\overline{\mathbf{C S 2}}\) )}

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

\section*{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

\section*{RESET SIGNAL ( \(\overline{\text { RES }}\) )}

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

\section*{CLOCK SIGNAL ( \(\boldsymbol{\phi}_{2}\) )}

The Phase 2 Clock Signal \(\left(\phi_{2}\right)\) 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.

\section*{READ/WRITE SIGNAL (R/W)}

Read/Write (R/面) 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 / \bar{W}\) line allows data to be transfered from the CPU to the peripheral devices from the PIAT.

\section*{REGISTER SELECT (RS0, RS1, RS2)}

Two of the Register Select lines (RS0, 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 Directıon 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
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Register Address (Hex)} & \multicolumn{3}{|c|}{Register Select Lines} & \multicolumn{2}{|l|}{Data Direction Register Control} & \multicolumn{2}{|l|}{Register Operation} \\
\hline & RS2 & RS1 & RSO & \[
\begin{gathered}
\text { CRA } \\
\text { (Bit 2) }
\end{gathered}
\] & \[
\begin{array}{|c|}
\hline \text { CRB } \\
\text { (Bit 2) }
\end{array}
\] & \(\mathrm{R} / \overline{\mathrm{W}}=\mathrm{H}\) & \(\mathbf{R} \bar{W}=\mathbf{L}\) \\
\hline 4 & H & L & L & 1 & - & Read PIBA & Write ORA \\
\hline 4 & H & L & L & 0 & - & Read DDRA & Write DDRA \\
\hline 5 & H & L & H & - & - & Read CRA & Write CRA \\
\hline 6 & H & H & L & - & 1 & Read PIBB & Write ORB \\
\hline 6 & H & H & L & - & 0 & Read DDRB & Write DDRA \\
\hline 7 & H & H & H & - & - & Read CRB & Write CRB \\
\hline
\end{tabular}

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
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{\begin{tabular}{c} 
Register \\
Address \\
(Hex)
\end{tabular}} & \begin{tabular}{c} 
Register \\
Select Lines
\end{tabular} & \multicolumn{2}{|c|}{ Counter/Timer Operation }
\end{tabular}

\section*{INTERRUPT REQUEST LINE ( \(\overline{\mathrm{IRQ}}\) )}

Three internal active low Interrupt Request lines ( \(\overline{\mathrm{RQQA}}, \overline{\mathrm{IRQB}}\), and \(\overline{\mathrm{RQT}}\) ) act to interrupt the microprocessor through the external \(\overline{\mathrm{RQ}}\) output. \(\overline{\mathrm{RQ}}\) 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{\text { IRQA }}\) and \(\overline{\text { IRQB }}\) Lines-These two internal Interrupt Request lines are associated with the Port A and Port B sections of the PIAT and are controlled by Control Registers CRA and CRB, and the Peripheral Control lines CA1, CA2, CB1, and CB2.

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

CRA bit 7 (IRQA1) is always set by an active transition of the CA1 interrupt input signal. However, \(\overline{\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 IRQA 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 TRQB 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{\operatorname{TRQB}}\) control is shown in Table 4.

Table 4. \(\overline{\operatorname{IRQA}}\) and \(\overline{\mathrm{IRQB}}\) Control Summary
\begin{tabular}{|c|c|}
\hline Control Register Bits & Action \\
\hline CRA-7 \(=1\) and CRA-0 \(=1\) & \(\overline{\text { RQA }}\) goes low (Active) \\
\hline CRA \(-6=1\) and CRA-3 \(=1\) & \(\overline{\text { IRQA }}\) goes low (Active) \\
\hline CRB-7 \(=1\) and CRB-0 \(=1\) & \(\overline{\text { IRQB }}\) goes low (Active) \\
\hline CRB-6 \(=1\) and CRB-3 \(=1\) & \(\overline{\text { IRQB goes low (Active) }}\) \\
\hline \multicolumn{2}{|c|}{ Note: } \\
\hline
\end{tabular}

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.

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

\section*{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.

\section*{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.

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)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{2}{*}{IRQA1 FLAG} & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { IRQA2 } \\
& \text { FLAG }
\end{aligned}
\]} & \multirow[t]{2}{*}{CA2 INPUT MODE SELECT \((=0)\)} & \[
\begin{gathered}
\text { IRQA2 } \\
\text { POSITIVE } \\
\text { TRANSITION }
\end{gathered}
\] & \[
\begin{gathered}
\overline{\text { IRQA }} \\
\text { ENABLE } \\
\text { FOR IRQA2 }
\end{gathered}
\] & \multirow[t]{2}{*}{ORA SELECT} & \[
\begin{aligned}
& \text { IRQA1 } \\
& \text { POSITIVE } \\
& \text { TRANSITION }
\end{aligned}
\] & \[
\begin{gathered}
\overline{\mathrm{RRQA}} \\
\text { ENABLE } \\
\text { FOR IRQA1 }
\end{gathered}
\] \\
\hline & & & \multicolumn{2}{|c|}{IRQA IRQA2 CONTROL} & & \multicolumn{2}{|c|}{IRQA/IRQA1 CONTROL} \\
\hline
\end{tabular}

CA2 OUTPUT MODE (BIT \(5=1\) )
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { IRQA1 } \\
& \text { FLAG }
\end{aligned}
\]} & \multirow[t]{2}{*}{0} & \multirow[t]{2}{*}{CA2 OUTPUT MODE SELECT \((=1)\)} & CA2 OUTPUT CONTROL & CA2 RESTORE CONTROL & \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { ORA } \\
& \text { SELECT }
\end{aligned}
\]} & IRQA1 POSITIVE TRANSITION & \[
\begin{gathered}
\overline{\mathrm{IRQA}} \\
\text { ENABLE } \\
\text { FOR IRQA1 }
\end{gathered}
\] \\
\hline & & & \multicolumn{2}{|c|}{CA2 CONTROL} & & \multicolumn{2}{|c|}{\(\overline{\text { IRQA }}\) IRQA 1 CONTROL} \\
\hline
\end{tabular}

CA2 INPUT OR OUTPUT MODE (BIT \(5=0\) or 1 )
\begin{tabular}{|cl|}
\hline Bit 7 & \begin{tabular}{l} 
IRQA1 FLAG \\
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
\end{tabular} \\
0 & \begin{tabular}{l} 
A or by RES
\end{tabular} \\
No transition has occurred on CA1 that satisfies the bit 1 IRQA1 transition polarity criteria \\
Bit 2 & OUTPUT REGISTER A SELECT \\
1 & \begin{tabular}{ll} 
Select Output Register A \\
0 & Select Data Direction Register A
\end{tabular} \\
Bit 1 & \begin{tabular}{l} 
IRQA1 POSITIVE TRANSITION \\
1
\end{tabular} \\
0 & Set IRQA1 Flag (bit 7) on a positive (low-to-high) transition of CA1. \\
Set IRQA1 Flag (bit 7) on a negative (high-to-low) transition of CA1.
\end{tabular}

CA2 INPUT MODE (BIT \(5=0\) )
\begin{tabular}{cl}
\hline Bit 6 & \begin{tabular}{l} 
IRQA2 FLAG \\
A transition has occurred on CA2 that satisfies the bit 4 \\
1
\end{tabular} \\
\begin{tabular}{ll} 
Register A or by \(\overline{R E S}\).
\end{tabular} \\
No transition has occurred on CA2 that satisfies the bit 4 IRQA2 transition polarity criteria
\end{tabular}

CA2 OUTPUT MODE (BIT \(5=1\) )
\begin{tabular}{|c|c|}
\hline Bit 6 & NOT USED \\
\hline 0 & Always zero. \\
\hline Bit 5 & CA2 MODE SELECT \\
\hline 1 & Select CA2 Output Mode \\
\hline Bit 4 & CA2 OUTPUT CONTROL \\
\hline 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 \\
\hline 0 & CA2 goes low on the first negative (high-to-low) \(\varnothing 2\) clock transition following a read of Output Register A. CA2 returns high as specified by bit 3 \\
\hline Bit 3 & CA2 READ STROBE RESTORE CONTROL (BIT \(4=0\) ) \\
\hline 1 & CA2 returns high on the next \(\phi 2\) clock negative transition following a read of Output Register A \\
\hline 0 & CA2 returns high on the next active CA1 transition following a read of Output Register A as specified by bit 1 \\
\hline
\end{tabular}

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

CB2 INPUT MODE (BIT \(5=0\) )

\section*{CONTROL REGISTER B (CRB)}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{2}{*}{\[
\begin{gathered}
\hline \text { IRQB1 } \\
\text { FLAG }
\end{gathered}
\]} & \multirow[t]{2}{*}{\[
\begin{gathered}
\text { IRQB2 } \\
\text { FLAG }
\end{gathered}
\]} & \multirow[t]{2}{*}{CB2 INPUT
MODE SELECT
\((=0)\)} & \[
\begin{gathered}
\text { IRQB2 } \\
\text { POSITIVE } \\
\text { TRANSITION }
\end{gathered}
\] & \[
\begin{gathered}
\overline{\mathrm{TRQB}} \\
\text { ENABLE } \\
\text { FOR IRQB2 }
\end{gathered}
\] & \multirow[t]{2}{*}{ORB SELECT} & \[
\begin{array}{|c|}
\hline \text { IRQB1 } \\
\text { POSITIVE } \\
\text { TRANSITION }
\end{array}
\] & \[
\begin{gathered}
\overline{\mathrm{IRQB}} \\
\text { ENABLE } \\
\text { FOR IRQB1 }
\end{gathered}
\] \\
\hline & & & \multicolumn{2}{|c|}{\(\overline{\mathrm{RQB}} / \mathrm{IRQB}^{2}\) CONTROL} & & \multicolumn{2}{|c|}{\(\overline{\text { IRQB } /{ }^{2} R B 1}\) CONTROL} \\
\hline
\end{tabular}

CB2 OUTPUT MODE (BIT \(5=1\) )
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { IRQB1 } \\
& \text { FLAG }
\end{aligned}
\]} & \multirow[t]{2}{*}{0} & \multirow[t]{2}{*}{CB2 OUTPUT MODE SELECT
\[
(=1)
\]} & CB2 OUTPUT CONTROL & CB2 RESTORE CONTROL & \multirow[t]{2}{*}{ORB SELECT} & \[
\begin{gathered}
\text { IRQB1 } \\
\text { POSITIVE } \\
\text { TRANSITION }
\end{gathered}
\] & \[
\begin{gathered}
\overline{\mathrm{TRQB}} \\
\text { ENABLE } \\
\text { FOR IRQB1 }
\end{gathered}
\] \\
\hline & & & \multicolumn{2}{|c|}{CB2 CONTROL} & & \multicolumn{2}{|c|}{\(\overline{\mathrm{TRQB}} / \mathrm{IRQB}_{1}\) CONTROL} \\
\hline
\end{tabular}

CB2 INPUT OR OUTPUT MODE (BIT \(5=0\) or 1)
\begin{tabular}{|c|c|}
\hline Bit 7 & IRQB1 FLAG \\
\hline 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 }}\) \\
\hline 0 & No transition has occurred on CB1 that satisfies the bit 1 IRQB1 transition polarity criteria \\
\hline Bit 2 & OUTPUT REGISTER B SELECT \\
\hline 1 & Select Output Register B \\
\hline 0 & Select Data Direction Register B \\
\hline Bit 1 & IRQB1 POSITIVE TRANSITION \\
\hline 1 & Set IRQB1 Flag (bit 7) on a positive (low-to-hıgh) transition of CB1. \\
\hline 0 & Set IRQB1 Flag (bit 7) on a negative (high-to-low) transition of CB1 \\
\hline Bit 0 & \(\overline{\text { IRQB }}\) ENABLE FOR IRQB1 \\
\hline 1 & Enable assertion of \(\overline{\mathrm{IRQB}}\) when IRQB1 Flag (bit 7) is set \\
\hline 0 & Disable assertion of \(\overline{\mathrm{IRQB}}\) when IRQB1 Flag (bit 7) is set \\
\hline
\end{tabular}

CB2 INPUT MODE (BIT \(5=0\) )


\section*{CB2 OUTPUT MODE (BIT \(5=1\) )}
\begin{tabular}{|c|c|}
\hline Bit 6 & NOT USED \\
\hline 0 & Always zero \\
\hline Bit 5 & CB2 MODE SELECT \\
\hline 1 & Select CB2 Output Mode. \\
\hline Bit 4 & CB2 OUTPUT CONTROL \\
\hline 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 \\
\hline 0 & CB2 goes low on the first negative (high-to-low) \(\varnothing 2\) clock transition following a write to Output Register B CB2 returns high as specified by bit 3 \\
\hline Bit 3 & CB2 WRITE STROBE RESTORE CONTROL (BIT \(4=0\) ) \\
\hline 1 & CB2 returns high on the next \(\varnothing 2\) clock negative transition following a write to Output Register B \\
\hline 0 & CB2 returns high on the next active CB1 transition following a write to Output Register B as specified by bit 1 \\
\hline
\end{tabular}

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

\section*{COUNTER/TIMER REGISTERS}

\section*{COUNTER MODE CONTROL REGISTER (CMCR)}

The 8-bit Counter Mode Control Register (CMCR) selects the Counter/Timer mode of operation and enables or disables both the internal \(\overline{\mathrm{IRQT}}\) and the Prescaler. The format of the CMCR is:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \begin{tabular}{l}
\[
\overline{\mathrm{IRQT}}
\] \\
Enabled
\end{tabular} & 0 & 0 & Prescaler Enabled & 0 & \multicolumn{3}{|l|}{Counter/Tımer Mode} \\
\hline
\end{tabular}
\begin{tabular}{cc} 
Bit 7 & \(\overline{\text { IRQT }}\) Enabled \\
0 & \(\overline{\mid R Q T}\) Disabled \\
1 & \(\overline{\text { IRQT }}\) Enabled
\end{tabular}

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

\section*{Bit 4 Prescaler Enabled \\ \(0 \quad\) Prescaler Disabled ( -1 ) \\ 1 Prescaler Enabled (-16)}

Bit 3 Not used, don't care value during write.
Bits 2-0 Counter/Timer Mode
\(0 \quad 0 \quad 0 \quad\) Mode 0-Disable Counter/Timer
\(0 \quad 0 \quad 1 \quad\) Mode 1-One-Shot Interval Timer
0 . 10 Mode 2-Free-Run Interval Timer
\(\begin{array}{llll}0 & 1 & 1 & \text { Mode 3-Pulse Width Measurement }\end{array}\)
1000 Mode 4-Event Counter
1001 Mode 5-One-Shot Pulse Width Generation
110 Mode 6-Free-Run Pulse Generation
111 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 \(\overline{\mathrm{RQT}}\) 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.

\section*{STATUS REGISTER (SR)}

The 8-bit Status Register (SR) reports the status of two interrupt conditions: Counter underflow ( \(\overline{\mathrm{RQT}}\) ) and Port A interrupt ( \(\overline{\mathrm{IRQA}})\). The format of the Status Register is:
\begin{tabular}{|l|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \begin{tabular}{l} 
UF (IRQT) \\
Interrupt \\
Flag
\end{tabular} & \begin{tabular}{l} 
IRQA \\
Interrupt \\
Flag
\end{tabular} & 0 & 1 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

Bit 7
Counter Underflow (UF) Interrupt Flag
Counter underflow has not occurred.
Counter underflow has occurred.

Bit 5-0
IRQA Interrupt Flag
Port A interrupt has not occurred.
Port A interrupt has not occurred.
Not used, always read as shown in register
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. \(\overline{I R Q A}\) 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 \(\overline{\text { RES }}\) occurs. Reading the Status Register also clears the \(\overline{\mathrm{RQA}}\) interrupt flag. The Status Register is read when the register address is 3 and \(R / \bar{W}\) is high.

\section*{LOWER LATCH (LL)}

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

\section*{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 (DO-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:

\section*{Register Address 0}
1. The UL is loaded from DO-D7.
2. The contents of the Latch (UL and LL) 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.

\section*{Register Address 1}
1. The UL is loaded from DO-D7.
2. All other elements of the Counter/Timer are unaffected.

\section*{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).

\section*{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\).

\section*{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.

\section*{SNAPSHOT LATCH (SL)}

The Snapshot Latch holds the value of the UC corresponding to the LC value. The SL is loaded with the value of the UC when the \(L L\) is written to, or when the LC is read. The 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.

\section*{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 \(\varnothing 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.

\section*{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.

\section*{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 IRQ to be asserted if the IRQT Enable bit is set in the CMCR. Upon decrementing below \$0000, the UC and LC are automatically reset to a value of \$FFFF and the counter continues down-counting. However, the UF bit in the SR will not be set again (due to the counter again decrementing through \(\$ 0000\) ) until the UL is again written at register address 0 . The CNTR line is not used in this mode. Figure 6 shows the timing relationship for Mode 1 operation.

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

\section*{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{RQQT}}\) 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

\section*{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 \(\varnothing 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 rennitiate 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.

\section*{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 \(\phi 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

\section*{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 SFFFF 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 tımeout.

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

\section*{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 depending upon its initial state), the counter is reloaded with the UL and LL value and the counter continues down-counting. The UF bit in the SR is set the first time the counter decrements past \(\$ 0000\) and is cleared only if a new write to UL at register address 0 occurs. Figure 11 shows the timing relationship of a Mode 6 operation.

This mode can be used to generate an asymmetrical waveform by toggling the UL and LL with the CNTR high and low times. Immediately after starting the counter with the first CNTR low time, load the LL and UL (by writing to register address 1, which does not restart the counter) with the CNTR high time. When the first counter underflow occurs, the counter loads the new latch value (i.e., the CNTR high time) into the counter and continues counting. During the \(\overline{\mathrm{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 \(\varnothing 2\) clock (e.g., a tone generator for audıo feedback).


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


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

\section*{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.

\section*{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 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.

\section*{INITIALIZING THE COUNTER/TIMER}

The following program segment is one suggested technique for ınitıalizing the Counter/Timer:
;Data Definition
\begin{tabular}{lll} 
SL & \(=\) \$XXX0 & ;Snapshot Latch \\
UC & \$XXX1 & ;Upper Counter \\
LC & \(=\) \$XXX2 & ;Lower Counter \\
SR & \$XXX3 & ;Status Register \\
ULEC & \(=\) \$XXX0 & ;Upper Latch and Enable Counter \\
UL & \(=\) \$XXX1 & ;Upper Latch \\
LL & \(=\) \$XXX2 & ;Lower Latch \\
CMCR & \(=\$ X X X 3\) & ;Counter Mode Control Register
\end{tabular}
;Program
\begin{tabular}{lll} 
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
\end{tabular}
\#Slovalue
LL
\#Shivalue
ULEC
;lower latch value ;write to lower latch ;upper latch value ;write to upper latch
;clear underflow flag, and enable counter

The following instructions is a way to change modes while the Counter/Timer is in operation:
\(\left.\begin{array}{lll}\text { LDA } & \text { \#\$mode } & \text {;select desired mode, except } \\
\text { mode 0 }\end{array}\right]\)\begin{tabular}{ll} 
STA & CMCR
\end{tabular}

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

\section*{READING THE COUNTER/TIMER}

To service an interrupt request, the following sequence can be used:
\begin{tabular}{lll} 
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
\end{tabular}

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 \(\quad\) get low counter value ;upper counter transferred to snapshot
;any miscellaneous code to store value if desired
LDA \$SL ;get high counter value

\section*{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

\section*{READING THE PERIPHERAL A I/O PORT}

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

Since the processor always reads the Peripheral A I/O port pins instead of the actual Peripheral Output Register (ORA), it is possible for the data read by the processor to differ from the contents of the Peripheral Output Register for an output line. This is true when the \(\mathrm{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 .

\section*{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.

\section*{BUS TIMING CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1MHz} & \multicolumn{2}{|c|}{2MHz} & \multicolumn{2}{|c|}{3MHz} & \multicolumn{2}{|c|}{4MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min & Max & Min & Max & Min & Max & Min & Max & \\
\hline \$2 Cycle & \(\mathrm{T}_{\mathrm{CrC}}\) & 1.0 & - & 0.5 & - & 0.33 & - & 0.25 & - & \(\mu \mathrm{S}\) \\
\hline ¢2 Pulse Width & \(\mathrm{t}_{\mathrm{c}}\) & 450 & - & 220 & - & 160 & - & 110 & - & ns \\
\hline ¢2 Rise and Fall Time & \(\mathrm{t}_{\mathrm{rc}}, \mathrm{t}_{\text {cc }}\) & - & 25 & - & 15 & - & 12 & - & 10 & ns \\
\hline
\end{tabular}

\section*{READ TIMING}
\begin{tabular}{|l|c|c|c|c|c|c|c|c|c|c|c|}
\hline Address Set-Up Time & \(\mathrm{t}_{\text {ACR }}\) & 140 & - & 70 & - & 53 & - & 35 & - & ns \\
\hline Address Hold Time & \(\mathrm{t}_{\mathrm{CAR}}\) & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline Peripheral Data Set-Up Time & \(\mathrm{t}_{\text {PCR }}\) & 300 & - & 150 & - & 110 & - & 75 & - & ns \\
\hline Data Bus Delay Time & \(\mathrm{t}_{\mathrm{CDR}}\) & - & 325 & - & 145 & - & 105 & - & 80 & ns \\
\hline Data Bus Hold Time & \(\mathrm{t}_{\text {HR }}\) & 20 & - & 20 & - & 20 & - & 20 & - & ns \\
\hline
\end{tabular}

\section*{WRITE TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline Address Set-Up Time & \(t_{\text {ACW }}\) & 140 & - & 70 & - & 53 & - & 53 & - & ns \\
\hline Address Hold Time & \(\mathrm{t}_{\text {CAW }}\) & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline R/W Set-Up Time & \(t_{\text {WCW }}\) & 180 & - & 90 & - & 67 & - & 45 & - & ns \\
\hline R/W Hold Time & \(\mathrm{t}_{\text {CWW }}\) & 0 & - & 0 & - & 0 & - & 0 & - & ns \\
\hline Data Bus Set-Up Time & \(t_{\text {DCW }}\) & 180 & - & 90 & - & 67 & - & 45 & - & ns \\
\hline Data Bus Hold Tıme & \(\mathrm{t}_{\text {HW }}\) & 10 & - & 10 & - & 10 & - & 10 & - & ns \\
\hline Peripheral Data Delay Time & \(t_{\text {CPW }}\) & - & 1.0 & - & 0.5 & - & 0.33 & - & 0.25 & \(\mu \mathrm{S}\) \\
\hline Peripheral Data Delay Time to CMOS Level & \(\mathrm{t}_{\text {cmos }}\) & - & 2.0 & - & 1.0 & - & 0.7 & - & 0.5 & \(\mu \mathrm{S}\) \\
\hline
\end{tabular}

\section*{PERIPHERAL INTERFACE TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1MHz} & \multicolumn{2}{|c|}{2MHz} & \multicolumn{2}{|c|}{3 MHz} & \multicolumn{2}{|c|}{4MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min & Max & Min & Max & Min & Max & Min & Max & \\
\hline Peripheral Data Setup & \(t_{\text {PCR }}\) & 300 & - & 150 & - & 110 & - & 75 & - & ns \\
\hline ¢2 Low to CA2 Low Delay & \(t_{\text {CA2 }}\) & - & 1.0 & - & 0.5 & - & 0.33 & - & 0.25 & \(\mu \mathrm{S}\) \\
\hline ¢2 Low to CA2 High Delay & \(\mathrm{t}_{\text {RS1 }}\) & - & 1.0 & - & 0.5 & - & 0.33 & - & 0.25 & \(\mu \mathrm{S}\) \\
\hline CA1 Active to CA2 High Delay & \(\mathrm{t}_{\text {RS2 }}\) & - & 2.0 & - & 1.0 & - & 0.67 & - & 0.5 & \(\mu \mathrm{S}\) \\
\hline \$2 High to CB2 Low Delay & \(\mathrm{t}_{\mathrm{CB2}}\) & - & 1.0 & - & 0.5 & - & 0.33 & - & 0.25 & \(\mu \mathrm{S}\) \\
\hline Perıpheral Data Valid to CB2 Low Delay & \(t_{\text {b }}\) & 0 & 1.5 & 0 & 0.75 & 0 & 0.5 & 0 & 0.37 & \(\mu \mathrm{S}\) \\
\hline ¢2 High to CB2 Hgh Delay & \(\mathrm{t}_{\text {RS1 }}\) & - & 1.0 & - & 0.5 & - & 0.33 & - & 0.25 & \(\mu \mathrm{S}\) \\
\hline CB1 Active to CB2 High Delay & \(\mathrm{t}_{\text {RS2 }}\) & - & 2.0 & - & 1.0 & - & 0.67 & - & 0.5 & \(\mu \mathrm{S}\) \\
\hline CA1, CA2, CB1 and CB2 Input Rise and Fall Time & \(t_{r}, t_{f}\) & - & 1.0 & - & 10 & - & 1.0 & - & 1.0 & \(\mu \mathrm{S}\) \\
\hline
\end{tabular}

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & \multicolumn{1}{c|}{ Symbol } & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & VdC \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & Vdc \\
\hline Output Voltage & \(\mathrm{V}_{\text {OUT }}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{r}
0 to +70 \\
-40 to +85
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{OPERATING CONDITIONS}
\begin{tabular}{|c|c|c|}
\hline Parameter & Symbol & Value \\
\hline Supply Voltage & Vcc & \(5 \mathrm{~V} \pm 5 \%\) \\
\hline Temperature Range & \(\mathrm{T}_{\mathrm{A}}\) & \\
\begin{tabular}{c} 
Commercial \\
Industrial
\end{tabular} & & \(0^{\circ}\) to \(70^{\circ} \mathrm{C}\) \\
\(-40^{\circ}\) to \(+85^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*Note: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\) to \(T_{H}\), (unless otherwise noted)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{3}\) & Max & Unit \({ }^{1}\) & Test Conditions \\
\hline Input High Voltage & \(\mathrm{V}_{1 H}\) & +2.0 & - & \(\mathrm{V}_{\mathrm{cc}}\) & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\mathrm{IL}}\) & -0.3 & - & +0.8 & V & \\
\hline \begin{tabular}{l}
Input Leakage Current: \\
R/W, \(\overline{\text { RES }}\), RS0, RS1, RS2, CSO, \(\overline{C S} 2, ~ C A 1, ~\) CB1, \(\phi 2\)
\end{tabular} & 1 N & - & \(\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}
\] \\
\hline Input Leakage Current for Three-State Off D0-D7, PB0-PB7, CB2 & \(\mathrm{I}_{\text {TS }}\) & - & \(\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}
\] \\
\hline Input High Current PAO-PA7, CA2 & \(\mathrm{I}_{\mathrm{H}}\) & -200 & -400 & - & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IH}}=2.4 \mathrm{~V}\) \\
\hline Input Low Current PAO-PA7, CA2 & ILL & - & -2 & -3.2 & mA & \(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage Logic PB0-PB7, CB2 (Darlington Drive) & \(\mathrm{V}_{\mathrm{OH}}\) & \[
\begin{aligned}
& 2.4 \\
& 1.5 \\
& \hline
\end{aligned}
\] & - & - & \[
\begin{aligned}
& \text { v } \\
& \text { v }
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{~L}_{\mathrm{LOAD}}=200 \mu \mathrm{~A} \\
& \mathrm{~L}_{\text {LOAD }}=-3.2 \mathrm{~mA}
\end{aligned}
\] \\
\hline Output Low Voltage PAO-PA7, CA2, PB0-PB7, CB2 DO-D7, IRQ, CNTR & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & +0.4 & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\text {LOAD }}=3.2 \mathrm{~mA} \\
& \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}
\end{aligned}
\] \\
\hline Output High Current (Sourcing) Logic PB0-PB7, CB2 (Darlington Drive) & IOH & \[
\begin{aligned}
& -200 \\
& -3.2
\end{aligned}
\] & \[
\begin{gathered}
-1500 \\
-6
\end{gathered}
\] & - & \[
\begin{aligned}
& \mu \mathrm{A} \\
& \mathrm{~mA}
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{OH}}=1.5 \mathrm{~V}
\end{aligned}
\] \\
\hline Output Low Current (Sinking) PAO-PA7, PBO-PB7, CB2, CA2 DO-D7, \(\overline{\mathrm{RQ}}, \mathrm{CNTR}\) & 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}\) \\
\hline \(\frac{\text { Output Leakage Current (Off State): }}{\frac{\mathrm{IRQ}}{}}\) & \(\mathrm{l}_{\text {OFF }}\) & - & 1 & \(\pm 10\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Power Dissipation & \(P_{\text {D }}\) & - & 7 & 10 & mW/MHz & \\
\hline \begin{tabular}{l}
Input Capacitance \\
D0-D7, PAO-PA7, PB0-PB7, CA2, CB2, CNTR R/ \(\bar{W}, \overline{R E S}, ~ R S O, ~ R S 1, ~ R S 2, ~ C S O, ~ \overline{C S 2 ~}\)
\[
C A 1, C B 1, \phi 2
\]
\end{tabular} & \(\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} \\
& f=2 \mathrm{MHz} \\
& T_{A}=25^{\circ} \mathrm{C}
\end{aligned}
\] \\
\hline Output Capacitance & \(\mathrm{Cout}^{\text {O }}\) & - & - & 10 & pF & \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. All units are direct current (dc) except for capacitance. \\
2. Negative sign indicates outward current flow, positive indicates inward flow. \\
3. Typical values are shown for \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) and \(\mathrm{TA}=25^{\circ} \mathrm{C}\).
\end{tabular}} \\
\hline
\end{tabular}

\section*{PACKAGE DIMENSIONS}


\title{
R65C51 \\ ASYNCHRONOUS COMMUNICATIONS INTERFACE ADAPTER (ACIA)
}

\section*{PRELIMINARY \\ FEATURES}

\section*{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 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{IRQ}}, \overline{\mathrm{DSR}}\), and \(\overline{\mathrm{DCD}}\) lines, Transmitter and Receiver Data Registers, and Overrun, Framing, and Parity Error conditions.

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

ORDERING INFORMATION
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|l|}{} \\
\hline
\end{tabular}
- 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
- 1 or 2 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

\section*{FUNCTIONAL DESCRIPTION}

A block diagram of the ACIA is presented in Figure 2 followed by a description of each functional element of the device.

\section*{DATA BUS BUFFERS}

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

\section*{INTERRUPT LOGIC}

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

\section*{I/O CONTROL}

The I/O Control Logic controls the selection of internal registers 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.

\section*{TIMING AND CONTROL}

The Timing and Control logıc 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.

Tımıng 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.

\section*{TRANSMITTER AND RECEIVER DATA REGISTERS}

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

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

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

\section*{STATUS REGISTER}

The Status Register indicates the state of interrupt conditions and other non-interrupt status 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).

*No interrupt occurs for these conditions

\section*{Reset Initialization}


Hardware reset
Program reset

\section*{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).

\section*{Receiver Data Register Full (Bit 3)}

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

\section*{Transmitter Data Register Empty (Bit 4)}

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

\section*{Data Carrier Detect (Bit 5) and Data Set Ready (Bit 6)}

These bits reflect the levels of the \(\overline{D C D}\) and \(\overline{D S R}\) inputs to the ACIA. A 0 indicates a low level (true condition) and a 1 indicates a high level (false). Whenever either of these inputs change state, an immediate processor interrupt (IRQ) occurs, 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.

\section*{Interrupt (Bit 7)}

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

\section*{CONTROL REGISTER}

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


\section*{Selected Baud Rate (Bits 0, 1, 2, 3)}

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

If the Receiver clock uses the same baud rate as the transmitter, then RxC becomes an output and can be used to slave other circuits to the ACIA. Figure 3 shows the Transmitter and Receiver layout.


Figure 3. Transmitter/Receiver Clock Circuits

\section*{Receiver Clock Source (Bit 4)}

This bit controls the clock source to the Receiver. A 0 causes the Receiver to operate at a baud rate of \(1 / 16\) an external clock. A 1 causes the Receiver to operate at the same baud rate as is selected for the transmitter.

\section*{Word Length (Bits 5, 6)}

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

\section*{Stop Bit Number (Bit 7)}

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

\section*{COMMAND REGISTER}

The Command Register controls specific modes and functions.
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline PMC & \multirow[b]{2}{*}{PME} & \multirow[b]{2}{*}{REM} & \multicolumn{2}{|l|}{TIC} & \multirow[b]{2}{*}{IRD} & \multirow[b]{2}{*}{DTR} \\
\hline PNC1/PNC0 & & & TIC1 & TICO & & \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline Bits 7-6 & Parity Mode Control (PMC) \\
\hline 76 & \\
\hline 0 & Odd parity transmitted/received \\
\hline 0 & Even parity transmitted/received \\
\hline 10 & Mark parity bit transmitted \\
\hline & Parity check disabled \\
\hline 11 & Space parity bit transmitted \\
\hline & Parity check disabled \\
\hline Bit 5 & Parity Mode Enabled (PME) \\
\hline 0 & Parity mode disabled \\
\hline & No parity bit generated \\
\hline & Parity check disabled \\
\hline 1 & Parity mode enabled \\
\hline Bit 4 & Receiver Echo Mode (REM) \\
\hline 0 & Receiver normal mode \\
\hline 1 & Receiver echo mode bits 2 and 3 \\
\hline & Must be zero for receiver echo mode, \(\overline{\mathrm{RTS}}\) will be low. \\
\hline Bits 3-2 & Transmitter Interrupt Control (TIC) \\
\hline 3 2 & \\
\hline \(0 \quad 0\) & \(\overline{\text { RTS }}=\) High, transmitter disabled \\
\hline 01 & \(\overline{\text { RTS }}=\) Low, transmit interrupt enabled \\
\hline 10 & \(\overline{\text { RTS }}=\) Low, transmit interrupt disabled \\
\hline 11 & \[
\begin{aligned}
\widehat{\mathrm{RTS}}= & \text { Low, transmit interrupt disabled } \\
& \text { transmit break on TxD }
\end{aligned}
\] \\
\hline Bit 1 & Receiver Interrupt Request Disabled (IRD) \\
\hline 0 & \(\overline{\mathrm{IRQ}}\) enabled (receiver) \\
\hline 1 & \(\overline{\mathrm{IRQ}}\) disabled (receiver) \\
\hline Bit 0 & Data Terminal Ready (DTR) \\
\hline 0 & Data terminal not ready (DTR high)* \\
\hline 1 & Data terminal ready (DTR low) \\
\hline
\end{tabular}

\section*{NOTE}
*The transmitter is disabled immediately. The receiver is disabled but will first complete receiving a byte in process of being received.

\section*{Data Terminal Ready (Bit 0)}

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

\section*{Receiver Interrupt Control (Bit 1)}

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

\section*{Transmitter Interrupt Control (Bits 2, 3)}

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

\section*{Receiver Echo Mode (Bit 4)}

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

\section*{Parity Mode Enable (Bit 5)}

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

\section*{Parity Mode Control (Bits 6, 7)}

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

\section*{Reset Initialization}
\(\begin{array}{llllllll}7 & 6 & 5 & 4 & 3 & 2 & 1 & 0\end{array}\)
\begin{tabular}{|l|l|l|l|l|l|l|l}
\hline 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline
\end{tabular}

\section*{INTERFACE SIGNALS}

Figure 4 shows the ACIA interface signals associated with the microprocessor and the modem.


Figure 4. ACIA Interface Diagram

\section*{MICROPROCESSOR INTERFACE}

\section*{Reset ( \(\overline{\mathrm{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. \(\overline{R E S}\) must be held low for one \(\varnothing 2\) clock cycle for a reset to occur.

\section*{Input Clock (ø2)}

The input clock is the system \(\varnothing 2\) clock and clocks all data transfers between the system microprocessor and the ACIA.

\section*{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.

\section*{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{R Q}\) microprocessor input. Normally a high level, \(\overline{\mathrm{IRQ}}\) goes low when an interrupt occurs.

\section*{Data Bus (D0-D7)}

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

\section*{Chip Selects (CSO, 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).

\section*{Register Selects (RSO, RS1)}

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

Table 1. ACIA Register Selection
\begin{tabular}{|c|c|l|l|}
\hline & & \multicolumn{2}{|c|}{ Register Operation } \\
\cline { 3 - 4 } RS1 & RS0 & \multicolumn{1}{|c|}{ R/ \(\overline{\mathbf{W}}=\) Low } & \multicolumn{1}{|c|}{\(\mathbf{R} \overline{\mathbf{W}}=\) High } \\
\hline L & L & \begin{tabular}{l} 
Write Transmit Data \\
Register
\end{tabular} & \begin{tabular}{l} 
Read Receiver \\
Data Register
\end{tabular} \\
\hline L & H & \begin{tabular}{l} 
Programmed Reset \\
(Data is "Don't \\
Care")
\end{tabular} & \begin{tabular}{l} 
Read Status \\
Register
\end{tabular} \\
\hline H & L & \begin{tabular}{l} 
Write Command \\
Register
\end{tabular} & \begin{tabular}{l} 
Read Command \\
Register
\end{tabular} \\
\hline H & H & \begin{tabular}{l} 
Write Control \\
Register
\end{tabular} & \begin{tabular}{l} 
Read Control \\
Register
\end{tabular} \\
\hline
\end{tabular}

Only the Command and Control registers can 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.

\section*{ACIA/MODEM INTERFACE}

\section*{Crystal Pins (XTLI, XTLO)}

These pins are normally directly connected to the parallel mode external crystal ( 1.8432 MHz ) to derive the various baud rates. Alternatively, an externally generated clock can drive the XTLI pin, in which case the XTLO pin must float. XTLI is the input pin for the transmit clock.

\section*{Transmit Data (TxD)}

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

\section*{Receive Data (RxD)}

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

\section*{Receive Clock (RxC)}

The RxC is a bl-directional pin which is either the receiver \(16 x\) clock input or the receiver \(16 x\) clock output. The latter mode results if the internal baud rate generator is selected for receiver data clocking.

\section*{Request to Send ( \(\overline{\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.

\section*{Clear to Send (CTS)}

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

\section*{Data Terminal Ready ( \(\overline{\mathrm{DTR}}\) )}

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

\section*{Data Set Ready ( \(\overline{\mathrm{DSR}}\) )}

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

\section*{Data Carrier Detect ( \(\overline{\mathbf{D C D}}\) )}

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

\section*{TRANSMITTER AND RECEIVER OPERATION}

\section*{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

\section*{Continuous Data Receive}

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


Figure 6. Continuous Data Receive

\section*{Transmit Data Register Not Loaded by Processor}

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

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


Figure 7. Transmit Data Register Not Loaded by Processor

\section*{Effect of 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. 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

\section*{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

\section*{Echo Mode Timing}

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


Figure 10. Echo Mode Timing

\section*{Effect of CTS on Echo Mode Operation}

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


Figure 11. Effect of CTS on Echo Mode

\section*{Overrun in Echo Mode}

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


Figure 12. Overrun in Echo Mode

\section*{Framing Error}

Framing Error is caused by the absence of Stop Bit(s) on received data. A Framing Error is indicated by the setting of bit 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 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

\section*{Effect of \(\overline{D C D}\) on Receiver}
\(\overline{D C D}\) is a modem output indicating the status of the carrier-fre-quency-detection circuit of the modem. This line goes high for a loss of carrier. Normally, when this occurs, the modem will stop transmitting data some time later. The ACIA asserts \(\overline{\mathrm{R} Q}\) 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{IRQ}}\) occurs (see Figure 14).


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

\section*{Timing with \(11 / 2\) Stop Bits}

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


Figure 15. Timing with \(11 / 2\) Stop Bits

\section*{Transmit Continuous "BREAK"}

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

\section*{Note}

If, while operating in the Transmit Continuous "BREAK" mode, the \(\overline{\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{\mathrm{CTS}}\) goes high.


Figure 16. Transmit Continuous "BREAK"

\section*{Receive Continuous "BREAK"}

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


Figure 17. Receive Continuous "BREAK"

\section*{STATUS REGISTER OPERATION}

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

This operation automatıcally clears Bit 7 ( \(\overline{\mathrm{RQ}})\). Subsequent transitions on \(\overline{\mathrm{DSR}}\) and \(\overline{\mathrm{DCD}}\) will cause another interrupt
2. Check \(\overline{\mathrm{RQ}}\) (Bıt 7) in the data read from the Status Regıster

If not set, the interrupt source is not the ACIA.
3. Check \(\overline{D C D}\) and \(\overline{D S R}\)

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

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

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

\section*{PROGRAM RESET OPERATION}

A program reset occurs when the processor performs a write operation to the ACIA with RS0 low and RS1 high. The program reset operates somewhat different from the hardware reset ( \(\overline{\mathrm{RES}} \mathrm{pin}\) ) and is described as follows:
1. Internal registers are not completely cleared. Check register formats for the effect of a program reset on internal registers.
2. The \(\overline{\mathrm{DTR}}\) line goes high immediately.
3. Receiver and transmitter interrupts are disabled immediately. If \(\overline{\mathrm{IRQ}}\) is low when the reset occurs, it stays low until serviced, unless interrupt was caused by \(\overline{\mathrm{DCD}}\) or \(\overline{\mathrm{DSR}}\) transition.
4. \(\overline{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.

\section*{MISCELLANEOUS}
1. If Echo Mode is selected, \(\overline{\mathrm{RTS}}\) goes low.
2. If Bit 0 of Command Register ( \(\overline{\mathrm{DTR}}\) ) is 0 (disabled), then:
a) All interrupts are disabled, including those caused by \(\overline{\mathrm{DCD}}\) and \(\overline{\mathrm{DSR}}\) transitions.
b) Transmitter is disabled immediately.
c) Receiver is disabled, but a character currently being received will be completed first.
3. Odd parity occurs when the sum of all the 1 bits in the data word (including the parity bit) is odd.
4. In the receive mode, the received parity bit does not go into the Recelver 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 initlates 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}}\).

\section*{GENERATION OF NON-STANDARD BAUD RATES}

\section*{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.

\section*{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 Fiequency }}{\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
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{Control Register Bits} & \multirow[t]{2}{*}{Divisor Selected For The Internal Counter} & \multirow[t]{2}{*}{Baud Rate Generated With 1.8432 MHz Crtstal} & \multirow[t]{2}{*}{Baud Rate Generated With a Crystal of Frequency (F)} \\
\hline 3 & 2 & 1 & 0 & & & \\
\hline 0 & 0 & 0 & 0 & No Divisor Selected & \(16 \times\) External Clock at Pin RxC & \(16 \times\) External Clock at Pin RxC \\
\hline 0 & 0 & 0 & 1 & 36,864 & \[
\frac{1.8432 \times 10^{6}}{36,864}=50
\] & \[
\frac{F}{36,864}
\] \\
\hline 0 & 0 & 1 & 0 & 24,576 & \[
\frac{1.8432 \times 10^{6}}{24,576}=75
\] & \[
\frac{F}{24,576}
\] \\
\hline 0 & 0 & 1 & 1 & 16,769 & \[
\frac{1.8432 \times 10^{6}}{16,769}=109.92
\] & \[
\frac{F}{16,769}
\] \\
\hline 0 & 1 & 0 & 0 & 13,704 & \[
\frac{1.8432 \times 10^{6}}{13,704}=134.51
\] & \[
\frac{F}{13,704}
\] \\
\hline 0 & 1 & 0 & 1 & 12,288 & \[
\frac{1.8432 \times 10^{6}}{12,288}=150
\] & \[
\frac{F}{12,288}
\] \\
\hline 0 & 1 & 1 & 0 & 6,144 & \[
\frac{1.8432 \times 10^{6}}{6,144}=300
\] & \[
\frac{F}{6,144}
\] \\
\hline 0 & 1 & 1 & 1 & 3,072 & \[
\frac{1.8432 \times 10^{6}}{3,072}=600
\] & \[
\frac{F}{3,072}
\] \\
\hline 1 & 0 & 0 & 0 & 1,536 & \[
\frac{1.8432 \times 10^{6}}{1,536}=1,200
\] & \[
\frac{F}{1,536}
\] \\
\hline 1 & 0 & 0 & 1 & 1,024 & \[
\frac{1.8432 \times 10^{6}}{1,024}=1,800
\] & \[
\begin{gathered}
F \\
\hline 1,024
\end{gathered}
\] \\
\hline 1 & 0 & 1 & 0 & 768 & \[
\frac{1.8432 \times 10^{6}}{768}=2,400
\] & \[
\frac{F}{768}
\] \\
\hline 1 & 0 & 1 & 1 & 512 & \[
\frac{1.8432 \times 10^{6}}{512}=3,600
\] & \[
\frac{F}{512}
\] \\
\hline 1 & 1 & 0 & 0 & 384 & \[
\frac{1.8432 \times 10^{6}}{384}=4,800
\] & \[
\frac{F}{384}
\] \\
\hline 1 & 1 & 0 & 1 & 256 & \[
\frac{1.8432 \times 10^{6}}{256}=7,200
\] & \[
\frac{F}{256}
\] \\
\hline 1 & 1 & 1 & 0 & 192 & \[
\frac{1.8432 \times 10^{6}}{192}=9,600
\] & \[
\begin{gathered}
\hline F \\
\hline 192
\end{gathered}
\] \\
\hline 1 & 1 & 1 & 1 & 96 & \[
\frac{1.8432 \times 10^{6}}{96}=19,200
\] & \[
\begin{aligned}
& \hline F \\
& \hline 96
\end{aligned}
\] \\
\hline
\end{tabular}

\section*{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 RxD, \(\overline{D T R}\) to \(\overline{D C D}, \overline{R T S}\) to \(\overline{C T S}\) ).

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

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 Regıster bit 1 must be 0 to dısable \(\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

\section*{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
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Characteristic} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min & Max & Min & Max & \\
\hline Transmit/Receive Clock Rate & \(\mathrm{t}_{\mathrm{CCY}}\) & 400* & - & 400* & - & \(n s\) \\
\hline Transmit/Receive Clock High Time & \(\mathrm{t}_{\mathrm{CH}}\) & 175 & - & 175 & - & ns \\
\hline Transmit/Receive Clock Low Time & \(\mathrm{t}_{\mathrm{CL}}\) & 175 & - & 175 & - & ns \\
\hline \begin{tabular}{l}
XTLI to TxD \\
Propagation Delay
\end{tabular} & \(t_{\text {D }}\) & - & 500 & - & 500 & ns \\
\hline RTS Propagation Delay & \(t_{\text {DLY }}\) & - & 500 & - & 500 & ns \\
\hline \(\overline{\mathrm{IRQ}}\) Propagation Delay (Clear) & \(\mathrm{t}_{\text {IRQ }}\) & - & 500 & - & 500 & ns \\
\hline \begin{tabular}{l}
Notes:
\[
\left(\mathrm{t}_{\mathrm{R}}, \mathrm{t}_{\mathrm{F}}=10 \text { to } 30 \mathrm{~ns}\right.
\] \\
*The baud rate with
\end{tabular} & ernal & \multicolumn{4}{|l|}{Notes:
\[
\left(t_{R}, t_{F}=10 \text { to } 30 \mathrm{~ns}\right)
\]} & \[
\mathrm{t}_{\mathrm{CCY}}
\] \\
\hline
\end{tabular}


Figure 20. Transmit Timing with External Clock


Figure 21. Receive External Clock Timing


Figure 22. Interrupt and Output Timing

\section*{AC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min & Max & Min & Max & \\
\hline \(\emptyset 2\) Cycle Time & \(\mathrm{t}_{\mathrm{CYC}}\) & 1000 & - & 500 & - & ns \\
\hline \(\emptyset 2\) Pulse Width & \(\mathrm{t}_{\mathrm{C}}\) & 400 & - & 200 & - & ns \\
\hline Address Set-Up Time & \(\mathrm{t}_{\text {ACW }}\) & 120 & - & 60 & - & ns \\
\hline Address Hold Tıme & \(t_{\text {CAH }}\) & 0 & - & 0 & - & ns \\
\hline R/్̄W Set-Up Time & \(\mathrm{t}_{\text {WCW }}\) & 120 & - & 60 & - & ns \\
\hline R/W Hold Time & \(\mathrm{t}_{\text {cWH }}\) & 0 & - & 0 & - & ns \\
\hline Data Bus Set-Up Tıme & \(\mathrm{t}_{\text {DCW }}\) & 120 & - & 60 & - & ns \\
\hline Data Bus Hold Tıme & \(\mathrm{t}_{\mathrm{HW}}\) & 20 & - & 10 & - & ns \\
\hline Read Access Tıme (Valıd Data) & \(\mathrm{t}_{\mathrm{CDR}}\) & - & 200 & - & 100 & ns \\
\hline Read Hold Tıme & \(\mathrm{t}_{\mathrm{HR}}\) & 20 & - & 10 & - & ns \\
\hline Bus Active Tıme (Invalid Data) & \(\mathrm{t}_{\text {CDA }}\) & 40 & - & 20 & - & ns \\
\hline
\end{tabular}

\section*{Notes:}
1. \(\mathrm{V}_{\mathrm{cc}}=5 \mathrm{OV} \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

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|l|c|c|}
\hline Parameter & Symbol & \multicolumn{1}{|c|}{ Value } & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & Vdc \\
\hline Output Voltage & \(\mathrm{V}_{\mathrm{OUT}}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
0 to +70 \\
-40 to +85
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{OPERATING CONDITIONS}
\begin{tabular}{|l|c|c|}
\hline Parameter & Symbol & Value \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & \(5 \mathrm{~V} \pm 5 \%\) \\
\hline Temperature Range & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
\(0^{\circ}\) to \(70^{\circ} \mathrm{C}\) \\
Commercial
\end{tabular} \\
\begin{tabular}{l} 
Industrial
\end{tabular} & & \(0^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\)
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.\) to \(T_{H}\), unless otherwise noted \()\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max & Unit & Test Conditions \\
\hline Input High Voltage & \(\mathrm{V}_{\mathrm{IH}}\) & 2.0 & - & \(\mathrm{V}_{\mathrm{CC}}\) & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\mathrm{IL}}\) & -0.3 & - & +0.8 & V & \\
\hline \begin{tabular}{l}
Input Leakage Current: \\
\(\emptyset 2, R / \bar{W}, \overline{R E S}, C S O, \overline{C S 1}, R S 0, R S 1, \overline{C T S}, R \times D, \overline{D C D}, D S R\)
\end{tabular} & IN & - & \(\pm 1\) & \(\pm 2.5\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& V_{\text {IN }}=0 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{CC}} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Input Leakage Current (Three State Off)
DO-D7 & \({ }_{\text {TS }}\) I & - & \(\pm 2\) & \(\pm 10\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Output High Voltage: DO-D7, TxD, RxC, \(\overline{R T S}, \overline{D T R}\) & \(\mathrm{V}_{\mathrm{OH}}\) & 2.4 & - & - & V & \[
\begin{aligned}
& V_{C C}=4.75 \mathrm{~V} \\
& I_{\text {LOAD }}=-100 \mu \mathrm{~A}
\end{aligned}
\] \\
\hline Output Low Voltage: D0-D7, TxD, RxC, \(\overline{R T S}, \overline{D T R}, \overline{\mathrm{RQ}}\) & \(\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}
\] \\
\hline Output High Current (Sourcing): D0-D7, TxD, RxC, \(\overline{\text { RTS }}, \overline{D T R}\) & IOH & -200 & -400 & - & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}\) \\
\hline 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}\) \\
\hline Output Leakage Current (off state): \(\overline{\mathrm{RQ}}\) & loff & - & & 10 & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\text {OUT }}=5.0 \mathrm{~V}\) \\
\hline Power Dissipation & \(\mathrm{P}_{\mathrm{D}}\) & - & 7 & 10 & mW/MHz & \\
\hline Input Capacitance All except \(\emptyset 2\) \(\emptyset 2\) & \[
\begin{aligned}
& \mathrm{C}_{\mathrm{CLK}} \\
& \mathrm{C}_{\text {IN }}
\end{aligned}
\] & - & & \[
\begin{aligned}
& 20 \\
& 10
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{pF} \\
& \mathrm{pF}
\end{aligned}
\] & \[
\begin{aligned}
& \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}
\] \\
\hline Output Capacitance & \(\mathrm{C}_{\text {OUt }}\) & - & & 10 & pF & \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. All units are direct current (dc) except for capacitance. \\
2. Negative sign indicates outward current flow, positive indicates inward flow. \\
3. Typical values are shown for \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) and \(\mathrm{TA}=25^{\circ} \mathrm{C}\).
\end{tabular}} \\
\hline
\end{tabular}

\section*{PACKAGE DIMENSIONS}


\section*{R65C52 \\ DUAL ASYNCHRONOUS COMMUNICATIONS INTERFACE ADAPTER (DACIA)}

\section*{PRELIMINARY}

\section*{DESCRIPTION}

The Rockwell CMOS R65C52 Dual Asynchronous Communications Interface Adapter (DACIA) provides an easily implemented, program controlled 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.

\section*{FEATURES}
- Low power CMOS N-well silicon gate technology
- Two independent full duplex channels with buffered receivers and transmitters.
- Data set/modem control functions
- Internal baud rate generator with 15 programmable baud rates (50 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 \mathrm{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.

\section*{ORDERING INFORMATION}



Note: N/C indicates no connection

Figure 1. R65C52 Pin Configuration

\section*{INTERFACE SIGNALS}

Figure 2 shows the DACIA interface signals associated with the microprocessor and the modem.
DATA BUS (DO-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.

\section*{READ/WRITE (R/ \(\overline{\mathbf{W}}\) )}

The \(R / \bar{W}\) input, generated by the microprocessor, controls the direction of data transfer. A high on the R/W line indicates a read cycle, while a low indicates a write cycle.

\section*{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{\mathrm{CS}}\).

\section*{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 \$OF, 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.


Figure 2. DACIA Interface Signals

\section*{CLEAR TO SEND ( \(\overline{\mathbf{C T S} 1, ~ \overline{C T S 2})}\)}

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 \(\overline{\mathrm{CTS}}\) status bit in the CSR reflects the current high or low state of CTS.

\section*{DATA CARRIER DETECT ( \(\overline{\text { DCD1 }}, \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{D C D}\) line.

\section*{DATA SET READY ( \(\overline{\mathrm{DSR1}}, \overline{\mathrm{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 CSR reflects the current state of the \(\overline{\mathrm{DSR}}\) line.

\section*{REQUEST TO SEND ( \(\overline{\operatorname{RTS} 1}, \overline{R T S 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{\text { RTS }}\) line is reflected by the \(\overline{\text { RTS }}\) bit in the CSR.

\section*{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{D T R}\) line is reflected by the \(\overline{\text { DTR }}\) bit in the CSR.

\section*{INTERRUPT REQUEST ( \(\overline{\mathrm{IRQ1}}, \overline{\mathrm{RQ2}})\)}

The \(\overline{\mathrm{RQ}}\) lines are open-drain outputs from the interrupt control logic. \(\overline{\mathrm{RQ} 1}\) 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{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{\[
\begin{aligned}
& \text { HEX } \\
& \text { ADDR }
\end{aligned}
\]} & \multicolumn{3}{|c|}{REGISTER SELECT LINES} & \multicolumn{2}{|l|}{CONTROL AND FORMAT REGISTER BITS} & \multirow[b]{2}{*}{\[
\begin{aligned}
& \text { REG } \\
& \text { ABBR }
\end{aligned}
\]} & \multicolumn{2}{|c|}{REGISTER ACCESS} \\
\hline & RS2 & RS1 & RS0 & CFR-7 & CFR-6 & & WRITE & READ \\
\hline 00 & L & L & L & - & - & IER1 ISR1 & INTERRUPT ENABLE REGISTER 1 & INTERRUPT STATUS REGISTER 1 \\
\hline \multirow[b]{2}{*}{01} & \multirow[b]{2}{*}{L} & \multirow[b]{2}{*}{\(L\)} & \multirow[b]{2}{*}{H} & 0 & - & CFR1 SR1 & CONTROL REGISTER 1 & STATUS REGISTER 1 \\
\hline & & & & 1 & - & CFR1 & FORMAT REGISTER 1 & INVALID \\
\hline \multirow[b]{2}{*}{02} & \multirow[b]{2}{*}{L} & \multirow[b]{2}{*}{H} & \multirow[b]{2}{*}{L} & - & 0 & CDR1 & COMPARE DATA REGISTER 1 & INVALID \\
\hline & & & & - & 1 & TBR1 & TRANSMIT BREAK REGISTER 1 & INVALID \\
\hline 03 & L & H & H & - & - & TDR1 RDR1 & TRANSMIT DATA REGISTER 1 & RECEIVE DATA REGISTER 1 \\
\hline 04 & H & L & L & - & - & IER2 ISR2 & INTERRUPT ENABLE REGISTER 2 & INTERRUPT STATUS REGISTER 2 \\
\hline \multirow[b]{2}{*}{05} & \multirow[b]{2}{*}{H} & \multirow[b]{2}{*}{L} & \multirow[b]{2}{*}{H} & 0 & - & \[
\begin{gathered}
\text { CFR2 } \\
\text { SR2 }
\end{gathered}
\] & CONTROL REGISTER 2 & STATUS REGISTER 2 \\
\hline & & & & 1 & - & CFR2 & FORMAT REGISTER 2 & INVALID \\
\hline \multirow[b]{2}{*}{06} & \multirow[b]{2}{*}{H} & \multirow[b]{2}{*}{H} & \multirow[b]{2}{*}{L} & - & 0 & CDR2 & COMPARE DATA REGISTER 2 & INVALID \\
\hline & & & & - & 1 & TBR2 & TRANSMIT BREAK REGISTER 2 & INVALID \\
\hline 07 & H & H & H & - & - & TDR2 RDR2 & TRANSMIT DATA REGISTER 2 & RECEIVE DATA REGISTER 2 \\
\hline
\end{tabular}

\section*{FUNCTIONAL DESCRIPTION}

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

\section*{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{RQQ}}\).


Figure 3. DACIA Block Diagram

\section*{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 low and \(\overline{C S}\) is low, the Data Bus Buffer writes data from the internal data bus to the system data lines. When \(R / \bar{W}\) is high and \(\overline{C S}\) is low, data is driven into the DACIA from the system data bus. Table 2 summarizes the Data Bus Buffer states.

Table 2. Data Bus Buffer Summary
\begin{tabular}{|cc|l|}
\hline \multicolumn{2}{|c|}{\begin{tabular}{l} 
Control \\
R/ Signals \\
L \\
\(\mathbf{C S}\)
\end{tabular}} & Data Bus Buffer State \\
\hline L & L & Write Mode - Tri-State \\
\hline\(H\) & L & Read Mode - Output Data \\
\hline
\end{tabular}

\section*{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.

\section*{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.

\section*{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 XTLI pin may be driven with an externally generated clock in which case the XTALO pin must float.

\section*{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.

\section*{Transmitter Clock (TxC)}

This pin is the transmitter 16x clock input when the baud rate generator is programmed for external clock. Figure 16 shows timing considerations for TxC.

\section*{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).

\section*{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

\section*{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.

\section*{Control Register (CFR Addressed with Bit 7 = 0)}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & TBR/CDR & \[
\begin{aligned}
& \text { NO. } \\
& \text { STOP } \\
& \text { BITS }
\end{aligned}
\] & ECHO & \multicolumn{4}{|l|}{BAUD RATE SELECTION} \\
\hline
\end{tabular}
\begin{tabular}{cl}
\begin{tabular}{c} 
Bit 7 \\
0
\end{tabular} & \begin{tabular}{l} 
Control or Format Register \\
Control Register
\end{tabular} \\
Bit 6 & TBR/CDR \\
1 & Access the Transmit Break Register (TBR) \\
0 & Access the Compare Data Register (CDR)
\end{tabular}
\begin{tabular}{cl} 
Bit 5 & Number of Stop Bits Per Character \\
1 & Two stop bits \\
0 & One stop bit \\
& \\
Bit 4 & Echo Selection (ECHO) \\
1 & Echo actıvated \\
0 & Echo deactivated
\end{tabular}

Bits 3-0 Baud Rate Selection
\begin{tabular}{lllll}
3 & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) & Baud Rate \\
0 & 0 & 0 & 0 & 50 \\
0 & 0 & 0 & 1 & 109.2 \\
0 & 0 & 1 & 0 & 134.58 \\
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 & 9600 \\
1 & 1 & 0 & 1 & 19200 \\
1 & 1 & 1 & 0 & 38400 \\
1 & 1 & 1 & 1 & External TxC and RxC Clocks
\end{tabular}

Format Register (CFR Addressed with Bit \(7=1\) )
\begin{tabular}{|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6} \quad \mathbf{5}\) & \(\mathbf{4} \quad \mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline \(\mathbf{1}\) & \begin{tabular}{c} 
NUMBER \\
OF DATA \\
BITS
\end{tabular} & \begin{tabular}{c} 
PARITY \\
SELECTION
\end{tabular} & \begin{tabular}{c} 
PARITY \\
ENABLE
\end{tabular} & \begin{tabular}{|c}
\(\overline{\text { DTR }}\) \\
CONTROL
\end{tabular} & \begin{tabular}{c}
\(\overline{\text { RTS }}\) \\
CONTROL
\end{tabular} \\
\hline
\end{tabular}
\begin{tabular}{cl} 
Bit 7 & Control or Format Register \\
1 & Format Register
\end{tabular}
\begin{tabular}{rll} 
Bits & \(6-5\) & Number of Data Bits Per Character \\
\(\mathbf{6}\) & \(\mathbf{5}\) & No. Bits \\
0 & 0 & 5 \\
0 & 1 & 6 \\
1 & 0 & 7 \\
1 & 1 & 8
\end{tabular}

\section*{Bits 4-3 Parity Mode Selection}
\begin{tabular}{|c|c|}
\hline 43 & Selects \\
\hline 00 & Odd Parity \\
\hline 01 & Even Parity \\
\hline 10 & Mark Parity \\
\hline 11 & Space Parity \\
\hline Bit 2 & Parity Enable \\
\hline 1 & Parity as specified by bits 4-3 \\
\hline 0 & No Parity \\
\hline Bit 1 & DTR Control \\
\hline 1 & \(\overline{\text { DTR }}\) high \\
\hline 0 & \(\overline{\text { DTR }}\) low \\
\hline Bit 0 & \(\overline{\text { RTS }}\) Control \\
\hline 1 & RTS high \\
\hline 0 & RTS low \\
\hline
\end{tabular}

\section*{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 writıng 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 \(\$ F F\) 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:
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline & & & & & & FRM & \\
\hline CLEAR/ & TDR & & & & PARITY & OVR & RDR \\
\hline SET & EMPTY & IE & IE & DSR & ERROR & BRK & FULL \\
\hline BITS & IE & & & & IE & CPR & IE \\
\hline
\end{tabular}

\section*{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.
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline \begin{tabular}{c} 
ANY \\
BIT \\
SET
\end{tabular} & TDR & \(\overline{\text { CTS }}\) & & \(\overline{\text { DCD }}\) & \(\overline{\text { DSR }}\) & & \begin{tabular}{c} 
FRM \\
PARITY
\end{tabular} \\
OVR & RDR \\
TRANS & TRANS & TRANS & ERROR & \begin{tabular}{c} 
BRK \\
RULL \\
FPR
\end{tabular} \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline Bit 7 & Any Bit Set \\
\hline 1 & Any bit (6 through 0) has been set to a 1 \\
\hline 0 & No bits have been set to a 1 \\
\hline Bit 6 & Transmit Data Register Empty (TDR EMPTY) \\
\hline 1 & Transmit Data Register has been transferred to the shift register \\
\hline 0 & New data has been written to the Transmit Data Register \\
\hline Bit 5 & Transition On \(\overline{\mathrm{CTS}}\) Line ( \(\overline{\mathbf{C T S}}\) TRANS) \\
\hline 1 & A positive or negative transition has occurred on CTS \\
\hline 0 & No transition has occurred on CTS, or ISR has been Read \\
\hline Bit 4 & Transition On \(\overline{\mathrm{DCD}}\) Line ( \(\overline{\mathrm{DCD}}\) TRANS) \\
\hline 1 & A positive or negative transition has occurred on \(\overline{D C D}\) \\
\hline 0 & No transition has occurred on \(\overline{\mathrm{DCD}}\), or ISR has been Read \\
\hline Bit 3 & Transition On \(\overline{\mathrm{DSR}}\) Line ( \(\overline{\mathrm{DSR}}\) TRANS) \\
\hline 1 & A positive or negative transition has occurred on \(\overline{\text { DSR }}\) \\
\hline 0 & No transition has occurred on \(\overline{\mathrm{DSR}}\), or ISR has been Read \\
\hline Bit 2 & Parity Error \\
\hline 1 & A parity error has occurred in received data \\
\hline 0 & No parity error has occurred, or the Receive Data Register (RDR) has been Read \\
\hline Bit 1 & Frame Error, Overrun or Break (FRM, OVR, BRK, CPR) \\
\hline 1 & A framing error, receive overrun, or receive break has occured, or, in Compare Mode \\
\hline 0 & No error, overrun, break has occured, RDR has been Read, or not in Compare Mode \\
\hline Bit 0 & Receive Data Register Full (RDR FULL) \\
\hline 1 & Shift register data has been transferred to Receive Data Register \\
\hline 0 & Receive Data Register has been Read \\
\hline
\end{tabular}

\section*{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.
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline \begin{tabular}{c} 
FRAMING \\
ERROR
\end{tabular} & \begin{tabular}{c} 
TRANS \\
UNDR
\end{tabular} & \(\overline{\mathrm{CTS}}\) \\
STATUS
\end{tabular}
\begin{tabular}{|c|c|}
\hline Bit 7 & Framing Error \\
\hline 1 & A framing error occurred in receive data \\
\hline 0 & No framing error occurred, or the RDR was Read \\
\hline Bit 6 & Transmitter Underrun (TRANS UNDR) \\
\hline 1 & Transmit shift register is empty and TDRE bits in IER and ISR are set \\
\hline 0 & A write to the TDR has occurred \\
\hline Bit 5 & \(\overline{\text { CTS Status }}\) \\
\hline 1 & A low-to-high transition occurred on CTS line \\
\hline 0 & A high-to-low transition occurred on CTS line \\
\hline Bit 4 & \(\overline{\text { DCD Status }}\) \\
\hline 1 & A low-to-high transition occurred on \(\overline{D C D}\) line \\
\hline 0 & A high-to-low transition occurred on \(\overline{\mathrm{DCD}}\) line \\
\hline Bit 3 & \(\overline{\text { DSR }}\) Status \\
\hline 1 & A low-to-high transition occurred on \(\overline{\mathrm{DSR}}\) line \\
\hline 0 & A high-to-low transition occurred on \(\overline{\mathrm{DSR}}\) line \\
\hline Bit 2 & REC Break \\
\hline 1 & A Receive Break has occurred \\
\hline 0 & No Receive Break occurred, or RDR, was read \\
\hline Bit 1 & \(\overline{\text { DTR Status }}\) \\
\hline 1 & A low-to-high transition occurred on \(\overline{\text { DTR }}\) line \\
\hline 0 & A high-to-low transition occurred on DTR line \\
\hline Bit 0 & \(\overline{\text { RTS Status }}\) \\
\hline 1 & A low-to-high transition occurred on \(\overline{\text { RTS }}\) line \\
\hline 0 & A high-to-low transition occurred on RTS line \\
\hline
\end{tabular}

\section*{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:
\begin{tabular}{|cccccc|c|c|}
\hline \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline & & NOT USED & & & \begin{tabular}{c} 
TRANS \\
BRK
\end{tabular} & \begin{tabular}{c} 
PAR/ \\
ADDR
\end{tabular} \\
\hline
\end{tabular}

Bits 7-2 Not used (don't care)
\begin{tabular}{cl} 
Bit 1 & Transmit Break (TRANS BRK) \\
1 & Transmit continuous Break until disabled \\
0 & Resume normal transmıssion \\
& \\
Bit \(\mathbf{0}\) & \begin{tabular}{l} 
Parity/Address Recognition (PAR ADDR) \\
1
\end{tabular} \\
0 & Send value of parity to ISR bit 2 \\
0 & Return to normal Parity Error recognition mode
\end{tabular}

\section*{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 and the FRM/OVR/BRK/CPR bit (bit 1) on the ISR is set 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.

\section*{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.

\section*{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
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{8}{|c|}{REGISTER BIT NUMBERS} \\
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline CLEAR/SET
BITS & TDR EMPTY IE & \[
\underset{\text { IE }}{\overline{\text { CTS }}}
\] & \[
\overline{\mathrm{DCD}}
\] & \[
\begin{gathered}
\overline{\mathrm{DSR}} \\
\mathrm{IE}
\end{gathered}
\] & PARITY ERROR IE & FRM, OVR BRK, CPR IE & RDR FULL IE \\
\hline ANY BIT SET & TDR EMPTY & \begin{tabular}{l}
\(\overline{C T S}\) \\
TRANS
\end{tabular} & \[
\begin{aligned}
& \overline{D C D} \\
& \text { TRANS }
\end{aligned}
\] & \[
\begin{gathered}
\overline{\text { DSR }} \\
\text { TRANS }
\end{gathered}
\] & PARITY ERROR & FRM, OVR BRK, CPR & \begin{tabular}{l}
RDR \\
FULL
\end{tabular} \\
\hline FRAMING ERROR & TRANS UNDR & \[
\begin{aligned}
& \overline{\text { CTS }} \\
& \text { STATUS }
\end{aligned}
\] & \[
\begin{aligned}
& \overline{\mathrm{DCD}} \\
& \text { STATUS }
\end{aligned}
\] & \[
\begin{aligned}
& \overline{D S R} \\
& \text { STATUS }
\end{aligned}
\] & REC BREAK & \[
\begin{aligned}
& \overline{\text { DTR }} \\
& \text { STATUS }
\end{aligned}
\] & \(\overline{R T S}\) STATUS \\
\hline 0 & TBR/ CDR & NO. STOP BITS & ECHO & & BAUD R & SELECTION & \\
\hline 1 & NUM & ITS & & \[
\begin{aligned}
& \text { TY } \\
& \text { TION }
\end{aligned}
\] & PARITY ENABLE & \begin{tabular}{l}
\(\overline{\text { DTR }}\) \\
CONTROL
\end{tabular} & \(\overline{\text { RTS }}\) CONTROL \\
\hline \multicolumn{6}{|c|}{NOT USED} & TRANS BRK & PAR/ ADDR \\
\hline \multicolumn{8}{|c|}{COMPARE BITS (ADDRESS RECOGNITION)} \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline REGISTER & \(\overline{\text { RES }}\) \\
\hline INTERRUPT ENABLE REGISTERS & \$80 \\
\hline INTERRUPT STATUS REGISTERS & - \\
\hline Status REGISTERS & - \\
\hline CONTROL REGISTERS AND FORMAT REGISTERS & - \\
\hline TRANSMIT BREAK REGISTERS & \$0F \\
\hline \begin{tabular}{l}
COMPARE \\
DATA \\
REGISTERS
\end{tabular} & - \\
\hline
\end{tabular}

\section*{CONTINUOUS DATA TRANSMIT}

In the normal operating mode, the TDRE bit in the ISR signals the MPU that the DACIA is ready to accept the next data word. An \(\overline{\mathrm{RQ}}\) occurs if the corresponding TDRE IRQ enable bit is set in the IER. The TDRE bit is set at the beginning of the start bit.

When the MPU writes a word to the TDR the TDRE bit is cleared. In order to maintain continuous transmission the TDR must be loaded before the stop bit(s) are ended. Figure 6 shows the relationship between \(\overline{\mathrm{RQ}}\) and TxD for the Continuous Data Transmit mode.


Figure 6. Continuous Data Transmit

\section*{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

\section*{TRANSMIT UNDERRUN CONDITION}

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


\section*{EFFECTS OF CTS ON TRANSMITTER}

The \(\overline{\mathrm{CTS}}\) control line controls the transmission of data or the handshaking of data to a "busy" device (such as a printer). When the \(\overline{\text { 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{\mathrm{CTS}}\) bit in the ISR is again set. Figure 9 shows the relationship of \(\overline{\mathrm{RQ}}\), TxD , and \(\overline{\mathrm{CTS}}\) for the effects of \(\overline{\mathrm{CTS}}\) on the transmitter.


Figure 9. Effects of CTS on Transmitter

\section*{EFFECTS OF OVERRUN ON RECEIVER}

If the processor does not read the RDR before the stop bit of the next word, an overrun error occurs, the overrun bit is set in the ISR, and the new data word is not transferred to the RDR. The RDR contains the last word not read by the MPU and all 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

\section*{ECHO MODE TIMING}

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


Figure 11. Echo Mode Timing

\section*{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 \(\overline{\mathrm{RQ}}\) and RxD when a framing error occurs.


Figure 12. Framing Error

\section*{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{IRQ}}\) and TxD for a Transmit Break character.


Figure 13. Transmit Break Character

\section*{RECEIVE BREAK CHARACTER}

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


Figure 14. Receive Break Character

\section*{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.

\section*{GENERATION OF NON-STANDARD BAUD RATES}

\section*{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.

\section*{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
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{4}{|c|}{Control Register Bits} & \multirow[t]{2}{*}{Divisor Selected For The Internal Counter} & \multirow[t]{2}{*}{Baud Rate Generated With \(\mathbf{3 . 6 8 6 4}\) MHz Crystal} & \multirow[t]{2}{*}{Baud Rate Generated With a Crystal of Frequency (f)} \\
\hline 3 & 2 & 1 & 0 & & & \\
\hline 0 & 0 & 0 & 0 & 73,728 & \(\left(36864 \times 10^{6}\right) / 73,728=50\) & f/73,728 \\
\hline 0 & 0 & 0 & 1 & 33,538 & \(\left(36864 \times 10^{6}\right) / 33,538=10992\) & f/33,538 \\
\hline 0 & 0 & 1 & 0 & 27,408 & \(\left(36864 \times 10^{6}\right) / 27,408=13458\) & f/27,408 \\
\hline 0 & 0 & 1 & 1 & 24,576 & \(\left(3.6864 \times 10^{6}\right) / 24,576=150\) & f/24,576 \\
\hline 0 & 1 & 0 & 0 & 12,288 & \(\left(36864 \times 10^{6}\right) / 12,288=300\) & f/12,288 \\
\hline 0 & 1 & 0 & 1 & 6,144 & \(\left(36864 \times 10^{6}\right) / 6,144=600\) & f/6,144 \\
\hline 0 & 1 & 1 & 0 & 3,072 & \(\left(3.6864 \times 10^{6}\right) / 3,072=1,200\) & f/3,072 \\
\hline 0 & 1 & 1 & 1 & 2,048 & \(\left(36864 \times 10^{6}\right) / 2,048=1,800\) & f/2,048 \\
\hline 1 & 0 & 0 & 0 & 1,536 & \(\left(36864 \times 10^{6}\right) / 1,536=2,400\) & f/1,536 \\
\hline 1 & 0 & 0 & 1 & 1,024 & \(\left(36864 \times 10^{6}\right) / 1,024=3,600\) & f/1,024 \\
\hline 1 & 0 & 1 & 0 & 768 & \(\left(36864 \times 10^{6}\right) / 768=4,800\) & f/768 \\
\hline 1 & 0 & 1 & 1 & 512 & \(\left(36864 \times 10^{6}\right) / 512=7,200\) & f/512 \\
\hline 1 & 1 & 0 & 0 & 384 & \(\left(3.6864 \times 10^{6}\right) / 384=9,600\) & f/384 \\
\hline 1 & 1 & 0 & 1 & 192 & \(\left(36864 \times 10^{6}\right) / 192=19,200\) & f/192 \\
\hline 1 & 1 & 1 & 0 & 96 & \(\left(3.6864 \times 10^{6}\right) / 96=38,400\) & f/96 \\
\hline 1 & 1 & 1 & 1 & 16 & \multicolumn{2}{|l|}{TxC/16 \(=\) Baud Rate or RxC/16 \(=\) Baud Rate} \\
\hline
\end{tabular}


Figure 15. DACIA External Clock Timing - Receive Data


Figure 16. DACIA External Clock Timing - Transmit Data

\section*{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
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Characteristic} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{2 MHz} & \multicolumn{2}{|c|}{4 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min & Max & Min & Max & \\
\hline R/ \(\bar{W}\), RSO-RS2 Valid to \(\overline{\text { CS }}\) Low (Setup Time) & \(t_{\text {wc }}\) & 0 & - & 0 & - & ns \\
\hline \(\overline{\mathrm{CS}}\) Low to R/ \(\bar{W}\), RSO-RS2 (Hold Time) & \(t_{\text {cWh }}\) & 65 & - & 65 & - & ns \\
\hline \(\overline{\mathrm{CS}}\) Low to Data Valid & \(\mathrm{t}_{\text {CDV }}\) & - & 100 & - & 100 & ns \\
\hline \(\overline{\mathrm{CS}}\) High to Data Invalid (Hold Time) & \(\mathrm{t}_{\mathrm{CDZ}}\) & - & 10 & - & 10 & ns \\
\hline Data Valid to \(\overline{\mathbf{C S}}\) High & \(t_{\text {DVCH }}\) & 20 & & 20 & & ns \\
\hline \begin{tabular}{l}
Note: \\
1. All times are in nanoseconds.
\end{tabular} & & & & & & \\
\hline
\end{tabular}


DACIA Read Cycle Waveforms


DACIA Write Cycle Waveforms

TRANSMIT/RECEIVE TIMING
\begin{tabular}{|c|c|c|c|c|}
\hline Characteristic & Symbol & Min & Max & Unit \\
\hline Transmit/Receive Clock Rate & \(\mathrm{t}_{\mathrm{CCY}}\) & 250 & - & ns \\
\hline Transmit/Receive Clock High Time & \(\mathrm{t}_{\mathrm{CH}}\) & 100 & - & ns \\
\hline Transmit/Receive Clock Low Time & \(\mathrm{t}_{\mathrm{CL}}\) & 100 & - & ns \\
\hline XTALI to TxD Propagation Delay & \(t_{\text {DD }}\) & - & 250 & ns \\
\hline XTALI to IRQ Propagation Delay & \(t_{\text {DI }}\) & - & 250 & ns \\
\hline \(\overline{\mathrm{CTS}}, \overline{\mathrm{DCD}}, \overline{\mathrm{DSR}}\) to \(\overline{\mathrm{IRQ}}\) & \(\mathrm{t}_{\mathrm{CTI}}\) & - & 150 & ns \\
\hline \(\overline{\text { IRQ }}\) Propagation Delay (Clear) & \(\mathrm{t}_{\mathrm{IRQ}}\) & - & 150 & ns \\
\hline \(\overline{\text { RTS }}\), \(\overline{\text { TTR Propagation Delay }}\) & \({ }^{\text {DLLY }}\) & - & 150 & ns \\
\hline
\end{tabular}

Note:
1. All times are in nanoseconds.


DACIA Transmit/Receive Timing

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline Parameter & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & Vdc \\
\hline Output Voltage & \(\mathrm{V}_{\mathrm{OUT}}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & Vdc \\
\hline \begin{tabular}{l} 
Operatıng Temperature \\
Commercıal \\
Industrıal
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
0 to +70 \\
-40 to +85
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{OPERATING CONDITIONS}
\begin{tabular}{|l|c|c|}
\hline Parameter & Symbol & Value \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & \(5 \mathrm{~V} \pm 5 \%\) \\
\hline Temperature Range & \(\mathrm{T}_{\mathrm{A}}\) & \\
Commercial & & \(0^{\circ}\) to \(70^{\circ} \mathrm{C}\) \\
Industrial & & \(40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0 \mathrm{~V}, T_{A}=T_{L}\right.\) to \(T_{H}\), unless otherwise noted \()\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Characteristic & Symbol & Min & Typ & Max & Unit & Test Conditions \\
\hline Input High Voltage Except XTALI and XTALO XTALI and XTALO & \(\mathrm{V}_{\mathrm{IH}}\) & \[
\begin{aligned}
& +2.0 \\
& +2.4
\end{aligned}
\] & - & \[
\begin{aligned}
& v_{c c}+0.3 \\
& v_{c c}+0.3
\end{aligned}
\] & V & \\
\hline Input Low Voltage Except XTALI and XTALO XTALI and XTALO & \(\mathrm{V}_{\text {IL }}\) & \[
\begin{aligned}
& -0.3 \\
& -0.3
\end{aligned}
\] & - & \[
\begin{aligned}
& +0.8 \\
& +0.4
\end{aligned}
\] & V & \\
\hline \begin{tabular}{l}
Input Leakage Current \\
R/ \(\bar{W}, \overline{R E S}, R S 0, R S 1, R S 2, R \times D, \overline{C T S}, \overline{D C D}, \overline{D S R}, \overline{R \times C}\), \(\overline{T X C}, \overline{\mathrm{CS}}\)
\end{tabular} & 1 N & - & 10 & 50 & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& V_{\text {IN }}=0 \mathrm{~V} \text { to } V_{C C} \\
& V_{C C}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Input Leakage Current for Three-State Off D0-D7 & \(\mathrm{I}_{\text {TSI }}\) & - & \(\pm 2\) & 10 & \({ }_{\mu} \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IN}}=0.4 \mathrm{~V} \text { to } 2.4 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Output High Voltage 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}
\] \\
\hline Output Low Voltage DO-D7, TxD, CLK OUT, RTS, DTR & \(\mathrm{V}_{\text {OL }}\) & - & - & +0.4 & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V} \\
& \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}
\end{aligned}
\] \\
\hline Output Leakage Current (Off State) \(\overline{\mathrm{RQ}}\) & \(\mathrm{l}_{\text {OFF }}\) & - & \(\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}
\] \\
\hline Power Dissipation & \(P_{\text {D }}\) & - & & 10 & mW/MHz & \\
\hline 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}
\] \\
\hline Output Capacitance & \(\mathrm{C}_{\text {OUT }}\) & - & - & 10 & pF & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{Notes:}
1. All units are direct current (dc) except for capacitance.

2 Negative sign indıcates outward current flow, positive indicates inward flow.
3. Typical values are shown for \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) and \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\).

\section*{PACKAGE DIMENSIONS}


\title{
R6265, R6765 DOUBLE-DENSITY FLOPPY DISK CONTROLLER (DDFDC)
}

\section*{PRELIMINARY}

\section*{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 R6265 interfaces to the \(31 / 2^{\prime \prime}\) Sony Micro Floppy disk drive as well as \(51 / 4^{\prime \prime}\) and \(8^{\prime \prime}\) disk drives. The R6265 writes and reads in the Sony compatible format and can also read from disks formatted in IBM compatible format. A combination of up to four \(31 / 2^{\prime \prime}, 51 / 4^{\prime \prime}\) and \(8^{\prime \prime}\) drives can be interfaced to and controlled by the R6265. The R6265 is pin-compatible with, and electrically identical to, the R6765.

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 R6265/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 DDFDC executes 15 separate multi-byte commands:
\begin{tabular}{ll} 
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) &
\end{tabular}

Read Data
Read Deleted Data
Write Deleted Data
Read a Track
Read ID

Recalibrate (Restore to Track 0)

\section*{FEATURES}
- Address mark detection circuitry
- Software control of
-Track stepping rate
-Head load time
-Head unload time
- Writes in:
-IBM compatible (single- and double-density format (R6765)
-Sony compatible (EMCA) format (R6265)
- Reads data written in:
-IBM compatible format (R6265 and R6765)
-Sony compatible format (R6265)
- 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
- The R6765 replaces the NEC \(\mu\) PD765A and Intel 8272
- The R6265 replaces the NEC \(\mu\) PD7265
- Single phase 4 or 8 MHz clock (R6765) or 8 MHz clock (R6265)
- Single +5 volt power supply

\section*{ORDERING INFORMATION}



Figure 1. DDFDC Input and Output Signals

\section*{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.

\section*{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. RST does not affect the Step Rate Time (SRT), Head Unload Time (HUT) or Head Load Time (HLT) set by a Specify command. If RDY goes high while RST is high, the DDFDC will assert INT within 1.024 ms . This interrupt can be cleared by issuing a Sense Interrupt Status command.
\(\overline{\mathbf{C S}}-C h i p\) 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}}=\) 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 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).
\(\overline{\mathbf{R D}}\)-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.

\section*{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.

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 \(\mathrm{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.

\section*{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—Voltage Controlled 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:
\begin{tabular}{|c|c|c|}
\hline \multirow{2}{*}{ Write Precompensation Status } & \multicolumn{2}{|c|}{ Preshift Outputs } \\
\cline { 2 - 3 } & PS0 & PS1 \\
\hline Normal & 0 & 0 \\
Late & 0 & 1 \\
Early & 1 & 0 \\
Invalid & 1 & 1 \\
\hline \(0=\) Low, \(1=\) High
\end{tabular}

\section*{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{\mathbf{R W}} / \mathrm{SEEK}\)-Read Write/Seek. Mode selection signal to the FDD which controls the multiplexer from the multiplexed signals. When \(\overline{\text { RW}} /\) SEEK is low, the Read/Write mode is commanded; when \(\overline{\mathrm{RW}} /\) SEEK is high, the Seek mode is commanded.
\begin{tabular}{|c|c|c|}
\hline\(\overline{\text { RW/SEEK }}\) & Mode & Active FDD Interface Signals \\
\hline Low & Read/Write & WP, FLT, LCT, FR \\
\hline High & Seek & TS, TRKO, DIR, STP \\
\hline
\end{tabular}

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, WPTTS 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{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.

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.

US0-US1-Unit Select. Output signals for floppy disk drive selection as follows:
\begin{tabular}{|c|c|c|}
\hline \multicolumn{2}{|c|}{ Unit Select } & \multirow{2}{*}{\begin{tabular}{c} 
Floppy Disk \\
Drive Select
\end{tabular}} \\
\hline USO & US1 & 0 \\
0 & 0 & 1 \\
0 & 1 & 2 \\
1 & 0 & 3 \\
1 & 1 & \\
\hline \(0=\) LOW, \(1=\) High \\
\hline
\end{tabular}

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 MFM = Low.

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

\section*{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 \(\overline{\mathrm{WR}}\), \(\overline{R D}\) and \(A O\) signals is shown below.
\begin{tabular}{|c|c|c|l|}
\hline A0 & \(\overline{\text { RD }}\) & \(\overline{\text { WR }}\) & \multicolumn{1}{|c|}{ Function } \\
\hline 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 \\
\hline \multicolumn{4}{|l}{} \\
\hline
\end{tabular}

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.

\section*{REGISTER DEFINITIONS}

Main Status Register (MSR)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline RQM & DIO & EXM & CB & D3B & D2B & D1B & DOB \\
\hline
\end{tabular}

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{\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 (DDFDC Busy) goes low is also \(12 \mu \mathrm{~s}\).

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

\section*{MSR}
\begin{tabular}{|c|c|}
\hline 7 & RQM -Request for Master. \\
\hline 0 & Data Register is not ready. \\
\hline 1 & Data Register is ready. \\
\hline MSR & \\
\hline \(\underline{6}\) & DIO -Data Input/Output. \\
\hline 0 & Data transfer is from system to the Data Register. \\
\hline 1 & Data transfer is from Data Register to the system. \\
\hline MSR & \\
\hline 5 & EXM -Execution Mode. (Non-DMA mode only). \\
\hline 0 & Execution phase ended, result phase begun. \\
\hline 1 & Execution phase started. \\
\hline
\end{tabular}

\section*{MSR}

4 CB -Controller (DDFDC) Busy.
\(\overline{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.
\(\overline{0} \quad\) 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.

\section*{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
\(\frac{1}{0}\) 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.

\section*{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)
\begin{tabular}{|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
\(\frac{7}{0} \quad \frac{6}{0} \quad\) IC \(\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.

\section*{STO}

5 SE -Seek End.
0 Seek command is not completed.
1 Seek command completed by DDFDC.
STO
4 EC -Equipment Check.
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)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{8}{|c|}{Bit Number} \\
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline RQM & DIO & EXM & CB & D3B & D2B & D1B & DOB \\
\hline \multicolumn{2}{|c|}{\multirow[b]{2}{*}{IC}} & \multirow{2}{*}{SE} & \multirow[b]{2}{*}{EC} & \multirow[b]{2}{*}{NR} & \multirow[b]{2}{*}{HD} & \multicolumn{2}{|c|}{US} \\
\hline & & & & & & US1 & USO \\
\hline EN & 0 & DE & OR & 0 & ND & NW & MA \\
\hline 0 & CM & DD & WT & SH & SN & BT & MD \\
\hline FLT & WP & RDY & TRKO & TS & HD & US1 & USO \\
\hline
\end{tabular}

Table 2. Command Symbol Description
\begin{tabular}{|c|c|c|}
\hline Symbol & Name & Description \\
\hline A0 & Address Line A0 & Controls selection of Main Status Register (A0 = low) or Data Regıster (A0 = high). \\
\hline D & Data & The data pattern which is going to be written into a sector \\
\hline D0-D7 & Data Bus & 8-bit data bus, where D0 is the least significant data line and D7 is the most significant data line. \\
\hline DTL & Data Length & When \(N\) is defined as 00, DTL is the number of data bytes to read from or write into the sector \\
\hline 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. \\
\hline 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. \\
\hline H & Head Address & Head number 0 or 1, as specified in ID field. \\
\hline 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). \\
\hline HLT & Head Load Time & The head load tıme in the FDD (2 to 254 ms in 2 ms increments). \\
\hline HUT & Head Unload Time & The head unload time after a read or write operation has occurred (16 to 240 ms in 16 ms increments) \\
\hline MF & FM or MFM Mode & When MF \(=0\), FM mode is selected; and when MF \(=1\), MFM mode is selected. \\
\hline 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 . \\
\hline N & Bytes/Sector & The number of data bytes written in a sector. \\
\hline ND & Non-DMA Mode & When ND \(=1\), operation is in the Non-DMA mode; when ND \(=0\), operation is in the DMA mode. \\
\hline NTN & New Track Number & A new track number, which will be reached as a result of the Seek command. Desired head position. \\
\hline PTN & Present Track Number & The track number at the completion of Sense Interrupt Status command. Present head position. \\
\hline R & Record (Sector) & The sector number to be read or written. \\
\hline R/W & Read/Write & Either read (R) or write (W) signal. \\
\hline ST & Sectors/Track & The number of sectors per track. \\
\hline SK & Skıp & Skip Deleted Data Address Mark. \\
\hline 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.) \\
\hline \[
\begin{aligned}
& \text { STO } \\
& \text { ST1 } \\
& \text { ST2 } \\
& \text { ST3 } \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
Status 0 \\
Status 1 \\
Status 2 \\
Status 3
\end{tabular} & 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. \\
\hline 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.' \\
\hline T & Track Number & The current/selected track number of the medium (0-255). \\
\hline US0,US1 & Unit Select & A selected drive number (0-3). \\
\hline
\end{tabular}


Status Register 1 (ST1)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline EN & 0 & \(D E\) & OR & 0 & ND & \(N W\) & \(M A\) \\
\hline
\end{tabular}

\section*{ST1}

7 EN -End of Track
\(\overline{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.
0 No error.
1 DDFDC detected a CRC error in ID field or the Data field.

\section*{ST1}

4 OR -Overrun.
No error.
DDFDC was not serviced by the system during data transfers, within a predetermined time interval.

ST1
3 -Not Used. Always Zero.
ST1
ND -No Data.
No error.
3 possible errors.
1. DDFDC cannot find sector specified in the Internal Data Register (IDR) 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.

\section*{ST1}

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

\section*{Status Register 2 (ST2)}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline 0 & CM & DD & WT & SH & SN & BT & MD \\
\hline
\end{tabular}

\section*{ST2}

ST2

\section*{ST2}

\section*{ST2}

ST2

\section*{ST2}

2 SN -Scan Not Satisfied.
0 No error.
1 DDFDC cannot find a sector on the track which meets the scan command condition.
\(7 \quad\)-Not Used. Always Zero.

6 CM -Control Mark.
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 which contained a Data Address Mark during execution of a Read Deleted Data command.

DD —Data Error in Data Field.
No error.
1 DDFDC detected a CRC error in the Data field.

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

3 SH -Scan Equal Hit.
0 No "equal" condition during a scan command.
1 "Equal" condition satisfied during a scan command.
-Not Used. Always Zero.
(20.

\section*{ST2}

1 BT —Bad Track.
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.

\section*{ST2}

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.

\section*{Status Register 3 (ST3)}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline FLT & WP & RDY & TRKO & TS & HD & US1 & USO \\
\hline
\end{tabular}

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

\section*{ST3}
\begin{tabular}{ll}
\(\mathbf{7}\) & FLT \\
\begin{tabular}{ll} 
Fault (FLT) signal from the FDD is low. \\
1 & Fault (FLT) signal from the FDD is high.
\end{tabular}
\end{tabular}
```

ST3
WP -Write Protect.
Write Protect (WP) signal from the FDD is low.
Write Protect (WP) signal from the FDD is high.

```
ST3
    \(\begin{array}{ll}\mathbf{5} & \text { RDY } \\ \frac{\text { Ready }}{0} & \text { Ready (RDY) signal from the FDD is low. } \\ 1 & \text { Ready (RDY) signal from the FDD is high. }\end{array}\)
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.

\section*{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.

\section*{COMMAND DESCRIPTION}

\section*{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 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 \(\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 \((\mathrm{SK}=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 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 \(S K=1\).

During disk data transfers from the DDFDC to the system, the DDFDC must be serviced by the system within \(27 \mu\) 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.

\section*{Command Phase:}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{9}{*}{W} & 1 & MT & MF & SK & 0 & 0 & 1 & 1 & 0 \\
\hline & 2 & X & X & X & X & X & HD & US1 & USO \\
\hline & 3 & \multicolumn{8}{|l|}{Track Number (T)} \\
\hline & 4 & \multicolumn{8}{|l|}{Head Number (H)} \\
\hline & 5 & \multicolumn{8}{|l|}{Sector Number (R)} \\
\hline & 6 & \multicolumn{8}{|l|}{Number of Data Bytes per Sector (N)} \\
\hline & 7 & \multicolumn{8}{|l|}{End of Track (EOT)} \\
\hline & 8 & \multicolumn{8}{|l|}{Gap Length (GPL)} \\
\hline & 9 & \multicolumn{8}{|l|}{Data Length (DTL)} \\
\hline
\end{tabular}

Table 3. DDFDC Transfer Capacity
\begin{tabular}{|c|c|c|c|c|}
\hline Multi-Track (MT) & MFM/FM (MF) & \begin{tabular}{l}
Bytes/Sector \\
( N )
\end{tabular} & Maximum Transfer Capacity (Bytes/Sector) (Number of Sectors) & Final Sector Read from Disk \\
\hline \[
\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 \\
\hline \[
\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 \\
\hline \[
\begin{aligned}
& 0 \\
& 0
\end{aligned}
\] & \[
\begin{aligned}
& 0 \\
& 1
\end{aligned}
\] & \[
\begin{aligned}
& 01 \\
& 02 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& (256)(15)=3,840 \\
& (512)(15)=7,680 \\
& \hline
\end{aligned}
\] & 15 at Side 0 or 15 at Side 1 \\
\hline \[
\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 \\
\hline \[
\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 \\
\hline \[
\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 \\
\hline
\end{tabular}

Table 4. DDFDC Command Termination Values
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{Command Phase ID} & \multirow[b]{2}{*}{Final Sector Transferred to/from Data Bus} & \multicolumn{4}{|c|}{Result Phase ID} \\
\hline \begin{tabular}{l}
Multi- \\
Track \\
(MT)
\end{tabular} & Head Number (HD) & & Track Number (T) & Head Number (H) & Sector Number (R) & \begin{tabular}{l}
No. of Data Bytes \\
(N)
\end{tabular} \\
\hline \multirow{4}{*}{0} & 0 & Less than EOT & NC & NC & \(R+1\) & NC \\
\hline & 0 & Equal to EOT & T + 1 & NC & 01 & NC \\
\hline & 1 & Less than EOT & NC & NC & R + 1 & NC \\
\hline & 1 & Equal to EOT & T + 1 & NC & 01 & NC \\
\hline \multirow{4}{*}{1} & 0 & Less than EOT & NC & NC & \(R+1\) & NC \\
\hline & 0 & Equal to EOT & NC & LSB & 01 & NC \\
\hline & 1 & Less than EOT & NC & NC & \(\mathrm{R}+1\) & NC \\
\hline & 1 & Equal to EOT & \(T+1\) & LSB & 01 & NC \\
\hline
\end{tabular}

\section*{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.

\section*{Result Phase:}
\begin{tabular}{|l|l|l|}
\hline R & 1 & Status Register 0 (ST0) \\
\cline { 2 - 9 } & 2 & Status Register 1 (ST1) \\
\hline 3 & Status Register 2 (ST2) \\
\hline 4 & Track Number (T) \\
\hline 5 & Head Number (H) \\
\hline 6 & Sector Number (R) \\
\hline 7 & Number of Data Bytes per Sector (N) \\
\hline
\end{tabular}

\section*{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 ST0 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.

\section*{Command Phase:}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{9}{*}{W} & 1 & MT & MF & 0 & 0 & 0 & 1 & 0 & 1 \\
\hline & 2 & X & X & X & X & X & HD & US1 & USO \\
\hline & 3 & \multicolumn{8}{|l|}{Track Number (T)} \\
\hline & 4 & \multicolumn{8}{|l|}{Head Number (H)} \\
\hline & 5 & \multicolumn{8}{|l|}{Sector Number (R)} \\
\hline & 6 & \multicolumn{8}{|l|}{Number of Data Bytes per Sector (N)} \\
\hline & 7 & \multicolumn{8}{|l|}{End of Track (EOT)} \\
\hline & 8 & \multicolumn{8}{|l|}{Gap Length (GPL)} \\
\hline & 9 & \multicolumn{8}{|l|}{Data Length (DTL)} \\
\hline
\end{tabular}

\section*{Result Phase:}
\begin{tabular}{|c|c|l|}
\hline \multicolumn{6}{|c|}{ R } & 1 & Status Regıster 0 (ST0) \\
\cline { 2 - 4 } & 2 & Status Regıster 1 (ST1) \\
\cline { 2 - 4 } & 3 & Status Register 2 (ST2) \\
\cline { 2 - 3 } & 4 & Track Number (T) \\
\cline { 2 - 3 } & 5 & Head Number (H) \\
\cline { 2 - 3 } & 6 & Sector Number (R) \\
\hline & 7 & Number of Data Bytes per Sector (N) \\
\hline
\end{tabular}

\section*{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.

\section*{Command Phase:}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{9}{*}{W} & 1 & MT & MF & 0 & 0 & 1 & 0 & 0 & 1 \\
\hline & 2 & X & X & X & X & X & HD & US1 & USO \\
\hline & 3 & \multicolumn{8}{|l|}{Track Number ( \(T\) )} \\
\hline & 4 & \multicolumn{8}{|l|}{Head Number (H)} \\
\hline & 5 & \multicolumn{8}{|l|}{Sector Number (R)} \\
\hline & 6 & \multicolumn{8}{|l|}{Number of Data Bytes per Sector (N)} \\
\hline & 7 & \multicolumn{8}{|l|}{End of Track (EOT)} \\
\hline & 8 & \multicolumn{8}{|l|}{Gap Length (GPL)} \\
\hline & 9 & \multicolumn{8}{|l|}{Data Length (DTL)} \\
\hline
\end{tabular}

\section*{Result Phase:}
\begin{tabular}{|c|c|c|}
\hline \multirow[t]{7}{*}{R} & 1 & Status Regıster 0 (STO) \\
\hline & 2 & Status Register 1 (ST1) \\
\hline & 3 & Status Register 2 (ST2) \\
\hline & 4 & Track Number (T) \\
\hline & 5 & Head Number (H) \\
\hline & 6 & Sector Number (R) \\
\hline & 7 & Number of Data Bytes per Sector(N) \\
\hline
\end{tabular}

\section*{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:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{9}{*}{W} & 1 & MT & MF & SK & 0 & 1 & 1 & 0 & 0 \\
\hline & 2 & X & X & X & X & X & HD & US1 & USO \\
\hline & 3 & \multicolumn{8}{|l|}{Track Number (T)} \\
\hline & 4 & \multicolumn{8}{|l|}{Head Number (H)} \\
\hline & 5 & \multicolumn{8}{|l|}{Sector Number (R)} \\
\hline & 6 & \multicolumn{8}{|l|}{Number of Data Bytes per Sector (N)} \\
\hline & 7 & \multicolumn{8}{|l|}{End of Track (EOT)} \\
\hline & 8 & \multicolumn{8}{|l|}{Gap Length (GPL)} \\
\hline & 9 & \multicolumn{8}{|l|}{Data Length (DTL)} \\
\hline
\end{tabular}

\section*{Result Phase:}
\begin{tabular}{|c|l|l|}
\hline \multicolumn{5}{|c|}{ R } & 1 & Status Register 0 (STO) \\
\cline { 2 - 4 } & 2 & Status Register 1 (ST1) \\
\cline { 2 - 4 } & 3 & Status Register 2 (ST2) \\
\cline { 2 - 4 } & 4 & Track Number (T) \\
\cline { 2 - 3 } & 5 & Head Number (H) \\
\cline { 2 - 3 } & 6 & Sector Number (R) \\
\cline { 2 - 3 } & 7 & Number of Data Bytes per Sector (N) \\
\hline
\end{tabular}

\section*{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.

\section*{Command Phase:}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{9}{*}{W} & 1 & 0 & MF & SK & 0 & 0 & 0 & 1 & 0 \\
\hline & 2 & X & X & X & X & X & HD & US1 & USO \\
\hline & 3 & \multicolumn{8}{|l|}{Track Number (T)} \\
\hline & 4 & \multicolumn{8}{|l|}{Head Number (H)} \\
\hline & 5 & \multicolumn{8}{|l|}{Sector Number (R)} \\
\hline & 6 & \multicolumn{8}{|l|}{Number of Data Bytes per Sector (N)} \\
\hline & 7 & \multicolumn{8}{|l|}{End of Track (EOT)} \\
\hline & 8 & \multicolumn{8}{|l|}{Gap Length (GPL)} \\
\hline & 9 & \multicolumn{8}{|l|}{Data Length (DTL)} \\
\hline
\end{tabular}

\section*{Result Phase:}
\begin{tabular}{|c|c|c|}
\hline \multirow[t]{7}{*}{R} & 1 & Status Register 0 (STO) \\
\hline & 2 & Status Register 1 (ST1) \\
\hline & 3 & Status Register 2 (ST2) \\
\hline & 4 & Track Number (T) \\
\hline & 5 & Head Number (H) \\
\hline & 6 & Sector Number (R) \\
\hline & 7 & Number of Data Bytes per Sector (N) \\
\hline
\end{tabular}

\section*{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:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow{2}{*}{\(W\)} & 1 & 0 & MF & 0 & 0 & 1 & 0 & 1 & 0 \\
\cline { 2 - 10 } & 2 & \(X\) & \(X\) & \(X\) & \(X\) & \(X\) & \(H D\) & US1 & USO \\
\hline
\end{tabular}

\section*{Result Phase:}
\begin{tabular}{|c|c|c|}
\hline \multirow[t]{7}{*}{R} & 1 & Status Register 0 (STO) \\
\hline & 2 & Status Register 1 (ST1) \\
\hline & 3 & Status Register 2 (ST2) \\
\hline & 4 & Track Number (T) \\
\hline & 5 & Head Number (H) \\
\hline & 6 & Sector Number (R) \\
\hline & 7 & Number of Data Bytes per Sector (N) \\
\hline
\end{tabular}

\section*{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 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 (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.

\section*{Command Phase:}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{6}{*}{w} & 1 & 0 & MF & 0 & 0 & 1 & 1 & 0 & 1 \\
\hline & 2 & X & X & X & X & X & HD & US1 & USO \\
\hline & 3 & \multicolumn{8}{|l|}{Number of Bytes per Sector (N)} \\
\hline & 4 & \multicolumn{8}{|l|}{Sectors per Track (ST)} \\
\hline & 5 & \multicolumn{8}{|l|}{Gap Length (GPL)} \\
\hline & 6 & \multicolumn{8}{|l|}{Data Pattern (D)} \\
\hline
\end{tabular}

Table 5. Standard Floppy Disk Sector Size Relationship
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline & & & No. of Data & No. of & Gap Le & (GPL) \({ }^{4}\) & \\
\hline \begin{tabular}{l}
Disk \\
Size
\end{tabular} & Mode & Sector Size Bytes/Sector & \begin{tabular}{l}
Bytes/Sector \\
( N )
\end{tabular} & Sectors/Track (ST) & Read/Write Command \({ }^{1}\) & Format Command \({ }^{2}\) & Remarks \\
\hline & & 128 & 00 & 1A & 07 & 1 B & \\
\hline & & 256 & 01 & OF & OE & 2A & \\
\hline & FM & 512 & 02 & 08 & 1B & 3A & \\
\hline & FM & 1024 & 03 & 04 & 47 & 8A & \\
\hline & & 2048 & 04 & 02 & C8 & FF- & \\
\hline " & & 4096 & 05 & 01 & C8 & FF & \\
\hline 8 & & 256 & 01 & 1A & OE & 36 & \\
\hline & & 512 & 02 & OF & 1B & 54 & \\
\hline & MFM \({ }^{3}\) & 1024 & 03 & 08 & 35 & 74 & \\
\hline & & 2048 & 04 & 04 & 99 & FF & \\
\hline & & 4096 & 05 & 02 & C8 & FF & \\
\hline & & 8192 & 06 & 01 & C8 & FF & \\
\hline & & 128 & 00 & 12 & 07 & 09 & \\
\hline & & 128 & 00 & 10 & 10 & 19 & \\
\hline & FM & 256 & 01 & 08 & 18 & 30 & \\
\hline & FM & 512 & 02 & 04 & 46 & 87 & \\
\hline & & 1024 & 03 & 02 & C8 & FF & \\
\hline & & 2048 & 04 & 01 & C8 & FF & \\
\hline \(51 / 4 \prime \prime\) & & 256 & 01 & 12 & OA & OC & \\
\hline & & 256 & 01 & 10 & 20 & 32 & \\
\hline & MFM \({ }^{3}\) & 512 & 02 & 08 & 2 A & 50 & \\
\hline & MFM & 1024 & 03 & 04 & 80 & F0 & \\
\hline & & 2048 & 04 & 02 & C8 & FF & \\
\hline & & 4096 & 05 & 01 & C8 & FF & \\
\hline \multirow{6}{*}{\(31 / 2^{\prime \prime}\)} & \multirow{3}{*}{FM} & 128 & 00 & OF & 07 & 1 B & \\
\hline & & 256 & 01 & 09 & OE & 2A & \\
\hline & & 512 & 02 & 05 & 1B & 3A & \\
\hline & \multirow{3}{*}{MFM \({ }^{3}\)} & 256 & 01 & OF & OE & 36 & \\
\hline & & 512 & 02 & 09 & 1B & 54 & \\
\hline & & 1024 & 03 & 05 & 35 & 74 & \\
\hline
\end{tabular}

\section*{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 \((N=00)\).
4. Values of ST and GPL are in hexadecimal.

\section*{Result Phase:}
\begin{tabular}{|l|l|l|}
\hline \multirow{5}{*}{\(R\)} & 1 & Status Register 0 (ST0) \\
\cline { 2 - 4 } & 2 & Status Register 1 (ST1) \\
\cline { 2 - 4 } & 3 & Status Register 2 (ST2) \\
\hline & 4 & Track Number (T)* \\
\cline { 2 - 3 } & 5 & Head Number (H)* \\
\cline { 2 - 3 } & 6 & Sector Number (R)* \\
\cline { 2 - 3 } & 7 & Number of Data Bytes per Sector (N)* \\
\hline * The ID information has no meaning in this command. \\
\hline
\end{tabular}

\section*{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_{\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 ( \(\mathrm{R}+\mathrm{STP} \rightarrow \mathrm{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.

Table 6. Scan Status Codes
\begin{tabular}{|l|c|c|c|}
\hline \multirow{2}{*}{ Command } & \multicolumn{2}{|c|}{ Status Register 2 } & \multirow{2}{*}{ Comments } \\
\cline { 2 - 3 } & Bit 2 = SN & Bit 3 = SH & \\
\hline \multirow{2}{*}{ Scan Equal } & 0 & 1 & \(D_{F D D}=D_{B U S}\) \\
& 1 & 0 & \(D_{F D D} \neq D_{B U S}\) \\
\hline \multirow{3}{*}{ Scan Low or Equal } & 0 & 1 & \(D_{F D D}=D_{B U S}\) \\
& 0 & 0 & \(D_{F D D}<D_{B U S}\) \\
& 1 & 0 & \(D_{F D D}>D_{B U S}\) \\
\hline \multirow{3}{*}{ Scan High or Equal } & 0 & 1 & \(D_{F D D}=D_{B U S}\) \\
& 0 & 0 & \(D_{F D D}>D_{B U S}\) \\
& 1 & 0 & \(D_{F D D}<D_{B U S}\) \\
\hline
\end{tabular}

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.

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.

\section*{SCAN EQUAL}

Command Phase:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{9}{*}{W} & 1 & MT & MF & SK & 1 & 0 & 0 & 0 & 1 \\
\hline & 2 & X & X & X & X & X & HD & US1 & USO \\
\hline & 3 & \multicolumn{8}{|l|}{Track Number (T)} \\
\hline & 4 & \multicolumn{8}{|l|}{Head Number (H)} \\
\hline & 5 & \multicolumn{8}{|l|}{Sector Number (R)} \\
\hline & 6 & \multicolumn{8}{|l|}{Number of Data Bytes per Sector (N)} \\
\hline & 7 & \multicolumn{8}{|l|}{End of Track (EOT)} \\
\hline & 8 & \multicolumn{8}{|l|}{Gap Length (GPL)} \\
\hline & 9 & \multicolumn{8}{|l|}{Sector Test Process (STP)} \\
\hline
\end{tabular}

\section*{Result Phase:}
\begin{tabular}{|c|l|l|}
\hline \multicolumn{6}{|c|}{} & 1 & Status Register 0 (ST0) \\
\cline { 2 - 9 } & 2 & Status Register 1 (ST1) \\
\cline { 2 - 8 } & 3 & Status Register 2 (ST2) \\
\cline { 2 - 3 } & 4 & Track Number (T) \\
\hline & 5 & Head Number (H) \\
\cline { 2 - 3 } & 6 & Sector Number (R) \\
\cline { 2 - 3 } & 7 & Number of Data Bytes per Sector (N) \\
\hline
\end{tabular}

\section*{SCAN LOW OR EQUAL}

Command Phase:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{9}{*}{W} & 1 & MT & MF & SK & 1 & 1 & 1 & 0 & 1 \\
\hline & 2 & X & X & X & X & X & HD & US1 & USO \\
\hline & 3 & \multicolumn{8}{|l|}{Track Number (T)} \\
\hline & 4 & \multicolumn{8}{|l|}{Head Number (H)} \\
\hline & 5 & \multicolumn{8}{|l|}{Sector Number (R)} \\
\hline & 6 & \multicolumn{8}{|l|}{Number of Data Bytes per Sector (N)} \\
\hline & 7 & \multicolumn{8}{|l|}{End of Track (EOT)} \\
\hline & 8 & \multicolumn{8}{|l|}{Gap Length (GPL)} \\
\hline & 9 & \multicolumn{8}{|l|}{Sector Test Process (STP)} \\
\hline
\end{tabular}

Result Phase:
\begin{tabular}{|c|l|l|}
\hline \multirow{5}{*}{ R } & 1 & Status Register 0 (ST0) \\
\cline { 2 - 8 } & 2 & Status Register 1 (ST1) \\
\cline { 2 - 4 } & 3 & Status Register 2 (ST2) \\
\cline { 2 - 3 } & 4 & Track Number (T) \\
\hline & 5 & Head Number (H) \\
\cline { 2 - 3 } & 6 & Sector Number (R) \\
\cline { 2 - 3 } & 7 & Number of Data Bytes per Sector (N) \\
\hline
\end{tabular}

\section*{SCAN HIGH OR EQUAL}

\section*{Command Phase:}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{9}{*}{W} & 1 & MT & MF & SK & 1 & 1 & 1 & 0 & 1 \\
\hline & 2 & X & X & X & X & X & HD & US1 & USO \\
\hline & 3 & \multicolumn{8}{|l|}{Track Number ( T )} \\
\hline & 4 & \multicolumn{8}{|l|}{Head Number (H)} \\
\hline & 5 & \multicolumn{8}{|l|}{Sector Number (R)} \\
\hline & 6 & \multicolumn{8}{|l|}{Number of Data Bytes per Sector (N)} \\
\hline & 7 & \multicolumn{8}{|l|}{End of Track (EOT)} \\
\hline & 8 & \multicolumn{8}{|l|}{Gap Length (GPL)} \\
\hline & 9 & \multicolumn{8}{|l|}{Sector Test Process (STP)} \\
\hline
\end{tabular}

\section*{Result Phase:}
\begin{tabular}{|c|c|l|}
\hline \multicolumn{6}{|c|}{ R } & 1 & Status Register 0 (ST0) \\
\cline { 2 - 9 } & 2 & Status Register 1 (ST1) \\
\cline { 2 - 9 } & 3 & Status Register 2 (ST2) \\
\cline { 2 - 3 } & 4 & Track Number (T) \\
\hline & 5 & Head Number (H) \\
\cline { 2 - 3 } & 6 & Sector Number (R) \\
\cline { 2 - 3 } & 7 & Number of Data Bytes per Sector (N) \\
\hline
\end{tabular}

\section*{SEEK}

The three-byte Seek command steps the FDD read/write head from track to track. The DDFDC has four 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 \(\operatorname{NT}\).

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 .

\section*{Command Phase:}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{3}{*}{W} & 1 & 0 & 0 & 0 & 0 & 1 & 1 & 1 & 1 \\
\hline & 2 & X & X & X & X & X & 0 & US1 & USO \\
\hline & 3 & \multicolumn{8}{|l|}{New Track Number (NTN)} \\
\hline
\end{tabular}

Result Phase: None.

\section*{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.

\section*{Command Phase:}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline W & 1 & 0 & 0 & 0 & 0 & 0 & 1 & 1 & 1 \\
\cline { 2 - 9 } & 2 & X & X & X & X & X & 0 & US1 & USO \\
\hline
\end{tabular}

Result Phase: None.

\section*{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.

The Sense Interrupt Status command is used in conjunction with the Seek and Recalibrate commands which have no result phase. When the disk drive has reached the desired head position the DDFDC asserts interrupt output. The host CPU must then issue a Sense Interrupt Status command to determine the actual cause of the interrupt, which could be Seek End or a change in ready status from one of the drives (see example in Figure 3).

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

Table 7. STO Seek and Interrupt Code Definition for Sense Interrupt Status
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{3}{|c|}{Status Register 0 (STO) Bits} & \multirow[b]{3}{*}{Cause} \\
\hline \multicolumn{2}{|l|}{Interrupt Code (IC)} & Seek End (SE) & \\
\hline 7 & 6 & 5 & \\
\hline 1 & 1 & 0 & RDY line changed state, either polarity \\
\hline 0 & 0 & 1 & Normal termination of Seek or Recalibrate command \\
\hline 0 & 1 & 1 & Abnormal termination of Seek or Recalibrate command \\
\hline
\end{tabular}

\section*{Command Phase:}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline W & 1 & 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 \\
\hline
\end{tabular}

Result Phase:
\begin{tabular}{|l|l|l|}
\hline R & 1 & Status Register 0 (STO) \\
\cline { 2 - 3 } & 2 & Present Track Number (PTN) \\
\hline
\end{tabular}

\section*{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} \quad(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.

\section*{Command Phase:}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multirow[t]{3}{*}{w} & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 1 \\
\hline & 2 & \multicolumn{4}{|c|}{SRT} & \multicolumn{4}{|c|}{HUT} \\
\hline & 3 & \multicolumn{7}{|c|}{HLT} & ND \\
\hline
\end{tabular}

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


\section*{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.

\section*{Command Phase:}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline W & 1 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 \\
\cline { 2 - 10 } & 2 & X & X & X & X & X & HD & US1 & USO \\
\hline
\end{tabular}

\section*{Result Phase:}
\begin{tabular}{|l|l|l|}
\hline R & \(\mathbf{1}\) & Status Register 3 (ST3) \\
\hline
\end{tabular}

\section*{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:
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline R/W & BYTE & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline W & 1 & \multicolumn{8}{|c|}{ Invalid Codes } \\
\hline
\end{tabular}

\section*{Result Phase:}
\begin{tabular}{|c|c|c|}
\hline\(R\) & 1 & Status Register \(0(S T O)=80\) \\
\hline
\end{tabular}

\section*{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.


NOTES
\begin{tabular}{|l|l|l|l|}
\hline A & DATA REGISTER READY TO BE WRITTEN INTO & C & DATA REGISTER READY FOR NEXT DATA BYTE TO BE READ \\
\hline B DATA REGISTER NOT READY TO BE WRITTEN INTO & D DATA REGISTER NOT READY FOR NEXT DATA BYTE TO BE READ
\end{tabular}

Figure 4. DDFDC and System Data Transfer Timing

\section*{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 ( \(\overline{\mathrm{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 \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.

\section*{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{\mathrm{DACK}}\) low (DMA Acknowledge) and \(\overline{\mathrm{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 \(\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.

\section*{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 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 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.

\section*{R6765 (FM MODE)}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline FIELD & gAP 4a & SYNC & IAM & GAP 1 & SYNC & idam & CYL & HD & SEC & No & CRC & GAP 2 & SYNC & data Am & DATA & & GAP 3 & GAP 4b \\
\hline NO. OF BYTES & 40x & 6x & & \(26 \times\) & 6x & & & & & & & 11× & 6× & & (1) & CRC & (1) & \\
\hline DATA & FF & 00 & FC & FF & 00 & FE & & & & & & FF & 00 & FB OR F8 & & & & \\
\hline
\end{tabular}
INDEX \(\qquad\)
—_ REPEAT N TIMES ——_

R6265 (FM MODE)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline FIELD & GAP 1 & SYNC & IDAM & CYL & HD & SEC & NO & CRC & GAP 2 & SYNC & DATA AM & DATA & & GAP 3 & GAP 4 \\
\hline NO OF GYTES & \(16 \times\) & \(6 \times\) & & & & & & & \(11 \times\) & \(6 \times\) & & (1) & CRC & (1) & \\
\hline DATA & FF & 00 & FC & & & & & & FF & 00 & FB OR F8 & & & & \\
\hline
\end{tabular}

INDEX \(\qquad\) REPEAT N TIMES


R6765 (MFM MODE)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline GAP 4a & SYNC & \multicolumn{2}{|c|}{IAM} & GAP 1 & SYNC & \multicolumn{2}{|c|}{IDAM} & CYL & HD & SEC & No & CRC & GAP 2 & SYNc & \multicolumn{2}{|c|}{data am} & data & & GAP 3 & GAP 4b \\
\hline \(80 \times\) & 12x & 3x & & \(50 \times\) & 12x & 3× & & & & & & & 22x & 12× & 3x & FB & (1) & CRC & (1) & \\
\hline 4 E & 00 & C2 & FC & 4 E & 00 & A1 & FE & & & & & & 4E & 00 & A1 & F8 & & & & \\
\hline
\end{tabular}

INDEX

\(\qquad\)

R6265 (MFM MODE)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline FIELD & GAP 1 & SYNC & \multicolumn{2}{|c|}{IDAM} & CYL & HD & SEC & No & CRC & GAP 2 & SYnc & \multicolumn{2}{|r|}{data am} & dATA & & GAP 3 & GAP 4 \\
\hline NO OF BYtes & 32× & 12x & 3x & & & & & & & 22x & 12x & \(3 \times\) & FB & (1) & CRC & (1) & \\
\hline data & 4 E & 00 & A1 & FE & & & & & & \(4 E\) & 00 & A1 & F8 & & & & \\
\hline
\end{tabular}

INDEX \(\qquad\) \(\mid\) REPEAT N TIMES

Figure 5. DDFDC Formats


Figure 6. DDFDC Formats


Figure 7. R6265/R6765 DDFDC Interface to Z 80

CLK


Figure 8. Clock Timing


Figure 9. Read Cycle Timing

A0, \(\overline{\mathbf{C S}}, \overline{\mathbf{D A C K}}\)


DATA IN D0-D7


Figure 10. Write Cycle Timing


Figure 11. DMA Operation Timing


Figure 12. FDD Write Operation Timing


Figure 13. FDD Read Operation Timing


Figure 14. Seek Operation Timing


Figure 15. Fault Reset Timing


Figure 17. Terminal Count Timing


Figure 18. Reset Timing

Figure 16. Index 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.8V 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 19. AC Timing Measurement Conditions

\section*{AC CHARACTERISTICS}
\(\left(\mathrm{V}_{\mathrm{Cc}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.\) to \(\left.70^{\circ} \mathrm{C}\right)\)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline Ref. Fig. & No. & \multicolumn{2}{|c|}{Characteristic} & Symbol & Alt. Sym. & Min. & Typ. & Max. & Unit & Test Conditions \\
\hline \multirow{6}{*}{5} & 1 & & ( \(8^{\prime \prime}\) or \(3-1 / 2^{\prime \prime}\) FDD) & & & 120 & 125 & 500 & ns & CLK \(=8 \mathrm{MHz}\) \\
\hline & 1 & Clock Period & (5-1/4 \({ }^{\prime \prime}\) FDD) & \(\mathrm{t}_{\mathrm{CY}}\) & \(\phi_{\text {CY }}\) & - & 250 & - & ns & CLK \(=4 \mathrm{MHz}\) \\
\hline & & \multicolumn{2}{|l|}{\multirow[t]{2}{*}{Clock High}} & & & 40 & & - & ns & CLK \(=8 \mathrm{MHz}\) \\
\hline & 2 & & & \({ }^{\text {cha }}\) & \(\phi_{0}\) & 40 & 62.5 & - & ns & CLK \(=8 \mathrm{MHz}\) \\
\hline & 3 & \multicolumn{2}{|l|}{Clock Rise Time} & \(\mathrm{t}_{\text {CLCH }}\) & \(\phi_{r}\) & - & - & 20 & ns & \\
\hline & 4 & \multicolumn{2}{|l|}{Clock Fall Time} & \(\mathrm{t}_{\mathrm{CHCL}}\) & \(\phi_{f}\) & - & - & 20 & ns & \\
\hline \multirow{6}{*}{6} & 5 & \multicolumn{2}{|l|}{AO, \(\overline{C S}\), \(\overline{\text { DACK }}\) Valid to \(\overline{R D}\) Low (Setup)} & \(\mathrm{t}_{\text {SLRL }}\) & \(\mathrm{t}_{\text {AR }}\) & 0 & - & - & ns & \\
\hline & 6 & \multicolumn{2}{|l|}{\(\overline{\mathrm{RD}}\) High to A0, \(\overline{C S}, \overline{\mathrm{DACK}}\) Invalid (Hold)} & \(\mathrm{t}_{\text {RHSH }}\) & \(t_{\text {RA }}\) & 0 & - & - & ns & \\
\hline & 7 & \multicolumn{2}{|l|}{\(\overline{\mathrm{RD}}\) Low Width} & \(\mathrm{t}_{\text {RLRH }}\) & \(t_{\text {RR }}\) & 250 & - & - & ns & \\
\hline & 8 & \multicolumn{2}{|l|}{\(\overline{\mathrm{RD}}\) Low to Data Valid (Access)} & \(\mathrm{t}_{\text {RLDV }}\) & \(\mathrm{t}_{\mathrm{RD}}\) & - & - & 200 & ns & L \(=100 \mathrm{pF}\) \\
\hline & 9 & \multicolumn{2}{|l|}{\(\overline{\mathrm{RD}}\) High to Output High Z} & \(\mathrm{t}_{\text {RHDZ }}\) & \(t_{\text {DF }}\) & 20 & - & 100 & ns & \(\mathrm{L}=100 \mathrm{pF}\) \\
\hline & 10 & \multicolumn{2}{|l|}{\(\overline{R D}\) High to INT High} & \(\mathrm{t}_{\text {RHIH }}\) & \(\mathrm{t}_{\text {RI }}\) & - & - & 500 & ns & \(\mathrm{CLK}=8 \mathrm{MHz}\) \\
\hline \multirow{6}{*}{7} & 11 & \multicolumn{2}{|l|}{AO, \(\overline{C S}, \overline{\text { DACK }}\) Valid to WR Low (Setup)} & \(\mathrm{t}_{\text {SLWL }}\) & \(t_{\text {AW }}\) & 0 & - & - & ns & \\
\hline & 12 & \multicolumn{2}{|l|}{\(\overline{\text { WR }}\) High to A0, \(\overline{\mathrm{CS}}, \overline{\mathrm{DACK}}\) Invalid (Hold)} & \(t_{\text {WHSH }}\) & \(t_{\text {WA }}\) & 0 & - & - & ns & \\
\hline & 13 & \multicolumn{2}{|l|}{\(\overline{\text { WR Low Width }}\)} & \(t_{\text {WLWH }}\) & \(t_{\text {wW }}\) & 250 & - & - & ns & \\
\hline & 14 & \multicolumn{2}{|l|}{Data Valıd to WR High (Setup)} & tovwh & \(t_{\text {DW }}\) & 150 & - & - & ns & \\
\hline & 15 & \multicolumn{2}{|l|}{\(\overline{\text { WR }}\) High to Data Invalid (Hold)} & \(\mathrm{t}_{\text {WHDX }}\) & \(t_{\text {WD }}\) & 5 & - & - & ns & \\
\hline & 16 & \multicolumn{2}{|l|}{WR High to INT High} & \(t_{\text {WHIH }}\) & \(t_{\text {wI }}\) & - & - & 500 & ns & \multirow{3}{*}{CLK \(=8 \mathrm{MHz}\)} \\
\hline \multirow{6}{*}{8} & 17 & \multicolumn{2}{|l|}{DRQ Cycle Time} & \(\mathrm{t}_{\text {QCY }}\) & \(\mathrm{t}_{\mathrm{MCY}}\) & 13 & - & - & \(\mu \mathrm{S}\) & \\
\hline & 18 & \multicolumn{2}{|l|}{DRQ High to \(\overline{\mathrm{RD}}, \overline{\mathrm{WR}}\) High (Response)} & \(\mathrm{t}_{\text {QHXH }}\) & \(\mathrm{t}_{\text {MRW }}\) & - & - & 12 & \(\mu \mathrm{S}\) & \\
\hline & 19 & \multicolumn{2}{|l|}{\(\overline{\text { DACK }}\) Low to DRQ Low (Delay)} & \(\mathrm{t}_{\text {ALQL }}\) & \(\mathrm{t}_{\text {AM }}\) & - & - & 200 & ns & \\
\hline & 19a & \multicolumn{2}{|l|}{DRQ High to \(\overline{\text { DACK }}\) Low (Delay)} & \({ }_{\text {taHAL }}\) & \(\mathrm{t}_{\text {MA }}\) & 200 & - & - & ns & \(\mathrm{t}_{\mathrm{CY}}=125 \mathrm{~ns}\) \\
\hline & \multirow[b]{2}{*}{20} & \multicolumn{2}{|l|}{DRQ High to \(\overline{\mathrm{RD}}\) Low (Delay)} & \(\mathrm{t}_{\text {QHRL }}\) & \(t_{\text {MR }}\) & 800 & - & - & ns & \multirow[t]{2}{*}{CLK \(=8 \mathrm{MHz}\)} \\
\hline & & \multicolumn{2}{|l|}{DRQ High to \(\overline{\text { WR }}\) Low (Delay)} & \({ }_{\text {Q }}\) QHWL & \(t_{\text {MW }}\) & 250 & - & - & ns & \\
\hline \multirow{10}{*}{9} & \multirow[t]{2}{*}{21} & \multirow[t]{2}{*}{WCK Cycle Time} & (8" or 3-1/2" FDD) & \multirow[t]{2}{*}{\(\mathrm{t}_{\mathrm{KCY}}\)} & \multirow[t]{2}{*}{\({ }^{\text {t }} \mathrm{CY}\)} & - & \[
\begin{aligned}
& 2 \\
& 1 \\
& \hline
\end{aligned}
\] & - & \[
\begin{aligned}
& \mu \mathrm{S} \\
& \mu \mathrm{~S} \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{MFM}=0 \\
& \text { MFM }=1
\end{aligned}
\] \\
\hline & & & (5-1/4" FDD) & & & - & \[
\begin{aligned}
& 1 \\
& 4 \\
& 2 \\
& \hline
\end{aligned}
\] & - & \[
\begin{aligned}
& \mu \mathrm{S} \\
& \mu \mathrm{~S} \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { MFM }=0 \\
& \text { MFM }=1
\end{aligned}
\] \\
\hline & 22 & \multicolumn{2}{|l|}{WCK High Width} & \(\mathrm{t}_{\text {KHKL }}\) & \(\mathrm{t}_{0}\) & 80 & 250 & 350 & ns & \\
\hline & 23 & \multicolumn{2}{|l|}{WCK Rise Time} & \(t_{\text {KLKH }}\) & \(\mathrm{t}_{\mathrm{r}}\) & - & - & 20 & ns & \\
\hline & 24 & \multicolumn{2}{|l|}{WCK Fall Time} & \(\mathrm{t}_{\text {KHKL }}\) & \(t_{f}\) & - & - & 20 & ns & \\
\hline & 25 & \multicolumn{2}{|l|}{WCK High to PS0, PS1 Valid (Delay)} & \(t_{\text {KHPV }}\) & \(\mathrm{t}_{\mathrm{CP}}\) & 20 & - & 100 & ns & \\
\hline & 25a & \multicolumn{2}{|l|}{WCK High to WE High (Delay)} & \(\mathrm{t}_{\text {DHEN }}\) & \(\mathrm{t}_{\text {CWE }}\) & 20 & - & 100 & ns & \\
\hline & 26 & \multicolumn{2}{|l|}{PS0, PS1 Valid to WDA High (Delay)} & \(\mathrm{t}_{\text {PVDH }}\) & \(t_{C D}\) & 20 & - & 100 & ns & \\
\hline & 27 & \multicolumn{2}{|l|}{WDA High Width} & \(t_{\text {DHDL }}\) & \(t_{\text {WDD }}\) & \(\mathrm{t}_{\text {WCH }}-50\) & - & - & ns & \\
\hline & 28 & \multicolumn{2}{|l|}{WE High to WCK High or WE Low to WCK Low} & \(\mathrm{t}_{\text {EHKH }}\) & \(t_{\text {WE }}\) & 20 & - & 100 & ns & \\
\hline \multirow{5}{*}{10} & 30 & \multirow[t]{2}{*}{RDW Cycle Time} & (8' \({ }^{\prime \prime}\) or 3-1/2" \({ }^{\prime \prime}\) FDD) & \multirow[t]{2}{*}{\({ }^{\text {t }}\) WCY} & \multirow[t]{2}{*}{\(\mathrm{t}_{\mathrm{WCY}}\)} & 二 & 2
1 & - & \[
\begin{aligned}
& \mu \mathrm{S} \\
& \mu \mathrm{~S} \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& M F M=0 \\
& M F M=1
\end{aligned}
\] \\
\hline & & & (5-1/4" FDD) & & & - & \[
\begin{aligned}
& 4 \\
& 2 \\
& \hline
\end{aligned}
\] & - & \[
\begin{aligned}
& \mu \mathrm{S} \\
& \mu \mathrm{~S} \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{MFM}=0 \\
& \text { MFM }=1
\end{aligned}
\] \\
\hline & 31 & \multicolumn{2}{|l|}{RDW Valid to RDD High (Setup)} & \(t_{\text {WVRH }}\) & \(t_{\text {WRD }}\) & 15 & - & - & ns & \\
\hline & 32 & \multicolumn{2}{|l|}{RDD Low to RDW Invalid (Hold)} & \(\mathrm{t}_{\text {RLWI }}\) & \(t_{\text {RDW }}\) & 15 & - & - & ns & \\
\hline & 33 & \multicolumn{2}{|l|}{RDD High Width} & \(\mathrm{t}_{\text {RHRL }}\) & \(t_{\text {RDD }}\) & 40 & - & - & ns & \\
\hline \multirow{9}{*}{11} & 35 & \multicolumn{2}{|l|}{US0, US1 Valid to SEEK High (Setup)} & \(\mathrm{t}_{\text {UVSH }}\) & \(t_{\text {US }}\) & 12 & - & - & \(\mu \mathrm{S}\) & \\
\hline & 36 & \multicolumn{2}{|l|}{SEEK Low to US0, US1 Invalid (Hold)} & \(\mathrm{t}_{\text {SLUI }}\) & \(\mathrm{t}_{\mathrm{SU}}\) & 15 & - & - & \(\mu \mathrm{S}\) & \\
\hline & 37 & \multicolumn{2}{|l|}{SEEK High to DIR Valid (Setup)} & \(\mathrm{t}_{\text {SHDV }}\) & \(\mathrm{t}_{\text {SD }}\) & 7 & - & - & \(\mu \mathrm{S}\) & \\
\hline & 38 & \multicolumn{2}{|l|}{DIR Invalid to SEEK Low (Hold)} & \(t_{\text {DXSL }}\) & \(t_{\text {DS }}\) & 30 & - & - & \(\mu \mathrm{S}\) & \(\mathrm{CLK}=8 \mathrm{MHz}\) \\
\hline & 39 & \multicolumn{2}{|l|}{DIR Valid to STP High (Setup)} & \(t_{\text {DVTH }}\) & \(\mathrm{t}_{\text {DST }}\) & 1 & - & - & \(\mu \mathrm{S}\) & CLK \(=8 \mathrm{MHz}\) \\
\hline & 40 & \multicolumn{2}{|l|}{STP Low to DIR Invalid (Hold)} & \({ }_{\text {t }}^{\text {TLDX }}\) & \(\mathrm{t}_{\text {STD }}\) & 24 & - & - & \(\mu \mathrm{S}\) & \\
\hline & 41 & \multicolumn{2}{|l|}{STP Low to US0, US1 Invalid (Hold)} & \(t_{\text {TLUX }}\) & \(t_{\text {STU }}\) & 5 & - & - & \(\mu \mathrm{S}\) & \\
\hline & 42 & \multicolumn{2}{|l|}{STP High Width} & \(t_{\text {THTL }}\) & \(t_{\text {STP }}\) & 6 & 7 & 8 & \(\mu \mathrm{S}\) & \\
\hline & 43 & \multicolumn{2}{|l|}{STP Cycle Time} & \(t_{\text {TCY }}\) & \(\mathrm{t}_{\mathrm{SC}}\) & \(33^{3}\) & - & note 1 & \(\mu \mathrm{S}\) & \\
\hline 12 & 44 & \multicolumn{2}{|l|}{FR High Width} & \(\mathrm{t}_{\text {FHFL }}\) & \(\mathrm{t}_{\text {FR }}\) & 8 & - & 10 & \(\mu \mathrm{S}\) & \\
\hline 13 & 45 & \multicolumn{2}{|l|}{IDX High Width} & \(\mathrm{t}_{\text {IHIL }}\) & \(\mathrm{t}_{\text {IDX }}\) & 10 & - & - & \(\mathrm{t}_{\mathrm{CY}}\) & \\
\hline 14 & 46 & \multicolumn{2}{|l|}{TC High Width} & \(t_{\text {THTL }}\) & \(t_{\text {TC }}\) & 1 & - & - & \({ }_{\text {t }}^{\text {CY }}\) & \\
\hline 15 & 47 & \multicolumn{2}{|l|}{RST High Width} & \(\mathrm{t}_{\text {RHRL }}\) & \(\mathrm{t}_{\text {RST }}\) & 14 & - & - & \(\mathrm{t}_{\mathrm{CY}}\) & \\
\hline
\end{tabular}
1. \(\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, and 2 ms to 32 ms with 4 MHz clock, under software control.

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|l|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & V \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & V \\
\hline Output Voltage & \(\mathrm{V}_{\mathrm{OUT}}\) & -0.3 to +7.0 & V \\
\hline Operating Temperature Range & \(\mathrm{T}_{\mathrm{A}}\) & 0 to +70 & \(\mathrm{C}^{\circ}\) \\
\hline Storage Temperature Range & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \(\mathrm{C}^{\circ}\) \\
\hline
\end{tabular}

OPERATING CONDITIONS
*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.
\begin{tabular}{|c|c|}
\hline Parameter & Range \\
\hline\(V_{C C}\) Power Supply & \(5.0 \mathrm{~V} \pm 5 \%\) \\
\hline Operating Temperature & \(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{DC CHARACTERISTICS}
\(\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{Vdc} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.\) to \(70^{\circ} \mathrm{C}\), unless otherwise noted)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Max & Unit & Test Conditions \\
\hline Input 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 & \\
\hline 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 & \\
\hline 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}\) \\
\hline 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}\) \\
\hline \(\mathrm{V}_{\text {cc }}\) Supply Current & \(\mathrm{I}_{\mathrm{cc}}\) & & 150 & mA & \(\mathrm{V}_{C C}=4.75 \mathrm{~V}\) \\
\hline Input Load Current & ILL & & 10 & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{CC}}\) \\
\hline All Inputs & & & -10 & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}\) \\
\hline High Level Output Leakage Current & L'OH & & 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}
\] \\
\hline 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}_{\text {OUT }}=+0.45 \mathrm{~V}
\end{aligned}
\] \\
\hline Internal Power Dissipation & \(\mathrm{P}_{\text {INT }}\) & - & 1.0 & W & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

CAPACITANCE
( \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} ; \mathrm{f}_{\mathrm{c}}=1 \mathrm{MHz} ; \mathrm{V}_{\mathrm{CC}}=0 \mathrm{~V}\) )
\begin{tabular}{|l|c|c|c|}
\hline Parameter & Symbol & Max Limit & Unit \\
\hline Clock Input & \(\mathrm{C}_{\mathbb{N}(\varnothing)}\) & 20 & pF \\
\hline Input & \(\mathrm{C}_{\mathrm{IN}}\) & 10 & pF \\
\hline Output & \(\mathrm{C}_{\text {OUT }}\) & 20 & pF \\
\hline \multicolumn{4}{|l|}{} \\
\hline
\end{tabular}

\section*{PACKAGE DIMENSIONS}

40-PIN CERAMIC DIP

\begin{tabular}{|c|c|c|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{3}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 50.29 & 51.31 & 1.980 & 2.020 \\
\hline B & 14.86 & 15.62 & 0.585 & 0.615 \\
\hline C & 2.54 & 4.19 & 0.100 & 0.165 \\
\hline D & 0.38 & -0.53 & 0.015 & 0.021 \\
\hline F & 0.76 & 1.40 & 0.030 & 0.055 \\
\hline G & 2.54 & BSC & 0.100 & BSC \\
\hline H & 0.76 & 1.78 & 0.030 & 0.070 \\
\hline J & 0.20 & 0.33 & 0.008 & 0.003 \\
\hline K & 2.54 & 4.19 & 0.100 & 0.165 \\
\hline L & 14.60 & 15.37 & 0.575 & 0.605 \\
\hline M & \(0^{\circ}\) & \(10^{\circ}\) & \(0^{\circ}\) & \(10^{\circ}\) \\
\hline N & 0.51 & 152 & 0.020 & 0060 \\
\hline
\end{tabular}

\section*{40-PIN PLASTIC DIP}

\begin{tabular}{|c|c|c|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 51.28 & 52.32 & 2.040 & 2.060 \\
\hline B & 13.72 & 14.22 & 0.540 & 0.560 \\
\hline C & 3.55 & 508 & 0.140 & 0.200 \\
\hline D & 0.36 & 0.51 & 0.014 & 0020 \\
\hline F & 1.02 & 1.52 & 0.040 & 0060 \\
\hline G & 2.54 BSC & \multicolumn{2}{|c|}{0.100} & BSC \\
\hline H & 1.65 & 216 & 0.065 & 0.085 \\
\hline J & 0.20 & 030 & 0008 & 0012 \\
\hline K & \multicolumn{2}{|c|}{305} & 3.56 & 0.120 \\
\hline L & \multicolumn{2}{|c|}{1524 BSC } & 0.140 \\
\hline M & \(7^{\circ}\) & \(10^{\circ}\) & \multicolumn{2}{|c|}{\(7^{\circ}\)} \\
\hline N & \multicolumn{2}{|c|}{0.51} & 1.02 & \multicolumn{2}{|c|}{0.020} & \(10^{\circ}\) \\
\hline
\end{tabular}

\section*{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-36
R65FRX and R65FKX RSC FORTH Development and Kernel ROMs ..... 3-68
R6501Q One-Chip Microprocessor ..... 3-76
R6500/1 One-Chip Microcomputer ..... 3-105
R6500/1E Emulator Device ..... 3-136
R6500/1EB and R6500/1EAB Backpack Emulator ..... 3-143
R6500/11, R6500/12, R6500/15 and R6500/16 One-Chip Microcomputers ..... 3-149
R65/11EB and R65/11EAB Backpack Emulator ..... 3-184
R6511Q and R6500/13 One-Chip Microprocessor and One-Chip Microcomputer ..... 3-189
R6500/41 and R6500/42 One-Chip Intelligent Peripheral Controllers ..... 3-224
R65/41EB and R65/41EAB Backpack Emulator ..... 3-253
R6541Q and R6500/43 One-Chip Intelligent Peripheral Controllers ..... 3-258

\title{
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 4K 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, and available in three configurations to accommodate application programs to 48 K .
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
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline Features/Models & R6500/1 & R6500/11 & R6500/15 & R6500/12 & R6500/16 & R6501Q/11Q & R6500/41 & R6500/42 & R6541Q \\
\hline - ROM (x8) & 2048 & 3072 & 4096 & 3072 & 4096 & - & 1536 & 1536 & 256 \\
\hline - RAM (x8) & 64 & 192 & 192 & 192 & 192 & 192 & 64 & 64 & 64 \\
\hline - I/O Lines & 32 & 32 & 32 & 56 & 56 & 32 & 23 & 47 & 23 \\
\hline - Serial Comm. & - & USART & USART & USART & USART & USART & - & - & - \\
\hline - 16-Bit Counters & ONE & TWO & TWO & TWO & TWO & TWO & ONE & ONE & ONE \\
\hline - Host/Slave Bus & - & - & - & - & - & - & 80/65 & 80/65 & 80/65 \\
\hline - Expansion Bus & - & 16K & 16K & 16K & 16K & 65K & 4K & 4K & \(8 \mathrm{~K} / 4 \mathrm{~K}\) \\
\hline \begin{tabular}{l}
- Interrupts \\
- External
\end{tabular} & 4 & 6 & 6 & 6 & 6 & 6 & 4 & 4 & 5 \\
\hline - Internal & 1 & 4 & 4 & 4 & 4 & 4 & 1 & 1 & 1 \\
\hline - Host & - & - & - & - & - & - & 2 & 2 & 2 \\
\hline - Standby RAM (mW) & 35 & 12 & 12 & 12 & 12 & 12 & - & - & - \\
\hline - Package & 40 DIP & 40 DIP & 40 DIP & 64 QUIP & 64 QUIP & 64 QUIP & 40 DIP & 64 QUIP & 64 QUIP \\
\hline Alternatıves for & 8048/49 & & & & & 8031 & & 8041 & \\
\hline
\end{tabular}

\title{
R65C00/21 DUAL CMOS MICROCOMPUTER AND R65C29 DUAL CMOS MICROPROCESSOR
}

\section*{PRELIMINARY \\ INTRODUCTION}

\section*{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

\section*{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 multımode 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 coltrol 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.

\section*{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.

\section*{NOTE}

All descriptions of R65C00/21 operation in this document also apply to the R65C29 except for internal ROM, and as otherwise noted.

\section*{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 ( \(\varnothing 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

\section*{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

\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline & XTALO & \(\square\) & 1 & & 64 & ， & Vcc & \\
\hline \multirow[t]{2}{*}{XTALI} & & \(\square\) & 2 & & 63 & \(\longrightarrow\) & & \(\overline{\text { RES }}\) \\
\hline & 02 & \(\square\) & 3 & & 62 & ص & \(\overline{\text { NMIA }}\) & \\
\hline OA & & \(\square\) & 4 & & 61 & － & & \(\overline{\text { NMIB }}\) \\
\hline & EMS &  & 5 & & 60 & \(ص\) & PG0 & \\
\hline \multirow[t]{2}{*}{SYNC} & & － & 6 & & 59 & － & & PG1 \\
\hline & R／W & \(\square\) & 7 & & 58 & 曰 & PG2 & \\
\hline \multirow[t]{2}{*}{A15} & & & 8 & & 57 & & & PG3 \\
\hline & A14 & \(\square\) & 9 & & 56 & \(ص\) & A0／D0 & \\
\hline \multirow[t]{2}{*}{A13} & & \(\square\) & 10 & & 55 & \(\square\) & & A1／D1 \\
\hline & A12 & \(\square\) & 11 & & 54 & \(\boxminus\) & A2／D2 & \\
\hline \multirow[t]{2}{*}{A11} & & & 12 & & 53 & \(\square\) & & A3／D3 \\
\hline & A10 & \(\square\) & 13 & R65C29 & 52 & 曰 & A4／D4 & \\
\hline \multirow[t]{2}{*}{A9} & & & 14 & R65C29 & 51 & \(\square\) & & A5／D5 \\
\hline & A8 & \(\square\) & 15 & & 50 & 曰 & A6／D6 & \\
\hline \multirow[t]{2}{*}{PF7} & & \(\square\) & 16 & & 49 & \(\square\) & & A7／D7 \\
\hline & PF6 & \(\square\) & 17 & & 48 & \(\square\) & PCO & \\
\hline \multirow[t]{2}{*}{PF5} & & & 18 & & 47 & \(\square\) & & PC1 \\
\hline & PF4 & \(\square\) & 19 & & 46 & \(ص\) & PC2 & \\
\hline \multirow[t]{2}{*}{PF3} & & & 20 & & 45 & \(\square\) & & PC3 \\
\hline & PF2 & \(\square\) & 21 & & 44 & \(ص\) & PC4 & \\
\hline \multirow[t]{2}{*}{PF1} & & & 22 & & 43 & & & PC5 \\
\hline & PFO & \(\square\) & 23 & & 42 & \(\square\) & PC6 & \\
\hline \multirow[t]{2}{*}{PA7} & & \(\square\) & 24 & & 41 & \(\square\) & & PC7 \\
\hline & PA6 & \(\square\) & 25 & & 40 & \(巳\) & PB0 & \\
\hline \multirow[t]{2}{*}{PA5} & & & 26 & & 39 & & & PB1 \\
\hline & PA4 & － & 27 & & 38 & \(\square\) & PB2 & \\
\hline \multirow[t]{2}{*}{PA3} & & & 28 & & 37 & & & PB3 \\
\hline & PA2 & \(\square\) & 29 & & 36 & 曰 & PB4 & \\
\hline \multirow[t]{2}{*}{PA1} & & & 30 & & 35 & \(\square\) & & PB5 \\
\hline & PAO & \(\square\) & 31 & & 34 & \(\boxminus\) & PB6 & \\
\hline Vss & & \(\square\) & 32 & & 33 & \(\longrightarrow\) & & PB7 \\
\hline
\end{tabular}

Figure 2．R65C00／21 and R65C29 Pin Assignments

Table 1. R65C00/21 Pin Description
\begin{tabular}{|c|c|c|c|}
\hline Signal Name & Pin No. & 1/0 & Description \\
\hline PAO-PA7 & 31-24 & 1/O & Port A. General purpose 8-bit I/O Port A. \\
\hline PB0-PB7 & 40-33 & I/O & Port B. General purpose 8-bit I/O Port B. \\
\hline PC0-PC7 & 48-41 & I/O & Port C. General purpose 8-bit I/O Port C. Host Data Bus in Host Mode. \\
\hline PDO-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. \\
\hline 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. \\
\hline PF0-PF7 & 23-16 & I/O & Port F. General purpose 8-bit I/O Port F. Under software control, each line has alternate functions as follows: \\
\hline PFONEG (PFO) & 23 & 1 & PFO Positive Edge Detect. Maskable CPU interrupt on PFO Positive Transition. \\
\hline PF1POS (PF) & 22 & I & PF1 Negative Edge Detect. Maskable CPU interrupt on PF1 Negative Transitıon. \\
\hline PF2LOW (PF2) & 21 & 1 & PF2 Low Level Detect. Maskable CPU interrupt on PF2 Low (external IRQ). \\
\hline TIMA (PF3) & 20 & \(1 / 0\) & Timer A External Input/Output. \\
\hline TIMB (PF4) & 19 & I/O & Timer B External Input/Output. \\
\hline HINT (PF7) & 16 & 0 & Host Interrupt. Actıve-low maskable interrupt request to Host. \\
\hline PG0-PG3 & 60-57 & 1 & Port G. General purpose 4-bit input Port G. Under software control, Port G serves as the Host Control Bus as follows: \\
\hline \(\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. \\
\hline HR/ \(\bar{W} / \overline{H W R}\) (PG1) & 59 & 1 & Host Bus Read-Write/Write Strobe Input. R/W for 6500/6800 bus; Write Strobe for Z80/8080 bus. \\
\hline HRS (PG2) & 58 & 1 & Host Bus Register Select Input. Low selects Data Buffer; high selects Status Flags. \\
\hline \(\overline{\mathrm{CS}}\) (PG3) & 57 & 1 & Host Bus Active-Low Chip Select Input. Low selects Host Bus operation dependıng on HRS and HR/W/HWR coding and Host Control and Status Register contents; high disables Host Bus interface. \\
\hline \(\overline{R E S}\) & 63 & 1 & Reset. Active-low Reset input intializes R65C00/21 to intial conditions-resets all registers and \(/ / O\) lines. \\
\hline \(\overline{\text { NMIA }}\) & 62 & 1 & CPU A Non-Maskable Interrupt. Non-maskable negative edge sensitive interrupt input to CPU A. \\
\hline \(\overline{\text { NMIB }}\) & 61 & 1 & CPU B Non-Maskable Interrupt. Non-maskable negative edge sensitive interrupt input to CPU B. \\
\hline \(\overline{E M S}\) & 5 & 0 & External Memory Strobe. Active-low. \\
\hline \(\not \chi^{2}\) & 3 & 0 & System Phase 2 Clock Output. Maskable as system clock input for slave operation. \\
\hline \(\mathrm{R} / \bar{W}\) & 7 & 0 & Read/Write. Read/write control output. High during read, low during write. \\
\hline SYNC & 6 & 0 & Sync. Instruction sync output. High When Op Code fetched \\
\hline \(\varnothing\) A & 4 & 0 & Phase A. Phase A clock output. High during CPU A bus cycle, low during CPU B bus cycle. \\
\hline 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. \\
\hline XTALI & 2 & 1 & Crystal/Master Clock Input. Input connection from crystal (or external master clock). \\
\hline VCC & 64 & & Power. 5.0 Vdc. \\
\hline VSS & 32 & & GND. Signal and power ground. \\
\hline
\end{tabular}

\section*{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.

\section*{NOTE}

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

\section*{INTERNAL MEMORY}

\section*{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.

\section*{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.

\section*{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 01 FF which may be external RAM.

\section*{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 Pointer Register, an 8 -bit Status 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.

\section*{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.

\section*{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).


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-01FF. When BCR bit 4 is a 1, all of page one RAM ( 256 bytes) is mapped externally (0100-01FF) 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

\section*{STACK POINTERS}

Each CPU in the R65C00/21 has its own independent 8-bit Stack Pointer 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.

\section*{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.

\section*{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 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.

\section*{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.

\section*{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 (IRQ), i.e., a low level, can be detected on PFO, 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{\operatorname{RQ}}\) interrupts when its own "I flag" bit is a 1.

\section*{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 addressıng modes of all instructions. The times indicated for each instruction are given in terms of CPU clock-tımes.

\section*{UNSIGNED MULTIPLY (MUL)}

The 10 clock-time hardware multıply 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.

\section*{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.

\section*{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 .

\section*{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.

\section*{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 .

\section*{INDEX REGISTER STACK OPERATIONS (PHX, PLX, PHY, AND PLY)}

These instructions are sımilar 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.

\section*{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.

\section*{INSTRUCTION DIFFERENCES FROM R6502}

Decımal 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 ( \(D=0\) ) operation when the \(\mathrm{R} 65 \mathrm{C} 00 / 21\) is RESET, whereas this bit is uninitalized 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.

\section*{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.

\section*{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.

\section*{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.

\section*{INTERRUPT DISABLE BIT (I)}

The interrupt disable bit (I) controls the servicing of an interrupt request ( \(\overline{\mathrm{RQQ}})\). If the I 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{RQ}}\) 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.

\section*{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 RES.

\section*{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{\mathrm{RQ}}\) signal being generated, the B is set to a 0 . There are no instructions which directly set or clear this bit.

\section*{OVERFLOW BIT (V)}

The overflow bit ( 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) instruction 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 V flag are ADC, BIT, CLV, PLP, RTI and SBC.

\section*{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 I/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 instructons 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)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \begin{tabular}{l} 
NEG \\
\((N)\)
\end{tabular} & \begin{tabular}{l} 
OVFL \\
\((V)\)
\end{tabular} & \begin{tabular}{l} 
NOT \\
USED
\end{tabular} & \begin{tabular}{l} 
BRK \\
(B)
\end{tabular} & \begin{tabular}{l} 
DEC \\
(D)
\end{tabular} & \begin{tabular}{l} 
IRQ \\
ENBL \\
\((I)\)
\end{tabular} & \begin{tabular}{l} 
ZERO \\
(Z)
\end{tabular} & \begin{tabular}{l} 
CARRY \\
(C)
\end{tabular} \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline Bit 7 & Negative (N) \({ }^{1}\) \\
\hline 1 & Negative Value \\
\hline 0 & Positive Value \\
\hline Bit 6 & Overflow (0) \({ }^{1}\) \\
\hline 1 & Overflow Set \\
\hline 0 & Overflow Clear \\
\hline Bit 5 & Not Used (Don't care value) \\
\hline Bit 4 & Break Command (B) \({ }^{1}\) \\
\hline 1 & Break Command \\
\hline 0 & Non-break Command \\
\hline Bit 3 & Decimal Mode (D) \({ }^{3}\) \\
\hline 1 & Decimal Mode \\
\hline 0 & Binary Mode \\
\hline Bit 2 & Interrupt Enable (I) \({ }^{\mathbf{2}}\) \\
\hline 1 & IRQ Interrupt Disable \\
\hline 0 & IRQ Interrupt Enable \\
\hline Bit 1 & Zero (Z)' \\
\hline 1 & Zero Result \\
\hline 0 & Non-Zero Result \\
\hline Bit 0 & Carry (C) \({ }^{1}\) \\
\hline 1 & Carry Set \\
\hline 0 & Carry Clear \\
\hline
\end{tabular}

Notes:
1. Not initialized by \(\overline{\mathrm{RES}}\).
2. Set logic 1 by RES.
3. Cleared to logic 0 by \(\overline{R E S}\)
4. There are two Processor Status Registers, one for each CPU.

\section*{INPUT/OUTPUT AND CONTROL/STATUS REGISTERS}

\section*{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 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 control/status 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
\begin{tabular}{|c|c|c|c|}
\hline Address & Read & Write & Register Names/Notes \\
\hline 00 & PA Data & PA Data & Port A Data I/O \\
\hline 01 & PB Data & PB Data & Port B Data l/O \\
\hline 02 & PC Data, \(0 \rightarrow \mathrm{IBF}^{3}\) & PC Data, \(1 \rightarrow\) OBE, \(0 \rightarrow \mathrm{RSO}^{3}\) & Port C Data l/O \\
\hline 03 & PC Data, \(0 \rightarrow 1 \mathrm{BF}^{3}\) & PC Data, \(1 \rightarrow\) OBE, \(1 \rightarrow \mathrm{RSO}^{3}\) & Port C Data //O \\
\hline 04 & PD Data \({ }^{1}\) & PD Data \({ }^{1}\) & Port D Data l/O \\
\hline 05 & - & PE Data \({ }^{1}\) & Port E Data Output Only \\
\hline 06 & PF Data & PF Data & Port F Data l/O \\
\hline 07 & PG Data & - & Port G Data Input Only \\
\hline 08 & - & PA Direction & Port A Direction \\
\hline 09 & - & PB Direction & Port B Direction \\
\hline OA & - & PC Direction & Port C Direction \\
\hline OB & - & PC Direction & Port C Direction \\
\hline \({ }^{0} \mathrm{C}\) & - & PD Direction \({ }^{1}\) & Port D Direction \\
\hline OD & - & - & \\
\hline OE & - & PF Direction & Port F Direction \\
\hline OF & - & & \\
\hline 10 & BCR & BCR & Bus Control Register \\
\hline 11 & HCSR & HCSR & Host Control and Status Register \\
\hline 12 & ICSR & ICSR & Interrupt Control and Status Register \\
\hline 13 & - & CIFR & Clear Interrupt Flags Register \\
\hline 14 & - & IPCIR & Inter-Processor Communication Interrupt Register \\
\hline 15 & PCR & PCR & Power Control Register \\
\hline 16 & TACSR & TACSR & Timer A Control and Status Register \\
\hline 17 & LCA, UCA \(\rightarrow\) SLA & LLA & Timer A Lower Counter (LCA)/Lower Latch (LLA) \\
\hline 18 & SLA & ULA & Timer A Snapshot Latch (SLA)/Upper Latch (ULA) \\
\hline 19 & SLA, O \(\rightarrow\) UFA \({ }^{2}\) & ULA, ULA \(\rightarrow\) UCA, \(L L A \rightarrow L C A, 0 \rightarrow U F A^{2}\) & Timer A Snapshot Latch (SLA)/Upper Latch, Download and Start Timer \\
\hline 1A & TBCSR & TBCSR & Timer B Control and Status Register \\
\hline 1B & LCB & LLB & Timer B Lower Counter (LCB)/Lower Latch (LLB) \\
\hline 1 C & UCB & ULB & Timer B Upper Counter (UCB)/Upper Latch (ULB) \\
\hline 1D & UCB, \(0 \rightarrow\) UFB \({ }^{2}\) & ULB, \(\mathrm{ULB} \rightarrow \mathrm{UCB}, \mathrm{LLB} \rightarrow \mathrm{LCB}, 0 \rightarrow \mathrm{UFB}^{2}\) & Timer B Upper Counter (UCB)/Upper Latch (ULB), Download and Start Timer \\
\hline 1 E & - & - & \\
\hline 1F & - & - & \\
\hline \multicolumn{3}{|l|}{\multirow[t]{7}{*}{\begin{tabular}{l}
Notes: \\
1. Addressed externally when in expanded bus mode. \\
3. \(\mathrm{R} 65 \mathrm{COO} / 2\) \\
2. Counter/Timer underflow flags: \\
UFA \(=\) Timer A Underflow Flag bit in TACSR \\
UFB \(=\) Timer B Underflow Flag bit in TBCSR \\
4. \(-=\) No
\end{tabular}}} & \\
\hline & & & 3. R65C00/21 to/from Host data transfer bits in HCSR: \\
\hline & & & IBF \(=\) Input Buffer Full flag bit \\
\hline & & & Buffer Empty flag bit \\
\hline & & & Select Input bit \\
\hline & & & ter Select Output bit \\
\hline & & & 4. - = Not used-indeterminate data when read \\
\hline
\end{tabular}

Table 3. Control/Status Registers Formats Summary
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline Address (Hex) & \multicolumn{8}{|c|}{Bit Number} & \multirow[b]{3}{*}{\begin{tabular}{l}
BUS \\
CONTROL \\
REGISTER \\
(BCR)
\end{tabular}} \\
\hline & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 & \\
\hline 10 & CPU A ACTIVE & \multicolumn{2}{|r|}{NOT USED} & PAGE ONE EXT & \multicolumn{2}{|c|}{PORT A NIBBLE MODE} & \multicolumn{2}{|r|}{BUS EXTENSION MODE} & \\
\hline 11 & \begin{tabular}{l}
O/P \\
BUFF \\
FULL \\
INT \\
FLAG \\
(OBF)
\end{tabular} &  & \begin{tabular}{l}
I/O \\
REG SEL \\
(RSI) \\
(RSO)
\end{tabular} & NOT USED & \begin{tabular}{l}
I/OA INT \\
ENBL \\
I/OB \\
INT \\
ENBL
\end{tabular} & \begin{tabular}{l}
HOST INT \\
ENBL
\end{tabular} & \[
\begin{aligned}
& \text { HOST } \\
& \text { BUS } \\
& \text { ENBL }
\end{aligned}
\] &  & \begin{tabular}{l}
HOST \\
CONTROL AND \\
STATUS \\
REGISTER \\
(HCSR)
\end{tabular} \\
\hline \multirow[b]{2}{*}{12} & \begin{tabular}{l}
IPCA \\
INT \\
FLAG
\end{tabular} & \multirow[t]{2}{*}{\begin{tabular}{l}
PF2 \\
LOW \\
INT \\
FLAG
\end{tabular}} & \multirow[t]{2}{*}{\begin{tabular}{l}
PF1 \\
NEG \\
EDGE \\
INT \\
FLAG
\end{tabular}} & \multirow[t]{2}{*}{\begin{tabular}{l}
PFO \\
POS \\
EDGE \\
INT \\
FLAG
\end{tabular}} & \begin{tabular}{l}
IPCA \\
INT \\
ENBL
\end{tabular} & \begin{tabular}{l}
PF2A \\
INT \\
ENBL
\end{tabular} & \begin{tabular}{l}
PF1A \\
INT \\
ENBL
\end{tabular} & \begin{tabular}{l}
PFOA \\
INT \\
ENBL
\end{tabular} & \multirow[t]{2}{*}{\begin{tabular}{l}
INTERRUPT \\
CONTROL AND STATUS REGISTER (ICSR)
\end{tabular}} \\
\hline & \[
\begin{aligned}
& \text { IPCB } \\
& \text { INT } \\
& \text { FLAG }
\end{aligned}
\] & & & & \begin{tabular}{l}
IPCB \\
INT \\
ENBL
\end{tabular} & \begin{tabular}{l}
IPCB \\
INT \\
ENBL
\end{tabular} & \begin{tabular}{l}
PF1B \\
INT \\
ENBL
\end{tabular} & \begin{tabular}{l}
PFOB \\
INT \\
ENBL
\end{tabular} & \\
\hline 13 & \begin{tabular}{l} 
CLR \\
IPCA \\
INT \\
FLAG \\
\hline CLR \\
IPCB \\
INT \\
FLAG
\end{tabular} & NOT USED & \begin{tabular}{l}
CLR \\
PF1 \\
NEG \\
INT \\
FLAG
\end{tabular} & \[
\begin{aligned}
& \text { CLR } \\
& \text { PFO } \\
& \text { POS } \\
& \text { INT } \\
& \text { FLAG }
\end{aligned}
\] & \multicolumn{4}{|c|}{NOT USED} & \begin{tabular}{l}
CLEAR \\
INTERRUPT \\
FLAGS \\
REGISTER (CIFR)
\end{tabular} \\
\hline 14 & \multicolumn{8}{|c|}{WRITE ONLY REGISTER-NO SPECIFIC BIT (IPCIR)} & \begin{tabular}{l}
INTER- \\
PROCESSOR COMMUNICATION INTERRUPT REGISTER (IPCIR)
\end{tabular} \\
\hline 15 & \multicolumn{6}{|c|}{NOT USED} & \begin{tabular}{l}
LOW \\
PWR \\
CPU B \\
(LPB)
\end{tabular} & LOW PWR CPU A (LPA) & POWER CONTROL REGISTER (PCR) \\
\hline 16 & TMR A UNFL FLAG (UFA) & PF3 LEVEL IND & NOT USED & \begin{tabular}{l}
TMR A INT \\
ENBL
\end{tabular} & TMR A CLK PRESC SEL & TIMER A MODE SELECT & \multicolumn{2}{|l|}{TIMER A MODE SELECT} & TIMER A CONTROL AND STATUS REGISTER (TACSR) \\
\hline 1A & \begin{tabular}{l}
TMR B \\
UNFL \\
FLAG \\
(UFB)
\end{tabular} & PF4 LEVEL IND & NOT USED & \begin{tabular}{l}
TMR B INT \\
ENBL
\end{tabular} & \multicolumn{2}{|r|}{NOT USED} & \multicolumn{2}{|c|}{TIMER B MODE SELECT} & \multirow[t]{2}{*}{TIMER B CONTROL AND STATUS REGISTER (TBCSR)} \\
\hline \multicolumn{9}{|l|}{Note: All control and status registers are cleared to zero by \(\overline{\text { RES }}\)} & \\
\hline
\end{tabular}

\section*{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:
\(\begin{array}{ll}\text { HCSR } & \text { Host Control and Status Register } \\ \text { ICSR } & \text { Interrupt Control and Status Register }\end{array}\)

\section*{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.

\section*{CLOCK CIRCUITS}

\section*{CLOCK OSCILLATOR}

The internal clock oscillator generates the system clock (ø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 I/O 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 \(\emptyset 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.

\section*{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\) 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.

\section*{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.

\section*{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.

Power Control Register (PCR)
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{6}{|c|}{} \\
\hline \multicolumn{5}{|c|}{ NOT USED } & & LOW & LOW \\
& & & PWR & PWR B \\
(LPB) & CPU A \\
(LPA) \\
\hline
\end{tabular}
\begin{tabular}{ll} 
Bits 7-2 & Not Used (Don't care) \\
\(\frac{\text { Bit } 1}{1}\) & \begin{tabular}{c} 
Low Power Mode Select for CPU B (LPB) \\
Low power mode requested by CPU B
\end{tabular} \\
0 & Normal power mode requested by CPU B
\end{tabular}
\begin{tabular}{cc} 
Bit 0 \\
0 & Low Power Mode Select for CPU A (LPA) \\
0 & Low power mode requested by CPU A \\
Normal power mode requested by CPU A
\end{tabular}

\section*{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

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{ALTERNATIVE MODES OF OPERATION}

Bidirectional Ports \(\mathrm{C}, \mathrm{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 (D0 through D7) 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.

\section*{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 \(\overline{\mathrm{RQ}}\) '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{RQ}}\) 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)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline IPCA & \multirow{6}{*}{\begin{tabular}{l}
PF2 \\
LOW \\
INT \\
FLAG
\end{tabular}} & \multirow{6}{*}{\begin{tabular}{l}
PF1 \\
NEG \\
EDGE \\
INT \\
FLAG
\end{tabular}} & \multirow{6}{*}{PFO POS EDGE INT FLAG} & IPCA & PF2A & PF1A & PFOA \\
\hline INT & & & & INT & INT & INT & INT \\
\hline FLAG & & & & ENBL & ENBL & ENBL & ENBL \\
\hline IPCB & & & & IPCB & PF2B & PF1B & PFOB \\
\hline INT & & & & INT & INT & INT & INT \\
\hline FLAG & & & & ENBL & ENBL & ENBL & ENBL \\
\hline
\end{tabular}

Bit 7

Bit 6 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
PFO Positive Edge Detect Interrupt Flag A positive-to-negative transition on PFO occurred No positive-to-negative transition on PFO occurred

Inter-Processor Communication Interrupt Enable (A or B)

Enables inter-processor communication interrupt (bit 7) Disábles 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)
Bit \(0 \quad\) PFO Interrupt Enable (A or B)
Enables PFO interrupt (bit 4)
0 Disables PFO interrupt (bit 4)


Figure 7. Inter Processor Communication

\section*{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)
\begin{tabular}{|l|l|l|l|l|l|l|l|}
\hline \multicolumn{1}{|c|}{7} & \multicolumn{1}{|c|}{6} & \multicolumn{1}{c|}{5} & \multicolumn{1}{c|}{4} & 3 & 2 & 1 & 0 \\
\hline CLR & & & & & & & \\
IPCA & & & & & & & \\
INT & & CLR & CLR & & & \\
FLAG & NOT & PF1 & PFO & & & \\
\cline { 1 - 1 } CLR & USED & NEG & POS & & NOT USED & \\
INT & INT & & & \\
INT & & FLAG & FLAG & & & \\
FLAG & & & & & & \\
\hline
\end{tabular}

\section*{Bit 7 Clear Inter-Processing Communication Interrupt Flag Has no effect on the IPC Flag Clears the IPC Interrupt Flag (specific CPU, A or B)}

\section*{Not Used}
\begin{tabular}{cc} 
Bit 5 & Clear PF1 Interrupt Flag \\
\hline 1 & Has no effect on the PF1 Interrupt Flag \\
0 & Clears the PF1 Interrupt Flag (either CPU)
\end{tabular}

Bit 4 Clear PFO Interrupt Flag
Has no effect on the PFO Interrupt Flag
Clears the PFO Interrupt Flag (either CPU)
Bit 3-0 Not Used

\section*{OUTPUT ONLY PORT E}

The output characteristics of Port E are identical to that of the bidirectional ports. The main difference is that there is no data direction register and also no capability of reading the information being output. Attempting to read Port E loads indeterminate data onto the internal bus.

Port \(E\) is a dual function port which, in addition to being an output port, can also serve as address bits A15 through A8 when the R65C00/21 is addressing external memory and I/O devices This is discussed in more detail under Bus Extension and Host Interface.

\section*{INPUT ONLY PORT G}

The input characteristics of the 4-bit Port \(G\) are the same as a bidirectonal port in an input mode. The difference is that only four bits are input into the least significant bits of the data register and the most significant bits are loaded as zeros.

\section*{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 \(\mathrm{R} / \overline{\mathrm{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.

\section*{COUNTER/TIMER A (TA)}

Counter/Tımer 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 .

\section*{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).
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 \(\overline{R Q Q}\) 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)
\begin{tabular}{|l|l|c|c|c|c|c|c|}
\hline \multicolumn{1}{|c|}{7} & \multicolumn{1}{c|}{6} & 5 & \multicolumn{1}{c|}{4} & \multicolumn{1}{c|}{3} & 2 & 1 & 0 \\
\hline TMR A & PF3 & TMR A & TMR A & \multicolumn{3}{|c|}{ TIMER A } \\
UNFL & TMR A & CLK \\
LEVEL \\
FLAG \\
(UFA)
\end{tabular}
USD USED \begin{tabular}{l} 
INT \\
ENBL
\end{tabular} \begin{tabular}{l} 
PRESC \\
SEL
\end{tabular}
\begin{tabular}{|c|c|}
\hline Bit 7 & Timer A Underflow Flag (UFA) \\
\hline 1 & Underflow condition occurred \\
\hline 0 & No underflow \\
\hline Bit 6 & Port F Bit 3 (PF3) Level \\
\hline 1 & PF3 High \\
\hline 0 & PF3 Low \\
\hline Bit 5 & Not Used (Don't care) \\
\hline Bit 4 & Timer A Interrupt Enable \\
\hline 1 & Enable Timer A Interrupt \\
\hline 0 & Disable Timer A Interrupt \\
\hline Bit 3 & Timer A Clock Prescaier Enable \({ }^{1}\) \\
\hline 1 & Enable Clock Prescaler (ø2/128) \\
\hline 0 & Disable Clock Prescaler (ø2) \\
\hline Bits 2 to 0 & Timer A Mode Select (TAMS) \\
\hline \(\underline{2} 10\) & \\
\hline 000 & Timer A Off \\
\hline 00 & Free-Run Event Counter Mode \({ }^{1}\) \\
\hline 0 1 0 & Free-Run Pulse Width Measurement Mode \({ }^{1}\) \\
\hline 0 O 11 & Retriggerable One-Shot Timer Mode \({ }^{+}\) \\
\hline 100 & One-Shot Interval Timer Mode \\
\hline 10 & Free-Run Interval Timer Mode \\
\hline 110 & One-Shot Pulse Generation Mode \\
\hline 11 & Free-Run Pulse Generation Mode \\
\hline
\end{tabular}

Note:
1. Prescaler must be disabled (bit \(3=0\) ) for Free-Run Event Counter Miode, Free-Run Pulse Width Measurement Mode, and Retriggerable One-Shot Timer Mode. These three modes do not allow prescaling.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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 \(\varnothing 2\), or scaled \(\varnothing 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.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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).
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.
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{8}{|c|}{Timer B Control and Status Register (TBCSR)} \\
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline TMR B UNFL FLAG (UFB) & \begin{tabular}{l}
PF4 \\
LEVEL IND
\end{tabular} & NOT USED & TMR B INT ENBL & NOT & ED & & \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline Bit 7 & Timer B Underflow Flag (UFB) \\
\hline 1 & Underflow condition occurred \\
\hline 0 & No underflow \\
\hline Bit 6 & Port F Bit 4 (PF4) Level Indicator \\
\hline 1 & PF4 High \\
\hline 0 & PF4 Low \\
\hline Bit 5 & Not Used (Don't care) \\
\hline Bit 4 & Timer B Interrupt Enable \\
\hline 1 & Enable Timer B Interrupt \\
\hline 0 & Disable Timer B Interrupt \\
\hline Bits 3-2 & Not Used (Don't care) \\
\hline Bits 1-0 & Timer B Mode Select (TMS) \\
\hline 10 & \\
\hline \(0 \quad 0\) & Free-Run Interval Timer Mode \\
\hline 01 & Free-Run Pulse Generator Mode \\
\hline 0 & Event Counter Mode \\
\hline 11 & Pulse Width Measurement Mode \\
\hline
\end{tabular}

\section*{Timer B Operating Modes}

The Timer B operating mode is selected by setting bits 0 and 1 in the TBCSR to the appropriate code.

\section*{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 \(\emptyset 2\) rate. When 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.

\section*{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 ø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.

\section*{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.

\section*{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 Ø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.

\section*{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\).

\section*{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 multıplexed 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 PEO 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 \(R / \bar{W}\). The SYNC and \(\emptyset 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-01\) FF). 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 \(B C R\) ) 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 \mathrm{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 I/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)
\begin{tabular}{|c|c|c|c|l|c|c|c|}
\hline 7 & 6 & 5 & \multicolumn{1}{|c|}{4} & 3 & 2 & 1 & 0 \\
\hline CPU A \\
ACTIVE
\end{tabular} NOT USED \begin{tabular}{l} 
PAGE \\
\hline \begin{tabular}{l} 
ONE \\
EXT
\end{tabular} \\
\begin{tabular}{l} 
PORT A \\
NIBBLE \\
MODE
\end{tabular} \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline Bit 7 & CPU A Active \\
\hline 1 & CPU A active \\
\hline 0 & CPU B active \\
\hline Bits 6-5 & Not Used (Don't Care) \\
\hline Bit 4 & Page One External/Internal Mapping \\
\hline 1 & Page One External \\
\hline 0 & Page One Internal \\
\hline Bits 3-2 & Port A Write Nibble Control* \\
\hline 3 2 & \\
\hline 00 & CPU A writes to both halves (PAO-PA7). \\
\hline 01 & CPU A writes to upper half (PA4-PA7); CPU B writes to lower half (PAO-PA3). \\
\hline 10 & CPU A writes to lower half (PAO-PA3); CPU B writes to upper half (PA04-PA7). \\
\hline 11 & CPU B writes to both halves (PA0-PA7). \\
\hline Bits 1-0 & Bus Extension Mode \\
\hline 10 & \\
\hline 00 & Bus Extension Mode not selected. \\
\hline 0 & 8-bit Address Extension Mode. Range equals 256. \\
\hline 10 & 12-bit Address Extension Mode. Range equals 4096. \\
\hline 11 & 16-bit Address Extension Mode. Range equals 65,536. \\
\hline
\end{tabular}

\section*{Note:}
*Either CPU may read the full port at any time.


Figure 9. Bus Extension Mode Block Diagram

\section*{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 (IINT) 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 \varnothing 2)\) and PG1 is the input for the host R/W (HRW) control lines.

When operating in the \(Z 80 / 8080\) mode, PGO 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{tabular}{|c|c|c|c|c|}
\hline \[
\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ø2 } \\
\text { (PG0) }
\end{gathered}
\] & Host Function (6500/6800 Mode) \\
\hline H & - & - & - & Host Interface Deselected \\
\hline L & L & L & H & Write Input Buffer, HCSR5 RSI cleared, set IBF \\
\hline L & L & H & H & Read Output Buffer, Clear OBF \\
\hline L & H & L & H & Write Input Buffer, HCSR5 RS1 set, set IBF \\
\hline L & H & H & H & Read upper 3 bits of HCSR; OBF, IBF \& RSO \\
\hline \[
\begin{gathered}
\overline{\mathrm{CS}} \\
\text { (PG3) }
\end{gathered}
\] & \[
\begin{aligned}
& \text { HRS } \\
& \text { (PG2) }
\end{aligned}
\] & \[
\begin{aligned}
& \overline{\text { HWR }} \\
& \text { (PG1) }
\end{aligned}
\] & \[
\begin{aligned}
& \hline \overline{\text { HRD }} \\
& \text { (PGO) }
\end{aligned}
\] & Host Function (8080/Z80 Mode) \\
\hline H & - & - & - & Deselected \\
\hline L & L & L & H & Write Input Buffer, HCSR5 RSI cleared, set IBF \\
\hline L & L & H & L & Read Output Buffer, Clear OBF \\
\hline L & H & L & H & Write Input Buffer, HCSR5 RS1 set, set IBF \\
\hline L & H & H & L & Read upper 3 bits of HCSR; OBF, IBF \& RSO \\
\hline
\end{tabular}

Host Control and Status Register (HCSR)
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline O/P BUFF FULL INT FLAG (OBE) & IV BUFF FULL INT FLAG (IBF) & I/O REG SEL (RSI) (RSO) & \[
\begin{aligned}
& \text { NOT } \\
& \text { USED }
\end{aligned}
\] & \begin{tabular}{l}
I/OA INT ENBL \\
I/OB INT ENBL
\end{tabular} & HOST INT ENBL & HOST BUS ENBL & HOST BUS TYPE \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline Bit 7 & Output Buffer Empty (OBE) Flag \\
\hline 1 & Output Buffer Full \\
\hline 0 & Output Buffer Empty \\
\hline Bit 6 & Input Buffer Full (IBF) Flag \\
\hline 1 & Input Buffer Full \\
\hline 0 & Input Buffer Empty \\
\hline Bit 5 & Register Select \\
\hline - & Distinguishes commands from data. Host reads \\
\hline & RSO and R65C00/21 reads RSI. Selection of 1 or 0 \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline Bit 4 & Not Used. (Don't care) \\
\hline Bit 3 & Input/Output Buffer Interrupt Enable \\
\hline 1 & Enable IRQ IBF = 1) \\
\hline 0 & Disable IRQ \\
\hline
\end{tabular}

Bit \(2 \quad\) Host Interrupt (IMIT) Output Enable
Disable HINT Output to Host
Enable HINT Output to Host (OBF =1)
\begin{tabular}{cc} 
Bit 1 & Host Bus Enable \\
1 & Disable Host Bus \\
0 & Enable Host Bus
\end{tabular}

Bit \(0 \quad\) Host Bus Type
Host Bus is \(\mathrm{Z80} / 8080\)
Host Bus is \(6500 / 6800\)
Note:
Register is cleared to all zeros by \(\overline{\mathrm{RES}}\).


Figure 10. Host Mode Block Diagam

\section*{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{\mathrm{RES}}\) input pin.

\section*{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
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Description & Mnemonic & Description \\
\hline ADC & Add Memory to Accumulator with Carry & LDA & Load Accumulator with Memory \\
\hline AND & "AND" Memory with Accumulator & LDX & Load Index X with Memory \\
\hline \multirow[t]{2}{*}{ASL} & \multirow[t]{2}{*}{Shift Left One Bit (Memory or Accumulator)} & LDY & Load Index Y with Memory \\
\hline & & LSR & Shift One Bit Right (Memory or Accumulator) \\
\hline *BRA & Branch Always & & \\
\hline *BBR & Branch on Bit Reset Relative & *MUL & Multiply \\
\hline *BBS & Branch on Bit Set Relative & & \\
\hline BCC & Branch on Carry Clear & NOP & No Operation \\
\hline BCS & Branch on Carry Set & & \\
\hline BEQ & Branch on Result Zero & ORA & "OR" Memory with Accumulator \\
\hline BIT & Test Bits in Memory with Accumulator & & \\
\hline BMI & Branch on Result Minus & PHA & Push Accumulator or Stack \\
\hline BNE & Branch on Result not Zero & PHP & Push Processor Status on Stack \\
\hline BPL & Branch on Result Plus & * PHX & Push Index X \\
\hline BRK & Force Break & *PHY & Push Index Y \\
\hline BVC & Branch on Overflow Clear & PLA & Pull Accumulator from Stack \\
\hline \multirow[t]{2}{*}{BVS} & \multirow[t]{2}{*}{Branch on Overflow Set} & PLP & Pull Processor Status from Stack \\
\hline & & *PLX & Pull Index X \\
\hline CLC & Clear Carry Flag & *PLY & Pull Index Y \\
\hline CLD & Clear Decimal Mode & & \\
\hline CLI & Clear Interrupt Disable Bit & *RMB & Reset Memory Bit \\
\hline CLV & Clear Overflow Flag & ROL & Rotate One Bit Left (Memory or Accumulator) \\
\hline CMP & Compare Memory and Accumulator & ROR & Rotate One Bit Right (Memory or Accumulator) \\
\hline CPX & Compare Memory and Index X & RTI & Return from Interrupt \\
\hline CPY & Compare Memory and Index Y & RTS & Return from Subroutine \\
\hline DEC & Decrement Memory by One & SBC & Subtract Memory from Accumulator with Borrow \\
\hline DEX & Decrement Index X by One & SEC & Set Carry Flag \\
\hline \multirow[t]{2}{*}{DEY} & \multirow[t]{2}{*}{Decrement Index Y by One} & SED & Set Decimal Mode \\
\hline & & SEI & Set Interrupt Disable Status \\
\hline \multirow[t]{2}{*}{EOR} & \multirow[t]{2}{*}{"Exclusive-Or" Memory with Accumulator} & *SMB & Set Memory Bit \\
\hline & & STA & Store Accumulator in Memory \\
\hline INC & Increment Memory by One & STX & Store Index X in Memory \\
\hline INX & Increment Index \(X\) by One & STY & Store Index Y in Memory \\
\hline \multirow[t]{2}{*}{INY} & \multirow[t]{2}{*}{Increment Index Y by One} & & \\
\hline & & TAX & Transfer Accumulator to Index X \\
\hline JMP & Jump to New Location & TAY & Transfer Accumulator to Index Y \\
\hline \multirow[t]{4}{*}{JSR} & \multirow[t]{4}{*}{Jump to New Location Saving Return Address} & TSX & Transfer Stack Poınter to Index X \\
\hline & & TXA & Transfer Index \(X\) to Accumulator \\
\hline & & TXS & Transfer Index \(X\) to Stack Register \\
\hline & & TYA & Transfer Index Y to Accumulator \\
\hline
\end{tabular}


\section*{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.


\section*{I/O PORT WAVEFORMS-ALL PORTS}


I/O PORT TIMING—ALL PORTS
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Symbol} & 2 MHz & 4 MHz & \multirow[b]{2}{*}{Min} & \multirow[b]{2}{*}{Max} \\
\hline & & Min & Max & & \\
\hline Input Data Setup Time & \(t_{\text {PS }}\) & 50 & - & 35 & - \\
\hline Input Data Hold Time (Port D) & \(\mathrm{t}_{\mathrm{PH}}\) & 10 & - & 10 & - \\
\hline \begin{tabular}{l}
Input Data Hold Time \\
(All ports except D)
\end{tabular} & & 25 & - & 25 & - \\
\hline Output Data Delay Time & \(\mathrm{t}_{\mathrm{PD}}\) & - & 120 & - & 100 \\
\hline
\end{tabular}

\section*{EXPANSION BUS TIMING}
\(\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\right.\) to \(70^{\circ} \mathrm{C}\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{2 MHz} & \multicolumn{2}{|c|}{4 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min. & Max. & Min. & Max. & \\
\hline \multicolumn{7}{|l|}{Clock/Control Timing} \\
\hline 02 Cycle Time & \(\mathrm{t}_{\mathrm{CYC}}\) & 500 & See Note 1 & 250 & See Note 1 & ns \\
\hline Pulse Width 02 Low & \(\mathrm{t}_{\text {PWL }}\) & 235 & 265 & 115 & 135 & ns \\
\hline Pulse Width 02 High & \(t_{\text {PWH }}\) & 235 & 265 & 115 & 135 & ns \\
\hline ¢A Delay Time - \(\emptyset 2\) to \(\emptyset 2 \mathrm{~A}\) & \(\mathrm{t}_{2 \mathrm{AD}}\) & 0 & 60 & 0 & 50 & ns \\
\hline \(\overline{\text { EMS }}\) Delay Time - Address Valid to EMS Low & \(t_{\text {EMA }}\) & 10 & - & 10 & - & ns \\
\hline EMS Delay Time - \(\emptyset 2\) to EMS Low & \(\mathrm{t}_{\text {EMD }}\) & - & 150 & - & 115 & ns \\
\hline EMS Hold Time & \(\mathrm{t}_{\text {EMH }}\) & 10 & - & 10 & - & ns \\
\hline R \(\bar{W}\) Delay Time & \(\mathrm{t}_{\text {RWD }}\) & 20 & 100 & 10 & 80 & ns \\
\hline PE Address Delay Time & \(t_{\text {AED }}\) & 20 & 100 & - 10 & 80 & ns \\
\hline PD Address Delay Time & \(t_{\text {ADD }}\) & 20 & 120 & 10 & 100 & ns \\
\hline \multicolumn{7}{|l|}{Write Timing} \\
\hline Data Delay Time - Write & \(\mathrm{t}_{\text {DDW }}\) & - & 120 & - & 100 & ns \\
\hline Data Hold Time - Write & \(\mathrm{t}_{\text {DHW }}\) & 20 & - & 20 & - & ns \\
\hline \multicolumn{7}{|l|}{Read Timing} \\
\hline PD Address Hold Tıme - Read & \(\mathrm{t}_{\text {ADH }}\) & 0 & 80 & 0 & 60 & ns \\
\hline Data Setup Time - Read & \(\mathrm{t}_{\text {DSR }}\) & 50 & - & 35 & - & ns \\
\hline Data Hold Time - Read & \(t_{\text {DHR }}\) & 10 & - & 10 & - & ns \\
\hline \multicolumn{7}{|l|}{Note: 1. The \(\emptyset 2\) clock should never be held static at a dc level. The maximum cycle time ( \(\mathrm{t}_{\mathrm{C} Y \mathrm{C}}\) ) that guarantees no data loss to internal registers is 20 microseconds.} \\
\hline
\end{tabular}

\section*{EXPANSION BUS WRITE CYCLE WAVE FORMS}


\section*{EXPANSION BUS READ CYCLE WAVE FORMS}


\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{iN}}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & Vdc \\
\hline Operatıng Temperature & \(\mathrm{T}_{\mathrm{A}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: 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.

\section*{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)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Max & Unit & Test Condition \\
\hline Input High Voltage & \(\mathrm{V}_{\mathrm{IH}}\) & +2.0 & - & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\text {LL }}\) & - & +0.8 & V & \\
\hline Output High Voltage & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\
& \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A}
\end{aligned}
\] \\
\hline Input Leakage Current & \(\mathrm{I}_{\text {N }}\) & - & \(\pm 10\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V} \text { or } \mathrm{V}_{\mathrm{CC}} \\
& \mathrm{~V}_{\mathrm{CC}}=0 \mathrm{~V}
\end{aligned}
\] \\
\hline Output Low Voltage & \(\mathrm{V}_{\text {OL }}\) & - & +0.4 & V & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V} \\
& \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Output Low Current \\
(All ports except Port G)
\end{tabular} & lout & - & -1.6 & mA & \(\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}\) \\
\hline Input Capacitance (XTALO, XTALI) (All Others) & \(\mathrm{C}_{\text {IN }}\) & - & \[
\begin{array}{r}
25 \\
5
\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}
\] \\
\hline Output Capacitance & \(\mathrm{C}_{\text {OUt }}\) & - & 10 & pF & \(\mathrm{A}=25^{\circ} \mathrm{C}\) \\
\hline Operating Frequency Crystal or Master Clock ø2 Clock & - & \[
\begin{aligned}
& .02 \\
& .01
\end{aligned}
\] & \[
\begin{aligned}
& 8.0 \\
& 4.0
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{MHz} \\
& \mathrm{MHz}
\end{aligned}
\] & \\
\hline Power Dissipation & \(\mathrm{P}_{\mathrm{D}}\) & - & 40 & mW & \[
\begin{aligned}
& V_{C C}=5 \mathrm{~V} \\
& f=2 \mathrm{MHz} \\
& T_{A}=25^{\circ} \mathrm{C}
\end{aligned}
\] \\
\hline
\end{tabular}

\section*{PACKAGE DIMENSIONS}

64 PIN PLASTIC QUIP (QUAD IN-LINE PACKAGE)


\title{
R65F11 AND R65F12 FORTH BASED MICROCOMPUTERS
}

\section*{SECTION 1 \\ INTRODUCTION}

\subsection*{1.1 FEATURES}
- FORTH kernel in ROM
- Enhanced 6502 CPU
-Four new bit manipulation instructions:
Set Memory Bit (SMB)
Reset Memory Bit (RMB)
Branch on Bit Set (BBS)
Branch on Bit Reset (BBR)
-Decimal and binary arithmetic modes
- 13 addressing modes
-True indexing
- 192-byte static RAM
- 16 bidirectional, TTL-compatible I/O lines (two ports, R65F11) or 40 bidirectional, TTL-compatible I/O lines (five ports, R65F12)
- One 8-bit port with programmable latched input
- Two 16-bit programmable counter/timers, with latches
-Pulse width measurement
-Asymmetrical pulse generation
-Pulse generation
-Interval timer
-Event counter
-Retriggerable interval timer
- Serial port
-Full-duplex asynchronous operation mode
-Selectable 5- to 8-bit characters
-Wake-up feature
-Synchronous shift register mode
-Standard programmable bit rates, programmable up to 62.5K 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-MHz or \(1-\mathrm{MHz}\) internal operation
-Internal clock with external XTAL at two times internal frequency
-External clock input divided by one or two
- \(1 \mu \mathrm{~s}\) minimum instruction execution time @ 2 MHz
- NMOS silicon gate, depletion load technology
- Single +5 V power supply
- 12 mW standby power for 32 bytes of the 192-byte RAM
- 40-pin DIP (R65F11)
- 64-pin QUIP (R65F12) has three additional 8-bit I/O ports to provide a total of \(40 \mathrm{I} / \mathrm{O}\) lines.

\subsection*{1.2 SUMMARY}

The Rockwell R65F11 and R65F12 are complete, high-performance 8 -bit NMOS single chip microcomputers, and are compatible with all members of the R6500 family.

The kernel of the high level Rockwell Single Chip RSC-FORTH language is contained in the preprogrammed ROM of the R65F11 and R65F12. RSC-FORTH is based on the popular fig-FORTH model with extensions. All of the run time functions of RSCFORTH are contained in the ROM, including 16 - and 32 -bit mathematical, logical and stack manipulation, plus memory and input/output operators. The RSC-FORTH Operating System allows an external user program written in RSC-FORTH or Assembly Language to be executed from external EPROM, or development of such a program under the control of the R65FR1 RSC-FORTH Development ROM. Other development ROM's can also be accommodated.

The R65F11 and R65F12 consist of an enhanced 6502 CPU, an internal clock oscillator, 192 bytes of Random Access Memory (RAM) and versatile interface circuitry. The interface circuitry includes two 16-bit programmable timer/counters, 16 bidirectional input/output lines (including four edge-sensitive lines and input latching on one 8 -bit port), a full-duplex serial I/O channel, ten interrupts and bus expandability.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of
computational power These features in combination with the FORTH high level operating system make the R65F11 and R65F12 ideal for microcomputer applications.

For systems requiring additional I/O ports, the 64-pin QUIP version, the R65F12, provides three additional 8 -bit ports.

A complete RSC-FORTH development system can be created with three MOS parts: the R65F11, one RAM chip and the R65FR1 Development ROM.

This product description is for the reader familiar with the R6502 CPU hardware and programmıng capabilities. A detailed description of the R6502 CPU hardware is included in the R6500 Microcomputer System Hardware Manual
(Order Number 201). A description of the instruction capabilites of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Order Number 202).

\subsection*{1.3 ORDERING INFORMATION}
\begin{tabular}{|l|l|}
\hline \multicolumn{1}{|c|}{ Part No. } & \multicolumn{1}{c|}{ Description } \\
\hline 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 & \begin{tabular}{l} 
FORTH Kernel ROM for expanded capacity \\
development
\end{tabular} \\
R65FR3P & \begin{tabular}{l} 
FORTH Development ROM for R6501Q \\
R65FK3P \\
FORTH Kernel ROM for R6501Q
\end{tabular} \\
\hline Order No. & \multicolumn{1}{|c|}{ Description } \\
\hline 2148 & FORTH Based Microcomputer User's Manual* \\
\hline \multicolumn{2}{|c|}{\begin{tabular}{l} 
Note: \\
*Included with R65FR1.
\end{tabular}} \\
\hline
\end{tabular}

\section*{SECTION 2 \\ INTERFACE REQUIREMENTS}

This section describes the interface requirements for the R65F11 and R65F12 single chip microcomputers. Figure 2-1 is the Interface Diagram for the R65F11 and R65F12, Figure 2-2 shows the pin out configuration and Table 2-1 describes the function of each pin of the R65F11 and R65F12. Figure \(3-1\) is a detailed block diagram.


Figure 2-1. R65F11 and R65F12 Interface Diagram

Table 2-1. R65F11 and R65F12 Pin Descriptions
\begin{tabular}{|c|c|c|c|}
\hline Signal Name & Pin No. R65F11 & Pin No. R65F12 & Description \\
\hline \(V_{\text {cc }}\) & 21 & 50 & Main power supply +5V \\
\hline \(V_{\text {RR }}\) & 39 & 12 & Separate power pin for RAM. In the event that \(\mathrm{V}_{\mathrm{Cc}}\) power is lost, this power retains RAM data. \\
\hline \(\mathrm{V}_{\text {Ss }}\) & 40 & 11 & Signal and power ground (OV) \\
\hline XTLI & 2 & 10 & Crystal or clock input for internal clock oscillator. Also allows input of X 1 clock signal if XTLO is connected to \(\mathrm{V}_{\text {ss }}\) or X 2 or \(\mathrm{X}_{4}\) clock if XTLO is floated. \\
\hline XTLO & 1 & 9 & Crystal output from internal clock oscillator. \\
\hline \(\overline{\text { RES }}\) & 20 & 41 & The Reset input is used to initialize the R65F11. This signal must not transition from low to high for at least eight cycles after \(V_{c c}\) reaches operating range and the internal oscillator has stabilized. \\
\hline \$2 & 3 & 13 & Clock signal output at internal frequency. \\
\hline \(\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. \\
\hline PAO-PA7 & 30-23 & 64-57 & Two 8-bit ports used for either \\
\hline PB0-PB7 & 38-31 & 8-1 & input/output. Each line of Ports A and B consist of an active transistor to \(\mathrm{V}_{\text {SS }}\) and a passive pull-up to \(\mathrm{V}_{\mathrm{cc}}\). \\
\hline \[
\begin{aligned}
& \text { PCO-PC7 } \\
& \text { AO-A3 } \\
& \mathrm{A} 12, \mathrm{R} \bar{W} \\
& \mathrm{~A} 13, \overline{E M S}
\end{aligned}
\] & 4-11 & 25-32 & Port C has an active pull-up transistor. Port D has active pull-up and pull-down transistors. Ports C and D lines form the external multiplexed \\
\hline \[
\begin{aligned}
& \text { PDO-PD7 } \\
& \text { A4-A11 } \\
& \text { D0-D7 }
\end{aligned}
\] & 19-12 & 40-33 & address and data bus to allow external memory addressing. \\
\hline PE0-PE7 & & 49-42 & On the R65F12, Port E may \\
\hline PF0-PF7 & & 24-17 & be used for output only. Ports \\
\hline PG0-PG4 & & 52-56, & F and \(G\) are similar to Ports \\
\hline PG5-PG7 & & 14-16 & \(A\) and \(B\) in construction and may be used for inputs or outputs. \\
\hline
\end{tabular}


Figure 2-2. Pin Out Configuration

\section*{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 kernel of FORTH in ROM complements the system hardware. A block diagram of the system is shown in Figure 3-1.

\section*{NOTE}

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

\subsection*{3.1 CPU LOGIC}

The R65F11 internal CPU is a standard 6502 configuration with an 8-bit Accumulator register, two 8-bit Index Registers ( X and Y ); an 8 -bit Stack Pointer register, and ALU, a 16 -bit Program Counter, and standard instruction register/decode and internal timing control logic.

\subsection*{3.1.1 Accumulator}

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

\subsection*{3.1.2 Index Registers}

There are two 8-bit index registers, X and Y . Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

\subsection*{3.1.3 Stack Pointer}

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal \(\overline{\mathrm{RQ}}\) interrupt, or the external interrupt line \(\overline{\mathrm{NMI}}\). The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may only be accessed from the top. The address of a memory location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1. Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus, and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 00FF-0040. After reset, which leaves the Stack Pointer indeterminate, normal usage calls for its initialization at 00FF.

\subsection*{3.1.4 Processor Status Register}

The 8-bit Processor Status Register contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6500 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. See Appendix B for details.

\subsection*{3.1.5 Program Counter}

The 16-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter ( PCL ) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter ( PCH ) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

\subsection*{3.1.6 Arithmetic And Logic Unit (ALU)}

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

\subsection*{3.1.7 Instruction Register and Instruction Decode}

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register then decoded along with timing and interrupt signals to generate control signals for the various registers.


Figure 3-1. Detailed Block Diagram

\subsection*{3.1.8 Timing Control}

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to TO each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.

\subsection*{3.1.9 Interrupt Logic}

Interrupt logic controls the sequencing of three interrupts; \(\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}\) and \(\overline{\mathrm{IRQ}}\). \(\overline{\mathrm{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.

\subsection*{3.2 CPU INSTRUCTION SET}

The machine code instruction set of the R65F11 and R65F12 microcomputers are based on the popular R6500 microprocessor set. They contain all the instructions in the standard R6502 set, with the addition of the four new bit instructions added to the R6511 processor family. Refer to Appendix A for the Op Code mnemonics addressing matrix for details on these instructions.

\subsection*{3.3 READ-ONLY-MEMORY (ROM)}

The ROM consists of preprogrammed memory with an address space from F400 to FFFF. It contains the run time kernel of the high level language Rockwell Single Chip FORTH. There are 133 included functions stored in the ROM. Codes are in the format of a two byte code field, which identifies the interpreter assigned to execute that word, followed by a variable length Parameter Field, which contains the instructions and data used by that interpreter according to the programmed intention of that definition. See Appendix D for a complete list of the names of all included words. All words needed for support of the run time operation of dedicated applications programs are included. The RSC-FORTH Operating System is also part of the ROM code and is entered upon Reset. This Operating System allow the R65F11 and R65F12 to auto start a user program written in either RSC-FORTH or Assembly Language or enter a Development ROM if one is present. If no auto start program is found, an attempt will be made to boot an operating program from floppy disk.

\subsection*{3.4 RANDOM ACCESS MEMORY (RAM)}

The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The R65F11 and R65F12 provide a separate power pin ( \(\mathrm{V}_{\mathrm{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 \(\mathrm{V}_{\mathrm{RR}}\) must be connected to \(\mathrm{V}_{\mathrm{CC}}\). During operation \(V_{R R}\) must be at the \(V_{C C}\) level.

For the RAM to retain data upon loss of \(\mathrm{V}_{\mathrm{Cc}}, \mathrm{V}_{\mathrm{RR}}\) must be supplied within operating range and \(\overline{R E S}\) must be driven low at least eight \(\phi 2\) clock pulses before \(V_{c c}\) falls out of operating range. \(\overline{\text { RES }}\) must then be held low while \(\mathrm{V}_{\mathrm{cc}}\) is out of operating range and until at least eight \(\emptyset 2\) clock cycles after \(\mathrm{V}_{\mathrm{cc}}\) is again within operating range and the internal \(\emptyset 2\) oscillator is stabilized. \(\mathrm{V}_{\mathrm{RR}}\) must remain within \(\mathrm{V}_{\mathrm{CC}}\) operating range during normal operation. When \(V_{C C}\) is out of operating range, \(\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

\subsection*{3.5 CLOCK OSCILLATOR}

A reference frequency can be generated with the on-chip oscillator using an external crystal. The oscillator reference frequency passes through an internal countdown network (divide by 2 ) to obtain the internal operating frequency (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 \(\mathrm{V}_{\text {SS }}\), 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 pF 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 \(\emptyset 2\) outputs will be skewed in time. If skewing represents a system problem it can be avoided by the Master/Slave connection and options shown in Figure 3-4.

The R65F11 and R65F12 is operated in the CLOCK MASTER MODE. A second processor could be operated in the CLOCK

SLAVE MODE. Mask optiois 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 \(\emptyset 2\) signal to the SLAVE unit is inverted, the MASTER and SLAVE UNITS WILL OPERATE OUT. OF PHASE. This approach allows the two devices to share external memory using cycle stealing techniques.

a. Crystal Input


b. Clock Inputs

Figure 3-3. Clock Oscillator Input Options


Figure 3-4. Master/Slave Connections

\subsection*{3.6 MODE CONTROL REGISTER (MCR)}

The Mode Control Register contains 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.

\subsection*{3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)}

An \(\overline{\mathrm{RQ}}\) interrupt request can be initiated by any or all of eight possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple simultaneous interrupts will cause the 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 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{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{tabular}{|c|c|}
\hline Bit Code & Function \\
\hline IFR 0 : & PAO Positive Edge Detect Flag-Set to a " 1 "when a positive going edge is detected on PAO. Cleared by RMB O (0010) instruction or by RES. \\
\hline IFR 1: & PA1 Positive Edge Detect Flag-Set to a 1 when a positive going edge is detected on PA1. Cleared by RMB 1 (0010) instruction or by RES. \\
\hline IFR 2: & PA2 Negative Edge Detect Flag-Set to a 1 when a negative going edge is detected on PA2. Cleared by RMB 2 (0010) instruction or by \(\overline{\text { RES }}\). \\
\hline IFR 3: & PA3 Negative Edge Detect Flag-Set to 1 when a negative going edge is detected on PA3. Cleared by RMB 3 (0010) instruction or by \(\overline{\text { RES }}\). \\
\hline IFR 4: & Counter A Underflow Flag-Set to a 1 when Counter A underflow occurs. Cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES. \\
\hline IFR 5: & Counter B Underflow Flag-Set to a 1 when Counter B underflow occurs. Cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by RES. \\
\hline IFR 6: & Receiver Interrupt Flag-Set to a 1 when any of the Serial Communication Status Register bits 0 through 3 is set to a 1 . Cleared when the Receiver Status bits (SCSR 0-3) are cleared or by RES. \\
\hline IFR 7: & Transmitter Interrupt Flag-Set to a 1 when SCSR 6 is set to a 1 while SCSR 5 is a 0 or SCSR 7 is set to a 1 . Cleared when the Transmitter Status bits (SCSR \(6 \& 7\) ) are cleared or by \(\overline{\text { RES }}\). \\
\hline
\end{tabular}

\subsection*{3.8 OPERATING SYSTEM}

The system startup function, COLD, is executed upon Reset. COLD, a high level FORTH word, forms the basis of the RSC Operating System. Upon reset this function initializes the R65F11 or R65F12 registers to establish the external 16K byte memory map and disable all interrupt sources. It also sets up the serial channel for 1200 baud (assuming a 1 MHz internal clock) asynchronous transmission (seven bits, parity disabled). The internal FORTH structure "W" is prepared for use and the low level input/output vectors are forced to point to the system serial channel routines. The FORTH User Area Pointer, UP, is assigned the value 0300 Hex.

A test is made of the variable CLD/WRM in memory location 030E. If this contains a value other than A55A Hex a cold reset is assumed. In this case, the low level IRQ vector, IRQVEC; the low level NMI Vector, NMIVEC, and the high level interrupt vector, INTVEC, are all forced to point to the system reset routine. This prevents an unintentionally generated interrupt from crashing the system. System variables TIB, RO, SO, UC/L, UPAD, UR/W and BASE are also initialized to their default values.

Whether a warm or cold reset, the memory map is then searched at every 1 K byte boundary starting at location 0400 Hex. The first two bytes at each boundary are checked against an A55A Hex bit pattern. This pattern indicates that an auto start program is installed. The next two bytes are assumed to point to the Parameter Field of the high level RSC-FORTH word to be executed upon reset. This may be the main function of a user defined program or the start up routine of a Development ROM. Figure 3-7 details proper alignment.

If no auto start ROM is found, the Operating System turns control over to a program that issues a "NO ROM" message to the systems terminal via the serial channel and attempts to boot a program from disk. A floppy disk controller, compatible with the WD1793 type, is assumed to be present at address 0100 Hex . The first half of Track 0 Sector 1 is loaded from a double density boot diskette into RAM starting at address 005 F . When successfully loaded execution will be turned over to this boot program.


Figure 3-7. Auto Start ROM

\title{
SECTION 4 PARALLEL INPUT/OUTPUT PORTS
}

The R65F11 has 16 VO lines grouped into two 8-bit ports (PA, PB) and 16 lines programmed as an Address/Data bus (PC \& PD). Ports A and B may be used either for input or output individually or in groups of any combination. The R65F12 has 24 additional port lines grouped into three 8 -bit ports (PE, PF, PG).

Multifunction I/O's such as Port A are protected from normal port I/O instructions when they are programmed to perform a multiplexed function.

Internal pull-up resistors (FET's with an impedance range of \(3 \mathrm{~K} \leqslant \mathrm{Rpu} \leqslant 12 \mathrm{~K}\) ohm) are provided on all port pins.

The direction of the I/O lines are controlled by 8 -bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, which simplifies I/O handling. The I/O addresses are shown in Table 4-1.

Table 4-1. I/O Port Addresses
\begin{tabular}{|c|c|}
\hline Port & Address \\
\hline A & 0000 \\
B & 0001 \\
E & 0004 \\
G & 0005 \\
\hline
\end{tabular}

Appendix F. 4 shows the I/O Port Timing.

\subsection*{4.1 INPUTS}

Inputs for Ports A and B are enabled by loading logic 1 into all \(1 / 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.0V) input will cause a logic 1 to be read. An \(\overline{R E S}\) signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

The status of the input lines can be interrogated at any time by reading the I/O port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers.

Read/Modify/Write instructions can be used to modify the operation of PA and PB. During the Read cycle of a Read/ Modify/Write instruction the Port IO register is read. For all other read instructions the port input lines are read. Read/ Modify/Write instructions are: ASL, DEC, INC, LSR, RMB, ROL, ROR, and SMB.

\subsection*{4.2 OUTPUTS}

Outputs for Ports A and B are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( \(>2.4 \mathrm{~V}\) ) output while a logic 0 will force a low ( \(<0.4 \mathrm{~V}\) ) output.

\subsection*{4.3 PORT A (PA)}

Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as a standard parallel 8 -bit, bit independent, l/O port or as serial channel I/O lines, counter I/O 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 \(\varnothing 2\) clock rate. Edge detection timing is shown in Appendix F.4.

\subsection*{4.4 PORT B (PB)}

Port B can be programmed as an 8 bit, bit independent \(1 / 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 tıming for Port \(B\) is shown in Appendix F.4.

Table 4-2. Port B Control \& Usage
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{4}{*}{\[
\begin{gathered}
\text { Pin } \\
\text { No. } \\
\text { R65F11 }
\end{gathered}
\]} & \multirow[b]{4}{*}{} & \multicolumn{2}{|r|}{I/O Mode} & \multicolumn{2}{|c|}{Latch Mode} \\
\hline & & \multicolumn{2}{|r|}{MCR4 \(=0\)} & \multicolumn{2}{|l|}{\begin{tabular}{l}
\[
\text { MCR4 }=1
\] \\
(2)
\end{tabular}} \\
\hline & & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & & Name & Type (1) & Name & Type \\
\hline 38 & 8 & PBO & I/O & PBO & INPUT \\
\hline 37 & 7 & PB1 & 1/0 & PB1 & INPUT \\
\hline 36 & 6 & PB2 & 1/0 & PB2 & INPUT \\
\hline 35 & 5 & PB3 & 1/0 & PB3 & INPUT \\
\hline 34 & 4 & PB4 & I/O & PB4 & INPUT \\
\hline 33 & 3 & PB5 & 1/0 & PB5 & INPUT \\
\hline 32 & 2 & PB6 & 1/0 & PB6 & INPUT \\
\hline 31 & 1 & PB7 & I/O & PB7 & INPUT \\
\hline
\end{tabular}

\footnotetext{
(1) Resistive pull-up, active buffer pull down
(2) Input data is stored in port B latch by PAO pulse
}

Table 4-3. Port A Control and Usage


\subsection*{4.5 PORT C (PC)}

Port C is preprogrammed as part of the Address/Data bus. PC0-PC7 function as A0-A3, A12, RW, A13, and EMS, respectively, as shown in Table 4-4. EMS (External Memory Select) is asserted (low) whenever the internal processor accesses memory area between 0100 and 3FFF. (See Memory Map, Appendix C). The leading edge of EMS may be used to strobe the eight address lines multiplexed on Port D. See Appendix F. 3 for Port C timing.

\subsection*{4.6 PORT D (PD)}

Port [ is also preprogrammed as part of the Address/Data bus. Data bits D0 through D7 are time multiplexed with address bits A4 through A11, respectively. Refer to the Memory Maps (Appendix C) for Multiplexed memory assignments. See Appendix F. 3 for Port D timing.

\subsection*{4.7 PORT E (PE), PORT F (PF), PORT G (PG)}

Ports E, F and G are available on the R65F12 only. Port E can only be used as outputs. Port F and Port G can be used for inputs or outputs and are similar to Port A and Port B in operation.

Table 4-4. Port C Control and Usage
\begin{tabular}{|c|c|c|}
\hline \multirow[b]{4}{*}{R65F11/ R65F12 Port} & \multicolumn{2}{|c|}{Multiplexed Mode} \\
\hline & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=1
\end{aligned}
\]} \\
\hline & \multicolumn{2}{|c|}{Signal} \\
\hline & Name & Type (1) \\
\hline PC0 & A0 & OUTPUT \\
\hline PC1 & A1 & OUTPUT \\
\hline PC2 & A2 & OUTPUT \\
\hline PC3 & A3 & OUTPUT \\
\hline PC4 & A12 & OUTPUT \\
\hline PC5 & R/W & OUTPUT \\
\hline PC6 & A13 & OUTPUT \\
\hline PC7 & EMS & OUTPUT \\
\hline
\end{tabular}

Table 4-5. Port D Control and Usage
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{5}{*}{R65F11/ R65F12 Port} & \multicolumn{4}{|c|}{Multiplexed Mode} \\
\hline & \multicolumn{4}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=1 \\
& \text { MCR5 }=1
\end{aligned}
\]} \\
\hline & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & \multicolumn{2}{|c|}{Phase 1} & \multicolumn{2}{|c|}{Phase 2} \\
\hline & Name & Type (2) & Name & Type (3) \\
\hline PDO & A4 & OUTPUT & DATAO & I/O \\
\hline PD1 & A5 & OUTPUT & DATA1 & 1/0 \\
\hline PD2 & A6 & OUTPUT & DATA2 & \(1 / 0\) \\
\hline PD3 & A7 & OUTPUT & DATA3 & \(1 / 0\) \\
\hline PD4 & A8 & OUTPUT & DATA4 & 1/0 \\
\hline PD5 & A9 & OUTPUT & DATA5 & \(1 / 0\) \\
\hline PD6 & A10 & OUTPUT & DATA6 & 1/0 \\
\hline PD7 & A11 & OUTPUT & DATA7 & 1/0 \\
\hline \multicolumn{5}{|l|}{\multirow[t]{3}{*}{\begin{tabular}{l}
(1) Active Buffer Pull-up and Pull-Down \\
(2) Tri-State Buffer is in Active Mode \\
(3) Tri-State Buffer is in Active Mode only during the Phase 2 Portion of a Write Cycle
\end{tabular}}} \\
\hline & & & & \\
\hline & & & & \\
\hline
\end{tabular}

\section*{SECTION 5 SERIAL INPUT/OUTPUT CHANNEL}

The R65F11 and R65F12 Mıcrocomputers provide a full duplex Serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 5-1. The serial bit rate is determined by Counter A for all modes except the Receiver Shift Register (RCVR S/R) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5 K bits per second (@ ø2 \(=1 \mathrm{MHZ}\) ). The transmitter (XMTR) and receiver (RCVR) can be independently programmed to operate in different modes and can be independently enabled or disabled.


Figure 5-1. Serial Communication Control Register
Except for the Receiver Shift Register Mode (RCVR S/R), all XMTR and RCVR bit rates will occur at one sixteenth of the Counter A interval timer rate. Counter \(A\) is forced into an interval timer mode whenever the serial \(I / O\) is enabled in a mode requiring an internal ctock.

Whenever Counter \(A\) is required as a timing source it must be loaded with the hexadecimal code that selects the data rate for the serial I/O Port Refer to Counter A (paragraph 6.1) for a table of hexadecimal values to represent the desired data rate.

\subsection*{5.1 TRANSMITTER OPERATION (XTMR)}

The XTMR operation and the transmitter related control/ status functions are enabied 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 })
\]

\subsection*{5.2 RECEIVER OPERATION (RCVR)}

The receiver and its selected control and status functions are enabled when SCCR-6 is set to a " 1 ." In the ASYN mode, data format must have a start bit, appropriate number of data bits, a parity bit (if enabled) and one stop bit. Refer to Figure \(5-2\) for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start bit and a strobe signal is generated at the approximate center of each incoming bit. Refer to Figure 5-3 for ASYN Receive Data Timing. The character assembly process does not start if the start bit signal is less than one-half the bit time after a low level is detected on the Receive Data Input. Framing error, over-run, and parity error conditions or a RCVR Data Register Full will set the appropriate status bits, and any of the above conditions will cause an Interrupt Request if the Receiver Interrupt Enable bit is set to logic 1.


Internal

- Serial Input Data Shifted in

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 SCSR0-3 are true.

\subsection*{5.3 SERIAL COMMUNICATION STATUS REGISTER (SCSR)}

The Serial Communication Status Register (SCSR) holds information on various communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 5-5. Bit assignments and functions of the SCSR are as follows:

SCSR 0: Receiver Data Register Full-Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by \(\overline{\text { RES }}\) and is disabled if SCCR \(6=0\). The SCSR 0 bit will not be set to a logic 1 if the received data contains an error condition, 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 Regıster, 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 writung 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 logıc 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{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 ASTYN 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{\mathrm{RES}}\).


Figure 5-5. SCSR Bit Allocations

\subsection*{5.4 WAKE-UP FEATURE}

In a multi-distributed microprocessor or microcomputer applications, a destination address is usually included at the beginning of the message. The Wake-Up Feature allows non-selected CPU's to ignore the remainder of the message until the beginning of the next message by setting the WakeUp bit. As long as the Wake-Up flag is true, the Receiver Data Register Full Flag remains false. The Wake-Up bit is automatically cleared when the receiver detects a string of ten consecutive 1's which indicates an idle transmit line. When the next byte is received, the Receiver Data Register Full Flag signals the CPU to wake-up and read the received data.

\section*{SECTION 6 COUNTER/TIMERS}

The R65F11 and R65F12 Microcomputers contain two 16-bit counters (Counter A and Counter B) and three 16-bit latches associated with the counters. Counter \(A\) has one 16 -bit latch and Counter B has two 16-bit latches. Each counter can be independently programmed to operate in one of four modes:

\section*{Counter A}
- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Counter

\section*{Counter B}
- Retriggerable Interval Counter
- Asymmetrical Pulse

Generation
- Interval Timer
- Event Counter

Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initializatıon value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4.2).

\subsection*{6.1 COUNTER A}

Counter A consists of a 16-bit counter and a 16-bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contains the count of either \(\phi 2\) clock pulses or external events, depending on the counter mode selected. The contents of Counter A may be read any time by executing a read at location 0019 for the Upper Counter A and at location 001A or location 0018 for the Lower Counter A. A read at location 0018 also clears the Counter A Underflow Flag (IFR4).

The 16-bit latch contains the counter initialization value, and can be loaded at any time by executing a write to the Upper Latch A at location 0019 and the Lower Latch A at location 0018. In ether 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 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 RES.

Counter A operates in any of four modes. These modes are selected by the Counter A Mode Control bits in the Control Register. See Table 6-1.

Table 6-1. Counter A Control Bits
\begin{tabular}{|c|c|l|}
\hline \begin{tabular}{c} 
MCR1 \\
(bit 1)
\end{tabular} & \begin{tabular}{c} 
MCR0 \\
(bit 0)
\end{tabular} & \multicolumn{1}{c|}{ Mode } \\
\hline 0 & 0 & Interval Timer \\
0 & 1 & Pulse Generation \\
1 & 0 & Event Counter \\
1 & 1 & Pulse Width Measurement \\
\hline
\end{tabular}

The interval Timer, Pulse Generation, and Pulse Width Measurement Modes are \(\emptyset 2\) clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line.

The Counter is set to the Interval Timer Mode (00) when a \(\overline{R E S}\) signal is generated.

\subsection*{6.1.1 Interval Timer}

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:
1. When the Counter is decremented from 0000 , the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the \(\varnothing 2\) clock rate. The 16 -bit Counter can hold from 1 to 65535 counts The Counter Timer capacity is therefore \(1 \mu \mathrm{~s}\) to 65535 ms at the \(1 \mathrm{MHz} \emptyset 2\) clock rate or \(0.5 \mu \mathrm{~s}\) to 32.767 ms at the \(2 \mathrm{MHz} \emptyset 2\) clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting \(\overline{\mathbb{R} Q}\) interrupt requests in the counter \(\overline{\operatorname{RRQ}}\) 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.

While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.

\subsection*{6.1.2 Pulse Generation Mode}

In tive Pulse Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs, or a write is performed to address 001A.

The normal output waveform is a symmetrical square-wave. The CA output is initialized high when entering the mode and transitions low when writing to 001A.

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

\subsection*{6.1.3 Event Counter Mode}

In this mode the CA is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the \(\$ 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 underfiow occurs.

Figure 62 is a timing diagram of the Event Counter Mode.


Figure 6-2. Event Counter Mode

\subsection*{6.1.4 Pulse Width Measurement Mode}

This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the \(\phi 2\) clock rate as long as the CA line is held in the low state. The Counter is stopped when CA is in the high state

The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4.

A tıming diagram for the Pulse Width Measurement Mode is shown in Figure 6-3.


Figure 6-3. Pulse Width Measurement

\subsection*{6.1.5 Serial I/O Data Rate Generation}

Counter A also provides clock timing for the Serial I/O which establishes the data rate for the Serial I/O port. When the Serial I/O is enabled, Counter \(A\) is forced to operate at the internal clock rate. Counter \(A\) is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4-2).

Table 6-2 identifies the values to be loaded in Counter A for selecting standard data rates with a \(\emptyset 2\) clock rate of 1 MHz and 2 MHz . Although Table 6-2 identifies only the more common data rates, any data rate from 1 to 62.5 K bps can be selected by using the formula:
\[
N=\frac{\phi 2}{16 \times b p s}-1
\]
where
\(\mathrm{N}=\) decimal value to be loaded into Counter A using its hexadecimal equivalent.
\(\phi 2=\) the clock frequency ( 1 MHz or 2 MHz )
bps = the desired data rate.

\section*{NOTE}

In Table 6-2 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of \(1.5 \%\) or less are acceptable. A revised clock rate is included in Table \(6-2\) for those baud rates which fall outside this limit.

Table 6-2. Counter A Values för Baud Rate Selection
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Standard Baud Rate} & \multicolumn{2}{|l|}{Hexadecimal Value} & \multicolumn{2}{|l|}{Actual Baud Rate At} & \multicolumn{2}{|l|}{Clock Rate Needed To Get Standard Baud Rate} \\
\hline & 1 MHz & 2 MHz & 1 MHz & 2 MHz & 1 MHz & 2 MHz \\
\hline 50 & 04E1 & 09С3 & 50.00 & 50.00 & 10000 & 20000 \\
\hline 75 & 0340 & 0682 & 7503 & 74.99 & 1.0000 & 20000 \\
\hline 110 & 0237 & 046F & 110.04 & 110.04 & 1.0000 & 2.0000 \\
\hline 150 & 0140 & 0340 & 149.88 & 150.06 & 10000 & 2.0000 \\
\hline 300 & 00CF & 01A0 & 30048 & 299.76 & 1.0000 & 20000 \\
\hline 600 & 0067 & 00CF & 600.96 & 600.96 & 10000 & 2.0000 \\
\hline 1200 & 0033 & 0067 & 120192 & 1201.92 & 1.0000 & 20000 \\
\hline 2400 & 0019 & 0033 & 2403.85 & 2403.85 & 10000 & 2.0000 \\
\hline 3600 & 0010 & 0021 & 367647 & 3676.47 & 09792 & 1.9584 \\
\hline 4800 & 000C & 0019 & 480769 & 480769 & 10000 & 20000 \\
\hline 7200 & 0008 & 0010 & 6944.44 & 735294 & 10368 & 1.9584 \\
\hline 9600 & 0006 & 000C & 8928.57 & 961538 & 10752 & 20000 \\
\hline
\end{tabular}

\subsection*{6.2 COUNTER B}

Counter B conșists of a 16-bit counter and two 16-bit latches organızed 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 contans 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. 001E The contents of the accumulator is copied into the Upper Latch \(B\) before the value in the 16 -bit Latch \(B\) is transferred to Counter B. Counter B will also be set to the latch value and the Counter B Underflow Flag bit (IFR5) will be set to a " 1 " whenever Counter \(B\) underflows by decrementing from 0000.

IFR 5 may be cleared by reading the Lower Counter \(B\) at location 001 C , by writing to address location 001 E , or by \(\overline{\mathrm{RES}}\).

Counter B operates in the same manner as Counter \(A\) in the Interval Timer and Event Counter modes. The Pulse Width Measurement Mode is replaced by the Retriggerable Interval Timer mode and the Pulse Generation mode is replaced by the Asymmetrical Pulse Generation Mode.

\subsection*{6.2.1 Retriggerable Interval Timer Mode}

When operating in the Retriggerable Interval Timer mode, Counter B is initialized to the latch value by writing to address 001E, by a Counter B underflow, or whenever a positive edge
occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the \(C B\) line. Figure 6-4 illustrates the operation.


Figure 6-4. Counter B. Retriggerable Interval Timer Mode

\subsection*{6.2.2 Asymmetrical Pulse Generation Mode}

Counter B has a special Asymmetrical Pulse Generatıon 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 O01E. Writing to address location 001E also causes the contents of the 16 -bit Latch \(B\) to be downloaded into the Counter \(B\) and causes the CB output to go low as shown in Figure 6-5.
3. When the Counter \(B\) underflow occurs the contents of the Latch \(C\) is loaded into the Counter B, and the CB output toggles to a high level and stays high until another underflow occurs. Latch B is then down-loaded and the CB output toggles to a low level repeating the whole process.

Figure 6-5. Counter B Pulse Generation
```

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)

```

\section*{SECTION 7 POWER ON/INITIALIZATION CONSIDERATIONS}

\subsection*{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, locatıons and contents. The external memory map will be searched for an auto start ROM.

A bit pattern of A55A at a 1 K byte page boundary indicates that an auto start program follows. The next two bytes are assumed to be a pointer to the high level RSC-FORTH word that is the entry point to that program. Auto start programs is written in assembly language, rather than RSC-FORTH, a series of indirect pointers as shown in 3-7 can be used to initiate program execution.

\subsection*{7.2 POWER ON TIMING}

After application of \(\mathrm{V}_{\mathrm{CC}}\) and \(\mathrm{V}_{\mathrm{RR}}\) power to the R65F11 or R65F12, RES must be held low for at least eight \(\varnothing 2\) clock cycles after \(\mathrm{V}_{\mathrm{Cc}}\) reaches operating range and the internal oscillator has stabilized. This stabilization time is dependent upon the input \(\mathrm{V}_{\mathrm{CC}}\) voltage and performance of the internal oscillator. The clock can be monitored at \(\varnothing_{2}\) (pin 3). Figure 7-1 illustrates the power turn-on waveforms. Clock stabilization time is typically 20 ms .


Figure 7-1. Power Turn-On Timing Detail

\subsection*{7.3 RESET ( \(\overline{\operatorname{RES}})\) CONDITIONING}

When \(\overline{\mathrm{RES}}\) is driven from low to high the R65F11 or R65F12 is put in a reset state. The registers and \(1 / O\) ports are configured as shown in Table \(7-1\) when the external ROM is autostarted.

Table 7-1. RES Initialization of I/O Ports and Registers
\begin{tabular}{|l|cccccccc|}
\hline & \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline REGISTERS & & & & & & & & \\
\(\quad\) Mode Control (MCR) & 1 & 1 & 1 & 0 & 0 & 0 & 0 & 0 \\
Int. Enable (IER) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Int. Flag (IFR) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Ser. Com. Control (SCCR) & 1 & 1 & 0 & 0 & 0 & 1 & 0 & 0 \\
Ser. Com. Status (SCSR) & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 \\
PORTS & & & & & & & & \\
PA Latch & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
PB Latch & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

\section*{APPENDIX A \\ R65F11 AND R65F12 INSTRUCTION SET}

\begin{abstract}
This appendix contains a summary of the R6500 instruction set. For detailed information, consult the R6500 Mıcrocomputer System Programming Manual, Document 29650 N30. The four instructions notated with a * are added instructions for the R65F11 and R65F12 which are not part of the standard 6502 instruction set.
\end{abstract}

\section*{A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE}
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Instruction & Mnemonic & Instruction \\
\hline ADC & Add Memory to Accumulator with Carry & LDA & Load Accumulator with Memory \\
\hline AND & "AND" Memory with Accumulator & LDX & Load Index X with Memory \\
\hline ASL & Shift Left One Bit (Memory or Accumulator) & LDY
LSR & Load Index Y with Memory \\
\hline *BBR & Branch on Bit Reset Relative & LSR & Shift One Bit Right (Memory or Accumulator) \\
\hline *BBS & \multicolumn{3}{|l|}{Branch on Bit Set Relative} \\
\hline BCC & Branch on Carry Clear & NOP & No Operation \\
\hline BCS & Branch on Carry Set & & \\
\hline BEQ & Branch on Result Zero & ORA & "OR" Memory with Accumulator \\
\hline BIT & Test Bits in Memory with Accumulator & & \\
\hline BMI & Branch on Result Minus & PHA & Push Accumulator on Stack \\
\hline BNE & Branch on Result not Zero & PHP & Push Processor Status on Stack \\
\hline BPL & Branch on Result Plus & PLA & Pull Accumulator from Stack \\
\hline BRK & Force Break & PLP & Pull Processor Status from Stack \\
\hline BVC & Branch on Overifow Clear & & \\
\hline \multirow[t]{2}{*}{BVS} & \multirow[t]{2}{*}{Branch on Overilow Set} & *RMB & Reset Memory Bit \\
\hline & & ROL & Rotate One Bit Left (Memory or \\
\hline CLC & Clear Carry Flag & & Accumulator) \\
\hline CLD & Clear Decimal Mode & ROR & Rotate One Bit Right (Memory or \\
\hline CLI & Clear Interrupt Disable Bit & & Accumulator) \\
\hline CLV & Clear Overilow Flag & RTI & Return from Interrupt \\
\hline CMP & Compare Memory and Accumulator & RTS & Return from Subroutine \\
\hline CPX & Compare Memory and Index X & & \\
\hline CPY & Compare Memory and Index Y & SBC & Subtract Memory from Accumulator with Borrow \\
\hline DEC & Decrement Memory by One & SEC & Set Carry Flag \\
\hline DEX & Decrement Index \(X\) by One & SED & Set Decimal Mode \\
\hline DEY & Decrement Index \(Y\) by One & SEI & Set Interrupt Disable Status \\
\hline & & -SMB & Set Memory Bit \\
\hline \multirow[t]{2}{*}{EOR} & \multirow[t]{2}{*}{"Exclusive-Or" Memory with Accumulator} & STA
STX & Store Accumulator in Memory Store Index \(X\) in Memory \\
\hline & & STY & Store Index Y in Memory \\
\hline INC & Increment Memory by One & & \\
\hline INX & Increment Index \(X\) by One & TAX & Transier Accumulator to Index \(X\) \\
\hline \multirow[t]{2}{*}{INY} & \multirow[t]{2}{*}{Increment Index Y by One} & TAY & Transfer Accumulator to Index \(Y\) \\
\hline & & TSX & Transfer Stack Pointer to Index X
Transfer Index X to Accumulator \\
\hline \multirow[t]{2}{*}{JSR} & Jump to New Location Saving Return & TXS & Transfer Index X to Stack Register \\
\hline & Address & TYA & Transfer Index Y to Accumulator \\
\hline
\end{tabular}


\section*{A. 3 INSTRUCTION CODE MATRIX}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline 0 & 0 & 1 & 2 & 3 & 4 & 5 & 6 & 7 & 8 & 9 & A & B & C & D & E & F & \\
\hline \(\sum_{0}\) & BRK implied 17 & \[
\begin{array}{|c|}
\hline \text { ORA } \\
\text { (IND, } X) \\
26
\end{array}
\] & & & & \[
\begin{aligned}
& \text { ORA } \\
& Z P \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { ASL } \\
& \mathrm{ZP} \\
& 25
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMBO } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & PHP Implied 13 & \[
\begin{aligned}
& \text { ORA } \\
& \text { IMM } \\
& 222
\end{aligned}
\] & ASL Accum 12 & & & \[
\begin{aligned}
& \text { ORA } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { ASL } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBRO } \\
& \text { ZP } \\
& 3 \quad 5^{\circ}
\end{aligned}
\] & 0 \\
\hline 1 & \begin{tabular}{l}
BPL \\
Relative \\
2 2**
\end{tabular} & \[
\begin{array}{|c|}
\hline \text { ORA } \\
\text { (IND), } Y^{\prime} \\
25^{\circ}
\end{array}
\] & & & & \[
\begin{aligned}
& \text { ORA } \\
& \text { ZP, } X \\
& 24
\end{aligned}
\] & \[
\begin{gathered}
\text { ASL } \\
\text { ZP, X } \\
26
\end{gathered}
\] & \[
\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 \\
34^{*}
\end{gathered}
\] & & & & \[
\begin{gathered}
\text { ORA } \\
\text { ABS, } x \\
34^{\circ}
\end{gathered}
\] & \[
\begin{gathered}
\text { ASL } \\
\text { ABS, } x \\
37
\end{gathered}
\] & \[
\begin{gathered}
\text { BBR1 } \\
\text { ZP } \\
3 \quad 5 *
\end{gathered}
\] & 1 \\
\hline 2 & JSR
Absolute 36 & \[
\begin{array}{|c|}
\hline \text { AND } \\
\text { (IND, X) } \\
26
\end{array}
\] & & & \[
\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{gathered}
\text { PLP } \\
\text { Implied } \\
14
\end{gathered}
\] & \[
\begin{aligned}
& \text { AND } \\
& \text { IMM } \\
& 22
\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}
& \text { ROL } \\
& \mathrm{ABS} \\
& 36
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBR2 } \\
& \text { ZP } \\
& 3 \quad 5^{*}
\end{aligned}
\] & 2 \\
\hline 3 & \begin{tabular}{l}
BMI \\
Relative 2 2**
\end{tabular} &  & & & & \[
\begin{aligned}
& \hline \text { AND } \\
& \text { ZP, } X \\
& 2 \quad 4 \\
& \hline
\end{aligned}
\] & \[
\begin{gathered}
\mathrm{ROL} \\
\mathrm{ZP}, \mathrm{X} \\
26
\end{gathered}
\] & \[
\begin{gathered}
\text { RMB3 } \\
\text { ZP } \\
2 \quad 5 \\
\hline
\end{gathered}
\] & SEC Implied 12 & AND ABS, \(Y\) \(34^{*}\) & & & &  & \[
\begin{gathered}
\mathrm{ROL} \\
\text { ABS, } \mathrm{X} \\
37
\end{gathered}
\] & \[
\begin{aligned}
& \text { BBR3 } \\
& \text { ZP } \\
& 3 \quad 5 *
\end{aligned}
\] & 3 \\
\hline 4 & RTI Implied 16 &  & & & & \[
\begin{aligned}
& \text { EOR } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { LSR } \\
& \mathrm{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 & & \[
\begin{aligned}
& \text { JMP } \\
& \text { ABS } \\
& 3 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { EOR } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { LSR } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBR4 } \\
& \text { ZP } \\
& 3 \quad 5^{\circ}
\end{aligned}
\] & 4 \\
\hline 5 & BVC Relative 2 2** &  & & & & \[
\begin{gathered}
\hline \text { EOR } \\
\text { ZP, } X \\
2 \quad 4 \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& \text { LSR } \\
& \text { ZP, X } \\
& 26
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMB5 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & CLI Implied 12 &  & & & &  & LSR ABS, \(X\) 37 & \[
\begin{gathered}
\text { BBR5 } \\
\text { ZP } \\
3 \quad 5^{\prime *}
\end{gathered}
\] & 5 \\
\hline 6 & RTS Implied 16 & \[
\begin{array}{|c|}
\hline \text { ADC } \\
\text { (IND, } X) \\
226
\end{array}
\] & & & & \[
\begin{aligned}
& \text { ADC } \\
& Z P \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { ROR } \\
& \text { ZP } \\
& 25
\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}
\] & ROR Accum 12 & & JMP Indirect 35 & \begin{tabular}{l}
ADC ABS \\
34
\end{tabular} & \[
\begin{aligned}
& \hline \text { ROR } \\
& \text { ABS } \\
& 3 \quad 6 \\
& \hline
\end{aligned}
\] & \[
\begin{gathered}
\text { BBR6 } \\
\text { ZP } \\
3 \quad 5^{* *}
\end{gathered}
\] & 6 \\
\hline 7 & BVS 2 2** & ADC
(IND, Y)
\[
25^{\circ}
\] & & & & \[
\begin{aligned}
& \text { ADC } \\
& \text { ZP, } X \\
& 24
\end{aligned}
\] & \[
\begin{aligned}
& \text { ROR } \\
& \text { ZP, X } \\
& 26
\end{aligned}
\] & \[
\begin{gathered}
\text { RMB7 } \\
\text { ZP } \\
2 \quad 5
\end{gathered}
\] & SEI Implied 12 & ADC ABS, \(Y\) \(34^{*}\) & & & & ADC ABS, \(X\) \(34^{*}\) & \[
\begin{gathered}
\mathrm{ROR} \\
\mathrm{ABS}, \mathrm{x}
\end{gathered}
\]
\[
37
\] & \[
\begin{aligned}
& \text { BBR7 } \\
& \text { ZP } \\
& 3 \quad 5 \cdot
\end{aligned}
\] & 7 \\
\hline 8 & & STA
(IND, \(X\) )
\(2 \quad 6\) & & & \[
\begin{aligned}
& \text { STY } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \hline \text { STA } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { STX } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{gathered}
\hline \text { SMBO } \\
\text { ZP } \\
2 \quad 5 \\
\hline
\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{tabular}{l}
STX ABS \\
34
\end{tabular} & \[
\begin{gathered}
\text { BBSO } \\
\text { ZP } \\
3 \quad 5 .
\end{gathered}
\] & 8 \\
\hline 9 & BCC Relative 2 2** & STA
(IND, Y)
\(2 \quad 6\) & & & \[
\begin{gathered}
\text { STY } \\
\text { ZP, X } \\
24
\end{gathered}
\] & \[
\begin{gathered}
\text { STA } \\
\text { ZP, } X \\
24
\end{gathered}
\] & \[
\begin{gathered}
S T X \\
Z P, Y \\
24
\end{gathered}
\] & \[
\begin{aligned}
& \text { SMB1 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & TYA Implied 12 & STA ABS, \(Y\) 35 &  & & & STA ABS, X 35 & & \[
\begin{gathered}
\hline \text { BBS } 1 \\
\text { ZP } \\
3 \quad 5^{* *} \\
\hline
\end{gathered}
\] & 9 \\
\hline A & \[
\begin{aligned}
& \text { LDY } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { LDA } \\
\text { (IND, } \mathrm{X}) \\
26
\end{array}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & & \[
\begin{aligned}
& \text { LDY } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDA } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDX } \\
& Z P \\
& 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}
\] & \[
\begin{array}{|c|}
\text { TAX } \\
\text { Implied } \\
1 \\
\hline 2
\end{array}
\] & & \[
\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 \\
\hline B & BCS
Relative 2 2** & \[
\begin{array}{|c|}
\hline \text { LDA } \\
\text { (IND), Y } \\
25^{*}
\end{array}
\] & & & \[
\begin{aligned}
& \text { LDY. } \\
& \text { ZP, X } \\
& 24
\end{aligned}
\] & \[
\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 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { CLVV } \\
& \text { Implied }
\end{aligned}
\]
\[
12
\] & \[
\begin{aligned}
& \text { LDA } \\
& \text { ABS, } Y \\
& 34^{*}
\end{aligned}
\] & TSX
Implied
\(1 \quad 2\) & & LDY ABS, \(X\) 3 4* &  &  & \[
\begin{gathered}
\text { BBS3 } \\
\text { ZP } \\
3 \quad 5^{* *}
\end{gathered}
\] & B \\
\hline C & \[
\begin{aligned}
& \text { CPY } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { CMP } \\
\text { (IND, X) } \\
26
\end{array}
\] & & & \[
\begin{aligned}
& \mathrm{CPY} \\
& \mathrm{ZP} \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { CMP } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { DEC } \\
& \mathrm{ZP} \\
& 25
\end{aligned}
\] & \[
\begin{aligned}
& \text { SMB4 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
INY \\
Implied \\
12
\end{tabular} & \[
\begin{aligned}
& \hline \text { CMP } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] & DEX Implied 12 & & \[
\begin{aligned}
& \text { CPY } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \hline \text { CMP } \\
& \text { ABS } \\
& 3 \quad 4 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \hline \text { DEC } \\
& \text { ABS } \\
& 3 \quad 6
\end{aligned}
\] & \[
\begin{gathered}
\text { BBS4 } \\
\text { ZP } \\
3 \quad 5^{* *}
\end{gathered}
\] & C \\
\hline D & BNE Relative 2 2** &  & & & & \[
\begin{aligned}
& \text { CMP } \\
& \text { ZP, } X \\
& 24
\end{aligned}
\] & \[
\begin{gathered}
\text { DEC } \\
\text { ZP, } \mathrm{X} \\
26
\end{gathered}
\] & \[
\begin{aligned}
& \hline \text { SMB5 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & CLD Implied 12 &  & & & &  & \[
\begin{aligned}
& \text { DEC } \\
& \text { ABS, } X
\end{aligned}
\]
\[
37
\] & \[
\begin{gathered}
\text { BBS5 } \\
\text { ZP } \\
3 \quad 5 \cdots
\end{gathered}
\] & D \\
\hline E & \[
\begin{aligned}
& \text { CPX } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
SBC
(IND, \(X)\) \\
26
\end{tabular} & & & \[
\begin{aligned}
& \mathrm{CPX} \\
& \mathrm{ZP} \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \hline \mathrm{SBC} \\
& \mathrm{ZP} \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { INC } \\
& Z P \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & \[
\begin{gathered}
\hline \text { SMB6 } \\
\text { ZP } \\
2 \quad 5 \\
\hline
\end{gathered}
\] & INX Implied 12 & \[
\begin{aligned}
& \hline \text { SBC } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] &  & & \[
\begin{aligned}
& \hline \text { CPX } \\
& \text { ABS } \\
& 3 \quad 4 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \hline \text { SBC } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \hline \text { INC } \\
& \text { ABS } \\
& 3 \quad 6 \\
& \hline
\end{aligned}
\] & \[
\begin{gathered}
\text { BBS6 } \\
\text { ZP } \\
3 \quad 5^{* *}
\end{gathered}
\] & E \\
\hline F & \begin{tabular}{l}
BEQ \\
Relative 2 2**
\end{tabular} &  & & & & \[
\begin{gathered}
\text { SBC } \\
\text { ZP, X } \\
24
\end{gathered}
\] & \[
\begin{gathered}
\text { INC } \\
\text { ZP, } X \\
26 \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& \text { SMB7 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & SED Implied 12 & \[
\begin{gathered}
\text { SBC } \\
\text { ABS, } Y \\
34^{*}
\end{gathered}
\] & & & & \[
\begin{gathered}
\text { SBC } \\
\text { ABS, } X \\
34^{*}
\end{gathered}
\] & INC ABS, \(X\) 37 & \[
\begin{aligned}
& \text { BBS7 } \\
& \text { ZP } \\
& 3 \quad 5^{\prime *}
\end{aligned}
\] & F \\
\hline & 0 & 1 & 2 & 3 & 4 & 5 & \(\delta\) & 7 & § & 9 & A & B & C & 0 & \(E\) & \(\bar{F}\) & \\
\hline
\end{tabular}

\footnotetext{
0 \begin{tabular}{c|c}
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}\)
\end{tabular}
}

\footnotetext{
*Add 1 to N if page boundary is crossed.
**Add 1 to N If branch occurs to same page;
add 2 to N if branch occurs to different page.
}

\section*{APPENDIX B \\ KEY REGISTER SUMMARY}


\section*{APPENDIX C \\ ADDRESS ASSIGNMENTS/MEMORY MAPS/PIN FUNCTIONS}

\section*{C. 1 I/O AND INTERNAL REGISTER ADDRESSES}
\begin{tabular}{|c|c|c|}
\hline ADDRESS (HEX) & READ & WRITE \\
\hline \[
\begin{array}{r}
001 F \\
1 E \\
1 D \\
1 C
\end{array}
\] & Lower Counter B Upper Counter B 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. \\
\hline \[
\begin{aligned}
& 1 B \\
& 1 A \\
& 19 \\
& 18
\end{aligned}
\] & \begin{tabular}{l}
Lower Counter A \\
Upper Counter A Lower Counter A, CLR Flag
\end{tabular} & Upper Latch A, Cntr A↔Latch A, CLR Flag Upper Latch A Lower Latch A \\
\hline \[
\begin{aligned}
& 17 \\
& 16 \\
& 15 \\
& 14
\end{aligned}
\] & Serial Receiver Data Register Serial Comm. Status Register Serial Comm. Control Register Mode Control Register & \begin{tabular}{l}
Serial Transmitter Data Register \\
Serial Comm. Status Reg. Bits 4 \& 5 only \\
Serial Comm. Control Register \\
Mode Control Register
\end{tabular} \\
\hline \[
\begin{aligned}
& 13 \\
& 12 \\
& 11 \\
& 10
\end{aligned}
\] & Interrupt Enable Register Interrupt Flag Register Read FF & \begin{tabular}{l}
Interrupt Enable Register \\
Clear Int Flag (Bits 0-3 only, Write 0's only)
\end{tabular} \\
\hline \[
\begin{aligned}
& \mathrm{OF} \\
& O E \\
& O D \\
& O C
\end{aligned}
\] &  &  \\
\hline \[
\begin{aligned}
& \text { OB } \\
& 0 A \\
& 09 \\
& 08
\end{aligned}
\] &  &  \\
\hline \[
\begin{aligned}
& 07 \\
& 06 \\
& 05 \\
& 04
\end{aligned}
\] & \[
\begin{aligned}
& \text { Port } \text { G* }^{*} \\
& \text { Port F* } \\
& \text { Port E }
\end{aligned}
\] & \[
\begin{aligned}
& \text { Port } \mathrm{G}^{\star} \\
& \text { Port } \mathrm{F}^{*} \\
& \text { Port } \mathrm{E}^{\star}
\end{aligned}
\] \\
\hline \[
\begin{array}{r}
03 \\
02 \\
01 \\
0000
\end{array}
\] & Port B Port A & \[
\begin{aligned}
& \quad \begin{array}{l}
\text {-二 } \\
\text { Port B } \\
\text { Port A }
\end{array}
\end{aligned}
\] \\
\hline
\end{tabular}

NOTE: *R65F12 Only

\section*{C. 2 MULTIPLE FUNCTION \\ PIN ASSIGNMENTS- \\ PORT C AND PORT D}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{2}{|c|}{ PIN } & \begin{tabular}{c} 
I/O PORT \\
FUNCTION \\
NUMBER
\end{tabular} & \begin{tabular}{c} 
MULTIPLEXED PORT \\
FUNCTION
\end{tabular} \\
\hline R65F11 & R65F12 & PLACED & A0 \\
\hline 4 & 25 & PC0 & A1 \\
5 & 26 & PC1 & A2 \\
6 & 27 & PC2 & A3 \\
7 & 28 & PC3 & A12 \\
\hline 8 & 29 & PC4 & R/W \\
9 & 30 & PC5 & A13 \\
10 & 31 & PC6 & EMS \\
11 & 32 & PC7 & A4/D0 \\
\hline 19 & 40 & PD0 & A5/D1 \\
18 & 39 & PD1 & A6/D2 \\
17 & 38 & PD2 & A7/D3 \\
16 & 37 & PD3 & A8/D4 \\
\hline 15 & 36 & PD4 & A9/D5 \\
14 & 35 & PD5 & A10/D6 \\
13 & 34 & PD6 & A11/D7 \\
\hline 12 & 33 & PD7 & \\
\hline
\end{tabular}

\section*{C. 3 MULTIPLEXED MODE} MEMORY MAP


\section*{C. 4 SYSTEM VARIABLES IN RAM}
\begin{tabular}{|c|c|c|c|}
\hline ADDRESS & NAME & COLD START VALUE & WARM START VALUE \\
\hline 0040 & IRQVEC & (COLD) & - \\
\hline 0042 & NMIVEC & (COLD) & - \\
\hline 0044 & UKEY & (INK) & (INK) \\
\hline 0046 & UEMIT & (OUT) & (OUT) \\
\hline 0048 & UP & 0300 & 0300 \\
\hline 004A & INTFLG & 00 & 00 \\
\hline 004B & (W-1) & 6 C & 6 C \\
\hline 004C & W & - & - \\
\hline 004E & IP & - & - \\
\hline 0050 & ( \(\mathrm{N}-1\) ) & - & - \\
\hline 0051 & N & - & - \\
\hline 0059 & XSAVE & - & - \\
\hline 005B & INTVEC & (COLD) & - \\
\hline 005D & TOS & - & - \\
\hline 0300 & TIB & 0380 & 0380 \\
\hline 0302 & R0 & OOFF & 00FF \\
\hline 0304 & S0 & 00C2 & 00 C 2 \\
\hline 0306 & UC/L & 0050 & - \\
\hline 0308 & UPAD & 037E & - \\
\hline 030A & URWW & (DISK) & - \\
\hline 030C & BASE & 0010 & - \\
\hline O30E & CLD/WRM & - & - \\
\hline 0310 & IN & - & - \\
\hline 0312 & DPL & - & - \\
\hline 0314 & HLD & - & - \\
\hline 0316 & DISKNO & - & - \\
\hline 0318 & CURCYL & - & - \\
\hline 031C & B/SIDE & - & - \\
\hline
\end{tabular}


\section*{APPENDIX E ELECTRICAL SPECIFICATIONS}

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}} \& \mathrm{~V}_{\mathrm{RR}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature Range, \\
Commercial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
\(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
0 to +70
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

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

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{R R}=V_{C C} ; V_{S S}=0 V ; T_{A}=0^{\circ}\right.\) to \(70^{\circ}\), unless otherwise specified \()\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline RAM Standby Voltage (Retention Mode) & \(V_{\text {RR }}\) & 3.0 & & \(\mathrm{V}_{\mathrm{cc}}\) & V & \\
\hline RAM Standby Current (Retention Mode) & \(I_{\text {RR }}\) & - & 4 & - & mA & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline Input High Voltage All Except XTLI XTLI & \(\mathrm{V}_{\mathrm{IH}}\) & \[
\begin{array}{r}
+2.0 \\
+4.0 \\
\hline
\end{array}
\] & & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{cc}} \\
& \mathrm{~V}_{\mathrm{cc}} \\
& \hline
\end{aligned}
\] & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\mathrm{IL}}\) & -0.3 & - & +0.8 & V & \\
\hline Input Leakage Current \(\overline{\mathrm{RES}}, \overline{\mathrm{NM}}\) & \(\mathrm{I}_{\text {I }}\) & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathbb{N}}=0\) to 5.0 V \\
\hline Input Low Current \(\mathrm{PA}, \mathrm{PB}, \mathrm{PC}, \mathrm{PD}, \mathrm{PF}^{3}, \mathrm{PG}^{3}\) & ILL & - & -1.0 & -1.6 & mA & \(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage (Except XTLO) & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & \(\mathrm{V}_{\mathrm{cc}}\) & V & \(\mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A}\) \\
\hline Output Low Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & +0.4 & V & \(\mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}\) \\
\hline \[
\begin{aligned}
& \text { I/O Port Pull-Up Resistance } \\
& \text { PAO-PA7, PB0-PB7, PC0-PC7, PF0-PF73, } \\
& \text { PGO-PG73 }
\end{aligned}
\] & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Output Leakage Current (Three-State Off) & Iout & - & - & \(\pm 10\) & \(\mu \mathrm{A}\) & \\
\hline Darlington Current Drive \(\mathrm{PE}^{3}\) & IOH & -1.0 & - & - & mA & \(\mathrm{V}_{\text {OUT }}=1.5 \mathrm{~V}\) \\
\hline Input Capacitance XTLI, XTLO All Others & \(\mathrm{C}_{\text {IN }}\) & - & - & \[
\begin{aligned}
& 50 \\
& 10
\end{aligned}
\] & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) & \(\mathrm{C}_{\text {OUt }}\) & - & - & 10 & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Outputs High) & \(\mathrm{P}_{\mathrm{D}}\) & - & & 1000 & mW & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\). \\
2. Negative sign indicates outward current flow, positive indicates inward flow. \\
3. R65F12 only.
\end{tabular}} \\
\hline
\end{tabular}

\section*{APPENDIX F \\ TIMING REQUIREMENTS AND CHARACTERISTICS}

\section*{F. 1 GENERAL NOTES}
1. \(\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}\) - RES sequence is required before proper operation is achieved.
3. All timing reference levels are 0.8 V and 2.0 V , unless otherwise specified.
4. All time units are nanoseconds, unless otherwise specified.
5. All capacitive loading is 130 pf maximum, except as noted below:
PA, PB, PE, PF, PG
- 50pf maximum

\section*{F. 2 CLOCK TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline T \({ }_{\text {cyc }}\) & Cycie Time & 1000 & \(10 \mu \mathrm{~s}\) & 500 & \(10 \mu \mathrm{~s}\) \\
\hline \(\mathrm{T}_{\mathrm{PWX} 1}\) & XTLI Input Clock Pulse Width XTLO = VSS & \[
\begin{aligned}
& 500 \\
& \pm 25
\end{aligned}
\] & - & \[
\begin{aligned}
& 250 \\
& \pm 10
\end{aligned}
\] & - \\
\hline \(\mathrm{T}_{\text {PW02 }}\) & Output Clock Pulse Width at Minimum \(\mathrm{T}_{\mathrm{crc}}\) & \(\mathrm{T}_{\text {PWX } 1}\) & \[
\begin{aligned}
& T_{P W \times 1} \\
& \pm 25
\end{aligned}
\] & \(\mathrm{T}_{\text {PWx } 1}\) & \[
\begin{aligned}
& T_{\text {Pw }}=1 \\
& \pm 20
\end{aligned}
\] \\
\hline \(\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}\) & Output Clock Rise, Fall Time & - & 25 & - & 15 \\
\hline \(\mathrm{T}_{\text {IR }} \mathrm{T}_{\text {IF }}\) & Input Clock Rise, Fall Time & - & 10 & - & 10 \\
\hline
\end{tabular}


\section*{F. 3 MULTIPLEXED MODE TIMING-PC AND PD}
(MCR \(5=1\), MCR \(6=1\), MCR \(7=1\) )
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline T PCRS & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline TPCAS & (PC0-PC4, PC6) Address Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {PBAS }}\) & (PD) Address Setup Time & - & 225 & - & 140 \\
\hline \(T_{\text {PBSU }}\) & (PD) Data Setup Time & 50 & - & 35 & - \\
\hline \(T_{\text {PBHR }}\) & (PD) Data Read Hold Time & 10 & - & 10 & - \\
\hline T PBHW & (PD) Data Write Hold Time & 30 & - & 30 & - \\
\hline T PBDD & (PD) Data Output Delay & - & 175 & - & 150 \\
\hline \(\mathrm{T}_{\text {PCHA }}\) & (PC0-PC4, PC6) Address Hoıl Time & 30 & - & 30 & - \\
\hline T PBHA & (PD) Address Hold Time & 10 & 100 & 10 & 80 \\
\hline \(T_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline T PCHV & (PC7) EMS Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PCVO }}{ }^{(1)}\) & (PC7) Address to EMS Delay Tıme & 30 & - & 30 & - \\
\hline T PCVP & (PC7) EMS Stabilization Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {ESU }}\) & \(\overline{\mathrm{EMS}}\) Set Up Tıme & - & 350 & - & 210 \\
\hline
\end{tabular}

NOTE 1 Values assume PC0-PC4, PC6 and PC7 have the same capacitive load

\section*{F.3.1 Multiplex Mode Timing Diagram}


\section*{F. 4 I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|l|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \[
\begin{aligned}
& T_{\text {POW }}{ }^{(1)} \\
& T_{\text {CMOS }}{ }^{(1)}
\end{aligned}
\] & \begin{tabular}{l}
Internal Write to Perıpheral Data Valıd PA, PB TTL \\
PA, PB CMOS
\end{tabular} & - & 500
1000 & - & \[
\begin{array}{r}
500 \\
1000
\end{array}
\] \\
\hline TpDSU & Perıpheral Data Setup Time PA, PB & 200 & - & 200 & - \\
\hline TPHR & Peripheral Data Hold Time PA, PB & 75 & - & 75 & - \\
\hline T EPW & PA0-PA3 Edge Detect Pulse Width & \(\mathrm{T}_{\mathrm{CYC}}\) & - & T CrC & - \\
\hline \[
\begin{aligned}
& T_{C P W} \\
& \left.T_{C D}{ }^{1}\right)
\end{aligned}
\] & \begin{tabular}{l}
Counters A and B \\
PA4, PA5 Input Pulse Width PA4, PA5 Output Delay
\end{tabular} & TCrc & - & TCrc & 500 \\
\hline \begin{tabular}{l}
\(T_{\text {PBLW }}\) \\
TpLSU \\
TPBLH
\end{tabular} & Port B Latch Mode PAO Strobe Pulse Width PB Data Setup Time PB Data Hold Time & \[
\begin{gathered}
T_{\text {crc }} \\
175 \\
30
\end{gathered}
\] & - & \[
\begin{gathered}
T_{\text {CrC }} \\
150 \\
30
\end{gathered}
\] & - \\
\hline & Serial I/O & & & & \\
\hline \(\mathrm{T}_{\text {PDW }}{ }^{(1)}\) & PA6 XMTR TTL & - & 500 & - & 500 \\
\hline \(\mathrm{T}_{\text {cmos }}{ }^{(1)}\) & PA6 XMTR CMOS & - & 1000 & - & 1000 \\
\hline \(\mathrm{T}_{\text {CPW }}\) & PA4 RCVR S/R Clock Width & \(4 \mathrm{~T}_{\mathrm{CrC}}\) & - & \(4 \mathrm{~T}_{\mathrm{CrC}}\) & - \\
\hline \(\mathrm{T}_{\text {PDW }}{ }^{(1)}\) & PA4 XMTR Clock-S/R Mode (TTL) & - & 500 & & 500 \\
\hline TCMOS \({ }^{(1)}\) & PA4 XMTR Clock-S/R Mode (CMOS) & - & 1000 & - & 1000 \\
\hline
\end{tabular}

NOTE 1. Maxımum Load Capactance 50pF Passive Pull-Up Required

\section*{F.4.1 I/O Edge Detect, Counter, and Serial I/O Timing}


\section*{APPENDIX G}

INCLUDED FORTH FUNCTIONS IN ROM
\begin{tabular}{|c|c|c|c|}
\hline BANKEXECUTE & BANKEEC! & BANKC@ & BANKC! \\
\hline EEC! & - & .R & D. \\
\hline ? & \#S & - \# & SIGN \\
\hline D.R & <\# & SPACES & SEEK \\
\hline \# > & DWRITE & DREAD & SELECT \\
\hline INIT & M/MOD & */ & */MOD \\
\hline DISK & / & /MOD & * \\
\hline MOD & M * & MAX & MIN \\
\hline M/ & ABS & D+- & +- \\
\hline DABS & COLD & (NUMBER) & HOLD \\
\hline \(S->D\) & ERASE & FILL & QUERY \\
\hline BLANKS & (.') & -TRAILING & TYPE \\
\hline EXPECT & DECIMAL & HEX & -DUP \\
\hline COUNT & PICK & ROT & > \\
\hline SPACE & U< & \(=\) & - \\
\hline < & 1- & 2+ & \(1+\) \\
\hline 2- & C/L & HLD & DPL \\
\hline PAD & CLD/WRM & BASE & UR/W \\
\hline IN & UC/L & RO & SO \\
\hline UPAD & BL & 4 & 3 \\
\hline TIB & 1 & 0 & C! \\
\hline 2 & C@ & @ & TOGGLE \\
\hline ! & BOUNDS & 2DUP & DUP \\
\hline +! & 2DROP & DROP & OVER \\
\hline SWAP & NEGATE & D+ & + \\
\hline DNEGATE & \(0=\) & R & R> \\
\hline \(0<\) & LEAVE & ;S & RP@ \\
\hline \(>\mathrm{R}\) & SP! & SP@ & XOR \\
\hline RP! & AND & U/ & U* \\
\hline OR & CR & ?TERMINAL & KEY \\
\hline CMOVE & ENCLOSE & (FIND) & DIGIT \\
\hline EMIT & (+LOOP) & (LOOP) & OBRANCH \\
\hline (DO)
BRANCH & EXECUTE & CLIT & LIT \\
\hline
\end{tabular}

\title{
R65FRx AND R65FKx RSC FORTH DEVELOPMENT AND KERNEL ROMS
}

\section*{INTRODUCTION}

The Rockwell Single Chip (RSC) FORTH System can be configured using the R65F11, R65F12 microcomputers or the R6501Q ROM-less microcomputer. One of these microcomputers, when used in conjunction with a development ROM and a FORTH kernel ROM, provide the designer with maximum flexibility when developing FORTH applications.

RSC-FORTH is based on the popular fig-FORTH model with extensions. The R65F11 and R65F12 both have the kernel of the high level Rockwell Single Chip RSC-FORTH language contained in the preprogrammed ROM. The R65FK2 and R65FK3 Kernel ROMs are preprogrammed ROMs for use with the R6501Q when developing larger applications requiring more memory and I/O line support. All of the run time functions of the RSC-FORTH are contained in these ROMs, including 16- and 32-bit mathematical, logical and stack manipulation, plus memory and input/output operators. The RSC-FORTH Operating System allows an external user program written in RSC-FORTH or Assembly Language to be executed from external EPROM, or development of such a program under the control of the R65FR1, R65FR2 or R65FR3 RSC-FORTH Development ROMs.

This document describes five different RSC-FORTH system configurations using the development and kernel ROMs.
ORDERING INFORMATION
\begin{tabular}{|l|l|}
\hline Part No. & \multicolumn{1}{|c|}{ Description } \\
\hline R65FR1P & FORTH Development ROM for R65F11 or R65F12 \\
R65FR2P & FORTH Development ROM for R6501Q \\
R65FR3P & FORTH Development ROM for R6501Q \\
R65FK2P & FORTH Kernel ROM for R6501Q \\
R65FK3P & FORTH Kernel ROM for R6501Q \\
R65F11P & 40-Pin FORTH Based Microcomputer at 1 MHz \\
R65F11AP & 40-Pın FORTH Based Mıcrocomputer at 2 MHz \\
R65F12Q & 64-Pın FORTH Based Mıcrocomputer at 1 MHz \\
R65F12AQ & 64-Pin FORTH Based Microcomputer at 2 MHz \\
R6501Q & 64-Pın One-Chip Microprocessor at 1 MHz \\
R6501AQ & 64-Pin One-Chıp Microprocessor at 2 MHz \\
\hline Order No. & \multicolumn{1}{|c|}{ Description } \\
\hline 2145 & R6501Q One-Chip Mıcroprocessor Product \\
& Description \\
2146 & R65F11 and R65F12 FORTH Based Microcomputer \\
& Product Descriptıon \\
2148 & RSC-FORTH User's Manual \\
2162 & Application Note: A Low-Cost Development Module \\
& for the R65F11 FORTH Mıcrocomputer \\
\hline
\end{tabular}

\section*{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\) FFF in the FORTH development configuration memory map
-R6501Q compatible for use in emulation of the R65F11/F12 FORTH development configuration
- R65FR3 FORTH Development ROM
-8K ROM
-Addressable from \$C000 through \$DFFF in the FORTH development configuration memory map
-Operates in the R6501Q FORTH development configuration
- R65FK2 FORTH Kernel ROM
-4K ROM
-Addressable from \$F400 through \$FFFF in the FORTH development configuration memory map
-R6501Q compatible for use in the emulation of the R65F11/F12 FORTH development configuration
-Replaces the FORTH kernel contained in the R65F11 and R65F12 microcomputers during development
- R65FK3 FORTH Kernel ROM
-4K ROM
-Addressable from \$F400 through \$FFFF in the FORTH development and production configuration memory maps
-R6501Q compatible
-Operates in the R6501Q FORTH development and production configurations

\section*{RSC-FORTH SYSTEM CONFIGURATIONS}

The three configurations of the RSC-FORTH System are identified by the CPU-Development ROM combinations listed below:

RSC-FORTH System Configurations
\begin{tabular}{|l|l|c|c|}
\hline CPU & \begin{tabular}{l} 
Kernel \\
ROM
\end{tabular} & \begin{tabular}{c} 
Development \\
ROM
\end{tabular} & \begin{tabular}{c} 
RSC \\
Configuration
\end{tabular} \\
\hline R65F11 & none & R65FR1 & 1 \\
R65F12 & none & R65FR1 & 1 \\
R6501Q & R65FK2 & R65FR2 & 2 \\
R6501Q & R65FK3 & R65FR3 & 3 \\
\hline
\end{tabular}

\section*{RSC-FORTH CONFIGURATION 1 (R65FR1) R65F11/R65F12 DEVELOPMENT AND PRODUCTION}

The RSC-FORTH Configuration 1 provides the designer with a FORTH development and application environment at a minimal cost. The application program is developed using an R65F11 or R65F12 microcomputer, an R65FR1 Development ROM and external RAM. Up to 8 K bytes of RAM space is available using this configuration. However, Configuration 1 is limited to 5 K or less bytes of RAM during development. This is the result of allocating 2 K bytes of RAM for disk buffers and at least 1 K bytes of RAM for the "Program heads". The program heads are contained in a dictionary containing the Name (NFA), Link Field Address (LFA) and the Parameter Field Address Pointer (PFA). This dictionary is a list of FORTH word words and user-defined FORTH words used in the development of a FORTH program and is not present during the execution of the FORTH program.

Although programs may reside in the upper 8K 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

\section*{CONFIGURATION 1A CONSIDERATIONS}

Features
-. 8K Bytes of User Memory
- 16 I/O Lines

\section*{Device Configuration}
\begin{tabular}{l|l|l|} 
& \multicolumn{2}{l}{ DEVELOPMENT } \\
R65ODUCTION \\
\hline & & \\
\hline & & \\
\hline R65FR1 Development ROM & & \\
\hline
\end{tabular}

\section*{User Memory-I/O Resource Matrix}

User memory may be a mix of ROM, EEROM, UVPROM or RAM.


\section*{CONFIGURATION 1B CONSIDERATIONS}

Features
- 8K Bytes of User Memory
- 40 I/O Lines

Device Configuration
\begin{tabular}{l|l|l|} 
& \multicolumn{1}{l}{ DEVELOPMENT } & PRODUCTION \\
R65F12 Microcomputer & & \\
\hline & & \\
\hline
\end{tabular}

\section*{User Memory-I/O Resource Matrix}

User memory may be a mix of ROM, EEROM, UVPROM or RAM.


\section*{RSC-FORTH CONFIGURATION 2}
(R65FR2, R65FK2)

\section*{R6501Q DEVELOPMENT AND R65F11/F12 PRODUCTION}

The RSC-FORTH Configuration 2 provides the designer with the capability of using the full 16 K bytes of external address space of the R65F11 and R65F12.

The R6501Q ROM-less microprocessor, when used with the R65FK2 Kernel ROM and the R65FR2 Development ROM, emulates the operation of the R65F11/F12. Because of the greater address space of the R6501Q, the R65FR2 Development ROM can be relocated to address \(\$ 4000\) and the disk buffers and HEADS program to \(\$ 6000\). This expands the available user memory space to 16 K bytes, \(\$ 0000\) through \(\$ 3 F F F\).

Using this configuration, the application program can be developed using the R6501Q and then later installed in an R65F11 or R65F12 microcomputer without modification.

Figure 2 shows the development and production configuration for the R6501Q. Configurations 2A and 2B list the features, memory maps, and the relationship of the R6501Q to the R65FR2 Development ROM and R65FK2 Kernel ROM in the development and production environment. Figure 3 is a schematic of the R6501Q, R65FR2, R65FK2 development setup.


Figure 2. R65FR2 and R65FK2 Configuration 2 Block Diagrams

\section*{CONFIGURATION 2A CONSIDERATIONS}

Features
- 16K Bytes of User "Headerless" Memory
- 16 I/O Lines

Device Configuration
\begin{tabular}{l||l|l|} 
& \multicolumn{2}{l}{ DEVELOPMENT PRODUCTION } \\
R65F11 Microcomputer & & \\
\hline & & \\
\hline R6501Q Microprocessor & & \\
\hline & & \\
\hline R65FR2 Development ROM & & \\
\hline & & \\
\hline R65FK2 Kernel ROM & & \\
\hline
\end{tabular}

\section*{Memory-I/O Matrix}

If floppy disk is used in the application, space for the disk buffers must be allocated in memory from \$0500 through \$3FFF or \(\$ 6000\) through \(\$ 7 F F F\). User memory can be a mix of ROM, EEROM, UVROM or RAM.


\section*{Memory Maps}



\section*{CONFIGURATION 2B CONSIDERATIONS}

Features
- 16K Bytes of User "Headerless" Memory
- 40 I/O Lines

\section*{Device Configuration}
\begin{tabular}{l}
\multicolumn{1}{c|}{ DEVELOPMENT } \\
R65F12 Microcomputer \\
R6501Q Microprocessor \\
R65FTION \\
R65F Development ROM \\
\hline
\end{tabular}

\section*{Memory-I/O Matrix}

If floppy disk is used in the application, space for the disk buffers must be allocated in memory \(\$ 0000\) through \(\$ 3 F F F\). User memory can be a mix of ROM, EEROM, UVROM or RAM.


Memory Maps



\section*{RSC-FORTH CONFIGURATION 3 (R65FR3, R65FK3)}

\section*{R6501Q BASED SYSTEM DEVELOPMENT AND PRODUCTION}

The RSC-FORTH Configuration 3 is designed for those applications which require a larger amount of ROM or RAM space than the R65F11 or R65F12 can provide.

In the development configuration, the user is provided with up to 48 K bytes of memory. The user memory is located from \(\$ 0000\) through \$BFFF. The program heads will use some of this area but the user will still have considerably more memory space available then in the previous configurations.

The production configuration provides up to 56 K bytes of user memory. This is due to the fact that the R65FR3 Development ROM, used in the development configuration, is not required in the production configuration and releases the 8 K bytes of memory space. This memory is located at \$C000 through \$DFFF.

Figure 4 shows the development and production configurations for the R6501Q. Configuration 3 lists the features, memory maps, and the relationship of the R6501Q to the R65FR3 Development ROM and the R65FK3 Kernel ROM in the development and production environment.


Figure 4. R65FR3 and R65FK3 Configuration 3 Block Diagrams

\section*{CONFIGURATION 3 CONSIDERATIONS}

Features
- R6501Q w/FORTH
- 48K Bytes of User Memory
- 30 I/O Lines

Device Configuration
DEVELOPMENT PRODUCTION

R6501Q Microcomputer

R65FK3 Development ROM

R65FR3 Kernel ROM


\section*{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.


\section*{Memory Maps}



\section*{R6501Q} ONE-CHIP MICROPROCESSOR

\section*{SECTION 1 INTRODUCTION}

\subsection*{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 bidirectıonal, 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

\subsection*{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 Order No. 201). A description of the instruction capabilities of the R6502 CPU is contained in the R6500 Microcomputer System Programming Manual (Document Order No. 202).

\subsection*{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

\subsection*{1.4 ORDERING INFORMATION}

R6501Q - 4 MHz Xtal, 1 MHz Operation-Commercial R6501AQ-4 MHz Xtal, 2 MHz Operation-Commercial R6501EQ-4 MHz Xtal, 1 MHz Operation-Industrial R6501AEQ-4 MHz Xtal, 2 MHz Operation-Industrial



Figure 2-1. Mechanical Outline \& Pin Out Configuration

\section*{SECTION 2 \\ 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.


MULTIPLEXED FUNCTIONS PINS (Software Selectable)
Figure 2-2. Interface Diagram

TABLE 2-1. R6501Q Pin Descriptions
\begin{tabular}{|c|c|c|}
\hline SIGNAL NAME & PIN NO. & DESCRIPTION \\
\hline \(V_{c c}\) & 21 & Main power supply +5 V \\
\hline \(V_{\text {RR }}\) & 43 & Separate power pin for RAM. In the event that \(\mathrm{V}_{\mathrm{cc}}\) power is off, this power retains RAM data. \\
\hline \(\mathrm{V}_{\text {ss }}\) & 44 & Signal and power ground ( 0 V ) \\
\hline XTLI & 42 & Crystal or clock input for internal clock oscillator. Allows input of X 1 clock signal if XTLO is connected to \(\mathrm{V}_{\mathrm{ss}}\) or of X 4 clock if XTLO is floated. \\
\hline XTLO & 41 & Crystal output from internal clock oscillator. \\
\hline \(\overline{\text { RES }}\) & 6 & The Reset input is used to initialize the device. This signal must not transition from low to high for at least eight cycles after \(\mathrm{V}_{\mathrm{cc}}\) reaches operating range and the internal oscillator has stabilized. \\
\hline \(\phi 2\) & 45 & Clock signal output at internal frequency. \\
\hline \(\overline{\mathrm{NMI}}\) & 23 & A negative going edge on the Non-Maskable Interrupt signal requests that a nonmaskable interrupt be generated with the CPU. \\
\hline PA0-PA7 & 39-32 & Four 8-bit ports used for \\
\hline PB0-PB7 & 31-24 & either input/output. Each line \\
\hline PC0-PC7 & 54-61 & of Ports A, B and C consists \\
\hline PD0-PD7 & \[
\begin{gathered}
62-64 \\
1-5
\end{gathered}
\] & of an active transistor to \(\mathrm{V}_{\text {ss }}\) and a passive pull-up to \(V_{c c}\). Port \(D\) functions as either an 8 -bit input or 8-bit output port. It has active pull-up and puilldown transistors. \\
\hline A0-A12, A15 & 20-7 & Fourteen address lines used to address a complete 65K external address space. Note: A13 \& A14 are sourced through PC6 \& PC7 when in the Full Address Mode. \\
\hline DB0-DB7 & 53-46 & Eight bidirectional data bus lines used to transmit data to and from external memory. \\
\hline SYNC & 22 & SYNC is a positive going signal for the full clock cycle whenever the CPU is performing an OP CODE fetch. \\
\hline R/ \(\bar{W}\) & 40 & Controls the direction of data transfer between the CPU and the external 65 K address space. The signal is high when reading and low when writing. \\
\hline
\end{tabular}

\section*{SECTION 3 SYSTEM ARCHITECTURE}

This section provides a functional description of the R6501Q. Functionally the R6501Q consists of a CPU, RAM, four 8-bit parallel I/O ports, a serial I/O port, dual counter/latch crrcuits, a mode control register, and an interrupt flag/enable dual register circuit. A block diagram of the system is shown in Figure 3-1.

\section*{NOTE}

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

\subsection*{3.1 CPU LOGIC}

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

\subsection*{3.1.1 Accumulator}

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

\subsection*{3.1.2 Index Registers}

There are two 8-bit index registers, \(X\) and \(Y\). Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly sımplifies many types of programs, especially those using data tables.

\subsection*{3.1.3 Stack Pointer}

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal \(\overline{\mathrm{RQ}}\) interrupt, or the external interrupt line \(\overline{\mathrm{NMI}}\). The Stack Pointer must be initialized by the user program.

The stack aliows simple ımpiementation of muitıpie leveı interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may be accessed only from the top. The address of a memory
location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1 . Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 00FF-0040. After reset, which leaves the Stack Pointer indeterminate, normal usage calls for its initialization at 00FF.

\subsection*{3.1.4 Arithmetic And Logic Unit (ALU)}

All arithmetıc and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs

\subsection*{3.1.5 Program Counter}

The 16-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter (PCH) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

\subsection*{3.1.6 Instruction Register and Instruction Decode}

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register, then decoded along with timing and interrupt signals to generate control signals for the various registers.

\subsection*{3.1.7 Timing Control}

The Timıng 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 beginnıng 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 tıming control unit.

Figure 3-1. Detailed Block Diagram

\subsection*{3.1.8 Interrupt Logic}

Interrupt logic controls the sequencing of three interrupts; \(\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}\) and \(\overline{\mathrm{RQQ}}\). \(\overline{\mathrm{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.

\subsection*{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 explanned in the following paragraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions. The four added instructions do not impact the CPU processor status register.

\subsection*{3.2.1 Set Memory Bit (SMB m, Addr.)}

This instruction sets to " 1 " one of the 8 -bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and one of eight bits to be set. The second byte of the instruction designates address \((0-255)\) of the byte to be operated upon.

\subsection*{3.2.2 Reset Memory Bit (RMB m, Addr.)}

This instruction is the same operation and format as SMB instruction except a reset to " 0 " of the bit results.

\subsection*{3.2.3 Branch On Bit Set Relative (BBS m, Addr, DEST)}

This instruction tests one of eight bits designated by a 3-bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction is used to specify the 8-bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

\subsection*{3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST)}

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

\subsection*{3.3 READ-ONLY-MEMORY (ROM)}

The R6501Q has no ROM and its Reset vector is at FFFC.

\subsection*{3.4 RANDOM ACCESS MEMORY (RAM)}

The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The R6501Q provides a separate power pin ( \(\mathrm{V}_{\mathrm{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 retaıned if standby power is supplied to the \(V_{R R} p I n\). 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{RB}}\) 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 operatıng range and until at least eight \(\emptyset 2\) clock cycles after \(\mathrm{V}_{\mathrm{cc}}\) is again within operating range and the internal \(\phi 2\) oscillator is stabilized. \(\mathrm{V}_{\mathrm{RR}}\) must remain within \(\mathrm{V}_{\mathrm{CC}}\) operating range during normal operation. When \(V_{c c}\) is out of operating range, \(V_{\text {RR }}\) must remain within the \(V_{R R}\) retention range in order to retain data. Figure 3.2 shows typical waveforms.


INITIAL APPLICATION OF \(V_{C C}\) AND \(V_{R R}\) LOSS OF \(V_{C C}\), RAM ON STANDBY POWER REAPPLICATION OF VCC.
\(>8 \mathbf{\phi 2}\) CLOCK PULSES AFTER OSCILLATOR STABILIZATION \(>8 \$ 2\) CLOCK PULSES

Figure 3-2. Data Retention Timing

\subsection*{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 \%\).

\section*{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-3 c\) 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 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

\subsection*{3.6 MODE CONTROL REGISTER (MCR)}

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for Counter A and Counter B. Its setting, along with the setting of the Serial Communications Control Register (SCCR), determines the basic configuration of the 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.

\subsection*{3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)}

An \(\overline{\mathrm{RQ}}\) interrupt request can be initiated by any or all of eight possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple
simultaneous interrupts 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

\subsection*{3.8 PROCESSOR STATUS REGISTER}

The 8-bit Processor Status Register, shown in Figure 3-7, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6502 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

\subsection*{3.8.1 Carry Bit (C)}

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.


Figure 3-7. Processor Status Register

Table 3-1. Interrupt Flag Register Bit Codes
\begin{tabular}{|c|c|}
\hline \[
\begin{aligned}
& \text { BIT } \\
& \text { CODE }
\end{aligned}
\] & FUNCTION \\
\hline IFR 0: & PAO Positive Edge Detect Flag-Set to a "1" when a positive going edge is detected on PAO. Cleared by RMB O (0010) instruction or by \(\overline{\text { RES }}\). \\
\hline IFR 1: & PA1 Positive Edge Detect Flag-Set to a 1 when a positive going edge is detected on PA1. Cleared by RMB 1 (0010) instruction or by \(\overline{\text { RES }}\). \\
\hline IFR 2: & PA2 Negative Edge Detect Flag-Set to a 1 when a negative going edge is detected on PA2. Cleared by RMB 2 (0010) instruction or by \(\overline{\text { RES. }}\) \\
\hline IFR 3: & PA3 Negative Edge Detect Flag-Set to 1 when a negative going edge is detected on PA3. Cleared by RMB 3 (0010) instruction or by \(\overline{\text { RES }}\). \\
\hline IFR 4: & Counter A Underflow Flag-Set to a 1 when Counter A underflow occurs. Cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES. \\
\hline IFR 5: & Counter B Underflow Flag-Set to a 1 when Counter B underflow occurs. Cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by RES. \\
\hline IFR 6: & Receiver Interrupt Flag-Set to a 1 when any of the Serial Communication Status Register bits 0 through 3 is set to a 1 . Cleared when the Receiver Status bits (SCSR 0-3) are cleared or by \(\overline{\text { RES. }}\) \\
\hline IFR 7: & Transmitter Interrupt Flag-Set to a 1 when SCSR 6 is set to a 1 while SCSR 5 is a 0 or SCSR 7 is set to a 1 . Cleared when the Transmitter Status bits (SCSR \(6 \& 7\) ) are cleared or by \(\overline{R E S}\). \\
\hline
\end{tabular}

\subsection*{3.8.2 Zero Bit (Z)}

The Zero Bit ( \(Z\) ) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The R6500 instruction set contains no instruction to specifically set or clear the Zero Bit The Zero Bit is, however, affected by the following instructions; ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

\subsection*{3.8.3 Interrupt Disable Bit (I)}

The Interrupt Disable Bit (I) is used to control the servicing of an interrupt request ( (IRQ). If the I Bit is reset to logic 0 , the \(\overline{\mathrm{RQ}}\) signal will be serviced. If the bit is set to logic 1 , the \(\overline{\mathrm{IRQ}}\) signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( \(\overline{\operatorname{RES}}\) ), \(\overline{\mathrm{RQ}}\), 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 is set by the BRK Instruction. The Return from Interrupt (RTI) and Pull Processor Status (PLP) instructions will also affect the I bit

\subsection*{3.8.4 Decimal Mode Bit (D)}

The Decimal Mode Bit (D) is used to control the arithmetic mode of the CPU. When this bit is set to logic 1 , the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction clears it. The PLP and RTI instructions also affect the Decimal Mode Bit.

\section*{CAUTION}

The Decimal Mode Bit will ether set or clear in an unpredictable manner upon power application. This bit must be initialized to the desired state by the user program or erroneous results may occur.

\subsection*{3.8.5 Break Bit (B)}

The Break Bit \((B)\) is used to determine the condition which caused the \(\overline{\mathrm{RQQ}}\) service routine to be entered. If the \(\overline{\mathrm{IRQ}}\) 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.

\subsection*{3.8.6 Overflow Bit (V)}

The Overflow Bit (V) is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits ( \(-128 \leqslant n \leqslant 127\) ). This indicator only has meanıng when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7) is changed because the result exceeds +127 or -128 , otherwise the bit is cleared to logic 0 The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction-which may be used to sample interface devices-allows the overflow flag to reflect the condition of bit 6 in the sampled field. During a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions affecting the \(V\) flag are ADC, BIT, CLV, PLP, RTI and SBC.

\subsection*{3.8.7 Negative Bit (N)}

The Negative Bit ( N ) is used to indicate that the sign bit (bit 7) in the resulting value of a data movement or data arithmetic operation is set to logic 1 . If the sign bit is set to logic 1 , the resulting value of the data movement or arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

\title{
SECTION 4 PARALLEL INPUT/OUTPUT PORTS \& BUS MODES
}

The devices have 32 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 l/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{R}_{\mathrm{L}} \leqslant 12 \mathrm{~K}\) ohm) are provided on all port pins except Port D.

The direction of the \(32 \mathrm{I} / \mathrm{O}\) lines 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
\begin{tabular}{cc}
\hline PORT & ADDRESS \\
\hline A & 0000 \\
B & 0001 \\
C & 0002 \\
D & 0003 \\
\hline
\end{tabular}

\subsection*{4.1 INPUTS}

Inputs for Ports A, B, and C are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to \(\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 D may only be all inputs or all outputs. All inputs is selected by setting bit 5 of the Mode Control Register (MCR5) to a " 0 ".

The status of the input lines can be interrogated at any time by reading the I/O port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers.

Read/Modify/Write instructions can be used to modify the operation of PA, PB, PC, \& PD. During the Read cycle of a Read/Modify/Write instruction the Port I/O register is read. For all other read instructions the port input lines are read. Read/Modify/Write instructions are: ASL, DEC, INC, LSR, RMB, ROL, ROR, and SMB.

\subsection*{4.2 OUTPUTS}

Outputs for Ports A thru D are controlled by writing the desired I/O line output states into the corresponding I/O port regıster bit positions. A logıc 1 will force a high ( \(>2.4 \mathrm{~V}\) ) output while a logıc 0 will force a low ( \(<0.4 \mathrm{~V}\) ) output.

Port D all outputs is selected by setting MCR5 to a "1".

\subsection*{4.3 Port A (PA)}

Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as a standard parallel 8-bit, bit independent, I/O port or as serial channel I/O lines, counter I/O lines, or an input data strobe for the Port B input latch option. Table 4-2 tabulates the control and usage of Port A.

In addition to their normal I/O functions, PAO and PA1 can detect positive going edges and PA2 and PA3 can detect negative going edges. A proper transition on these pins will set a corresponding status bit in the IFR and generate an interrupt request if the respective Interrupt Enable Bit is set. The maximum rate at which an edge can be detected is onehalf the \(\not \varnothing 2\) clock rate. Edge detection timing is shown in Appendix E.3.

Table 4-2. Port A Control and Usage
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{5}{*}{PAO (2) PIN 39} & \multicolumn{2}{|c|}{PAO I/O} & \multicolumn{2}{|l|}{PORT B LATCH MODE} & & \\
\hline & \multicolumn{2}{|c|}{MCR4 \(=0\)} & \multicolumn{2}{|c|}{MCR4 \(=1\)} & & \\
\hline & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} & & \\
\hline & NAME & TYPE & \multirow[t]{2}{*}{\begin{tabular}{|c} 
NAME \\
PORT B \\
LATCH STROBE
\end{tabular}} & TYPE & & \\
\hline & PAO & 1/0 & & INPUT (1) & & \\
\hline & & & \multicolumn{4}{|l|}{} \\
\hline \multirow[b]{4}{*}{\begin{tabular}{l}
PA1 (2) \\
PIN 38 \\
PA2 (3) \\
PIN 37 \\
PA3 (3) \\
PIN 36
\end{tabular}} & \multicolumn{2}{|c|}{PA1-PA3 I/O} & \multicolumn{4}{|l|}{\multirow[t]{4}{*}{}} \\
\hline & \multicolumn{2}{|c|}{SIGNAL} & & & & \\
\hline & NAME & TYPE & & & & \\
\hline & \[
\begin{aligned}
& \text { PA1 } \\
& \text { PA2 } \\
& \text { PA3 }
\end{aligned}
\] & \[
\begin{aligned}
& 1 / 0 \\
& 1 / 0 \\
& 1 / 0
\end{aligned}
\] & & & & \\
\hline & & & & & & \\
\hline \multirow{10}{*}{\[
\begin{array}{r}
\text { PA4 } \\
\text { PIN } 35
\end{array}
\]} & \multicolumn{2}{|c|}{PA4 I/O} & \multicolumn{4}{|c|}{COUNTER A I/O} \\
\hline & \multicolumn{2}{|l|}{\[
\begin{aligned}
& \text { MCRO }=0 \\
& \text { MCR1 }=0 \\
& \text { SCCR7 }=0 \\
& \text { RCVR S/R MODE }=0 \\
& \text { (4) (5) }
\end{aligned}
\]} & \multicolumn{2}{|l|}{\[
\begin{aligned}
& \text { MCRO }=1 \\
& \text { MCR1 }=0 \\
& \text { SCCR7 }=0 \\
& \text { RCVR S/R MODE }=0
\end{aligned}
\]
(4)} & \multicolumn{2}{|l|}{\[
\begin{aligned}
& \text { SCCR7 }=0 \\
& \text { SCCR6 }=0 \\
& \text { MCR1 }=1
\end{aligned}
\]} \\
\hline & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} \\
\hline & NAME & TYPE & NAME & TYPE & NAME & TYPE \\
\hline & PA4 & 1/0 & CNTA & OUTPUT & CNTA & INPUT (1) \\
\hline & \multicolumn{6}{|c|}{SERIAL I/O SHIFT REGISTER CLOCK} \\
\hline & \multicolumn{3}{|c|}{\[
\begin{aligned}
& \text { SCCR7 }=1 \\
& \text { SCCR5 }=1
\end{aligned}
\]} & \multicolumn{3}{|l|}{\begin{tabular}{l}
RCVR S/R MODE \(=1\) \\
(4)
\end{tabular}} \\
\hline & \multicolumn{3}{|c|}{SIGNAL} & \multicolumn{3}{|c|}{SIGNAL} \\
\hline & \multicolumn{2}{|c|}{NAME} & TYPE & \multicolumn{2}{|l|}{NAME} & TYPE \\
\hline & \multicolumn{2}{|c|}{XMTR CLOCK} & OUTPUT & \multicolumn{2}{|l|}{RCVR CLOCK} & INPUT (1) \\
\hline & & & & & & \\
\hline \multirow{5}{*}{\[
\begin{array}{r}
\text { PA5 } \\
\text { PIN } 34
\end{array}
\]} & \multicolumn{2}{|c|}{PA5 I/O} & \multicolumn{4}{|c|}{COUNTER B I/O} \\
\hline & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR3 }=0 \\
& \text { MCR2 }=0
\end{aligned}
\]} & \multicolumn{2}{|r|}{\[
\begin{aligned}
& \text { MCR3 }=0 \\
& \text { MCR2 }=1
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR3 }=1 \\
& \text { MCR2 }=X
\end{aligned}
\]} \\
\hline & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} \\
\hline & NAME & TYPE & NAME & TYPE & & TYPE \\
\hline & PA5 & 1/0 & CNTB & OUTPUT & CNTB & INPUT (1) \\
\hline & \multicolumn{2}{|c|}{\multirow[b]{2}{*}{PA6 I/O}} & & & \multicolumn{2}{|l|}{\multirow[t]{12}{*}{\begin{tabular}{l}
(1) HARDWARE BUFFER FLOAT \\
(2) POSITIVE EDGE DETECT \\
(3) NEGATIVE EDGE DETECT \\
(4) RCVR S/R MODE \(=1\) WHEN SCCR6 \(\cdot \overline{\text { SCCR5 }} \cdot \operatorname{SCCR4}=1\) \\
(5) For the following mode combinations PA4 is available as an Input Only pin: \\
SCCR7-SCCR6-SCCR5*MCR1 \\
\(+\overline{\text { SCCR7 }}\)-SCCR6-SCR4-MCR1 \\
+ SCCR7. \(\overline{\text { SCCR6 }} \cdot \overline{\text { SCCR5 }}\) \\

\end{tabular}}} \\
\hline \multirow{5}{*}{\[
\begin{array}{r}
\text { PA6 } \\
\text { PIN } 33
\end{array}
\]} & & & \multicolumn{2}{|c|}{SERIAL I/O XMTR OUTPUT} & & \\
\hline & \multicolumn{2}{|c|}{SCCR7 \(=0\)} & \multicolumn{2}{|c|}{SCCR7 = 1} & & \\
\hline & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} & & \\
\hline & NAME & TYPE & NAME & TYPE & & \\
\hline & PA6 & 1/0 & XMTR & OUTPUT & & \\
\hline & & & & & & \\
\hline \multirow{5}{*}{\[
\begin{array}{r}
\text { PA7 } \\
\text { PIN } 32
\end{array}
\]} & \multicolumn{2}{|c|}{PA7 I/O} & \multicolumn{2}{|c|}{SERIAL I/O RCVR INPUT} & & \\
\hline & \multicolumn{2}{|c|}{SCCR6 \(=0\)} & \multicolumn{2}{|c|}{SCCR6 = 1} & & \\
\hline & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} & & \\
\hline & NAME & TYPE & NAME & TYPE & & \\
\hline & PA7 & \(1 / 0\) & RCVR & INPUT (1) & & \\
\hline
\end{tabular}

\subsection*{4.4 PORT B (PB)}

Port B can be programmed as an 8-bit, bit-independent I/O port. It has a latched input capability which may be enabled or disabled via the Mode Control Register (MCR). Table 4-3 tabulates the control and usage of Port B. An Input Data Strobe signal must be provided thru PAO when Port B is programmed to be used with latched input option. Input data latch timing for Port \(B\) is shown in Appendix E.3.

Table 4-3. Port B Control \& Usage
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{\multirow[t]{2}{*}{}} & \multicolumn{2}{|r|}{I/O MODE} & \multicolumn{2}{|c|}{LATCH MODE} \\
\hline & & \multicolumn{2}{|r|}{MCR4 \(=0\)} & \multicolumn{2}{|r|}{\begin{tabular}{l}
\[
\text { MCR4 }=1
\] \\
(2)
\end{tabular}} \\
\hline \multirow[b]{2}{*}{\[
\begin{gathered}
\text { PIN } \\
\#
\end{gathered}
\]} & \multirow[b]{2}{*}{PIN NAME} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} \\
\hline & & NAME & \begin{tabular}{l}
TYPE \\
(1)
\end{tabular} & NAME & TYPE \\
\hline 31 & PBO & PBO & 1/0 & PBO & INPUT \\
\hline 30 & PB1 & PB1 & I/O & PB1 & INPUT \\
\hline 29 & PB2 & PB2 & 1/0 & PB2 & INPUT \\
\hline 28 & PB3 & PB3 & 1/0 & PB3 & INPUT \\
\hline 27 & PB4 & PB4 & 1/0 & PB4 & INPUT \\
\hline 26 & PB5 & PB5 & 1/0 & PB5 & INPUT \\
\hline 25 & PB6 & PB6 & 1/0 & PB6 & INPUT \\
\hline 24 & PB7 & PB7 & I/O & PB7 & INPUT \\
\hline
\end{tabular}
(1) RESISTIVE PULL-UP, ACTIVE BUFFER PULL DOWN
(2) INPUT DATA IS STORED IN PORT B LATCH BY PAO PULSE


Figure 4-1a. Full Address Mode

\subsection*{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 l/O pins.

\subsection*{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.

\subsection*{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 A0-A12 used for selecting 8 K of external memory.


Figure 4-1b. Normal Bus Mode

Table 4-4. Port C Control and Usage
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{2}{|c|}{\multirow[b]{2}{*}{, '}} & \multicolumn{2}{|r|}{FULL ADDRESS MODE} & \multicolumn{2}{|c|}{I/O MODE} \\
\hline & & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=0
\end{aligned}
\]} \\
\hline & \multirow[b]{2}{*}{PIN NAME} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} \\
\hline \# & & NAME & TYPE & NAME & \begin{tabular}{l}
TYPE \\
(1)
\end{tabular} \\
\hline 54 & PCO & PC0 & 1/O (1) & PCO & I/O \\
\hline 55 & PC1 & PC1 & I/O (1) & PC1 & 1/0 \\
\hline 56 & PC2 & PC2 & 1/O (1) & PC2 & 1/O \\
\hline 57 & PC3 & PC3 & I/O (1) & PC3 & 1/0 \\
\hline 58 & PC4 & PC4 & I/O (1) & PC4 & 1/O \\
\hline 59 & PC5 & PC5 & I/O (1) & PC5 & \(1 / 0\) \\
\hline 60 & PC6 & A13 & OUTPUT (2) & PC6 & 1/O \\
\hline 61 & PC7 & A14 & OUTPUT (2) & PC7 & 1/O \\
\hline
\end{tabular}

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
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{\multirow[t]{2}{*}{}} & \multicolumn{4}{|c|}{I/O MODES} \\
\hline & & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=\mathrm{X} \\
& \text { MCR5 }=0
\end{aligned}
\]} & \multicolumn{2}{|r|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=\mathrm{X} \\
& \text { MCR5 }=\mathbf{1}
\end{aligned}
\]} \\
\hline \multirow[b]{2}{*}{\[
\begin{gathered}
\text { PIN } \\
\#
\end{gathered}
\]} & \multirow[b]{2}{*}{PIN NAME} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} \\
\hline & & NAME & \begin{tabular}{l}
TYPE \\
(1)
\end{tabular} & NAME & \begin{tabular}{l}
TYPE \\
(2)
\end{tabular} \\
\hline 62 & PDO & PD0 & INPUT & PDO & OUTPUT \\
\hline 63 & PD1 & PD1 & INPUT & PD1 & OUTPUT \\
\hline 64 & PD2 & PD2 & INPUT & PD2 & OUTPUT \\
\hline 1 & PD3 & PD3 & INPUT & PD3 & OUTPUT \\
\hline 2 & PD4 & PD4 & INPUT & PD4 & OUTPUT \\
\hline 3 & PD5 & PD5 & InPut & PD5 & OUTPUT \\
\hline 4 & PD6 & PD6 & INPUT & PD6 & OUTPUT \\
\hline 5 & PD7 & PD7 & INPUT & PD7 & OUTPUT \\
\hline
\end{tabular}

NOTES:
1. Tri-State Buffer is in High Impedance Mode

2 Tri-State Buffer is in Active Mode

\section*{SECTION 5 SERIAL INPUT/OUTPUT CHANNEL}

The device provides a full duplex Serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 5-1. The serial bit rate is determined by Counter A for all modes except the Receiver Shift Register (RCVR S/R) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5 K bits per second (at \(\phi 2=1 \mathrm{MHZ}\) ). The transmitter (XMTR) and receiver (RCVR) can be independently programmed to operate in different modes and can be independently enabled or disabled.


Figure 5-1. Serial Communication Control Register

Except for the Receiver Shift Register Mode (RCVR S/R), all XMTR and RCVR bit rates will occur at one sixteenth of the Counter A interval timer rate. Counter A is forced into an interval timer mode whenever the serial I/O is enabled in a mode requiring an internal clock.

Whenever Counter \(\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.

\subsection*{5.1 TRANSMITTER OPERATION (XTMR)}

The XTMR operation and the transmitter related control/ status functions are enabled by bit 7 of the Serial Communicatıons Control Register (SCCR). The transmitter, when in the Asynchronous (ASYN) mode, automatically adds a start bit, one or two stop bits, and, when enabled, a parity bit to the transmitted data. A word of transmitted data (in asynchronous parity mode) can have \(5,6,7\), or 8 bits of data. The nine data modes are shown in Figure 5-2. When parity is disabled, the 5, 6, 7 or 8 bits of data are terminated with two stop bits.



Figure 5-2. SIO Data Modes
In the S/R mode, eight data bits are always shifted out. Bits/ character and parity control bits are ignored. The serial data is shifted out via the SO output (PA6) and the shift clock is available at the CA (PA4) pin. When the transmitter underruns in the S/R mode the SO output and shift clock are held in a high state.

The XMTR Interrupt Flag bit (IFR7) is controlled by Serial Communication Status Register bits SCSR5, SCSR6 and SCSR7.
\[
\text { IFR7 }=\text { SCSR6 }(\overline{\text { SCSR5 }}+\text { SCSR7 })
\]

\subsection*{5.2 RECEIVER OPERATION (RCVR)}

The receiver and its selected control and status functions are enabled when SCCR-6 is set to a "1." In the ASYN mode, data format must have a start bit, the appropriate number of data bits, a parity bit (if enabled), and one stop bit. Refer to paragraph 5.1 for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start bit and a strobe signal is generated at the approximate center of each incoming bit. Refer to Figure 5-3 for ASYN Receive Data Timing. The character assembly process does not start if the start bit signal is less than one-half the bit time after a low level is detected on the Receive Data Input. Framing error, over-run, and parity error conditions or a RCVR Data Register Full will set the appropriate status bits. Any of the above conditions will cause an Interrupt Request if the Receiver Interrupt Enable bit is set to logic 1.


\section*{*Serial Input Data Shifted 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.

\subsection*{5.3 SERIAL COMMUNICATION STATUS REGISTER (SCSR)}

The Serial Communication Status Register (SCSR) holds information on various communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 5-5. Bit assignments and functions of the SCSR are as follows:

SCSR 0: Receiver Data Register Full-Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by \(\overline{\mathrm{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{\mathrm{RES}}\) or when the receiver detects a string of ten consecutive 1's. When the Wake-Up bit is set SCSR0 through SCSR3 are inhibited.
SCSR 5: End of Transmission-Set to a logic 1 by writing a " 1 " in bit position 5 of address: 0016. The End of Transmission bit is cleared by RES or upon writing a new data word into the Transmitter Data Register. When the End-of-Transmission bit is true the Transmitter Register Empty bit is disabled until a Transmitter Under-Run occurs.
SCSR 6: Transmitter Data Register Empty-Set to a logic 1 when the contents of the Transmitter Data Register are transferred to the Transmitter Shift Register. Cleared upon writing new data into the Transmit Data Register. This bit is initialized to a logic 1 by \(\overline{\mathrm{RES}}\).
SCSR 7: Transmitter Under-Run-Set to a logic 1 when the last data bit is transmitted if the transmitter is in a S/R Mode or when the last stop bit is transmitted if the XMTR is in the ASYN Mode while the Transmitter Data Register Empty Bit is set. Cleared by a transfer of new data into the Transmitter Shift Register or by \(\overline{\text { RES }}\).


Figure 5-5. SCSR Bit Allocations

\subsection*{5.4 WAKE-UP FEATURE}

In a multi-distributed microprocessor or microcomputer appliations, a destination address is usually included at the beginning of the message. The Wake-Up Feature allows non-selected CPU's to ignore the remainder of the message until the beginning of the next message by setting the Wake-Up bit. As long as the Wake-Up flag is true, the Receiver Data Register Full Flag remains false. The Wake-Up bit is automatically cleared when the receiver detects a string of eleven consecutive 1's which indicates an idle transmit line. When the next byte is received, the Receiver Data Register Full Flag signals the CPU to wake-up and read the received data.

\section*{SECTION 6 COUNTER/TIMERS}

The device contains two 16 -bit counters (Counter \(A\) and Counter B) and three 16 -bit latches associated with the counters. Counter A has one 16-bit latch and Counter B has two 16-bit latches. Each counter can be independently programmed to operate in one of four modes:
\begin{tabular}{ll}
\multicolumn{1}{c}{ Counter A } & \multicolumn{1}{c}{ Counter B } \\
- Pulse width & - Retriggerable Interval Counter \\
measurement & - Asymmetrical Pulse \\
- Pulse Generation & Generation \\
- Interval Timer & - Interval Timer \\
- Event Counter & - Event Counter
\end{tabular}

Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4.2).

\subsection*{6.1 COUNTER A}

Counter A consists of a 16 -bit counter and a 16 -bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contains the count of either \(\emptyset 2\) clock pulses or external events, depending on the counter mode selected. The contents of Counter A may be read any time by executing a read at location 0019 for the Upper Counter A and at location 001A or location 0018 for the Lower Counter A. A read at location 0018 also clears the Counter A Underflow Flag (IFR4).

The 16 -bit latch contains the counter initialization value and can be loaded at any time by executing a write to the Upper Latch A at location 0019 and the Lower Latch A at location 0018. In either case, the contents of the accumulator are copied into the applicable latch register.

Counter A can be started at any time by writing to address: 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 \(\mathbf{A}\). Counter \(\mathbf{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.
\begin{tabular}{ccl}
\hline \begin{tabular}{c} 
MCR1 \\
(bit 1)
\end{tabular} & \begin{tabular}{c} 
MCR0 \\
(bit 0)
\end{tabular} & \multicolumn{1}{c}{ Mode } \\
\hline 0 & 0 & Interval Timer \\
0 & 1 & Pulse Generation \\
1 & 0 & Event Counter \\
1 & 1 & Pulse Width Measurement \\
\hline
\end{tabular}

The Interval Timer, Pulse Generation, and Pulse Width Measurement Modes are \(\emptyset_{2}\) clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line.

The Counter is set to the Interval Timer Mode (00) when a \(\overline{R E S}\) signal is generated.

\subsection*{6.1.1 Interval Timer}

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:
1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the 02 clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore \(1 \mu \mathrm{~s}\) to 65,535 ms at the \(1 \mathrm{MHz} \phi 2\) clock rate or \(0.5 \mu \mathrm{~s}\) to 32.767 ms at the \(2 \mathrm{MHz} \emptyset 2\) clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting \(\overline{\mathrm{IRQ}}\) interrupt requests in the counter \(\overline{\mathrm{IRQ}}\) interrupt routine.

When Counter A decrements from 0000, the Counter A Underflow (IFR4) is set to logic 1 . If the Counter \(A\) Interrupt Enable Bit (IER4) is also set, an IRQ interrupt request will be generated. The Counter A Underflow bit in the Interrupt Flag Register can be examined in the \(\overline{\mathrm{RQ}}\) interrupt routine to determine that the \(\overline{\mathrm{RQ}}\) was generated by the Counter A Underflow.

While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.

\subsection*{6.1.2 Pulse Generation Mode}

In the Pulse Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs or a write is performed to address 001A.

The normal output waveform is a symmetrical square-wave. The CA output is initialized high when entering the mode and transitions low when writing to 001A.

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

\subsection*{6.1.3 Event Counter Mode}

In this mode the CA is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the \(\phi 2\) clock rate.

The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter A Underflow bit (IER4) is set to logic 1 if the underflow occurs.

Figure 6.2 is a timıng diagram of the Event Counter Mode.


Figure 6-2. Event Counter Mode

\subsection*{6.1.4 Pulse Width Measurement Mode}

This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the \(\varnothing 2\) clock rate as long as the CA line is held in the low state. The Counter is stopped when CA is in the high state.

The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4.

A timing diagram for the Pulse Width Measurement Mode is shown in Figure 6.3.


Figure 6-3. Pulse Width Measurement

\subsection*{6.1.5 Serial I/O Data Rate Generation}

Counter A also provides clock timing for the Serial I/O which establishes the data rate for the Serial I/O port. When the Serial I/O is enabled, Counter \(A\) is forced to operate at the internal clock rate. Counter \(A\) is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4-2).

Table 6-1 identifies the values to be loaded in Counter A for selecting standard data rates with a \(\phi 2\) clock rate of 1 MHz and 2 MHz . Although Table 6-1 identifies only the more common data rates, any data rate from 1 to 62.5 K bps can be selected by using the formula:
\[
N=\frac{\phi 2}{16 \times \mathrm{bps}}-1
\]
where
\(\mathrm{N} \quad=\) decimal value to be loaded into Counter A using its hexadecimal equivalent.
\(\phi 2=\) the clock frequency ( 1 MHz or 2 MHz )
bps \(=\) the desired data rate.

\section*{NOTE}

In Table 6-1 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of \(1.5 \%\) or less are acceptable. A revised clock rate is included in Table 6-1 for those baud rates which fall outside this limit.

Table 6-1. Counter A Values for Baud Rate Selection
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{\[
\begin{aligned}
& \text { STANDARD } \\
& \text { BAUD } \\
& \text { RATE }
\end{aligned}
\]} & \multicolumn{2}{|l|}{HEXADECIMAL
VALUE} & \multicolumn{2}{|l|}{\begin{tabular}{l}
03 \\
ACTUAL BAUD RATE AT
\end{tabular}} & \multicolumn{2}{|l|}{\begin{tabular}{l} 
CLOCK RATE \\
NEEDED \\
TO GET \\
STANDARD \\
BAUD RATE \\
\hline
\end{tabular}} \\
\hline & 1 MHz & 2 MHz & 1 MHz & 2 MHz & 1 MHz & 2 \\
\hline 50 & 04E1 & 09C3 & 50.00 & 50.00 & 1.0000 & 2.0000 \\
\hline 75 & 0340 & 0682 & 75.03 & 74.99 & 1.0000 & 2.0000 \\
\hline 110 & 0237 & 046F & 110.04 & 110.04 & 1.0000 & 2.0000 \\
\hline 150 & 01A0 & 0340 & 149.88 & 150.06 & 1.0000 & 2.0000 \\
\hline 300 & 00CF & 01A0 & 300.48 & 299.76 & 1.0000 & 2.0000 \\
\hline 600 & 0067 & 00CF & 60096 & 600.96 & 10000 & 2.0000 \\
\hline 1200 & 0033 & 0067 & 1201.92 & 1201.92 & 1.0000 & 2.0000 \\
\hline 2400 & 0019 & 0033 & 2403.85 & 2403.85 & 1.0000 & 2.0000 \\
\hline 3600 & 0010 & 0021 & 3676.47 & 3676.47 & 0.9792 & 1.9584 \\
\hline 4800 & 000C & 0019 & 4807.69 & 480769 & 10000 & 2.0000 \\
\hline 7200 & 0008 & 0010 & 6944.44 & 7352.94 & 1.0368 & 1.9584 \\
\hline 9600 & 0006 & 000C & 8928.57 & 9615.38 & 1.0752 & 2.0000 \\
\hline
\end{tabular}

\subsection*{6.2 COUNTER B}

Counter B consists of a 16-bit counter and two 16-bit latches organized as follows: Lower Counter B (LCB), Upper Counter B (UCB), Lower Latch B (LLB), Upper Latch B (ULB), Lower Latch C (LLC), and Upper Latch C (ULC). Latch C is used only in the asymmetrical pulse generation mode. The counter contains the count of either \(\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 001 C , by writing to address location 001E, or by RES.

Counter B operates in the same manner as Counter A in the Interval Timer and Event Counter modes. The Pulse Width Measurement Mode is replaced by the Retriggerable Interval Timer mode and the Pulse Generation mode is replaced by the Asymmetrical Pulse Generation Mode. Mode Control Register bits MCR2 and MCR3 select the four Counter B modes in a sımılar manner and codıng as MCR0 and MCR1 select the modes of Counter \(A\).

\subsection*{6.2.1 Retriggerable Interval Timer Mode}

When operating in the Retriggerable Interval Timer mode, Counter \(B\) is initialized to the latch value by writing to address 001E, by a Counter B underflow, or whenever a positive edge occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the \(C B\) line. Figure 6-4 illustrates the operation.


\subsection*{6.2.2 Asymmetrical Pulse Generation Mode}

Counter B has a special Asymmetrical Pulse Generation Mode whereby a pulse train with programmable pulse width and period can be generated without the processor intervention once the latch values are initialized.

In this mode, the 16 -bit Latch B is initialized with a value which corresponds to the duration between pulses (referred to as \(D\) in the following descriptions). The 16-bit Latch \(C\) is initialized with a value corresponding to the desired pulse width (referred to as \(P\) in the following descriptions). The initialization sequence for Latch B and C and the starting of a counting sequence are as follows:
1. The lower 8 bits of \(P\) are loaded into LLB by writing to address 001C; the upper 8 bits of \(P\) are loaded into ULB and the full 16 bits are transferred to Latch C by writing to address location 001D. At this point both Latch \(B\) and Latch \(C\) contain the value of \(P\).
2. The lower 8 bits of \(D\) are loaded into LLB by writing to address 001C; the upper 8 bits of \(D\) are loaded into ULB by writing to address location 001E. Writing to address location 001E also causes the contents of the 16-bit Latch B to be downloaded into the Counter B and the CB output to go low as shown in Figure 6-5.
3. When Counter \(B\) underflow occurs the contents of the Latch \(C\) are loaded into the Counter \(B\) and the CB output toggles to a high level, staying high until another underflow occurs. Latch \(B\) is then down-loaded and the CB output toggles to a low level repeating the whole process.

\section*{SECTION 7 \\ POWER ON/INITIALIZATION CONSIDERATIONS}

\subsection*{7.1 POWER ON TIMING}

After application of \(V_{C C}\) and \(V_{R R}\) power to the device, \(\overline{\text { RES }}\) must be held low for at least eight \(\phi 2\) clock cycles after \(\mathrm{V}_{\mathrm{cc}}\) reaches operating range and the internal oscillator has stabilized. This stabilization time is dependent upon the input \(\mathrm{V}_{\mathrm{cc}}\) voltage and performance of the internal oscillator. The clock can be monitored at \(\varnothing 2\) (pin 3). Figure 7-1 illustrates the power turn-on waveforms. Clock stabilization time is typically 20 ms .


Figure 7-1. Power Turn-On Timing Detail

\subsection*{7.2 POWER-ON RESET}

When \(\overline{\text { RES }}\) goes from low to high, the device sets the Interrupt Mask Bit-bit 2 of the Processor Status Registerand initiates a reset vector fetch at address FFFC and FFFD to begin user program execution. All of the I/O ports (PA, PB, PC, PD) will be forced to the high (logic 1) state. All bits of the Control Register will be cleared to logic 0 causing the Interval Timers counter mode (mode 00) to be selected and all interrupt enabled bits to be reset.


Figure 6-5. Counter B Pulse Generation

\subsection*{7.3 RESET ( \(\overline{\operatorname{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. RES Initialization of I/O Ports and Registers
\begin{tabular}{lcccccccc} 
& \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline REGISTERS & & & & & & & & \\
\hline 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 \\
\hline
\end{tabular}

All RAM and other CPU registers will initialize in a random, non-repeatable data pattern.

\subsection*{7.4 INITIALIZATION}

Any initialization process for the device should include a \(\overline{R E S}\), 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
SEC
...
special function registers
and clear RAM as required
Clear Interrupts

\title{
APPENDIX A \\ ENHANCED R6502 INSTRUCTION SET
}

\begin{abstract}
This appendix contains a summary of the Enhanced R6502 instruction set. For detailed information, consult the R6502 Microcomputer System Programming Manual, Document 29650 N30. The four instructions notated with a * are added instructions to enhance the standard 6502 instruction set.
\end{abstract}

\section*{A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE}
\begin{tabular}{|c|c|c|}
\hline ADC & Add Memory to Accumulator with Carry & LDA \\
\hline AND & "AND" Memory with Accumulator & LDX \\
\hline \multirow[t]{2}{*}{ASL} & Shift Left One Bit (Memory or Accumulator) & LDY \\
\hline & & LSR \\
\hline *BBR & Branch on Bit Reset Relative & \\
\hline *BBS & Branch on Bit Set Relative & \\
\hline BCC & Branch on Carry Clear & NOP \\
\hline BCS & Branch on Carry Set & \\
\hline BEQ & Branch on Result Zero & ORA \\
\hline BIT & Test Bits in Memory with Accumulator & \\
\hline BMI & Branch on Result Mınus & PHA \\
\hline BNE & Branch on Result not Zero & PHP \\
\hline BPL & Branch on Result Plus & PLA \\
\hline BRK & Force Break & PLP \\
\hline BVC & Branch on Overflow Clear & \\
\hline BVS & Branch on Overflow Set & *RMB
ROL \\
\hline CLC & Clear Carry Flag & \\
\hline CLD & Clear Decimal Mode & ROR \\
\hline CLI & Clear Interrupt Disable Bit & \\
\hline CLV & Clear Overflow Flag & RTI \\
\hline CMP & Compare Memory and Accumulator & RTS \\
\hline CPX & Compare Memory and Index X & \\
\hline CPY & Compare Memory and Index Y & SBC \\
\hline DEC & Decrement Memory by One & SEC \\
\hline DEX & Decrement Index \(X\) by One & SED \\
\hline \multirow[t]{2}{*}{DEY} & Decrement Index Y by One & SEI \\
\hline & & *SMB \\
\hline \multirow[t]{3}{*}{EOR} & "Exclusive-Or" Memory with & STA \\
\hline & Accumulator & STX \\
\hline & & STY \\
\hline INC & Increment Memory by One & \\
\hline INX & Increment Index X by One & TAX \\
\hline \multirow[t]{2}{*}{INY} & Increment Index Y by One & TAY \\
\hline & & TSX \\
\hline JMP & Jump to New Location & TXA \\
\hline \multirow[t]{2}{*}{JSR} & Jump to New Location Saving Return & TXS \\
\hline & Address & TYA \\
\hline
\end{tabular}

Load Accumulator with Memory Load Index X with Memory Load Index Y with Memory Shift One Bit Right (Memory or Accumulator)

No Operation
"OR" Memory with Accumulator
Push Accumulator on Stack
Push Processor Status on Stack
Pull Accumulator from Stack
Pull Procesșor Status from Stack
Reset Memory Bit
Rotate One Bit Left (Memory or Accumulator)
Rotate One Bit Right (Memory or Accumulator)
Return from Interrupt
Return from Subroutine
Subtract Memory from Accumulator with Borrow
Set Carry Flag
Set Decimal Mode
Set Interrupt Disable Status
Set Memory Bit
Store Accumulator in Memory
Store Index \(X\) in Memory
Store Index Y in Memory
Transfer Accumulator to Index X Transfer Accumulator to Index \(Y\) Transfer Stack Pointer to Index \(X\) Transfer Index \(X\) to Accumulator Transfer Index X to Stack Register
Transfer Index \(Y\) to Accumulator


\section*{A. 3 INSTRUCTION CODE MATRIX}


**Add 1 to N if page boundary is crossed.
**Add 1 to N if branch occurs to same page; add 2 to N if branch occurs to different page.

\section*{APPENDIX B \\ KEY REGISTER SUMMARY}


CPU Registers


\section*{Mode Control Register}


Serial Communications Control Register


Interrupt Enable and Flag Registers


XMTR Under-Run
Serial Communications Status Register

\section*{APPENDIX C ADDRESS ASSIGNMENTS/MEMORY MAPS/PIN FUNCTIONS}

\section*{C. 1 I/O AND INTERNAL REGISTER ADDRESSES}
\begin{tabular}{|c|c|c|}
\hline ADDRESS (HEX) & READ & WRITE \\
\hline 001F & - & - - \\
\hline 1 E & Lower Counter B & Upper Latch B, Cntr B \(\leftarrow\) Latch B, CLR Flag \\
\hline 1D & Upper Counter B & Upper Latch B, Latch C \(\leftarrow\) Latch B \\
\hline 1 C & Lower Counter B, CLR Flag & Lower Latch B \\
\hline 1 B & - - & - \\
\hline 1A & Lower Counter A & Upper Latch A, Cntr A↔Latch A, CLR Flag \\
\hline 19 & Upper Counter A & Upper Latch A \\
\hline 18 & Lower Counter A, CLR Flag & Lower Latch A \\
\hline 17 & Serial Receiver Data Register & Serial Transmitter Data Register \\
\hline 16 & Serial Comm Status Register & Serial Comm. Status Reg Bits 4 \& 5 only \\
\hline 15 & Serial Comm. Control Register & Serial Comm. Control Register \\
\hline 14 & Mode Control Register & Mode Control Register \\
\hline 13 & \multirow[t]{4}{*}{Interrupt Enable Register Interrupt Flag Regıster Read FF} & \multirow[t]{4}{*}{\begin{tabular}{l}
Interrupt Enable Regıster \\
Clear Int Flag (Bits 0-3 only, Write 0's only)
\end{tabular}} \\
\hline 12 & & \\
\hline 11 & & \\
\hline 0010 & & \\
\hline 0 F & \multicolumn{2}{|l|}{\multirow{11}{*}{\begin{tabular}{l}
RESERVED \\
These addresses are reserved and are used by the CPU during Read and Write operation over the external Data Bus (DO-D7).
\end{tabular}}} \\
\hline OE & & \\
\hline OD & & \\
\hline OB & & \\
\hline \multirow[t]{2}{*}{\[
\begin{aligned}
& 0 A \\
& 09
\end{aligned}
\]} & & \\
\hline & & \\
\hline 08 & & \\
\hline 07 & & \\
\hline 06 & & \\
\hline 05 & & \\
\hline 04 & & \\
\hline 03 & Port D & Port D \\
\hline 02 & Port C & Port C \\
\hline 01 & Port B & Port B \\
\hline 0000 & Port A & Port A \\
\hline
\end{tabular}

\section*{C. 2 FULL ADDRESS MODE MEMORY MAP \\ R6501Q}


\section*{C. 4 MULTIPLE FUNCTION PIN ASSIGNMENTS -PORT C AND PORT D}
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
PIN \\
NUMBER
\end{tabular} & \begin{tabular}{c} 
FULL ADDRESS \\
MODE
\end{tabular} & \begin{tabular}{c} 
I/O PORT \\
FUNCTION
\end{tabular} \\
\hline 54 & PC0 & PC0 \\
55 & PC1 & PC1 \\
56 & PC2 & PC2 \\
57 & PC3 & PC3 \\
\hline 58 & PC4 & PC4 \\
59 & PC5 & PC5 \\
60 & A13 & PC6 \\
61 & A14 & PC7 \\
\hline 62 & PD0 & PD0 \\
63 & PD1 & PD1 \\
64 & PD2 & PD2 \\
1 & PD3 & PD3 \\
\hline 2 & PD4 & PD4 \\
3 & PD5 & PD5 \\
4 & PD6 & PD6 \\
5 & PD7 & PD7 \\
\hline
\end{tabular}

\title{
APPENDIX D ELECTRICAL SPECIFICATIONS
}

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}} \& \mathrm{~V}_{\mathrm{RA}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\text {IN }}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature Range, \\
Commercial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
\(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{M}}\) \\
0 to +70
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature Range & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{R R}=V_{C C} ; V_{S S}=0 \mathrm{~V} ; T_{A}=0^{\circ}\right.\) to \(70^{\circ} \mathrm{C}\), unless otherwise specified \()\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline RAM Standby Voltage (Retention Mode) & \(V_{\text {RR }}\) & 3.0 & & \(\mathrm{V}_{\mathrm{CC}}\) & V & \\
\hline RAM Standby Current (Retention Mode) & \(\mathrm{I}_{\text {RR }}\) & - & 4 & - & mA & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline Input High Voltage All Except XTLI XTLI & \(\mathrm{V}_{\mathrm{IH}}\) & \[
\begin{aligned}
& +2.0 \\
& +4.0 \\
& \hline
\end{aligned}
\] & - & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{cc}} \\
& \mathrm{v}_{\mathrm{cc}} \\
& \hline
\end{aligned}
\] & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\text {IL }}\) & -0.3 & - & +0.8 & V & \\
\hline Input Leakage Current \(\overline{R E S}, \overline{N M I}\) & IN & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\text {IN }}=0\) to 5.0 V \\
\hline Input Low Current PA, PB, PC, PD & ILL & - & -1.0 & -1.6 & mA & \(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage (Except XTLO) & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & \(\mathrm{V}_{\mathrm{cc}}\) & V & \(\mathrm{L}_{\text {LOAD }}=-100 \mu \mathrm{~A}\) \\
\hline Output Low Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & +0.4 & V & \(\mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}\) \\
\hline I/O Port Pull-Up Resistance PA0-PA7, PB0-PB7, PC0-PC7 & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Output Leakage Current (Three-State Off) & lout & - & - & \(\pm 10\) & \(\mu \mathrm{A}\) & \\
\hline Input Capacitance XTLI, XTLO All Others & \(\mathrm{C}_{\text {IN }}\) & - & - & \[
\begin{aligned}
& 50 \\
& 10
\end{aligned}
\] & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& V_{I N}=0 \mathrm{~V} \\
& f=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) & \(\mathrm{C}_{\text {OUT }}\) & - & - & 10 & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Outputs High) & \(\mathrm{P}_{\mathrm{D}}\) & - & 750 & 1100 & mW & \(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\). \\
2. Negative sign indicates outward current flow, positive indicates inward flow.
\end{tabular}} \\
\hline
\end{tabular}

\section*{APPENDIX E \\ TIMING REQUIREMENTS AND CHARACTERISTICS}

\section*{E. 1 GENERAL NOTES}
1. \(V_{c \dot{c}}=5 \mathrm{~V} \pm 5 \%, 0^{\circ} \mathrm{C} \leqslant T A \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) - 130pf maximum

\section*{E. 2 CLOCK TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\mathrm{crc}}\) & Cycle Time & 1000 & \(10 \mu \mathrm{~s}\) & 500 & \(10 \mu \mathrm{~s}\) \\
\hline \(\mathrm{T}_{\text {Pwx }}\) & XTLI Input Clock Pulse Width XTLO = VSS & \[
\begin{gathered}
500 \\
\pm 25
\end{gathered}
\] & - & \[
\begin{aligned}
& 250 \\
& \pm 10
\end{aligned}
\] & - \\
\hline \(\mathrm{T}_{\text {Pwo2 }}\) & Output Clock Pulse Width at Minimum Torc & \(\mathrm{T}_{\text {PWx1 }}\) & \[
\begin{aligned}
& T_{p w x 1} \\
& \pm 25
\end{aligned}
\] & \(T_{\text {Pwx }}\) & \[
\begin{aligned}
& T_{p w x_{1}} \\
& \pm 20
\end{aligned}
\] \\
\hline \(\mathrm{T}_{\mathrm{F}}, \mathrm{T}_{\mathrm{F}}\) & Output Clock Rise, Fall Time & - & 25 & - & 15 \\
\hline \(\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}\) & Input Clock Rise, Fall Time & - & 10 & - & 10 \\
\hline
\end{tabular}


\section*{E. 3 I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline  & \begin{tabular}{l}
Internal Write to Peripheral Data Valid \\
PA, PB, PC TTL \\
PA, PB, PC CMOS \\
PD
\end{tabular} & \[
\underline{\square}
\] & \[
\begin{array}{r}
500 \\
1000 \\
175
\end{array}
\] & - & \[
\begin{array}{r}
500 \\
1000 \\
150
\end{array}
\] \\
\hline \[
\left\lvert\, \begin{aligned}
& T_{\text {PDSU }} \\
& T_{\text {PDSU }}
\end{aligned}\right.
\] & Peripheral Data Setup Time PA, PB, PC PD & \[
\begin{array}{r}
200 \\
50
\end{array}
\] & - & \[
\begin{array}{r}
200 \\
50
\end{array}
\] & - \\
\hline \[
\begin{aligned}
& \mathrm{T}_{\text {PHR }} \\
& \mathrm{T}_{\text {PHR }}
\end{aligned}
\] & Peripheral Data Hold Time PA, PB, PC PD & \[
\begin{aligned}
& 75 \\
& 10 \\
& \hline
\end{aligned}
\] & - & \[
\begin{aligned}
& 75 \\
& 10 \\
& \hline
\end{aligned}
\] & - \\
\hline \(\mathrm{T}_{\text {EPW }}\) & PA0-PA3 Edge Detect Pulse Width & Tcrc & - & Tcre & - \\
\hline \[
\begin{aligned}
& \mathrm{T}_{\text {cpw }} \\
& \mathrm{T}_{\text {co }}{ }^{(1)}
\end{aligned}
\] & \begin{tabular}{l}
Counters A and B \\
PA4, PA5 Input Pulse Width PA4, PA5 Output Delay
\end{tabular} & \(\mathrm{T}_{\text {crc }}\) & & Tcrc & \\
\hline \begin{tabular}{l}
\(T_{\text {petw }}\) \\
Tpisu \\
\(\mathrm{T}_{\text {PвLH }}\)
\end{tabular} & \begin{tabular}{l}
Port B Latch Mode \\
PAO Strobe Pulse Width PB Data Setup Time PB Data Hold Time
\end{tabular} & \[
\begin{gathered}
T_{\text {crc }} \\
175 \\
30 \\
\hline
\end{gathered}
\] & 二 & \[
\begin{array}{r}
\mathrm{T}_{\mathrm{crc}} \\
150 \\
30 \\
\hline
\end{array}
\] & - \\
\hline \begin{tabular}{l}
\(T_{\text {PDW }}{ }^{(1)}\) \\
\(\mathrm{T}_{\mathrm{CMOS}}{ }^{(1)}\) \\
\(\mathrm{T}_{\text {cPW }}\) \\
\(T_{\text {pow }}{ }^{(1)}\) \\
\(\mathrm{T}_{\text {cmos }}{ }^{\text {(1) }}\)
\end{tabular} & \begin{tabular}{l}
Serial I/O \\
PA6 XMTR TTL \\
PA6 XMTR CMOS \\
PA4 RCVR S/R Clock Width \\
PA4 XMTR Clock-S/R Mode (TTL) \\
PA4 XMTR Clock-S/R Mode (CMOS)
\end{tabular} &  & \[
\begin{array}{r}
500 \\
1000 \\
- \\
500 \\
1000
\end{array}
\] & \(4 \bar{T}_{\text {crc }}\) & \[
\begin{array}{r}
500 \\
1000 \\
- \\
500 \\
1000
\end{array}
\] \\
\hline
\end{tabular}

NOTE 1 Maximum Load Capacitance 50pF

\section*{Passive Pull-Up Required}

\section*{E.3.1 I/O, Edge Detect, Counter, and Serial I/O Timing}


\section*{E. 4 MICROPROCESSOR TIMING (D0-D7, A0-A12, A15, SYNC, R/W)}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|l|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\text {Rws }}\) & R/W Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {ADS }}\) & A0-A12, A15 Setup Time & - & 150 & - & 75 \\
\hline \(\mathrm{T}_{\text {DSU }}\) & D0-D7 Data Setup Time & 50 & - & 35 & - \\
\hline \(\mathrm{T}_{\text {HR }}\) & D0-D7 Read Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {Hw }}\) & D0-D7 Write Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {mos }}\) & D0-D7 Write Output Delay & - & 175 & - & 130 \\
\hline \(\mathrm{T}_{\text {SYM }}\) & SYNC Setup & - & 225 & - & 175 \\
\hline \(\mathrm{T}_{\text {HA }}\) & A0-A12, A15 Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {HRW }}\) & R/W Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {ACC }}\) & \begin{tabular}{l}
External Memory Access \\
Time \(\mathrm{T}_{\mathrm{AcC}}=\mathrm{T}_{\mathrm{CrC}}-\mathrm{T}_{\mathrm{F}}-\) \\
\(T_{\text {ADS }}-T_{\text {DSU }}\)
\end{tabular} & - & \(\mathrm{T}_{\text {ACC }}\) & - & \(\mathrm{T}_{\text {ACC }}\) \\
\hline \(\mathrm{T}_{\text {SYH }}\) & SYNC Hold Time & 30 & - & 30 & - \\
\hline
\end{tabular}

\section*{E.4.1 Microprocessor Timing Diagram}


\section*{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 Order No. 202).

\section*{FEATURES}
- Single-chip microcomputer
- R6502 software compatible
- Eight-bit parallel processing
- Decimal or binary arithmetic
- Variable length stack
- True indexing capability
- Thirteen addressing modes
- 1 or 2 MHz clock operation, with the following options:
- External single clock input
- RC time base input
- Crystal time base input
- Single +5 V power supply
- 500 mw operating power
- Separate power pın for RAM with standby power only \(10 \%\) of operating power
- 2K x 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 \mathrm{I} / \mathrm{O}\) edge detect
- NMI and Reset interrupts

\section*{SECTION 2 \\ INTERFACE REQUIREMENTS}

This section describes the interface requirements for the R6500/1 single chip microcomputer. Figure 2-1 is the Interface Diagram for the R6500/1. Figure \(2-2\) shows the pin out


Figure 2-1. R6500/1 Interface Diagram
configuration and Table 2-1 describes the function of each pin of the R6500/1.


Figure 2-2. R6500/1 Pin Out Designation

Table 2-1. R6500/1 Pin Description
\begin{tabular}{|c|c|c|}
\hline Signal Name & Pin No. & Description \\
\hline VCC & 30 & Main power supply +5 V \\
\hline VRR & 1 & Separate power pin for RAM. In the event that VCC power is lost, this power retains RAM data. \\
\hline VSS & 12 & Signal and power ground (0V) \\
\hline XTLI & 10 & Crystal, clock or RC network input for internal clock oscillator. \\
\hline XTLO & 1 & Crystal or RC network output from internal clock oscillator. \\
\hline \(\overline{\text { RES }}\) & 39 & \begin{tabular}{l}
The Reset input is used to initialize the R6500/1. The signal must not transition from low to high for at least eight cycles after VCC reaches operating range and the internal oscillator has stabilized (see section 5). \\
+10 V input enables the test mode.
\end{tabular} \\
\hline \(\overline{\mathrm{NMI}}\) & 40 & A negative going edge on the Non-Maskable Interrupt signal requests that a nonmaskable interrupt be generated within the CPU. \\
\hline PA0-PA7 & 38-31 & Four 8-bit ports used for either input/output. Each line consists of an active transistor to \\
\hline PB0-PB7 & 29-22 & VSS and an optional passive pull-up to VCC. The two lower bits of the PA port \\
\hline PC0-PC7 & 20-13 & (PA0-PA1) also serve as edge detect inputs with maskable interrupts. \\
\hline PD0-PD7 & 9-2 & \\
\hline CNTR & 21 & This line is used as a Counter input/output line. CNTR is an input in the Event Counter and Pulse Width Measurement modes and is an output in the Interval Timer and Pulse Generator modes. It consists of an active transistor to VSS and an optional passive pull-up to VCC. \\
\hline
\end{tabular}

\section*{SECTION 3 SYSTEM ARCHITECTURE}

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

\subsection*{3.1 INDEX REGISTERS}

There are two 8-bit index registers, X and Y . Each index register can be used as a base to modify the address data program counter and thus obtain a new address - the sum of the program counter contents and the and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

\subsection*{3.2 STACK POINTER}

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to
either user instructions or the interrupt lines \(\overline{\mathrm{NMI}}\) and \(\overline{\mathrm{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.

\subsection*{3.3 ARITHMETIC AND LOGIC UNIT (ALU)}

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers


Figure 3-1. R6500/1 Block Diagram
(except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

\subsection*{3.4 ACCUMULATOR}

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

\subsection*{3.5 PROGRAM COUNTER}

The 12-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter (PCH) is placed on the high-order 4 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

\subsection*{3.6 INSTRUCTION REGISTER AND INSTRUCTION DECODE}

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instructıon Regıster then decoded along with tımıng and interrupt signals to generate control signals for the various registers.

\subsection*{3.7 TIMING CONTROLS}

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to TO each time an instruction fetch is executed and is advanced at the beginning of each Phase One clock pulse for as many cycles as are required to complete the instruction. Each data transfer which takes place between the registers is caused by decoding the contents of both the instruction register and timing control unit.

\subsection*{3.8 INTERRUPT LOGIC}

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

\subsection*{3.9 CLOCK OSCILLATOR}

The Clock Oscillator provides the basic timing signals used by the R6500/1 CPU. The reference frequency is provided by an external source, and can be from a crystal, 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.


Figure 3-2. Clock Oscillator Input Options

\subsection*{3.10 PROCESSOR STATUS REGISTER}

The 8-bit Processor Status Register, shown in Figure 3-3, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6500 instruction
set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

\subsection*{3.10.1 CARRY BIT (C)}

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

\subsection*{3.10.2 ZERO BIT (Z)}

The Zero Bit (Z) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are
not all zero. The R6500 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

\subsection*{3.10.3 INTERRUPT DISABLE BIT (I)}

The Interrupt Disable Bit (I) is used to control the servicing of an interrupt request (IRQ). If the I Bit is reset to logic 0 , the \(\overline{\mathrm{RQ}}\) signal will be serviced. If the bit is set to logic 1 , the \(\overline{\mathrm{RQ}}\) signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( \(\overline{\mathrm{RES}}\) ) or NonMaskable Interrupt ( \(\overline{\mathrm{NMI} \text { ) signal is detected. }}\)

The I bit is cleared by the Clear Interrupt (CLI) instruction, the Pull Processor Status from Stack (PLP) instruction, or as the result of executing a Return from Interrupt (RTI) instruction (providing the Interrupt Disable Bit was cleared prior to the interrupt). The Interrupt Disable Bit may be set or cleared under program control using a Set Interrupt Disable (SEI) or a Clear Interrupt Disable (CLI) instruction, respectively.


Figure 3-3. Processor Status Register

\subsection*{3.10.4 DECIMAL MODE BIT (D)}

The Decimal Mode Bit (D), is used to control the arithmetic mode of the CPU. When this bit is set to logic 1 , the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction will clear it. The PLP and RTI instructions also effect the Decimal Mode Bit.

\section*{CAUTION}

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application to R6500/1. This bit must be initialized to the desired state by the user program or erroneous results may occur.

\subsection*{3.10.5 BREAK BIT (B)}

The Break Bit \((B)\) is used to determine the condition which caused the \(\overline{\mathrm{RQ}}\) service routine to be entered. If the \(\overline{\mathrm{RQ}}\) service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1. If the \(\overline{I R Q}\) routine was entered as the result of an \(\overline{\operatorname{RQ}}\) signal being generated, the \(B\) bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

\subsection*{3.10.6 OVERFLOW BIT (V)}

The Overflow Bit ( V ) is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits \((-128 \leqslant n \leqslant\) 127). This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction which may be used to sample interface devices, allows the overflow flag to reflect the condition of bit 6 in the sampled field. Duriing a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions which affect the V flag are ADC, BIT, CLV, PLP, RTI and SBC.

\subsection*{3.10.7 NEGATIVE BIT (N)}

The Negative Bit ( N ) is used to indicate that the sign bit (bit 7), in the resulting value of a data movement or data arithmetic operation, is set to logic 1. If the sign bit is set to logic 1 , the resulting value of the data movement or
arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation \(s\) positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

\subsection*{3.11 \(2 \mathrm{~K} \times 8\) ROM}

The R6500/1 2048 byte \(\times 8\)-bit Read Only Memory (ROM) usually contains the user's program instructions and other fixed constants. These program instructions and constants are mask-programmed into the ROM during fabrication of the R6500/1 device. The R6500/1 ROM is memory mapped from 800 to FFF.

\section*{\(3.1264 \times 8\) RAM}

The 64 byte \(\times 8\)-bit Random Access Memory (RAM) contains the user program stack and is used for scratchpad memory during system operation. This RAM is completely static in operation and requires no clock or dynamic refresh. The data contained in RAM is read out nondestructively with the same polarity as the input data. A standby power pin, VRR allows RAM memory to be maintained on \(10 \%\) of the operating power. In the event that VCC power is lost and execution stops, this standby power retains RAM data until execution resumes.

In order to take advantage of zero page addressing capabilities, the R6500/1 RAM is assigned page zero memory address 0 to 03F.

\subsection*{3.13 CONTROL REGISTER}

The Control Register (CR), shown in Figure 3-4, is located at address 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{\text { RES }}\) signal.

Table 3-1. CR Control Signals
\begin{tabular}{|l|c|}
\hline \multicolumn{1}{|c|}{ Control Signal Name } & \begin{tabular}{c} 
Bit \\
Number
\end{tabular} \\
\hline Counter Mode Control 0 (CMC0) & 0 \\
Counter Mode Control 1 (CMC1) & 1 \\
PA1 Interrupt Enabled (A1IE) & 2 \\
PA0 Interrupt Enabled (AOIE) & 3 \\
Counter Interrupt Enabled (CIE) & 4 \\
\hline
\end{tabular}

The three status signals are summarized in Table 3-2.


Figure 3-4. Control Register (CR)

Table 3-2. CR Status Signals
\begin{tabular}{|l|c|}
\hline \multicolumn{1}{|c|}{ Status Signal Name } & \begin{tabular}{c} 
Bit \\
Number
\end{tabular} \\
\hline PA1 Negative Edge Detected (A1ED) & 5 \\
PA0 Positive Edge Detected (A0ED) & 6 \\
Counter Overflow (CTRO) & 7 \\
\hline
\end{tabular}

The status signals are read-only information. The status bits are set to logic 1 by hardware monitoring logic and cleared to logic 0 by the occurrence of RES signal or by specific address commands. Each of these signals is described in the following sections.

\subsection*{3.13.1 COUNTER MODE CONTROL 0 AND 1}

Counter Mode Control signals CMCO and CMC1 (bits 0 and 1) control the Counter operating modes. The modes of operation and the corresponding configuration of CMCO and CMC1 are summarized in Table 3-3.

These modes are controlled by writing the appropriate bit values into the Counter Mode Control bits.

Table 3-3. Counter Mode Control Selection
\begin{tabular}{|c|c|l|}
\hline \begin{tabular}{c} 
CMC1 \\
(Bit 1)
\end{tabular} & \begin{tabular}{c} 
CMC0 \\
(Bit 0)
\end{tabular} & \multicolumn{1}{|c|}{ Mode } \\
\hline 0 & 0 & Interval Timer \\
0 & 1 & Pulse Generator \\
1 & 0 & Event Counter \\
1 & 1 & Pulse Width Measurement \\
\hline
\end{tabular}

The Counter is set to the Interval Timer Mode (00) when a \(\overline{\text { RES }}\) signal is generated or if the user program stores logic 0 into Bits 0 and 1 of the Control Register. A complete description of each of the Counter modes is given in Section 3.14.1.

\subsection*{3.13.2 PA1 INTERRUPT ENABLE BIT (A1IE)}

If the PA1 Interrupt Enable Bit (CR2) is set to logic 1, an \(\overline{\text { IRQ }}\) interrupt request signal will be generated when the PA1 Negative Edge Detected Bit (CR5) is set.

\subsection*{3.13.3 PAO INTERRUPT ENABLE BIT (AOIE)}

If the PAO Interrupt Enable Bit (CR3) is set to logic 1, the \(\overline{\mathrm{RQ}}\) interrupt request signal will be .generated when the PAO Positive Edge Detected Bit (CR6) is set.

\subsection*{3.13.4 COUNTER INTERRUPT ENABLE BIT (CIE)}

If the Counter Interrupt Enable Bit (CR4) is set to logic 1, the \(\overline{\mathrm{RQ}}\) interrupt request signal will be generated when Counter Overflow (CR7) is set.

\subsection*{3.13.5 PA1 NEGATIVE EDGE DETECTED BIT (A1ED)}

The PA1 Negative Edge Detected Bit (CR5) is set to logic 1 whenever a negative (falling) edge is detected on PA1. This bit is cleared to logic 0 by \(\overline{\operatorname{RES}}\) or by writing to address 08A.

The edge detecting circuitry is active when PA1 is used either as an input or as an output. When PA1 is used as an output, A1ED will be set when the negative edge is detected during a logical 1 to 0 transition.

When PA1 is used as an input and the negative edge detecting circuitry is used, A1ED should be cleared by the user program upon initialization and when the PA1 Negative Edge Detected \(\overline{\mathrm{RQQ}}\) processing is completed.

\subsection*{3.13.6 PAO POSTIIVE EDGE DETECTED BIT (AOED)}

The PAO Positive Edge Detected Bit (CR6) is set to logic 1 whenever a positive (rising) edge is detected on PAO. The bit is cleared to logic 0 by 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{IRQ}}\) processing.

\subsection*{3.13.7 COUNTER OVERFLOW BIT (CTRO)}

The Counter Overflow Bit (CR7) is set to logic 1 whenever a counter overflow occurs in any of the four counter operating modes. Overflow occurs when the counter is decremented one count from 0000. This bit is cleared to logic 0 by \(\overline{\operatorname{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{\mathbb{R Q}}\) 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.

\subsection*{3.14 COUNTER/LATCH}

The Counter/Latch consists of a 16 -bit Counter and a 16 -bit Latch. The Counter resides in two 8 -bit registers: address 086 contains the Upper Count value (bits 8-15 of the Counter) and address 087 contains the Lower Count value (bits \(0-7\) of the Counter). The Counter contains the count of either \(\varnothing 2\) clock periods or external events depending on which counter mode is selected in the Control Register (Section 3.13.1).

The Latch contains the Counter initialization value. The Latch resides in two 8-bit registers: address 084 contains the Upper Latch value (bits \(8-15\) of the Latch) and address 085 contains the Lower Latch value (bits 0-7 of the Latch). The 16-bit Latch can hold values from 0 to 65535.

The Latch registers can be loaded at any time by executing a write to the Upper Latch Address (084) and the Lower Latch Address (085). In each case, the contents of the Accumulator are copied into the applicable Latch register. The Upper Latch and Lower Latch can be loaded independently; it is not required to load both registers at the same time or sequentially. The Upper Latch can also be loaded by writing to address 088.

The Counter can be initialized at any time by writing to address 088. The contents of the Accumulator will be copied into the Upper Latch before the value in the Upper Latch is transferred to the Upper Counter.

The Counter will also be initialized to the Latch value whenever the Counter overflows. When the Counter decrements from 0000, the next Counter value will be the Latch value, not FFFF.

Whenever the Counter overflows, the Counter Overflow Bit (CR7) is set to logic 1. This bit is cleared whenever the lower eight bits of the counter are read from address 087 or by writing to address 088.

\subsection*{3.14.1 COUNTER MODES}

The Counter operates in any of four modes. These modes are selected by the Counter Mode Control bits in the Control Register.
\begin{tabular}{lcc}
\multicolumn{1}{c}{ Mode } & CMC1 & CMC0 \\
Interval Timer & 0 & 0 \\
Pulse Generator & 0 & 1 \\
Event Counter & 1 & 0 \\
Pulse Width Measurement & 1 & 1
\end{tabular}

The Interval Timer, Pulse Generator, and Pulse Width Measurement Modes are \(\varnothing 2\) clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line.

\section*{Interval Timer (Mode 0)}

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:
1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF).
2 When a write operation is performed to the Load Upper Latch and Transfer Latch to counter address (088), the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the \(\phi 2\) clock rate. The 16 -bit Counter can hold from 1 to 65535 counts The

Counter Timer capacity is therefore \(1 \mu \mathrm{~s}\) to 65.535 ms at the 1 \(\mathrm{MHz} \phi 2\) clock rate or \(0.5 \mu\) s to 32.768 ms at the \(2 \mathrm{MHz} \phi 2\) clock rate. Time intervals greater than the maximum Counter value can be easily measured by counting \(\overline{\mathrm{RQ}}\) interrupt requests in the counter \(\overline{\text { 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{\mathrm{IRQ}}\) interrupt routine to determine that the \(\overline{\mathrm{IRQ}}\) was generated by the Counter Overflow.

While the timer is operating in the Interval Timer Mode, the Counter Out/Event line is held in the high (output disabled) state.

A timing diagram of the Interval Timer Mode is shown in Figure 3-5.


Figure 3-5. Interval Timer (Mode 0) Timing Diagram

\section*{Pulse Generator Mode (Mode 1)}

In the Pulse Generator mode, the Counter Out/Event In line (CNTR) operates as a Counter Out. The CNTR line toggles from low to high or from high to low whenever a Counter Overflow occurs, or a write is performed to address 088.

Either a symmetric or asymmetric output waveform can be
output on the CNTR line in this mode. The CNTR output is initialized high by a \(\overline{\text { RES }}\) 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.

\section*{Event Counter Mode (Mode 2)}

In this mode the CNTR line is used as an Event Counter. The Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the \(\emptyset 2\) clock rate.

The Counter can count up to 65,535 occurrences before overflowing. As in the other modes, the Counter Overflow bit (CR7) is set to logic 1 if the overflow occurs.
Figure 3-6 is a timing diagram of the Event Counter Mode.

\section*{Pulse Width Measurement Mode (Mode 3)}

This mode allows the accurate measurement of a low pulse duration on the CNTR line. In this mode, CNTR is used in the Event In capacity. The Counter decrements by one
count at the \(\phi 2\) clock rate as long as the CNTR line is held in the low state. The Counter is stopped when CNTR is in the high state.

If the CNTR pin is left disconnected, this mode may be selected to stop the Counter since the internal pull-up device will cause the CNTR input to be in the high ( \(>2.0 \mathrm{~V}\) ) state.
A timing diagram for the Pulse Width Measurement Mode is shown in Figure 3-7.

\subsection*{3.15 INPUT/OUTPUT PORTS}

The R6500/1 provides four 8-bit Input/Output (I/O) ports (PA, PB, PC, PD). These 32 I/O lines are completely bidirectional. All lines may be used either for input or output in any combination; that is, there are no line grouping or port association restrictions.


Figure 3-6. Event Counter Mode (Mode 2)


Figure 3-7. Pulse Width Measurement (Mode 3)

The direction of the \(32 \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
\begin{tabular}{|c|c|}
\hline Port & Address \\
\hline A & 080 \\
B & 081 \\
C & 082 \\
D & 083 \\
\hline
\end{tabular}

Figure \(3-8\) shows the I/O Port Timings.

\subsection*{3.15.1 INPUTS}

Inputs are enabled by loading logic 1 into all I/O port register bit positions that are to correspond to I/O input lines. A low ( \(<08 \mathrm{~V}\) ) input signal will cause a logıc 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.

\subsection*{3.15.2 OUTPUTS}

Outputs are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( \(>2.4 \mathrm{~V}\) ) output while a logic 0 will force a low ( \(<0.4 \mathrm{~V}\) ) output.

\subsection*{3.15.3 EDGE DETECTION CAPABILITY}

Ports PAO and PA1 have an edge detection capability. Figure 3-9 shows the edge detection timing.

\section*{PAO Positive Edge Detecting Capability}

In addition to its normal I/O function, PAO will detect an asynchronous positive (rising) edge signal and set the PAO Positive Edge Detected signal (CR6) to logic 1. The maximum rate at which this positive edge can be detected is one-half the \(\varnothing 2\) clock rate.

If the PAO Interrupt Enable Bit (CR3) is set, an \(\overline{\mathrm{RQ}}\) interrupt request will also be generated. The PAO Positive Edge Detected signal can be cleared by writing to address 089.

\section*{I/O PORT OUTPUT TIMING}


\section*{I/O PORT INPUT TIMING}


Figure 3-8. I/O Port Timing


Figure 3-9. PA0 and PA1 Edge Detection Timing

\section*{PA1 Negative Edge Detecting Capability}

In addition to its normal I/O function, PA1 will detect an asynchronous negative (falling) edge signal and set the PA1 Negative Edge Detected signal (CR5) to logic 1. The maximum rate at which this negative edge can be detected is one-half the \(\varnothing 2\) clock rate.

If the PA1 Interrupt Enable signal (CR2) is set, an ITR̄ interrupt request will also be generated. The PA1 Negative Edge Detected signal may be cleared by writing to address 08A.

\subsection*{3.16 MASK OPTIONS}

An option is provided to delete the internal pull-up resistance from PA, PB, PC and/or PD ports at mask time. This optıon is available for 8 -bit port groups only, not for individual port lines. This option may by used to aid interface with CMOS drivers, or in order to interface with external pull-up devices.

An option is also provided to delete the internal pull-up resistance on the CNTR line.

\section*{SECTION 4 \\ IRQ INTERRUPT REQUEST GENERATION}

An \(\overline{\mathrm{RQ}}\) interrupt request can be initiated by any or all of three possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Control Register.

The first source of \(\overline{\mathrm{RQ}}\) is Counter Overflow. The \(\overline{\mathrm{IRQ}}\) interrupt request will be driven low whenever both the Counter Interrupt Enable (CR4) and the Counter Overflow (CR7) are logic 1.

The second source of \(\overline{\mathrm{RQ}}\) is detection of a positive edge on PAO. The \(\overline{\mathrm{RQ}}\) inerrupt request will be driven low whenever both the PAO Interrupt Enable (CR3) and the PAO Positive Edge Detected (CR6) are logic 1.

The third source of \(\overline{\mathrm{RQ}}\) is detection of a negative edge on PA1. The \(\overline{\mathbb{R Q}}\) 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{IR}}\) interrupt request to remain active until all interrupting conditions have been serviced and cleared.

\section*{CAUTION}

If the same data, i.e., the same RAM, counter/latch or I/O addresses, are operated on asynchronously by a normal processing routine and by an interrupt service routine, care must be taken to prevent loss of data due to the interrupt routine altering the data during update of the data by the normal processing routine. This situation can be prevented by disabling the \(\overline{\mathrm{IRQ}}\) interrupt with the SEI instruction before starting the data update in the normal processing and then enabling the interrupt with the CLI instruction upon completion of data update.

\section*{SECTION 5 \\ POWER ON/OFF CONSIDERATIONS}

\subsection*{5.1 POWER-ON RESET}

The occurrence of \(\overline{\mathrm{RES}}\) going from low to high will cause the R6500/1 to set the Interrupt Mask Bit - bit 2 of the Processor Status Register - and initiate a reset vector fetch at address FFE and FFF to begin user program execution. All of the I/O ports (PA, PB, PC, and PD) and CNTR will be forced to the high (logic 1) state. All bits of the Control Register will be cleared to logic 0 causing the Interval Timer counter mode (mode 00) to be selected and causing all interrupt enabled bits to be reset.

\subsection*{5.2 POWER ON/OFF TIMING}

After application of VCC power to the R6500/1, \(\overline{\text { RES }}\) must be held low for at least eight \(\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.

\subsection*{5.3 RAM DATA RETENTION — VRR REQUIREMENTS}

For the RAM to retain data upon loss of VCC, VRR must be supplied within operating range and \(\overline{\mathrm{RES}}\) must be driven
low at least eight \(\phi 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.

\subsection*{5.4 RAM DATA RETENTION OPERATION}

The requirement for R6500/1 RAM data retention and restart operation is application dependent. If R6500/1 RAM data retention is not required during loss of VCC, then VRR can be connected to the same power source as VCC. With this configuration a complete initialization of R6500/1 program variables in RAM is required upon VCC and VRR power application.

If the R6500/1 RAM is to retain data during loss of VCC, the following is required:
1. Connection of VCC and VRR to separate power supplies or to the same primary power supply with isolation diodes and battery or other backup power for VRR.
2. VCC power monitor hardware with power loss and cold/warm start indications to the R6500/1.
3 Power loss detection as well as cold and warm start initialization in the R6500/1 program.


Figure 5-1. Power Turn-On Timing Detail


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 NMI interrupt input in order to cause an immediate R6500/1 interrupt upon power loss detection.

The power monitor hardware should also provide an indication of cold start (initial VCC and VRR power application) or warm start (VCC power re-application while VRR is retained on backup power) provided as input on a data I/O pin.

A level indication is sufficient. The R6500/1 program can then initialize all, or partial, program variables upon initialization then jump to any other starting address as required
depending upon cold/warm start condition.

Upon power loss detection, the R6500/1 should save all required CPU register data in either the stack or dedicated RAM. The stack may be preferred if dedicated RAM is not available. If the program is to restart at the interrupted address, then all CPU registers must be saved, i.e., S, P, PC, A, X, and Y. The stack pointer must be saved in a dedicated RAM address. Note that processor status \(P\) and the program counter, PC, are already saved on the stack by the NMI interrupt R6500/1 hardware processing. If the warm start can be performed at a specific address, then the saving of the register data at power loss detection may not be required. Figure 5-3 shows top level flowcharts of typical power down and power-up processing.


Figure 5-3. Typical R6500/1 Power Loss Recovery Flowcharts

\title{
SECTION 6 TEST
}

\subsection*{6.1 TEST MODE}

The R6500/1 test function is multiplexed on the RES input pin. The three input states for this pin are:
\begin{tabular}{ll} 
1. \(<0.8 \mathrm{~V}\) & \begin{tabular}{l} 
Reset state. All R6500/1 outputs are \\
forced to the high state.
\end{tabular} \\
\(2 .>2.0 \mathrm{~V}\) and & \begin{tabular}{l} 
Normal run state. The low to high transı- \\
tion on the \(\overline{\mathrm{RES}}\) pin initiates fetch of the \\
reset vector from address FFC and FFD \\
and starts user program execution at the \\
vectored address.
\end{tabular} \\
3. \(>5.5 \mathrm{~V}\) \\
\(<10.0 \mathrm{~V}\) and & \begin{tabular}{l} 
Test state. The only internal action that \\
takes place is switching of the data \\
source for instruction memory from in- \\
ternal ROM to I/O port "C". Bit 0 of port \\
"C" is the data least significant bit (LSB).
\end{tabular}
\end{tabular}

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{\operatorname{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.

\subsection*{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 short 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 \(\mathrm{I} / \mathrm{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:
\begin{tabular}{ll} 
PA0 & \begin{tabular}{l} 
Data Ready (DR) - Positive edge indi- \\
cates data is ready for sampling by the \\
R6500/1.
\end{tabular} \\
PA1 & \begin{tabular}{l} 
End of Data (EOD \()\) - Negative edge \\
indicates that all the data has been \\
transferred to the R6500/1.
\end{tabular} \\
PA2 & \begin{tabular}{l} 
Data Taken (DT) - \\
\(0=\) Data Not Taken
\end{tabular} \\
PA7 & \begin{tabular}{l}
\(1=\) Data Taken
\end{tabular} \\
& \begin{tabular}{l} 
Normal Mode Select (NMS) - \\
\(0=\) Test Mode
\end{tabular} \\
PB7-PB0 & \begin{tabular}{l}
\(1=\) Normal Mode \\
\\
\end{tabular}\(\quad\)\begin{tabular}{l} 
Data input, i.e., instruction or data (PB7 \\
\(=\) MSB, PB0 \(=\) LSB)
\end{tabular}
\end{tabular}

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 indıcate 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{E O D}\) ). 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-1. RAM Program Loader Flowchart


Figure 6-2. R6500/1 RAM Program Load Handshake

Table 6-1. RAM Program Loader Assembly Listing
R6500/1 RAM LOADER ..... PAGE 001
\begin{tabular}{|c|c|c|c|c|c|}
\hline LINE \# & LOC & CODE & \multicolumn{2}{|c|}{LINE} & \\
\hline 0002 & 0000 & & PORTB = & & ;Port B Address \\
\hline 0003 & 0000 & & PORTA \(=\) & & ;Port A Address \\
\hline 0004 & 0000 & & CLRPAO \(=\) & & ;CLR PAO Edge Detect \\
\hline 0005 & 0000 & & CTLREG \(=\) & & ;Control Register \\
\hline 0006 & 0000 & & BEGIN \(=\$ 0\) & & ;RAM First Address \\
\hline 0008 & 0000 & & & * \(=\$ 0800\) & \\
\hline 0009 & 0800 & A2 3F & Reset & LDX \#\$3F & \\
\hline 0010 & 0802 & 9A & & TXS & ;Initialize Stack Pointer \\
\hline 0011 & 0803 & D8 & & CLD & ;Set Binary Add Mode \\
\hline 0012 & 0804 & A2 00 & & LDX \#\$00 & ;Initialize RAM Index \\
\hline 0013 & 0806 & A5 80 & & LDA PORTA & \\
\hline 0014 & 0808 & 302 D & & BMI INIT & ;Test Mode Selected (PA7 = 0)? \\
\hline 0016 & 080A & A5 80 & PAZCK & LDA PORTA & ;Yes \\
\hline 0017 & 080C & 4A & & LSR A & \\
\hline 0018 & 080D & B0 1C & & BCS EODCK1 & ;Data Ready High (PA0 = 1)? \\
\hline 0020 & 080F & A9 FB & & LDA \#\$FB & ;No, Reset Data Taken \\
\hline 0021 & 0811 & B5 80 & & STA PORTA & ;0->PA2 \\
\hline 0023 & 0813 & A9 20 & RDYCK & LDA \#\$20 & \\
\hline 0024 & 0815 & 248 F & & BIT CTLREG & \\
\hline 0025 & 0817 & 501 A & & BVC EODCK2 & ;Data Ready (PA0 Pos Edge Detected)? \\
\hline 0027 & 0819 & 8589 & & STA CLRPAO & ;Yes, Clear PaO Pos Edge Detected \\
\hline 0028 & 081B & A5 81 & & LDA PORTB & ;Load Data From Port B \\
\hline 0029 & 0081D & 9500 & & STA BEGIN,X & ;Store in RAM \\
\hline 0030 & 081F & A9 FF & & LDA \#\$FF & \\
\hline 0031 & 0821 & 8580 & & STA PORTA & ;Set Data Taken (1->PA2) \\
\hline 0032 & 0823 & E8 & & INX & ;Increment RAM Index \\
\hline 0033 & 0824 & EO 40 & & CPX \#\$40 & \\
\hline 0034 & 0826 & D0 E2 & & BNE PAZCK & ;Is RAM Full? \\
\hline 0036 & 0828 & 4C 0000 & JMPBEG & JMP BEGIN & ;Yes, Go To RAM Program Execution \\
\hline 0038 & 082B & A9 20 & EODCK1 & LDA \#\$20 & \\
\hline 0039 & 082D & 258 F & & AND CTLREG & \\
\hline 0040 & 082F & F0 D9 & & BEQ PAZCK & ;End of Data (PA1 Neg Edge Detected)? \\
\hline 0041 & 0831 & D0 F5 & & BNE JMPBEG & ;Yes, Go To RAM Program Execution \\
\hline 0043 & 0833 & FO DE & EODCK2 & BEQ RDYCK & ;End of Data (PA1 Neg Edge Detected)? \\
\hline 0044 & 0835 & D0 F1 & & BNE JMPBEG & ;Yes, Go To Ram Program Execution \\
\hline 0046 & 0837 & & INIT & & ;First Address of Normal Program \\
\hline 0048 & 0837 & & & * \(=\) FFFC & \\
\hline 0049 & OFFC & 0008 & RES & WOR RESET & ;Reset Vector \\
\hline 0050 & OFFE & & & .END & \\
\hline
\end{tabular}

\footnotetext{
Errors \(=0000<0000>\)
}

End of Assembly

\section*{APPENDIX A — SYSTEM MEMORY MAP}


\section*{Notes:}
(1) I/O command only; ı.e, no stored data.
(2) Clears Counter Overflow - Bit 7 in Control Register.

\section*{APPENDIX B — R6500 INSTRUCTION SET}

This appendix contains a summary of the R6500 instruction set. For detailed information, consult the R6500 Microcomputer System Programming Manual, Document Order No. 202.

\section*{B. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE}

Add Memory to Accumulator with Carry
"AND" Memory with Accumulator
Shift Left One Bit (Memory or Accumulator)
Branch on Carry Clear
Branch On Carry Set
Branch on Result Zero
Test Bits in Memory with Accumulator
Branch on Result Minus
Branch on Result not Zero
Branch on Result Plus
Force Break
Branch on Overflow Clear
Branch on Overflow Set
Clear Carry Flag
Clear Decimal Mode
Clear Interrupt Disable Bit
Clear Overflow Flag
Compare Memory and Accumulator
SBC
SEC
SED
SEI
STA
STX
STY
TAX
TAY
TSX
TXA
TXS
TYA

Load Accumulator with Memory
Load Index X with Memory
Load Index Y with Memory
Shift One Bit Right (Memory or Accumulator)
No Operation
"OR" Memory with Accumulator
Push Accumulator on Stack
Push Processor Status on Stack
Pull Accumulator from Stack
Pull Processor Status from Stack
Rotate One Bit Left (Memory or Accumulator)
Rotate One Bit Right (Memory or Accumulator)
Return from Interrupt
Return from Subroutine
Subtract Memory from Accumulator with Borrow
Set Carry Flag
Set Decimal Mode
Set Interrupt Disable Status
Store Accumulator in Memory
Store Index \(X\) in Memory
Store Index \(Y\) in Memory
Transfer Accumulator to Index \(\mathbf{X}\)
Transfer Accumulator to Index \(Y\)
Transfer Stack Pointer to Index X
Transfer Index \(X\) to Accumulator
Transfer Index X to Stack Register
Transfer Index \(Y\) to Accumulator

\section*{B2. INSTRUCTION SET SUMMARY TABLE}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{2}{|r|}{instructions} & \multicolumn{3}{|l|}{Immediate} & \multicolumn{3}{|l|}{ABSOLIITE} & \multicolumn{3}{|l|}{zEROPAGE} & \multicolumn{2}{|r|}{ACCUM} & \multicolumn{3}{|c|}{Implied} & \multicolumn{3}{|l|}{} & \multicolumn{2}{|l|}{(INO), Y} & \multicolumn{3}{|r|}{2 Page, x} & \multicolumn{3}{|l|}{} & \multicolumn{2}{|r|}{ABS, Y} & \multicolumn{3}{|r|}{relative} & \multicolumn{2}{|l|}{INDIRECT} & \multicolumn{3}{|r|}{2 Page, r} & \multicolumn{2}{|l|}{PROCESSOR STATUS
CODES} \\
\hline MNEMONIC & operation & OP & \(\bigcirc\) & * & OP & \(n\) & * & OP & \(n\) & " & OP & n & " OP & \(n\) & " & OP & \(n\) & \(\cdots\) & OP \({ }^{\text {n }}\) & n " & OP & DP \(n\) & " & OP & n & * & OP & \(n\) & OP & n & * 0 & OP & \(n\) & OP & \(n\) & \(\because \frac{7}{N}\) & \begin{tabular}{|l|llllllll|}
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline\(N\) & \(V\) & 0 & \(B\) & \(D\) & 1 & \(Z\) & \(C\) \\
\hline\(N\) & \(V\) & & & & & & &
\end{tabular} & MNEMONIC \\
\hline \begin{tabular}{l}
ADC \\
AND \\
ASL \\
BCC \\
BCS
\end{tabular} & \[
\begin{array}{ll}
A+M+C \cdot A \\
A \wedge M-A & \text { (4) (1) } \\
C-Z-0 & \\
\text { BRANCH ON } C=0 & (2) \\
\text { BRANCH ON } C=1 & \text { (2) }
\end{array}
\] & 69 & \[
\begin{aligned}
& 2 \\
& 2
\end{aligned}
\] & & \begin{tabular}{l|l|}
60 \\
20 \\
OE
\end{tabular} & 4
4
6 & \[
3
\] & 65 & \begin{tabular}{l|}
3 \\
3 \\
5
\end{tabular} & 2
2
2 & OA & 2 & 1 & & & & 6 & & \[
\begin{array}{l|l}
\hline 71 & 5 \\
39 & 5
\end{array}
\] & & \begin{tabular}{l|l}
2 & 75 \\
2 & 35 \\
& 16
\end{tabular} &  & 2
2
2 & 70 & 4
4
7 & 3
3
3 & \[
\begin{aligned}
& 79 \\
& 39
\end{aligned}
\] & & \(3{ }^{3} 80\) & 2 & \[
\begin{aligned}
& 2 \\
& 2
\end{aligned}
\] & & & & & &  & \begin{tabular}{l}
ADC \\
AND \\
ASL \\
BCC \\
BCS
\end{tabular} \\
\hline \[
\begin{aligned}
& \hline B E O \\
& B I T \\
& B M \\
& B N E \\
& B P L
\end{aligned}
\] & \begin{tabular}{l}
BRANCHONZ \(=1\) (2) \\
AAM \\
BRANCHONN = 1 (2) \\
BRANCHONZ \(=0 \quad\) (2) \\
BRANCHONN \(=0\) (2)
\end{tabular} & & & & 2 C & 4 & 3 & 24 & 3 & 2 & & & & & & & & & & & & & & & & & & & F0 & 2
2
2
2
2 & \[
2
\]
\[
2
\]
\[
2
\]
\[
2
\] & & & & & &  & \[
\begin{aligned}
& \text { BEO } \\
& B E T \\
& B M I \\
& B N E \\
& B P L
\end{aligned}
\] \\
\hline \[
\begin{align*}
& \hline B R K \\
& B \vee C  \tag{2}\\
& B \vee S  \tag{2}\\
& C L C \\
& C L D \\
& \hline
\end{align*}
\] & \[
\begin{aligned}
& \text { BREAK } \\
& \text { BRANCH ONV }=0 \\
& \text { BRANCH ONV }=1 \\
& O \rightarrow C \\
& O \rightarrow D
\end{aligned}
\] & & & & & & & & & & & & \[
\begin{aligned}
& 00 \\
& 18 \\
& 08
\end{aligned}
\] & \[
\begin{array}{|c|}
7 \\
2 \\
2 \\
2
\end{array}
\] & 1
1
1 & & & & & & & & & & & & & & 50
70 & 2 & 2 & & & & & & \[
\left[\begin{array}{llllllll}
\cdot & \cdot & \cdot & 1 & \cdot & 1 & \cdot & \cdot \\
\cdot & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot \\
\cdot & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot \\
\cdot & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot & 0 \\
\cdot & \cdot & \cdot & \cdot & 0 & \cdot & \cdot & \cdot \\
\hline
\end{array}\right.
\] & \[
\begin{aligned}
& B R K \\
& B \vee C \\
& B \vee S \\
& C L C \\
& C \vee D
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& C L I \\
& C L V \\
& C M P \\
& C P X \\
& \text { CPY } \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& O-1 \\
& O \rightarrow V \\
& A-M \\
& X-M \\
& Y-M
\end{aligned}
\] & \begin{tabular}{l} 
C9 \\
E0 \\
CO \\
\hline
\end{tabular} & 2
2
2 & 2 & \begin{tabular}{l|}
CD \\
EC \\
CC \\
\hline
\end{tabular} & 4 & \[
\begin{aligned}
& 3 \\
& 3 \\
& 3 \\
& \hline
\end{aligned}
\] & C5 & \[
\begin{aligned}
& 3 \\
& 3 \\
& 3
\end{aligned}
\] & 2 & & & 58
88 & \[
\left.\begin{aligned}
& 2 \\
& 2
\end{aligned} \right\rvert\,
\] & \[
\begin{aligned}
& 1 \\
& 1
\end{aligned}
\] & C1 & 6 & 2 D & D1 5 & 52 & 2 D5 & D5 4 & 2 & OO & 4 & 3 & 09 & 4 & 3 & & & & & & & &  & \[
\begin{aligned}
& C L I \\
& C L V \\
& C M P \\
& C P X \\
& C P Y \\
& \hline
\end{aligned}
\] \\
\hline \begin{tabular}{l}
DEC \\
DEX \\
DEY \\
EOR \\
INC
\end{tabular} & \[
\begin{align*}
& M-1 \rightarrow M \\
& X-1 \rightarrow X \\
& Y-1 \bullet Y \\
& A \forall M \bullet A  \tag{1}\\
& M+1 \not M
\end{align*}
\] & 49 & 2 & 2 & \[
\begin{array}{|c|}
\hline \mathrm{CEE} \\
\hline \\
\hline \mathrm{ED} \\
\hline
\end{array}
\] & \[
6
\] & \[
\begin{aligned}
& 3 \\
& 3 \\
& 3
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \mathrm{C} 6 \\
\\
\hline 45 \\
\hline
\end{array}
\] & 3
5 & 2 & & & CA & 2
2 & 1 & 41 & 6 & 25 & 51 & 52 & \[
2 \begin{aligned}
& \hline 06 \\
& 55 \\
& F 6
\end{aligned}
\] & \[
\begin{array}{c|c|}
\hline 66 & 6 \\
55 & 4 \\
56 & 6 \\
\hline
\end{array}
\] & 2
2
2 & \[
\begin{array}{|c|}
\hline \mathrm{OE} \\
\hline 50 \\
\hline F E \\
\hline
\end{array}
\] & 7
4
7 & 3
3
3 & 59 & 4 & 3 & & & & & & & & \begin{tabular}{lllllllll|}
\(N\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(z\) & \(\cdot\) \\
\(N\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(z\) & \(\cdot\) \\
\(N\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(z\) & \(\cdot\) \\
\(N\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(z\) & \(\cdot\) \\
\(N\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(\cdot\) & \(z\) & \(\cdot\)
\end{tabular} & \begin{tabular}{l}
DEC \\
DEX \\
DEY \\
EOR \\
INC
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { INX } \\
& \text { INY } \\
& \text { JMP } \\
& \text { JSR } \\
& \text { LDA } \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
\[
\begin{aligned}
& x+1 \rightarrow x \\
& y+1 \rightarrow y
\end{aligned}
\] \\
JUMP TO NEW LOC JUMP SUB
\[
M \cdots A
\]
\end{tabular} & A9 & 2 & 2 & \begin{tabular}{|l|}
\(4 C\) \\
20 \\
\(A D\) \\
\hline
\end{tabular} & \[
\begin{aligned}
& 3 \\
& 6 \\
& 4
\end{aligned}
\] & \[
\begin{aligned}
& 3 \\
& 3 \\
& 3 \\
& \hline
\end{aligned}
\] & A5 & 3 & 2 & & & E8 & 2 & \[
\begin{aligned}
& 1 \\
& 1
\end{aligned}
\] & A1 & 6 & 2 B & B) 5 & 5.2 & 85 & 85.4 & 2 & BD & 4 & 3 & B9 & 43 & 3 & & & 6C & 5 & 3 & & & \(\begin{array}{cccccccc}\text { N } & \cdot & \cdot & \cdot & \cdot & z & \cdot \\ \text { N } & \cdot & \cdot & \cdot & \cdot & \cdot & z & \cdot \\ \cdot & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot \\ \text { P } & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot \\ \text { N } & \cdot & \cdot & \cdot & \cdot & \cdot & z & \cdot\end{array}\) & \[
\begin{aligned}
& \text { INX } \\
& \text { INY } \\
& \text { JMP } \\
& \text { JSR } \\
& \text { LDA }
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { LDX } \\
& \text { LDY } \\
& \text { LSR } \\
& \text { NOP } \\
& \text { ORA } \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
\[
\begin{aligned}
& M \rightarrow X \\
& M \cdot Y \\
& 0 \rightarrow-[-\sigma-C
\end{aligned}
\] \\
NO OPERATION \\
\(A \vee M \rightarrow A\)
\end{tabular} & \[
\begin{gathered}
\mathrm{A}^{\mathrm{A}} \\
\mathrm{AO} \\
09 \\
\hline
\end{gathered}
\] & 2
2
2 & 2
2
2 & \[
\begin{aligned}
& \mathrm{AE} \\
& \mathrm{AC} \\
& \mathrm{AE} \\
& \\
& O D
\end{aligned}
\] & \[
\begin{aligned}
& 4 \\
& 4 \\
& 6 \\
& 4
\end{aligned}
\] & \[
\begin{aligned}
& 3 \\
& 3 \\
& 3 \\
& 3
\end{aligned}
\] & \[
\begin{aligned}
& A 6 \\
& A 4 \\
& A 6 \\
& \\
& 05
\end{aligned}
\] & \[
\begin{aligned}
& 3 \\
& 3 \\
& 5 \\
& 3
\end{aligned}
\] & \[
\begin{aligned}
& 2 \\
& 2 \\
& 2 \\
& \hline
\end{aligned}
\] & 4A & 2 & \(1{ }^{1}\) EA & 2 & 1 & 01 & 6 & 2 & \({ }^{1} 1\) & 52 &  & \[
\begin{array}{c|c}
B 4 & 4 \\
56 & 6 \\
15 & 4 \\
\hline
\end{array}
\] & 2
2
2 & \[
\begin{gathered}
B C \\
5 E \\
10
\end{gathered}
\] & 4
7
4 & 3
3
3 & \[
\begin{gathered}
\mathrm{BE}^{\mathrm{BE}} \\
19 \\
\hline
\end{gathered}
\] & 4 & & & & & & 86 & 4 & 2 & \[
\begin{array}{|cccccccc}
N & \cdots & \cdot & \cdot & \cdot & \cdot & z & \cdot \\
N & \cdot & \cdot & \cdot & \cdot & \cdot & z & \cdot \\
O_{l} & \cdot & \cdot & \cdot & \cdot & z & C \\
\cdots & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot & \cdot \\
N & \cdot & \cdot & \cdot & \cdot & \cdot & z & \cdot \\
\hline
\end{array}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { LDY } \\
& \text { LSA } \\
& \text { NOP } \\
& \text { ORA }
\end{aligned}
\] \\
\hline \begin{tabular}{l}
PHA \\
PHP \\
PLA \\
PLP \\
ROL
\end{tabular} & \[
\begin{array}{lr}
\hline A \rightarrow M S & S-1 \rightarrow S \\
P \rightarrow M s & S-1 \rightarrow S \\
S+1 \rightarrow S & M s \rightarrow A \\
S+1 \rightarrow S & M s \rightarrow P \\
H & -C= \\
\hline
\end{array}
\] & & & & 2 E & 6 & 3 & 26 & 5 & 2 & 2 A & 2 & 48
08
68
28 & \[
\begin{array}{|l|}
\hline 3 \\
3 \\
4 \\
4
\end{array}
\] & 1
1
1
1 & & & & & & & 36.6 & 2 & 3 E & 7 & 3 & & & & & & & & & & &  & \[
\begin{aligned}
& \text { PHA } \\
& \text { PHP } \\
& \text { PLA } \\
& \text { PLP } \\
& \text { ROL }
\end{aligned}
\] \\
\hline \[
\begin{align*}
& \text { ROR } \\
& \text { R T I } \\
& \text { RT S } \\
& \text { S B C }  \tag{1}\\
& \text { SEE C } \\
& \text { SEE }
\end{align*}
\] & \begin{tabular}{l}
\(\square\) \(\square\) 0 \\
RTRNINT \\
RTRN SUB
\[
\begin{aligned}
& A-M-\bar{C} \cdot A \\
& 1 \rightarrow C \\
& 1 \rightarrow D
\end{aligned}
\]
\end{tabular} & E9 & 2 & 2 & ED \({ }_{\text {EE }}\) & 4 & 3 & \[
\begin{gathered}
66 \\
\text { E5 }
\end{gathered}
\] & \begin{tabular}{l}
5 \\
3
\end{tabular} & \[
2
\] & \(6^{6 A}\) & 2 & \begin{tabular}{|c}
1 \\
40 \\
60 \\
\\
38 \\
\\
\hline 88
\end{tabular} & \[
\begin{aligned}
& 6 \\
& 6 \\
& 2 \\
& 2
\end{aligned}
\] & 1
1
1
1 & E1 & 6 & 2 & \(F 1\) & 52 & \[
\begin{array}{l|l} 
& 76 \\
2 & F 5
\end{array}
\] & \[
\begin{array}{c|c|}
\hline 76 & 6 \\
\text { F5 } & 4
\end{array}
\] & 2 & \[
\begin{aligned}
& \text { TE } \\
& F D
\end{aligned}
\] & 7 & 3
3 & F9 & 4 & 3 & & & & & & & &  & \begin{tabular}{l}
ROR \\
R T 1 \\
RTS \\
SBC \\
SEC \\
SED
\end{tabular} \\
\hline \[
\begin{aligned}
& \hline S E I \\
& S T A \\
& S T X \\
& S T Y \\
& T A X \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 1 \rightarrow 1 \\
& A \rightarrow M \\
& X \rightarrow M \\
& Y \rightarrow M \\
& A \rightarrow X \\
& \hline
\end{aligned}
\] & & & & 8 D
8 E
8 C & 4
4
4 & 3
3
3 & 85
86
84 & 3
3
3 & 2
2
2 & & & \begin{tabular}{l}
78 \\
AA
\end{tabular} & \({ }_{2}^{2}\) & 1
1 & 81 & 6 & 29 & 916 & 62 & \[
\begin{array}{l|l}
2 & 95 \\
& 94
\end{array}
\] & \[
\begin{array}{l|l}
95 & 4 \\
94 & 4
\end{array}
\] & 2 & 90 & 5 & 3 & 99 & 5 & 3 & & & & & 96 & 4 & 2 &  & \begin{tabular}{llll}
\hline\(S\) & \(E\) & \(I\) \\
\(S\) & \(T\) & \(A\) \\
\(S\) & \(T\) & \(X\) \\
\(S\) & \(T\) & \(Y\) \\
\(T\) & \(A\) & \(X\) \\
\hline
\end{tabular} \\
\hline \[
\begin{aligned}
& \hline T A Y \\
& T S Y \\
& T \times A \\
& T \times S \\
& T Y A \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& A \rightarrow Y \\
& S \rightarrow X \\
& X \rightarrow A \\
& X \rightarrow S \\
& Y \cdot A \\
& \hline
\end{aligned}
\] & & & & & & & & & & & & AB & \begin{tabular}{l}
2 \\
2 \\
2 \\
2 \\
2 \\
\hline
\end{tabular} & \begin{tabular}{l}
1 \\
1 \\
1 \\
1 \\
1 \\
\hline
\end{tabular} & & & & & & & & & & & & & & & & & & & & & & \(\left.\begin{array}{ccccccc}N & \cdot & \cdot & \cdot & \cdot & z & \cdot \\ N & \cdot & \cdot & \cdot & \cdot & \cdot & z\end{array}\right) \cdot\) & TA Y Y
TS
TXA
TX S
TY
T \\
\hline \multicolumn{19}{|c|}{\begin{tabular}{l}
1) ADD 1 to N IF PAGE BOUNDARY IS CROSSED \\
(2) ADD 1 TO N IF BRANCH OCCURS TO SAME PAGE \\
ADD 2 TO \(N\) IF BRANCH OCCURS TO DIFFERENT PAGE \\
(3) CARRY NOT = BORROW \\
(4) IFINDECIMAL MODF ZFLAGISINVALID ACCUMULATOR MUUST BECHECKED FURZERO RESULT
\end{tabular}} & & A
\(M\)
\(M S\) &  & \begin{tabular}{l}
INDE \\
INDE \\
ACC \\
MEM \\
MEM
\end{tabular} & ORY &  & & & & & \begin{tabular}{l}
DDRES \\
R
\end{tabular} & & &  &  & DD UBTRA ND R xCLUS & & & \begin{tabular}{l}
\(M_{7}\) MEMORY \\
\(M_{0}\) MEMORY \\
\(n \quad\) NO CYCLE \\
\# NO BYTES
\end{tabular} & cit \({ }^{\text {c }}\) \\
\hline
\end{tabular}

\section*{APPENDIX C — SYSTEM SPECIFICATIONS}

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{RR}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
0 to +70 \\
-40 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{R R}=V_{C C} ; V_{S S}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=0^{\circ}\right.\) to \(70^{\circ} \mathrm{C}\), unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline RAM Standby Voltage (Retention Mode) & \(\mathrm{V}_{\text {RR }}\) & 3.0 & & \(\mathrm{V}_{\mathrm{CC}}\) & V & \\
\hline RAM Standby Current (Retention Mode) Commercial Industrial & \(I_{\text {RR }}\) & - & \[
\begin{aligned}
& 10 \\
& 12
\end{aligned}
\] & - & mA & \\
\hline \begin{tabular}{l}
Input High Voltage \\
All Except XTLI XTLI
\end{tabular} & \(\mathrm{V}_{\mathrm{IH}}\) & \[
\begin{aligned}
& +2.0 \\
& +4.0
\end{aligned}
\] & - & \begin{tabular}{l}
\(\mathrm{V}_{\mathrm{CC}}\) \\
\(V_{C C}\)
\end{tabular} & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\text {IL }}\) & -0.3 & - & +0.8 & V & \\
\hline Input Leakage Current \(\overline{R E S}, \overline{\text { NMI }}\) & \(\mathrm{I}_{\mathrm{IN}}\) & - & \(\pm 1.0\) & \(\pm 2.5\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IN}}=0\) to 5.0 V \\
\hline Input Low Current &  & - & -1.0 & -1.6 & mA & \(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & - & V & \[
\begin{aligned}
& \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \\
& \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline Output Hıgh Voltage (CMOS) & \(\mathrm{V}_{\text {CMOS }}\) & \(V_{C C}=30 \%\) & - & - & V & \(\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}\) \\
\hline Output Low Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & +0.4 & V & \(\mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}\) \\
\hline I/O Port Pull-Up Resistance PA0-PA7, PB0-PB7, PC0-PC7,
PD0-PD7, CNTR & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Output High Current (Sourcing) & IOH & -100 & - & - & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\text {OUT }}=2.4 \mathrm{~V}\) \\
\hline Output Low Current (Sınking) & \(\mathrm{IOL}^{\text {l }}\) & 1.6 & - & - & mA & \(\mathrm{V}_{\text {OUT }}=0.4 \mathrm{~V}\) \\
\hline \begin{tabular}{l}
Input Capacitance \\
XTLI, XTLO \\
PA, PB, PC, PD, CNTR
\end{tabular} & \(\mathrm{C}_{\text {IN }}\) & - & - & \[
\begin{aligned}
& 50 \\
& 10
\end{aligned}
\] & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) & \(\mathrm{C}_{\text {OUT }}\) & - & - & 10 & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Outputs High) & \(P_{D}\) & - & 750 & 1100 & mW & \(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{C C}=5.0 \mathrm{~V}\). \\
2. Negative sign indicates outward current flow, positive indicates inward flow.
\end{tabular}} \\
\hline
\end{tabular}

\section*{AC CHARACTERISTICS}
\(\left(V_{C C}=5 \mathrm{~V} \pm 10 \%\right.\) for R6500/1, \(\mathrm{V}_{\mathrm{CC}}=5 \mathrm{~V} \pm \%\) for \(\mathrm{R} 6500 / 1 \mathrm{~A}\) )
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min & Max & Min & Max & \\
\hline XTLI Input Clock Cycle Time & \(\mathrm{T}_{\text {cyc }}\) & 0.500 & 5.0 & 0.250 & 5.0 & \(\mu \mathrm{sec}\) \\
\hline Internal Write to Peripheral Data Valid (TTL) & \(\mathrm{T}_{\text {PDW }}\) & 1.0 & & 0.5 & & \(\mu \mathrm{sec}\) \\
\hline Internal Write to Peripheral Data Valid (CMOS) & T cmos & 2.0 & & 1.0 & & \(\mu \mathrm{sec}\) \\
\hline Peripheral Data Setup Time & \(\mathrm{T}_{\text {PDSU }}\) & 400 & & 200 & & nsec \\
\hline Count and Edge Detect Pulse Width & \(\mathrm{T}_{\text {PW }}\) & 1.0 & & 0.5 & & \(\mu \mathrm{sec}\) \\
\hline
\end{tabular}

\section*{APPENDIX D - R6500/1E EMULATOR PART}

\section*{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.

\section*{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
\begin{tabular}{|c|c|c|}
\hline Signal Name & \begin{tabular}{l}
Pin \\
No.
\end{tabular} & Description \\
\hline \(\overline{\mathrm{R} / \mathrm{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. \\
\hline 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. \\
\hline SYNC & 6 & The Sync signal is provided to identify cycles in which the CPU is performing OP CODE fetch. SYNC goes high during the \(\varnothing 2\) clock low pulse of an OP CODE fetch and stays high for the remainder of that cycle. If the RDY line is pulled low during the \(\emptyset 2\) clock low pulse in which SYNC went high, the CPU will halt in its current state and will remain in that state until the RDY line goes high. Using this technique, the SYNC signal can be used to control RDY to cause single instruction execution. \\
\hline \(\phi 2\) & 1 & Phase 2 ( \(\varnothing 2\) ) clock pulse. Data transfer takes place only during \(\varnothing 2\) clock pulse high. \\
\hline A0-A11 & 25-37 & Address Bus lines. The address bus buffers on the R6500/1E are push/pull type drivers capable of 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. \\
\hline D0-D7 & 53-46 & Data Bus lines. All transfers of instructons 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 \\
\hline
\end{tabular}

\section*{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.

\section*{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.

\section*{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.

\section*{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

\section*{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.

\section*{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 Ø2 clock oscillator has stabilized.


\section*{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 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.

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
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{2}{|c|}{Address} & \multicolumn{3}{|c|}{PROM Select} & \multirow[b]{2}{*}{Selected Address Range} \\
\hline 411 & A10 & \[
\begin{gathered}
2708 \text { No. } 1 \\
\text { CE }
\end{gathered}
\] & \[
2708 \text { No. } 2
\] & \[
\begin{gathered}
2808 \text { No. } 3 \\
\mathrm{CE}
\end{gathered}
\] & \\
\hline 0 & 0 & 1 & 1 & 1 & 000-3FF \\
\hline 0 & 1 & 0 & 1 & 1 & 400-7FF \\
\hline 1 & 0 & 1 & 0 & 1 & 800-BFF \\
\hline 1 & 1 & 1 & 1 & 0 & C00-FFF \\
\hline
\end{tabular}

\section*{D. 6 R6500/1E TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min. & Max. & Min. & Max. & \\
\hline \(\mathrm{R} \overline{\mathrm{W}}\) setup time from CPU & \(\mathrm{T}_{\text {Rws }}\) & & 300 & & 200 & ns \\
\hline Address setup time from CPU & \(\mathrm{T}_{\text {ADS }}\) & & 300 & & 200 & ns \\
\hline Memory read access time & \(\mathrm{T}_{\text {Acc }}\) & & 525 & & 225 & ns \\
\hline Data stabilization time & \(\mathrm{T}_{\text {DSU }}\) & 150 & & 75 & & ns \\
\hline Data hold time - Read & \(\mathrm{T}_{\text {HR }}\) & 10 & & 10 & & ns \\
\hline Data hold time - Write & \(\mathrm{T}_{\mathrm{HW}}\) & 30 & & 30 & & ns \\
\hline Data delay time from CPU & \(\mathrm{T}_{\text {MDS }}\) & & 200 & & 150 & ns \\
\hline RDY setup time & \(\mathrm{T}_{\text {RDY }}\) & 100 & & 50 & & ns \\
\hline SYNC delay time from CPU & \(\mathrm{T}_{\text {SYNC }}\) & & 350 & & 175 & ns \\
\hline Address hold time & \(\mathrm{T}_{\mathrm{HA}}\) & 30 & & 30 & & ns \\
\hline \(\mathrm{R} \bar{W}\) hold time & \(\mathrm{T}_{\text {HRW }}\) & 30 & & 30 & & ns \\
\hline Cycle Time & \(\mathrm{T}_{\mathrm{crc}}\) & 1.0 & 10.0 & 0.5 & 10.0 & \(\mu \mathrm{s}\) \\
\hline
\end{tabular}

PHASE 2 ( \(\phi 2\) ) TIMING REFERENCE


\section*{D. 7 R6500/1E DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=0^{\circ}\right.\) to \(70^{\circ} \mathrm{C}\), unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline Input High Voltage D0-D7, RDY & \(\mathrm{V}_{\mathrm{IH}}\) & \(\mathrm{V}_{\text {ss }}+2.4\) & - & - & V & \\
\hline Input Low Voltage D0-D7, RDY & \(\mathrm{V}_{\text {IL }}\) & - & - & \(\mathrm{V}_{\mathrm{ss}}+0.8\) & V & \\
\hline Input Leakage Current (Three-State Off)
D0-D7 & \(\mathrm{I}_{\mathrm{N}}\) & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IN}}=0 \text { to } 5.0 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Output High Voltage DO-D7, SYNC, AO-A11, R \(\bar{W}, \emptyset 2\) & \(\mathrm{V}_{\mathrm{OH}}\) & \(\mathrm{V}_{\text {ss }}+2.4\) & - & - & V & \[
\begin{aligned}
& \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A} \\
& \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline Output Low Voltage DO-D7, SYNC, A0-A11, R \(\bar{W}, \emptyset 2\) & \(\mathrm{V}_{\text {OL }}\) & - & - & \(\mathrm{V}_{\mathrm{ss}}+0.6\) & V & \[
\begin{aligned}
& \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA} \\
& \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline I/O Port Pull-Up Resistance & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Input Capacitance RDY D0-D7 & \(\mathrm{C}_{\mathrm{IN}}\) & - & - & \[
\begin{aligned}
& 10 \\
& 15
\end{aligned}
\] & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance A0-A11, R \(\bar{W}\), SYNC \(\emptyset 2\) & \(\mathrm{C}_{\text {OUT }}\) & - & \[
\overline{50}
\] & \[
\begin{aligned}
& 12 \\
& 80
\end{aligned}
\] & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Outputs High) & \(\mathrm{P}_{\mathrm{D}}\) & - & 750 & 1200 & mW & \(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{C C}=5.0 \mathrm{~V}\). \\
2. Negative sign indicates outward current flow, positive indicates inward flow.
\end{tabular}} \\
\hline
\end{tabular}

\section*{R6500/1E MICROPROCESSOR EMULATOR DEVICE}

\section*{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-pın DIP ceramic (R6500/1EC) and 64-pin QUIP Plastic (R6500/1EQ).

ORDERING INFORMATION
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{1}{|c|}{\begin{tabular}{c} 
Part \\
Number
\end{tabular}} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \begin{tabular}{c} 
Frequency \\
Option
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range
\end{tabular} \\
\hline R6500/1EC & Ceramıc & 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 & Plastıc & 1 MHz & \(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
R6500/1EAQ & Plastıc & 2 MHz & \(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}



Pin Configuration

\section*{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.

\section*{MEMORY MAP}

An additional 1024 bytes of memory (400-7FF) are addressable in the device.

\section*{EXTERNAL FREQUENCY REFERENCE}

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

\section*{I/O PORT PULLUPS}

The device has internal I/O port pullup resistance only.

\section*{DEVICE ADDITIONAL SIGNALS}

\section*{Signal Pin}
Name No.
Signal Pin

Name \(\Phi 2\) No.

Phase 2 ( \(\Phi 2\) ) clock pulse. Data transfer can take place only during \(\Phi 2\) clock pulse.

A0-A11 25-32 Address Bus Lines. The address bus buf-34-37 fers 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 technıque 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.

\section*{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 RES line be held low for at least eight \(\Phi 2\) clock cycles after \(V_{C C}\) reaches operating range (Figure 1).

\section*{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 2 K 2716 PROM. Since the R6500/1 has a 2K ROM capacity, the contents of the PROM could be masked directly into the production R6500/1 ROM.

Figure 3 shows a connection to 3 K 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.


Figure 1. I/O Port Initialization


Figure 2. Device Connected to One 2716 PROM (2K Bytes)


Figure 3. Device Connected to Three PROMS (3K Bytes)

TRUTH TABLE
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{2}{|c|}{Address} & \multicolumn{3}{|c|}{PROM Select} & \multirow[b]{2}{*}{Selected Address Range} \\
\hline A11 & A10 & \[
\begin{gathered}
2708 \text { No. } 3 \\
\overline{C E}
\end{gathered}
\] & \[
\begin{gathered}
2708 \text { No. } 2 \\
\overline{C E}
\end{gathered}
\] & \[
\begin{gathered}
2808 \text { No. } 1 \\
\overline{C E}
\end{gathered}
\] & \\
\hline 0 & 0 & 1 & 1 & 1 & 000-3FF \\
\hline 0 & 1 & 1 & 1 & 0 & 400-7FF \\
\hline 1 & 0 & 1 & 0 & 1 & 800-BFF \\
\hline 1 & 1 & 0 & 1 & 1 & C00-FFF \\
\hline
\end{tabular}

\section*{DEVICE TIMING}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min. & Max. & Min. & Max. & \\
\hline \(\mathrm{R} / \overline{\mathrm{W}}\) setup time from CPU & TRWS & & 300 & & 200 & ns \\
\hline Address setup time from CPU & TADS & & 300 & & 200 & ns \\
\hline Memory read access time & TACC & & 525 & & 225 & ns \\
\hline Data stabilization time & TDSU & 150 & & 75 & & ns \\
\hline Data hold time - Read & THR & 10 & & 10 & & ns \\
\hline Data hold time - Write & THW & 30 & & 30 & & ns \\
\hline Data delay time from CPU & TMDS & & 200 & & 150 & ns \\
\hline RDY setup time & TRDY & 100 & & 50 & & ns \\
\hline SYNC delay tıme from CPU & TSYNC & & 350 & & 175 & ns \\
\hline Address hold time & THA & 30 & & 30 & & ns \\
\hline \(\mathrm{R} / \bar{W}\) hold time & THRW & 30 & & 30 & & ns \\
\hline Cycle Time & TCYC & 1.0 & 10.0 & 0.5 & 10.0 & \(\mu \mathrm{S}\) \\
\hline
\end{tabular}

\section*{ELECTRICAL CHARACTERISTICS}
( \(\mathrm{V}_{\mathrm{CC}}=5.0 \pm 5 \%, \quad \mathrm{~V}_{S S}=0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) )
\begin{tabular}{|c|c|c|c|c|c|}
\hline Characteristic & Symbol & Min & Typ & Max & Unit \\
\hline Input High Threshold Voltage DO-D7, RDY, & \(\mathrm{V}_{\text {IHT }}\) & \(V_{S S}+24\) & . - & - & Vdc \\
\hline Input Low Threshold Voltage DO-D7, RDY, & VILT & - & - & \(V_{S S}+0.8\) & Vdc \\
\hline Three-State (Off State) Input Current
\[
\begin{aligned}
& \left(\mathrm{V}=04 \text { to } 24 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}\right) \\
& \mathrm{DO} \mathrm{D} 7
\end{aligned}
\] & ITSI & - & - & 10 & \(\mu \mathrm{A}\) \\
\hline \begin{tabular}{l}
Output High Voltage \\
( \(\mathrm{LOAD}=100 \mu \mathrm{Adc}, \mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}\) ) \\
DO-D7, SYNC, AO-A11, R/W, \(\phi 2\)
\end{tabular} & \(\mathrm{V}_{\mathrm{OH}}\) & \(\mathrm{V}_{\text {SS }}+2.4\) & - & - & Vdc \\
\hline \[
\begin{aligned}
& \text { Output Low Voltage } \\
& \quad\left(\text { LOAD }=1.6 \mathrm{mAdc}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}\right) \\
& \text { DO-D7, SYNC, AO-A11, R/ } / \overline{\mathrm{W}}, \phi 2
\end{aligned}
\] & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & \(V_{S S}+06\) & Vdc \\
\hline Power Dissipatıon & PD & - & 0.75 & 120 & W \\
\hline \[
\begin{aligned}
& \text { Capacıtance } \\
& \left(V_{\text {In }}=0, T_{A}=25^{\circ} \mathrm{C}, f=1 \mathrm{MHz}\right) \\
& \text { RDY } \\
& \text { DO-D7 } \\
& \text { A0-A11, R/ } \bar{W}, \text { SYNC } \\
& \phi 2
\end{aligned}
\] & \begin{tabular}{l}
C \\
\(C_{\text {In }}\) \\
Cout \\
\(\mathrm{C}_{\phi 2}\)
\end{tabular} & - & \[
\begin{aligned}
& - \\
& - \\
& 50
\end{aligned}
\] & \[
\begin{aligned}
& 10 \\
& 15 \\
& 12 \\
& 80
\end{aligned}
\] & pF \\
\hline I/O Port Pull-up Resistance & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 60 & 11.5 & kohm \\
\hline
\end{tabular}

\section*{DETAILED MEMORY MAP}


\section*{TIMING DIAGRAMS}


\section*{PACKAGE DIMENSIONS}

R6500/1EC 64-PIN DIP CERAMIC


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

\section*{R6500/1EQ 64-PIN QUIP PLASTIC}


\section*{R6500/1EB and R6500/1EAB BACKPACK EMULATOR}

\section*{INTRODUCTION}

The Rockwell R6500/1EB and R6500/1EAB Backpack Emulator is the PROM prototyping version of the 8 -bit, masked-ROM R6500/1 one-chip microcomputer. Like the R6500/1, the backpack device is totally upward/downward compatible with all members of the R6500/1 family. It is designed to accept standard 5 -volt, 24 -pin EPROMs or ROMs directly, in a socket on top of the Emulator. This packaging concept allows a standard EPROM to be easily removed, reprogrammed, then reinserted as often as desired.

The backpack devices have the same pinouts as the maskedROM R6500/1 microcomputer. These 40 pins are functionally and operationally identical to the pıns on the R6500/1, with some minor differences (described herein). The R6500/1 Microcomputer Product Description Document Order No. 212 includes a description of the interface signals and their functions. Whereas the masked-ROM R6500/1 provides 2 K bytes of read-only memory, the R6500/1EB will address 3 K bytes of external program memory. This extra memory accommodates program patches, test programs or optional programs during breadboard and prototype development states.

\section*{ORDERING INFORMATION}

BACKPACK EMULATOR
\begin{tabular}{|c|c|c|c|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Memory \\
Capacity
\end{tabular} & \begin{tabular}{c} 
Compatible \\
Memories
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range and Speed
\end{tabular} \\
\hline R6500/1EB3 & \(3 \mathrm{~K} \times 8\) & 2732 & \(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
1 MHz \\
R6500/1EAB3 & \(3 \mathrm{~K} \times 8\) & \begin{tabular}{c}
2732 A \\
\((250 \mathrm{~ns})\)
\end{tabular} & \begin{tabular}{c}
\(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
2 MHz
\end{tabular} \\
\hline
\end{tabular}

SUPPORT PRODUCTS
\begin{tabular}{|c|c|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \multicolumn{1}{c|}{ Description } \\
\hline S65-101 & System 65 Microcomputer Development System \\
M65-040 & PROM Programmer Module \\
M65-081 & 1-MHz R6500/1 Personality Module \\
M65-082 & \(2-\mathrm{MHz}\) R6500/1 Personality Module \\
\hline
\end{tabular}

\section*{FEATURES}
- PROM version of the R6500/1
- Completely pin compatible with R6500/1 single-chip microcomputers
- Profile approaches 40 -pin DIP of R6500/1
- Accepts 5 -volt, 24-pin industry-standard EPROMs
-4K memories-2732, 2732A (3K bytes addressable)
- Use as prototyping tool or for low volume production
- 3 K bytes of memory capacity ( 4 K memories)
- \(64 \times 8\) static RAM
- Separate power pin for RAM
- Software compatibility with the R6500 family
- 32 bi-directional TTL compatıble I/O lines (4 ports)
- 1 bı-directional TTL compatıble 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 sensıtive, counter)
- Crystal or external tıme base
- Single +5 V power supply


R6500/1EB-R6500/1EAB Backpack Emulator

\section*{CONFIGURATION}

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

\section*{EXTERNAL FREQUENCY REFERENCE}

The external frequency reference may be a crystal or a 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.

\section*{I/O PORT PULLUPS}

The emulator devices have internal I/O port pullup resistors.

\section*{TEST MODE DELETED}

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

\section*{PRODUCT SUPPORT}

The Backpack Emulator is just one of the products that Rockwell offers to facilitate system and program development for the R6500/1.
The 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.


R6500/1EB Interface Diagram

DETAILED MEMORY MAP
\begin{tabular}{|c|c|c|}
\hline & & HEX \\
\hline \multirow{7}{*}{PROM} & IRQ VECTOR HIGH & \multirow[t]{6}{*}{\begin{tabular}{l}
FFF \\
FFD \\
FFC \\
FFB \\
FFA \\
FF9
\end{tabular}} \\
\hline & IRQ VECTOR LOW & \\
\hline & RES VECTOR HIGH & \\
\hline & RES VECTOR LOW & \\
\hline & NMI VECTOR HIGH & \\
\hline & NMI VECTOR LOW & \\
\hline & R6500/1 USER PROGRAM & \multirow[t]{2}{*}{\[
400
\]} \\
\hline PROM & R6500/1EB EXTENDED PROGRAM AREA (1) & \\
\hline NOT USED & UNASSIGNED & \multirow[b]{2}{*}{08F} \\
\hline \multirow{13}{*}{I/O} & CONTROL REGISTER & \\
\hline & UNASSIGNED & 08E \\
\hline & CLEAR PA1 NEG EDGE DETECTED (2) & 08A \\
\hline & CLEAR PAO POS EDGE DETECTED (2) & 089 \\
\hline & UPPER LATCH AND TRANSFER LATCH TO COUNTER & 088 \\
\hline & LOWER COUNT (3) & 087 \\
\hline & UPPER COUNT & 086 \\
\hline & LOWER LATCH & 085 \\
\hline & UPPER LATCH & 084 \\
\hline & PORT D & 083 \\
\hline & PORT C & 082 \\
\hline & PORT B & 081 \\
\hline & PORT A & 080 \\
\hline \[
\begin{array}{|l|}
\hline \text { NOT } \\
\text { USED }
\end{array}
\] & UNASSIGNED & \\
\hline RAM & USER RAM & 000 \\
\hline
\end{tabular}

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

\section*{RAM MAPPING}

The Backpack Emulator allows RAM mapping into 040-07F, 100-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.

\section*{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.

\section*{BACKPACK MEMORY SIGNAL DESCRIPTION}
\begin{tabular}{|c|c|c|}
\hline Signal Name & Pin No. & Description \\
\hline 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. \\
\hline A0-A9 & \[
\begin{aligned}
& 1 \mathrm{~S}-8 \mathrm{~S}, \\
& 23 \mathrm{~S}, 24 \mathrm{~S}
\end{aligned}
\] & Address Bus Lines. The address bus lines are buffered by push/pull type drivers that can drive one standard TTL load. \\
\hline A10 & 19S & Address Bus Line 10. This address line has the same characteristics and functions as Lines A0-A9 \\
\hline \(\overline{\mathrm{CE}}\) & 18 S & \(\overline{\mathrm{CE}}\) is active when the address is 400-FFF This line can drive one TTL load \\
\hline \(\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}}\). \\
\hline \(V_{C C}\) & 24S & Main Power Supply \(\$ 5 \mathrm{~V}\). This pin is tied directly to \(\mathrm{pin} 30\left(\mathrm{~V}_{\mathrm{CC}}\right)\). \\
\hline A11 & 215 & Address Bus Line II. This pin is tied to A11. During backup power, power is supplied only to the RAM memory, and not to the PROMs. \\
\hline \(\mathrm{V}_{\text {SS }}\) & 12 S & Signal and Power Ground (zero volts). This pin is tied directly to pin \(12\left(\mathrm{~V}_{\mathrm{SS}}\right)\). \\
\hline
\end{tabular}


Pin Configuration

READ TIMING CHARACTERISTICS
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min. & Max. & Min. & Max. & \\
\hline \(\overline{\mathrm{OE}}\) setup time from CPU & \(\mathrm{T}_{\text {OES }}\) & - & 300 & - & 150 & ns \\
\hline Address setup time from CPU & \(\mathrm{T}_{\text {ADS }}\) & - & 300 & - & 150 & ns \\
\hline Memory read access time & \(\mathrm{T}_{\text {ACC }}\) & - & 525 & - & 250 & ns \\
\hline Data stabilizatıon time & T \({ }_{\text {dSU }}\) & 150 & - & 100 & - & ns \\
\hline Data hold time-Read & \(\mathrm{T}_{\mathrm{HR}}\) & 10 & - & 10 & - & ns \\
\hline Address hold time & \(\mathrm{T}_{\mathrm{HA}}\) & 30 & - & 30 & - & ns \\
\hline \(\overline{\mathrm{OE}}\) hold time & \(\mathrm{T}_{\text {Hoe }}\) & 30 & - & 30 & - & ns \\
\hline Cycle Tıme & \(\mathrm{T}_{\mathrm{CYC}}\) & 1.0 & 10.0 & 0.5 & 10.0 & \(\mu \mathrm{s}\) \\
\hline
\end{tabular}

READ TIMING WAVEFORMS

* \(\phi 2\) IS SHOWN FOR REFERENCE ONLY AND IS NOT AVAILABLE EXTERNAL TO THE DEVICE.

I/O PORT INITIALIZATION TIMING


\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{c} 
Operating Temperature \\
Commercial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
\(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
0 to +70
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{S S}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=0^{\circ}\right.\) to \(70^{\circ}\), unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline Input High Voltage
D0-D7 & \(\mathrm{V}_{\mathrm{IH}}\) & \(\mathrm{V}_{\text {Ss }}+24\) & - & - & V & \\
\hline Input Low Voltage
D0-D7 & \(\mathrm{V}_{\text {IL }}\) & - & - & \(\mathrm{V}_{\mathrm{ss}}+0.8\) & v & \\
\hline Input Leakage Current (Three-State Off) D0-D7 & \(\mathrm{I}_{\mathrm{N}}\) & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IN}}=0.4 \text { to } 2.4 \mathrm{~V} \\
& \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}
\end{aligned}
\] \\
\hline Output High Voltage (Except XTLO) D0-D7, A0-A11, \(\overline{O E}\) & \(\mathrm{V}_{\mathrm{OH}}\) & \(\mathrm{V}_{\mathrm{ss}}+2.4\) & - & - & V & \[
\begin{aligned}
& \mathrm{I}_{\mathrm{LOAD}}=-100 \mu \mathrm{~A} \\
& \mathrm{~V}_{S S}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline Output Low Voltage D0-D7, A0-A11, \(\overline{O E}\) & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & \(\mathrm{v}_{\mathrm{ss}}+0.6\) & v & \[
\begin{aligned}
& \mathrm{I}_{\mathrm{LOAD}}=1.6 \mathrm{~mA} \\
& \mathrm{~V}_{\mathrm{SS}}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline I/O Port Pull-Up Resistance & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 115 & Kohm & \\
\hline Input Capacitance D0-D7 & \(\mathrm{C}_{\text {IN }}\) & - & - & 15 & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) A0-A11 & \(\mathrm{C}_{\text {OUT }}\) & - & - & 12 & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{1 \mathrm{~N}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Loss EPROM) & \(\mathrm{P}_{\mathrm{D}}\) & - & 800 & 1300 & mW & \(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

\section*{Notes:}
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\).
2. Negative sign indicates outward current flow, positive indicates inward flow.

\section*{PACKAGE DIMENSIONS}

40-PIN BACKPACK


\title{
R6500/11, R6500/12, \\ R6500/15 AND R6500/16 ONE-CHIP MICROCOMPUTERS
}

\section*{SECTION 1 \\ INTRODUCTION}

\subsection*{1.1 FEATURES}
- Enhanced 6502 CPU
-Four new bit manıpulation instructions: Set Memory Bit (SMB) Reset Memory Bit (RMB) Branch on Bit Set (BBS) Branch on Bit Reset (BBR)
-Decimal and bınary arithmetıc modes
- 13 addressing modes
-True indexing
- 3K-byte mask-programmable ROM (R6500/11, R6500/12)
- 4K-byte mask-programmable ROM (R6500/15, R6500/16)
- 192-byte static RAM
- 32 TTL-compatible I/O lines (R6500/11, R6500/15)
- 56 TTL-compatible I/O lines (R6500/12, R6500/16)
- 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.5K bits/sec @ 1 MHz
- Ten interrupts
-Four edge-sensitive lines; two positive, two negative
-Reset
-Non-maskable
-Two counter underflows
-Serial data received
-Serial data transmitted
- Bus expandable to 16 K bytes of external memory
- Flexible clock circuitry
\(-2-\mathrm{MHz}\) or \(1-\mathrm{MHz}\) internal operation
-Internal clock with external 2 MHz to 4 MHz series resonant XTAL at two or four times internal frequency
-External clock input divided by one, two or four
- \(1 \mu \mathrm{~s}\) minimum instruction execution time @ 2 MHz
- NMOS-3 silicon gate, depletion load technology
- Single +5 V power supply
- 12 mW stand-by power for 32 bytes of the 192-byte RAM
- 40-pin DIP (R6500/11 and R6500/15)
- 64-pin QUIP (R6500/12 and R6500/16)

\subsection*{1.2 SUMMARY}

These Rockwell microcomputers are complete, high-performance 8-bit NMOS-3 microcomputers on a single chip, and are compatible with all members of the R6500 family.

The R6500/11 consists of an enhanced 6502 CPU, an internal clock oscillator, 3072 bytes of Read-Only Memory, 192 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/15 is identical to the R6500/11 except it has 4 K of ROM.

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 R6500/16 is identical to the R6500/12 except it has 4 K of ROM.

The innovative architecture and the demonstrated high performance of the R6502 CPU, as well as instruction simplicity, results in system cost-effectiveness and a wide range of computational power. These features make either device a leading candidate for microcomputer applications.

To allow prototype circuit development, Rockwell offers a PROMcompatible 64-pin extended microprocessor device. This device. the R6511Q, provides all R6500/11 or R6500/15 interface lines, plus the address bus, data bus and control lines to interface with external memory. With the addition of external circuits it can also be used to emulate the R6500/12 or R6500/16 (contact Rockwell sales offices listed on the back page for details).

A backpack emulator, the R65/11EB, is available for developing R6500/11 applications. No backpack part is available for the R6500/12.

The R6511Q may also be used as a CPU-RAM-I/O counter device in multichip systems.

Rockwell supports development of 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).

\subsection*{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 or /15 order form.

The R6500/12 or /16 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*{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 or /15 Mechanical Outline and Pin Out Configuration


Figure 2-3. R6500/12 or /16 Mechanical Outline and Pin Out Configuration

Table 2-1. Pin Descriptions
\begin{tabular}{|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal Name} & \multicolumn{2}{|r|}{Pin Number} & \multirow[b]{2}{*}{Description} \\
\hline & R6500/11 or /15 & R6500/12 or /16 & \\
\hline \(\mathrm{V}_{\text {cc }}\) & 21 & 50 & Main power supply +5 V \\
\hline \(V_{\text {RR }}\) & 39 & 12 & Separate power pin for RAM. In the event that \(V_{c c}\) power is lost, this power retains RAM data. \\
\hline \(\mathrm{V}_{\mathrm{ss}}\) & 40 & 11 & Signal and power ground ( 0 V ) \\
\hline 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}_{\text {ss }}\), or X2 or X4 clock if XTLO is floated \\
\hline XTLO & 1 & 9 & Crystal output from internal clock oscillator. \\
\hline \(\overline{\text { RES }}\) & 20 & 41 & The Reset input is used to initialize the device. This signal must not transition from low to high for at least eight cycles after \(\mathrm{V}_{\mathrm{cc}}\) reaches operating range and the internal oscillator is stabilized. \\
\hline \(\not{ }^{2}\) & 3 & 13 & Clock signal output at internal frequency. \\
\hline \(\overline{\text { NMI }}\) & 22 & 51 & A negative going edge on the Non-Maskable Interrupt signal requests that a nonmaskable interrupt be generated within the CPU. \\
\hline PAO-PA7 & 30-23 & 64-57 & Four 8-bit ports used for either input/output. Each line of Ports A, B and C consist \\
\hline PB0-PB7 & 38-31 & 8-1 & of an active transistor to \(\mathrm{V}_{\text {SS }}\) and an optional passive pull-up to \(\mathrm{V}_{\mathrm{cc}}\). In the abbre- \\
\hline PC0-PC7 & 4-11 & 25-32 & viated or multiplexed modes of operation Port C has an active pull-up transistor. \\
\hline PDO-PD7 & 19-12 & 40-33 & Port \(D\) functions as etther an 8 -bit input or 8 -bit output port. It has active pull-up and pull-down transistors. \\
\hline PE0-PE7 & N/A & 49-42 & For the R6500/12 or /16, the 64 pin QUIP version, three additional ports (24 lines) \\
\hline PF0-PF7 & N/A & 24-17 & are provided. Each line consists of an active transistor to V \({ }_{\text {SS }}\). PFO-PF7 and \\
\hline PG0-PG7 & N/A & \[
\begin{gathered}
52-56 \\
4 \\
14-16
\end{gathered}
\] & PGO-PG7 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{mps}\) at 2.4 V except port E (PEO-PE7) which will source 1 mA at 1.5 V . \\
\hline
\end{tabular}

\section*{SECTION 3 SYSTEM ARCHITECTURE}

This section provides a functional description of the devices. Functionally they consist of a CPU, both ROM and RAM memories, four 8-bit parallel I/O ports (seven in the 64-pin versions), a serial I/O port, dual counter/latch circuits, a mode control register, and an interrupt flag/enable dual register circuit. A block diagram of the system is shown in Figure 3-1.

\section*{NOTE}

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

\subsection*{3.1 CPU LOGIC}

The internal CPU is a standard 6502 configuration with an 8 -bit Accumulator register, two 8-bit Index Registers (X and Y); an 8-bit Stack Pointer register, an ALU, a 16-bit Program Counter, and standard instruction register/decode and internal timing control logic.

\subsection*{3.1.1 Accumulator}

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

\subsection*{3.1.2 Index Registers}

There are two 8-bit index registers, \(X\) and \(Y\). Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

\subsection*{3.1.3 Stack Pointer}

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremiented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal \(\overline{\mathrm{RQ}}\) interrupt, or the external interrupt line \(\overline{\mathrm{NMI}}\). The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may only be accessed from the top. The address of a memory
location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1 . Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus, and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 00FF-0040. After reset, which leaves the Stack Pointer indeterminate, normal usage calls for its initialization at 00FF.

\subsection*{3.1.4 Arithmetic And Logic Unit (ALU)}

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

\subsection*{3.1.5 Program Counter}

The 16-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter ( PCH ) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

\subsection*{3.1.6 Instruction Register and Instruction Decode}

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register then decoded along with timing and interrupt signals to generate control signals for the various registers.

\subsection*{3.1.7 Timing Control}

The Timıng 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. System Block Diagram

\subsection*{3.1.8 Interrupt Logic}

Interrupt logic controls the sequencing of three interrupts; \(\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}\) and \(\overline{\mathrm{IRQ}} . \overline{\mathrm{IQQ}}\) is generated by any one of eight conditions: 2 Counter Overflows, 2 Positive Edge Detects, 2 Negative Edge Detects, and 2 Serial Port Conditions.

\subsection*{3.2 NEW INSTRUCTIONS}

In addition to the standard 6502 instruction set, four instructions have been added to the devices to simplify operations that previously required a read/modif/write operation. In order for these instructions to be equally applicable to any I/O ports, with or without mixed input and output functions, the I/O ports have been designed to read the contents of the specified port data register during the Read cycle of the read/ modify/write operation, rather than I/O pins as in normal read cycles. The added instructions and their format are explained in the following subparagraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions.

\subsection*{3.2.1 Set Memory Bit (SMB m, Addr.)}

This instruction sets to " 1 " one of the 8 -bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and 1 of 8 bits to be set. The second byte of the instruction designates address ( \(00-\mathrm{FF}\) ) of the byte or I/O port to be operated upon.

\subsection*{3.2.2 Reset Memory Bit (RMB m, Addr.)}

This instruction is the same operation and format as SMB instruction except a reset to " 0 " of the bit results.

\subsection*{3.2.3 Branch On Bit Set Relative (BBS m, Addr, DEST)}

This instruction tests one of 8 bits designated by a three bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction is used to specify the 8 bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

\subsection*{3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST)}

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

\subsection*{3.3 READ-ONLY-MEMORY (ROM)}

In the R6500/11 or R6500/12 the ROM consists of 3072 bytes (3K) of mask programmable memory with an address space from F400 to FFFF. ROM locations FFFA through FFFF are assigned for interrupt and reset vectors.

In the R6500/15 or R6500/16 the ROM consists of 4096 bytes (4K) of mask programmable memory with an address space from F000 to FFFF. ROM locations FFFA through FFFF are assigned for interrupt and reset vectors.

\subsection*{3.4 RANDOM ACCESS MEMORY (RAM)}

The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The R6500/11 provides a separate power pin ( \(V_{R R}\) ) which may be used for standby power for 32 bytes located at 0040-005F. In the event of the loss of \(V_{c c}\) power, the lowest 32 bytes of RAM data will be retained if standby power is supplied to the \(V_{R R}\) pin. If the RAM data retention is not required then \(V_{R R}\) must be connected to \(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_{\text {RR }}\) must be supplied within operating range and \(\overline{\text { RES }}\) must be driven low at least eight \(\varnothing 2\) clock pulses before \(V_{c c}\) falls out of operatıng range. \(\overline{\operatorname{RES}}\) must then be held low while \(V_{c c}\) is out of operating range and untıl at least eight \(\emptyset 2\) clock cycles after \(\mathrm{V}_{\mathrm{cc}}\) is again within operating range and the internal \(\emptyset 2\) oscillator is stabilized. \(\mathrm{V}_{\mathrm{RR}}\) must remain within \(\mathrm{V}_{\mathrm{CC}}\) operating range during normal operation. When \(V_{c c}\) is out of operating range, \(\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.


1 INITIAL APPLICATION OF \(V_{C C}\) AND \(V_{R R}\).
2 LOSS OF \(V_{C C}\), RAM ON STANDBY POWER.
3 REAPPLICATION OF VCC.
\(4>802\) CLOCK PULSES AFTER OSCILLATOR STABILIZATION. \(5>8 \mathbf{1}\) CLOCK PULSES.

Figure 3-2. Data Retention Timing

\subsection*{3.5 CLOCK OSCILLATOR}

Three customer selectable mask options are available for controlling the device tıming. 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 ether 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


c. Clock Inputs

Internal timing can also be controlled by driving the XTLI pın 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.

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 tıming. When a common external source is used to drive multiple devices the internal timing between devices as well as their \(\phi 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

Figure 3-3. Closk Oscillator Input Options

\subsection*{3.6 MODE CONTROL REGISTER (MCR)}

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for Counter A and Counter B. Its setting, along with the setting of the Serial Communications Control Register (SCCR), determines the basic configuration of the device in any application. Initializing this register is one of the first actions of any software program. The Mode Control Register bit assignment is shown in Figure 3-5.


Figure 3-5. Mode Control Register
The use of Counter A Mode Select is shown in Section 6.1.
The use of Counter B Mode Select is shown in Section 6.2.
The use of Port B Latch Enable is shown in Section 4.4.
The use of Port D in Tri-State Enable is shown in Section 4.6.

The use of Bus Mode Select is shown in Section 4.5 and 4.6.

\subsection*{3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)}
\(\mathrm{An} \overline{\mathrm{IRQ}}\) interrupt request can be initiated by any or all of eight possible sources. These sources are all capable of being enabled or disabled by the use of the appropriate interrupt enabled bits in the Interrupt Enable Register (IER). Multiple simultaneous interrupts 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. A logic " 1 " is ignored when writing to edge detect IFR bits.

Each IFR bit has a corresponding bit in the Interrupt Enable Register which can be set to a "1" by writing a "1" in the respective bit position at location 0012. Individual IER bits may be cleared by writing a " 0 " in the respective bit position, or by RES. If set to a " 1 ", an IRQ will be generated when the corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 3-6 and the functions of each bit are explained in Table 3-1.


Figure 3-6. Interrupt Enable and Flag Registers

Table 3-1. Interrupt Flag Register Bit Codes
\begin{tabular}{|c|c|}
\hline \[
\begin{aligned}
& \text { BIT } \\
& \text { CODE }
\end{aligned}
\] & FUNCTION \\
\hline IFR 0: & PA0 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. }}\) \\
\hline IFR 1: & PA1 Positive Edge Detect Flag-Set to a 1 when a positive going edge is detected on PA1. Cleared by RMB 1 (0010) instruction or by \(\overline{\text { RES }}\). \\
\hline IFR 2: & PA2 Negative Edge Detect Flag-Set to a 1 when a negative going edge is detected on PA2. Cleared by RMB 2 ( 0010 ) instruction or by RES. \\
\hline IFR 3: & PA3 Negative Edge Detect Flag-Set to 1 when a negative going edge is detected on PA3. Cleared by RMB 3 (0010) instruction or by RES. \\
\hline IFR 4: & Counter A Underflow Flag-Set to a 1 when Counter A underflow occurs. Cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES. \\
\hline IFR 5: & Counter B Underflow Flag-Set to a 1 when Counter B underflow occurs. Cleared by reading the Lower Counter \(B\) at location 001C, by writing to address locatıon 001E, or by RES. \\
\hline IFR 6: & Receiver Interrupt Flag-Set to a 1 when any of the Serial Communication Status Register bits 0 through 3 is set to a 1 . Cleared when the Receiver Status bits (SCSR 0-3) are cleared or by RES \\
\hline IFR 7: & Transmitter Interrupt Flag-Set to a 1 when SCSR 6 is set to a 1 while SCSR 5 is a 0 or SCSR 7 is set to a 1 . Cleared when the Transmitter Status bits (SCSR 6 \& 7) are cleared or by \(\overline{\text { RES }}\). \\
\hline
\end{tabular}

\subsection*{3.8 PROCESSOR STATUS REGISTER}

The 8-bit Processor Status Register, shown in Figure 3-7, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6502 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

\subsection*{3.8.1 Carry Bit (C)}

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operatıons which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

\subsection*{3.8.2 Zero Bit (Z)}

The Zero Bit ( \(Z\) ) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to
zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The R6500 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions; ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

\subsection*{3.8.3 Interrupt Disable Bit (I)}

The Interrupt Disable Bit \((\mathbb{I})\) is used to control the servicıng of an interrupt request ( \(\overline{\mathrm{IRQ}})\). If the I Bit is reset to logic 0 , the \(\overline{\mathrm{RQ}}\) signal will be serviced. If the bit is set to logic 1 , the \(\overline{\mathrm{RQ}}\) 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

\subsection*{3.8.4 Decimal Mode Bit (D)}

The Decimal Mode Bit (D), is used to control the arithmetic mode of the CPU. When this bit is set to logic 1 , the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction will clear it. The PLP and RTI instructions also effect the Decimal Mode Bit.

\section*{CAUTION}

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application. This bit must be initialized to the desired state by the user program or erroneous results may occur.

\subsection*{3.8.5 Break Bit (B)}

The Break Bit (B) is used to determine the condition which caused the \(\overline{\mathrm{RQ}}\) service routine to be entered. If the \(\overline{\mathrm{RQ}}\) service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1. If the \(\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.

\subsection*{3.8.6 Overflow Bit (V)}

The Overflow Bit (V) is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits ( \(-128 \leqslant n \leqslant 127\) ).

This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction which may be used to sample interface devices, allows the overflow flag to reflect the condition of bit 6 in the sampled field. During a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions which affect the V flag are ADC, BIT, CLV, PLP, RTI and SBC.

\subsection*{3.8.7 Negative Bit (N)}

The Negative Bit ( N ) is used to indicate that the sign bit (bit 7), in the resulting value of a data movement or data arithmetic operation, is set to logic 1 . If the sign bit is set to logic 1 , the resulting value of the data movement or arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

\section*{SECTION 4 PARALLEL INPUT/OUTPUT PORTS}

The R6500/11 or R6500/15 has 32 I/O lines grouped into four 8 -bit ports (PA, PB, PC, and PD). Ports A through C may be used either for input or output individually or in groups of any combination. Port D may be used as all inputs or all outputs.

The R6500/12 or R6500/16, a 64 pin QUIP device, has three additional ports: PE, PF and PG. PE is outputs only; PF and PG are bidirectional.

Multifunction I/O's such as Port A and Port C are protected from normal port I/O instructions when they are programmed to perform a multiplexed function.

Internal pull-up resistors (FET's with an impedance range of \(3 \mathrm{~K} \leqslant \mathrm{Rpu} \leqslant 12 \mathrm{~K}\) ohm) may be provided on all port pins except Port D and E as a mask option.

The direction of the I/O lines are controlled by four 8 -bit port registers located in page zero. This arrangement provides quick programming access using simple two-byte zero page address instructions. There are no direction registers associated with the I/O ports, which simplifies I/O handling. The I/O addresses are shown in Table 4-1. Section E. 6 shows the I/O Port Timing.

Table 4-1. I/O Port Addresses
\begin{tabular}{|cc|}
\hline Port & Address \\
\hline A & 0000 \\
B & 0001 \\
C & 0002 \\
D & 0003 \\
E & 0004 \\
G & 0005 \\
\hline
\end{tabular}

\subsection*{4.1 INPUTS}

Inputs for Ports A, B, and C and also Ports F and G of the R6500/12 or R6500/16 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 modify the operation of PA, PB, PC, \& PD and also ports PF and PG of the R6500/12. During the Read cycle of a Read/Modify/ Write instruction the Port I/O register is read. For all other read instructions the port input lines are read. Read/Modify/ Write instructions are: ASL, DEC, INC, LSR, RMB, ROL, ROR, and SMB.

\subsection*{4.2 OUTPUTS}

Outputs for Ports A thru D and Ports E thru G of the R6500/12 or R6500/16 are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( \(>2.4 \mathrm{~V}\) ) output while a logic 0 will force a low ( \(<0.4 \mathrm{~V}\) ) output.

Port D all outputs is selected by setting MCR5 to a " 1 ".
Port E is always all outputs.

\subsection*{4.3 PORT A (PA)}

Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as a standard parallel 8-bit, bit independent, 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


\subsection*{4.4 PORT B (PB)}

Port B can be programmed as an 8 bit, bit independent I/O port. It has a latched input capability which may be enabled or disabled via the Mode Control Register (MCR). Table 4-3 tabulates the control and usage of Port B. An Input Data Strobe signal must be provided thru PAO when Port B is programmed to be used with latched input option. Input data latch timing for Port B is shown in Section E.5.

Table 4-3. Port B Control \& Usage
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{4}{*}{Pin Name} & \multicolumn{2}{|c|}{I/O Mode} & \multicolumn{2}{|c|}{Latch Mode} \\
\hline & \multicolumn{2}{|c|}{MCR4 \(=0\)} & \multicolumn{2}{|c|}{\begin{tabular}{l}
\[
\text { MCR4 }=1
\] \\
(2)
\end{tabular}} \\
\hline & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & Name & Type (1) & Name & Type \\
\hline PB0 & PB0 & I/O & PBO & INPUT \\
\hline PB1 & PB1 & 1/O & PB1 & INPUT \\
\hline PB2 & PB2 & 1/0 & PB2 & INPUT \\
\hline PB3 & PB3 & 1/0 & PB3 & INPUT \\
\hline PB4 & PB4 & 1/0 & PB4 & INPUT \\
\hline PB5 & PB5 & 1/0 & PB5 & INPUT \\
\hline PB6 & PB6 & 1/0 & PB6 & INPUT \\
\hline PB7 & PB7 & 1/0 & PB7 & INPUT \\
\hline \multicolumn{5}{|l|}{\begin{tabular}{l}
(1) Resistive pull-up, active buffer pull down \\
(2) Input data is stored in port B latch by PAO pulse
\end{tabular}} \\
\hline
\end{tabular}

\subsection*{4.5 PORT C (PC)}

Port C can be programmed as an I/O port and in conjunction with Port D, as an abbreviated bus, or as a multiplexed bus. When used in the abbreviated or multiplexed bus modes, PC0-PC7 function as A0-A3, A12, R/W, A13, and EMS, respectively, as shown in Table 4-4. EMS (External Memory Select) is asserted (low) whenever the internal processor accesses memory area between 0100 and 3FFF. (See Memory Map, Appendix B). The leading edge of EMS may be used to strobe the eight address lines multiplexed on Port D in the Multiplexed Bus Mode. See Appendix E. 3 through E. 5 for Port C timing.

\subsection*{4.6 PORT D (PD)}

Port D can be programmed as an I/O Port, an 8-bit tri-state data bus, or as a multiplexed bus. Mode selection for Port \(D\) is made by the Mode Control Register (MCR). The Port \(D\) output drivers can be selected as tri-state drivers by setting bit 5 of the MCR to 0 (zero). Table 4-5 shows the necessary settings for the MCR to achieve the various modes for Port D. When Port D is selected to operate in the Abbreviated Mode PD0-PD7 serves as data register bits D0-D7. When Port \(D\) is selected to operate in the Multiplexed Mode data bits D0 through D7 are time multiplexed with address bits A4 through A11, respectively. Refer to the Memory Maps (Appendix C) for Abbreviated and Multiplexed memory assignments. See Appendix E. 3 through E. 5 for Port D timing.

\subsection*{4.7 PORT E, PORT F AND PORT G (PE, PF \& PG) R6500/12 OR /16 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
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{4}{*}{\begin{tabular}{l}
Pin \\
Name
\end{tabular}} & \multicolumn{2}{|c|}{I/O Mode} & \multicolumn{2}{|c|}{Abbreviated Mode} & \multicolumn{2}{|c|}{Multiplexed Mode} \\
\hline & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=\mathrm{X}
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
\text { MCR7 } & =1 \\
\text { MCR6 } & =0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=1
\end{aligned}
\]} \\
\hline & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & Name & Type (1) & Name & \begin{tabular}{l}
Type \\
(2)
\end{tabular} & Name & \begin{tabular}{l}
Type \\
(2)
\end{tabular} \\
\hline PC0 & PCO & I/O & AO & OUTPUT & AO & OUTPUT \\
\hline PC 1 & PC1 & I/O & A1 & OUTPUT & A1 & OUTPUT \\
\hline PC2 & PC2 & I/O & A2 & OUTPUT & A2 & OUTPUT \\
\hline PC3 & PC3 & I/O & A3 & OUTPUT & A3 & OUTPUT \\
\hline PC4 & PC4 & I/O & A12 & OUTPUT & A12 & OUTPUT \\
\hline PC5 & PC5 & I/O & RW & OUTPUT & RW & OUTPUT \\
\hline PC6 & PC6 & I/O & A13 & OUTPUT & A13 & OUTPUT \\
\hline PC7 & PC7 & I/O & EMS & OUTPUT & EMS & OUTPUT \\
\hline
\end{tabular}
(1) Resistive Pull-Up, Active Buffer Pull-Down
(2) Active Buffer Pull-Up and Pull-Down

Table 4-5. Port D Control and Usage
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{5}{*}{Pin Name} & \multicolumn{4}{|c|}{I/O Modes} & \multicolumn{2}{|r|}{Abbreviated Mode} & \multicolumn{4}{|c|}{Multiplexed Mode} \\
\hline & \multicolumn{2}{|r|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=X \\
& \text { MCR5 }=0
\end{aligned}
\]} & \multicolumn{2}{|r|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=x \\
& \text { MCR5 }=1
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=0 \\
& \text { MCR5 }=1
\end{aligned}
\]} & \multicolumn{4}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR5 }=1 \\
& \text { MCR5 }=1
\end{aligned}
\]} \\
\hline & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & \multirow[b]{2}{*}{Name} & \multirow[b]{2}{*}{Type (1)} & \multirow[b]{2}{*}{Name} & \multirow[b]{2}{*}{Type (2)} & \multirow[b]{2}{*}{Name} & \multirow[b]{2}{*}{Type (3)} & \multicolumn{2}{|c|}{Phase 1} & \multicolumn{2}{|c|}{Phase 2} \\
\hline & & & & & & & Name & Type (2) & Name & Type (3) \\
\hline PDO & PD0 & INPUT & PDO & OUTPUT & DATAO & I/O & A4 & OUTPUT & DATAO & I/O \\
\hline PD1 & PD1 & INPUT & PD1 & OUTPUT & DATA1 & 1/0 & A5 & OUTPUT & DATA1 & \(1 / 0\) \\
\hline PD2 & PD2 & INPUT & PD2 & OUTPUT & DATA2 & 1/0 & A6 & OUTPUT & DATA2 & 1/0 \\
\hline PD3 & PD3 & INPUT & PD3 & OUTPUT & DATA3 & I/O & A7 & OUTPUT & DATA3 & 1/0 \\
\hline PD4 & PD4 & INPUT & PD4 & OUTPUT & DATA4 & 1/0 & A8 & OUTPUT & DATA4 & 1/0 \\
\hline PD5 & PD5 & INPUT & PD5 & OUTPUT & DATA5 & \(1 / 0\) & A9 & OUTPUT & DATA5 & \(1 / 0\) \\
\hline PD6 & PD6 & INPUT & PD6 & OUTPUT & DATA6 & I/O & A10 & OUTPUT & DATA6 & I/O \\
\hline PD7 & PD7 & INPUT & PD7 & OUTPUT & DATA7 & I/O & A11 & OUTPUT & DATA7 & I/O \\
\hline
\end{tabular}

\footnotetext{
(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
}

\section*{SECTION 5 SERIAL INPUT/OUTPUT CHANNEL}

The device provides a full duplex Serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 5-1. The serial bit rate is determined by Counter A for all modes except the Receiver Shift Register (RCVR \(S / R\) ) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5 K bits per second (@ \(\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 \(1 / O\) Port. Refer to Counter A (paragraph 6.1) for a table of hexadecimal values to represent the desired data rate.

\subsection*{5.1 TRANSMITTER OPERATION (XTMR)}

The XTMR operation and the transmitter related control/ status functions are enabled by bit 7 of the Serial Communications Control Register (SCCR). The transmitter, when in the Asynchronous (ASYN) mode, automatically adds a start bit, one or two stop bits, and, when enabled, a parity bit to the transmitted data. A word of transmitted data (in asynchronous parity mode) can have \(5,6,7\), or 8 bits of data. The nine data modes are in Figure 5-2. When parity is disabled, the \(5,6,7\) or 8 bits of data are terminated with two stop bits.


Figure 5-2. Transmitted Data Modes
In the S/R mode, eight data bits are always shifted out. Bits/ character and parity control bits are ignored. The serial data is shifted out via the SO output (PA6) and the shift clock is available at the CA (PA4) pin. When the transmitter underruns in the S/R mode the SO output and shift clock are held in a high state.

The XMTR Interrupt Flag bit (IFR7) is controlled by Serial Communication Status Register bits SCSR5, SCSR6 and SCSR7.
\[
\text { IFR7 }=\text { SCSR6 }(\overline{\text { SCSR5 }}+\text { SCSR7 })
\]

\subsection*{5.2 RECEIVER OPERATION (RCVR)}

The receiver and its selected control and status functions are enabled when SCCR-6 is set to a "1." In the ASYN mode, data format must have a start bit, appropriate number of data bits, a parity bit (if enabled) and one stop bit. Refer to paragraph 5.1 for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start bit and a strobe signal is generated at the approximate center of each incoming bit. Refer to Figure 5-3 for ASYN Receive Data Timing. The character assembly process does not start if the start bit signal is less than one-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 SCSR0-3 are true.

\subsection*{5.3 SERIAL COMMUNICATION STATUS REGISTER (SCSR)}

The Serial Communication Status Register (SCSR) holds information on various communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 5-5. Bit assignments and functions of the SCSR are as follows:

SCSRO: Receiver Data Register Full -Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by \(\overline{\text { RES }}\) and is disabled if 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 Regıster, 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 contans 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{R E S}\) 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 initıalized 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 Regıster 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 Allocation

\subsection*{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*{SECTION 6 \\ COUNTER/TIMERS}

The device contains two 16 -bit counters (Counter A and Counter B) and three 16 -bit latches associated with the counters. Counter A has one 16-bit latch and Counter B has two 16-bit latches. Each counter can be independently programmed to operate in one of four modes:

\section*{Counter A}
- Pulse width measurement
- Pulse Generatıon
- Interval Timer
- Event Counter

\section*{Counter B}
- Retriggerable Interval Counter
- Asymmetrical Pulse Generation
- Interval Timer
- Event Counter

Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4.2).

\subsection*{6.1 COUNTER A}

Counter A consists of a 16-bit counter and a 16-bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contans the count of either \(\varnothing 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 ether 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 locatıon 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.
\begin{tabular}{|c|c|l|}
\hline \begin{tabular}{c} 
MCR1 \\
(bit 1)
\end{tabular} & \begin{tabular}{l} 
MCRO \\
(bit 0)
\end{tabular} & \multicolumn{1}{c|}{ Mode } \\
\hline 0 & 0 & Interval Tımer \\
0 & 1 & Pulse Generatıon \\
1 & 0 & Event Counter \\
1 & 1 & Pulse Width Measurement \\
\hline
\end{tabular}

The Interval Tımer, Pulse Generation, and Pulse Width Measurement Modes are \(\phi 2\) clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line.

The Counter is set to the Interval Timer Mode (00) when a \(\overline{R E S}\) signal is generated.

\subsection*{6.1.1 Interval Timer}

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:
1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the \(\emptyset 2\) clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore \(1 \mu\) 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{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 IRQ interrupt request will be generated. The Counter A Underflow bit in the Interrupt Flag Register can be examined in the \(\overline{\mathrm{IRQ}}\) interrupt routine to determine that the \(\overline{\mathrm{RQ}}\) was generated by the Counter A Underflow.

While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.

\subsection*{6.1.2 Pulse Generation Mode}

In the Pulse Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs, or a write is performed to address 001A.

The normal output waveform is a symmetrical square-wave. The CA output is initialized high when entering the mode and transitions low when writing to 001A.

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

\subsection*{6.1.3 Event Counter Mode}

In this mode the CA is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the \(\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

\subsection*{6.1.4 Pulse Width Measurement Mode}

This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the \(\varnothing 2\) clock rate as long as the CA line is held in the low state. The Counter is stopped when CA is in the high state.

The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4.

A timing diagram for the Pulse Width Measurement Mode is shown in Figure 6.3.


Figure 6-3. Pulse Width Measurement

\subsection*{6.1.5 Serial I/O Data Rate Generation}

Counter A also provides clock timing for the Serial I/O which establishes the data rate for the Serial I/O port. When the Serial I/O is enabled, Counter A is forced to operate at the internal clock rate. Counter \(A\) is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4-2).

Table 6-1 identifies the values to be loaded in Counter A for selecting standard data rates with a \(\varnothing 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 MHiz or 2 MHz )
bps = the desired data rate.

\section*{NOTE}

In Table 6-1 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of \(1.5 \%\) or less are acceptable A revised clock rate is included in Table 6-1 for those baud rates which fall outside this limit.

Table 6-1. Counter A Values for Baud Rate Selection
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Standard Baud Rate} & \multicolumn{2}{|l|}{Hexadecimal Value} & \multicolumn{2}{|l|}{Actual Baud Rate At} & \multicolumn{2}{|l|}{Clock Rate Needed To Get Standard Baud Rate} \\
\hline & 1 MHz & 2 MHz & 1 MHz & 2 MHz & 1 MHz & 2 MHz \\
\hline 50 & 04E1 & 09C3 & 50.00 & 50.00 & 1.0000 & 2.0000 \\
\hline 75 & 0340 & 0682 & 75.03 & 74.99 & 1.0000 & 2.0000 \\
\hline 110 & 0237 & 046F & 110.04 & 110.04 & 1.0000 & 2.0000 \\
\hline 150 & 01A0 & 0340 & 149.88 & 150.06 & 1.0000 & 2.0000 \\
\hline 300 & 00CF & 01A0 & 300.48 & 299.76 & 1.0000 & 2.0000 \\
\hline 600 & 0067 & 00CF & 600.96 & 600.96 & 1.0000 & 2.0000 \\
\hline 1200 & 0033 & 0067 & 1201.92 & 1201.92 & 1.0000 & 2.0000 \\
\hline 2400 & 0019 & 0033 & 2403.85 & 2403.85 & 1.0000 & 2.0000 \\
\hline 3600 & 0010 & 0021 & 3676.47 & 3676.47 & 0.9792 & 1.9584 \\
\hline 4800 & 000C & 0019 & 4807.69 & 4807.69 & 1.0000 & 2.0000 \\
\hline 7200 & 0008 & 0010 & 6944.44 & 7352.94 & 1.0368 & 1.9584 \\
\hline 9600 & 0006 & 000C & 8928.57 & 9615.38 & 1.0752 & 2.000 \\
\hline
\end{tabular}

\subsection*{6.2 COUNTER B}

Counter B consists of a 16 -bit counter and two 16 -bit latches organized as follows: Lower Counter B (LCB), Upper Counter B (UCB), Lower Latch B (LLB), Upper Latch B (ULB), Lower Latch C (LLC), and Upper Latch C (ULC). Latch C is used only in the asymmetrical pulse generation mode. The counter contains the count of either \(\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 \(\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.

\subsection*{6.2.1 Retriggerable Interval Timer Mode}

When operating in the Retriggerable Interval Timer mode, Counter B is initialized to the latch value by writing to address 001E, by a Counter B underflow, or whenever a positive edge occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the CB line. Figure 6-4 illustrates the operation.


Figure 6-4. Counter B Retriggerable Interval Timer Mode

\subsection*{6.2.2 Asymmetrical Pulse Generation Mode}

Counter B has a special Asymmetrical Pulse Generation Mode whereby a pulse train with programmable pulse width and period can be generated without the processor intervention once the latch values are initialized.

In this mode, the 16 -bit Latch \(B\) is initialized with a value which corresponds to the duration between pulses (referred to as \(D\) in the following descriptions). The 16 -bit Latch \(C\) is initialized with a value which corresponds to the desired pulse width (referred to as \(P\) in the following descriptions). The initialization sequence for Latch B and C and the starting of a counting sequence are as follows:
1. The lower 8 bits of \(P\) are loaded into LLB by writing to address 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 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.

\title{
SECTION 7 \\ POWER ON/INITIALIZATION CONSIDERATIONS
}

\subsection*{7.1 POWER-ON TIMING}

After applications of \(V_{C C}\) and \(V_{R R}\) power to the device, \(\overline{\text { RES }}\) must be held low for at least eight \(\emptyset 2\) clock cycles after \(V_{c c}\) reaches operating range and the interal oscillator has stabilized. This stabilization time is dependent upon the input \(\mathrm{V}_{\mathrm{CC}}\) voltage and performance of the internal oscillator. The clock can be monitored at \(\emptyset 2\) (pin 3). Figure 7-1 illustrates the power turn-on waveforms. Clock stabilization time is typically 20 ms .


Figure 7-1. Power Turn-on Timing Detail

\subsection*{7.2 POWER-ON RESET}

The occurrence of \(\overline{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 (PA, PB, PC, PD) will be forced to the high (logic 1) state. All bits of the Control Register will be cleared to logic 0 causing the Interval Timers counter mode (mode 00) to be selected and causing all interrupt enabled bits to be reset.


Figure 6-5. Counter B Pulse Generation

\subsection*{7.3 RESET ( \(\overline{\operatorname{RES}})\) CONDITIONING}

When \(\overline{\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
\begin{tabular}{|lcccccccc|}
\hline & \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline Registers & & & & & & & & \\
\(\quad\) Processor Status & - & - & - & - & - & 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 \\
\hline
\end{tabular}

All RAM and other CPU registers will initialize in a random, non-repeatable data pattern.

\subsection*{7.4 INITIALIZATION}

Any initialization process for the device should include a \(\overline{\text { RES, }}\), as indicated in the preceding paragraphs. After stabilization of the internal clock (if a power on situation) an initialization subroutine should be executed to perform (as a minimum) the following functions:
1. The Stack Pointer should be set
2. Clear or Set Decimal Mode
3. Set or Clear Carry Flag
4. Set up Mode Controls as required
5. Clear Interrupts

A typıcal initıalization subroutine could be as follows:
LDX Load stack pointer starting address into \(X\) Register
TXS Transfer X Register value to Stack Pointer
CLD Clear Decımal Mode
SEC Set Carry Flag
Set-up Mode Control and special function
. . . . . registers as required
CLI Clear Interrupts

\title{
APPENDIX A ENHANCED R6502 INSTRUCTION SET
}

\begin{abstract}
This appendix contains a summary of the R6502 instruction set. For detailed information, consult the R6502 Microcomputer System Programming Manual, Order No. 202. The four instructions notated with a * are added instructions to enhance the standard 6502 instruction set.
\end{abstract}

\section*{A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE}
\begin{tabular}{llll} 
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 & \begin{tabular}{l} 
Shift One Bit Right (Memory or
\end{tabular} \\
"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
\end{tabular}


\section*{A. 3 INSTRUCTION CODE MATRIX}


*Add 1 to N if page boundary is crossed
**Add 1 to N if branch occurs to same page, add 2 to N if branch occurs to different page.

\section*{APPENDIX B \\ KEY REGISTER SUMMARY}


CPU Registers


Mode Control Register


\section*{Interrupt Enable and Flag Registers}


XMTR Under-Run
Serial Communications Status Register

\section*{APPENDIX C \\ ADDRESS ASSIGNMENTS/MEMORY MAPS/PIN FUNCTIONS}

\section*{C. 1 I/O AND INTERNAL REGISTER ADDRESSES}
\begin{tabular}{|c|c|c|}
\hline ADDRESS (HEX) & READ & WRITE \\
\hline \[
\begin{array}{r}
001 \mathrm{~F} \\
1 \mathrm{E} \\
1 \mathrm{D} \\
1 \mathrm{C}
\end{array}
\] & Lower Counter B Upper Counter B 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 \\
\hline \[
\begin{aligned}
& 1 \mathrm{~B} \\
& 1 \mathrm{~A} \\
& 19 \\
& 18
\end{aligned}
\] & \begin{tabular}{l}
Lower Counter A \\
Upper Counter A Lower Counter A, CLR Flag
\end{tabular} & \begin{tabular}{l}
Upper Latch A, Cntr A Latch A, CLR Flag Upper Latch A \\
Lower Latch A
\end{tabular} \\
\hline \[
\begin{aligned}
& 17 \\
& 16 \\
& 15 \\
& 14
\end{aligned}
\] & Serial Receiver Data Register Serial Comm. Status Register Serial Comm. Control Register Mode Control Register & \begin{tabular}{l}
Serial Transmitter Data Register \\
Serial Comm Status Reg Bits 4 \& 5 only \\
Serial Comm. Control Register \\
Mode Control Register
\end{tabular} \\
\hline \[
\begin{array}{r}
13 \\
12 \\
11 \\
0010
\end{array}
\] & Interrupt Enable Register Interrupt Flag Register Read FF & \begin{tabular}{l}
Interrupt Enable Register \\
Clear Int Flag (Bits 0-3 only, Write O's only)
\end{tabular} \\
\hline \[
\begin{aligned}
& O F \\
& O E \\
& O D \\
& O C
\end{aligned}
\] &  &  \\
\hline \[
\begin{aligned}
& \mathrm{OB} \\
& 0 A \\
& 09 \\
& 08
\end{aligned}
\] & \[
\begin{aligned}
& -= \\
& -= \\
& -=
\end{aligned}
\] &  \\
\hline \[
\begin{aligned}
& \hline 07 \\
& 06 \\
& 05 \\
& 04 \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
Port G* \\
Port F* \\
Port E *
\end{tabular} & \begin{tabular}{l}
Port G* \\
Port F* \\
Port E*
\end{tabular} \\
\hline \[
\begin{array}{r}
03 \\
02 \\
01 \\
0000
\end{array}
\] & \begin{tabular}{l}
Port D \\
Port C \\
Port B \\
Port A
\end{tabular} & \begin{tabular}{l}
Port D \\
Port C \\
Port B \\
Port A
\end{tabular} \\
\hline
\end{tabular}

NOTE• *R6500/12Q or /16Q only.

\section*{C. 2 ABBREVIATED MODE MEMORY MAP}


\section*{C. 3 MULTIPLEXED MODE MEMORY MAP}


\section*{C. 4 MULTIPLE FUNCTION PIN ASSIGNMENTS—PORT C AND PORT D}
\begin{tabular}{|c|c|c|c|}
\hline \begin{tabular}{c} 
PIN \\
NUMBER
\end{tabular} & \begin{tabular}{c} 
I/O PORT \\
FUNCTION
\end{tabular} & \begin{tabular}{c} 
ABBREVIATED PORT \\
FUNCTION
\end{tabular} & \begin{tabular}{c} 
MULTIPLEXED PORT \\
FUNCTION
\end{tabular} \\
\hline 4 & PCO & A0 & AO \\
5 & PC1 & A1 & A1 \\
6 & PC2 & A2 & A2 \\
7 & PC3 & A3 & A3 \\
\hline 8 & PC4 & A12 & A12 \\
9 & PC5 & R/W & R/W \\
10 & PC6 & A13 & A13 \\
11 & PC7 & EMS & EMS \\
\hline 19 & PD0 & D0 & A4/D0 \\
18 & PD1 & D1 & A5/D1 \\
17 & PD2 & D2 & A6/D2 \\
16 & PD3 & D3 & A7/D3 \\
\hline 15 & PD4 & \(D 4\) & A8/D4 \\
14 & PD5 & D5 & A9/D5 \\
13 & PD7 & D6 & A10/D6 \\
12 & & D7 & A11/D7 \\
\hline
\end{tabular}

\title{
APPENDIX D \\ ELECTRICAL SPECIFICATIONS
}

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}} \& \mathrm{~V}_{\text {RR }}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{c} 
Operating Temperature \\
Commercial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
\(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
0 to +70
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

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

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{R R}=V_{C C} ; V_{S S}=0 V ; T_{A}=0^{\circ}\right.\) to \(70^{\circ}\), unless otherwise specified \()\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline RAM Standby Voltage (Retention Mode) & \(\mathrm{V}_{\text {RR }}\) & 3.0 & & \(\mathrm{V}_{\mathrm{cc}}\) & V & \\
\hline RAM Standby Current (Retention Mode) & \(\mathrm{I}_{\text {RR }}\) & - & 4 & - & mA & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline \begin{tabular}{l}
Input High Voltage \\
All Except XTLI and \(\emptyset 2\) in Slave Option XTLI and \(\emptyset 2\) in Slave Option
\end{tabular} & \(\mathrm{V}_{\mathrm{IH}}\) & \[
\begin{aligned}
& +2.0 \\
& +4.0 \\
& \hline
\end{aligned}
\] & - & \[
\begin{array}{r}
\mathrm{V}_{\mathrm{cc}} \\
\mathrm{v}_{\mathrm{cc}} \\
\hline
\end{array}
\] & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\text {IL }}\) & -0.3 & - & +0.8 & V & \\
\hline Input Leakage Current \(\overline{R E S}, \overline{N M I}\) & IN & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IN}}=0\) to 5.0 V \\
\hline Input Low Current
\[
\mathrm{PA}, \mathrm{~PB}, \mathrm{PC}, \mathrm{PD}, \mathrm{PF}^{3}, \mathrm{PG}^{3}
\] & \(1 /\) & - & -1.0 & -1.6 & mA & \(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage (Except XTLO) & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & \(\mathrm{V}_{\mathrm{cc}}\) & V & \(\mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A}\) \\
\hline Output Low Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & +0.4 & V & \(\mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}\) \\
\hline I/O Port Pull-Up Resistance PAO-PA7, PB0-PB7, PC0-PC7, PF0-PF73, PG0-PG73 & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Output Leakage Current (Three-State Off) & lout & - & - & \(\pm 10\) & \(\mu \mathrm{A}\) & \\
\hline \begin{tabular}{l}
Input Capacitance XTLI, XTLO \\
\(\mathrm{PA}, \mathrm{PB}, \mathrm{PC}, \mathrm{PD}, \mathrm{PF}^{3}, \mathrm{PG}^{3}\)
\end{tabular} & \(\mathrm{C}_{\text {IN }}\) & - & - & \[
\begin{aligned}
& 50 \\
& 10 \\
& \hline
\end{aligned}
\] & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& V_{I N}=0 \mathrm{~V} \\
& f=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) & \(\mathrm{C}_{\text {OUT }}\) & - & - & 10 & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& V_{I N}=0 \mathrm{~V} \\
& f=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Outputs High) & \(P_{D}\) & - & - & 1200 & mW & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\). \\
2. Negative sign indicates outward current flow, positive indicates inward flow. \\
3. R6500/12Q and R6500/16Q only.
\end{tabular}} \\
\hline
\end{tabular}

\section*{APPENDIX E \\ TIMING REQUIREMENTS AND CHARACTERISTICS}

\section*{E. 1 GENERAL NOTES}
1. \(\mathrm{V}_{\mathrm{cc}}=5 \mathrm{~V} \pm 5 \%, 0^{\circ} \mathrm{C} \leqslant \mathrm{TA} \leqslant 70^{\circ} \mathrm{C}\)
2. \(A\) valid \(V_{c c}-\overline{R E S}\) sequence is required before proper operation is achieved.
3. All tıming 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 maxımum, except as noted below:

PA, PB
- 50pf maximum

PC (I/O Modes Only) - 50pf maxımum
PC (ABB and Mux Mode) - 130pf maximum
PC6, PC7 (Full Address Mode) - 130pf maximum

\section*{E. 2 CLOCK TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\mathrm{crc}}\) & Cycle Time & 1000 & \(10 \mu \mathrm{~s}\) & 500 & \(10 \mu \mathrm{~s}\) \\
\hline \(\mathrm{T}_{\text {Pwx1 }}\) & XTLI Input Clock Pulse Width XTLO = VSS & \[
\begin{gathered}
500 \\
\pm 25
\end{gathered}
\] & - & \[
\begin{aligned}
& 250 \\
& \pm 10
\end{aligned}
\] & - \\
\hline \(\mathrm{T}_{\text {Pwo }}\) & Output Clock Pulse Width at Minimum \(\mathrm{T}_{\mathrm{crc}}\) & \(\mathrm{T}_{\text {Pwx1 }}\) & \[
\begin{aligned}
& T_{p w x_{1}} \\
& \pm 25
\end{aligned}
\] & \(\mathrm{T}_{\text {Pwx1 }}\) & \[
\begin{aligned}
& T_{p w \times 1} \\
& \pm 20
\end{aligned}
\] \\
\hline \(\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}\) & Output Clock Rise, Fall Time & - & 25 & - & 15 \\
\hline \(\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}\) & Input Clock Rise, Fall Time & - & 10 & - & 10 \\
\hline
\end{tabular}


\section*{E. 3 ABBREVIATED MODE TIMING-PC AND PD}
(MCR \(5=1\), MCR \(6=0\), MCR \(7 \stackrel{=}{=}\) )
\begin{tabular}{|l|l|c|c|c|c|}
\hline \multirow{2}{*}{ SYMBOL } & \multicolumn{1}{|c|}{ PARAMETER } & \multicolumn{2}{|c|}{\(\mathbf{1}\) MHz } & \multicolumn{2}{|c|}{\(\mathbf{2}\) MHz } \\
\cline { 3 - 6 } & & MIN & MAX & MIN & MAX \\
\hline\(T_{\text {PCAS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline\(T_{\text {PCAS }}\) & (PC0-PC4, PC6) Address Setup Time & - & 200 & - & 140 \\
\hline\(T_{\text {PBSU }}\) & (PD) Data Setup Time & 50 & - & 35 & - \\
\hline\(T_{\text {PBHR }}\) & (PD) Data Read Hold Time & 10 & - & 10 & - \\
\hline\(T_{\text {PBHW }}\) & (PD) Data Write Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {PBOD }}\) & (PD) Data Output Delay & - & 175 & - & 130 \\
\hline\(T_{\text {PCHA }}\) & (PC0-PC4, PC6) Address Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline\(T_{\text {PCHV }}\) & (PC7) EMS Hold Time & 10 & - & 10 & - \\
\hline\(T_{\text {PCVD }}{ }^{\text {(1) }}\) & (PC7) Address to EMS Delay Time & 30 & 220 & 30 & 130 \\
\hline\(T_{\text {PCVP }}\) & (PC7) \(\overline{\text { EMS Stabilization Time }}\) & 30 & - & 30 & - \\
\hline
\end{tabular}

NOTE 1 Values assume PC0-PC4, PC6 and PC7 have the same capacitive load.

\section*{E.3.1 Abbreviated Mode Timing Diagram}


\section*{E. 4 MULTIPLEXED MODE TIMING—PC AND PD}
(MCR \(5=1\), MCR \(6=1\), MCR \(7=1\) )
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {PCAS }}\) & (PC0-PC4, PC6) Address Setup Tıme & - & 200 & - & 140 \\
\hline \(\mathrm{T}_{\text {PBAS }}\) & (PD) Address Setup Time & - & 220 & - & 120 \\
\hline \(\mathrm{T}_{\text {PBSU }}\) & (PD) Data Setup Time & 50 & - & 35 & - \\
\hline \(\mathrm{T}_{\text {PBHR }}\) & (PD) Data Read Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PBнW }}\) & (PD) Data Write Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PBDD }}\) & (PD) Data Output Delay & - & 175 & - & 140 \\
\hline \(\mathrm{T}_{\text {PCHA }}\) & (PC0-PC4, PC6) Address Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PBHA }}\) & (PD) Address Hold Tıme & 40 & 100 & 40 & 80 \\
\hline \(\mathrm{T}_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\mathrm{PCHV}}\) & (PC7) EMS Hold Tıme & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PCVD }}{ }^{(1)}\) & (PC7) Address to EMS Delay Time & 30 & 200 & 30 & 150 \\
\hline \(\mathrm{T}_{\text {Pcvp }}\) & (PC7) EMS Stabilizatıon Time & 30 & - & 30 & - \\
\hline
\end{tabular}

NOTE 1. Values assume PDO-PD7 and PC7 have the same capactive load.

\section*{E.4.1 Multiplex Mode Timing Diagram}


\section*{E. 5 I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \begin{tabular}{l}
\(T_{\text {pow }}{ }^{\text {(1) }}\) \\
\(\mathrm{T}_{\text {смоs }}{ }^{\text {(1) }}\) \\
\(T_{\text {PDow }}\)
\end{tabular} & Internal Write to Peripheral Data Valid PA, PB, PC, PE, PF, PG, TTL PA, PB, PC, PE, PF, PG, CMOS PD & Z & \[
\begin{array}{r}
500 \\
1000 \\
175 \\
\hline
\end{array}
\] & - & \[
\begin{array}{r}
500 \\
1000 \\
150 \\
\hline
\end{array}
\] \\
\hline \(T_{\text {posu }}\)
\(T_{\text {posu }}\) & Peripheral Data Setup Time PA, PB, PC, PF, PG PD & \[
\begin{array}{r}
200 \\
50
\end{array}
\] & 二 & \[
\begin{array}{r}
200 \\
50
\end{array}
\] & - \\
\hline \[
\begin{aligned}
& T_{\text {PHA }} \\
& 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}
\] & - \\
\hline \(\mathrm{T}_{\text {EPW }}\) & PA0-PA3 Edge Detect Pulse Width & \(\mathrm{T}_{\mathrm{crc}}\) & - & Tcrc & - \\
\hline \[
\begin{aligned}
& T_{\text {cPW }} \\
& T_{\text {cD }}{ }^{(1)}
\end{aligned}
\] & \begin{tabular}{l}
Counters A and B \\
PA4, PA5 Input Pulse Width PA4, PA5 Output Delay
\end{tabular} & Terc & \[
\overline{500}
\] & Tcrc & 500 \\
\hline \begin{tabular}{l}
\(\mathrm{T}_{\text {peLw }}\) \\
\(T_{\text {plsu }}\) \\
\(\mathrm{T}_{\text {рвLн }}\)
\end{tabular} & Port B Latch Mode PAO Strobe Pulse Width PB Data Setup Time PB Data Hold Time & \[
\begin{array}{r}
T_{\text {cre }} \\
175 \\
30
\end{array}
\] & 二 & \[
\begin{array}{r}
T_{\text {cre }} \\
150 \\
30
\end{array}
\] & - \\
\hline & Serial I/0 & & & & \\
\hline \(\mathrm{T}_{\text {Pow }}{ }^{(1)}\) & PA6 XMTR TTL & - & 500 & - & 500 \\
\hline T \(\mathrm{cmos}^{(1)}\) & PA6 XMTR CMOS & - & 1000 & - & 1000 \\
\hline \(\mathrm{T}_{\text {cpw }}\) & PA4 RCVR S/R Clock Width & \(4 \mathrm{~T}_{\text {crc }}\) & - & 4 Tcrc & - \\
\hline \(\mathrm{T}_{\text {Pow }}{ }^{(1)}\) & PA4 XMTR Clock-S/R Mode (TTL) & , & 500 & & 500 \\
\hline \(\mathrm{T}_{\text {смоя }}{ }^{\text {(1) }}\) & PA4 XMTR Clock-S/R Mode (CMOS) & - & 1000 & - & 1000 \\
\hline
\end{tabular}

\footnotetext{
NOTE 1: Maximum Load Capacitance: 50pF Passive Pull-Up Required
}

\section*{E.5.1 I/O, Edge Detect, Counter, and Serial I/O Timing}


\section*{R65/11EB AND R65/11EAB BACKPACK EMULATORS}

\section*{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. 29651N23, 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.

\section*{ORDERING INFORMATION}

Backpack Emulator
\begin{tabular}{|c|c|c|c|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Memory \\
Capacity
\end{tabular} & \begin{tabular}{c} 
Compatible \\
Memories
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range and Speed
\end{tabular} \\
\hline R65/11EB & \(4 \mathrm{~K} \times 8\) & 2732 & \(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
1 MHz \\
R65/11EAB & \(4 \mathrm{~K} \times 8\) & 2732 A & \begin{tabular}{c}
\(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
2 MHz
\end{tabular} \\
\hline
\end{tabular}

Support Products
\begin{tabular}{|l|l|}
\hline \multicolumn{1}{|c|}{\begin{tabular}{c} 
Part \\
Number
\end{tabular}} & Description \\
\hline S65-101 & \begin{tabular}{l} 
SYSTEM 65 Microcomputer \\
Development System
\end{tabular} \\
M65-040 & PROM Programmer Module \\
M65-131 & \(1-\mathrm{MHz}\) R6500/11 Personality Module \\
M65-132 & \(2-\mathrm{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) \\
\hline
\end{tabular}

\section*{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

\section*{CONFIGURATIONS}

The Backpack Emulator is available in two different versions, to accommodate 1 MHz and 2 MHz speeds. Both versions provide 192 bytes of RAM and I/O, as well as 24 signals to support the external memory "backpack" socket.

The emulator will relocate the EPROM address space to FXXX (see Memory Map). EPROM addresses FFA through FFF must contain the interrupt vectors.

\section*{EXTERNAL FREQUENCY REFERENCE}

The external frequency reference may be a crystal or a clock-the 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.

\section*{I/O PORT PULLUPS}

The devices have internal I/O port pullup resistors on ports \(\mathrm{A}, \mathrm{B}, \& \mathrm{C}\). Port D has push-pull drivers.

\section*{PRODUCT SUPPORT}

The Backpack Emulator is just one of the products that Rockwell offers to facilitate system and program development for the R6500/11.

The 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
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline XTLO & \[
\bullet_{1}
\] & \[
\begin{aligned}
& \text { A7 } \\
& \text { A6 }
\end{aligned}
\] & \[
\begin{array}{r}
\theta_{1 s} \\
2 s
\end{array}
\] & \[
\begin{aligned}
& 24 s \\
& 23 s
\end{aligned}
\] & \[
\overline{\mathrm{F}} \mathrm{cc}
\] & \[
40
\] & & \multirow[t]{2}{*}{\begin{tabular}{l}
\(V_{S S}\) \\
\(V_{R R}\) \\
PB0
\end{tabular}} & \multicolumn{3}{|r|}{BACKPACK MEMORY SIGNAL} \\
\hline \(\phi 2\) & 3 & A5 & 3s & 22s & -A9 & 38 & & & Signal & & \\
\hline PC0 & 4 & A4 5 & 4s & 21 s & A11 & 37 & \(\square\) & PB1 & Name & Pin No. & Description \\
\hline PC1 & 5 & A3 & 5 s & 20s & TOE & 36 & \(\square\) & PB2 & & & \\
\hline PC2 & 6 & A2 \(\square\) & 6 s & 19s & A10 & 35 & \(\square\) & PB3 & D0-D7 & \[
9 \mathrm{~S}-11 \mathrm{~S},
\] & Data Bus Lines. All instruction and data \\
\hline PC3 & 7 & A1 & 7 s & 18s & ¢CE & 34 & \(\square\) & PB4 & & \[
13 S-17 S
\] & transfers take place on the data bus lines. \\
\hline PC4 & 8 & A0 & 8 s & 17s & -D7 & 33 & ] & PB5 & & & The buffers driving the data bus lines have \\
\hline PC5 & 9 & D0 & 9s & 16 s & -D6 & 32 & \(\square\) & PB6 & & & full three-state capability. Each data bus \\
\hline PC6 & 10 & D1 & 10s & 15s & PD5 & 31 & & PB7 & & & pin is connected to an input and an output \\
\hline PC7 & 11 & D2 & 11 s & 14s & -D4 & 30 & \(\square\) & PAO & & & buffer, with the output buffer remaining in \\
\hline PD7 & 12 & \(\mathrm{V}_{\mathbf{s s}}\) & 12 s & 13s & D3 & 29 & \(\square\) & PA1 & & & the floating condition. \\
\hline PD6 & 13 & & & & & 28 & \(\square\) & PA2 & A0-A7 & 1S-8S, & Address Bus Lines. The address bus lines \\
\hline PD5 & 14 & & 24-PIN & CKET & & 27 & \(\square\) & PA3 & A8, A9 & 23S, 24S & are buffered by push/pull type drivers that \\
\hline PD4 & 15 & & & & & 26 & & PA4 & A10 & 19S & can drive one standard TTL load. \\
\hline PD3 & 16 & & & & & 25 & \(\square\) & PA5 & A11 & 21 S & \\
\hline PD2 & 17 & & , & & & 24 & 1 & PA6 & \(\overline{C E}\) & 18S & Chip Enable. \(\overline{\mathrm{CE}}\) is active when the address \\
\hline PD1 & 18 & & & & & 23 & & PA7 & & & is 8000-FFFF. This line can drive one TTL \\
\hline PDO & 19 & & & & & 22 & I & NMI & & & load. \\
\hline RES & 20 & & & & & 21 & I & V cc & \(\overline{O E}\) & 20 S & Memory Enable Line. This signal provides \\
\hline & & & in Con & urat & ion & & & & & & the output enable for the memory to place information on the data bus lines. This signal is driven by an inverted \(\mathrm{R} / \overline{\mathrm{W}}\) signal from the CPU. It can drive 1 TL load. \\
\hline & & & & & & & & & \(\mathrm{V}_{\mathrm{Cc}}\) & 24S & Main Power Supply +5 V . This pin is tied directly to pin \(21\left(\mathrm{~V}_{\mathrm{CC}}\right)\). \\
\hline & & & & & & & & & \(\mathrm{V}_{\text {SS }}\) & 12 S & Signal and Power Ground (zero volts). This pin is tied directly to pin \(40\left(\mathrm{~V}_{\mathrm{SS}}\right)\). \\
\hline
\end{tabular}

\section*{I/O AND INTERNAL REGISTER ADDRESSES}
\begin{tabular}{|c|c|c|}
\hline Address (Hex) & Read & Write \\
\hline 001 F & - - & - - \\
\hline 1E & Lower Counter B & Upper Latch B, Cntr B↔Latch B, CLR Flag \\
\hline 1D & Upper Counter B & Upper Latch B, Latch C \(\leftarrow\) Latch B \\
\hline 1 C & Lower Counter B, CLR Flag & Lower Latch B \\
\hline 1B & -- & -- \\
\hline 1A & Lower Counter A & Upper Latch A, Cntr A Latch A, CLR Flag \\
\hline 19 & Upper Counter A & Upper Latch A \\
\hline 18 & Lower Counter A, CLR Flag & Lower Latch A \\
\hline 17 & Serial Receiver Data Register & Serial Transmitter Data Register \\
\hline 16 & Serial Comm. Status Register & Serial Comm. Status Reg. Bits 4 \& 5 only \\
\hline 15 & Serial Comm. Control Register & Serial Comm. Control Register \\
\hline 14 & Mode Control Register & Mode Control Register \\
\hline 13 & - - & - - \\
\hline 12 & Interrupt Enable Register & Interrupt Enable Register \\
\hline 11 & Interrupt Flag Register & - \\
\hline 0010 & Read FF & Clear Int Flag (Bits 0-3 only, Write O's only) \\
\hline 04 thru OF & - - & - - \\
\hline 03 & Port D & Port D \\
\hline 02 & Port C & Port C \\
\hline 01 & Port B & Port B \\
\hline 0000 & Port A & Port A \\
\hline
\end{tabular}

READ TIMING CHARACTERISTICS
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min. & Max. & Min. & Max. & \\
\hline \(\overline{O E}\) and \(\overline{C E}\) setup time from CPU & Toes & - & 225 & - & 140 & ns \\
\hline Address setup time from CPU & \(\mathrm{T}_{\text {ADS }}\) & - & 225 & - & 140 & ns \\
\hline Memory read access time & \(T_{\text {ACC }}\) & - & 700 & - & 315 & ns \\
\hline Data set up time & T \({ }_{\text {dSU }}\) & 50 & - & 35 & - & ns \\
\hline Data hold time-Read & \(\mathrm{T}_{\mathrm{HR}}\) & 10 & - & 10 & - & ns \\
\hline Address hold time & \(\mathrm{T}_{\mathrm{HA}}\) & 30 & - & 30 & - & ns \\
\hline \(\overline{\mathrm{OE}}\) and \(\overline{\mathrm{CE}}\) hold time & Thoe & 30 & - & 30 & - & ns \\
\hline Cycle Time & \(\mathrm{T}_{\mathrm{CrC}}\) & 1.0 & 10.0 & 0.5 & 10.0 & \(\mu \mathrm{s}\) \\
\hline
\end{tabular}

\section*{READ TIMING WAVEFORMS}



\section*{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)\)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Characteristic & Symbol & Min & Typ & Max & Unit \\
\hline Input High Threshold Voltage
D0-D7 & \(\mathrm{V}_{\mathrm{IHT}}\) & \(\mathrm{V}_{\mathrm{ss}}+2.0\) & - & - & Vdc \\
\hline Input Low Threshold Voltage D0-D7 & \(V_{\text {ILT }}\) & - & - & \(\mathrm{V}_{\mathrm{ss}}+0.8\) & Vdc \\
\hline 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{D} 0-\mathrm{D} 7
\end{aligned}
\] & \(\mathrm{I}_{\text {TSI }}\) & - & - & \(\pm 10\) & \(\mu \mathrm{A}\) \\
\hline \begin{tabular}{l}
Output High Voltage
\[
\left(I_{\text {LOAD }}=100 \mu \text { Adc, } V_{C C}=4.75 \mathrm{~V}\right)
\] \\
D0-D7, A0-A11, \(\overline{O E}, \overline{C E}\)
\end{tabular} & \(\mathrm{V}_{\text {OH }}\) & \(\mathrm{V}_{\mathrm{ss}}+2.4\) & - & - & Vdc \\
\hline \[
\begin{aligned}
& \text { Output Low Voltage } \\
& \text { (I } I_{\text {LOAD }}=1.6 \mathrm{mAdc}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \text { ) } \\
& \text { DO-D7, A0-A11, OE, } \mathrm{CE}
\end{aligned}
\] & \(\mathrm{V}_{\text {OL }}\) & V
- & - & \(\mathrm{V}_{\mathrm{ss}}+0.4\) & Vdc \\
\hline Power Dissipation (less EPROM) & \(\mathrm{P}_{\mathrm{D}}\) & - & 0.80 & 1.20 & W \\
\hline \begin{tabular}{l}
Capacitance
\[
\left(\mathrm{V}_{\mathrm{In}}=0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right)
\] \\
D0-D7 (High Impedance State) Input Capacitance
\end{tabular} & \begin{tabular}{l}
C \\
\(\mathrm{C}_{\text {out }}\) \\
\(\mathrm{C}_{\text {In }}\)
\end{tabular} & - & - & \[
\begin{array}{r}
10 \\
10 \\
\hline
\end{array}
\] & pF \\
\hline I/O Port Pull-up Resistance & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & kohm \\
\hline
\end{tabular}


\section*{R6511Q and R6500/13 ONE-CHIP MICROPROCESSOR and ONE-CHIP MICROCOMPUTER}

\section*{SECTION 1 \\ INTRODUCTION}

\subsection*{1.1 FEATURES}
- Enhanced 6502 CPU
-Four new bit manipulation instructions
- Set Memory Bit (SMB)
- Reset Memory Bit (RMB)
- Branch on Bit Set (BBS)
- Branch on Bit Reset (BBR)
-Decimal and binary arithmetic modes
- 13 addressing modes
—True indexing
- 256-byte mask-programmable ROM or no ROM*
- 192-byte static RAM
- 32 bıdirectional, 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/tımers, with latches
-Pulse width measurement
-Asymmetrical pulse generation
-Pulse generation
-Interval timer
-Event counter
-Retriggerable interval timer
- Serial port
-Full-duplex asynchronous operation mode
-Selectable 5- to 8 -bit characters
-Wake-up feature
-Synchronous shift register mode
-Standard programmable bit rates programmable up to 62.5 K bits \(/ \mathrm{sec} @ 1 \mathrm{MHz}\)
- Ten interrupts
-Four edge-sensitive lines; two positive, two negative
-Reset
-Non-maskable
-Two counter underflows
-Serial data received
-Serial data transmitted
- Bus expandable to 64 K bytes of external memory
*R6511Q has no ROM.
- Flexible clock circuitry
\(-2-\mathrm{MHz}\) or \(1-\mathrm{MHz}\) internal operation
-Internal clock with external XTAL at two or four times internal frequency
-External clock input divided by one, two or four
- \(1 \mu \mathrm{~s}\) minımum instruction execution tıme @ 2 MHz
- NMOS-3 silicon gate, depletion load technology
- Single +5 V power supply
- 12 mW stand-by power for 32 bytes of the 192-byte RAM
- 64-pIn QUIP

\section*{NOTE}

This document uses the term R6500/13 to describe both parts. See section 1.3 for a description of the options available when using the R6500/13 and the fixed features of the R6511Q.

\subsection*{1.2 SUMMARY}

The Rockwell R6500/13 is a complete, high-performance 8 -bit NMOS-3 microcomputer on a single chip and is compatible with all members of the R6500 family.

The R6500/13 consists of an enhanced 6502 CPU, an internal clock oscillator, an optional 256 bytes of Read-Only Memory, 192 bytes of Random Access Memory (RAM) and versatile interface circuitry. The interface circuitry includes two 16-bit programmable timer/counters, 32 bidirectional input/output lines (includıng 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 contans 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 contanned in the R6500 Microcomputer System Programming Manual (Document Number 29650N30).

\subsection*{1.3 CUSTOMER OPTIONS}

The R6500/13 microcomputer is available with the following customer specified mask options.
- Option 1 Crystal or RC oscillator
- Option 2 Clock divide by 2 or 4
- Option 3 Clock MASTER Mode or SLAVE Mode
- Option 4 with or without a 256 byte ROM
- Option 5 Reset Vector at FFFC or 7FFF
- Option 6 Port A with or without internal pull-up resistors
- Option 7 Port B with or without internal pull-up resistors
- Option 8 Port C with or without internal pull-up resistors

All options should be specified on an R6500/13 order form.
The R6511Q has no customer specified mask options. It has the following characteristics.
- Crystal Oscillator
- Clock Divide by 2
- Clock MASTER Mode
- Without ROM
- Reset Vector at FFFC
- No internal pull-up resistors or any Port (PA, PB, or PC)


Figure 2-1. Mechanical Outline \& Pin Out Configuration

\section*{SECTION 2 \\ INTERFACE REQUIREMENTS}

This section describes the interface requirements for the R6511Q and R6500/13. Figure 2-1 and 2-2 show the Interface Diagram and the pin out configuration for both devices. Table 2-1 describes the function of each pin. Figure 3-1 has a detailed block diagram of the R6500/13 ports which illustrates the internal function of the device.


Figure 2-2. Interface Diagram

Table 2-1. R6500/13 Pin Descriptions
\begin{tabular}{|c|c|c|}
\hline Signal Name & Pin No. & Description \\
\hline \(V_{c c}\) & 21 & Main power supply +5V \\
\hline \(V_{\text {RR }}\) & 43 & Separate power pin for RAM. In the event that \(\mathrm{V}_{\mathrm{cc}}\) power is off, this power retains RAM data. \\
\hline \(V_{\text {ss }}\) & 44 & Signal and power ground (0V) \\
\hline XTLI & 42 & Crystal or clock input for internal clock oscillator. Also allows input of X1 clock signal if XTLO is connected to \(\mathrm{V}_{\mathrm{ss}}\), or X 2 or X 4 clock if XTLO is floated. \\
\hline XTLO & 41 & Crystal output from internal clock oscillator. \\
\hline \(\overline{\text { RES }}\) & 6 & The Reset input is used to initialize the device. This signal must not transition from low to high for at least eight cycles after \(\mathrm{V}_{\mathrm{cc}}\) reaches operating range and the internal oscillator has stabilized. \\
\hline \(\phi 2\) & 45 & Clock signal output at internal frequency. \\
\hline \(\overline{\mathrm{NMI}}\) & 23 & A negative going edge on the Non-Maskable Interrupt signal requests that a nonmaskable interrupt be generated with the CPU. \\
\hline \[
\begin{aligned}
& \text { PAO-PA7 } \\
& \text { PBO-PB7 }
\end{aligned}
\] & \[
\begin{aligned}
& 39-32 \\
& 31-24
\end{aligned}
\] & Four 8-bit ports used for either input/output. Each line \\
\hline PC0-PC7 & 54-61 & of Ports A, B and C consists \\
\hline PD0-PD7 & \[
\begin{gathered}
62-64 \\
1-5
\end{gathered}
\] & of an active transistor to \(\mathrm{V}_{\mathrm{ss}}\) and an optional passive pullup to \(\mathrm{V}_{\mathrm{cc}}\). In the abbreviated or multiplexed modes of operation Port C has an active pull-up transistor. Port D functions as either an 8 -bit input or 8 -bit output port. It has active pull-up and pulldown transistors. \\
\hline A0-A12, A15 & 20-7 & Fourteen address lines used to address a complete 65 K external address space. Note: A13 \& A14 are sourced through PC6 \& PC7 when in the Full Address Mode. \\
\hline DB0-DB7 & 53-46 & Eight bidirectional data bus lines used to transmit data to and from external memory. \\
\hline SYNC & 22 & SYNC is a positive going signal for the full clock cycle whenever the CPU is performing an OP CODE fetch. \\
\hline \(\mathrm{R} / \overline{\mathrm{W}}\) & 40 & Controls the direction of data transfer between the CPU and the external 65 K address space. The signal is high when reading and low when writing. \\
\hline
\end{tabular}

\section*{SECTION 3 SYSTEM ARCHITECTURE}

This section provides a functional description of the R6500/ 13. Functionally the R6500/13 consists of a CPU, both RAM and optional ROM memories, four 8-bit parallel I/O ports, a serial I/O port, dual counter/latch circuits, a mode control register, and an interrupt flag/enable dual register circuit. A block diagram of the system is shown in Figure 3-1.

\section*{NOTE}

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

\subsection*{3.1 CPU LOGIC}

The R6500/13 internal CPU is a standard 6502 configuration with an 8-bit Accumulator register, two 8-bit Index Registers ( X and Y ); an 8-bit Stack Pointer register, an ALU, a 16-bit Program Counter, and standard instruction register/decode and internal timing control logic.

\subsection*{3.1.1 Accumulator}

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

\subsection*{3.1.2 Index Registers}

There are two 8 -bit index registers, \(X\) and \(Y\). Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especally those usıng data tables

\subsection*{3.1.3 Stack Pointer}

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, an internal \(\overline{\mathrm{RQ}}\) interrupt, or the external interrupt line \(\overline{\mathrm{NMI}}\). The Stack Pointer must be initialized by the user program.

The stack allows simple implementation of multiple level interrupts, subroutine nesting and simplification of many types of data manipulation. The JSR, BRK, RTI and RTS instructions use the stack and Stack Pointer.

The stack can be envisioned as a deck of cards which may be accessed only from the top. The address of a memory
location is stored (or "pushed") onto the stack. Each time data are to be pushed onto the stack, the Stack Pointer is placed on the Address Bus, data are written into the memory location addressed by the Stack Pointer, and the Stack Pointer is decremented by 1. Each time data are read (or "pulled") from the stack, the Stack Pointer is incremented by 1. The Stack Pointer is then placed on the Address Bus and data are read from the memory location addressed by the Pointer.

The stack is located on zero page, i.e., memory locations 00FF-0040. After reset, which leaves the Stack Pointer indetermınate, normal usage calls for its initialization at 00FF.

\subsection*{3.1.4 Arithmetic And Logic Unit (ALU)}

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter) The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero, the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

\subsection*{3.1.5 Program Counter}

The 16 -bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter \((\mathrm{PCH})\) is placed on the high-order 8 bits of the Address Bus The Counter is incremented each time an instruction or data is fetched from program memory.

\subsection*{3.1.6 Instruction Register and Instruction Decode}

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register, then decoded along with timing and interrupt signals to generate control signals for the various registers.

\subsection*{3.1.7 Timing Control}

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is set to TO each time an instruction fetch is executed and is advanced at the beginnıng 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

\subsection*{3.1.8 Interrupt Logic}

Interrupt logic controls the sequencing of three interrupts; \(\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}\) and IRQ. \(\overline{\mathrm{IRQ}}\) is generated by any one of eight conditions: 2 Counter Overflows, 2 Positive Edge Detects, 2 Negative Edge Detects, and 2 Serial Port Conditions.

\subsection*{3.2 NEW INSTRUCTIONS}

In addition to the standard R6502 instruction set, four new bit manipulation instructions have been added to the R6500/ 13. The added instructions and their format are explained in the following paragraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions. The four added instructions do not impact the CPU processor status register.

\subsection*{3.2.1 Set Memory Bit (SMB m, Addr.)}

This instruction sets to " 1 " one of the 8 -bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and one of eight bits to be set. The second byte of the instruction designates address (0-255) of the byte to be operated upon.

\subsection*{3.2.2 Reset Memory Bit (RMB m, Addr.)}

This instruction is the same operation and format as SMB instruction except a reset to " 0 " of the bit results.

\subsection*{3.2.3 Branch On Bit Set Relative (BBS m, Addr, DEST)}

This instruction tests one of eight bits designated by a 3-bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction is used to specify the 8 -bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

\subsection*{3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST)}

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

\subsection*{3.3 READ-ONLY-MEMORY (ROM)}

The optional ROM consists of 256 bytes mask programmable memory with an address space from 7F00 to 7FFF. ROM locations FFFA to FFFF are assigned for interrupt vectors. The reset vector can be optionally at 7FFE or FFFC.

The R6511Q has no ROM and its Reset vector is at FFFC.

\subsection*{3.4 RANDOM ACCESS MEMORY (RAM)}

The RAM consists of 192 bytes of read/write memory with an assigned page zero address of 0040 through 00FF. The R6500/13 provides a separate power pin ( \(\mathrm{V}_{\mathrm{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_{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 \(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{R E S}\) must then be held low while \(V_{c c}\) is out of operating range and until at least eight \(\emptyset 2\) clock cycles after \(V_{c c}\) is again within operating range and the internal \(\emptyset 2\) oscillator is stabilized. \(V_{R R}\) must remain withın \(V_{C C}\) operating range during normal operation. When \(\mathrm{V}_{\mathrm{cc}}\) is out of operating range, \(V_{R R}\) must remain within the \(V_{R R}\) retention range in order to retain data. Figure 3.2 shows typical waveforms.


Figure 3-2. Data Retention Timing

\subsection*{3.5 CLOCK OSCILLATOR}

The R6511Q has been configured for a crystal oscillator, a divide by 2 countdown network, and for Master Mode Operation.

Three customer selectable mask options are available for controlling the R6500/13 timing. The R6500/13 can be ordered with a crystal 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 sunce the resistor method can have tolerances approaching \(50 \%\).

Internal tıming can also be controlled by driving the XTLI pın with an external frequency source. Figure 3-3c shows typical connections. If XTLO is left floatıng, the external source is divided by the internal countdown network However, if XTLO


Figure 3-3. Clock Oscillator Input Options
is tied to \(\mathrm{V}_{\text {ss }}\), the internal countdown network is bypassed causing the chip to operate at the frequency of the external source.

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.

\section*{Note:}

When operating at a 1 MHz internal frequency place a 15-22 pt capacitor between XTLO and GND.
\(\emptyset 2\) is a buffered output signal which closely approximates the internal timing. When a common external source is used to drive multiple devices the internal timing between devices as well as their \(\phi 2\) outputs will be skewed in time. If skewing represents a system problem it can be avoided by the Master/Slave connection and options shown in Figure 3-4.

One R6500/13 is operated in the CLOCK MASTER MODE and a second in the CLOCK SLAVE MODE. Mask options in the SLAVE unit convert to \(\emptyset 2\) signal into a clock input pin which is tightly coupled to the internal timing generator. As a result the internal timing of the MASTER and SLAVE units are synchronized with minimum skew. If the \(\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


\subsection*{3.6 MODE CONTROL REGISTER (MCR)}

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for Counter A and Counter B. Its setting, along with the setting of the Serial Communications Control Register (SCCR), determines the basic configuration of the R6500/13 in any application. Initializing this register is one of the first actions of any software program. The Mode Control Register bit assignment is shown in Figure 3-5.


Figure 3-5. Mode Control Register
The use of Counter A Mode Select is shown in Section 6.1.

The use of Counter B Mode Select is shown in Section 6.2.
The use of Port B Latch Enable is shown in Section 4.4.
The use of Port \(D\) in Tri-State Enable is shown in Section 4.6.

The use of Bus Mode Select is shown in Section 4.5 and 4.6

\subsection*{3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)}

An \(\overline{\mathrm{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 contans the information that indicates which I/O or counter needs attention. The contents of the Interrupt Flag Register may be examined at any time by reading at address: 0011. Edge detect IFR bits may be cleared by executing a RMB instruction at address location 0010. The RMB X, (0010) instruction reads FF, modifies bit \(X\) to a " 0 ", and writes the modified value at address location 0011. In this way IFR bits set to a " 1 " after the read cycle of a Read-Modify-Write instruction (such as RMB) are protected from being cleared. A logic " 1 " is ignored when writing to edge detect IFR bits.

Each IFR bit has a corresponding bit in the Interrupt Enable Register which can be set to a " 1 " by writing a " 1 " in the respective bit position at location 0012. Individual IER bits may be cleared by writing a " 0 " in the respective bit position, or by RES. If set to a " 1 ", an IRQ will be generated when the corresponding IFR bit becomes true. The Interrupt Flag Register and Interrupt Enable Register bit assignments are shown in Figure 3-6 and the functions of each bit are explained in Table 3-1.


Figure 3-6. Interrupt Enable and Flag Registers

Table 3-1. Interrupt Flag Register Bit Codes
\begin{tabular}{|c|c|}
\hline \[
\begin{aligned}
& \text { Bit } \\
& \text { Code }
\end{aligned}
\] & Function \\
\hline IFR 0 & PA0 Positive Edge Detect Flag-Set to a " 1 " when a positive going edge is detected on PA0. Cleared by RMB O (0010) instruction or by \(\overline{\text { RES }}\) \\
\hline IFR 1 & PA1 Positive Edge Detect Flag-Set to a 1 when a positive going edge is detected on PA1 Cleared by RMB 1 (0010) instruction or by \(\overline{\text { RES }}\) \\
\hline IFR 2 & PA2 Negative Edge Detect Flag-Set to a 1 when a negative going edge is detected on PA2 Cleared by RMB 2 (0010) instruction or by \(\overline{\text { RES }}\) \\
\hline IFR 3. & PA3 Negative Edge Detect Flag-Set to 1 when a negative going edge is detected on PA3. Cleared by RMB 3 (0010) instruction or by RES \\
\hline IFR 4. & Counter A Underflow Flag-Set to a 1 when Counter A underflow occurs. Cleared by reading the Lower Counter A at location 0018, by writing to address location 001A, or by RES. \\
\hline IFR 5: & Counter B Underflow Flag-Set to a 1 when Counter B underflow occurs. Cleared by reading the Lower Counter B at location 001C, by writing to address location 001E, or by RES. \\
\hline IFR 6 & Receiver Interrupt Flag-Set to a 1 when any of the Serial Communication Status Register bits 0 through 3 is set to a 1 . Cleared when the Receiver Status bits (SCSR 0-3) are cleared or by RES. \\
\hline IFR 7. & Transmitter Interrupt Flag-Set to a 1 when SCSR 6 is set to a 1 while SCSR 5 is a 0 or SCSR 7 is set to a 1 . Cleared when the Transmitter Status bits (SCSR 6 \& 7) are cleared or by RES \\
\hline
\end{tabular}

\subsection*{3.8 PROCESSOR STATUS REGISTER}

The 8-bit Processor Status Register, shown in Figure 3-7, contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6502 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

\subsection*{3.8.1 Carry Bit (C)}

The Carry Bit (C) can be considered as the ninth bit of an arthmetic 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 operatıons which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

\subsection*{3.8.2 Zero Bit (Z)}

The Zero Bit \((Z)\) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to
zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The R6500 instruction set contains no instruction to specifically set or clear the Zero Bit. The Zero Bit is, however, affected by the following instructions; ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

\subsection*{3.8.3 Interrupt Disable Bit (I)}

The Interrupt Disable Bit \((I)\) is used to control the servicing of an interrupt request ( \(\overline{\mathrm{RQ}})\). If the I Bit is reset to logic 0 , the \(\overline{\mathrm{RQ}}\) signal will be serviced. If the bit is set to logic 1 , the \(\overline{\mathrm{RQ}}\) signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( \(\overline{\operatorname{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

\subsection*{3.8.4 Decimal Mode Bit (D)}

The Decimal Mode Bit (D) is used to control the arithmetic mode of the CPU. When this bit is set to logic 1, the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction clears it. The PLP and RTI instructions also affect the Decimal Mode Bit.

\section*{CAUTION}

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application. This bit must be initialized to the desired state by the user program or erroneous results may occur.

\subsection*{3.8.5 Break Bit (B)}

The Break Bit \((B)\) is used to determine the condition which caused the \(\overline{\mathrm{RQ}}\) service routine to be entered. If the \(\overline{\mathrm{RQ}}\) service routine was entered because the CPU executed a BRK command, the Break Bit will be set to logic 1. If the 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.

\subsection*{3.8.6 Overflow Bit (V)}

The Overflow Bit (V) is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contained in seven bits \((-128 \leqslant n \leqslant 127)\).

This indicator only has meaning when signed arithmetic (sign and seven magnitude bits) is performed. When the ADC or SBC instruction is performed, the Overflow Bit is set to logic 1 if the polarity of the sign bit (bit 7) is changed because the result exceeds +127 or -128 ; otherwise the bit is cleared to logic 0 . The V bit may also be cleared by the programmer using a Clear Overflow (CLV) instruction.

The Overflow Bit may also be used with the BIT instruction. The BIT instruction-which may be used to sample interface devices-allows the overflow flag to reflect the condition of bit 6 in the sampled field. During a BIT instruction the Overflow Bit is set equal to the content of the bit 6 on the data tested with BIT instruction. When used in this mode, the overflow has nothing to do with signed arithmetic, but is just another sense bit for the microprocessor. Instructions affecting the \(V\) flag are ADC, BIT, CLV, PLP, RTI and SBC.

\subsection*{3.8.7 Negative Bit (N)}

The Negative Bit \((\mathrm{N})\) is used to indicate that the sign bit (bit 7) in the resulting value of a data movement or data arithmetic operation is set to logic 1 . If the sign bit is set to logic 1 , the resulting value of the data movement or arithmetic operation is negative; if the sign bit is cleared, the result of the data movement or arithmetic operation is positive. There are no instructions that set or clear the Negative Bit since the Negative Bit represents only the status of a result. The instructions that effect the state of the Negative Bit are: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

\title{
SECTION 4 PARALLEL INPUT/OUTPUT PORTS \& BUS MODES
}

The devices have \(32 \mathrm{I} / \mathrm{O}\) lines grouped into four 8 -bit ports (PA, PB, PC, and PD). Ports A through C may be used either for input or output individually or in groups of any combination. Port D may be used as all inputs or all outputs.

Multifunction I/O's such as Port A and Port C are protected from normal port I/O instructions when they are programmed to perform a multiplexed function.

Internal pull-up resistors (FET's with an impedance range of \(3 K \leqslant R_{L} \leqslant 12 \mathrm{~K}\) ohm) are provided on all port pins except Port D. A mask option to delete the internal pull-ups in 8-bit port groups is available.

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. 6 shows the I/O Port Timing.

Table 4-1. I/O Port Addresses
\begin{tabular}{|c|c|}
\hline Port & Address \\
\hline A & 0000 \\
B & 0001 \\
C & 0002 \\
D & 0003 \\
\hline
\end{tabular}

\subsection*{4.1 INPUTS}

Inputs for Ports A, B, and C are enabled by loadıng 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{\operatorname{RES}}\) signal forces all I/O port registers to logic 1 thus initially treating all I/O lines as inputs.

Port D may only be all inputs or all outputs. All inputs is selected by setting bit 5 of the Mode Control Register (MCR5) to a " 0 ".

The status of the input lines can be interrogated at any time by reading the I/O port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers.

Read/Modify/Write instructions can be used to modify the operation of PA, PB, PC, \& PD. During the Read cycle of a Read/Modify/Write instruction the Port I/O register is read. For all other read instructions the port input lines are read. Read/Modify/Write instructions are: ASL, DEC, INC, LSR, RMB, ROL, ROR, and SMB.

\subsection*{4.2 OUTPUTS}

Outputs for Ports A thru D are controlled by writing the desired I/O line output states into the corresponding I/O port register bit positions. A logic 1 will force a high ( \(>2.4 \mathrm{~V}\) ) output while a logic 0 will force a low ( \(<0.4 \mathrm{~V}\) ) output.

Port D all outputs is selected by setting MCR5 to a "1".

\subsection*{4.3 Port A (PA)}

Port A can be programmed via the Mode Control Register (MCR) and the Serial Communications Control Register (SCCR) as a standard parallel 8-bit, bit independent, I/O port or as serial channel I/O lines, counter I/O lines, or an input data strobe for the Port B input latch option. Table 4-2 tabulates the control and usage of Port A.

In addition to their normal I/O functions, PAO and PA1 can detect positive going edges and PA2 and PA3 can detect negative going edges. A proper transition on these pins will set a corresponding status bit in the IFR and generate an interrupt request if the respective Interrupt Enable Bit is set. The maximum rate at which an edge can be detected is onehalf the \(\emptyset 2\) clock rate. Edge detection timing is shown in Appendix E.5.

Table 4-2. Port A Control \& Usage


\subsection*{4.4 PORT B (PB)}

Port B can be programmed as an 8-bit, bit-independent I/O port. It has a latched input capability which may be enabled or disabled via the Mode Control Register (MCR). Table 4-3 tabulates the control and usage of Port B. An Input Data Strobe signal must be provided thru PAO when Port B is programmed to be used with latched input option. Input data latch timing for Port \(B\) is shown in Appendix E.5..

Table 4-3. Port B Control \& Usage
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{\multirow[t]{2}{*}{}} & \multicolumn{2}{|c|}{I/O Mode} & \multicolumn{2}{|c|}{Latch Mode} \\
\hline & & \multicolumn{2}{|l|}{MCR4 \(=0\)} & \multicolumn{2}{|r|}{\begin{tabular}{l}
\[
\text { MCR4 }=1
\] \\
(2)
\end{tabular}} \\
\hline \multirow[b]{2}{*}{\[
\begin{gathered}
\text { Pin } \\
\#
\end{gathered}
\]} & \multirow[b]{2}{*}{\begin{tabular}{l}
Pin \\
Name
\end{tabular}} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & & Name & \begin{tabular}{l}
Type \\
(1)
\end{tabular} & Name & Type \\
\hline 31 & PB0 & PB0 & 1/0 & PBO & INPUT \\
\hline 30 & PB1 & PB1 & 1/0 & PB1 & INPUT \\
\hline 29 & PB2 & PB2 & \(1 / 0\) & PB2 & INPUT \\
\hline 28 & PB3 & PB3 & 1/0 & PB3 & INPUT \\
\hline 27. & PB4 & PB4 & I/O & PB4 & INPUT \\
\hline 26 & PB5 & PB5 & I/O & PB5 & INPUT \\
\hline 25 & PB6 & PB6 & 1/0 & PB6 & INPUT \\
\hline 24 & PB7 & PB7 & I/O & PB7 & INPUT \\
\hline
\end{tabular}
(1) Resistive Pull-Up, Active Buffer Pull-Down
(2) Input data is stored in Port B latch by PAO Pulse

\subsection*{4.5 PORT C (PC)}

Port C can be programmed as an I/O port, 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 PC0-PC5 operating as normal \(1 / O\) pins. When used in the abbreviated or multiplexed bus modes, PC0-PC7 function as A0-A3, A12, R/W, A13, and EMS, respectively, as shown in Table 4-4. EMS (External Memory Select) is asserted (low) whenever the internal processor accesses memory area between 0100 and 3FFF. (See Memory Map, Appendix B). The leading edge of EMS may be used to strobe the eight address lines multiplexed on Port \(D\) in the Multiplexed Bus Mode. See Appendices E. 3 through E. 5 for Port C timing.

\subsection*{4.6 PORT D (PD)}

Port D can be programmed as an I/O Port, an 8-bit tri-state data bus, or as a multiplexed bus. Mode selection for Port \(D\) is made by the Mode Control Register (MCR). The Port D output drivers can be selected as tri-state drivers by setting
bit 5 of the MCR to 1 (one). Table 4-5 shows the necessary settings for the MCR to achieve the various modes for Port D. When Port D is selected to operate in the Abbreviated Mode PD0-PD7 serves as data register bits 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 Appendices E. 3 through E. 5 for Port D timing.

\subsection*{4.7 BUS MODES}

A special attribute of Port \(C\) and Port \(D\) is their capability to be configured via the Mode Control Register (see Section 3.6) into four different modes.

In the Full Address Mode, the separate address and data bus are used in conjunction with PC6 and PC7, which automatically provide A13 and A14. The remaining ports perform the normal I/O function.

In the I/O Bus Mode all ports serve as I/O. The address and data bus are still functional but without A13 and A14. Since the internal RAM and registers are in the 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 16K of external addresses are provided. Port C provides the lower addresses and control signals. Port D multiplexes functions. During the first half of the cycle it contains the remaining necessary 8 address bits for 16 K ; during the second half of the cycle it contains a bidirectional data bus. The address bits appearing on Port D must be latched into an external holding register. The leading edge of 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
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{\multirow[t]{2}{*}{}} & \multicolumn{2}{|c|}{Full Address Mode} & \multicolumn{2}{|c|}{I/O Mode} & \multicolumn{2}{|r|}{Abbreviated Mode} & \multicolumn{2}{|r|}{Multiplexed Mode} \\
\hline & & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=1
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=1
\end{aligned}
\]} \\
\hline & & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline \[
\begin{gathered}
\text { Pin } \\
\#
\end{gathered}
\] & \begin{tabular}{l}
Pin \\
Name
\end{tabular} & Name & Type & Name & \begin{tabular}{l}
Type \\
(1)
\end{tabular} & Name & \begin{tabular}{l}
Type \\
(2)
\end{tabular} & Name & \begin{tabular}{l}
Type \\
(2)
\end{tabular} \\
\hline 54 & PCO & PCO & 1/O (1) & PCO & 1/0 & A0 & OUTPUT & AO & OUTPUT \\
\hline 55 & PC1 & PC1 & 1/O (1) & PC 1 & I/O & A1 & OUTPUT & A1 & OUTPUT \\
\hline 56 & PC2 & PC2 & 1/O (1) & PC2 & I/O & A2 & OUTPUT & A2 & OUTPUT \\
\hline 57 & PC3 & PC3 & 1/O (1) & PC3 & 1/0 & A3 & OUTPUT & A3 & OUTPUT \\
\hline 58 & PC4 & PC4 & 1/O (1) & PC4 & 1/0 & A12 & OUTPUT & A12 & OUTPUT \\
\hline 59 & PC5 & PC5 & I/O (1) & PC5 & 1/0 & RW & OUTPUT & RW & OUTPUT \\
\hline 60 & PC6 & A13 & OUTPUT (2) & PC6 & 1/0 & A13 & OUTPUT & A13 & OUTPUT \\
\hline 61 & PC7 & A14 & OUTPUT (2) & PC7 & 1/0 & EMS & OUTPUT & EMS & OUTPUT \\
\hline
\end{tabular}
(1) Resistive Pull-Up, Active Buffer Pull-Down
(2) Active Buffer Pull-Up and Pull-Down

Table 4-5. Port D Control \& Usage
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{5}{*}{\[
\begin{gathered}
\text { Pin } \\
\#
\end{gathered}
\]} & \multirow[b]{5}{*}{Pin Name} & \multicolumn{4}{|c|}{I/O Modes} & \multicolumn{2}{|l|}{Abbreviated Mode} & \multicolumn{4}{|c|}{Multiplexed Mode} \\
\hline & & \multicolumn{2}{|r|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=X \\
& \text { MCR5 }=0
\end{aligned}
\]} & \multicolumn{2}{|r|}{\[
\begin{aligned}
\text { MCR7 } & =0 \\
\text { MCR6 } & =X \\
\text { MCR5 } & =1
\end{aligned}
\]} & \multicolumn{2}{|l|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=0 \\
& \text { MCR5 }=1
\end{aligned}
\]} & \multicolumn{4}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=1 \\
& \text { MCR5 }=1
\end{aligned}
\]} \\
\hline & & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} & \multicolumn{2}{|c|}{Signal} \\
\hline & & & & \multirow[b]{2}{*}{Name} & \multirow[t]{2}{*}{\begin{tabular}{l}
Type \\
(2)
\end{tabular}} & \multirow[b]{2}{*}{Name} & \multirow[t]{2}{*}{Type (3)} & \multicolumn{2}{|c|}{02 Low} & \multicolumn{2}{|c|}{02 High} \\
\hline & & Name & (1) & & & & & Name & Type (2) & Name & Type (3) \\
\hline 62 & PDO & PDO & INPUT & PDO & OUTPUT & DATAO & 1/O & A4 & OUTPUT & DATAO & 1/0 \\
\hline 63 & PD1 & PD1 & INPUT & PD1 & OUTPUT & DATA1 & 1/0 & A5 & OUTPUT & DATA1 & \(1 / 0\) \\
\hline 64 & PD2 & PD2 & INPUT & PD2 & OUTPUT & DATA2 & 1/0 & A6 & OUTPUT & DATA2 & \(1 / 0\) \\
\hline 1 & PD3 & PD3 & INPUT & PD3 & OUTPUT & DATA3 & 1/0 & A7 & OUTPUT & DATA3 & I/O \\
\hline 2 & PD4 & PD4 & INPUT & PD4 & OUTPUT & DATA4 & 1/O & A8 & OUTPUT & DATA4 & 1/0 \\
\hline 3 & PD5 & PD5 & INPUT & PD5 & OUTPUT & DATA5 & 1/0 & A9 & OUTPUT & DATA5 & \(1 / 0\) \\
\hline 4 & PD6 & PD6 & INPUT & PD6 & OUTPUT & DATA6 & 1/O & A10 & OUTPUT & DATA6 & \(1 / 0\) \\
\hline 5 & PD7 & PD7 & INPUT & PD7 & OUTPUT & DATA7 & 1/0 & A11 & OUTPUT & DATA7 & 1/0 \\
\hline
\end{tabular}
(1) Tr-State Buffer is in High Impedance Mode
(2) Tri-State Buffer is in Active Mode
(3) Trı-State Buffer is in Active Mode only during the phase 2 portion of a Write Cycle

A. FULL ADDRESS MODE

C. ABBREVIATED BUS MODE

B. NORMAL BUS MODE

D. MULTIPLEXED BUS MODE

Figure 4-1. Bus Mode Configurations


Figure 4-2. Memory Map

\section*{SECTION 5 SERIAL INPUT/OUTPUT CHANNEL}

The device provides a full duplex Serial I/O channel with programmable bit rates and operating modes. The serial I/O functions are controlled by the Serial Communication Control Register (SCCR). The SCCR bit assignment is shown in Figure 5-1. The serial bit rate is determined by Counter \(A\) for all modes except the Receiver Shift Register (RCVR S/R) mode for which an external shift clock must be provided. The maximum data rate using the internal clock is 62.5 K bits per second (at \(\dagger 2=1 \mathrm{MHZ}\) ). The transmitter (XMTR) and receiver (RCVR) can be independently programmed to operate in different modes and can be independently enabled or disabled.


Figure 5-1. Serial Communication Control Register
Except for the Receiver Shift Register Mode (RCVR S/R), all XMTR and RCVR bit rates will occur at one sixteenth of the Counter A interval timer rate. Counter A is forced into an interval timer mode whenever the serial I/O is enabled in a mode requiring an internal clock.

Whenever Counter A is required as a timing source it must be loaded with the hexadecimal code that selects the data rate for the serial I/O Port. Refer to Counter A (paragraph 6.1) for a table of hexadecimal values to represent the desired data rate.

\subsection*{5.1 TRANSMITTER OPERATION (XTMR)}

The XTMR operation and the transmitter related control/ status functions are enabled by bit 7 of the Serial Communications Control Register (SCCR). The transmitter, when in the Asynchronous (ASYN) mode, automatically adds a start bit, one or two stop bits, and, when enabled, a parity bit to the transmitted data. A word of transmitted data (in asynchronous parity mode) can have \(5,6,7\), or 8 bits of data. The nine data modes are shown in Figure 5-2. When parity is disabled, the 5, 6, 7 or 8 bits of data are terminated with two stop bits.


Figure 5-2. SIO Data Modes
In the S/R mode, eight data bits are always shifted out. Bits/ character and parity control bits are ignored. The serial data is shifted out via the SO output (PA6) and the shift clock is available at the CA (PA4) pin. When the transmitter underruns in the S/R mode the SO output and shift clock are held in a high state.

The XMTR Interrupt Flag bit (IFR7) is controlled by Serial Communication Status Register bits SCSR5, SCSR6 and SCSR7.
\[
\text { IFR7 }=\text { SCSR6 }(\overline{\text { SCSR5 }}+\text { SCSR7 })
\]

\subsection*{5.2 RECEIVER OPERATION (RCVR)}

The receiver and its selected control and status functions are enabled when SCCR-6 is set to a "1." In the ASYN mode, data format must have a start bit, the appropriate number of data bits, a parity bit (if enabled), and one stop bit. Refer to paragraph 5.1 for a diagram of bit allocations. The receiver bit period is divided into 8 sub-intervals for internal synchronization. The receiver bit stream is synchronized by the start bit and a strobe signal is generated at the approximate center of each incoming bit. Refer to Figure 5-3 for ASYN Receive Data Timing. The character assembly process does not start if the start bit signal is less than one-half the bit time after a low level is detected on the Receive Data Input. Framing error, over-run, and parity error conditions or a RCVR Data Register Full will set the appropriate status bits. Any of the above conditions will cause an- Interrupt Request if the Receiver Interrupt Enable bit is set to logic 1.


Figure 5-3. ASYN Receive Data Timing
In the S/R mode, an external shift clock must be provided at CA (PA4) pin along with 8 bits of serial data (LSB first) at the SI input (PA7). The maximum data rate using an external shift clock is one-eighth the internal clock rate. Refer to Figure 5-4 for S/R Mode Timing.


Figure 5-4. S/R Mode Timing
A RCVR interrupt (IFR6) is generated whenever any of SCSR0-3 are true.

\subsection*{5.3 SERIAL COMMUNICATION STATUS REGISTER (SCSR)}

The Serial Communication Status Register (SCSR) holds information on varıous communication error conditions, status of the transmitter and receiver data registers, a transmitter end-of-transmission condition, and a receiver idle line condition (Wake-Up Feature). The SCSR bit assignment is shown in Figure 5-5. Bit assignments and functions of the SCSR are as follows:

SCSR 0: Receiver Data Register Full-Set to a logic 1 when a character is transferred from the Receiver Shift Register to the Receiver Data Register. This bit is cleared by reading the Receiver Data Register, or by \(\overline{\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 logıc 1 by writing a " 1 " in bit 4 of address. 0016. The Wake-Up bit is cleared by \(\overline{R E S}\) 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 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{\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

\subsection*{5.4 WAKE-UP FEATURE}

In a multi-distributed microprocessor or microcomputer applications, a destination address is usually included at the beginning of the message. The Wake-Up Feature allows
non-selected CPU's to ignore the remainder of the message 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 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 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.


\title{
SECTION 6 COUNTER/TIMERS
}

The device contains two 16 -bit counters (Counter A and Counter B) and three 16 -bit latches associated with the counters. Counter A has one 16-bit latch and Counter B has two 16 -bit latches. Each counter can be independently programmed to operate in one of four modes:

\section*{Counter A}
- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Counter

\section*{Counter B}
- Retriggerable Interval Counter
- Asymmetrical Pulse Generation
- Interval Timer
- Event Counter

Operating modes of Counter A and Counter B are controlled by the Mode Control Register. All counting begins at the initialization value and decrements. When modes are selected requiring a counter input/output line, PA4 is automatically selected for Counter A and PA5 is automatically selected for Counter B (see Table 4.2).

\subsection*{6.1 COUNTER A}

Counter A consists of a 16 -bit counter and a 16 -bit latch organized as follows: Lower Counter A (LCA), Upper Counter A (UCA), Lower Latch A (LLA), and Upper Latch A (ULA). The counter contans 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 RES.

Counter A operates in any of four modes. These modes are selected by the Counter A Mode Control bits in the Control Register.
\begin{tabular}{|c|c|l|}
\hline \begin{tabular}{c} 
MCR1 \\
(bit 1)
\end{tabular} & \begin{tabular}{c} 
MCR0 \\
(bit 0)
\end{tabular} & \multicolumn{1}{|c|}{ Mode } \\
\hline 0 & 0 & Interval Timer \\
0 & 1 & Pulse Generation \\
1 & 0 & Event Counter \\
1 & 1 & Pulse Width Measurement \\
\hline
\end{tabular}

The Interval Timer, Pulse Generation, and Pulse Width Measurement Modes are \(\phi 2\) clock counter modes. The Event Counter Mode counts the occurrences of an external event on the CNTR line.

The Counter is set to the Interval Timer Mode (00) when a \(\overline{R E S}\) signal is generated.

\subsection*{6.1.1 Interval Timer}

In the Interval Timer mode the Counter is initialized to the Latch value by either of two conditions:
1. When the Counter is decremented from 0000, the next Counter value is the Latch value (not FFFF).
2. When a write operation is performed to the Load Upper Latch and Transfer Latch to Counter address 001A, the Counter is loaded with the Latch value. Note that the contents of the Accumulator are loaded into the Upper Latch before the Latch value is transferred to the Counter.

The Counter value is decremented by one count at the 02 clock rate. The 16 -bit Counter can hold from 1 to 65535 counts. The Counter Timer capacity is therefore \(1 \mu \mathrm{~s}\) to 65.535 ms at the \(1 \mathrm{MHz} \phi 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{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 IRQ interrupt request will be generated. The Counter A Underflow bit in the Interrupt Flag Register can be examined in the \(\overline{\mathrm{IRQ}}\) interrupt routine to determine that the \(\overline{\mathrm{RQ}}\) was generated by the Counter A Underflow.

While the timer is operating in the Interval Timer Mode, PA4 operates as a PA I/O bit.

A timing diagram of the Interval Timer Mode is shown in Figure 6-1.

\subsection*{6.1.2 Pulse Generation Mode}

In the Pulse Generation mode, the CA line operates as a Counter Output. The line toggles from low to high or from high to low whenever a Counter A Underflow occurs or a write is performed to address 001A.

The normal output waveform is a symmetrical square-wave. The CA output is initialized high when entering the mode and transitions low when writing to 001A.

Asymmetric waveforms can be generated if the value of the latch is changed after each counter underflow.

A one-shot waveform can be generated by changing from Pulse Generation to Interval Timer mode after only one occurrence of the output toggle condition.

\subsection*{6.1.3 Event Counter Mode}

In this mode the CA is used as an Event Input line, and the Counter will decrement with each rising edge detected on this line. The maximum rate at which this edge can be detected is one-half the \(\emptyset 2\) clock rate.

The Counter can count up to 65,535 occurrences before underflowing. As in the other modes, the Counter A Underflow bit (IER4) is set to logic 1 if the underflow occurs.

Figure 6.2 is a timing diagram of the Event Counter Mode.


Figure 6-2. Event Counter Mode

\subsection*{6.1.4 Pulse Width Measurement Mode}

This mode allows the accurate measurement of a low pulse duration on the CA line. The Counter decrements by one count at the \(\varnothing 2\) clock rate as long as the CA line is held in the low state The Counter is stopped when CA is in the high state.

The Counter A underflow flag will be set only when the count in the timer reaches zero. Upon reaching zero the timer will be loaded with the latch value and continue counting down as long as the CA pin is held low. After the counter is stopped by a high level on CA, the count will hold as long as CA remains high. Any further low levels on CA will again cause the counter to count down from its present value. The state of the CA line can be determined by testing the state of PA4.

A tıming diagram for the Pulse Width Measurement Mode is shown in Figure 6.3.


Figure 6-3. Pulse Width Measurement

\subsection*{6.1.5 Serial I/O Data Rate Generation}

Counter A also provides clock tımıng for the Serial I/O which establishes the data rate for the Serial I/O port. When the Serial I/O is enabled, Counter \(A\) is forced to operate at the internal clock rate. Counter \(A\) is not required for the RCVR S/R mode. The Counter I/O (PA4) may also be required to support the Serial I/O (see Table 4-2).

Table 6-1 identifies the values to be loaded in Counter A for selecting standard data rates with a \(\phi 2\) clock rate of 1 MHz and 2 MHz . Although Table 6-1 identifies only the more common data rates, any data rate from 1 to 62.5 K bps can be selected by using the formula:
\[
N=\frac{\phi 2}{16 \times b p s}-1
\]
where
\(\mathrm{N} \quad=\) decımal value to be loaded into Counter A using its hexadecimal equivalent.
\(\phi 2=\) the clock frequency ( 1 MHz or 2 MHz )
bps = the desired data rate.

\section*{NOTE}

In Table 6-1 you will notice that the standard data rate and the actual data rate may be slightly different. Transmitter and receiver errors of \(1.5 \%\) or less are acceptable. A revised clock rate is included in Table 6-1 for those baud rates which fall outside this limit.

Table 6-1. Counter A Values for Baud Rate Selection
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[t]{2}{*}{Standard Baud Rate} & \multicolumn{2}{|l|}{Hexadecimal Value} & \multicolumn{2}{|l|}{Actual Baud Rate At} & \multicolumn{2}{|l|}{Clock Rate Needed To Get Standard 'Baud Rate} \\
\hline & 1 MHz & 2 MHz & 1 MHz & 2 MHz & 1 MHz & 2 MH \\
\hline 50 & 04E1 & 09 C 3 & 50.00 & 50.00 & 1.0000 & 2.0000 \\
\hline 75 & 0340 & 0682 & 75.03 & 74.99 & 1.0000 & 2.0000 \\
\hline 110 & 0237 & 046F & 110.04 & 110.04 & 1.0000 & 2.0000 \\
\hline 150 & 01A0 & 0340 & 149.88 & 150.06 & 1.0000 & 2.0000 \\
\hline 300 & OOCF & 01A0 & 300.48 & 299.76 & 1.0000 & 2.0000 \\
\hline 600 & 0067 & 00CF & 600.96 & 60096 & 1.0000 & 2.0000 \\
\hline 1200 & 0033 & 0067 & 1201.92 & 120192 & 1.0000 & 20000 \\
\hline 2400 & 0019 & 0033 & 2403.85 & 2403.85 & 10000 & 2.0000 \\
\hline 3600 & 0010 & 0021 & 3676.47 & 3676.47 & 0.9792 & 1.9584 \\
\hline 4800 & 000C & 0019 & 4807.69 & 4807.69 & 1.0000 & 2.0000 \\
\hline 7200 & 0008 & 0010 & 694444 & 7352.94 & 1.0368 & 1.9584 \\
\hline 9600 & 0006 & 000C & 892857 & 9615.38 & 1.0752 & 2.0000 \\
\hline
\end{tabular}

\subsection*{6.2 COUNTER B}

Counter B consists of a 16-bit counter and two 16-bit latches organized as follows: Lower Counter B (LCB), Upper Counter B (UCB), Lower Latch B (LLB), Upper Latch B (ULB), Lower Latch C (LLC), and Upper Latch C (ULC). Latch C is used only in the asymmetrical pulse generation mode. The counter contains the count of either \(\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 intialized at any time by writing to address: 001 E . The contents of the accumulator is copied into the Upper Latch B before the value in the 16 -bit Latch B is transferred to Counter B. Counter B will also be set to the latch value and the Counter B Underflow Flag bit (IFR5) will be set to a "1" whenever Counter B underflows by decrementing from 0000.

IFR 5 may be cleared by reading the Lower Counter B at location 001 C , by writing to address location 001 E , or by \(\overline{\mathrm{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 MCR0 and MCR1 select the modes of Counter \(A\).

\subsection*{6.2.1 Retriggerable Interval Timer Mode}

When operating in the Retriggerable Interval Timer mode, Counter \(B\) is initialized to the latch value by writing to address 001E, by a Counter B underflow, or whenever a positive edge occurs on the CB pin (PA5). The Counter B interrupt flag will be set if the counter underflows before a positive edge occurs on the CB line. Figure 6-4 illustrates the operation.


Figure 6-4. Counter B. Retriggerable Interval Timer Mode

\subsection*{6.2.2 Asymmetrical Pulse Generation Mode}

Counter B has a special Asymmetrical Pulse Generation Mode whereby a pulse train with programmable pulse width and period can be generated without the processor intervention once the latch values are initialized.

In this mode, the 16 -bit Latch \(B\) is initialized with a value which corresponds to the duration between pulses (referred to as \(D\) in the following descriptions). The 16 -bit Latch \(C\) is initialized with a value corresponding to the desired pulse width (referred to as \(P\) in the following descriptions). The initialization sequence for Latch \(B\) and \(C\) and the starting of a counting sequence are as follows:
1. The lower 8 bits of \(P\) are loaded into LLB by writing to address 001 C ; the upper 8 bits of \(P\) are loaded into ULB and the full 16 bits are transferred to Latch \(C\) by writing to address location 001D. At this point both Latch \(B\) and Latch \(C\) contain the value of \(P\).
2. The lower 8 bits of \(D\) are loaded into LLB by writing to address 001C; the upper 8 bits of \(D\) are loaded into ULB by writing to address location 001E. Writing to address location 001E also causes the contents of the 16-bit Latch \(B\) to be downloaded into the Counter \(B\) and the CB output to go low as shown in Figure 6-5.
3. When Counter \(B\) underflow occurs the contents of the Latch \(C\) are loaded into the Counter B and the CB output toggles to a high level, staying high until another underflow occurs. Latch \(B\) is then down-loaded and the CB output toggles to a low level repeating the whole process.

\section*{SECTION 7 \\ POWER ON/INITIALIZATION CONSIDERATIONS}

\subsection*{7.1 POWER ON TIMING}

After application of \(V_{C C}\) and \(V_{\text {RR }}\) power to the device, \(\overline{\text { RES }}\) must be held low for at least eight \(\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

\subsection*{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

\subsection*{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
\begin{tabular}{|l|cccccccc|}
\hline \multicolumn{1}{|c|}{ Bit No. } & \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline REGISTERS & & & & & & & & \\
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 \\
\hline
\end{tabular}

All RAM and other CPU registers will initialize in a random, non-repeatable data pattern.

\subsection*{7.4 INITIALIZATION}

Any initialization process for the device should include a \(\overline{\mathrm{RES}}\), as indicated in the preceeding paragraphs. After stabilization of the internal clock (if a power on situation) an initialization subroutine should be executed to perform (as a minimum) the following functions:
1. The Stack Pointer should be set
2. Clear or Set Decimal Mode
3. Set or Clear Carry Flag
4. Set up Mode Controls as required
5. Clear Interrupts

A typical initialization subroutine could be as follows:
\begin{tabular}{ll} 
LDX & \begin{tabular}{l} 
Load stack pointer starting address into \\
\\
X Register
\end{tabular} \\
TXS & Transfer X Register value to Stack Pointer \\
CLD & Clear Decimal Mode \\
SEC & Set Carry Flag \\
\(\ldots\). & Set-up Mode Control and \\
\(\ldots\). & special function registers \\
\(\ldots\). & and clear RAM as required \\
CLI & Clear Interrupts
\end{tabular}

\title{
APPENDIX A \\ ENHANCED R6502 INSTRUCTION SET
}

\begin{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.
\end{abstract}

\section*{A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE}
\begin{tabular}{|c|c|c|c|}
\hline MNEMONIC & INSTRUCTION & MNEMONIC & INSTRUCTION \\
\hline ADC & Add Memory to Accumulator with Carry & LDA & Load Accumulator with Memory \\
\hline AND & "AND" Memory with Accumulator & LDX & Load Index X with Memory \\
\hline \multirow[t]{2}{*}{ASL} & \multirow[t]{2}{*}{Shift Left One Bit (Memory or Accumulator)} & LDY & Load Index Y with Memory \\
\hline & & \multirow[t]{2}{*}{LSR} & Shift One Bit Right (Memory or \\
\hline *BBR & Branch on Bit Reset Relative & & Accumulator) \\
\hline *BBS & \multicolumn{2}{|l|}{Branch on Bit Set Relative} & \\
\hline BCC & Branch on Carry Clear & NOP & No Operation \\
\hline BCS & Branch on Carry Set & & \\
\hline BEQ & Branch on Result Zero & ORA & "OR" Memory with Accumulator \\
\hline BIT & Test Bits in Memory with Accumulator & & \\
\hline BMI & Branch on Result Minus & PHA & Push Accumulator on Stack \\
\hline BNE & Branch on Result not Zero & PHP & Push Processor Status on Stack \\
\hline BPL & Branch on Result Plus & PLA & Pull Accumulator from Stack \\
\hline BRK & Force Break & PLP & Pull Processor Status from Stack \\
\hline BVC & Branch on Overflow Clear & & \\
\hline \multirow[t]{2}{*}{BVS} & \multirow[t]{2}{*}{Branch on Overflow Set} & *RMB & Reset Memory Bit \\
\hline & & ROL & Rotate One Bit Left (Memory or \\
\hline CLC & Clear Carry Flag & & Accumulator) \\
\hline CLD & Clear Decimal Mode & ROR & Rotate One Bit Right (Memory or \\
\hline CLI & Clear Interrupt Disable Bit & & Accumulator) \\
\hline CLV & Clear Overflow Flag & RTI & Return from Interrupt \\
\hline CMP & Compare Memory and Accumulator & RTS & Return from Subroutine \\
\hline CPX & Compare Memory and Index X & & \\
\hline CPY & Compare Memory and Index Y & SBC & Subtract Memory from Accumulator with Borrow \\
\hline DEC & Decrement Memory by One & SEC & Set Carry Flag \\
\hline DEX & Decrement Index \(X\) by One & SED & Set Decimal Mode \\
\hline \multirow[t]{2}{*}{DEY} & \multirow[t]{2}{*}{Decrement Index Y by One} & SEI & Set Interrupt Disable Status \\
\hline & & *SMB & Set Memory Bit \\
\hline \multirow[t]{3}{*}{EOR} & "Exclusive-Or" Memory with & STA & Store Accumulator in Memory \\
\hline & \multirow[t]{2}{*}{Accumulator} & STX & Store Index X in Memory \\
\hline & & STY & Store Index Y in Memory \\
\hline INC & Increment Memory by One & & \\
\hline INX & Increment Index X by One & TAX & Transfer Accumulator to Index X \\
\hline \multirow[t]{2}{*}{INY} & \multirow[t]{2}{*}{Increment Index Y by One} & TAY & Transfer Accumulator to Index \(Y\) \\
\hline & & TSX & Transfer Stack Pointer to Index X \\
\hline JMP & Jump to New Location & TXA & Transfer Index X to Accumulator \\
\hline \multirow[t]{2}{*}{JSR} & Jump to New Location Saving Return & TXS & Transfer Index X to Stack Register \\
\hline & Address & TYA & Transfer Index Y to Accumulator \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow{3}{*}{MNEMONIC} & \multirow{3}{*}{operation} & \multicolumn{42}{|c|}{ADDRESSING MODES} & \multicolumn{5}{|l|}{PROCESSOR STATUS
CODES} \\
\hline & & \multicolumn{2}{|l|}{MMmediate} & \multicolumn{3}{|l|}{ABSOLUTE} & \multicolumn{3}{|l|}{ZERO PAGE} & \multicolumn{2}{|l|}{ACCUM} & & \multicolumn{3}{|l|}{IMPLIED} & \multicolumn{3}{|l|}{( \({ }^{\text {ND, }}\), X\()\)} & \multicolumn{2}{|l|}{(iND), Y} & \multicolumn{3}{|l|}{z Page, x} & \multicolumn{3}{|l|}{ABS, X} & \multicolumn{2}{|l|}{ABS, Y} & \multicolumn{2}{|l|}{Relative} & \multicolumn{3}{|l|}{INDIRECT} & \multicolumn{2}{|l|}{Z PAGE, Y} & \multicolumn{8}{|r|}{BIT ADDRESSING (OP BY BIT \#)} & 7 & - & \multirow[t]{2}{*}{. 4} & \multirow[t]{2}{*}{\[
\frac{21}{212}
\]} & \multirow[t]{2}{*}{\[
\frac{0}{c}
\]} \\
\hline & & OP & \# & OP & \({ }^{\circ} \mathrm{P}\) n & \# & OP & n & \# & OP & n & \# & OP & n & \# & OP & n & \# & OP & \# & OP & n & \# & OP & n \(\#\) & O & OP \({ }^{\text {n }}\) & n & OP & n \({ }^{\text {\# }}\) & OP & \(n\) & 0 & OP & n \# & \% 0 & 1 & 2 & 3 & 4 & 5 & 6 & 7 & N & v . & & & \\
\hline ADC &  & \[
\begin{aligned}
& 69 \\
& 29
\end{aligned}
\] & \[
\begin{array}{|l|l}
\hline 2 & 2 \\
2 & 2
\end{array}
\] & \[
\begin{array}{|l|l|}
\hline 2 & 60 \\
2 & 20 \\
\hline
\end{array}
\] & \[
\begin{array}{l|l|}
\hline 6 D & 4 \\
20 & 4 \\
\hline
\end{array}
\] & \[
\begin{array}{|l|}
\hline 3 \\
3 \\
\hline
\end{array}
\] & \[
\begin{array}{l|}
\hline 65 \\
25 \\
\hline
\end{array}
\] & \[
\begin{array}{|l|}
\hline 3 \\
3 \\
\hline
\end{array}
\] & \[
\begin{array}{|l|}
\hline 2 \\
2 \\
\hline
\end{array}
\] & & & & & & & & 6 & \begin{tabular}{l|l|l}
2 & 7 \\
2 & 3 \\
& \\
&
\end{tabular} & \[
\begin{aligned}
& 71 \\
& 31
\end{aligned}
\] & \begin{tabular}{l|l|l}
5 & 2 \\
5 & 2 \\
& \\
&
\end{tabular} & 75
35 & \begin{tabular}{|c}
4 \\
4 \\
4
\end{tabular} & \[
\begin{aligned}
& 2 \\
& 2 \\
& 2
\end{aligned}
\] & 70 & 4 & \[
\begin{array}{l|l}
3 & 7 \\
3 & \\
3
\end{array}
\] & \[
\begin{aligned}
& 79 \\
& 39
\end{aligned}
\] & 43 & & & & & & & & & & & & & & & & N & v: &  & 2 & \begin{tabular}{ll} 
z & \\
\(z\) & \\
\hline
\end{tabular} \\
\hline ASL & C- \(\begin{array}{lll}7 & 0 & -0\end{array}\) & & & OE & E 6 & 3 & 06 & & & OA & 2 & 1 & & & & & & & & & 16 & 4 & 2 & & 7 & & & & & & & & & & & & & & & & & & & N & . & \(\cdots\) & 2 & \(z c\) \\
\hline BBR[\#(0-7)] &  & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & \[
\begin{gathered}
0 F \\
8 F
\end{gathered}
\] & \[
\begin{gathered}
1 F \\
9 F
\end{gathered}
\] & \[
\begin{gathered}
2 F \\
A F
\end{gathered}
\] & \[
\begin{aligned}
& 3 \mathrm{~F} \\
& \mathrm{BF}
\end{aligned}
\] & \[
\left|\begin{array}{l|l|}
4 \mathrm{~F} \\
\mathrm{CF}
\end{array}\right|
\] & \[
\begin{aligned}
& 5 \mathrm{~F} \\
& \mathrm{DF}
\end{aligned}
\] & \[
\begin{aligned}
& 6 \mathrm{~F} \\
& \mathrm{EF}
\end{aligned}
\] & 7 FF & & . . & . . & . & . . \\
\hline BCC & Branch on \(\mathrm{C}=0\) ( \({ }^{\text {a }}\) & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & \(\cdot\) & - & . \(\cdot\) & . & . \\
\hline BCS & Branch on \(\mathrm{C}=1\)
Branch on \(\mathrm{Z}=1\)
(2) & & & & & & & & & & & & & & & & & & & & & & & & & & & & & \(\begin{array}{lll}2 & 2 \\ 2 & 2\end{array}\) & & & & & & & & & & & & & & & : & . . & \(\cdots\) & . \\
\hline BIT & A^M & & & 2 C & 2C 4 & 3 & 24 & 3 & 2 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & M. M & \(\mathrm{M}_{6}\). & . \(\cdot\) & \(z\) & z \\
\hline BMI
BNE & \(\begin{array}{ll}\text { Branch on } \mathrm{N}=1 \\ \text { Branch on } \mathrm{Z}=0 & \text { (2) } \\ \text { (2) }\end{array}\) & & & & & & & & & & & & & & & & & & & & & & & & & & & & & \(\begin{array}{lll}2 & 2 \\ 2 & 2 \\ 2\end{array}\) & & & & & & & & & & & & & & & \(\therefore\). & \(\because\) & \(\cdots\) & \(\cdots\) \\
\hline BPL & Branch on \(\mathrm{N}=0^{-}\)(2) & & & & & & & & & & & & & & & & & & & & & & & & & & & & 10 & & & & & & & & & & & & & & & & \(\therefore\). & \(\therefore .:\) & : & \(\therefore\). \\
\hline BRK & Break (See Fig 1) & & & & & & & & & & & & 00 & 7 & 1 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & . & . 1 - & 1. & - . \\
\hline BVC & \(\begin{array}{ll}\text { Branch on } \mathrm{V}=0 \\ \text { Branch on } \mathrm{V}=1 & \text { (2) }\end{array}\) & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & - . & - . & - & - \(\cdot\) \\
\hline CLC & \(\lim _{0 \rightarrow \mathrm{C}}\) & & & & & & & & & & & & 18 & & 1 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & ‥ & ! . . & : & . 0 \\
\hline CLD & \(0 \rightarrow\) D & & & & & & & & & & & & D8 & 2 & 1 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & . & - o & o . & . \(\cdot\) \\
\hline CLI & \(\xrightarrow{0 \rightarrow 1}\) & & & & & & & & & & & & 58 & & 1 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & - & - . & 0 & - \\
\hline CMP & \({ }_{\text {A }}^{0} \mathrm{M}\) (1) & C9 & & CD & & & & & & & & & & & & C1 & 6 & 2 D & D1 & 52 & D5 & 4 & 2 & DD & 4 & 3 D & D9 4 & 43 & & & & & & & & & & & & & & & & N & \(\stackrel{\text { N }}{ }\) & . & - & \(\dot{z}\) c \\
\hline CPX & X M & E0 & 2 & 2 EC & EC 4 & & E4 & & 2 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & N & N. & . & 2 & z c \\
\hline \({ }_{\text {CPY }}\) & \(\begin{array}{lll}Y & M \\ M & 1 \rightarrow\end{array}\) & C0 & \(2{ }^{2}\) & \(2{ }^{\text {CC }}\) & \begin{tabular}{l|l|l} 
CE & 4 \\
\hline & \\
6
\end{tabular} & & \({ }_{C 6}\) & & 2 & & & & & & & & & & & & D6 & 6 & 2 & DE & 73 & 3 & & & & & & & & & & & & & & & & & & & N: & . . & \(\therefore .:\) & \\
\hline DEX & \(\begin{array}{ll}\text { X } \\ \mathrm{X} & 1 \rightarrow \mathrm{C}\end{array}\) & & & & & & & & & & & & CA & 2 & 1 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & N. & . . & . . & z . \\
\hline DEY &  & & & & & & & & & & & & 88 & 2 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & N: & \(\cdots\) & - & z. \\
\hline EOR &  & 49 & 22 & \[
\begin{array}{l|l|l|l|l|l|}
\hline 4 \mathrm{DE} \\
\mathrm{EF}
\end{array}
\] & \[
\begin{array}{c|c}
4 D & 4 \\
E E & 6 \\
\hline
\end{array}
\] & 3
3 & \[
\left|\begin{array}{l}
45 \\
\mathrm{E} 6
\end{array}\right|
\] & & 2 & & & & & & & 41 & & & 51 & 52 & 55
\(F 6\) & 4 & 2 & & 4 &  & & 43 & & & & & & & & & & & & & & & & & N: & . . & \(\cdots\) & z z . \\
\hline INX & \(\mathrm{X}-1 \rightarrow \mathrm{X}\) & & & & & & & & & & & & EB & 2 & 1 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & N & . . & . . & . & z \\
\hline INY & Y \(1 \rightarrow Y\) & & & & & & & & & & & & C8 & & 1 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & . . & - \(\cdot\) & - & z \\
\hline JMP & Jump to New Loc & & & & \({ }^{C} 3\) & 3 & & & & & & & & & & & & & & & & & & & & & & & & & 6 C & 5 & 3 & & & & & & & & & & & & - & - & - & . \\
\hline LDA & \(\mathrm{Mamp}_{M \rightarrow \mathrm{~A}}\) (1) & & & & AD 4 & & A5 & & & & & & & & & A1 & 6 & & B1 & 52 & B5 & 4 & & & 4 & & & & & & & & & & & & & & & & & & & & ! . & \(\because\) & \(\cdots\) & z \\
\hline LDX & \(\underline{M \rightarrow X}\) (1) & A2 & 22 & 2 AE & AE 4 & & A6 & & 2 & & & & & & & & & & & & & & & & & & & \(4{ }^{4}\) & & & & & & 86 & 4 & & & & & & & & & & - & - & - & z. \\
\hline LDY & \(\mathrm{M} \mathrm{\rightarrow Y}\) (1) & AO & 22 & 2 AC & \(\begin{array}{ll}\text { AC } & 4 \\ 4 & \\ & \\ \end{array}\) & & \({ }_{4}{ }_{4}\) & & & & & & & & & & & & & & 84 & 4 & 2 & & 4 & 3 & & & & & & & & & & & & & & & & & & & \(\because:\) & \(\cdots\) & \(\because\) & z \({ }_{\text {c }}\) \\
\hline LSR &  & & & 4 E & 4 E 6 & & 46 & & 2 & 4A & 2 & & & & & & & & & & 56 & 6 & & & 7 & & & & & & & & & & & & & & & & & & & & : & \(\because\) & : & z c \\
\hline ORA & AVM \(\rightarrow\) A (1) & 09 & 22 & 2 OD & D 4 & 3 & 05 & 3 & 2 & & & & & & & 01 & & 2 & 11 & 52 & 15 & 4 & 2 & 1D & 4 & 3 & 19 & 43 & & & & & & & & & & & & & & & & & - • & - . & . & z \\
\hline PHA &  & & & & & & & & & & & & 48 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & \(\therefore\). & \(\cdots\) & : & : \\
\hline PHP &  & & & & & & & & & & & & \[
\begin{aligned}
& 08 \\
& 68
\end{aligned}
\] & \[
\left|\begin{array}{l}
3 \\
4
\end{array}\right|
\] & \[
\left|\begin{array}{l}
1 \\
1
\end{array}\right|
\] & & & & & & & & & & & & & & & & & & & & & & & & & & & & & N & . & \(\because\). & - . & z \\
\hline PLP & S \(1 \rightarrow\) S Ms \(\rightarrow\) P & & & & & & & & & & & & 28 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & (R) & (Restor & red) & \\
\hline RMB[\#(\#-7)] & \(\mathrm{O}_{0} \rightarrow \mathrm{M}_{0}\) (5) & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & 07 & 17 & 27 & 37 & 47 & 57 & 67 & 77 & & \(\cdots\) & \(\cdots \cdot\) & & \\
\hline \[
\begin{aligned}
& \mathrm{ROL} \\
& \mathrm{ROR}
\end{aligned}
\] &  & & & & \[
\begin{array}{l|l|}
\hline 2 \mathrm{EE} & 6 \\
6 \mathrm{CE} & 6
\end{array}
\] & & \[
\begin{aligned}
& 26 \\
& 66
\end{aligned}
\] & \[
\left.\begin{aligned}
& 5 \\
& 5
\end{aligned} \right\rvert\,
\] & \[
\left.\begin{aligned}
& 2 \\
& 2
\end{aligned} \right\rvert\,
\] & \[
\left.\begin{array}{|l|}
2 A \\
6 A
\end{array} \right\rvert\,
\] & \[
\left.\begin{array}{|l|}
2 \\
2
\end{array} \right\rvert\,
\] & & & & & & & & & & 36
76 & 6 & 2 & & 7 & 3 & & & & & & & & & & & & & & & & & & N &  & \(\because\). & \(\because:\) & z
z
C
c \\
\hline RTI & Ritr Int (See Fig 1) & & & & & & & & & & & & 40 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & (R & (Restor & red) & - \\
\hline RTS & Ritn Sub (See Fig 2) & E9 & & & & & E5 & 3 & 2 & & & & 60 & & & E1 & & & F1 & 52 & F5 & 4 & & FD & 4 & 3 & F9 & 43 & & & & & & & & & & & & & & & & & v: & : . & \(\cdots\) & \(\dot{z}^{\text {(3) }}\) \\
\hline SEC & \(\left.\right|_{1 \rightarrow C} ^{A-M-C \rightarrow A}\) & & 2 & & & & & & & & & & 38 & & & & & & & & & & & & & & F & & & & & & & & & & & & & & & & & & . & . \(\cdot\) & - & . 1 \\
\hline SED & \(1 \rightarrow \mathrm{D}\) & & & & & & & & & & & & F8 & 2 & 1 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & - & \(\cdots\) & 1. & - . \\
\hline SEI \({ }_{\text {SMB }(\# 10-7)}\) &  & & & & & & & & & & & & 78 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & . & . & : & 1. & : . \\
\hline \[
\left\lvert\, \begin{aligned}
& \text { SMB }[\#(0-7)] \\
& \text { STA }
\end{aligned}\right.
\] &  & & & & 3 C & & 85 & & & & & & & & & 81 & 6 & & 91 & 62 & & 4 & 2 & 9 D & 5 & 3 & c, & 53 & & & & & & & & 87 & 97 & A7 & B7 & C7 & D7 & E7 & & : & : & \(\therefore\). & . & \(\cdots\) \\
\hline STX & \(x \rightarrow M\) & & & & BE 4 & & 86 & 3 & 2 & & & & & & & & & & & & - & & & & & & & & & & & & & 96 & 2 & & & & & & & & & & . & - • & - . & - . \\
\hline STY & \(Y \rightarrow M\) & & & & & & & & 2 & & & & & & & & & & & & & & 2 & & & & & & & & & & & & & & & & & & & & & & \(\because\) & : & \(\therefore\). & i \\
\hline TAX \({ }_{\text {TAY }}\) & \(\underset{\substack{\text { A } \\ A \rightarrow Y}}{ }\) & & & & & & & & & & & & A \({ }_{\text {A }}\) & 2 & 1 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & \(\cdots\) & ! & ! . & \% \({ }^{2}\) \\
\hline TSX & \({ }_{s} \rightarrow x\) & & & & & & & & & & & & BA & 2 & 1 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & \(\cdots\) & . & -• & z. \\
\hline TXA &  & & & & & & & & & & & & \[
\begin{aligned}
& 8 A \\
& 9 A
\end{aligned}
\] & 2 & 1 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & \(\because\). & : & : . & . z . \\
\hline TXS & \(\underset{\substack{x \rightarrow S \\ y \rightarrow A}}{ }\) & & & & & & & & & & & & \[
\begin{aligned}
& 9 A \\
& 98
\end{aligned}
\] & 2 & 1 & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & . . & . . & \\
\hline NOTES & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & LEGE & END & & & & & & & & & \(M_{6}\) & & & Memory & \(y \mathrm{Bt} 6\) & \\
\hline 1 Add 1 to N & N if page boundary is c & ossed & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & X & & Index & x X & & & & & & & - & & & Add & & \\
\hline 2 Add 1 to N & \(N\) if branch occurs to sa & me pa & page & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & Y & & Index & & & & & & & & - & & & Subtrac & & \\
\hline Add 2 to & N if branch occurs to diff & fferent & thage & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & A & \(=\) & Accu & mulato & & & & & & & \(\wedge\) & & & And & & \\
\hline 3 Carry not & = Borrow & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & M & \(=\) & Mem & nory per & er effe & ctive & addr & ress & & & v & & \(=\mathrm{Or}\) & Or & & \\
\hline 4 If in decim & nal mode \(Z\) flag is invalid & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & Ms & & Mem & nory per & er sta & ck po & onter & & & & \(\checkmark\) & & \(=E x\) & Exclusiv & ive Or & \\
\hline accumulat & tor must be checked on & zero & result & & & & & & & & & & & & & & & & & & & & & & & & & & & & & & \(\mathrm{M}_{\mathrm{b}}\) & & Selec & cter ze & ero pa & ge m & nemor & ry bit & & & n & & \(=\mathrm{N}\) & Number & of cy & cycles \\
\hline 5 Effects 8-b & -bt data tield of the spec & cified & zero & page & e addres & & & & & & & & & & & & & & & & & & & & & & & & & & & & \(\mathrm{M}_{7}\) & \(=\) & Mem & nory Bit & & & & & & & \# & & & Number & er of & Byles \\
\hline
\end{tabular}

\section*{A. 3 INSTRUCTION CODE MATRIX}


\footnotetext{
0 \begin{tabular}{c|c}
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}\)
\end{tabular}
}
*Add 1 to N if page boundary is crossed.
**Add 1 to N if branch occurs to same page; add 2 to N if branch occurs to different page.

\section*{APPENDIX B \\ KEY REGISTER SUMMARY}


CPU Registers


Mode Control Register


3

Processor Status Register


Interrupt Enable and Flag Registers


Serial Communications Status Register

\section*{APPENDIX C \\ ADDRESS ASSIGNMENTS/MEMORY MAPS/PIN FUNCTIONS}

\section*{C. 1 I/O AND INTERNAL REGISTER ADDRESSES}
\begin{tabular}{|c|c|c|}
\hline ADDRESS (HEX) & READ & WRITE \\
\hline \[
\begin{array}{r}
001 \mathrm{~F} \\
1 \mathrm{E} \\
1 \mathrm{D} \\
1 \mathrm{C}
\end{array}
\] & \begin{tabular}{l}
Lower Counter B \\
Upper Counter B Lower Counter B, CLR Flag
\end{tabular} & Upper Latch B, Cntr B \(\leftarrow\) Latch B, CLR Flag Upper Latch B, Latch C \(\leftarrow\) Latch B Lower Latch B. \\
\hline \[
\begin{aligned}
& 1 B \\
& 1 A \\
& 19 \\
& 18
\end{aligned}
\] & \begin{tabular}{l}
Lower Counter A \\
Upper Counter A Lower Counter A, CLR Flag
\end{tabular} & Upper Latch A, Cntr A \(\leftarrow\) Latch A, CLR Flag Upper Latch A Lower Latch A \\
\hline \[
\begin{aligned}
& 17 \\
& 16 \\
& 15 \\
& 14 \\
& \hline
\end{aligned}
\] & Serial Receiver Data Register Serial Comm. Status Register Serial Comm. Control Register Mode Control Register & \begin{tabular}{l}
Serial Transmitter Data Register \\
Serial Comm. Status Reg. Bits 4 \& 5 only \\
Serial Comm Control Register \\
Mode Control Register
\end{tabular} \\
\hline \[
\begin{array}{r}
13 \\
12 \\
11 \\
0010
\end{array}
\] & Interrupt Enable Regıster Interrupt Flag Register Read FF & \begin{tabular}{l}
Interrupt Enable Regıster \\
Clear Int Flag (Bits 0-3 only, Write 0's only)
\end{tabular} \\
\hline \[
\begin{aligned}
& O F \\
& O E \\
& O D \\
& O C
\end{aligned}
\] & \multicolumn{2}{|l|}{\multirow{3}{*}{\begin{tabular}{l}
RESERVED \\
These addresses are reserved and are used by the CPU during Read and Write operation over the external Data Bus (DO-D7).
\end{tabular}}} \\
\hline \[
\begin{aligned}
& \hline 0 B \\
& O A \\
& 09 \\
& 08 \\
& \hline
\end{aligned}
\] & & \\
\hline \[
\begin{aligned}
& 07 \\
& 06 \\
& 05 \\
& 04
\end{aligned}
\] & & \\
\hline \[
\begin{array}{r}
03 \\
02 \\
01 \\
0000
\end{array}
\] & \begin{tabular}{l}
Port D \\
Port C \\
Port B \\
Port A
\end{tabular} & \begin{tabular}{l}
Port D \\
Port C \\
Port B \\
Port A
\end{tabular} \\
\hline
\end{tabular}

\section*{C. 2 FULL ADDRESS MODE MEMORY MAP \\ R6511Q OR R6500/13}

\section*{C. 3 FULL ADDRESS MODE MEMORY MAP R6500/13 ONLY}


\section*{C. 4 MULTIPLE FUNCTION PIN ASSIGNMENTS—PORT C AND PORT D}
\begin{tabular}{|c|c|c|c|c|}
\hline \begin{tabular}{c} 
PIN \\
NUMBER
\end{tabular} & \begin{tabular}{c} 
FULL ADDRESS \\
MODE
\end{tabular} & \begin{tabular}{c} 
I/O PORT \\
FUNCTION
\end{tabular} & \begin{tabular}{c} 
ABBREVIATED PORT \\
FUNCTION
\end{tabular} & \begin{tabular}{c} 
MULTIPLEXED PORT \\
FUNCTION
\end{tabular} \\
\hline 54 & PC0 & PC0 & A0 & A0 \\
55 & PC1 & PC1 & A1 & A1 \\
56 & PC2 & PC2 & A2 & A2 \\
57 & PC3 & PC3 & A12 & A3 \\
\hline 58 & PC4 & PC4 & A12 \\
59 & PC5 & PC5 & R/W \\
60 & A13 & PC6 & A13 & A13 \\
61 & A14 & PC7 & EMS & EMS \\
\hline 62 & PD0 & PD0 & D0 & A4/D0 \\
63 & PD1 & PD1 & D1 & A5/D1 \\
64 & PD2 & PD2 & D2 & A6/D2 \\
1 & PD3 & PD3 & D3 & A7/D3 \\
\hline 2 & PD4 & PD4 & D4 & A8/D4 \\
3 & PD5 & PD5 & D5 & A9/D5 \\
4 & PD6 & PD6 & D6 & A10/D6 \\
5 & PD7 & PD7 & D7 & A11/D7 \\
\hline
\end{tabular}

\title{
APPENDIX D \\ ELECTRICAL SPECIFICATIONS
}

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}} \& \mathrm{~V}_{\mathrm{RR}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{r}
\(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
0 to +70 \\
-40 to +85
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, V_{R R}=V_{C C} ; V_{S S}=0 V ; T_{A}=0^{\circ}\right.\) to \(70^{\circ}\), unless otherwise specified \()\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline RAM Standby Voltage (Retention Mode) & \(\mathrm{V}_{\mathrm{RR}}\) & 3.0 & & \(\mathrm{V}_{\text {cc }}\) & V & \\
\hline RAM Standby Current (Retention Mode) Commercial Industrial & \(\mathrm{I}_{\mathrm{RR}}\) & - & \[
\begin{aligned}
& 4 \\
& 5.2
\end{aligned}
\] & - & mA & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline \begin{tabular}{l}
Input High Voltage \\
All Except XTLI and \(\emptyset 2\) in Slave Option XTLI and \(\emptyset 2\) in Slave Option
\end{tabular} & \(\mathrm{V}_{\mathrm{IH}}\) & \[
\begin{array}{r}
+2.0 \\
+4.0 \\
\hline
\end{array}
\] & - & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{cc}} \\
& \mathrm{v}_{\mathrm{cc}} \\
& \hline
\end{aligned}
\] & v & \\
\hline Input Low Voltage & \(\mathrm{V}_{\text {IL }}\) & -0.3 & - & +0.8 & V & \\
\hline Input Leakage Current
\[
\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}
\] & \(\mathrm{I}_{\mathrm{N}}\) & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\text {IN }}=0\) to 5.0 V \\
\hline Input Low Current PA, PB, PC, PD & I/L & - & -1.0 & -1.6 & mA & \(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage (Except XTLO) & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & \(\mathrm{V}_{\mathrm{cc}}\) & V & \(\mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A}\) \\
\hline Output Low Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & +0.4 & V & \(\mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA}\) \\
\hline I/O Port Pull-Up Resistance PA0-PA7, PB0-PB7, PC0-PC7 & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Output Leakage Current (Three-State Off) & Iout & - & - & \(\pm 10\) & \(\mu \mathrm{A}\) & \\
\hline Input Capacitance XTLI, XTLO All Others & \(\mathrm{C}_{\text {IN }}\) & - & - & \[
\begin{aligned}
& 50 \\
& 10 \\
& \hline
\end{aligned}
\] & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) & \(\mathrm{C}_{\text {OUt }}\) & - & - & 10 & pF & \[
\begin{aligned}
& T_{A}=25^{\circ} \mathrm{C} \\
& V_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Outputs High) Commercial Industrial & \(P_{\text {D }}\) & - & \[
\begin{array}{r}
750 \\
-
\end{array}
\] & \[
\begin{aligned}
& 1100 \\
& 1200 \\
& \hline
\end{aligned}
\] & mW & \(\mathrm{T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{C C}=5.0 \mathrm{~V}\). \\
2. Negative sign indicates outward current flow, positive indicates inward flow.
\end{tabular}} \\
\hline
\end{tabular}

\section*{APPENDIX E \\ TIMING REQUIREMENTS AND CHARACTERISTICS}

\section*{E. 1 GENERAL NOTES}
1. \(V_{c c}=5 \mathrm{~V} \pm 5 \%, 0^{\circ} \mathrm{C} \leqslant T A \leqslant 70^{\circ} \mathrm{C}\)
2. A valid \(V_{c c}-\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}{lll}
\text { PA, PB } & \text { - } 50 \mathrm{pf} \text { maximum } \\
\text { PC (I/O Modes Only) } & -\quad 50 \mathrm{pf} \text { maximum } \\
\text { PC (ABB and Mux Mode) } & -\quad 130 \mathrm{pf} \text { maximum } \\
\text { PC6, PC7 (Full Address Mode) } & -\quad 130 \mathrm{pf} \text { maximum }
\end{array}
\]

\section*{E. 2 CLOCK TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\mathrm{CYC}}\) & Cycle Time & 1000 & \(10 \mu \mathrm{~s}\) & 500 & \(10 \mu \mathrm{~s}\) \\
\hline \(\mathrm{T}_{\text {PWx } 1}\) & XTLI Input Clock Pulse Width XTLO = VSS & \[
\begin{gathered}
500 \\
\pm 25
\end{gathered}
\] & - & \[
\begin{gathered}
250 \\
\pm 10
\end{gathered}
\] & - \\
\hline \(\mathrm{T}_{\text {PW02 }}\) & Output Clock Pulse Width at Minimum Tcyc & \(T_{\text {PWx }}\) & \[
\begin{aligned}
& T_{P W \times 1} \\
& \pm 25
\end{aligned}
\] & \(\mathrm{T}_{\mathrm{PW} \times 1}\) & \[
\begin{aligned}
& T_{P W \times 1} \\
& \pm 20
\end{aligned}
\] \\
\hline \(\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}\) & Output Clock Rise, Fall Time & - & 25 & - & 15 \\
\hline \(\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}\) & Input Clock Rise, Fall Time & - & 10 & - & 10 \\
\hline
\end{tabular}


Note that both EMS and Phase \(2\left(\phi_{2}\right)\) must be used to correctly enable the chip selects in the multiplexed or abbreviated bus modes.


\section*{R6511Q Microprocessor and R6500/13 Microcomputer}

\section*{E. 3 ABBREVIATED MODE TIMING—PC AND PD}
(MCR \(5=1\), MCR \(6=0\), MCR \(7=1\) )
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {PCAS }}\) & (PC0-PC4, PC6) Address Setup Time & - & 200 & - & 100 \\
\hline \(\mathrm{T}_{\text {PBSU }}\) & (PD) Data Setup Time & 50 & - & 35 & - \\
\hline \(\mathrm{T}_{\text {PвнR }}\) & (PD) Data Read Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PBHW }}\) & (PD) Data Write Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {Pbod }}\) & (PD) Data Output Delay & - & 175 & - & 130 \\
\hline \(\mathrm{T}_{\text {PCHA }}\) & (PC0-PC4, PC6) Address Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PCHV }}\) & (PC7) EMS Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PcVP }}\) & (PC7) EMS Stabilization Time & 30 & - & 30 & - \\
\hline TESU & EMS Setup Time & - & 350 & - & 210 \\
\hline
\end{tabular}

\section*{E.3.1 Abbreviated Mode Timing Diagram}


\section*{E. 4 MULTIPLEXED MODE TIMING—PC AND PD}
(MCR \(5=1\), MCR \(6=1\), MCR \(7=1\) )
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {PCAS }}\) & (PC0-PC4, PC6) Address Setup Time & - & 200 & - & 100 \\
\hline \(\mathrm{T}_{\text {PbAS }}\) & (PD) Address Setup Tıme & - & 220 & - & 120 \\
\hline \(\mathrm{T}_{\text {PBSU }}\) & (PD) Data Setup Time & 50 & - & 35 & - \\
\hline \(\mathrm{T}_{\text {PBHR }}\) & (PD) Data Read Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PBHW }}\) & (PD) Data Write Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PBDD }}\) & (PD) Data Output Delay & - & 175 & - & 140 \\
\hline \(\mathrm{T}_{\text {PCHA }}\) & (PC0-PC4, PC6) Address Hold Time & 30 & - & 30 & - \\
\hline \(T_{\text {PBHA }}\) & (PD) Address Hold Time & 10 & 100 & 10 & 80 \\
\hline \(T_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline \(T_{\text {PCHV }}\) & (PC7) EMS Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PCVD }}{ }^{(1)}\) & (PC7) Address to EMS Delay Time & 30 & & 30 & \\
\hline \(\mathrm{T}_{\text {PCVP }}\) & (PC7) \(\overline{\text { EMS }}\) Stabilizatıon Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {ESU }}\) & EMS Setup Time & - & 350 & - & 210 \\
\hline \multicolumn{6}{|l|}{NOTE 1 Values assume PC0-PC4, PC6 and PC7 have the same capacitive load} \\
\hline
\end{tabular}

\section*{E.4.1 Multiplex Mode Timing Diagram}


\section*{E. 5 I/O, EDGE DETECT, COUNTERS, AND SERIAL I/O TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \begin{tabular}{l}
\(T_{\text {Pow }}{ }^{\text {(1) }}\) \\
\(\mathrm{T}_{\text {смоs }}{ }^{\text {(1) }}\) \\
\(T_{\text {poow }}\)
\end{tabular} & \begin{tabular}{l}
Internal Write to Peripheral Data Valid \\
PA, PB, PC TTL \\
PA, PB, PC CMOS \\
PD
\end{tabular} & - & \[
\begin{gathered}
500 \\
1000 \\
175
\end{gathered}
\] & — & \[
\begin{array}{r}
500 \\
1000 \\
150 \\
\hline
\end{array}
\] \\
\hline \begin{tabular}{l}
\(T_{\text {posu }}\) \\
\(T_{\text {posu }}\)
\end{tabular} & Peripheral Data Setup Time PA, PB, PC PD & \[
\begin{array}{r}
200 \\
50
\end{array}
\] & - & \[
\begin{array}{r}
200 \\
50
\end{array}
\] & - \\
\hline \[
\begin{aligned}
& T_{\text {PHR }} \\
& T_{\text {PHR }}
\end{aligned}
\] & Peripheral Data Hold Time PA, PB, PC PD & \[
\begin{aligned}
& 75 \\
& 10
\end{aligned}
\] & - & \[
\begin{aligned}
& 75 \\
& 10
\end{aligned}
\] & - \\
\hline \(\mathrm{T}_{\text {EPW }}\) & PA0-PA3 Edge Detect Pulse Width & \(\mathrm{T}_{\mathrm{CYC}}\) & - & \(\mathrm{T}_{\mathrm{crc}}\) & - \\
\hline \[
\begin{aligned}
& \mathrm{T}_{\mathrm{CPW}} \\
& \mathrm{~T}_{\mathrm{CD}}{ }^{(1)}
\end{aligned}
\] & \begin{tabular}{l}
Counters \(A\) and \(B\) \\
PA4, PA5 Input Pulse Width PA4, PA5 Output Delay
\end{tabular} & \(\mathrm{T}_{\mathrm{crc}}\) & \[
500
\] & \(\mathrm{T}_{\text {cyc }}\) & - \\
\hline \begin{tabular}{l}
\(\mathrm{T}_{\text {pgLw }}\) \\
Tplsu \\
\(T_{\text {PGLH }}\)
\end{tabular} & Port B Latch Mode PAO Strobe Pulse Width PB Data Setup Time PB Data Hold Time & \[
\begin{array}{r}
T_{\text {crc }} \\
175 \\
30
\end{array}
\] & - & \[
\begin{array}{r}
T_{\mathrm{crc}} \\
150 \\
30
\end{array}
\] & - \\
\hline \begin{tabular}{l}
\(T_{\text {pow }}{ }^{(1)}\) \\
\(\mathrm{T}_{\text {смоs }}{ }^{\text {(1) }}\) \\
\(T_{\text {CPW }}\) \\
\(T_{\text {Pow }}{ }^{(1)}\) \\
\(\mathrm{T}_{\text {смоs }}{ }^{\text {(1) }}\)
\end{tabular} & \begin{tabular}{l}
Serial I/0 \\
PA6 XMTR TTL \\
PA6 XMTR CMOS \\
PA4 RCVR S/R Clock Width \\
PA4 XMTR Clock-S/R Mode (TTL) \\
PA4 XMTR Clock-S/R Mode (CMOS)
\end{tabular} &  & \[
\begin{array}{r}
500 \\
1000 \\
- \\
500 \\
1000
\end{array}
\] & \(4 \mathrm{~T}_{\mathrm{crc}}\) & \[
\begin{array}{r}
500 \\
1000 \\
- \\
500 \\
1000
\end{array}
\] \\
\hline
\end{tabular}

NOTE 1 Maximum Load Capacitance. 50pF
Passive Pull-Up Required

\section*{E.5.1 I/O, Edge Detect, Counter, and Serial I/O Timing}


\section*{E. 6 MICROPROCESSOR TIMING (D0-D7, A0-A12, A15, SYNC, R/W)}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|l|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\text {Rws }}\) & R/W Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {ADS }}\) & \[
\begin{aligned}
& \text { A0-A12, A15 Setup } \\
& \text { Time }
\end{aligned}
\] & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {DSU }}\) & D0-D7 Data Setup Time & 50 & - & 35 & - \\
\hline \(\mathrm{T}_{\text {HR }}\) & D0-D7 Read Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\mathrm{Hw}}\) & D0-D7 Write Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {mos }}\) & D0-D7 Write Output Delay & - & 175 & - & 150 \\
\hline \(\mathrm{T}_{\text {SYN }}\) & SYNC Setup & - & 225 & - & 175 \\
\hline \(\mathrm{T}_{\text {HA }}\) & A0-A12, A15 Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {HRW }}\) & R/W Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {ACC }}\) & \begin{tabular}{l}
External Memory Access \\
Time \(\mathrm{T}_{\mathrm{ACC}}=\mathrm{T}_{\mathrm{CrC}}-\mathrm{T}_{\mathrm{F}}\) \(T_{\text {ADS }}-T_{\text {DSU }}\)
\end{tabular} & - & \(\mathrm{T}_{\text {ACC }}\) & - & \(\mathrm{T}_{\text {ACC }}\) \\
\hline \(\mathrm{T}_{\text {SYH }}\) & SYNC Hold TIme & 30 & - & 30 & - \\
\hline
\end{tabular}

\section*{E.6.1 Microprocessor Timing Diagram}


\section*{R6500/41 AND R6500/42 ONE-CHIP INTELLIGENT PERIPHERAL CONTROLLERS} Rockwell

\section*{SECTION 1 \\ INTRODUCTION}

\subsection*{1.1 FEATURES}
- Directly compatible with \(6500,6800,8080\), and \(Z 80\) 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 4K 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)

\section*{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.

\subsection*{1.2 SUMMARY}

The Rockwell R6500/41 and R6500/42 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. The one-chip R6500/41 IPC has an enhanced R6502 CPU, 1.5K 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 \(1 / \mathrm{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/ \(\star\) 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).

\subsection*{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 optıon. This option is available for port groups only, not for individual port lines.

\section*{SECTION 2 \\ 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 tıming requirements.


Figure 2-1. Interface Diagram
\begin{tabular}{|c|}
\hline  \\
\hline
\end{tabular}

Figure 2.2 R6500/41 Pin Out Designation (40 PIN DIP)


Figure 2-4. R6500/42 Pin Out Designation (64 PIN OUIP)


Figure 2-3. R6500/41 Dimensional Outline


Figure 2-5. R6500/42 Dimensional Outline

Table 2-1. Pin Description


\section*{SECTION 3 \\ SYSTEM ARCHITECTURE}

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.

\section*{NOTE}

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

\subsection*{3.1 CPU LOGIC}

The internal CPU 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.

\subsection*{3.1.1 Accumulator}

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

\subsection*{3.1.2 Index Registers}

There are two 8-bit index registers, X and Y . Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly simplifies many types of programs, especially those using data tables.

\subsection*{3.1.3 Stack Pointer}

The Stack Pointer is an 8-bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, 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, ie., memory locations 007F-0040. Normal usage calls for the initialization of the Stack Pointer at 007F.

\subsection*{3.1.4 Arithmetic and Logic Unit (ALU)}

All arithmetic and logic operations take place in the ALU, including incrementing and decrementing internal registers (except the Program Counter). The ALU cannot store data for more than one cycle. If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs.

\subsection*{3.1.5 Program Counter}

The 16-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter (PCL) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter ( PCH ) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

\subsection*{3.1.6 Instruction Register and Instruction Decode}

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register then decoded along with timing and interrupt signals to generate control signals for the various registers.

\subsection*{3.1.7 Timing Control}

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is initialized each time an instruction fetch is executed and is advanced at the beginning of each low level of the Clock in puise 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 tımıng control unit.


Figure 3-1. R6500/41 \& R6500/42 Block Diagram

\subsection*{3.1.8 Interrupt Logic}

Interrupt logıc controls the sequencing of two interrupts: \(\overline{\operatorname{RES}}\) and \(\overline{\mathrm{IRQ}}, \overline{\mathrm{IRQ}}\) is generated by any one of four conditions: Counter Overflow, Positive Edge Detect, Negative Edge Detect, and Input Data Register Full.

\subsection*{3.2 NEW INSTRUCTIONS}

In addition to the standard 6502 instruction set, four instructions have been added to the devices to simplify operations that previously required a read/modify/write operation. In order for these instructions to be equally applicable to any I/O ports, with or without mixed input and output functions, the I/O ports have been designed to read the contents of the specified port data register during the Read cycle of the read/ modify/write operation, rather than I/O pins as in normal read cycles. The added instructions and their format are explained in the following subparagraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions.

\subsection*{3.2.1 Set Memory Bit (SMB m, Addr.)}

This instruction sets to " 1 " one of the 8 -bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and 1 of 8 bits to be set. The second byte of the instruction designates address ( \(00-\mathrm{FF}\) ) of the byte or \(\mathrm{I} / \mathrm{O}\) port to be operated upon.

\subsection*{3.2.2 Reset Memory Bit (RMB m, Addr.)}

This instruction is the same operation and format as SMB instruction except a reset to " 0 " of the bit results.

\subsection*{3.2.3 Branch on Bit Set Relative (BBS m, Addr, DEST)}

This instruction tests one of 8 bits designated by a three bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction is used to specify the 8 bit relative address to which the instruction branches If the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

\subsection*{3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST)}

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

\subsection*{3.3 READ-ONLY-MEMORY (ROM)}

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.

\subsection*{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.

\subsection*{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\).

\subsection*{3.6 MODE CONTROL REGISTER (MCR)}

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for 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
\begin{tabular}{|c|c|}
\hline Control Signal & Description \\
\hline IER 0 & Positive Edge Detect, Interrupt Enablewhen this bit is true, a positive going signal on PAO will generate an IRQ and set the corresponding flag bit \\
\hline 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. \\
\hline 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 \\
\hline 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 37 1) Reading the ODR clears INT-1 and ODRF flags \\
\hline IER 4 & Input Data Regıster 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 37 1) \\
\hline IER 5 & Counter Interrupt Enable-if enabled, an \(\overline{\mathrm{IRQ}}\) is generated whenever the Counter overflows \\
\hline
\end{tabular}

\subsection*{3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)}

An 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 untll 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 examıned at any tıme by readıng at address: 0011. Edge detect IFR bits may be cleared by executıng 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 writıng 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

\subsection*{3.7.1 External Interrupts ( \(\overline{\text { INT }}\) )}

An external interrupt \(\overline{\mathbb{N T}}\) to the Host computer may be selected in two modes. (See Section 5 for information on the Host/Device interface).

\section*{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{\mathrm{INT}}\) is negated when the Host processor reads the ODR.

\section*{INPUT DATA REGISTER (IDR) EMPTY}

When IER 4 of the Interrupt Enable Register is set to a " 1 ", the device will assert the INT (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.

\subsection*{3.8 PROCESSOR STATUS REGISTER}

The 8-bit Processor Status Register, shown in Figure 3-4, contans seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the CPU. The R6502 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags. Each of the eight processor status flags is described in the following sections.

\subsection*{3.8.1 Carry Bit (C)}

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.
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.

\subsection*{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{RQ}}\) signal will be serviced. If the bit is set to logic 1 , the \(\overline{\operatorname{IRQ}}\) signal will be ignored. The CPU will set the Interrupt Disable Bit to logic 1 if a RESET ( \(\overline{\operatorname{RES}}\) ) 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.

\subsection*{3.8.2 Zero Bit (Z)}

The Zero Bit ( \(Z\) ) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to


Figure 3-4. Processor Status Register

\subsection*{3.8.4 Decimal Mode Bit (D)}

The Decimal Mode Bit (D), is used to control the arithmetic mode of the CPU. When this bit is set to logic 1 , the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction will clear it. The PLP and RTI instructıons also effect the Decimal Mode Bit.

\section*{CAUTION}

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application to the device. This bit must be initialized to the desired state by the user program or erroneous results may occur

\subsection*{3.8.5 Break Bit (B)}

The Break Bit (B) is used to determine the condition which caused the 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 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

\subsection*{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=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.

\subsection*{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*{SECTION 4 \\ PARALLEL INPUT/OUTPUT PORTS}

\section*{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, \(\overline{\mathrm{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 optıon.

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 \(1 / 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\}\)

\subsection*{4.1 INPUTS}

Inputs for Ports A and C, and also Ports F and G of the R6500/42, are enabled by loadıng 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 I/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.

\subsection*{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 MCR6 be set to a " 1 " and MCR7 be set to a " 0 ".

\subsection*{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, PA0 can detect postive 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 \(\varnothing 2\) clock rate. Edge detection timing is shown in Section E.5.

Table 4-2. Port A Control \& Usage
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{PAO-PA1 I/O} & \multicolumn{2}{|c|}{\multirow[t]{2}{*}{\[
\begin{gathered}
\text { PA2 I/O } \\
\hline \text { MCR0 }=0 \\
\text { MCR1 }=0
\end{gathered}
\]}} & \multicolumn{4}{|c|}{PA2 COUNTER} & \multicolumn{2}{|l|}{PA3-PA7 I/O} \\
\hline & & & & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCRO }=1 \\
& \text { MCR1 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR0 }=X \\
& \text { MCR1 }=1
\end{aligned}
\]} & & \\
\hline \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} \\
\hline NAME & TYPE & NAME & TYPE & NAME & TYPE & NAME & TYPE & NAME & TYPE \\
\hline \[
\begin{aligned}
& \hline \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 \\
\hline
\end{tabular}
(1) POSITIVE EDGE DETECT
(2) NEGATIVE EDGE DETECT
(3) HARDWARE BUFFER FLOAT

\subsection*{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 Appendıx E. 3 through E. 5 for Port B timing.

\subsection*{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, PC0-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.

\subsection*{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 Appendıx E. 3 through E 5 for Port E, F \& Port G tıming

Table 4-3. Port B Control \& Usage
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{\multirow[t]{3}{*}{}} & \multicolumn{4}{|c|}{I/O MODES} & \multicolumn{2}{|l|}{ABBREVIATED MODE} & \multicolumn{4}{|c|}{MULTIPLEXED MODE} \\
\hline & & \multicolumn{2}{|r|}{\multirow[t]{2}{*}{\[
\begin{aligned}
& \hline \text { MCR7 }=0 \\
& \text { MCR6 }=0 \\
& \hline \text { SIGNAL } \\
& \hline
\end{aligned}
\]}} & \multicolumn{2}{|r|}{\multirow[t]{2}{*}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=1 \\
& \hline \text { SIGNAL }
\end{aligned}
\]}} & \multicolumn{2}{|r|}{\multirow[t]{2}{*}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCRR }=0 \\
& \hline \text { SIGNAL }
\end{aligned}
\]}} & \multicolumn{4}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=1 \\
& \hline
\end{aligned}
\]} \\
\hline & & & & & & & & \multicolumn{2}{|c|}{PHASE 1} & \multicolumn{2}{|c|}{PHASE 2} \\
\hline & PIN & \multirow[b]{2}{*}{NAME} & \multirow[t]{2}{*}{\begin{tabular}{l}
TYPE \\
(1)
\end{tabular}} & \multirow[b]{2}{*}{NAME} & \multirow[t]{2}{*}{\begin{tabular}{l}
TYPE \\
(2)
\end{tabular}} & \multirow[b]{2}{*}{NAME} & \multirow[t]{2}{*}{\begin{tabular}{l}
TYPE \\
(3)
\end{tabular}} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} \\
\hline \# & \# & & & & & & & NAME & TYPE (2) & NAME & TYPE (3) \\
\hline 30 & 49 & PB0 & INPUT & PB0 & OUTPUT & D0 & 1/0 & A4 & OUTPUT & D0 & 1/0 \\
\hline 31 & 50 & PB1 & INPUT & PB1 & OUTPUT & D1 & 1/0 & A5 & OUTPUT & D1 & 1/0 \\
\hline 32 & 51 & PB2 & INPUT & PB2 & OUTPUT & D2 & 1/0 & A6 & OUTPUT & D2 & 1/0 \\
\hline 33 & 52 & PB3 & INPUT & PB3 & OUTPUT & D3 & I/O & A7 & OUTPUT & D3 & 1/0 \\
\hline 34 & 53 & PB4 & INPUT & PB4 & OUTPUT & D4 & 1/0 & A8 & OUTPUT & D4 & 1/0 \\
\hline 35 & 54 & PB5 & INPUT & PB5 & OUTPUT & D5 & 1/0 & A9 & OUTPUT & D5 & 1/O \\
\hline 36 & 55 & PB6 & INPUT & PB6 & OUTPUT & D6 & 1/0 & A10 & OUTPUT & D6 & 1/0 \\
\hline 37 & 56 & PB7 & INPUT & PB7 & OUTPUT & D7 & 1/0 & A11 & OUTPUT & D7 & 1/0 \\
\hline
\end{tabular}
(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
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{\multirow[t]{3}{*}{}} & \multicolumn{2}{|c|}{I/O MODE} & \multicolumn{2}{|c|}{ABBREVIATED MODE} & \multicolumn{2}{|r|}{\[
\begin{aligned}
& \hline \hline \text { MULTIPLEXED } \\
& \text { MODE }
\end{aligned}
\]} \\
\hline & & \multicolumn{2}{|c|}{\[
\begin{aligned}
\text { MCR7 } & =0 \\
\text { MCR6 } & =\mathbf{x}
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR }=1
\end{aligned}
\]} \\
\hline & & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} \\
\hline \[
\begin{gathered}
\text { PIN } \\
\#
\end{gathered}
\] & \[
\begin{gathered}
\text { PIN } \\
\#
\end{gathered}
\] & NAME & TYPE
(1) & NAME & \begin{tabular}{l}
TYPE \\
(2)
\end{tabular} & NAME & \begin{tabular}{l}
TYPE \\
(2)
\end{tabular} \\
\hline 13 & 16 & PCO & 1/0 & AO & OUTPUT & AO & OUTPUT \\
\hline 14 & 17 & PC 1 & 1/0 & A1 & OUTPUT & A1 & OUTPUT \\
\hline 15 & 18 & PC2 & 1/0 & A2 & OUTPUT & A2 & OUTPUT \\
\hline 16 & 19 & PC3 & I/O & A3 & OUTPUT & A3 & OUTPUT \\
\hline 17 & 20 & PC4 & 1/0 & EMS & OUTPUT & EMS & OUTPUT \\
\hline 18 & 21 & PC5 & 1/0 & \(\mathrm{R} / \overline{\mathrm{W}}\) & OUTPUT & \(\underline{R} / \bar{W}\) & OUTPUT \\
\hline 19 & 22 & PC6* & 1/O & \(\overline{\mathrm{INT}}{ }^{*}\) & OUTPUT & \(\underline{1 N T}{ }^{*}\) & OUTPUT \\
\hline
\end{tabular}
(1) RESISTIVE PULL-UP, ACTIVE BLUFFER PULL-DOWN \(\quad\) *PC6 if MCR5 \(=0, \overline{\text { INT }}\) If MCR5 \(=1\)
(2) ACTIVE BUFFER PULL-UP AND PULL-DOWN

\section*{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. 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
\begin{tabular}{|c|c|l|}
\hline RS (A \()\) & READ & WRITE \\
\hline 1 & \begin{tabular}{l} 
HOST \\
STATUS FLAG
\end{tabular} & \begin{tabular}{l} 
COMMAND \\
INPUT
\end{tabular} \\
\hline 0 & \begin{tabular}{l} 
DATA REG \\
OUTPUT
\end{tabular} & \begin{tabular}{l} 
DATA REG \\
INPUT
\end{tabular} \\
\hline
\end{tabular}

\subsection*{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 (HB0-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{C S}\) is asserted
- RS (AO) input selects ODR or HSFR
- The contents of ODR or the Flag Regıster are placed on the host data bus (HB0-HB7) when the appropriate Host read signals are asserted.

\subsection*{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 contaıns 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 seviced by the device in ether read or write modes and monitored by the Host (Read Only).

Flag F1 can be read at anytıme 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 tıme 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{\mathrm{RES}}\) input

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:


Figure 5-1. Host Status Flag Register Bit Allocation

\subsection*{5.3 HOST COMPUTER INTERFACE}

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)
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{\begin{tabular}{c} 
Characteristics \\
\(\mathbf{1}\) and \(\mathbf{2} \mathbf{~ M H z}\)
\end{tabular}} & Symbol & Min & Max \\
\hline\(\overline{\mathrm{CS}, \mathrm{R} / \overline{\mathrm{W}}, \mathrm{RS} \text { Setup Time }}\) & \(\mathrm{t}_{\mathrm{CS}}\) & 10 & - \\
\hline Access Time & \(\mathrm{t}_{\mathrm{DA}}\) & - & \(90^{\circ}\) \\
\hline Data Hold Time & \(\mathrm{t}_{\mathrm{DHR}}\) & 10 & - \\
\hline Control Hold Time & \(\mathrm{t}_{\text {HC }}\) & 10 & - \\
\hline Write Data Setup Time & \(\mathrm{t}_{\text {WDS }}\) & 75 & - \\
\hline Write Data Hold Time & \(\mathrm{t}_{\text {DHW }}\) & 10 & - \\
\hline Write Stroke Width & \(\mathrm{t}_{\text {WR }}\) & 75 & - \\
\hline \begin{tabular}{l} 
Note: \\
90 ns when loading \(=130 \mathrm{pF}+1\) TTL LOAD and \\
75 ns when loading \(=90 \mathrm{pF}+1\) TTL LOAD.
\end{tabular} \\
\hline
\end{tabular}

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)
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{\begin{tabular}{c} 
Characteristics \\
1 and \(2 \mathbf{M H z}\)
\end{tabular}} & Symbol & Min & Max \\
\hline\(\overline{\mathrm{CS}}, \mathrm{AO}\) Setup Time & \(\mathrm{t}_{\mathrm{CS}}\) & 10 & - \\
\hline Data Access Time on Read & \(\mathrm{t}_{\mathrm{DA}}\) & - & \(90^{\circ}\) \\
\hline Data Hold Time & \(\mathrm{t}_{\mathrm{DHR}}\) & 10 & - \\
\hline Control Hold Time & \(\mathrm{t}_{\mathrm{HC}}\) & 10 & - \\
\hline Write Data Setup Time & \(\mathrm{t}_{\mathrm{WDS}}\) & 75 & - \\
\hline Write Data Hold Time & \(\mathrm{t}_{\mathrm{DHW}}\) & 10 & - \\
\hline Write Stroke Width & \(\mathrm{t}_{\text {WR }}\) & 75 & - \\
\hline
\end{tabular}

\section*{Note:}

90 ns when loading \(=130 \mathrm{pF}+1 \mathrm{TTL}\) LOAD and
75 ns when loading \(=90 \mathrm{pF}+1 \mathrm{TTL}\) LOAD.


Figure 5-3. Timing Diagram—Host Interface (MCR4 = 0) (6500 Version)


Figure 5-4. Timing Diagram—Host Interface (MCR4 = 1) (8080 Version)

\section*{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•

\section*{Counter}
- Pulse width measurement
- Pulse Generatıon
- 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.

\subsection*{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 contans the count of etther \(\phi 2\) clock pulses or external events, depending on the counter mode selected The contents of the Counter may be read any tıme 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 etther 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
\begin{tabular}{|c|c|l|}
\hline \begin{tabular}{c} 
MCR1 \\
(bit 1)
\end{tabular} & \begin{tabular}{c} 
MCR0 \\
(bit 0)
\end{tabular} & \multicolumn{1}{c|}{ Mode } \\
\hline 0 & 0 & Interval Tımer \\
0 & 1 & Pulse Generatıon \\
1 & 0 & Event Counter \\
1 & 1 & Pulse Width Measurement \\
\hline
\end{tabular}

The Interval Timer, Pulse Generation, and Pulse Width Measurement Modes are \(\phi 2\) clock counter modes The Event Counter Mode counts the occurrences of an external event on the CNTR line (PA2)

The Counter is set to the Interval Timer Mode (00) when a \(\overline{\mathrm{RES}}\) signal is generated

\subsection*{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} \emptyset 2\) clock rate or \(0.5 \mu \mathrm{~s}\) to 32767 ms at the \(2 \mathrm{MHz} \phi 2\) clock rate Time intervals greater than the maximum Counter value can be easily measured by counting \(\overline{\mathrm{RQ}}\) interrupt requests in the counter \(\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{IRQ}}\) 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

\subsection*{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

\subsection*{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 62 is a timing diagram of the Event Counter Mode


Figure 6-2. Event Counter Mode

\subsection*{6.1.4 Pulse Width Measurement Mode}

This mode allows the accurate measurement of a low pulse duration on the 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*{SECTION 7}

POWER ON/INITIALIZATION CONSIDERATIONS

\subsection*{7.1 POWER ON TIMING}

After application of VCC power to the device, \(\overline{\operatorname{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 tıme is typıcally 20 ms


Figure 7-1. Power Turn-On Timing Detail

\subsection*{7.2 POWER-ON RESET}

The occurrence of \(\overline{\operatorname{RES}}\) going from low to high will cause the device to set the Interrupt Mask Bit-bit 2 of the Processor Status Register-and initiate a reset vector fetch at address FFFC and FFFD to begin user program execution All of the I/O ports 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

\subsection*{7.3 RESET ( \(\overline{\operatorname{RES}}\) ) CONDITIONS}

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 set as shown in Table 7-1

Table 7-1. \(\overline{R E S}\) Initialization of I/O Ports and Registers
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline BIT NO. \(\longrightarrow\) & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{9}{|l|}{REGISTERS} \\
\hline Processor Status & - & - & - & - & - & 1 & - & - \\
\hline Mode Control (MCR) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline Int Enable (IER) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline Int Flag (IFR) & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 \\
\hline Host Status Flag & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline Input Data & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline Output Data & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
\hline \multicolumn{9}{|l|}{PORTS} \\
\hline PA Latch & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline PB Latch & , & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline PC Latch & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline PE Latch \()\) R6500/42 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline PF Latch R6500/42 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline PG Latch only & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 \\
\hline
\end{tabular}

All RAM and other CPU registers will initialize in a random, nonrepeatable data pattern

\subsection*{7.4 INITIALIZATION}

Any initialization process for the device should include a \(\overline{R E S}\) as indicated in the preceding paragraphs. After stabilization of the external clock (if a power on situation) an initıalization routine should be executed to perform (as a minımum) 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 poınter starting address into X Register
TXS Transfer \(X\) Regıster 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

\title{
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.

\section*{A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE}
\begin{tabular}{|c|c|c|c|}
\hline MNEMONIC & INSTRUCTION & MNEMONIC & INSTRUCTION \\
\hline ADC & Add Memory to Accumulator with Carry & LDA & Load Accumulator with Memory \\
\hline AND & "AND" Memory with Accumulator & LDX & Load Index X with Memory \\
\hline \multirow[t]{3}{*}{ASL} & \multirow[t]{3}{*}{Shift Left One Bit (Memory or Accumulator)} & LDY & Load Index Y with Memory \\
\hline & & LSR & Shift One Bit Right (Memory or \\
\hline & & & Accumulator) \\
\hline *BBR & Branch on Bit Reset Relative & & \\
\hline *BBS & Branch on Bit Set Relative & & \\
\hline BCC & Branch on Carry Clear & NOP & No Operation \\
\hline BCS & Branch on Carry Set & & \\
\hline BEQ & Branch on Result Zero & & \\
\hline BIT & Test Bits in Memory with Accumulator & ORA & "OR" Memory with Accumulator \\
\hline BMI & Branch on Result Minus & & \\
\hline BNE & Branch on Result not Zero & & \\
\hline BPL & Branch on Result Plus & PHA & Push Accumulator on Stack \\
\hline BRK & Force Break & PHP & Push Processor Status on Stack \\
\hline BVC & Branch on Overflow Clear & PLA & Pull Accumulator from Stack \\
\hline BVS & Branch on Overflow Set & PLP & Pull Processor Status from Stack \\
\hline CLC & Clear Carry Flag & *RMB & Reset Memory Bit \\
\hline CLD & Clear Decimal Mode & ROL & Rotate One Bit Left (Memory or \\
\hline CLI & Clear Interrupt Disable Bit & & Accumulator) \\
\hline CLV & Clear Overflow Flag & ROR & Rotate One Bit Right (Memory or \\
\hline CMP & Compare Memory and Accumulator & & Accumulator) \\
\hline CPX & Compare Memory and Index X & RTI & Return from Interrupt \\
\hline CPY & Compare Memory and Index Y & RTS & Return from Subroutine \\
\hline DEC & Decrement Memory by One & SBC & Subtract Memory from Accumulator with \\
\hline DEX & Decrement Index \(X\) by One & & Borrow \\
\hline \multirow[t]{3}{*}{DEY} & Decrement Index Y by One & SEC & Set Carry Flag \\
\hline & & SED & Set Decimal Mode \\
\hline & & SEI & Set Interrupt Disable Status \\
\hline \multirow[t]{4}{*}{EOR} & "Exclusive-Or" Memory with & *SMB & Set Memory Bit \\
\hline & Accumulator & STA & Store Accumulator in Memory \\
\hline & & STX & Store Index X in Memory \\
\hline & & STY & Store Index Y in Memory \\
\hline INC & Increment Memory by One & & \\
\hline INX & Increment Index X by One & & \\
\hline \multirow[t]{3}{*}{INY} & Increment Index Y by One & TAX & Transfer Accumulator to Index X \\
\hline & & TAY & Transfer Accumulator to Index Y \\
\hline & & TSX & Transfer Stack Pointer to Index \(X\) \\
\hline JMP & Jump to New Location & TXA & Transfer Index X to Accumulator \\
\hline \multirow[t]{2}{*}{JSR} & Jump to New Location Saving Return & TXS & Transfer Index \(X\) to Stack Register \\
\hline & Address & TYA & Transfer Index \(Y\) to Accumulator \\
\hline
\end{tabular}


\section*{A. 3 INSTRUCTION CODE MATRIX}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline - & 0 & 1 & 2 & 3 & 4 & 5 & 6 & 7 & 8 & 9 & A & B & C & D & E & F & \\
\hline \(\sum_{0}\) & BRK Implied 17 & \[
\begin{gathered}
\text { ORA } \\
\text { (IND, X) } \\
266
\end{gathered}
\] & & & & \[
\begin{aligned}
& \hline \text { ORA } \\
& Z P \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \hline \text { ASL } \\
& \mathrm{ZP} \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & \[
\begin{gathered}
\text { RMBO } \\
\text { ZP } \\
2 \quad 5 \\
\hline
\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}
\] & \[
\begin{aligned}
& \text { ASL } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{gathered}
\text { BBRO } \\
\text { ZP } \\
3 \quad 5^{* *}
\end{gathered}
\] & 0 \\
\hline 1 & \begin{tabular}{l}
BPL \\
Relative 2 2**
\end{tabular} & \[
\begin{gathered}
\text { ORA } \\
\text { (IND), } Y \\
25^{*}
\end{gathered}
\] & & & & \[
\begin{aligned}
& \text { ORA } \\
& \text { ZP, } X \\
& 24
\end{aligned}
\] & \[
\begin{gathered}
\hline \text { ASL } \\
\text { ZP, X } \\
26 \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& \text { RMB1 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
\(\underset{\substack{\text { CLClied } \\ \text { Imp }}}{ }\) \\
12
\end{tabular} & \[
\begin{gathered}
\text { ORA } \\
\text { ABS, Y } \\
3 \quad 4^{*}
\end{gathered}
\] & & & & ORA ABS, \(X\) \(34^{*}\) &  & \[
\begin{aligned}
& \text { BBR1 } \\
& \text { ZP } \\
& 3 \quad 5 * *
\end{aligned}
\] & 1 \\
\hline 2 & JSR
Absolute 36 & \[
\begin{gathered}
\text { AND } \\
\text { (IND, X) } \\
266
\end{gathered}
\] & & & \[
\begin{aligned}
& \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{aligned}
& \text { RMB2 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & PLP Implied 14 & \[
\begin{aligned}
& \text { AND } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & ROL Accum 12 & & \[
\begin{aligned}
& \text { BIT } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \hline \text { AND } \\
& \text { ABS } \\
& 3 \quad 4 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{ROL} \\
& \mathrm{ABS} \\
& 3 \\
& 3
\end{aligned}
\] & \[
\begin{gathered}
\text { BBR2 } \\
\text { ZP } \\
3 \quad 5^{* *}
\end{gathered}
\] & 2 \\
\hline 3 &  & \[
\begin{aligned}
& \text { AND } \\
& \text { (ND, Y) } \\
& 25^{*}
\end{aligned}
\] & & & & \[
\begin{aligned}
& \text { AND } \\
& \text { ZP, } X \\
& 24
\end{aligned}
\] & \[
\begin{gathered}
\mathrm{ROL} \\
\mathrm{ZP}, \mathrm{X} \\
2.6
\end{gathered}
\] & \[
\begin{aligned}
& \text { RMB3 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & SEC Implied 12 & \[
\begin{aligned}
& \text { AND } \\
& \text { ABS, } Y \\
& 34^{\circ}
\end{aligned}
\] & & & & \[
\begin{gathered}
\text { AND } \\
\text { ABS, } x \\
3 \quad 4^{*}
\end{gathered}
\] & \[
\begin{gathered}
\mathrm{ROL} \\
\mathrm{ABS}, \mathrm{x} \\
3 \quad 7
\end{gathered}
\] & \[
\begin{aligned}
& \text { BBR3 } \\
& \text { ZP } \\
& 3 \quad 5 *
\end{aligned}
\] & 3 \\
\hline 4 & RTI Implied 16 & \[
\begin{aligned}
& \text { EOR } \\
& \text { (IND, X) } \\
& 266
\end{aligned}
\] & & & & \[
\begin{aligned}
& \text { EOR } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { LSR } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMB4 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & PHA Implied 13 & \[
\begin{aligned}
& \text { EOR } \\
& \text { IMM } \\
& 2 \quad 2
\end{aligned}
\] & LSR Accum 12 & & JMP ABS \(3 \quad 3\) & \[
\begin{aligned}
& \text { EOR } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { LSR } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{gathered}
\text { BBR4 } \\
\text { ZP } \\
3 \quad 5 *
\end{gathered}
\] & 4 \\
\hline 5 & BVC Relative 2 2"* & \[
\begin{gathered}
\text { EOR } \\
\text { (IND), } Y \\
2 \quad 5^{*} \\
\hline
\end{gathered}
\] & & & & \[
\begin{gathered}
\text { EOR } \\
\text { ZP, X } \\
2 \quad 4 \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& \text { LSR } \\
& \text { ZP, X } \\
& 26
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMB5 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & CLI Implied 12 &  & & & &  &  & \[
\begin{aligned}
& \text { BBR5 } \\
& \text { ZP } \\
& 3 \quad 5 *
\end{aligned}
\] & 5 \\
\hline 6 & RTS Implied 16 & \[
\begin{gathered}
\text { ADC } \\
\text { (IND, X) } \\
266
\end{gathered}
\] & & & & \[
\begin{aligned}
& \text { ADC } \\
& Z P \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{ROR} \\
& \mathrm{ZP} \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMB6 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & PLA Implied 14 & \[
\begin{aligned}
& \hline \text { ADC } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] &  & &  & \begin{tabular}{l}
ADC ABS \\
34
\end{tabular} & \[
\begin{aligned}
& \text { ROR } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBR6 } \\
& \text { ZP } \\
& 3 \quad 5 * *
\end{aligned}
\] & 6 \\
\hline 7 &  & ADC
(IND, Y)
\(25^{*}\) & & & & \[
\begin{aligned}
& \text { ADC } \\
& \text { ZP, } X \\
& 24
\end{aligned}
\] & \[
\begin{aligned}
& \text { ROR } \\
& \text { ZP, X } \\
& 26
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{RMB7} \\
& \mathrm{ZP} \\
& 2 \quad 5
\end{aligned}
\] & SEI Implied 12 & \[
\begin{gathered}
\text { ADC } \\
A B S, Y \\
3 \quad 4^{*}
\end{gathered}
\] & & & & \[
\begin{gathered}
\text { ADC } \\
\text { ABS, } X \\
34^{*}
\end{gathered}
\] & ROR ABS, \(X\) 37 & \[
\begin{aligned}
& \text { BBR7 } \\
& \text { ZP } \\
& 3 \quad 5^{* *}
\end{aligned}
\] & 7 \\
\hline 8 & & \[
\begin{gathered}
\hline \text { STA } \\
\text { (IND, X) } \\
2 \quad 6 \\
\hline
\end{gathered}
\] & & & \[
\begin{aligned}
& \text { STY } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { STA } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { STX } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \hline \text { SMBO } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & DEY Implied 12 & & TXA Implied 12 & & \[
\begin{aligned}
& \hline \text { STY } \\
& \text { ABS } \\
& 3 \quad 4 \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
STA ABS \\
34
\end{tabular} & \[
\begin{aligned}
& \hline \text { STX } \\
& \text { ABS } \\
& 3 \quad 4 \\
& \hline
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { BBSO } \\
\text { ZP } \\
3 \quad 5^{* *} \\
\hline
\end{array}
\] & 8 \\
\hline 9 & \(\left.\)\begin{tabular}{|c|}
\hline BCC \\
Relative \\
2
\end{tabular}\(\quad 2{ }^{* *} \right\rvert\,\) & \[
\begin{gathered}
\hline \text { STA } \\
\text { (IND, Y) } \\
2 \quad 6 \\
\hline
\end{gathered}
\] & & & \[
\begin{gathered}
\text { STY } \\
\text { ZP, X } \\
24
\end{gathered}
\] & \[
\begin{gathered}
\text { STA } \\
\text { ZP, } \mathrm{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\) & \begin{tabular}{|c|}
\hline TXS \\
Implied \\
1
\end{tabular} & & & \[
\begin{gathered}
\text { STA } \\
\text { ABS, } \mathrm{X} \\
35
\end{gathered}
\] & & \[
\begin{aligned}
& \text { BBS1 } \\
& \text { ZP } 5 \text { "* }
\end{aligned}
\] & 9 \\
\hline A & \[
\begin{aligned}
& \hline \text { LDY } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { LDA } \\
\text { (IND, X) } \\
2 \quad 6 \\
\hline
\end{array}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] & & \[
\begin{aligned}
& \text { LDY } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDA } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { SMB2 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & TAY Implied 12 & \[
\begin{aligned}
& \text { LDA } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & TAX Implied 12 & & \[
\begin{aligned}
& \text { LDY } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDA } \\
& \text { ABS }
\end{aligned}
\]
\[
34
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBS2 } \\
& \text { ZP } \\
& 3 \quad 5 *
\end{aligned}
\] & A \\
\hline B & \begin{tabular}{l}
BCS \\
Relative \\
2 2**
\end{tabular} &  & & & \[
\begin{aligned}
& \text { LDY } \\
& \text { ZP, X } \\
& 24
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDA } \\
& \text { ZP, } \mathrm{X} \\
& 24
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { ZP, Y } \\
& 24
\end{aligned}
\] & \[
\begin{aligned}
& \text { SMB3 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & CLV Implied 12 &  &  & &  &  &  & \[
\begin{gathered}
\text { BBS3 } \\
\text { ZP } \\
3 \quad 5 * \\
\hline
\end{gathered}
\] & B \\
\hline C & \[
\begin{aligned}
& \text { CPY } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & \[
\begin{array}{|c}
\hline \text { CMP } \\
\text { (IND, X) } \\
2 \quad 6 \\
\hline
\end{array}
\] & & & \[
\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{aligned}
& \text { SMB4 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & \begin{tabular}{cc}
1 & 2 \\
InY \\
Implied \\
1 & 2
\end{tabular} & \[
\begin{aligned}
& \text { CMP } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & \begin{tabular}{|c|}
\hline DEX \\
Implied \\
1 \\
2
\end{tabular} & & \[
\begin{aligned}
& \text { CPY } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { CMP } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { DEC } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBS4 } \\
& \text { ZP } \\
& 3 \quad 5^{* *}
\end{aligned}
\] & C \\
\hline D & \begin{tabular}{l}
BNE \\
Relative \\
2 2**
\end{tabular} & \[
\begin{array}{|c|}
\hline \text { CMP } \\
\text { (IND), Y } \\
2 \quad 5^{*} \\
\hline
\end{array}
\] & & & & \[
\begin{aligned}
& \text { CMP } \\
& \text { ZP, } X \\
& 24 \\
& \hline
\end{aligned}
\] & \[
\begin{gathered}
\hline \text { DEC } \\
\text { ZP, } X \\
26 \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& \text { SMB5 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] &  &  & & & &  & DEC
\[
37
\] & \[
\begin{gathered}
\text { BBS5 } \\
\text { ZP } \\
3 \quad 5 * * \\
\hline
\end{gathered}
\] & D \\
\hline E & \[
\begin{aligned}
& \hline \text { CPX } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { SBC } \\
\text { (IND, X) } \\
2 \quad 6 \\
\hline
\end{array}
\] & & & \[
\begin{aligned}
& \hline \text { CPX } \\
& 2 P \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \hline \text { SBC } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{array}{r}
1 \mathrm{NC} \\
\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}
& \hline \text { SBC } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] &  & & \[
\begin{aligned}
& \hline C P X \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \begin{tabular}{l}
SBC \\
ABS \\
34
\end{tabular} & \[
\begin{aligned}
& \text { INC } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{gathered}
\hline \text { BBS6 } \\
\text { ZP } \\
3 \quad 5 * * \\
\hline
\end{gathered}
\] & E \\
\hline F & \begin{tabular}{l}
BEQ \\
Relative \\
2 2"*
\end{tabular} & SBC
(IND), \(Y\)
\(2 \quad 5^{*}\) & & & & \[
\begin{gathered}
\hline \text { SBC } \\
\text { ZP, } X \\
2 \quad 4 \\
\hline
\end{gathered}
\] & \[
\begin{gathered}
\hline \text { INC } \\
\text { ZP, } X \\
2 \quad 6 \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& \text { SMB7 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] &  &  & & & &  &  & \[
\begin{gathered}
\text { BBS7 } \\
\text { ZP } \\
3 \quad 5^{* *} \\
\hline
\end{gathered}
\] & F \\
\hline
\end{tabular}
*Add 1 to N if page boundary is crossed.
**Add 1 to \(N\) if branch occurs to same page; add 2 to N if branch occurs to different page.

\section*{APPENDIX B \\ KEY REGISTER SUMMARY}


\section*{APPENDIX C}

MEMORY MAPS AND ADDRESS AND PIN ASSIGNMENTS
C. 1 ABBREVIATED BUS MODE MEMORY MAP

C. 2 MULTIPLEXED BUS MODE MEMORY MAP


\section*{C. 3 I/O AND INTERNAL REGISTER ADDRESSES}
\begin{tabular}{|c|c|c|}
\hline ADDRESS & READ & WRITE \\
\hline \[
\begin{array}{r}
001 F \\
1 \mathrm{E} \\
1 \mathrm{D} \\
1 \mathrm{C}
\end{array}
\] & Host Status Flag Register Input Data Register (IDR) & \begin{tabular}{l}
Host Status Flag Register \\
Output Data Register (ODR)
\end{tabular} \\
\hline \[
\begin{aligned}
& 1 \mathrm{~B} \\
& 1 \mathrm{~A} \\
& 19 \\
& 18
\end{aligned}
\] & \begin{tabular}{l}
Lower Counter \\
Lower Counter \& Clear Flag (IFR5) Upper Counter
\end{tabular} & \begin{tabular}{l}
Lower Latch \\
Upper Latch/Transfer Latch to Counter \& Clear Flag (IFR5) Upper Latch
\end{tabular} \\
\hline \[
\begin{aligned}
& 17 \\
& 16 \\
& 15 \\
& 14 \\
& \hline
\end{aligned}
\] & Mode Control Register & Mode Control Register \\
\hline \[
\begin{aligned}
& 13 \\
& 12 \\
& 11 \\
& 10
\end{aligned}
\] & Interrupt Enable Register Interrupt Flag Regıster Read "FF" & \begin{tabular}{l}
Interrupt Enable Register \\
Clear Int Flag Bit
\end{tabular} \\
\hline \[
\begin{aligned}
& O F \\
& O E \\
& O D \\
& O C
\end{aligned}
\] &  &  \\
\hline \[
\begin{aligned}
& \hline O B \\
& O A \\
& 09 \\
& 08 \\
& \hline
\end{aligned}
\] &  &  \\
\hline \[
\begin{aligned}
& 07 \\
& 06 \\
& 05 \\
& 04
\end{aligned}
\] & \begin{tabular}{l}
Port G (R6500/42 only) \\
Port F (R6500/42 only) \\
Port E (R6500/42 only)
\end{tabular} & \begin{tabular}{l}
Port G (R6500/42 only) \\
Port F (R6500/42 only) \\
Port E (R6500/42 only)
\end{tabular} \\
\hline \[
\begin{aligned}
& 03 \\
& 02 \\
& 01 \\
& 00
\end{aligned}
\] & \begin{tabular}{l}
Port C \\
Port B \\
Port A
\end{tabular} & \begin{tabular}{l}
Port C \\
Port B \\
Port A
\end{tabular} \\
\hline
\end{tabular}

\section*{C. 4 MULTIPLE FUNCTION PIN ASSIGNMENTS}
\begin{tabular}{|c|c|c|c|c|}
\hline \multicolumn{2}{|c|}{PIN NUMBER} & \multirow[t]{2}{*}{1/0 FUNCTION} & \multirow[t]{2}{*}{ABBREVIATED PORT FUNCTION} & \multirow[t]{2}{*}{MULTIPLEXED PORT FUNCTION} \\
\hline R6500/41 & R6500/42 & & & \\
\hline 13 & 16 & PCO & A0 & AO \\
\hline 14 & 17 & PC 1 & A1 & A1 \\
\hline 15 & 18 & PC2 & A2 & A2 \\
\hline 16 & 19 & PC3 & A3 & A3 \\
\hline 17 & 20 & PC4 & \(\mathrm{R} \bar{W}\) & \(\mathrm{R} / \overline{\mathrm{W}}\) \\
\hline 18 & 21 & PC5 & EMS & EMS \\
\hline 19 & 22 & PC6/INT & \(\mathrm{PC6} / \overline{\mathrm{INT}}\) & PC6/INT \\
\hline 30 & 49 & PB0 & D0 & A4/D0 \\
\hline 31 & 50 & PB1 & D1 & A5/D1 \\
\hline 32 & 51 & PB2 & D2 & Á6/D2 \\
\hline 33 & 52 & PB3 & D3 & A7/D3 \\
\hline 34 & 53 & PB4 & D4 & A8/D4 \\
\hline 35 & 54 & PB5 & D5 & A9/D5 \\
\hline 36 & 55 & PB6 & D6 & A10/D6 \\
\hline 37 & 56 & PB7 & D7 & A11/D7 \\
\hline
\end{tabular}

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & VdC \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{c} 
Operating Temperature \\
Commercial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
\(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
0 to +70
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{S S}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=0^{\circ}\right.\) to \(70^{\circ} \mathrm{C}\), unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline Input High Voltage & \(\mathrm{V}_{\mathrm{IH}}\) & +2.0 & - & \(\mathrm{V}_{\mathrm{cc}}\) & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\text {IL }}\) & -0.3 & - & +0.8 & V & \\
\hline Input Leakage Current RES, \(\overline{\text { NMI }}\) & \(\mathrm{I}_{\text {IN }}\) & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\text {IN }}=0\) to 5.0 V \\
\hline Input Low Current & \(\mathrm{I}_{\text {L }}\) & - & -1.0 & -1.6 & mA & \(\mathrm{V}_{\mathrm{IL}}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & \(\mathrm{V}_{\mathrm{cc}}\) & V & \[
\begin{aligned}
& \mathrm{I}_{\mathrm{LOAD}}=-100 \mu \mathrm{~A} \\
& \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline Output High Voltage (CMOS) & \(\mathrm{V}_{\text {cmos }}\) & \(\mathrm{V}_{\mathrm{CC}}-30 \%\) & - & \(\mathrm{V}_{\mathrm{CC}}\) & V & \(\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}\) \\
\hline Output Low Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & +0.4 & v & \[
\begin{aligned}
& \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA} \\
& \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline I/O Port Pull-Up Resistance PA0-PA7, PC0-PC7, PF0-PF73, PG0-PG73 & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Output High Current (Sourcing) & IOH & -100 & - & - & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}\) \\
\hline Output Low Current (Sinking, PE3) & \(\mathrm{I}_{\mathrm{OL}}\) & 1.6 & - & - & mA & \(\mathrm{V}_{\mathrm{OL}}=0.4 \mathrm{~V}\) \\
\hline Darlington Current Drive ( \(\mathrm{PE}^{3}\) ) & IOH & -1.0 & - & - & mA & \(\mathrm{V}_{\mathrm{OH}}=1.5 \mathrm{~V}\) \\
\hline \begin{tabular}{l}
Input Capacitance \\
\(\mathrm{PA}, \mathrm{PB}, \mathrm{PC}, \mathrm{PF}^{3}, \mathrm{PG}^{3}\)
\end{tabular} & \(\mathrm{C}_{\text {IN }}\) & - & - & 10 & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) & \(\mathrm{C}_{\text {OUT }}\) & - & - & 10 & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Outputs High) & \(P_{\text {D }}\) & - & 550 & 1050 & mW & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}

Notes:
1. Typical values measured at \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\).
2. Negative sign indicates outward current flow, positive indicates inward flow.
3. R6500/42 only.

\section*{APPENDIX E \\ TIMING REQUIREMENTS AND CHARACTERISTICS}

\section*{E. 1 GENERAL NOTES}
\(1 \mathrm{~V} \mathrm{cc} 5 \mathrm{~V} \pm 5^{\circ}{ }_{0}, 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 08 V and 20 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 { - 50pf maxımum } \\
\text { PB, PC (I/O Modes Only) } & - \text { 50pf maxımum } \\
\text { PB, PC (ABB and Mux Mode) } & \text { - } 130 \mathrm{pf} \text { maxımum }
\end{array}
\]

\section*{E. 2 CLOCK TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} \\
\hline & & MIN & MaX & MIN & MAX \\
\hline \(\mathrm{T}_{\text {crc }}\) & Cycle Time & 1000 & \(10 \mu \mathrm{~s}\) & 500 & \(10 \mu \mathrm{~s}\) \\
\hline \(\mathrm{T}_{\text {pwso }}\) & CLKIN Input Clock Pulse Width & 475 & - & 240 & - \\
\hline \(\mathrm{T}_{\text {pwoz }}\) & Output Clock Pulse Width at Minimum \(\mathrm{T}_{\text {crc }}\) & \(T_{\text {pwob }}\) & \[
\begin{aligned}
& T_{\text {Pw\&o }} \\
& +25
\end{aligned}
\] & Tpwto & \[
\begin{aligned}
& T_{\text {pwof }} \\
& +20
\end{aligned}
\] \\
\hline \(\mathrm{T}_{\mathrm{R}}, \mathrm{T}_{\mathrm{F}}\) & \begin{tabular}{l}
Output Clock Rise. \\
Fall Time
\end{tabular} & - & 25 & - & 15 \\
\hline \(\mathrm{T}_{\text {IR }} \mathrm{T}_{\text {IF }}\) & Input Clock Rise Fall Time & - & 10 & - & 10 \\
\hline
\end{tabular}


\section*{E. 3 ABBREVIATED MODE TIMING-PB AND PC}
(MCR \(5=1\), MCR \(6=0\), MCR \(7=1)\)
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {PCAS }}\) & (PC0-PC3) Address Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {PBSU }}\) & (PB) Data Setup Time & 50 & - & 35 & - \\
\hline \(\mathrm{T}_{\text {PBHR }}\) & (PB) Data Read Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PBHW }}\) & (PB) Data Write Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {Pbod }}\) & (PB) Data Output Delay & - & 175 & - & 150 \\
\hline \(\mathrm{T}_{\text {PCHA }}\) & (PC0-PC3) Address Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PCHV }}\) & (PC4) EMS Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PCVP }}\) & (PC4) \(\overline{\text { EMS }}\) Stabilization Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {EsV }}\) & EMS Setup Time & - & 350 & - & 210 \\
\hline
\end{tabular}

NOTE 1. Values assume PCO-PC5 have the same capacitive load

\section*{E.3.1 Abbreviated Mode Timing Diagram}


\section*{E. 4 MULTIPLEXED MODE TIMING-PB AND PC}
(MCR \(5=1\), MCR \(6=1\), MCR \(7=1\) )
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow[b]{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {PCAS }}\) & (PC0-PC3) Address Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {PbAS }}\) & (PB) Address Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {PBSU }}\) & (PB) Data Setup Time & 50 & - & 35 & - \\
\hline \(\mathrm{T}_{\text {Pвнв }}\) & (PB) Data Read Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PBHW }}\) & (PB) Data Write Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {Pbod }}\) & (PB) Data Output Delay & - & 175 & - & 150 \\
\hline \(\mathrm{T}_{\text {PCHA }}\) & (PC0-PC3) Address Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PBHA }}\) & (PB) Address Hold Time & 0 & 100 & 0 & 80 \\
\hline \(\mathrm{T}_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PCHV }}\) & (PC4) EMS Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{TPCVD}^{(1)}\) & (PC4) Address to EMS Delay Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {Pcyp }}\) & (PC4) EMS Stabilization Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {ESU }}\) & EMS Setup Time & - & 350 & - & 210 \\
\hline
\end{tabular}

NOTE 1: Values assume PC0-PC5 have the same capacitive load.

\section*{E.4.1 Multiplex Mode Timing Diagram}


\section*{E. 5 I/O, EDGE DETECT AND COUNTER TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline  & Internal Write to Peripheral Data Valid PA, PC TTL PA, PC CMOS PB & - & \[
\begin{array}{r}
500 \\
1000 \\
175
\end{array}
\] & - & \[
\begin{array}{r}
500 \\
1000 \\
150 \\
\hline
\end{array}
\] \\
\hline \begin{tabular}{l}
\(T_{\text {PDSU }}\) \\
\(T_{\text {POSU }}\)
\end{tabular} & Perıpheral Data Setup Time PA, PC PB & \[
\begin{array}{r}
200 \\
50
\end{array}
\] & - & \[
\begin{array}{r}
200 \\
50
\end{array}
\] & - \\
\hline \begin{tabular}{l}
\(T_{\text {PHR }}\) \\
\(T_{\text {PHA }}\)
\end{tabular} & Peripheral Data Hold Time
PA, PC
PB & \[
\begin{aligned}
& 75 \\
& 10
\end{aligned}
\] & - & \[
\begin{aligned}
& 75 \\
& 10
\end{aligned}
\] & - \\
\hline \(\mathrm{T}_{\text {EPW }}\) & PA0-PA1 Edge Detect Pulse Width & \(\mathrm{T}_{\mathrm{crc}}\) & - & Tcrc & - \\
\hline \(T_{\text {CPW }}\) \(\mathrm{T}_{\mathrm{CO}}{ }^{11)}\) & \begin{tabular}{l}
Counter \\
PA2 Input Pulse Width PA2 Output Delay
\end{tabular} & \(\mathrm{T}_{\text {crc }}\) & \[
500
\] & Tcre
- & \[
\overline{500}
\] \\
\hline
\end{tabular}

NOTE 1 Maximum Load Capacitance 50pF Passive Pull-Up Required

\section*{E.5.1 I/O, Edge Detect, Counter}


\section*{R65/41EB AND R65/41EAB BACKPACK EMULATORS}

\section*{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 descrıption 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.0K bytes of external program memory This extra memory accommodates program patches, test programs or optional programs during breadboard and prototype development states.

\section*{ORDERING INFORMATION}

Backpack Emulator
\begin{tabular}{|c|c|c|c|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Memory \\
Capacity
\end{tabular} & \begin{tabular}{c} 
Compatible \\
Memories
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range and Speed
\end{tabular} \\
\hline R65/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 & \begin{tabular}{c}
\(0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) \\
2 MHz
\end{tabular} \\
\hline
\end{tabular}

Support Products
\begin{tabular}{|l|l|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & Description \\
\hline S65-101 & SYSTEM 65 Microcomputer \\
& Development System \\
M65-040 & PROM Programmer Module \\
M65-131 & \(1-\mathrm{MHz}\) R6500/41 Personality Module \\
M65-132 & \(2-\mathrm{MHz}\) R6500/41 Personality Module \\
RDC-1001 & Rockwell Development Center \\
RDC-131 & 1 MHz R6500/41 Personality Set (RDC) \\
RDC-132 & 2 MHz R6500/41 Personality Set (RDC) \\
\hline
\end{tabular}

\section*{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 -pın 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 compatıbility with the R6500 family
- 23 bi-directınal 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

\section*{CONFIGURATIONS}

The Backpack Emulator is available in two different versions, to accommodate 1 MHz and 2 MHz speeds. Both versions provide 192 bytes of RAM and I/O, as well as 24 signals to support the external memory "backpack" socket.

External 4 K memories with addresses of 000 to FFF, are upward translated to addresses F000 to FFFF when assembled to form the Backpack Emulator.

\section*{EXTERNAL FREQUENCY REFERENCE}

The external frequency reference is an output timing signal \(\not \varnothing 2\). This is an internally synchronized \(1 \times\) clock output suitable for external memory or peripheral interfacing.

\section*{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.

\section*{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, 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 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


I/O AND INTERNAL REGISTER ADDRESSES
\begin{tabular}{|c|c|c|}
\hline Address & Read & Write \\
\hline \[
\begin{array}{r}
001 F \\
1 E \\
1 D \\
1 C
\end{array}
\] & Host Status Flag Register Input Data Register (IDR) & \begin{tabular}{l}
Host Status Flag Register \\
Output Data Register (ODR)
\end{tabular} \\
\hline \[
\begin{aligned}
& 1 B \\
& 1 A \\
& 19 \\
& 18
\end{aligned}
\] & Lower Counter Lower Counter \& Clear Flag (IFR5) Upper Counter & Lower Latch Upper Latch/Transfer Latch to Counter \& Clear Flag (IFR5) Upper Latch \\
\hline \[
\begin{aligned}
& 17 \\
& 16 \\
& 15 \\
& 14
\end{aligned}
\] & Mode Control Register & Mode Control Register \\
\hline \[
\begin{aligned}
& 13 \\
& 12 \\
& 11 \\
& 10
\end{aligned}
\] & Interrupt Enable Register Interrupt Flag Register Read "FF" & Interrupt Enable Register Clear Int Flag Bit \\
\hline \[
\begin{gathered}
03 \text { thru } 0 F \\
02 \\
01 \\
0000
\end{gathered}
\] & \begin{tabular}{l}
Port C \\
Port B \\
Port A
\end{tabular} & \begin{tabular}{l}
Port C \\
Port B \\
Port A
\end{tabular} \\
\hline
\end{tabular}

READ TIMING CHARACTERISTICS
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal} & \multirow[b]{2}{*}{Symbol} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min. & Max. & Min. & Max. & \\
\hline \(\overline{\mathrm{OE}}\) and \(\overline{\mathrm{CE}}\) setup time from CPU & Toes & - & 225 & - & 140 & ns \\
\hline Address setup time from CPU & \(\mathrm{T}_{\text {ADS }}\) & - & 225 & - & 140 & Pis \\
\hline Memory read access time & \(\mathrm{T}_{\text {ACC }}\) & - & 700 & - & 315 & ns \\
\hline Data set up tıme & \(\mathrm{T}_{\text {DSU }}\) & 50 & - & 35 & - & ns \\
\hline Data hold time-Read & \(\mathrm{T}_{\mathrm{HR}}\) & 10 & - & 10 & - & ns \\
\hline Address hold time & THA & 30 & - & 30 & - & ns \\
\hline \(\overline{\mathrm{OE}}\) and \(\overline{\mathrm{CE}}\) hold time & Thoe & 30 & - & 30 & - & ns \\
\hline Cycle Time & \(\mathrm{T}_{\text {cyc }}\) & 10 & 10.0 & 0.5 & 10.0 & \(\mu \mathrm{s}\) \\
\hline
\end{tabular}

\section*{READ TIMING WAVEFORMS}


\section*{ABBREVIATED BUS MODE MEMORY MAP}

\section*{MULTIPLEXED BUS}

MODE MEMORY MAP


\section*{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.\) )
\begin{tabular}{|c|c|c|c|c|c|}
\hline Characteristic & Symbol & Min & Typ & Max & Unit \\
\hline Input High Threshold Voltage D0-D7 & \(V_{\text {IHT }}\) & \(\mathrm{V}_{\mathrm{SS}}+2.0\) & - & - & Vdc \\
\hline Input Low Threshold Voltage
D0-D7 & \(V_{\text {ILT }}\) & - & - & \(\mathrm{V}_{\mathrm{SS}}+0.8\) & Vdc \\
\hline 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}
\] & \(I_{\text {TSI }}\) & - & - & \(\pm 10\) & \(\mu \mathrm{A}\) \\
\hline \[
\begin{aligned}
& \text { Output High Voltage } \\
& \text { (I } \text { LOAD }^{=100 \mu} \mu \mathrm{Adc}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V} \text { ) } \\
& \mathrm{DO}-\mathrm{D7}, \mathrm{AO}-\mathrm{A} 11, \overline{\mathrm{OE}, \overline{\mathrm{CE}}}
\end{aligned}
\] & \(\mathrm{V}_{\mathrm{OH}}\) & \(\mathrm{V}_{\text {SS }}+2.4\) & - & - & Vdc \\
\hline \[
\begin{aligned}
& \text { Output Low Voltage } \\
& \text { (I LOAD }=1.6 \text { mAdc, } V_{C C}=4.75 \mathrm{~V} \text { ) } \\
& \text { DO-D7, AO-A11, } \overline{\mathrm{CE}}, \mathrm{CE}
\end{aligned}
\] & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & \(\mathrm{V}_{\mathrm{ss}}+0.4\) & Vdc \\
\hline Power Dissipation (less EPROM) & \(P_{\text {D }}\) & - & 0.50 & - & W \\
\hline \begin{tabular}{l}
Capacitance
\[
\left(\mathrm{V}_{\mathrm{In}}=0, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHz}\right)
\] \\
D0-D7 (High Impedance State) Input Capacitance
\end{tabular} & \begin{tabular}{l}
C \\
\(\mathrm{C}_{\text {out }}\) \\
\(\mathrm{C}_{\text {in }}\)
\end{tabular} & - & - & \[
\begin{aligned}
& 10 \\
& 10
\end{aligned}
\] & pF \\
\hline I/O Port Pull-up Resistance & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & kohm \\
\hline
\end{tabular}


40-Pin Backpack Package

\section*{R6541Q AND R6500/43 INTELLIGENT PERIPHERAL CONTROLLERS}

\section*{SECTION 1 INTRODUCTION}

\subsection*{1.1 FEATURES}
- Directly compatible with \(6500,6800,8080\), and \(Z 80\) 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 4 K 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

\section*{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/43 and the fixed features of the R6541Q.

\subsection*{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, 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).

\subsection*{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

\title{
SECTION 2 \\ 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
\begin{tabular}{|c|c|c|c|c|c|}
\hline SIGNAL NAME & PIN NO. R6541Q \& R6500/43 & DESCRIPTION & SIGNAL NAME & PIN NO. R6541Q \& R6500/43 & DESCRIPTION \\
\hline CLKIN
¢2 & 11
24 & \begin{tabular}{l}
Symmetrical square wave 100 KHz to 2 MHZ , TTL compatible input. \\
Output timing signal-This is an internally synchronized \(1 \times\) clock output suitable for external memory or peripheral interfacing.
\end{tabular} & PB0-PB7 & 49-56 & 8 bit I/O port used for either input or output. Each line consists of an active transistor 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. D0-D7 are multiplexed with address lines \\
\hline \(\overline{R E S}\) & 57 & The reset input is used to initialize the device. Section 7 describes the process and conditions of the \(\overline{R E S}\) procedure. & PC0-PC6 & 31-25 & \begin{tabular}{l}
A4-A11 in the Multiplexed Bus Mode. \\
7 bit I/O port used for either input or output. Each line consists of an active transis-
\end{tabular} \\
\hline VCC & 64 & Power supply input ( +5 V ) & & & tor to \(\mathrm{V}_{\text {ss }}\) and an optional \\
\hline 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 \\
\hline \(\overline{\mathrm{CS}}\) & 12 & Chip select pin for host interface. & & & control signals for use in abbreviated and multiplex \\
\hline 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 PC0-PC5 have active pullups. \\
\hline & & cate that information being read from the IPC is a status or data byte. & A0-A11, A15 & \[
\begin{gathered}
7-1 \\
63-58
\end{gathered}
\] & Thirteen address lines used to address a complete 8 K external address space. \\
\hline \[
E(\overline{R D})
\] & 13 & Host timing control signal for data register write and read. & DB0-DB7 & 41-48 & Eight bidirectıonal data bus lines used to transmit data to \\
\hline \(\mathrm{R} / \overline{\mathrm{W}}\) ( \(\overline{\mathrm{WR}})\) & 14 & Host tıming control signal for data register write and read. & SYNC & 9 & \begin{tabular}{l}
and from external memory. \\
SYNC is a positive going sig-
\end{tabular} \\
\hline HB0-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. \\
\hline \(\overline{\mathrm{NMI}}\) & 8 & A negative going edge on the Non-Maskable Interrupt signal requests that a nonmaskable interrupt be generated with the CPU. & \(\mathrm{R} / \overline{\mathrm{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. \\
\hline PA0-PA7 & 33-40 & 8 bit l/O port used for either input or output. Each line consists of an active transistor 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 output pin, CNTR, and is mode selected. & & & \\
\hline
\end{tabular}

\section*{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.

\section*{NOTE}

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

\subsection*{3.1 CPU LOGIC}

The internal CPU 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.

\subsection*{3.1.1 Accumulator}

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

\subsection*{3.1.2 Index Registers}

There are two 8 -bit index registers, \(X\) and \(Y\). Each index register can be used as a base to modify the address data program counter and thus obtain a new address-the sum of the program counter contents and the index register contents.

When executing an instruction which specifies indirect addressing, the CPU fetches the op code and the address, and modifies the address from memory by adding the index register to it prior to loading or storing the value of memory.

Indexing greatly sımplifies many types of programs, especially those using data tables.

\subsection*{3.1.3 Stack Pointer}

The Stack Pointer is an 8 -bit register. It is automatically incremented and decremented under control of the microprocessor to perform stack manipulation in response to either user instructions, 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

\subsection*{3.1.4 Arithmetic and Logic Unit (ALU)}

All arithmetic and logic operations take place in the ALU, includıng incrementing and decrementing internal registers (except the Program Counter) The ALU cannot store data for more than one cycle If data are placed on the inputs to the ALU at the beginning of a cycle, the result is always gated into one of the storage registers or to external memory during the next cycle.

Each bit of the ALU has two inputs. These inputs can be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, and so on) using the data on the two inputs

\subsection*{3.1.5 Program Counter}

The 16-bit Program Counter provides the addresses that are used to step the processor through sequential instructions in a program. Each time the processor fetches an instruction from program memory, the lower (least significant) byte of the Program Counter ( PCL ) is placed on the low-order bits of the Address Bus and the higher (most significant) byte of the Program Counter (PCH) is placed on the high-order 8 bits of the Address Bus. The Counter is incremented each time an instruction or data is fetched from program memory.

\subsection*{3.1.6 Instruction Register and Instruction Decode}

Instructions are fetched from ROM or RAM and gated onto the Internal Data Bus. These instructions are latched into the Instruction Register then decoded along with timing and interrupt signals to generate control signals for the various registers.

\subsection*{3.1.7 Timing Control}

The Timing Control Logic keeps track of the specific instruction cycle being executed. This logic is initialized each tıme an instruction fetch is executed and is advanced at the beginnıng 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.


\subsection*{3.1.8 Interrupt Logic}

Interrupt logic controls the sequencing of three interrupts: \(\overline{\mathrm{RES}}, \overline{\mathrm{NMI}}\), and \(\overline{\mathrm{RQ}}\). \(\overline{\mathrm{RQ}}\) is generated by any one of four conditions: Counter Overflow, Positive Edge Detect, Negative Edge Detect, and Input Data Register Full.

\subsection*{3.2 NEW INSTRUCTIONS}

In addition to the standard 6502 instruction set, four instructions have been added to the devices to simplify operations that previously required a read/modify/write operation. In order for these instructıons to be equally applicable to any I/O ports, with or without mixed input and output functions, the I/O ports have been designed to read the contents of the specified port data register during the Read cycle of the read/ modify/write operation, rather than I/O pins as in normal read cycles. The added instructions and their format are explained in the following subparagraphs. Refer to Appendix A for the Op Code mnemonic addressing matrix for these added instructions.

\subsection*{3.2.1 Set Memory Bit (SMB m, Addr.)}

This instruction sets to " 1 " one of the 8 -bit data field specified by the zero page address (memory or I/O port). The first byte of the instruction specifies the SMB operation and 1 of 8 bits to be set. The second byte of the instruction designates address (00-FF) of the byte or I/O port to be operated upon.

\subsection*{3.2.2 Reset Memory Bit (RMB m, Addr.)}

This instruction is the same operation and format as SMB instruction except a reset to " 0 " of the bit results.

\subsection*{3.2.3 Branch on Bit Set Relative (BBS m, Addr, DEST)}

This instruction tests one of 8 bits designated by a three bit immediate field within the first byte of the instruction. The second byte is used to designate the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction is used to specify the 8 bit relative address to which the instruction branches if the bit tested is a " 1 ". If the bit tested is not set, the next sequential instruction is executed.

\subsection*{3.2.4 Branch On Bit Reset Relative (BBR m, Addr, DEST)}

This instruction is the same operation and format as the BBS instruction except that a branch takes place if the bit tested is a " 0 ".

\subsection*{3.3 READ-ONLY-MEMORY (ROM)}

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.

\subsection*{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.

\subsection*{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\).

\subsection*{3.6 MODE CONTROL REGISTER (MCR)}

The Mode Control Register contains control bits for the multifunction I/O ports and mode select bits for 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 Sectıon 6

The use of Interrupt Select is shown in Section 4.5.
The use of Bus Mode Select is shown in Sections 44 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
\begin{tabular}{|c|c|}
\hline Control Signal & Description \\
\hline 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. \\
\hline IER 1 & Negative Edge Detect Interrupt Enablewhen this bit is set to a "1" a negative going signal on PA1 will generate an \(\overline{\mathrm{RQ}}\) and set the corresponding flag bit. \\
\hline 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. \\
\hline 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. \\
\hline IER 4 & Input Data Regıster 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). \\
\hline IER 5 & Counter Interrupt Enable-If enabled, an \(\overline{\mathrm{IRQ}}\) is generated whenever the Counter overflows. \\
\hline
\end{tabular}

\subsection*{3.7 INTERRUPT FLAG REGISTER (IFR) AND INTERRUPT ENABLE REGISTER (IER)}

An \(\overline{\mathrm{RQ}}\) interrupt request can be initiated by any or all of 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 untll 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 examıned 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.

\subsection*{3.7.1 External Interrupts (INT)}

An external interrupt \(\overline{\mathrm{NT}}\) to the Host computer may be selected in two modes. (See Section 5 for information on the Host/Device interface).

\section*{OUTPUT DATA REGISTER (ODR) FULL}

When IER 3 of the Interrupt Enable Register is set to a " 1 ", the device will assert the \(\overline{\mathrm{NT}}\) (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.

\section*{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.

\subsection*{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.

\subsection*{3.8.1 Carry Bit (C)}

The Carry Bit (C) can be considered as the ninth bit of an arithmetic operation. It is set to logic 1 if a carry from the eighth bit has occurred or cleared to logic 0 if no carry occurred as the result of arithmetic operations.

The Carry Bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instruction, respectively. Other operations which affect the Carry Bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

\subsection*{3.8.2 Zero Bit (Z)}

The Zero BIt \((Z)\) is set to logic 1 by the CPU during any data movement or calculation which sets all 8 bits of the result to
zero. This bit is cleared to logic 0 when the resultant 8 bits of a data movement or calculation operation are not all zero. The 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.

\subsection*{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{RQ}}\) 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{\text { RES }}\) ) 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 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.


Figure 3-4. Processor Status Register

\subsection*{3.8.4 Decimal Mode Bit (D)}

The Decimal Mode Bit (D), is used to control the arithmetic mode of the CPU. When this bit is set to logic 1 , the adder operates as a decimal adder. When this bit is cleared to logic 0 , the adder operates as a straight binary adder. The adder mode is controlled only by the programmer. The Set Decimal Mode (SED) instruction will set the D bit; the Clear Decimal Mode (CLD) instruction will clear it. The PLP and RTI instructions also effect the Decimal Mode Bit.

\section*{CAUTION}

The Decimal Mode Bit will either set or clear in an unpredictable manner upon power application to the device. This bit must be initialized to the desired state by the user program or erroneous results may occur.

\subsection*{3.8.5 Break Bit (B)}

The Break Bit (B) is used to determıne the condition which caused the \(\overline{I R Q}\) service routine to be entered. If the \(\overline{\mathrm{IRQ}}\) 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{RQ}}\) signal being generated, the \(B\) bit will be cleared to logic 0 . There are no instructions which can set or clear this bit.

\subsection*{3.8.6 Overflow Bit (V)}

The Overflow Bit \((\mathrm{V})\) is used to indicate that the result of a signed, binary addition, or subtraction, operation is a value that cannot be contaned in seven bits \((-128 \leqslant n \leqslant 127)\).

This indıcator only has meaning when signed arithmetıc (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.

\subsection*{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.

\title{
SECTION 4 PARALLEL INPUT/OUTPUT PORTS
}

\section*{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{\mathbb{N T}}\). 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
\begin{tabular}{|c|c|}
\hline PORT & ADDRESS \\
\hline A & 0000 \\
\hline B & 0001 \\
\hline C & 0002 \\
\hline E ) & 0004 \\
\hline F \(\}\) R6500/42 only & 0005 \\
\hline G & 0006 \\
\hline
\end{tabular}

\subsection*{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 \(1 / O\) port addresses. Note that this will return the actual status of the input lines, not the data written into the I/O port registers.

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.

\subsection*{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 ".

\subsection*{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 \(\varnothing 2\) clock rate. Edge detection timing is shown in Section E.5.

Table 4-2. Port A Control \& Usage
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{2}{|r|}{PA0-PA1 I/O} & \multicolumn{2}{|c|}{PA2 I/O} & \multicolumn{4}{|c|}{PA2 COUNTER} & \multicolumn{2}{|l|}{PA3-PA7 I/O} \\
\hline & & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCRO }=0 \\
& \text { MCR1 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCRO }=1 \\
& \text { MCR1 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCRO }=X \\
& \text { MCR1 }=\mathbf{1}
\end{aligned}
\]} & & \\
\hline & & & & & & & & & \\
\hline NAME & TYPE & NAME & TYPE & NAME & TYPE & NAME & TYPE & NAME & TYPE \\
\hline \[
\begin{aligned}
& \hline \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 \\
\hline
\end{tabular}

\footnotetext{
(1) POSITIVE EDGE DETECT
(2) NEGATIVE EDGE DETECT
(3) HARDWARE BUFFER FLOAT
}

\subsection*{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.

\subsection*{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
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{4}{*}{R6541Q \& R6500/43} & \multicolumn{4}{|c|}{I/O MODES} & \multicolumn{2}{|l|}{ABBREVIATED MODE} & \multicolumn{4}{|c|}{MULTIPLEXED MODE} \\
\hline & \multicolumn{2}{|r|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=1
\end{aligned}
\]} & \multicolumn{2}{|l|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=0
\end{aligned}
\]} & \multicolumn{4}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR }=1
\end{aligned}
\]} \\
\hline & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{PHASE 1} & \multicolumn{2}{|c|}{PHASE 2} \\
\hline & \multirow[b]{2}{*}{NAME} & \multirow[b]{2}{*}{\begin{tabular}{l}
TYPE \\
(1)
\end{tabular}} & \multirow[b]{2}{*}{NAME} & \multirow[b]{2}{*}{\begin{tabular}{l}
TYPE \\
(2)
\end{tabular}} & \multirow[b]{2}{*}{NAME} & \multirow[b]{2}{*}{\begin{tabular}{l}
TYPE \\
(3)
\end{tabular}} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} \\
\hline PIN \# & & & & & & & NAME & TYPE (2) & NAME & TYPE (3) \\
\hline 49 & PB0 & INPUT & PB0 & OUTPUT & D0 & I/O & A4 & OUTPUT & D0 & 1/0 \\
\hline 50 & PB1 & INPUT & PB1 & OUTPUT & D1 & 1/0 & A5 & OUTPUT & D1 & 1/0 \\
\hline 51 & PB2 & INPUT & PB2 & OUTPUT & D2 & 1/0 & A6 & OUTPUT & D2 & 1/0 \\
\hline 52 & PB3 & INPUT & PB3 & OUTPUT & D3 & 1/0 & A7 & OUTPUT & D3 & 1/0 \\
\hline 53 & PB4 & INPUT & PB4 & OUTPUT & D4 & 1/O & A8 & OUTPUT & D4 & I/O \\
\hline 54 & PB5 & INPUT & PB5 & OUTPUT & D5 & 1/O & A9 & OUTPUT & D5 & 1/0 \\
\hline 55 & PB6 & INPUT & PB6 & OUTPUT & D6 & 1/0 & A10 & OUTPUT & D6 & I/O \\
\hline 56 & PB7 & INPUT & PB7 & OUTPUT & D7 & 1/0 & A11 & OUTPUT & D7 & I/O \\
\hline
\end{tabular}
(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
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow{3}{*}{R6541Q \& R6500/43} & \multicolumn{2}{|c|}{I/O MODE} & \multicolumn{2}{|c|}{ABBREVIATED MODE} & \multicolumn{2}{|r|}{MULTIPLEXED MODE} \\
\hline & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=0 \\
& \text { MCR6 }=\text { X }
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=0
\end{aligned}
\]} & \multicolumn{2}{|c|}{\[
\begin{aligned}
& \text { MCR7 }=1 \\
& \text { MCR6 }=1
\end{aligned}
\]} \\
\hline & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} & \multicolumn{2}{|c|}{SIGNAL} \\
\hline PIN \# & NAME & \begin{tabular}{l}
TYPE \\
(1)
\end{tabular} & NAME & \begin{tabular}{l}
TYPE \\
(2)
\end{tabular} & NAME & \begin{tabular}{l}
TYPE \\
(2)
\end{tabular} \\
\hline 31 & PC0 & 1/0 & AO & OUTPUT & AO & OUTPUT \\
\hline 30 & PC 1 & 1/0 & A1 & OUTPUT & A1 & OUTPUT \\
\hline 29 & PC2 & 1/0 & A2 & OUTPUT & A2 & OUTPUT \\
\hline 28 & PC3 & 1/0 & A3 & OUTPUT & A3 & OUTPUT \\
\hline 27 & PC4 & 1/0 & EMS & OUTPUT & EMS & OUTPUT \\
\hline 26 & PC5 & 1/0 & \(\mathrm{R} / \bar{W}\) & OUTPUT & \(\mathrm{R} / \overline{\mathrm{W}}\) & OUTPUT \\
\hline 25 & PC6* & 1/0 & \(\overline{1 \mathrm{NT}^{*}}\) & OUTPUT & \(\overline{\text { INT*}}\) & OUTPUT \\
\hline
\end{tabular}

\footnotetext{
(1) RESISTIVE PULL-UP, ACTIVE BUFFER PULL-DOWN
(2) ACTIVE BUFFER PULL-UP AND PULL-DOWN
}

\subsection*{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 sımilar 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. Appendıx 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.
PORT B


Figure 4-1b.


Figure 4-1c.


Figure 4-1d.

\footnotetext{
\# OPTIONAL PC6
\# \# NOT AVAILABLE WITH BOOTSTRAP ROM OPTION
*EMS VALID@ 0100 THRU OFFF
}

\section*{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 Regıster. 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 matrıx. A hardware interrupt procedure and a software polling procedure is available to control data traffic between the CPU and Host.
\begin{tabular}{|c|c|l|}
\hline RS \(\left(A_{0}\right)\) & READ & WRITE \\
\hline 1 & \begin{tabular}{l} 
HOST \\
STATUS FLAG
\end{tabular} & \begin{tabular}{l} 
COMMAND \\
INPUT
\end{tabular} \\
\hline 0 & \begin{tabular}{l} 
DATA REG \\
OUTPUT
\end{tabular} & \begin{tabular}{l} 
DATA REG \\
INPUT
\end{tabular} \\
\hline
\end{tabular}

Figure 5-1. Host Addressing Matrix

\subsection*{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.

\subsection*{5.2 HOST STATUS FLAG REGISTER}

A Host Status Flag Regıster 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 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 (ㄴNT) 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 regıster.

The Host Status Flag Register is cleared by the \(\overline{\mathrm{RES}}\) input.


Figure 5-2. Host Status Flag Register Bit Allocation

\subsection*{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, 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 ether a 6500 or 8080 operational and two control tines to ether 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 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 \(\emptyset 2\) for 6800, \(\emptyset 2\) for 6500 ) and the R/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)
\begin{tabular}{|l|c|c|c|}
\hline \begin{tabular}{l} 
CHARACTERISTICS \\
\(\mathbf{1}\) AND 2 MHz
\end{tabular} & SYMBOL & MIN & MAX \\
\hline CS, R/W, RS Setup Time & \(\mathrm{t}_{\mathrm{CS}}\) & 10 & - \\
\hline Access TIme & \(\mathrm{t}_{\text {DA }}\) & - & \(90^{*}\) \\
\hline Data Hold Time & \(\mathrm{t}_{\text {DHR }}\) & 10 & - \\
\hline Control Hold Time & \(\mathrm{t}_{\text {HC }}\) & 10 & - \\
\hline Write Data Setup TIme & \(\mathrm{t}_{\text {WDS }}\) & 75 & - \\
\hline Write Data Hold TIme & \(\mathrm{t}_{\text {DHW }}\) & 10 & - \\
\hline Write Stroke Width & \(\mathrm{t}_{\text {WR }}\) & 75 & - \\
\hline
\end{tabular}
*NOTE.
90 ns when loading \(=130 \mathrm{pf}+1\) TTL LOAD and
75 ns when loading \(=90 \mathrm{pf}+1\) 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{\mathrm{RD}}\) 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)
\begin{tabular}{|c|c|c|c|}
\hline CHARACTERISTICS 1 AND 2 MH & SYMBOL & MIN & MAX \\
\hline CS, A0 Setup Time & \(\mathrm{t}_{\mathrm{cs}}\) & 10 & - \\
\hline Data Access Time on Read & \(t_{\text {DA }}\) & - & \(90^{*}\) \\
\hline Data Hold Time & \(t_{\text {DHR }}\) & 10 & - \\
\hline Control Hold Time & \(\mathrm{t}_{\mathrm{HC}}\) & 10 & - \\
\hline Write Data Setup Time & \(t_{\text {wDs }}\) & 75 & - \\
\hline Write Data Hold Tıme & \(t_{\text {DHW }}\) & 10 & - \\
\hline Write Strobe Width & \(t_{\text {WR }}\) & 75 & - \\
\hline
\end{tabular}
*NOTE
90 ns when loadıng \(=130 \mathrm{pf}+1\) TTL LOAD and 75 ns when loadıng \(=90 \mathrm{pf}+1\) TTL LOAD.


Figure 5-3. Timing Diagram-Host Interface (MCR4 = 0) ( 6500 Version)


Figure 5-4. Timing Diagram—Host Interface (MCR4 = 1) (8080 Version)

\section*{SECTION 6 COUNTER/TIMERS}

The device contans 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:

\section*{Counter}
- Pulse width measurement
- Pulse Generation
- Interval Timer
- Event Counter

Operatıng 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

\subsection*{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 \(\emptyset 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 locatıon 0019 also clears the Counter Underflow Flag (IFR5).

The 16 -bit latch contains the counter initialization value, and can be loaded at any tıme by executing a write to the Upper Latch at location 0018 and the Lower Latch at location 001A. In ether 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 locatıon 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.
\begin{tabular}{|c|c|l|}
\hline \begin{tabular}{c} 
MCR1 \\
(bit 1)
\end{tabular} & \begin{tabular}{c} 
MCR0 \\
(bit 0)
\end{tabular} & \multicolumn{1}{c|}{ Mode } \\
\hline 0 & 0 & Interval Tımer \\
0 & 1 & Pulse Generatıon \\
1 & 0 & Event Counter \\
1 & 1 & Pulse Width Measurement \\
\hline
\end{tabular}

The Interval Tımer, Pulse Generatıon, 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 (PA2).

The Counter is set to the Interval Timer Mode (00) when a \(\overline{R E S}\) signal is generated.

\subsection*{6.1.1 Interval Timer 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} \emptyset 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 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{IRQ}}\) was generated by the Counter Underflow.

While the timer is operating in the Interval Timer Mode, PA2 operates as a PA I/O.

A tıming diagram of the Interval Timer Mode is shown in Figure 6-1.


Figure 6-1. Interval Timer Timing Diagram

\subsection*{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.

\subsection*{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


\subsection*{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 agaın 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*{SECTION 7 \\ POWER ON/INITIALIZATION CONSIDERATIONS}

\subsection*{7.1 POWER ON TIMING}

After application of VCC power to the device, \(\overline{\operatorname{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

\subsection*{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.

\subsection*{7.3 RESET ( \(\overline{\operatorname{RES}})\) CONDITIONS}

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 set as shown in Table 7-1.

Table 7-1. \(\overline{R E S}\) Initialization of I/O Ports and Registers
\begin{tabular}{|l|cccccccc|}
\hline & \(\mathbf{7}\) & \(\mathbf{6}\) & \(\mathbf{5}\) & \(\mathbf{4}\) & \(\mathbf{3}\) & \(\mathbf{2}\) & \(\mathbf{1}\) & \(\mathbf{0}\) \\
\hline REGISTERS & & & & & & & & \\
\(\quad\) Processor Status & - & - & - & - & - & 1 & - & - \\
Mode Control (MCR) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Int. Enable (IER) & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
Int. Flag (IFR) & 0 & 0 & 0 & 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 \\
\hline
\end{tabular}

All RAM and other CPU registers will initialize in a random, nonrepeatable data pattern

\subsection*{7.4 INITIALIZATION}

Any initialization process for the device should include a \(\overline{R E S}\) as indicated in the preceding paragraphs. After stabilization of the external clock (if a power on situation) an initialization routine should be executed to perform (as a minımum) 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
\(\ldots\) registers and Clear RAM as required
CLI Clear Interrupts

\section*{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 N30.

The four instructions notated with a * are added instructions for the IPC devices which are not part of the standard 6502 instruction set.

\section*{A. 1 INSTRUCTION SET IN ALPHABETIC SEQUENCE}
\begin{tabular}{|c|c|c|c|}
\hline MNEMONIC & INSTRUCTION & MNEMONIC & INSTRUCTION \\
\hline ADC & Add Memory to Accumulator with Carry & LDA & Load Accumulator with Memory \\
\hline AND & "AND" Memory with Accumulator & LDX & Load Index X with Memory \\
\hline ASL & Shift Left One Bit (Memory or Accumulator) & LDY & Load Index Y with Memory \\
\hline & & LSR & Shift One Bit Right (Memory or Accumulator) \\
\hline *BBR & Branch on Bit Reset Relative & & \\
\hline *BBS & Branch on Bit Set Relative & & \\
\hline BCC & Branch on Carry Clear & NOP & No Operation \\
\hline BCS & Branch on Carry Set & & \\
\hline BEQ & Branch on Result Zero & & \\
\hline BIT & Test Bits in Memory with Accumulator & ORA & "OR" Memory with Accumulator \\
\hline BMI & Branch on Result Minus & & \\
\hline BNE & Branch on Result not Zero & & \\
\hline BPL & Branch on Result Plus & PHA & Push Accumulator on Stack \\
\hline BRK & Force Break & PHP & Push Processor Status on Stack \\
\hline BVC & Branch on Overflow Clear & PLA & Pull Accumulator from Stack \\
\hline BVS & Branch on Overflow Set & PLP & Pull Processor Status from Stack \\
\hline CLC & Clear Carry Flag & *RMB & Reset Memory Bit \\
\hline CLD & Clear Decimal Mode & ROL & Rotate One Bit Left (Memory or \\
\hline CLI & Clear Interrupt Disable Bit & & Accumulator) \\
\hline CLV & Clear Overflow Flag & ROR & Rotate One Bit Right (Memory or \\
\hline CMP & Compare Memory and Accumulator & & Accumulator) \\
\hline CPX & Compare Memory and Index X & RTI & Return from Interrupt \\
\hline CPY & Compare Memory and Index Y & RTS & Return from Subroutine \\
\hline DEC & Decrement Memory by One & SBC & Subtract Memory from Accumulator with \\
\hline DEX & Decrement Index \(X\) by One & & Borrow \\
\hline DEY & Decrement Index Y by One & SEC & Set Carry Flag \\
\hline & & SED & Set Decimal Mode \\
\hline & & SEI & Set Interrupt Disable Status \\
\hline EOR & "Exclusive-Or" Memory with & *SMB & Set Memory Bit \\
\hline & Accumulator & STA & Store Accumulator in Memory \\
\hline & & STX & Store Index X in Memory \\
\hline & & STY & Store Index Y in Memory \\
\hline INC & Increment Memory by One & & \\
\hline INX & Increment Index X by One & & \\
\hline INY & Increment Index Y by One & TAX & Transfer Accumulator to Index X \\
\hline & & TAY & Transfer Accumulator to Index Y \\
\hline & & TSX & Transfer Stack Pointer to Index X \\
\hline JMP & Jump to New Location & TXA & Transfer Index X to Accumulator \\
\hline JSR & Jump to New Location Saving Return Address & TXS & Transfer Index \(X\) to Stack Register Transfer Index \(Y\) to Accumulator \\
\hline
\end{tabular}


\section*{A. 3 INSTRUCTION CODE MATRIX}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline L & \({ }^{0}\) & 1 & 2 & 3 & 4 & 5 & 6 & 7 & 8 & 9 & A & B & C & D & E & F & \\
\hline 2 0 & BRK Implied 17 &  & & & & \[
\begin{aligned}
& \hline \text { ORA } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
ASL \\
ZP \\
25
\end{tabular} & \[
\begin{gathered}
\text { RMBO } \\
\text { ZP } \\
2 \quad 5 \\
\hline
\end{gathered}
\] & PHP Implied 13 & \[
\begin{aligned}
& \hline \text { ORA } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] & ASL Accum 12 & & & ORA ABS 34 & \begin{tabular}{l}
ASL ABS \\
36
\end{tabular} & \[
\begin{aligned}
& \text { BBR0 } \\
& \text { ZP } \\
& 3^{\star * *}
\end{aligned}
\] & 0 \\
\hline 1 & \begin{tabular}{l}
BPL \\
2 2**
\end{tabular} &  & & & & \[
\begin{gathered}
\text { ORA } \\
\text { ZP, } \mathrm{X} \\
24 \\
\hline
\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 &  & & & & \[
\begin{aligned}
& \text { ORA } \\
& \text { ABS, } X \\
& 34^{*}
\end{aligned}
\] &  & \[
\begin{aligned}
& \text { BBR1 } \\
& \text { ZP } \\
& 3^{* *}
\end{aligned}
\] & 1 \\
\hline 2 & \begin{tabular}{l}
JSR
Absolute \\
36
\end{tabular} & AND
(IND, \(X\) )
\(2 \quad 6\) & & & \[
\begin{aligned}
& \mathrm{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{gathered}
\mathrm{RMB2} 2 \\
\mathrm{ZP} \\
2 \quad 5 \\
\hline
\end{gathered}
\] &  & \[
\begin{aligned}
& \hline \text { AND } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] & ROL Accum 12 & & \[
\begin{aligned}
& \hline \text { BIT } \\
& \text { ABS } \\
& 3 \quad 4 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { AND } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{ROL} \\
& \mathrm{ABS} \\
& 3 \quad 6 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBR2 } \\
& \text { ZP } \\
& 3^{* *}
\end{aligned}
\] & 2 \\
\hline 3 &  &  & & & & \[
\begin{aligned}
& \hline \text { AND } \\
& \text { ZP, } X \\
& 24 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{ROL} \\
& \mathrm{ZP}, \mathrm{X} \\
& 26 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMB3 } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\end{aligned}
\] & SEC Implied 12 & \[
\begin{aligned}
& \text { AND } \\
& \text { ABS, Y } \\
& 34^{*}
\end{aligned}
\] & & & & \[
\begin{gathered}
\text { AND } \\
\text { ABS, } X \\
34^{*}
\end{gathered}
\] & \[
\begin{gathered}
\text { ROL } \\
\text { ABS, } x \\
37
\end{gathered}
\] & \[
\begin{aligned}
& \text { BBR3 } \\
& 3^{\text {ZP }} 5^{* *}
\end{aligned}
\] & 3 \\
\hline 4 & RTI Implied 16 &  & & & & \[
\begin{aligned}
& \text { EOR } \\
& \text { ZP } \\
& 2 \quad 3 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { LSR } \\
& \text { ZP } \\
& 2 \quad 5 \\
& \hline
\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 \\
& \hline
\end{aligned}
\] & LSR Accum 12 & & JMP ABS \(3 \quad 3\) & \[
\begin{aligned}
& \text { EOR } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & LSR ABS 36 & \[
\begin{aligned}
& \text { BBR4 } \\
& \text { ZP } \\
& 3 \text { 5** }
\end{aligned}
\] & 4 \\
\hline 5 & \begin{tabular}{l}
BVC \\
Relative \\
2 2**
\end{tabular} & EOR
(IND), \(Y\)
\(25^{*}\) & & & & \[
\begin{aligned}
& \text { EOR } \\
& \text { ZP, X } \\
& 24
\end{aligned}
\] & \[
\begin{aligned}
& \text { LSR } \\
& \text { ZP, X } \\
& 26
\end{aligned}
\] & \[
\begin{aligned}
& \text { RMB5 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & \begin{tabular}{l}
CLI \\
Implied
\[
12
\]
\end{tabular} & EOR
\(A B S, Y\)
3
3 \(|\) & & & & EOR
ABS, \(x\)
3
\(4^{\star}\) & \[
\begin{array}{|c|}
\hline \text { LSR } \\
\text { ABS, } x \\
3 \\
7
\end{array}
\] & \[
\begin{aligned}
& \text { BBR5 } \\
& \text { ZP } \\
& 3 \text { 5** }
\end{aligned}
\] & 5 \\
\hline 6 & RTS Implied 16 &  & & & & \[
\begin{aligned}
& \text { ADC } \\
& \text { 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 \\
\hline
\end{gathered}
\] & PLA Implied 14 & \[
\begin{aligned}
& \hline \text { ADC } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] &  & &  & ADC ABS 34 & \[
\begin{aligned}
& \text { ROR } \\
& \text { ABS } \\
& 3 \quad 6 \\
& \hline
\end{aligned}
\] & \[
\begin{gathered}
\text { BBR6 } \\
3^{\mathrm{ZP}} 5^{\star *} \\
\hline
\end{gathered}
\] & 6 \\
\hline 7 & \begin{tabular}{|c|}
\hline BVS \\
Relative \\
2
\end{tabular} \(2^{* *}\) & ADC
\((\) IND, Y)
\(25^{*}\) & & & & \[
\begin{aligned}
& \text { ADC } \\
& \text { ZP, X } \\
& 24
\end{aligned}
\] & \[
\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{tabular}{c} 
\\
\(A D C\) \\
\(A B S, Y\) \\
3
\end{tabular} \(4^{*}\). & & & & \[
\begin{gathered}
\hline A D C \\
A B S, x \\
3
\end{gathered} 4^{*} .
\] & ROR
ABS, \(X\)
37 & \[
\begin{aligned}
& \text { BBR7 } \\
& 3^{\text {ZP }} 5^{* *}
\end{aligned}
\] & 7 \\
\hline 8 & & STA
(IND, X)
26 & & & \[
\begin{aligned}
& \text { STY } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { STA } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { STX } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { SMBO } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & DEY Implied 12 & & TXA Implied 12 & & \[
\begin{aligned}
& \text { STY } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \[
\begin{aligned}
& \text { STA } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & STX ABS 34 & \[
\begin{aligned}
& \text { BBSO } \\
& 3 \text { ZP } 5^{* *}
\end{aligned}
\] & 8 \\
\hline 9 & \begin{tabular}{|c|}
\hline BCC \\
Relative \\
2 \\
2
\end{tabular} &  & & & \[
\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 &  & \begin{tabular}{l}
TXS
Implied
1 \\
12
\end{tabular} & & & \[
\begin{gathered}
\text { STA } \\
\text { ABS, } x \\
35
\end{gathered}
\] & & \[
\begin{aligned}
& \text { BBS 1 } \\
& \text { ZP } 5^{* *}
\end{aligned}
\] & 9 \\
\hline A & \[
\begin{aligned}
& \text { LDY } \\
& \text { IMM } \\
& 22
\end{aligned}
\] &  & \[
\begin{aligned}
& \text { LDX } \\
& \text { IMM } \\
& 2 \quad 2
\end{aligned}
\] & & \[
\begin{aligned}
& \text { LDY } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDA } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { ZP } \\
& 2 \quad 3
\end{aligned}
\] & \[
\begin{aligned}
& \text { SMB2 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & TAY Implied 12 & \[
\begin{aligned}
& \text { LDA } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & TAX Implied 12 & & LDY ABS 34 & \[
\begin{aligned}
& \text { LDA } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { LDX } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBS2 } \\
& \text { ZP } \\
& 3 \text { 5** }
\end{aligned}
\] & A \\
\hline B & BCS
Relative
2 \(2^{* *}\) & \[
\begin{array}{|c}
\text { LDA } \\
\text { (IND), Y } \\
25^{*}
\end{array}
\] & & & \[
\begin{gathered}
\text { LDY } \\
\mathrm{ZP}, \mathrm{X} \\
24
\end{gathered}
\] & \[
\begin{aligned}
& \text { LDA } \\
& \text { ZP, X } \\
& 24
\end{aligned}
\] & \[
\begin{gathered}
\text { LDX } \\
Z P, Y \\
24
\end{gathered}
\] & \[
\begin{aligned}
& \text { SMB3 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & CLV Implied 12 & \begin{tabular}{|c|}
\hline LDA \\
ABS, \(Y\) \\
3
\end{tabular} \(4^{*}\) &  & & \[
\left.\begin{array}{|c|}
\hline \text { LDY } \\
\text { ABS, } X \\
3 \\
\hline
\end{array} 4^{*} \right\rvert\,
\] & \[
\begin{aligned}
& \text { LDA } \\
& \text { ABS, } X \\
& 34^{*}
\end{aligned}
\] & \[
\begin{gathered}
\text { LDX } \\
\text { ABS, Y } \\
34^{*}
\end{gathered}
\] & \[
\begin{aligned}
& \text { BBS3 } \\
& \begin{array}{l}
\text { ZP } \\
5^{* \star}
\end{array}
\end{aligned}
\] & B \\
\hline C & \[
\begin{aligned}
& \text { CPY } \\
& \text { IMM } \\
& 22
\end{aligned}
\] & \[
\begin{array}{|c|}
\hline \text { CMP } \\
(\text { IND }, \mathrm{X}) \\
26
\end{array}
\] & & & \[
\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}
\] &  & & CPY ABS 34 & \[
\begin{aligned}
& \text { CMP } \\
& \text { ABS } \\
& 3 \quad 4
\end{aligned}
\] & \[
\begin{aligned}
& \text { DEC } \\
& \text { ABS } \\
& 36
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBS4 } \\
& \text { ZP } \\
& 35^{* *}
\end{aligned}
\] & C \\
\hline D &  & \[
\begin{gathered}
\text { CMP } \\
\text { (IND), Y } \\
25^{*}
\end{gathered}
\] & & & & \[
\begin{gathered}
\text { CMP } \\
\text { ZP, X } \\
24
\end{gathered}
\] & \[
\begin{gathered}
\text { DEC } \\
\text { ZP, X } \\
26
\end{gathered}
\] & \[
\begin{gathered}
\text { SMB5 } \\
\text { ZP } \\
2 \quad 5 \\
\hline
\end{gathered}
\] &  &  & & & & \[
\begin{gathered}
\hline \text { CMP } \\
\text { ABS, } x \\
3 \quad 4^{*}
\end{gathered}
\] &  & \[
\begin{aligned}
& \text { BBS5 } \\
& \text { ZP } \\
& 3 \text { 5** }
\end{aligned}
\] & D \\
\hline E & \[
\begin{aligned}
& \hline \text { CPX } \\
& \text { IMM } \\
& 2 \quad 2 \\
& \hline
\end{aligned}
\] & \[
\begin{array}{|c}
\hline \text { SBC } \\
\text { (IND, X) } \\
26
\end{array}
\] & & & \[
\begin{aligned}
& \hline \mathrm{CPX} \\
& \mathrm{ZP} \\
& 2 \quad 3 \\
& \hline
\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{aligned}
& \text { SMB6 } \\
& \text { ZP } \\
& 2 \quad 5
\end{aligned}
\] & INX Implied 12 & \[
\begin{aligned}
& \text { SBC } \\
& \text { IMM } \\
& 2 \quad 2
\end{aligned}
\] &  & & \[
\begin{aligned}
& \text { CPX } \\
& \text { ABS } \\
& 34
\end{aligned}
\] & \begin{tabular}{l}
SBC \\
ABS \\
34
\end{tabular} & \[
\begin{aligned}
& \hline \text { INC } \\
& \text { ABS } \\
& 3 \quad 6 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \text { BBS6 } \\
& \text { ZP } \\
& 3^{* *}
\end{aligned}
\] & E \\
\hline F &  &  & & & & \[
\begin{gathered}
\text { SBC } \\
\text { ZP, 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, } \mathrm{X} \\
3 \quad 4^{*}
\end{gathered}
\] &  & \[
\begin{aligned}
& \text { BBS7 } \\
& \text { ZP } 5^{* *}
\end{aligned}
\] & F \\
\hline & 0 & 1 & 2 & 3 & 4 & 5 & 6 & 7 & 8 & 9 & A & B & C & D & E & F & \\
\hline
\end{tabular}

0 \begin{tabular}{c|c}
0 \\
\begin{tabular}{c|c} 
BRK \\
Implied \\
1 & 7
\end{tabular} & \(\begin{array}{l}\text {-OP Code } \\
\text {-Addressing Mode } \\
\text {-Instruction Bytes; Machine Cycles }\end{array}\) \\
\hline
\end{tabular}

\section*{APPENDIX B \\ KEY REGISTER SUMMARY}

CPU Registers


Mode Control Register


Host Status Flag Register


Processor Status Register


Interrupt Enable and Flag Registers


Host Addressing Matrix
\begin{tabular}{|c|c|l|}
\hline RS \(\left(A_{0}\right)\) & READ & WRITE \\
\hline 1 & \begin{tabular}{l} 
HOST \\
STATUS FLAG
\end{tabular} & \begin{tabular}{l} 
COMMAND \\
INPUT
\end{tabular} \\
\hline 0 & \begin{tabular}{l} 
DATA REG \\
OUTPUT
\end{tabular} & \begin{tabular}{l} 
DATA REG \\
INPUT
\end{tabular} \\
\hline
\end{tabular}

APPENDIX C

\section*{C. 1 MEMORY MAPS AND ADDRESS AND PIN ASSIGNMENTS}


\section*{C. 2 I/O AND INTERNAL REGISTER ADDRESSES}
\begin{tabular}{|c|c|c|}
\hline ADDRESS & READ & WRITE \\
\hline \[
\begin{array}{r}
001 \mathrm{~F} \\
1 \mathrm{E} \\
1 \mathrm{D} \\
1 \mathrm{C}
\end{array}
\] & \begin{tabular}{l}
Host Status Flag Register \\
Input Data Register (IDR)
\end{tabular} & Host Status Flag Register Output Data Regıster (ODR) \\
\hline \[
\begin{aligned}
& 1 \mathrm{~B} \\
& 1 \mathrm{~A} \\
& 19 \\
& 18
\end{aligned}
\] & \begin{tabular}{l}
Lower Counter \\
Lower Counter \& Clear Flag (IFR5) Upper Counter
\end{tabular} & \begin{tabular}{l}
Lower Latch \\
Upper Latch/Transfer Latch to Counter \& Clear Flag (IFR5) Upper Latch
\end{tabular} \\
\hline \[
\begin{aligned}
& 17 \\
& 16 \\
& 15 \\
& 14
\end{aligned}
\] & Mode Control Register & Mode Control Register \\
\hline \[
\begin{aligned}
& 13 \\
& 12 \\
& 11 \\
& 10
\end{aligned}
\] & Interrupt Enable Register Interrupt Flag Register Read "FF" & \begin{tabular}{l}
Interrupt Enable Register \\
Clear Int Flag Bit
\end{tabular} \\
\hline \[
\begin{aligned}
& \mathrm{OF} \\
& O E \\
& O D \\
& O C
\end{aligned}
\] & \[
\begin{aligned}
& -- \\
& -- \\
& --
\end{aligned}
\] &  \\
\hline \[
\begin{aligned}
& \text { OB } \\
& 0 A \\
& 09 \\
& 08
\end{aligned}
\] & \[
\begin{aligned}
& \text { - - } \\
& \text { - }
\end{aligned}
\] &  \\
\hline \[
\begin{aligned}
& 07 \\
& 06 \\
& 05 \\
& 04
\end{aligned}
\] & \[
\begin{aligned}
& \text { - } \\
& \text {-二 }
\end{aligned}
\] & —— \\
\hline \[
\begin{aligned}
& 03 \\
& 02 \\
& 01 \\
& 00
\end{aligned}
\] & \begin{tabular}{l}
Port C \\
Port B \\
Port A
\end{tabular} & \begin{tabular}{l}
Port C \\
Port B \\
Port A
\end{tabular} \\
\hline
\end{tabular}

\section*{C. 3 MULTIPLE FUNCTION PIN ASSIGNMENTS}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{2}{|c|}{\(\begin{array}{c}\text { PIN NUMBER } \\
\text { R6541Q }\end{array}\)} & \(\begin{array}{c}\text { R6500/43 }\end{array}\) & FUNCTION
\end{tabular}\(\left.\left.] \begin{array}{c}\text { ABBREVIATED PORT } \\
\text { FUNCTION }\end{array}\right] \begin{array}{c}\text { MULTIPLEXED PORT } \\
\text { FUNCTION }\end{array}\right]\)

\title{
APPENDIX D ELECTRICAL SPECIFICATIONS
}

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{c} 
Operating Temperature \\
Commercial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
\(\mathrm{T}_{\mathrm{L}}\) to \(\mathrm{T}_{\mathrm{H}}\) \\
0 to +70
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 5 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{~V} ; \mathrm{T}_{\mathrm{A}}=0^{\circ}\right.\) to \(70^{\circ}\), unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ \({ }^{1}\) & Max & Unit & Test Conditions \\
\hline Input High Voltage & \(\mathrm{V}_{1 \text { IH }}\) & +2.0 & - & \(\mathrm{V}_{\mathrm{Cc}}\) & V & \\
\hline Input Low Voltage & \(\mathrm{V}_{\text {IL }}\) & -0.3 & - & +0.8 & V & \\
\hline Input Leakage Current & \(\mathrm{I}_{\mathrm{IN}}\) & - & - & \(\pm 10.0\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IN}}=0\) to 5.25 V \\
\hline Input Low Current & \(I_{\text {IL }}\) & - & -1.0 & -1.6 & mA & \(\mathrm{V}_{\mathrm{lL}}=0.4 \mathrm{~V}\) \\
\hline Output High Voltage & \(\mathrm{V}_{\mathrm{OH}}\) & +2.4 & - & \(\mathrm{V}_{\text {cc }}\) & V & \[
\begin{aligned}
& \mathrm{I}_{\mathrm{LOAD}}=-100 \mu \mathrm{~A} \\
& \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline Output High Voltage (CMOS) & \(\mathrm{V}_{\text {cmos }}\) & \(\mathrm{V}_{\text {cC }}-30 \%\) & - & \(\mathrm{V}_{C C}\) & V & \(\mathrm{V}_{\mathrm{CC}}=4.75 \mathrm{~V}\) \\
\hline Output Low Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & - & - & +0.4 & V & \[
\begin{aligned}
& \mathrm{I}_{\text {LOAD }}=1.6 \mathrm{~mA} \\
& \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}
\end{aligned}
\] \\
\hline I/O Port Pull-Up Resistance PAO-PA7, PC0-PC7, PF0-PF73, PG0, PG73 & \(\mathrm{R}_{\mathrm{L}}\) & 3.0 & 6.0 & 11.5 & Kohm & \\
\hline Output High Current (Sourcing) & IOH & -100 & - & - & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\text {OUT }}=2.4 \mathrm{~V}\) \\
\hline Output Low Current (Sinking, PE \({ }^{\text {a }}\) & \({ }_{\mathrm{OL}}\) & 1.6 & - & - & mA & \(\mathrm{V}_{\text {OUT }}=0.4 \mathrm{~V}\) \\
\hline Darlington Current Drive ( \(\mathrm{PE}^{3}\) ) & \({ }^{\text {OH }}\) & -1.0 & - & - & mA & \(\mathrm{V}_{\text {OUT }}=1.5 \mathrm{~V}\) \\
\hline Input Capacitance XTLI, XTLO All Others & \(\mathrm{C}_{\text {IN }}\) & \[
-
\] & - & \[
\begin{aligned}
& 50 \\
& 10 \\
& \hline
\end{aligned}
\] & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Output Capacitance (Three-State Off) & \(\mathrm{C}_{\text {OUT }}\) & - & - & 10 & pF & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C} \\
& \mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V} \\
& \mathrm{f}=1.0 \mathrm{MHz}
\end{aligned}
\] \\
\hline Power Dissipation (Outputs High) & \(P_{\text {D }}\) & - & 750 & 1100 & mW & \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. Typical values measured at \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\). \\
2. Negative sign indicates outward current flow, positive indicates inward flow. \\
3. R6500/43 only.
\end{tabular}} \\
\hline
\end{tabular}

\section*{APPENDIX E TIMING REQUIREMENTS AND CHARACTERISTICS}

\section*{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:

PA, PB
- 50 pF maximum

PB, PC (I/O Modes Only) - 50 pF maximum
PB, PC (ABB and Mux Mode) - 130 pF maximum

\section*{E. 2 CLOCK TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|c|}{1 MHz} & \multicolumn{2}{|c|}{2 MHz} \\
\hline & & Min & Max & Min & Max \\
\hline \(\mathrm{T}_{\text {CYC }}\) & Cycle Time & 1000 & \(10 \mu \mathrm{~s}\) & 500 & \(10 \mu \mathrm{~S}\) \\
\hline \(\mathrm{T}_{\text {PW@O }}\) & CLKIN Input Clock Pulse Width & 475 & - & 240 & - \\
\hline \(\mathrm{T}_{\text {PW02 }}\) & Output Clock Pulse Width at Minımum \(\mathrm{T}_{\mathrm{CYC}}\) & \(\mathrm{T}_{\text {PW@O }}\) & \[
\begin{aligned}
& T_{\text {Pwoo }} \\
& +25
\end{aligned}
\] & \(\mathrm{T}_{\text {PWøO }}\) & \[
\begin{gathered}
T_{\text {Pwoo }} \\
+20
\end{gathered}
\] \\
\hline \(T_{R}, T_{F}\) & Output Clock Rise, Fall Time & - & 25 & - & 15 \\
\hline \(\mathrm{T}_{\text {IR }}, \mathrm{T}_{\text {IF }}\) & Input Clock Rise, Fall Time & - & 10 & - & 10 \\
\hline
\end{tabular}


\section*{E. 3 ABBREVIATED MODE TIMING-PB AND PC}
(MCR \(5=1\), MCR \(6=0\), MCR \(7=1\) )
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {PCAS }}\) & (PC0-PC3) Address Setup Time & - & 225 & - & 140 \\
\hline \(T_{\text {PBSU }}\) & (PB) Data Setup Time & 50 & - & 35 & - \\
\hline \(T_{\text {PBHR }}\) & (PB) Data Read Hold Time & 10 & - & 10 & - \\
\hline \(T_{\text {PBHW }}\) & (PB) Data Write Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PBDD }}\) & (PB) Data Output Delay & - & 175 & - & 150 \\
\hline \(\mathrm{T}_{\text {PCHA }}\) & (PC0-PC3) Address Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {PCHR }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\mathrm{PCHV}}\) & (PC4) \(\overline{\text { EMS }}\) Hold Tıme & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PCVP }}\) & (PC4) \(\overline{\text { EMS }}\) Stabilization Tıme & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {Esu }}\) & EMS Setup Time & - & 350 & - & 210 \\
\hline \multicolumn{6}{|l|}{NOTE 1 Values assume PC0-PC5 have the same capacitive load} \\
\hline
\end{tabular}

\section*{E.3.1 Abbreviated Mode Timing Diagram}


\section*{E. 4 MULTIPLEXED MODE TIMING—PB AND PC}
(MCR \(5=1\), MCR \(6=1\), MCR \(7=1\) )
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(T_{\text {PCRS }}\) & (PC5) R/W Setup Time & - & 225 & - & 140 \\
\hline \(T_{\text {PCAS }}\) & (PC0-PC3) Address Setup Time & - & 225 & - & 140 \\
\hline \(T_{\text {Pbas }}\) & (PB) Address Setup Tıme & - & 225 & - & 140 \\
\hline \(T_{\text {pesu }}\) & (PB) Data Setup Time & 50 & - & 35 & - \\
\hline \(\mathrm{T}_{\text {PBHR }}\) & (PB) Data Read Hold Time & 10 & - & 10 & - \\
\hline \(T_{\text {PBHW }}\) & (PB) Data Write Hold Time & 30 & - & 30 & - \\
\hline \(T_{\text {P800 }}\) & (PB) Data Output Delay & - & 175 & - & 150 \\
\hline \(T_{\text {PCMA }}\) & (PCO-PC3) Address Hold Tıme & 30 & - & 30 & - \\
\hline \(T_{\text {PBHA }}\) & (PB) Address Hold Tıme & 0 & 100 & 0 & 80 \\
\hline \(T_{\text {PCHA }}\) & (PC5) R/W Hold Time & 30 & - & 30 & - \\
\hline \(T_{\text {PCHV }}\) & (PC4) EMS Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {PCVD }}{ }^{\text {(1] }}\) & (PC4) Address to EMS Delay Time & 30 & - & 30 & - \\
\hline \(T_{\text {PCVY }}\) & (PC4) \(\overline{\text { EMS }}\) Stabilizatıon Time & 30 & - & 30 & - \\
\hline TEsu & EMS Setup Time & - & 350 & - & 210 \\
\hline \multicolumn{6}{|l|}{NOTE 1 Values assume PC0-PC5 have the same capacitive load.} \\
\hline
\end{tabular}

\section*{E.4.1 Multiplex Mode Timing Diagram}


\section*{E. 5 I/O, EDGE DETECT AND COUNTER TIMING}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|r|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \begin{tabular}{l}
\(T_{\text {Pow }}{ }^{(1)}\) \\
\(\mathrm{T}_{\text {смоs }}{ }^{(1)}\) \\
\(T_{\text {poow }}\)
\end{tabular} & \begin{tabular}{l}
Internal Write to Peripheral Data Valid \\
PA, PC TTL \\
PA, PC CMOS \\
PB
\end{tabular} & - & \[
\begin{array}{r}
500 \\
1000 \\
175
\end{array}
\] & - & \[
\begin{array}{r}
500 \\
1000 \\
150
\end{array}
\] \\
\hline \[
\begin{aligned}
& T_{\text {Posu }} \\
& T_{\text {PDSU }}
\end{aligned}
\] & \begin{tabular}{l}
Peripheral Data Setup Time
PA, PC \\
PB
\end{tabular} & \[
\begin{array}{r}
200 \\
50
\end{array}
\] & - & 200
50 & - \\
\hline \[
\begin{aligned}
& T_{\text {PHR }} \\
& T_{\text {PHR }}
\end{aligned}
\] & Peripheral Data Hold Time
PA, PC
PB & 75
10 & - & 75
10 & - \\
\hline \(\mathrm{T}_{\text {EPW }}\) & PA0-PA1 Edge Detect Pulse Width & Tcrc & - & Tcrc & - \\
\hline \[
\begin{aligned}
& T_{\text {cpw }} \\
& T_{\text {co }}{ }^{(11)}
\end{aligned}
\] & \begin{tabular}{l}
Counter \\
PA2 Input Pulse Width PA2 Output Delay
\end{tabular} & Tcrc & \(\overline{500}\) & \(\mathrm{T}_{\text {cre }}\) & \(\overline{500}\) \\
\hline
\end{tabular}

NOTE 1 Maximum Load Capacitance 50pF Passive Pull-Up Required

\section*{E.5.1 I/O, Edge Detect, Counter.}


\section*{E. 6 MICROPROCESSOR TIMING (DO-D7,} A0-A12, A15, SYNC, R/W)
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow{2}{*}{SYMBOL} & \multirow{2}{*}{PARAMETER} & \multicolumn{2}{|r|}{1 MHz} & \multicolumn{2}{|l|}{2 MHz} \\
\hline & & MIN & MAX & MIN & MAX \\
\hline \(\mathrm{T}_{\text {Rws }}\) & R/W Setup Time & - & 225 & - & 140 \\
\hline \(\mathrm{T}_{\text {AOS }}\) & AO-A12, A15 Setup Time & - & 150 & - & 75 \\
\hline \(\mathrm{T}_{\text {osu }}\) & D0-D7 Data Setup Tıme & 50 & - & 35 & - \\
\hline \(\mathrm{T}_{\text {HR }}\) & D0-D7 Read Hold Time & 10 & - & 10 & - \\
\hline \(\mathrm{T}_{\text {Hw }}\) & D0-D7 Write Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {mos }}\) & D0-D7 Write Output Delay & - & 175 & - & 130 \\
\hline \(\mathrm{T}_{\text {smm }}\) & SYNC Setup & - & 225 & - & 175 \\
\hline \(\mathrm{T}_{\text {HA }}\) & A0-A12. A15 Hold Time & 30 & - & 30 & - \\
\hline \(T_{\text {HRW }}\) & R/W Hold Time & 30 & - & 30 & - \\
\hline \(\mathrm{T}_{\text {ACC }}\) & \begin{tabular}{l}
External Memory Access \\
Time \(T_{\text {acc }} \quad \mathrm{T}_{\mathrm{crc}}-\mathrm{T}_{\mathrm{t}}-\)
\[
T_{A D S}-T_{D S U}
\]
\end{tabular} & - & \(\mathrm{T}_{\text {ACC }}\) & - & \(\mathrm{T}_{\text {ACC }}\) \\
\hline \(\mathrm{T}_{\text {SYH }}\) & SYNC Hold Time & 30 & - & 30 & - \\
\hline
\end{tabular}

\section*{E.6.1 Microprocessor Timing Diagram}


\section*{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
R23C128 128K CMOS ROM ..... 4-23
R23256 and R23257 256K Static ROMs ..... 4-27
UV Erasable PROMs
R87C64 64K CMOS UV EPROM ..... 4-31
EPROM Pinouts Guide ..... 4-37

\section*{MEMORY PRODUCTS \\ High Density NMOS ROMs and Low Power CMOS ROMs/EPROM}

Rockwell NMOS and CMOS masked ROMs support a broad range of high volume permanent memory applications. A wide selection of different size ROMs with various speed, power and temperature range options-backed by Rockwell dependability and service-will meet your production needson schedule and at the right price. Industry standard pin-outs allow easy prototyping with popular EPROMS.

Covering a wide spectrum of sizes-32K through 256K bits, Rockwell NMOS ROMs can efficiently implement such applications as single 4 K -byte ROM-based controllers to multiple 32K-byte ROM-based personal computers and graphics work stations. Low-power standby mode is a standard feature on larger density ROMs and a mask option on lower density ROMs.

For low power applications, such as battery powered portable computers and terminals, Rockwell CMOS ROMs are unsurpassed. Extremely low power dissipation in both
active and standby modes, reduce power supply requirements and extend operating time between battery replacement/recharge. Latched address (and optional latched chip select) features enhance design-in for both multiplexed and non-multiplexed address/data bus structures. The latched address scheme is compatible with systems using a clocked chip enable, a good engineering practice to eliminate contention and reduce noise. In addition, the ROM output drivers are not enabled until valid data is available. This eliminates noise and excess power consumption due to unneeded output data line transitions.

For many permanent memory applications, or ROM code prototyping, the Rockwell R87C64 is ideal. With low-power dissipation in both active and standby modes, the R87C64 will meet your most demanding power sensitive requirements and allow in-line cost-reduction upgrade to Rockwell CMOS ROMs for larger production runs.

Rockwell Has The Right ROM For Your System
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{10}{|c|}{NMOS ROMS} \\
\hline \multirow[b]{2}{*}{Density} & \multirow[b]{2}{*}{Organization} & \multirow[b]{2}{*}{Part No.} & \multirow[b]{2}{*}{Max. Access Time (ns)} & \multicolumn{2}{|l|}{Active Power (mW)} & \multicolumn{2}{|l|}{Standby Power ( mW )} & \multirow[b]{2}{*}{Package} & \multirow[b]{2}{*}{Compatible PROM} \\
\hline & & & & Typ. & Max. & Typ. & Max. & & \\
\hline \multirow[t]{2}{*}{32K} & \multirow[t]{2}{*}{\(4096 \times 8\)} & \[
\begin{aligned}
& \text { R2332A } \\
& \text { R2332AS }
\end{aligned}
\] & \[
\begin{aligned}
& \text { 200/250/300/450 } \\
& 250 / 300 / 450
\end{aligned}
\] & \[
\begin{aligned}
& 125 \\
& 125
\end{aligned}
\] & \[
\begin{aligned}
& 275 \\
& 275
\end{aligned}
\] & \[
\overline{37.5}
\] & \[
\overline{80}
\] & \begin{tabular}{l}
24-pin DIP \\
24-pin DIP
\end{tabular} & \[
\begin{aligned}
& 2532 \\
& 2532
\end{aligned}
\] \\
\hline & & \[
\begin{aligned}
& \text { R2332B } \\
& \text { R2332BS }
\end{aligned}
\] & \[
\begin{aligned}
& \text { 200/250/300/450 } \\
& 250 / 300 / 450
\end{aligned}
\] & \[
\begin{aligned}
& 125 \\
& 125
\end{aligned}
\] & \[
\begin{aligned}
& 275 \\
& 275
\end{aligned}
\] & \[
37.5
\] & \[
80
\] & \[
\begin{aligned}
& \text { 24-pin DIP } \\
& \text { 24-pin DIP }
\end{aligned}
\] & \[
\begin{aligned}
& 2732 \\
& 2732
\end{aligned}
\] \\
\hline \multirow[t]{2}{*}{64K} & \multirow[t]{2}{*}{\(8192 \times 8\)} & \[
\begin{aligned}
& \text { R2364A } \\
& \text { R2364AS }
\end{aligned}
\] & \[
\begin{aligned}
& 200 / 250 / 300 \\
& 200 / 250 / 300
\end{aligned}
\] & \[
\begin{aligned}
& 125 \\
& 125
\end{aligned}
\] & \[
\begin{aligned}
& 275 \\
& 275
\end{aligned}
\] & \[
\overline{37.5}
\] & \[
\overline{80}
\] & \[
\begin{aligned}
& \text { 24-pin DIP } \\
& \text { 24-pin DIP }
\end{aligned}
\] & MCM68764 MCM68764 \\
\hline & & \[
\begin{aligned}
& \text { R2364B } \\
& \text { R2364BS }
\end{aligned}
\] & \[
\begin{aligned}
& \text { 200/250/300 } \\
& 200 / 250 / 300
\end{aligned}
\] & \[
\begin{aligned}
& 125 \\
& 125
\end{aligned}
\] & \[
\begin{aligned}
& 275 \\
& 275
\end{aligned}
\] & \[
37.5
\] & \[
80
\] & 28-pin DIP 28-pin DIP & \[
\begin{aligned}
& 2764 \\
& 2764
\end{aligned}
\] \\
\hline 128K & \(16384 \times 8\) & R23128 & 250/300 & 125 & 275 & 37.5 & 80 & 28-pin DIP & 2764 \\
\hline 256K & \(32768 \times 8\) & \[
\begin{aligned}
& \text { R23256 } \\
& \text { R23257 }
\end{aligned}
\] & \[
\begin{aligned}
& \hline 200 / 250 / 450 \\
& 200 / 250 / 450
\end{aligned}
\] & \[
\begin{aligned}
& 125 \\
& 125
\end{aligned}
\] & \[
\begin{aligned}
& 400 \\
& 400
\end{aligned}
\] & \[
\begin{aligned}
& 40 \\
& 40
\end{aligned}
\] & \[
\begin{aligned}
& 100 \\
& 100
\end{aligned}
\] & \[
\begin{aligned}
& 28 \text {-pin DIP } \\
& \text { 28-pin DIP } \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 2764 \\
& 2564
\end{aligned}
\] \\
\hline \multicolumn{10}{|c|}{CMOS ROMS} \\
\hline 64K & \(8192 \times 8\) & R23C64 & 150/250/300 & 51 & \(10^{1}\) & 0.03 & 0.05 & 28-pin DIP & \(2764{ }^{2}\) \\
\hline 128K & \(16384 \times 8\) & R23C128 & 150/250/300 & \(8{ }^{1}\) & 151 & 0.03 & 0.05 & 28-pin DIP & \(2764{ }^{2}\) \\
\hline
\end{tabular}

\section*{Notes:}
1. @ \(1 \mu\) s cycle time.
2. The R23C64 and R23C128 latch the address inputs on the falling edge of \(\overline{\mathrm{E}}\).

\section*{R2332A AND R2332B \(32 \mathrm{~K}(4 \mathrm{~K} \times 8)\) STATIC ROM}

\section*{DESCRIPTION}

The R2332A and R2332B ROMs are 32,768-bit static Read-Only Memories (ROMs), organized as 4,096 eight-bit bytes, that offer maxımum 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 32K-bit ROMs are compatible with industry standard 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 minımum noise immunity of 04 volts
The mask-programmable chip enable input ( \(E / \bar{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

\section*{FEATURES}
- \(4,096 \times 8\) organızatıon
- 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

\section*{ORDERING INFORMATION}



\section*{*Mask-programmable option}
* \(\mathrm{N}=\) No effect on selection/enable logic, however, no voltage other than logic levels shall be applied.

R2332A and R2332B Pin Configuration

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.5 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.5 to +7.0 & Vdc \\
\hline Output Voltage & \(\mathrm{V}_{\mathrm{OUT}}\) & -0.5 to +7.0 & Vdc \\
\hline \begin{tabular}{c} 
Temperature Under Bias \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & -10 to +80 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -65 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline Power Dissipation & P & 1.0 & W \\
\hline
\end{tabular}
*NOTE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

DC CHARACTERISTICS \(V_{C C}=5.0 \mathrm{~V} \pm 10 \%, T_{A}=0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) (unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ \({ }^{3}\) & Max & Units & Test Conditions \\
\hline \(\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}\) \\
\hline \(\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}\) \\
\hline \(\mathrm{V}_{\text {IH }}\) & Input High Voltage & 2.0 & & \(\mathrm{V}_{\mathrm{Cc}}\) & V & \\
\hline \(\mathrm{V}_{\text {IL }}\) & Input Low Voltage & -0.5 & & 0.8 & V & \\
\hline \(I_{\text {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}\) \\
\hline ILO & Output Leakage Current & & & \(\pm 10\) & \(\mu \mathrm{A}\) & \begin{tabular}{l}
\(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}\), chip deselected, \\
\(\mathrm{V}_{\text {OUT }}=+0.4 \mathrm{~V}\) to \(\mathrm{V}_{\mathrm{CC}}\)
\end{tabular} \\
\hline \(I_{\text {cc }}\) & Power Supply Current, Active & & 25 & 55 & mA & \(V_{C C}=5.5 \mathrm{~V}\) \\
\hline \(\mathrm{I}_{\text {SB }}\) & Power Supply Current, Standby \({ }^{1}\) & & 7.5 & 16 & mA & 5.5 \\
\hline \(\mathrm{C}_{1}\) & Input Capacitance \({ }^{2}\) & & & 7 & pF & \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\), chip deselected, pın under test at \(0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\), \\
\hline \(\mathrm{C}_{0}\) & Output Capacitance \({ }^{2}\) & & & 10 & pF & \\
\hline \multicolumn{4}{|l|}{\begin{tabular}{l}
1 Applies only to chıp enable with power down standby mode \\
3. Typical values are for \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) \\
2. This parameter is periodically sampled and is not \(100 \%\) tested
\end{tabular}} & \multicolumn{3}{|l|}{3. Typical values are for \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{C C}=5.0 \mathrm{~V}\)} \\
\hline
\end{tabular}

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)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline & & & & & & & & & & \\
\hline Symbol & Parameter & Min & Max & Min & Max & Min & Max & Min & Max & Unit \\
\hline \(t_{\text {AVAX }}\) & Address Valid to Address Don't Care & 200 & & 250 & & 300 & & 450 & & ns \\
\hline \(\mathrm{t}_{\text {ELEH }}\) & Chip Enable Low to Chip Enable High \({ }^{2}\) & 200 & & 250 & & 300 & & 450 & & ns \\
\hline \(\mathrm{t}_{\text {AVQV }}\) & Address Valıd to Output Valıd (t \({ }_{\text {Acc }}\) ) (Access) & & 200 & & 250 & & 300 & & 450 & ns \\
\hline \(\mathrm{t}_{\text {ELQV }}\) & Chip Enable Low to Output Valıd (Access) \({ }^{2}\) & & 200 & & 250 & & 300 & & 450 & ns \\
\hline \(\mathrm{t}_{\text {AVQX }}\) & Address Valid to Output ( \(\mathrm{t}_{\mathrm{OH}}\) ) Invalid & 10 & & 10 & & 10 & & 10 & & ns \\
\hline \(\mathrm{t}_{\text {ELQX }}\) & Chip Enable Low to Output ( \(\mathrm{t}_{\mathrm{co}}\) ) Invalid & 10 & & 10 & & 10 & & 10 & & ns \\
\hline \(\mathrm{t}_{\mathrm{EHQZ}}\) & Chip Enable High to Output High Z (t \({ }_{\text {dF }}\) ) & 10 & \(70^{4}\) & 10 & \(70^{4}\) & 10 & \(70^{4}\) & 10 & \(70^{4}\) & ns \\
\hline \(t_{\text {PU }}\) & Chip Selection to Power Up Time \({ }^{2}\) & 0 & & 0 & & 0 & & 0 & & ns \\
\hline \(t_{\text {PD }}\) & Chip Deselection to Power Down Time \({ }^{2}\) & & 1004 & & 1004 & & 1004 & & 1004 & ns \\
\hline \(t_{\text {AVEL }}\) & Address Valid to Chip Enable Low & 0 & & 0 & & 0 & & 0 & & ns \\
\hline \(\mathrm{t}_{\text {GLQV }}\) & Chip Select Low to Output Valıd \({ }^{3}\) & 10 & \(90^{4}\) & 10 & \(90^{4}\) & 10 & \(90^{4}\) & 10 & \(90^{4}\) & ns \\
\hline \(\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 \\
\hline \begin{tabular}{l}
Notes: \\
1. Test Out \\
2. Mask- \\
3. Mask- \\
4. Add 2
\end{tabular} & \begin{tabular}{l}
ditıons: \\
Load: 2 TTL Loads and 100 pF, Input Transitio grammed for chip enable with power down stand grammed for chip enable without power down for extended temperature devices \(\left(-40^{\circ} \mathrm{C}\right.\) to
\end{tabular} & Time: & ns; Ti de. & Ref & nce & : Inp & 1.5V; & ut: 0 & 2.0 V & \\
\hline
\end{tabular}

\section*{TIMING DIAGRAMS}

READ CYCLE TIMING 1
(E HELD LOW)


READ CYCLE TIMING 2
\begin{tabular}{l}
\(\begin{array}{c}\text { ADDRESS } \\
\text { INPUTS }\end{array}\) \\
\hline \(\bar{E}\) (CHIP ENABLE)
\end{tabular}


\section*{TYPICAL CHARACTERISTICS}

SUPPLY CURRENT VS AMBIENT TEMPERATURE

\(\mathrm{T}_{\mathrm{A}}\)-Ambient Temperature- \({ }^{\circ} \mathrm{C}\)

ACCESS TIME
vs
AMBIENT TEMPERATURE

\(\mathrm{T}_{\mathrm{A}}\)-Ambient Temperature- \({ }^{\circ} \mathrm{C}\)

\section*{PACKAGE DIMENSIONS}


24-PIN PLASTIC DIP


\section*{R2364A \\ \(64 \mathrm{~K}(8 \mathrm{~K} \times 8\) ) STATIC ROM}

\section*{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 industry standard 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 ( \(\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.

\section*{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
- Mask-programmable chip enable
- Tri-state outputs for memory expansion

\section*{ORDERING INFORMATION}
\begin{tabular}{|l|l|l|}
\hline Part Number: R2364A
\end{tabular}


R2364A Pin Configuration

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.5 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\text {IN }}\) & -0.5 to +7.0 & Vdc \\
\hline Output Voltage & \(\mathrm{V}_{\text {OUT }}\) & -0.5 to +7.0 & Vdc \\
\hline \begin{tabular}{l} 
Temperature Under Bias \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & -10 to +80 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -60 to +95 & \\
\hline Power Dissipation & P & 1.0 & W \\
\hline
\end{tabular}
*NOTE: Stresses above those listed under "Absolute Maximum Ratings' may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{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)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ \({ }^{3}\) & Max & Units & Test Conditions \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output High Voltage & 2.4 & & \(\mathrm{V}_{\text {cc }}\) & V & \(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}\) \\
\hline \(\mathrm{V}_{\text {OL }}\) & Output Low Voltage & & & 0.4 & V & \(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=3.3 \mathrm{~mA}\) \\
\hline \(\mathrm{V}_{\text {IH }}\) & Input High Voltage & 2.0 & & \(\mathrm{V}_{\mathrm{Cc}}\) & V & \\
\hline \(\mathrm{V}_{\text {IL }}\) & Input Low Voltage & -0.5 & & 0.8 & V & \\
\hline \(\mathrm{I}_{\mathrm{LI}}\) & Input Load Current & & & 10 & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, 0 \mathrm{~V} \leq \mathrm{V}_{\mathrm{IN}} \leq 5.5 \mathrm{~V}\) \\
\hline \(\mathrm{I}_{\text {L }}\) & Output Leakage Current & & & \(\pm 10\) & \(\mu \mathrm{A}\) & \begin{tabular}{l}
\(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}\), chip deselected, \\
\(\mathrm{V}_{\text {OUT }}=+0.4 \mathrm{~V}\) to \(\mathrm{V}_{\mathrm{CC}}\)
\end{tabular} \\
\hline \(I_{C C}\) & Power Supply Current, Active & & 25 & 55 & mA & \(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}\) \\
\hline \(\mathrm{I}_{\text {SB }}\) & Power Supply Current, Standby \({ }^{1}\) & & 7.5 & 16 & mA & \\
\hline \(\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}\) \\
\hline - \(\mathrm{C}_{0}\) & Output Capacitance \({ }^{2}\) & & & 10 & pF & \(\mathrm{f}=1 \mathrm{MHz}\) \\
\hline
\end{tabular}

\section*{Notes:}
1. Applies only to chip enable with power down standby mode.
3. Typical values are for \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\).
2. This parameter is periodically sampled and is not \(100 \%\) tested.

\section*{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)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|l|}{R2364A2} & \multicolumn{2}{|l|}{R2364A25} & \multicolumn{2}{|r|}{R2364A3} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min. & Max. & Min. & Max. & Min. & Max. & \\
\hline \(t_{\text {AVAX }}\) & Address Valid to Address Don't Care & 200 & & 250 & & 300 & & ns \\
\hline \(\mathrm{t}_{\text {ELEH }}\) & Chip Enable Low to Chip Enable High \({ }^{2}\) & 200 & & 250 & & 300 & & ns \\
\hline \(\mathrm{t}_{\text {AVQV }}\) & Address Valid to Output Valid ( \(\mathrm{t}_{\text {ACC }}\) ) (Access) & & 200 & & 250 & & 300 & ns \\
\hline \(\mathrm{t}_{\text {elav }}\) & Chip Enable Low to Output Valid (Access) \({ }^{2}\) & & 200 & & 250 & & 300 & ns \\
\hline \(t_{\text {avax }}\) & Address Valid to Output ( \(\mathrm{t}_{\mathrm{OH}}\) ) Invalid & 10 & & 10 & & 10 & & ns \\
\hline \(t_{\text {ELax }}\) & Chip Enable Low to Output ( \(\mathrm{t}_{\mathrm{co}}\) ) Invalid & 10 & & 10 & & 10 & & ns \\
\hline \(t_{\text {EHQz }}\) & Chip Enable High to Output High Z ( \(\mathrm{t}_{\text {PF }}\) ) & 10 & \(70^{4}\) & 10 & \(70^{4}\) & 10 & \(70^{4}\) & ns \\
\hline \(t_{\text {PU }}\) & Chip Selection to Power Up Time \({ }^{2}\) & 0 & & 0 & & 0 & & ns \\
\hline \(t_{\text {PD }}\) & Chip Deselection to Power Down Time \({ }^{2}\) & & \(100{ }^{4}\) & & 1004 & & 1004 & ns \\
\hline \(t_{\text {AVEL }}\) & Address Valid to Chip Enable Low & 0 & & 0 & & 0 & & ns \\
\hline \(\mathrm{t}_{\text {GLQx }}\) & Chip Select Low to Output Invalid \({ }^{3}\) & 10 & \(90^{4}\) & 10 & \(90^{4}\) & 10 & \(90^{4}\) & ns \\
\hline \(\mathrm{t}_{\text {GHOZ }}\) & Chip Select High to Output High Z & 10 & \(70^{4}\) & 10 & \(70^{4}\) & 10 & \(70^{4}\) & ns \\
\hline
\end{tabular}

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)\).

TIMING DIAGRAMS
READ CYCLE TIMING 1 (E HELD LOW)


\section*{TYPICAL CHARACTERISTICS}

SUPPLY CURRENT VS AMBIENT TEMPERATURE


SUPPLY CURRENT VS SUPPLY VOLTAGE


ACCESS TIME VS AMBIENT TEMPERATURE


\section*{PACKAGE DIMENSIONS}


24-PIN PLASTIC DIP


\section*{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 industry standard microprocessors.

All three R2364B ROMs operate totally asynchronously, and require no clock input. Three mask-programmable chip select inputs allow up to eight 64K ROMs to be OR-tied without external decoding. These devices provide tri-state output buffers for memory expansion. The R2364B ROMs offer TTL input and output levels with a minimum noise immunity of 0.4 volts.

The mask-programmable chip enable input ( \(\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.

\section*{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

\section*{ORDERING INFORMATION}



R2364B Block Diagram

*Mask-programmable option.
\(\mathrm{N}=\mathrm{No}\) effect on selection/enable logic, however, voltage other than logic levels shall not be applied.

\section*{R2364B Pin Configuration}

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.5 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.5 to +7.0 & Vdc \\
\hline Output Voltage & \(\mathrm{V}_{\text {OUT }}\) & -0.5 to +7.0 & Vdc \\
\hline \begin{tabular}{c} 
Temperature Under Bias \\
Commercıal \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{l}
-10 to +80 \\
-50 \\
to +95
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -65 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline Power Dissipation & P & 1.0 & W \\
\hline
\end{tabular}
*NOTE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) (unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & 1 Typ \(^{3}\) & Max & Units & Test Conditions \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output High Voltage & 24 & & \(\mathrm{V}_{\mathrm{cc}}\) & V & \(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}\) \\
\hline \(\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}\) \\
\hline \(\mathrm{V}_{\text {IH }}\) & Input High Voltage & 2.0 & & \(\mathrm{V}_{\mathrm{cc}}\) & V & \\
\hline \(\mathrm{V}_{\text {IL }}\) & Input Low Voltage & -0.5 & & 0.8 & V & \\
\hline \(I_{\text {LI }}\) & Input Load Current & & & 10 & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, 0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq 5.5 \mathrm{~V}\) \\
\hline \(\mathrm{I}_{\text {LO }}\) & Output Leakage Current & & & \(\pm 10\) & \(\mu \mathrm{A}\) & \begin{tabular}{l}
\(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}\), chip deselected, \\
\(\mathrm{V}_{\text {OUT }}=+0.4 \mathrm{~V}\) to \(\mathrm{V}_{\mathrm{CC}}\)
\end{tabular} \\
\hline \(I_{\text {cc }}\) & Power Supply Current, Active & & 25 & 55 & mA & \(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}\) \\
\hline \(I_{\text {SB }}\) & Power Supply Current, Standby \({ }^{1}\) & & 7.5 & 16 & mA & \\
\hline \(\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}\) \\
\hline \(\mathrm{C}_{0}\) & Output Capacitance \({ }^{2}\) & & & 10 & pF & \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes \\
1. Applies only to chip enable with power down standby mode. \\
3. Typical values are for \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) \\
2. This parameter is periodically sampled and is not \(100 \%\) tested
\end{tabular}} \\
\hline
\end{tabular}

\section*{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)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|r|}{R2364B2} & \multicolumn{2}{|l|}{R2364B25} & \multicolumn{2}{|r|}{R2364B3} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min. & Max. & Min. & Max. & Min. & Max. & \\
\hline \(\mathrm{t}_{\text {AVAX }}\) & Address Valid to Address Don't Care & 200 & & 250 & & 300 & & ns \\
\hline \(t_{\text {ELEH }}\) & Chip Enable Low to Chip Enable High \({ }^{2}\) & 200 & & 250 & & 300 & & ns \\
\hline \(\mathrm{t}_{\text {AVQV }}\) & Address Valid to Output Valid ( \(\mathrm{tacc}^{\text {) }}\) (Access) & & 200 & & 250 & & 300 & ns \\
\hline \(\mathrm{t}_{\text {ELQV }}\) & Chip Enable Low to Output Valid (Access) \({ }^{2}\) & & 200 & & 250 & & 300 & ns \\
\hline \(\mathrm{t}_{\text {AVQX }}\) & Address Valid to Output ( \(\mathrm{tOH}^{\text {) }}\) Invalid & 10 & & 10 & & 10 & & ns \\
\hline \(\mathrm{t}_{\text {ELQX }}\) & Chip Enable Low to Output ( \(\mathrm{t}_{\mathrm{co}}\) ) Invalid & 10 & & 10 & & 10 & & ns \\
\hline \(\mathrm{t}_{\text {EHQZ }}\) & Chip Enable High to Output High Z ( \(\mathrm{t}_{\mathrm{DF}}\) ) & 10 & \(70^{4}\) & 10 & \(70^{4}\) & 10 & \(70^{4}\) & ns \\
\hline \(t_{\text {PU }}\) & Chip Selection to Power Up Time \({ }^{2}\) & 0 & & 0 & & 0 & & ns \\
\hline \(t_{\text {PD }}\) & Chip Deselection to Power Down Time \({ }^{2}\) & & 1004 & & 1004 & & 1004 & ns \\
\hline \(t_{\text {AVEL }}\) & Address Valid to Chip Enable Low & 0 & & 0 & & 0 & & ns \\
\hline \(\mathrm{t}_{\text {GLQV }}\) & Chip Select Low to Output Valid \({ }^{3}\) & 10 & \(90^{4}\) & 10 & \(90^{4}\) & 10 & \(90^{4}\) & ns \\
\hline \(\mathrm{t}_{\text {GHQZ }}\) & Chıp Select High to Output High Z & 10 & \(70^{4}\) & 10 & \(70^{4}\) & 10 & \(70^{4}\) & ns \\
\hline
\end{tabular}

\section*{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. \(\bar{G}\) may be delayed up to \(t_{\text {avav }}-t_{\text {glov }}\) after the falling edge of \(\bar{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(\mathrm{V}_{11}\right)\) and addresses have been valid for at least \(\mathrm{t}_{\text {Avav }}-\mathrm{t}_{\mathrm{GLQV}}\).
6. \(t_{G H a z}\) and \(t_{E H a z}\) are specified from \(\bar{G}\) or \(\bar{E}\), whichever occurs first

TIMING DIAGRAMS


\section*{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



\title{
R23C64 64K (8K x 8) CMOS ROM
}

\section*{PRELIMINARY}

\section*{DESCRIPTION}

The Rockwell R23C64 is an \(8 \mathrm{~K} \times 8\) ( 65,536 bits) CMOS read-on-memory (ROM) housed in a 28 -pin JEDEC standard 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, latched or non-latched chip selects, optional extended temperature range, and packaged in ceramic or low-cost plastic.
The R23C64 is controlled via the chip enable ( \(\overline{\mathrm{E}}\) ) and the mask programmable output enable ( \(\mathrm{G} / \overline{\mathrm{G}} / \mathrm{N}\) ) and chip selects ( \(\mathrm{S} 1 / \overline{\mathrm{S} 1} / \mathrm{N}\) and \(\mathrm{S} 2 / \overline{\mathrm{S} 2 N}\) ). The address is latched on the falling edge of \(\overline{\mathrm{E}}\), allowing the R23C64 to operate on a multiplexed bus as well as a non-multiplexed bus. The output enable and 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, output enable and chip select pins are ignored (standby). \(\bar{E}\) may also be held low indefinitely, keeping the address latched and the output buffers under output enable and chip select control. The R23C64 is in a low-power quiescient active mode when \(\overline{\mathrm{E}}\) is low and the other control inputs ( \(\mathrm{G}, \mathrm{S} 1\) and S 2 ) are steady state.

\section*{FEATURES}
- \(8,192 \times 8\) organization
- JEDEC standard pinout
- Extremely low power
- Active \(10 \mathrm{~mW} / \mathrm{MHz}\) (max.)
- Active quiescent \(50 \mu \mathrm{~W}\) (max.)
- Standby \(50 \mu \mathrm{~W}\) (max.)
- Fast access times: \(150 \mathrm{~ns}, 250 \mathrm{~ns}\) and 300 ns (max.)
- Mask programmable chip selects and output enable
- Latched addresses and (optional) latched chip selects
- Drives two TTL loads and 100 pF
- Single 5V \(\pm 10 \%\) power supply
- Pin compatible with Mostek MK37000

\section*{ORDERING INFORMATION}



\section*{R23C64 Block Diagram}

*Mask-programmable option.
\(N=\) No effect on selection logic, however, voltage greater than logic level shall not be applied.

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|l|l|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & \multicolumn{1}{c|}{ Symbol } & \multicolumn{1}{c|}{ Value } & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & VdC \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & VdC \\
\hline Output Voltage & \(\mathrm{V}_{\mathrm{OUT}}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & Vdc \\
\hline \begin{tabular}{l} 
Temperature Under Bias \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{c}
-10 to +80 \\
-50 to +95
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline Power Dissipation & P & \multicolumn{1}{c|}{1.0} & W \\
\hline
\end{tabular}
*NOTE: Stresses above those listed under "Absolute Maximum Ratings' may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{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)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ \({ }^{3}\) & Max & Units & Test Conditions \\
\hline \(\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}\) \\
\hline \(\mathrm{V}_{\mathrm{OL}}\) & Output Low Voltage & & & 0.4 & V & \(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{l}_{\mathrm{OL}}=3.2 \mathrm{~mA}\) \\
\hline \(\mathrm{V}_{\mathrm{IH}}\) & Input High Voltage & 2.0 & & \(\mathrm{V}_{\mathrm{CC}}\) & V & \\
\hline \(\mathrm{V}_{\text {IL }}\) & Input Low Voltage & -0.3 & & 0.8 & V & \\
\hline ILI & Input Load Current & & & \(\pm 1\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, 0 \mathrm{~V}<\mathrm{V}_{\mathrm{IN}}<5.5 \mathrm{~V}\) \\
\hline Lo & Output Leakage Current & & & \(\pm 10\) & \(\mu \mathrm{A}\) & \begin{tabular}{l}
\(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}\), chip deselected, \\
\(\mathrm{V}_{\text {OUT }}=+0.4 \mathrm{~V}\) to \(\mathrm{V}_{\mathrm{CC}}\)
\end{tabular} \\
\hline \(\mathrm{I}_{\mathrm{CC} 1}\) & Power Supply Current, Active & & & 2 & mA & \(\mathrm{t}_{\text {ELQV }}=150 \mathrm{~ns}^{1}, \mathrm{~V}_{\text {CC }}=5.5 \mathrm{~V}\) \\
\hline \(\mathrm{ICC2}\) & Power Supply Current, Standby & & & 10 & \(\mu \mathrm{A}\) & \(\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{CC}}-0.5 \mathrm{~V}\); all other pins active \\
\hline \(\mathrm{ICC3}\) & Power Supply Current, Active Quiescent & & & 10 & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \mathrm{E}=\mathrm{V}_{\mathrm{IL}} \\
& \overline{\mathrm{G}}=\overline{\mathrm{S} 1}=\overline{\mathrm{S} 2}=\text { Steady State }\left(\mathrm{V}_{\mathrm{IL}} \text { or } \mathrm{V}_{\mathrm{IH}}\right)
\end{aligned}
\] \\
\hline \(\mathrm{C}_{1}\) & \begin{tabular}{l}
Input Capacitance (all but \(\overline{\mathrm{E}})^{2}\) \\
(E)
\end{tabular} & & & \[
\begin{gathered}
7 \\
10
\end{gathered}
\] & \[
\begin{aligned}
& \mathrm{pF} \\
& \mathrm{pF}
\end{aligned}
\] & \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\), chip deselected, pin under test at \(\mathrm{OV}, \mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHZ}\) \\
\hline \(\mathrm{C}_{0}\) & Output Capacitance \({ }^{2}\) & & & 10 & pF & \\
\hline
\end{tabular}

\section*{Notes:}
1. \(\mathrm{t}_{\text {ELEH }}=150 \mathrm{~ns}\), all pins active, no loads, \(1 \mu \mathrm{~s}\) cycle time ( \(\mathrm{t}_{\text {ELEL }}=1 \mu \mathrm{~S}\) ).
2. This parameter is periodically sampled and is not \(100 \%\) tested.
3. Typical values are for \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\).

\section*{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)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|l|}{R23C64-15} & \multicolumn{2}{|l|}{R23C64-25} & \multicolumn{2}{|c|}{R23C64-3} & \multirow[b]{2}{*}{Unit} \\
\hline & & Min & Max & Min & Max & Min & Max & \\
\hline \(t_{\text {ELEL }}\) & Cycle Time & 220 & & 365 & & 465 & & ns \\
\hline \(\mathrm{t}_{\text {ELEH }}\) & Chıp Enable Low to Chip Enable High & 150 & & 250 & & 300 & & ns \\
\hline \(\mathrm{t}_{\text {EHEL }}\) & Chip Enable High to Chip Enable Low & 60 & & 100 & & 150 & & ns \\
\hline \(\mathrm{t}_{\text {ELQV }}\) & Chip Enable Low to Output Valıd (Access) & & 150 & & 250 & & 300 & ns \\
\hline \(t_{\text {aVEL }}\) & Address Setup Time & 0 & & 0 & & 0 & & ns \\
\hline \(t_{\text {ELAX }}\) & Address Hold Time & 50 & & 65 & & 80 & & ns \\
\hline \(\mathrm{t}_{\text {GVQV }}\) & Output Enable Valıd to Output Valid & 75 & & 100 & & 150 & & ns \\
\hline \(\mathrm{t}_{\text {EHQX }}\) & Chip Enable Hıgh to Output Invalid & 10 & & 10 & & 10 & & ns \\
\hline \(\mathrm{t}_{\text {GXQX }}\) & Output Enable Invalid to Output Invalıd & 10 & & 10 & & 10 & & ns \\
\hline \(\mathrm{t}_{\text {EHQZ }}{ }^{4}\) & Chip Enable High to Output High Z & & 50 & & 65 & & 70 & ns \\
\hline \(\mathrm{t}_{\mathrm{GXQ}}{ }^{4}\) & Output Enable Invalıd to Output High Z & & 60 & & 75 & & 90 & ns \\
\hline \(\mathrm{t}_{\mathrm{F}}, \mathrm{t}_{\mathrm{R}}\) & Rise and Fall Tımes \({ }^{2}\) & & 10 & & 15 & & 20 & ns \\
\hline
\end{tabular}

Notes:
1 Test Conditions Output Load: 2 TTL Loads and 100 pF ; Input Transition Tıme. 20 ns ; Tıming Reference Levels: Input 15 V , Output \(08 \mathrm{~V}, 20 \mathrm{~V}\)
2. Rise and Fall times stated are required for these high performance parameters only and may be relaxed for slower operation, e \(\mathrm{g}, 100 \mathrm{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. \(t_{E H Q Z}, t_{G H Q Z}\) are specified from \(\bar{G}\) or \(\bar{E}\), whichever occurs first.

\section*{TIMING DIAGRAM}

READ CYCLE TIMING


\section*{NOTES:}
1. CHIP SELECTS (S1/ \(\overline{\mathbf{S} 1}\) AND S2/(̄2) LATCHED.
2. CHIP SELECTS (S1/्̄र1 AND S2/S2) NOT LATCHED.

\section*{PACKAGE DIMENSIONS}

28-PIN CERAMIC DIP


28-PIN PLASTIC DIP


\section*{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 128K-bit ROMs are compatible with industry standard microprocessors.

The R23128 ROMs operate totally asynchronously, and require no clock input. The mask-programmable chip select (S1/S1) input allows two 128 K ROMs to be OR-tied without external decoding. These devices provides 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 ( \(\bar{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.

\section*{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

\section*{ORDERING INFORMATION}


R23128 Block Diagram

*Mask-programmable optıon.
\(N=\) no effect on selection/enable logic, however, voltage greater than logic levels shall not be applied

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|l|c|l|}
\hline \multicolumn{1}{|c|}{ Parameter } & \multicolumn{1}{|c|}{ Symbol } & \multicolumn{1}{c|}{ Value } & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.5 to +7.0 & VdC \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.5 to +7.0 & Vdc \\
\hline Output Voltage & \(\mathrm{V}_{\text {OUT }}\) & -0.5 to +7.0 & Vdc \\
\hline \begin{tabular}{l} 
Temperature under Bias \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & \begin{tabular}{l}
-10 to +80 \\
-50 to +95
\end{tabular} & C \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -65 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline Power Dissipation & P & 1.0 & W \\
\hline
\end{tabular}
*NOTE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device.. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{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)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ \({ }^{2}\) & Max & Units & Test Conditions \\
\hline \(\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}\) \\
\hline \(\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}\) \\
\hline \(\mathrm{V}_{\text {IH }}\) & Input HIGH Voltage & 2.0 & & \(\mathrm{V}_{\mathrm{CC}}\) & V & \\
\hline \(\mathrm{V}_{\text {IL }}\) & Input LOW Voltage & -0.5 & & 0.8 & V & \\
\hline \(I_{\text {LI }}\) & Input Load Current & & & 10 & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, 0 \mathrm{~V} \leq \mathrm{V}_{\text {IN }} \leq 55 \mathrm{~V}\) \\
\hline ILO & Output Leakage Current & & & \(\pm 10\) & \(\mu \mathrm{A}\) & \begin{tabular}{l}
\(V_{C C}=55 \mathrm{~V}\), chip deselected \\
\(\mathrm{V}_{\text {OUT }}=+0.4 \mathrm{~V}\) to \(\mathrm{V}_{\mathrm{CC}}\)
\end{tabular} \\
\hline \(I_{C C}\) & Power Supply Current, Active & & 20 & 55 & mA & \(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}\) \\
\hline \(I_{\text {SB }}\) & Power Supply Current, Standby & & 7.5 & 16 & mA & \\
\hline \(\mathrm{C}_{1}\) & Input Capacitance \({ }^{1}\) & & & 7 & pF & \(\mathrm{V}_{\mathrm{Cc}}=5.0 \mathrm{~V}\), chip deselected, pin \\
\hline \(\mathrm{C}_{0}\) & Output Capacitance \({ }^{1}\) & & & 10 & pF & \[
f=1 \mathrm{MHz}
\] \\
\hline
\end{tabular}

\section*{Note:}
1. This parameter is periodically sampled and is not \(100 \%\) tested.
2. Typical values are for \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\)

\section*{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)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|c|}{R23128-25} & \multicolumn{2}{|l|}{R23128-3} & \multirow[b]{2}{*}{Units} \\
\hline & & Min & Max & Min & Max & \\
\hline \(t_{\text {AVAX }}\) & Address Valid to Address Don't Care & 250 & & 300 & & ns \\
\hline \(\mathrm{t}_{\text {ELEH }}\) & Chip Enable Low to Chip Enable High & 250 & & 300 & & ns \\
\hline \(\mathrm{t}_{\text {AVQV }}\) & Address Valıd to Output Valid (t \(\mathrm{ACC}^{\text {) }}\) (Access) & & 250 & & 300 & ns \\
\hline \(\mathrm{t}_{\text {ELQV }}\) & Chip Enable Low to Output Valid (Access) & & 250 & & 300 & ns \\
\hline \(t_{\text {AVQX }}\) & Address Valid to Output ( \(\mathrm{t}_{\mathrm{OH}}\) ) Invalid & 10 & & 10 & & ns \\
\hline \(\mathrm{t}_{\text {ELQX }}\) & Chip Enable Low to Output ( \(\mathrm{t}_{\mathrm{co}}\) ) Invalıd & 10 & & 10 & & ns \\
\hline \(\mathrm{t}_{\text {EHQZ }}\) & Chip Enable High to Output High Z (t \(\mathrm{DFF}^{\text {) }}\) & 10 & 70 & 10 & 70 & ns \\
\hline \(t_{\text {PU }}\) & Chıp Selection to Power Up Time & 0 & & 0 & & ns \\
\hline \(t_{P D}\) & Chip Deselection to Power Down Time & & 100 & & 100 & ns \\
\hline \(t_{\text {AVEL }}\) & Address Valid to Chip Enable Low & 0 & & 0 & & ns \\
\hline \(\mathrm{t}_{\text {GLQV }}\) & Chip Select Low to Output Valıd & 10 & \(90^{2}\) & 10 & \(90^{2}\) & ns \\
\hline \(\mathrm{t}_{\text {GHQZ }}\) & Chip Select High to Output High Z & 10 & \(70^{2}\) & 10 & \(70^{2}\) & ns \\
\hline
\end{tabular}

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 Add 20 ns for extended temperature devices \(\left(-40^{\circ} \mathrm{C}\right.\) to \(\left.+85^{\circ} \mathrm{C}\right)\)
3. \(\bar{G}\) may be delayed up to \(t_{A v Q V}-t_{G L Q v}\) after the falling edge of \(\overline{\mathrm{E}}\) without impact on \(\mathrm{t}_{\mathrm{AVQ}}\). Data is available at the 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 ( \(\mathrm{V}_{\mathrm{IL}}\) ) and addresses have been valid for at least \(\mathrm{t}_{\mathrm{AVQV}} \mathrm{t}_{\mathrm{GLOV}}\)
\(4 t_{G H Q Z}\) and \(t_{E H Q Z}\) are specified from \(\bar{G}\) or \(\bar{E}\), whichever occurs first.


\section*{TYPICAL CHARACTERISTICS}



\section*{R23C128 \\ 128K (16K \(\times 8\) ) CMOS ROM}

\section*{PRELIMINARY}

\section*{DESCRIPTION}

The Rockwell R23C128 is a \(16 \mathrm{~K} \times 8\) ( 131,072 bits) CMOS read-only-memory (ROM) housed in a 28 -pin JEDEC standard 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, latched or non-latched chip select, optional extended temperature range, and packaged in ceramic or low-cost plastic.
The R23C128 is controlled via the chip enable ( \(\overline{\mathrm{E}})\) and the mask programmable output enable ( \(\mathrm{G} / \overline{\mathrm{G}} / \mathrm{N}\) ) and chip select ( \(\mathrm{S} 1 / \overline{\mathrm{S} 1} / \mathrm{N}\) ). The address is latched on the falling edge of \(\bar{E}\), allowing the R23C128 to operate on a multiplexed bus as well as a nonmultiplexed bus. The output enable and chip select 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, output enable and chip select pins are ignored (standby). \(\overline{\mathrm{E}}\) may also be held low indefinitely, keeping the address latched and the output buffers under output enable and chip select control. The R23C128 is in a low-power quiescent active mode when \(\bar{E}\) is low and the other control inputs ( \(G\) and S1) are steady state.

\section*{FEATURES}
- 16,384 \(\times 8\) organization
- JEDEC standard pinout
- Extremely low power
- Active \(15 \mathrm{~mW} / \mathrm{MHz}\) (max.)
- Active quiescent \(50 \mu \mathrm{~W}\) (max.)
—Standby \(50 \mu \mathrm{~W}\) (max.)
- Fast access times: \(150 \mathrm{~ns}, 250 \mathrm{~ns}\) and 300 ns (max.)
- Mask programmable chip select and output enable
- Latched addresses and (optional) latched chip select
- Drives two TTL loads and 100 pF
- Single \(5 \mathrm{~V} \pm 10 \%\) power supply

ORDERING INFORMATION
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|l|}{Part Number: R23C128} \\
\hline & L Package C = Ceramic P = Plastic \\
\hline & \[
\begin{aligned}
& \text { - Temperature Range } \\
& \text { No letter }=0^{\circ} \mathrm{C} \text { to }+70^{\circ} \mathrm{C} \\
& \mathrm{E}=-40^{\circ} \mathrm{C} \text { to }+85^{\circ} \mathrm{C}
\end{aligned}
\] \\
\hline Note Submit ROM codes using Rockwell & - Access Time (Max). \(15=150 \mathrm{~ns}\) \\
\hline ROM Code Order Form, & \(25=250 \mathrm{~ns}\) \\
\hline Order No. 2137 & \(3=300 \mathrm{~ns}\) \\
\hline
\end{tabular}


*Mask-programmable optıon.
\(\mathrm{N}=\) No effect on selection logic, however, voltage greater than logic level shall not be applied.

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|l|l|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & \multicolumn{1}{c|}{ Symbol } & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & VdC \\
\hline Input Voltage & \(\mathrm{V}_{\text {IN }}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & VdC \\
\hline Output Voltage & \(\mathrm{V}_{\text {OUT }}\) & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & VdC \\
\hline \begin{tabular}{l} 
Temperature Under Bias \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{A}}\) & -10 to +80 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline Power Dissipation & P & 1.0 & W \\
\hline
\end{tabular}
*NOTE: Stresses above those listed under "Absolute Maximum Ratings' may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{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)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min & Typ \({ }^{3}\) & Max & Units & Test Conditions \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output High Voltage & 2.4 & & \(\mathrm{V}_{\text {cc }}\) & V & \(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-200 \mu \mathrm{~A}\) \\
\hline \(\mathrm{V}_{\text {OL }}\) & Output Low Voltage & & & 0.4 & V & \(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{IOL}=3.2 \mathrm{~mA}\) \\
\hline \(\mathrm{V}_{\text {IH }}\) & Input High Voltage & 2.0 & & \(\mathrm{V}_{\mathrm{CC}}\) & V & \\
\hline \(\mathrm{V}_{\text {iL }}\) & Input Low Voltage & -0.3 & & 0.8 & V & \\
\hline \(\mathrm{I}_{1}\) & Input Load Current & & & \(\pm 1\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \mathrm{OV}<\mathrm{V}_{\mathrm{IN}}<5.5 \mathrm{~V}\) \\
\hline lo & Output Leakage Current & & & \(\pm 10\) & \(\mu \mathrm{A}\) & \begin{tabular}{l}
\(V_{C C}=5.5 \mathrm{~V}\), chip deselected, \\
\(\mathrm{V}_{\text {OUT }}=+0.4 \mathrm{~V}\) to \(\mathrm{V}_{\mathrm{CC}}\)
\end{tabular} \\
\hline \(\mathrm{ICCl}_{1}\) & Power Supply Current, Active & & & 3 & mA & \(\mathrm{t}_{\text {ELQV }}=150 \mathrm{~ns}^{1}, \mathrm{~V}_{C C}=5.5 \mathrm{~V}\) \\
\hline \(\mathrm{ICC2}\) & Power Supply Current, Standby & & & 10 & \(\mu \mathrm{A}\) & \(\bar{E}=\mathrm{V}_{C C}-0.5 \mathrm{~V}\); all other pins active \\
\hline \(\mathrm{ICC3}\) & Power Supply Current, Active Quiescent & & & 10 & \(\mu \mathrm{A}\) & \[
\begin{aligned}
& \bar{E}=\frac{V_{\mathrm{IL}}}{\mathrm{G}}=\frac{\text { Steady State }\left(V_{\mathrm{IL}} \text { or } V_{\mathrm{HH}}\right)}{} .
\end{aligned}
\] \\
\hline \(C_{1}\) & \begin{tabular}{l}
Input Capacitance (all but \(\overline{\mathbf{E}})^{2}\) \\
(E)
\end{tabular} & & & \[
\begin{gathered}
7 \\
10 \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& \mathrm{pF} \\
& \mathrm{pF}
\end{aligned}
\] & \(V_{C C}=5.0 \mathrm{~V}\), chip deselected, pin under test at \(O V, T_{A}=25^{\circ} \mathrm{C}, \mathrm{f}=1 \mathrm{MHZ}\) \\
\hline \(\mathrm{C}_{0}\) & Output Capacitance \({ }^{2}\) & & & 10 & pF & \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. \(\mathrm{t}_{\text {ELEH }}=150 \mathrm{~ns}\), all pins active, no loads, \(1 \mu \mathrm{~s}\) cycle time ( \(\mathrm{t}_{\text {ELEL }}=1 \mu \mathrm{~s}\) ). \\
2. This parameter is periodically sampled and is not \(100 \%\) tested. \\
3. Typical values are for \(\mathrm{T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\).
\end{tabular}} \\
\hline
\end{tabular}

\section*{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)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|l|}{R23C128-15} & \multicolumn{2}{|l|}{R23C128-25} & \multicolumn{2}{|r|}{R23C128-3} & \multirow[b]{2}{*}{Unit} \\
\hline Symbol & & Min & Max & Min & Max & Min & Max & \\
\hline \(\mathrm{t}_{\text {ELEL }}\) & Cycle Time & 220 & & 365 & & 465 & & ns \\
\hline \(\mathrm{t}_{\text {ELEH }}\) & Chip Enable Low to Chip Enable High & 150 & & 250 & & 300 & & ns \\
\hline \(\mathrm{t}_{\text {EHEL }}\) & Chip Enable High to Chip Enable Low & 60 & & 100 & & 150 & & ns \\
\hline \(\mathrm{t}_{\text {ELQV }}\) & Chip Enable Low to Output Valıd (Access) & & 150 & & 250 & & 300 & ns \\
\hline \(\mathrm{t}_{\text {AVEL }}\) & Address Setup Time & 0 & & 0 & & 0 & & ns \\
\hline \(\mathrm{t}_{\text {ELAX }}\) & Address Hold Time & 50 & & 65 & & 80 & & ns \\
\hline \(\mathrm{t}_{\text {GVQV }}\) & Output Enable Valıd to Output Valid & 75 & & 100 & & 150 & & ns \\
\hline \(\mathrm{t}_{\text {EHQX }}\) & Chip Enable High to Output Invalid & 10 & & 10 & & 10 & & ns \\
\hline \(\mathrm{t}_{\mathrm{GXQX}}\) & Output Enable Invalid to Output Invalid & 10 & & 10 & & 10 & & ns \\
\hline \(\mathrm{t}_{\mathrm{EHQz}}{ }^{4}\) & Chip Enable Hıgh to Output Hıgh Z & & 50 & & 60 & & 70 & ns \\
\hline \(\mathrm{t}_{\mathrm{GXQ}}{ }^{4}\) & Output Enable Invalid to Output Hıgh Z & & 60 & & 75 & & 90 & ns \\
\hline \(\mathrm{t}_{\mathrm{F}}, \mathrm{t}_{\mathrm{R}}\) & Rise and Fall Tımes \({ }^{2}\) & & 10 & & 15 & & 20 & ns \\
\hline
\end{tabular}

\section*{Notes:}
1. Test Conditıons' Output Load. 2 TTL Loads and 100 pF, Input Transitıon Time• 20 ns , Timıng Reference Levels. Input: 15 V ; Output: 0.8 V , 2.0 V .
2. Rise and Fall tımes stated are required for these high performance parameters only and may be relaxed for slower operatıon, 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_{\text {Avav }}-t_{G L Q v}\).
4. \(t_{E H Q Z}, t_{G H Q Z}\) are specified from \(\bar{G}\) or \(\bar{E}\), whichever occurs first.

TIMING DIAGRAM

\section*{read cycle timing}


\section*{NOTES:}
1. CHIP SELECT (S1/S̄) LATCHED.
2. CHIP SELECT (S1/S1) NOT LATCHED.


\title{
R23256 AND R23257 256K (32K \(\times 8\) ) STATIC ROMS
}

\section*{PRELIMINARY}

\section*{DESCRIPTION}

The R23256 and R23257 are 262,144-bit static Read-Only Memories (ROMs), organized as 32,768 eight-bit bytes, that offer maximum access times of 200 nanoseconds. These ROMs are in industry-standard \(28-\mathrm{pin}\), dual in-line packages, and are available in ceramic or low-cost plastic. These fully-static 256K-bit ROMs are compatible with industry standard microprocessors and are designed for installation in systems requiring highperformance large-capacity storage and simple interfacing.
The R23256 and R23257 ROMs operate totally asynchronously, and require no clock input. These ROMs offer TTL input and output levels with a minimum noise immunity of 0.4 volts. The R23256 has a Chip Select ( \(\mathrm{S} 1 / \overline{\mathrm{S} 1}\) ) input which allows two of these ROMs to be wire-ORed without external decoding. The R23256 also has an Output Enable ( \(G / \bar{G}\) ) input to eliminate bus contention in multiple-bus systems. The R23256 has two Chip Select ( \(\mathrm{S} 1 / \mathrm{S} 1\) and \(\mathrm{S} 2 / \mathrm{S} 2\) ) inputs which allow up to four of these ROMs to be wire-ORed without external decoding.
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.
The R23256 is pin compatible with the 2764 EPROM and the R23257 is pin compatible with the 2564 EPROM, which eliminates the need to redesign printed circuit boards for volume mask programmable ROMs after prototyping with EPROMs.

\section*{FEATURES}
- \(32,768 \times 8\) organization
- Access times: \(200 \mathrm{~ns}, 250 \mathrm{~ns}\), and 450 ns (max)
- Low max. power dissipation: 400 mW (active), 100 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 select/output enable lines
- Tri-state outputs for memory expansion
- R23256 pin compatible with 2764 EPROM
- R23257 pin compatible with 2564 EPROM

\section*{ORDERING INFORMATION}



\footnotetext{
*Mask-programmable option.
\(\mathrm{N}=\) No effect on selection logic, however, voltage greater than logic level shall not be applied.
}

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|c|c|c|c|}
\hline Parameter & Symbol & Value & Unit \\
\hline Supply Voltage & \(V_{\text {CC }}\) & -0.5 to +7.0 & Vdc \\
\hline Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & -0.5 to +7.0 & Vdc \\
\hline Output Voltage & \(\mathrm{V}_{\text {OUT }}\) & -0.5 to +7.0 & Vdc \\
\hline Temperature-under Bias Commercial Industrial & \(\mathrm{T}_{\text {A }}\) & \[
\begin{aligned}
& -10 \text { to }+80 \\
& -50 \text { to }+95
\end{aligned}
\] & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -65 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline Power Dissipation & P & 1.0 & W \\
\hline
\end{tabular}
*NOTE: Stresses above those listed under "Absolute Maximum Ratings' may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(V_{C C}=5.0 \mathrm{~V} \pm 10 \%, \mathrm{~T}_{\mathrm{A}}=0^{\circ} \mathrm{C}\) to \(70^{\circ} \mathrm{C}\) (unless otherwise specified)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min. & Typ & Max & Units & Test Conditions \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output HIGH Voltage & 2.4 & & \(\mathrm{V}_{\mathrm{cc}}\) & V & \(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OH}}=-1.0 \mathrm{~mA}\) \\
\hline \(\mathrm{V}_{\mathrm{OL}}\) & Output LOW Voltage & & & 0.4 & V & \(\mathrm{V}_{\mathrm{CC}}=4.5 \mathrm{~V}, \mathrm{I}_{\mathrm{OL}}=3.2 \mathrm{~mA}\) \\
\hline \(\mathrm{V}_{\mathrm{IH}}\) & Input HIGH Voltage & 2.0 & & \(\mathrm{V}_{\mathrm{cc}}\) & V & \\
\hline \(\mathrm{V}_{\text {IL }}\) & Input LOW Voltage & -0.5 & & 0.8 & V & \\
\hline \(\mathrm{I}_{\mathrm{LI}}\) & Input Load Current & & & 10 & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, 0 \mathrm{~V} \leq \mathrm{V}_{1 \mathrm{~N}} \leq 5.5 \mathrm{~V}\) \\
\hline ILO & Output Leakage Current & & & \(\pm 10\) & \[
\mu \mathrm{A}
\] & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}, \text { chip deselected, } \\
& \mathrm{V}_{\mathrm{OUT}}=+0.4 \mathrm{~V} \text { to } \mathrm{V}_{\mathrm{CC}}
\end{aligned}
\] \\
\hline \(I_{C C}\) & Power Supply Current, Active & & & 80 & mA & \(\mathrm{V}_{\mathrm{CC}}=5.5 \mathrm{~V}\) \\
\hline \(\mathrm{I}_{\text {SB }}\) & Power Supply Current, Standby & & & 20 & mA & \(\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{IH}}\) \\
\hline \(\mathrm{C}_{1}\) & Input Capacitance \({ }^{1}\) & & & 7 & pF & \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\), chip deselected, pin under \\
\hline \(\mathrm{C}_{0}\) & Output Capacitance \({ }^{1}\) & & & 10 & pF & test at \(0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\)
\[
\mathrm{f}=1 \mathrm{MHz}
\] \\
\hline
\end{tabular}

Notes:
1. This parameter is periodically sampled and is not \(100 \%\) tested.

\section*{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)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|r|}{\[
\begin{aligned}
& \text { R23256-20 } \\
& \text { R23257-20 }
\end{aligned}
\]} & \multicolumn{2}{|l|}{\[
\begin{aligned}
& \text { R23256-25 } \\
& \text { R23257-25 }
\end{aligned}
\]} & \multicolumn{2}{|r|}{\[
\begin{aligned}
& \text { R23256-45 } \\
& \text { R23257-45 }
\end{aligned}
\]} & \multirow[b]{2}{*}{Units} \\
\hline & & Min & Max & Min & Max & Min & Max & \\
\hline \(t_{\text {AVAX }}\) & Address Valid to Address Don't Care & 200 & & 250 & & 450 & & ns \\
\hline \(t_{\text {ELEH }}\) & Chip Enable Low to Chip Enable High & 200 & & 250 & & 450 & & ns \\
\hline \(\mathrm{t}_{\text {AVQV }}\) & Address Valıd to Output Valıd ( \(\mathrm{t}_{\text {Acc }}\) )(Access) & & 200 & & 250 & & 450 & ns \\
\hline \(\mathrm{t}_{\text {ELQV }}\) & Chip Enable Low to Output Valid (Access) & & 200 & & 250 & & 450 & ns \\
\hline \(t_{\text {AXQX }}\) & Address Change to Output Invalid ( \(\mathrm{t}_{\mathrm{OH}}\) ) & 10 & & 10 & & 10 & & ns \\
\hline \(\mathrm{t}_{\text {ELQX }}\) & Chip Enable Low to Output Active ( \(\mathrm{t}_{\mathrm{co}}\) ) & 10 & & 10 & & 10 & ; & ns \\
\hline \(\mathrm{t}_{\text {EHQZ }}\) & Chip Enable High to Output High Z (t \({ }_{\text {DF }}\) ) & & 85 & & 100 & & 150 & ns \\
\hline \(t_{\text {PU }}\) & Chip Selection to Power Up Time & 0 & & 0 & & 0 & & ns \\
\hline \(t_{\text {PD }}\) & Chip Deselection to Power Down Time & & 85 & & 100 & & 150 & ns \\
\hline \(t_{\text {AVEL }}\) & Address Setup to Chip Enable Low & 0 & & 0 & & 0 & & ns \\
\hline \(\mathrm{t}_{\text {GLQV }}\) & Output Enable Low to Output Valtd & 10 & 85 & 10 & 100 & 10 & 150 & ns \\
\hline \(\mathrm{t}_{\text {GHQZ }}\) & Output Enable High to Output High Z & & 85 & & 100 & & 150 & ns \\
\hline
\end{tabular}

\section*{Notes:}
1. Test Conditions: Output Load• 2 TTL loads and 100 pF ; Input transition time: 20 ns ; Tıming reference levels: Input: 1.5 V ; Output: \(0.8 \mathrm{~V}, 2.0 \mathrm{~V}\)
2. Add 20 ns for extended temperature devices \(\left(-40^{\circ} \mathrm{C}\right.\) to \(\left.+85^{\circ} \mathrm{C}\right)\).
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. \(t_{G H Q Z}\) and \(t_{E H Q Z}\) are specified from \(\bar{G}\) or \(\bar{E}\) whichever occurs first.


R23256 and R23257 Block Diagram


\section*{R87C64 \\ 64K (8K \(\times 8\) ) CMOS UV EPROM}

\section*{PRELIMINARY}

\section*{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 \(\vec{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.

\section*{ORDERING INFORMATION}


R87C64 Block Diagram

\section*{FEATURES}
- \(8,192 \times 8\) organization
- JEDEC approved pin-out
- Low Power
-Active 75 mW (max.)
-Standby \(500 \mu \mathrm{~W}\) (max.)
- Access times: \(250 \mathrm{~ns}, 300 \mathrm{~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.


R87C64 Pin Configuration
\begin{tabular}{|l|l|}
\hline AO-A12 & ADDRESSES \\
\hline\(\overline{\mathrm{E}}\) & CHIP ENABLE \\
\hline\(\overline{\mathrm{G}}\) & OUTPUT ENABLE \\
\hline DQO-DQ7 & DATA INPUT/OUTPUT \\
\hline\(\overline{\mathrm{P}}\) & PROGRAM ENABLE \\
\hline
\end{tabular}

R87C64 Pin Names

\section*{ABSOLUTE MAXIMUM RATINGS*}
\begin{tabular}{|l|l|l|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & \multicolumn{1}{|c|}{ Value } & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & -0.3 to +7.0 & Vdc \\
\hline \begin{tabular}{c} 
Input Voltage \\
All, except Vpp during \\
Programming \\
Vpp during Programming
\end{tabular} & \(\mathrm{V}_{\mathrm{IN}}\) & & VdC \\
\hline Output Voltage & & -0.3 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & \\
\hline Temperature under Bias & \(\mathrm{V}_{\text {OUT }}\) & -0.3 to +22.0 to \(\mathrm{V}_{\mathrm{CC}}+0.3\) & \(\mathrm{Vdc}_{\mathrm{A}}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -10 to +80 & \({ }^{\circ} \mathrm{C}\) to +125 \\
\hline Power Dissipation & P & 1.0 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
"NOTE: Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{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)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Symbol & Parameter & Min. & Typ. \({ }^{3}\) & Max. & Unit & Test Conditions \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output High Voltage & 2.4 & & - & V & \(\mathrm{I}_{\mathrm{OH}}=-400 \mu \mathrm{~A}\) \\
\hline \(\mathrm{V}_{\text {OL }}\) & Output Low Voltage & - & & 0.45 & V & \(\mathrm{I}_{\mathrm{OL}}=2.1 \mathrm{~mA}\) \\
\hline \(\mathrm{V}_{1}\) & Input High Voltage & 2.0 & & \(\mathrm{V}_{\text {cc }}+0.3\) & V & \\
\hline \(\mathrm{V}_{\text {LL }}\) & Input Low Voltage & -0.1 & & 0.8 & V & \\
\hline \(\mathrm{ICCl}_{1}\) & \(\mathrm{V}_{\text {CC }}\) Standby Current & & 2 & 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}}\) \\
\hline \(\mathrm{ICC2}\) & \(V_{\text {CC }}\) Active Current & & 2 & 15 & mA & \(\bar{E}=\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}\), note 4 \\
\hline Ipp & \(V_{\text {PP }}\) Current & & & 100 & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{PP}}=\mathrm{V}_{\mathrm{CC}} \mathrm{max}\). \\
\hline \(\mathrm{I}_{\mathrm{IN}}\) & Input Leakage Current & & & \(\pm 10\) & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}\) to \(\mathrm{V}_{\mathrm{CC}}\) \\
\hline 10 & Output Leakage Current & & & \(\pm 10\) & \(\mu \mathrm{A}\) & \(V_{\text {OUT }}=O V\) to \(V_{\text {CC }}\) \\
\hline \(\mathrm{C}_{1}\) & Input Capacitance \({ }^{2}\) & & & 7 & pF & \(\mathrm{V}_{\mathrm{cc}}=50 \mathrm{~V}\), chip deselected, pin under test \\
\hline \(\mathrm{C}_{0}\) & Output Capacitance \({ }^{2}\) & & & 10 & pF & at \(0 \mathrm{~V}, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\)
\[
f=1 \mathrm{MHz}
\] \\
\hline \multicolumn{7}{|l|}{\begin{tabular}{l}
Notes: \\
1. Applies only to chip enable with power down standby mode. \\
2. This parameter is periodically sampled and is not \(100 \%\) tested. \\
3. Typical values are for \(T_{A}=25^{\circ} \mathrm{C}\) and \(\mathrm{V}_{\mathrm{CC}}=5.0 \mathrm{~V}\) \\
4. Cycle Time \(=1 \mu \mathrm{~s}\), all pins active, no loads.
\end{tabular}} \\
\hline
\end{tabular}

\section*{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}\)
\begin{tabular}{|c|l|c|c|c|c|c|}
\hline Symbol & \multicolumn{1}{|c|}{ Parameter } & Min. & Typ. & Max. & Unit & Test Conditions \\
\hline \(\mathrm{V}_{\mathrm{IH}}\) & Input High Voltage & 2.0 & & \(\mathrm{~V}_{\mathrm{CC}}+0.3\) & V & \\
\hline \(\mathrm{~V}_{\mathrm{IL}}\) & Input Low Voltage & -0.1 & & 0.8 & V & \\
\hline \(\mathrm{I}_{\mathrm{CC}}\) & \(\mathrm{V}_{\mathrm{CC}}\) Active Current & & & 0.5 & mA & \multirow{2}{*}{\(\overline{\mathrm{E}}=\overline{\mathrm{P}}=\mathrm{V}_{\mathrm{IL}}, \overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IH}}\)} \\
\hline \(\mathrm{I}_{\mathrm{PP}}\) & \(\mathrm{V}_{\mathrm{PP}}\) Active Current & & & 30 & mA & \\
\hline \(\mathrm{I}_{\mathrm{IN}}\) & Input Leakage Current & & & 10 & \(\mu \mathrm{~A}\) & \(\mathrm{~V}_{\mathrm{IN}}=0 \mathrm{~V}\) to \(\mathrm{V}_{\mathrm{CC}}\) \\
\hline
\end{tabular}

\section*{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)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline & \multirow[b]{2}{*}{Parameter} & \multicolumn{3}{|c|}{R87C64-25} & \multicolumn{3}{|c|}{R87C64-35} & \multirow[b]{2}{*}{Unit} & \multirow[b]{2}{*}{Test Conditions \({ }^{3}\)} \\
\hline Symbol & & Min. & Typ. & Max. & Min. & Typ. & Max. & & \\
\hline \(\mathrm{t}_{\text {AVQV }}\) & Address to Data Valid & & & 250 & & & 350 & ns & \(\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}\) \\
\hline \(\mathrm{t}_{\text {ELQV }}\) & Chip Enable to Data Valid & & & 250 & & & 350 & ns & \(\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}\) \\
\hline \(\mathrm{t}_{\text {GLQv }}{ }^{1}\) & Output Enable to Data Valıd & 10 & & 100 & 10 & & 120 & ns & \(\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{IL}}\) \\
\hline \(\mathrm{t}_{\mathrm{GHQz}}{ }^{2}\) & Output Enable to High Impedance & 0 & & 90 & 0 & & 100 & ns & \(\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{IL}}\) \\
\hline \(\mathrm{t}_{\mathrm{AXQX}}\) & Address to Output Hold & 0 & & & 0 & & & ns & \(\overline{\mathrm{E}}=\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}\) \\
\hline \(\mathrm{t}_{\text {EHQZ }}\) & Chip Enable to High Impedance & 0 & & 90 & 0 & & 100 & ns & \(\overline{\mathrm{G}}=\mathrm{V}_{\mathrm{IL}}\) \\
\hline
\end{tabular}

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 \(\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}_{\text {GLQV }}\).
2. \(t_{G H Q Z}\) and \(t_{E H O Z}\) 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 \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

\section*{READ TIMING DIAGRAM}


\section*{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)
\begin{tabular}{|l|l|c|c|c|c|}
\hline Symbol & & Min. & Typ. & Max. & Units \\
\hline \(\mathrm{t}_{\text {AVPL }}\) & Address set-up time & 2 & & & \(\mu \mathrm{~s}\) \\
\hline \(\mathrm{t}_{\mathrm{DZQL}}\) & \(\overline{\mathrm{G}}\) set-up time & 2 & & & \(\mu \mathrm{~s}\) \\
\hline \(\mathrm{t}_{\mathrm{DVPL}}\) & Data set-up time & 2 & & & \(\mu \mathrm{~s}\) \\
\hline \(\mathrm{t}_{\mathrm{ELPL}}\) & \(\overline{\mathrm{E}}\) set-up time & 2 & & & \(\mu \mathrm{~s}\) \\
\hline \(\mathrm{t}_{\mathrm{VHPL}}\) & \(\mathrm{V}_{\text {PP }}\) set-up time & 2 & & & \(\mu \mathrm{~s}\) \\
\hline \(\mathrm{t}_{\mathrm{PHDX}}\) & Data hold time & 2 & & & \(\mu \mathrm{~s}\) \\
\hline \(\mathrm{t}_{\mathrm{GHAX}}\) & Address hold time & 0 & & & \(\mu \mathrm{~s}\) \\
\hline \(\mathrm{t}_{\mathrm{GLQV}}\) & Output enable to data valid & & & ns \\
\hline \(\mathrm{t}_{\mathrm{GHQZ}}\) & Output disable to output high impedance & 0 & & 120 & ns \\
\hline \(\mathrm{t}_{\mathrm{PLPH}}\) & \(\overline{\mathrm{PE}}\) pulse width during programming & 45 & & 50 & 55 \\
\hline
\end{tabular}

\section*{Notes:}

Test Conditions:
Output Load: 1 TTL gate and \(\mathrm{C}_{\mathrm{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

\section*{PROGRAM TIMING DIAGRAM}


\section*{OPERATING MODES}

The Rockwell R87C64 has five modes of operation (see table 1).

\section*{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 \(\overline{\mathrm{E}}\) and \(\overline{\mathrm{G}}\) must be \(\mathrm{V}_{\mathrm{IL}}\). \(\overline{\mathrm{E}}\) is the power control and should be used for device selection. \(\overline{\mathrm{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.

\section*{Standby Mode}

The standby mode of the R87C64 reduces power dissipation. The R87C64 is placed in the standby mode by making \(\overline{\mathrm{E}}=\mathrm{V}_{\mathrm{IH}}\). This is independent of \(\bar{G}\) and automatically puts the outputs in their high impedance (High-Z) state.

\section*{Program Mode}

The R87C64 is in the program mode when \(V_{P P}\) 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.

\section*{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_{G L Q V}\) after the falling edge of \(\overline{\mathrm{G}}\).

\section*{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 \(\bar{P}\).

Table 1. Mode Selection


\section*{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 W -sec/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.

\section*{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.

\section*{PACKAGE DIMENSIONS}

\section*{28-PIN CERDIP}

\begin{tabular}{|c|r|r|c|c|}
\hline \multirow{2}{*}{ DIM } & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{c|}{ INCHES } \\
\cline { 2 - 5 } & MIN & MAX & MIN & MAX \\
\hline A & 36.32 & 37.34 & 1.430 & 1.470 \\
\hline B & 12.95 & 13.46 & 0.510 & 0.530 \\
\hline C & 3.68 & 4.19 & 0.145 & 0.165 \\
\hline D & 0.41 & 0.51 & 0.016 & 0.020 \\
\hline F & 1.27 & 1.52 & 0050 & 0060 \\
\hline G & \multicolumn{2}{|c|}{2.54 BSC } & \multicolumn{2}{c|}{0.100 BSC } \\
\hline J & 0.20 & 0.30 & 0.008 & 0.012 \\
\hline J & 0.20 & 0.30 & 0.008 & 0.012 \\
\hline K & 3.18 & 4.19 & 0.125 & 0.165 \\
\hline L & 16.13 & 17.41 & 0.635 & 0.685 \\
\hline M & 15.24 & 15.75 & 0.600 & 0.620 \\
\hline N & 0.89 & 1.14 & 0.035 & 0.045 \\
\hline
\end{tabular}

\section*{EPROM PINOUTS GUIDE}


NOTE: Pins without their function designated are the same as the corresponding pin on the 2532.

MOS ROM/EPROM Memory Device Pin Symbols \& Names
\begin{tabular}{|c|c|c|}
\hline JEDEC Standard 21A Symbol & Older Symbol & Pin Name \\
\hline A & & Address Input \\
\hline DQ & & Data Input/Output \\
\hline \(\bar{S}\) & \(\overline{\mathrm{CS}}\) & Chip Select \\
\hline \(\bar{E}\) & \(\overline{C E}, \mathrm{PD}\) & Chip Enable, Power Down \\
\hline \(\overline{\mathbf{G}}\) & \(\overline{O E}\) & Output Enable \\
\hline \(\overline{\text { P }}\) & \(\overline{\text { PGM }}\) & Program Enable \\
\hline VCC & & System/Logic Voltage \\
\hline VPP & & Programming Voltage \\
\hline VSS, GND & & System Ground \\
\hline
\end{tabular}

Rockwell ROM/EPROM Compatibility
\begin{tabular}{|c|l|c|}
\hline Size & \begin{tabular}{c} 
Rockwell \\
ROM/EPROM
\end{tabular} & \begin{tabular}{c} 
Compatible \\
EPROM
\end{tabular} \\
\hline 32 K & R2332A & 2532 \\
& R2332B & 2732 \\
\hline \multirow{2}{*}{64 K} & R2364A & 68764 \\
& R2364B & 2764 \\
& R23C64* & 2764 \\
& R87C64 & 2764 \\
\hline 128 K & R23128 & 27128 \\
& R23C128* & 27128 \\
\hline 28 K & R23256 & 27256 \\
\hline
\end{tabular}
*NOTE: Address lines are latched on the falling edge of \(\overline{\mathrm{E}}\).

\section*{SECTION 5 \\ INTELLIGENT DISPLAY CONTROLLERS}
Page
Product Family Overview ..... 5-2
10937 and 10957 Alphanumeric Display Controller ..... 5-3
10938 and 10939 Dot Matrix Display Controller ..... 5-11
10939, 10942 and 10943 Dot Matrix Display Controller ..... 5-21
10941 and 10939 Alphanumeric and Bargraph Display Controller ..... 5-31
10951 Bargraph and Numeric Display Controller ..... 5-41
10955 Segmented Display Controller/Driver ..... 5-51

\title{
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 10955, now available, is similar to the 10937/10951 devices except the user has control over the number of display outputs allocated as strobes or segments, the PLA is doubled in size to allow 128 characters and the PLA can be bypassed to allow direct control of segments.

VACUUM FLUORESCENT CONTROLLER APPLICATIONS
\begin{tabular}{|c|c|c|c|}
\hline \multirow[b]{2}{*}{Display Type} & \multirow[t]{2}{*}{\begin{tabular}{c} 
Single Chip \\
\hline Display \\
Controller \\
(See Part No.)
\end{tabular}} & \multicolumn{2}{|c|}{Multi-Chip Display Controller} \\
\hline & & Anode Driver Type (See Part No.) & Grid Driver (10939) \\
\hline \begin{tabular}{l}
8 Char. 14-18 Seg. \\
10 Char. 14-18 Seg. \\
16 Char. 14-18 Seg. \\
20 Char. 14-18 Seg. \\
32 Char. 14-18 Seg. \\
40 Char. 14-18 Seg.
\end{tabular} & \[
\begin{aligned}
& 1 \text { (10937) } \\
& 1 \text { (10937) } \\
& 1 \text { (10937) }
\end{aligned}
\] & \[
\begin{aligned}
& 1 \text { (10941)* } \\
& 1(10941)^{*} \\
& 1 \text { (10941)* }
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 2 \\
& 2
\end{aligned}
\] \\
\hline \begin{tabular}{l}
- 20 Char. \(5 \times 7\) MTX \\
- 32 Char. \(5 \times 7\) MTX \\
- 40 Char. \(5 \times 7\) MTX \\
- 40 Char. \(5 \times 12\) MTX \\
- 80 Char. \(5 \times 7\) MTX \\
- 80 Char. \(5 \times 12\) MTX
\end{tabular} & & \(1(10938)\)
\(1(10938)\)
\(1(10938)\)
1 EA (10942)
\((10943)\)
\(1(10938)\)
1 EA (10942)
\((10943)\) & \[
\begin{aligned}
& 1 \\
& 2 \\
& 2 \\
& 2 \\
& 4 \\
& 4
\end{aligned}
\] \\
\hline - Numeric + Bar Graph & 1 (10951) & & \\
\hline - Alpha-Numeric + Bar Graph with PLA Bypass & 1 (10955) & & \\
\hline
\end{tabular}

Note: *Also controls Bar Graph Displays

\section*{10937 and 10957 ALPHANUMERIC DISPLAY CONTROLLER}

\section*{DESCRIPTION}

The 10937 and 10957 Alphanumeric Display Controllers, two of the Rockwell Intelligent Display Controller products, are MOS/LSI general purpose display controllers designed to interface to segmented displays (vacuum fluorescent, or LED).

The 10937 or 10957 will drive displays with up to 16 characters with 14 or 16 segments plus a decimal point and comma tail. Segment decoding within each device provides for the ASCII character set (upper case only). No external drive circuitry is required for displays that operate on 20 ma of drive current up to 50 volts. A \(16 \times 64\)-bit segment decoder provides internal ASCII character set decoding for the display.

The 10937 and 10957 are identical with the exception that the 10957 has two additional decodings for the decimal point and comma tail.

\section*{FEATURES}
- 16 character display driver with decimal point and comma tail
- 14 or 16 drivers
- Up to 66 kHz data rate
- TTL compatible
- Direct digit drive of 20 ma at 50 volts
- Supports vacuum fluorescent, or LED displays
- \(64 \times 16\)-bit PLA provides segment decoding for ASCII character set (all caps only)
- Serial data input for 8 -bit display and control words.
- 40-Pin DIP

\section*{ORDERING INFORMATION}
\begin{tabular}{|l|c|c|c|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \begin{tabular}{c} 
Drive \\
Voltage
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range \(\left({ }^{\circ} \mathrm{C}\right)\)
\end{tabular} \\
\hline 109X7P-40 & Plastic & 40 V & 0 to +70 \\
109X7P-50 & Plastic & 50 V & 0 to +70 \\
109X7PE-40 & Plastic & 40 V & -40 to +85 \\
109X7PE-50 & Plastic & 50 V & -40 to +85 \\
\hline
\end{tabular} Note: X \(=3\) or 5 .


10937 and 10957 Block Diagram

\section*{INTERFACE DESCRIPTION}

Pin Functions
\begin{tabular}{|l|c|l|}
\hline Signal Name & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline VSS & 1 & Power and signal reference \\
AD16-AD1 & \(2-17\) & Digits 16 through 1 driver outputs \\
VDD & 18 & DC power connection \\
A & 19 & A clock output used for testing \\
POR & 20 & Power-on reset input \\
DATA & 21 & Serial data input \\
SCLK & 22 & Serial data clock input \\
SGA-SGP & \(23-38\) & Segments A through P driver outputs \\
TAIL & 39 & Comma tail driver output \\
PNT & 40 & Decimal point driver output \\
\hline
\end{tabular}

\section*{SPECIFICATIONS}

\section*{MAXIMUM RATINGS*}

All voltages are specified relative to \(V_{S S}\).
\begin{tabular}{|l|l|l|l|l|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Min & Max & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & +0.3 & -20 & V \\
Input Voltage & \(\mathrm{V}_{\text {IN }}\) & +0.3 & -20 & V \\
Output Voltage & & \(\mathrm{V}_{\text {OUT }}\) & +0.3 & -50 \\
Operating Temperature & & V \\
Commercial & \(\mathrm{T}_{\mathrm{C}}\) & 0 & +70 & \({ }^{\circ} \mathrm{C}\) \\
Industrial & \(\mathrm{T}_{\text {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 \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline &  \\
\hline
\end{tabular}

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

\section*{DC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multicolumn{3}{|c|}{Limits ( \(\left.\mathbf{V}_{\mathbf{S S}}=\mathbf{0}\right)\)} & \multicolumn{3}{|c|}{Limits ( \(\mathrm{V}_{\mathrm{Ss}}=+5 \mathrm{~V}\) )} & \multirow[b]{2}{*}{Conditions} & \multirow[b]{2}{*}{Unit} \\
\hline & Min. & Typ. & Max. & Min. & Typ. & Max. & & \\
\hline Supply Voltage ( \(\mathrm{V}_{\mathrm{DD}}\) ) & -16.5 & -15.0 & -13.5 & -11.5 & -10.0 & -8.5 & & V \\
\hline Input DATA, SCLK, & & & & & & & & V \\
\hline Logic "1" & -1.0 & & +0.3 & + 4.0 & & +5.3 & & V \\
\hline Logic "0" & \(V_{D D}\) & & -4.2 & \(V_{D D}\) & & \(+6.8\) & & \\
\hline Input POR & & & & & & & & \\
\hline Logic "1" & -3.0 & & +0.3 & +2.0 & & \(+5.3\) & & \\
\hline Logic " 0 ", & \(V_{D D}\) & & -10.0 & \(\mathrm{V}_{\mathrm{DD}}\) & & -5.0 & & \\
\hline Output Digit and & & & & & & & & \\
\hline Segment Strobes & & - & & & & & & \\
\hline Driver On & & & & & & & & \\
\hline Commercial & & & -1.5 & & & +3.5 & At 10 mA & V \\
\hline Industrial & & & -1.7 & & & +3.3 & At 10 mA & V \\
\hline Driver Off 109X7-40 & & & -40 & & & -35 & Actual value & V \\
\hline Driver Off 109X7-50 & & & -50 & & & -45 & determined by & V \\
\hline  & & & -50 & & & -45 & external circuit & \(\checkmark\) \\
\hline Output Leakage & ! & & 10 & & & 10 & Per driver when & \(\mu \mathrm{A}\) \\
\hline Input Leakage & & & 10 & & & 10 & driver is off & \(\mu \mathrm{A}\) \\
\hline
\end{tabular}

Notes: All outputs require pulldown resistors. \(X=3\) or 5 depending on device.

\section*{AC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max & Unit \\
\hline SCLK Clock & & & & & \\
On Time & \(T_{\text {on }}\) & 1.0 & & \(\mu \mathrm{~s}\) \\
Off Time & \(T_{\text {off }}\) & 1.0 & & \(\mu \mathrm{~s}\) \\
Data Input Sample Time & \(T_{\text {boff }}\) & 200 & & ns \\
Before SCLK Clock Off & \(\mathrm{T}_{\text {aoff }}\) & 100 & & & \\
After SCLK Clock Off & & & & \\
\hline
\end{tabular}


\section*{SLK and Serial Data Timing}


SCLK and Serial Data (Control Word) Examples


Data Word LSB/MSB Timing


\section*{FUNCTIONAL DESCRIPTION}

The 10937 or 10957 is a general purpose display controller for multiplexed, segmented displays with up to 16 character positions and 14 or 16 segments, plus decimal point and comma tail. No external drive circuitry is needed for displays requiring up to \(\mathbf{2 0}\) ma of drive current up to 50 volts. All timing signals required to control the display are generated in the 10937 or 10957 device without any refresh input from the host processor.

Input data is loaded into the Display Data Buffer via the Serial Data Input (Data) channel. Internal timing and control blocks synchronize the segment and digit output signals to provide the proper timing for the multiplexing operation. A \(16 \times 64\)-bit PLA is provided for segment decoding for the full ASCII character set (upper case only).

Input data is loaded into the 10937 or 10957 ADC as a series of 8 -bit words with the most significant bit (MSB), bit 7, first. If bit 7 of any word loaded is a logic 1 (this bit is referred to as the control bit C ), the loaded word is a control data word. If the C bit of any word is a logic 0 , the loaded word is a display data word. The following paragraphs describe the format and functions of these control and display data words.

\section*{INPUT CONTROL DATA WORDS}

When the C-Bit (bit 7) of the 8-bit input word is a logic 1, bits 5 and 6 are decoded into one of four control commands while data associated with the command are extracted from bits 0-4 (see Table 1). The four control codes perform the following display functions:
- Load the Display Data Buffer pointer,
- Load the Digit Counter,
- Load the Duty Cycle register,
- Enter Test Mode.

Table 1 lists the control codes and their functions.

\section*{Buffer Pointer Control}

The Buffer Pointer Control code allows the Display Data Buffer pointer to be set to any digit position so that individual characters may be modified. The Buffer Pointer is loaded with a decimal equivalent value 2 less than the desired value (i.e., to point to the digit controlled by AD6 of the display, a value of 4 is entered). See Table 2 for a complete list of the Buffer Pointer values.

Table 2. Buffer Pointer Control Codes
\begin{tabular}{|c|c|c|}
\hline Hex Coxiver & Pointer Value & Character Controlled By \\
\hline A0 & 16 & AD2 \\
A1 & 1 & AD3 \\
A2 & 2 & AD4 \\
A3 & 3 & AD5 \\
A4 & 4 & AD6 \\
A5 & 5 & AD7 \\
A6 & 6 & AD8 \\
A7 & 7 & AD9 \\
A8 & 8 & AD10 \\
A9 & 9 & AD11 \\
AA & 10 & AD12 \\
AB & 11 & AD13 \\
AC & 12 & AD14 \\
AD & 13 & AD15 \\
AE & 14 & AD16 \\
AF & 15 & AD1 \\
\hline
\end{tabular}

\section*{Digit Counter Control}

The Digit Counter Control code is normally used only during initialization routines to define the number of character positions to be controlled. This code maximizes the duty cycle for any display. If 16 characters are to be controlled, enter a value of 0 (zero). Otherwise, enter the value desired.

\section*{Duty Cycle Control}

The Duty Cycle Control code is used to turn the display on and off, and to adjust display brightness. As shown in the block diagram, the time slot for each character is 32 clock cycles. The segment and digit drivers for each character are on for a maximum of 31 cycles with a 1 cycle inter-digit off-time. The Duty Cycle Control code contains a 5-bit numeric field which modifies the on-time for the driver outputs from 0 to 31 cycles. A duty cycle of 0 puts both the segment and digit drivers into the off state.

\section*{Enter Test Mode}

The Enter Test Mode code is a device test function only. If executed, it will lock the device in the Test Mode. Once locked in, the device can only be removed from Test Mode by performing a power-on reset.
If this mode is activated, the digit time is reduced from 32 to 4 clock cycles to speed up the output driver sequencing time for ease in testing.

\section*{INPUT DISPLAY DATA WORDS}

Display data words are loaded as 8 -bit ASCII format codes. The 64 codes available (with the C-bit set to 0 to indicate a display data word) are shown in Table 3 with their corresponding ASCII characters.

Table 1. Control Data Words
\begin{tabular}{|c|c|c|}
\hline \multicolumn{2}{|c|}{8-Bit Control Word} & \multirow[b]{2}{*}{- Function} \\
\hline C-Bit (Bit 7) & 7-Bit Code (Bits 6-0) & \\
\hline \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & 010NNNN \({ }^{(1)}\) 100NNNN \({ }^{(1)}\) 11NNNNN \({ }^{(2)}\) OONNNNN \({ }^{(3)}\) & BUFFER POINTER CONTROL (Position of character to be changed) DIGIT COUNTER CONTROL (Number of characters to be output) DUTY CYCLE CONTROL (On/off and brightness control) ENTER TEST MODE (Not a user function) \\
\hline \multicolumn{2}{|l|}{\begin{tabular}{l}
Notes: 1 . NNNN is a 4 -bit binary value representing the digit number to be loaded. \\
2. NNNNN is a 5 -bit binary value representing the number of clock cycles each digit is on.
\end{tabular}} & 3. This code is a device test function only. If executed it will lock the device in the test mode. Once locked in, the device can only be removed from Test Mode by performing a power-on reset. \\
\hline
\end{tabular}

Sixteen display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer is automatically incremented before each data word is stored in the Display Buffer except for decimal point and comma words. These do not cause the Buffer Pointer to increment and thus are always associated with the previous character entered. To select the next character
position to be loaded out of the normal sequence, use the Buffer Pointer Control command before entering the display data word. It is not necessary to use the Buffer Pointer Control command to cycle back to position 1 when less than 16 character positions are being used.


Figure 1. Display Scan Timing Diagram (Duty Cycle)

Table 3. Character Assignments for Display Data Words
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multicolumn{2}{|l|}{DATA WORD} & \multirow[b]{2}{*}{CHARACTER} & \multicolumn{2}{|l|}{DATA WORD} & \multirow[b]{2}{*}{CHARACTER} & \multicolumn{2}{|l|}{DATA WORD} & \multirow[b]{2}{*}{CHARACTER} & \multicolumn{2}{|l|}{DATA WORD} & \multirow[b]{2}{*}{CHARACTER} \\
\hline BINARY & HEX & & BINARY & HEX & & BINARY & HEX & & BINARY & HEX & \\
\hline 0X000000 & 00 & (1) & OX010000 & 10 & P & 0X100000 & 20 & & OX110000 & 30 & 0 \\
\hline \(0 \times 000001\) & 01 & A & \(0 \times 010001\) & 11 & Q & \(0 \times 100001\) & 21 & 1 & 0X110001 & 31 & 1 \\
\hline 0x000010 & 02 & B & 0X010010 & 12 & R & \(0 \times 010010\) & 22 & " & 0X110010 & 32 & 2 \\
\hline \(0 \times 000011\) & 03 & C & \(0 \times 010011\) & 13 & S & \(0 \times 100011\) & 23 & \# & 0X110011 & 33 & 3 \\
\hline \(0 \times 000100\) & 04 & D & \(0 \times 010100\) & 14 & T & 0X100100 & 24 & \$ & 0X110100 & 34 & 4 \\
\hline \(0 \times 000101\) & 05 & E & 0X010101 & 15 & U & \(0 \times 100101\) & 25 & \% & 0X110101 & 35 & 5 \\
\hline \(0 \times 000110\) & 06 & F & 0X010110 & 16 & V & 0X100110 & 26 & \& & 0X110110 & 36 & 6 \\
\hline \(0 \times 000111\) & 07 & G & \(0 \times 010111\) & 17 & W & \(0 \times 100111\) & 27 & & 0X110111 & 37 & 7 \\
\hline \(0 \times 001000\) & 08 & H & 0X011000 & 18 & X & 0x101000 & 28 & ! & 0X111000 & 38 & \(\varepsilon\) \\
\hline \(0 \times 001001\) & 09 & 1 & \(0 \times 011001\) & 19 & Y & \(0 \times 101001\) & 29 & ) & OX111001 & 39 & 9 \\
\hline \(0 \times 001010\) & OA & \(J\) & 0X011010 & 1A & Z & 0X101010 & 2A & * & 0X111010 & 3A & : \\
\hline \(0 \times 001011\) & OB & K & \(0 \times 011011\) & 1 B & [ & 0x101011 & 2 B & + & 0X111011 & 3 B & ; \\
\hline 0x001100 & OC & L & 0X011100 & 1 C & 1 & 0X101100 & 2 C & & OX111100 & 3 C & < \\
\hline 0X001101 & OD & M & 0X011101 & 1D & 1 & 0X101101 & 2D & - & 0X111101 & 3D & \(=\) \\
\hline \(0 \times 001110\) & OE & N & 0X011110 & 1 E & \(\wedge\) & 0X101110 & 2 E & - & 0X111110 & 3 E & > \\
\hline 0X001111 & OF & 0 & \(0 \times 011111\) & 1 F & & 0X101111 & 2F & \(\backslash\) & 0X111111 & 3F & \(?\) \\
\hline
\end{tabular}

\section*{POWER-ON RESET (POR)}

The Power-On Reset (POR) initializes the internal circuits of the 10937 or 10957 ADC when power ( \(V_{D D}\) is applied. The following conditions are established after a Power-On Reset:
a. The Digit Drivers (AD1 - AD16) are in the off state (floating).
b. The Segment Drivers (SGA-SGP) are in the off state (floating). This includes PNT and Tail.
c. The Duty Cycle is set to 0 .
d. The Digit Counter is set to 16 (a bit code value of 0 ).
e. The Buffer Pointer points to the character controlled by AD1.

\section*{DIGIT DRIVERS (AD1-AD16)}

The sixteen Digit Drivers (AD1 - AD16) are used to select each of the display digits sequentially during a refresh scan. Display segments will be illuminated when both the Digit Drivers and Segment Drivers for a particular character are energized simultaneously. The timing characteristics of both the digits and segments are shown in Figure 1. See POR for the Power-On Reset state of these drivers.

Table 4. Additional Codes for PNT and Tail On 10957
\begin{tabular}{|c|c|c|}
\hline \multicolumn{2}{|c|}{ DATA WORD } & \multirow{2}{*}{ CHARACTER } \\
\hline BINARY & HEX & \\
\hline 01101100 & 6 C & \multirow{2}{*}{, (Tail only) } \\
01101110 & 6 E & Blank
\end{tabular}

\section*{SEGMENT DRIVERS (SGA-SGP)}

Sixteen (16) Segment Drivers are provided (SGA - SGP), plus the decimal point (PNT) and comma tail (TAIL). The segment outputs are internally decoded from the 8 -bit characters in the Display Data Buffer by means of a \(64 \times 16\)-bit PLA. The Segment Driver Allocations are shown in Figure 2. Data codes and their corresponding segment patterns are shown in Figure 3. Timing characteristics for the segment outputs are shown in Figure 1. See POR for the Power-On Reset state of these drivers.

\section*{NOTE}

For 14-segment displays, SGA is used for the top segment and SGF is used for the bottom segment. SGB and SGE can be floated.

\section*{TYPICAL SYSTEM HOOK-UP}

Figure 4 shows the 10937 or 10957 as it would be connected to a V-F display when driven by a host system. \(\mathrm{E}_{\mathrm{K}}\) is determined by the V-F display specifications and \(\mathrm{R}_{\mathrm{C}}\) is selected to provide proper biasing current for zeners. Pull down resistors \(\mathrm{R}_{\mathrm{A}}\) and \(\mathrm{R}_{\mathrm{G}}\) are determined by the interconnection capacitance between the device and the display.


Figure 2. Segment Driver Allocations


16-Segment Display
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline 00 & \(|-1|\) & 08 & \(|1-1|\) & 10 & \(\mid 1\) & 18 & \[
1 /
\] & 20 & & 28 & 1 & 30 &  & 38 & \(\left\lvert\, \begin{aligned} & -1 \\ & -1\end{aligned}\right.\) \\
\hline 01 &  & 09 &  & 11 &  & 19 & \[
\begin{gathered}
1 / \\
1
\end{gathered}
\] & 21 & \[
\overline{1}
\] & 29 & 1
1 & 31 & \[
1
\] & 39 & \(\square \mid\) \\
\hline 02 &  & OA & & 12 & \(1-1\) & 1A & \(1 /\) & 22 & 1 & 2A & \(\frac{11}{11}\) & 32 & --1 & 3 A & \\
\hline 03 &  & OB & 11 & 13 &  & 1B &  & 23 &  & 2B & -1- & 33 &  & 3B & / \\
\hline 04 &  & OC & 1 & 14 &  & 1 C & \[
\searrow
\] & 24 &  & \[
\left|\begin{array}{c}
2 C \\
-- \\
6 C *
\end{array}\right|
\] &  & 34 & \(\mid--1\) & 3 C & \[
1
\] \\
\hline 05 &  & OD & \(1 \begin{array}{ll}1 \\ 1 & 1\end{array}\) & 15 &  & 1D & & 25 & \(1 /\) & 2D & - - & 35 &  & 3D & - - \\
\hline 06 & - & OE & \[
\left\lvert\, \begin{array}{ll}
1 & 1 \\
1 & \searrow
\end{array}\right.
\] & 16 & \(11 /\) & 1E & / & 26 & \[
\begin{aligned}
& \overline{1} \\
& -\searrow \mid
\end{aligned}
\] & \[
\left\lvert\, \begin{gathered}
2 \mathrm{E} \\
-\mathrm{E} \\
\hline \mathrm{E}^{*}
\end{gathered}\right.
\] & Blank & 36 &  & 3E & \[
\searrow
\] \\
\hline 07 &  & OF &  & 17 &  & 1F & & 27 & 1 & 2 F & \(1 /\) & 37 & & 3F & 1 \\
\hline
\end{tabular}

14-Segment Display
Notes: Bit 7 of the data byte is a "don't care" bit except for PNT and TAIL on 10957. Data byte hex codes shown assume bit 7 is a zero.

\footnotetext{
* = 10957 only.
}

Figure 3. Display Segment Driver Character Patterns


Figure 4. Partial System Schematic

\section*{10938 AND 10939 DOT MATRIX DISPLAY CONTROLLER}

\section*{DESCRIPTION}

The Rockwell 10938 and 10939 Dot Matrix Display Controller is a two-chip MOS/LSI general purpose display controller system designed to interface to dot matrix displays (vacuum-fluorescent or LED).

The two-chip set will drive displays with up to 35 anodes (dots) and up to 20 grids (characters) plus a cursor. The chips can be cascaded to drive larger displays of as many as 80 characters. An internal PLA-type decoder provides character decoding and dot pattern generation for the full 96 -character ASCII set and an additional 32 special characters.

ORDERING INFORMATION
\begin{tabular}{|l|l|r|}
\hline \multicolumn{1}{|c|}{\begin{tabular}{c} 
Part \\
Number
\end{tabular}} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \multicolumn{1}{|c|}{\begin{tabular}{c} 
Temperature \\
Range \(\left({ }^{\circ} \mathbf{C}\right)\)
\end{tabular}} \\
\hline 10938 P & Plastıc & 0 to +70 \\
10938 PE & Plastic & -40 to +85 \\
10939 P & Plastıc & 0 to +70 \\
10939 PE & Plastic & -40 to +85 \\
\hline
\end{tabular}

\section*{FEATURES}
- 20-character display driver cascadable to 80
- Standard \(5 \times 7\) character font. Custom fonts available by special order
- Separate cursor driver output
- Direct drive capability for vacuum-fluorescent displays
- \(128 \times 35\) PLA provides segment decoding for full 96-character ASCII set, plus 32 special characters
- Serial or parallel data input for 8 -bit display and control characters
- Brightness, refresh rate, and display mode controls
- 40-pin DIP


Block Diagram of 10938 and 10939

\section*{INTERFACE DESCRIPTION}

10938 Pin Functions
\begin{tabular}{|l|c|l|}
\hline Signal Name & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline V \(_{\text {SS }}\) & 2 & Power and signal reference \\
SGO1-SG35 & \(3-25,27-38\) & Anode driver outputs \\
SCLK-DIS & 39 & Serial data shiff clock \\
DATA-LOAD & 40 & Serial data output/latch control \\
V \(_{\text {DD }}\) & 1 & DC Power \\
V \(_{\text {GG }}\) & 26 & Display voltage \\
\hline
\end{tabular}


10938 Pin Configuration

\section*{SPECIFICATIONS}

\section*{ABSOLUTE MAXIMUM RATINGS*}

Voltages are referenced to \(\mathrm{V}_{S S}\)
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Operating Temperature & & & \\
Commercial & Tc & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
Industrial & Ti & -40 to +85 & \({ }^{\circ} \mathrm{C}\) \\
Storage Temperature & & -55 to +125 & \({ }^{\circ} \mathrm{C}\) \\
\hline Operating Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & -22 to -18 & Vdc \\
\hline Operating Display Voltage & \(\mathrm{V}_{\mathrm{GG}}\) & -50 & Vdc \\
\hline
\end{tabular}

10939 Pin Functions
\begin{tabular}{|l|c|l|}
\hline Signal Name & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline V \(_{\text {SS }}\) & 36 & Power and signal reference \\
V DD \(^{\prime}\) & 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 & Serial data output/latch control \\
STR00-STR19 & \(15-34\) & Grid Driver Outputs \\
VGG & 35 & Display voltage \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|}
\hline SCLK-DIS & 1 & 40 & \(\square\) DATA-LOAD \\
\hline SOP & 2 & 39 & \(\square\) MASTER \\
\hline SIP & 3 & 38 & \(\square\) CLOCK \\
\hline POR & 4 & 37 & \(\square \mathrm{V}_{\mathrm{DD}}\) \\
\hline LD & 5 & 36 & \(\mathrm{V}_{\text {ss }}\) \\
\hline D0 & 6 & 35 & \(\mathrm{V}_{\mathrm{GG}}\) \\
\hline D1 & 7 & 34 & STR00 \\
\hline D2 & 8 & 33 & STR01 \\
\hline D3 & 9 & 32 & \(\square\) STR02 \\
\hline D4 & 10 & 31 & STR03 \\
\hline D5 & 11 & 30 & - STR04 \\
\hline D6 & 12 & 29 & \(\square\) STR05 \\
\hline D7 & 13 & 28 & \(\square\) STR06 \\
\hline CURSOR & 14 & 27 & \(\square\) STR07 \\
\hline STR19 & 15 & 26 & \(\square\) STR08 \\
\hline STR18 & 16 & 25 & \(\square\) STR09 \\
\hline STR17 & 17 & 24 & \(\square\) STR10 \\
\hline STR16 & 18 & 23 & \(\square\) STR11 \\
\hline STR15 & 19 & 22 & \(\square\) STR12 \\
\hline STR14 & 20 & 21 & STR13 \\
\hline
\end{tabular}

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

\section*{DC CHARACTERISTICS}

All voltages referenced to \(V_{S S}\)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Parameter & Notes & Symbol & Min & Typ & Max & Unit \\
\hline \[
\begin{aligned}
& \text { Input DO-D7, LD, SIP } \\
& \text { Logic " } 1 \text { "', } \\
& \text { Logic " } 0 \text { " }
\end{aligned}
\] & 2 & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IH}} \\
& \mathrm{~V}_{\mathrm{IL}}
\end{aligned}
\] & \[
\begin{aligned}
& -1.2 \\
& V_{D D}
\end{aligned}
\] & & \[
\begin{aligned}
& +0.3 \\
& -4.2
\end{aligned}
\] & \[
\begin{aligned}
& \text { v } \\
& \text { v }
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { Input POR } \\
& \text { Logic " } 1 \text { "', } \\
& \text { Logic " } 0 \text { " }
\end{aligned}
\] & 2 & \[
\begin{aligned}
& \mathrm{V}_{\text {IHPO }} \\
& \mathrm{V}_{\text {ILPO }}
\end{aligned}
\] & \[
\begin{aligned}
& -3.0 \\
& V_{D D}
\end{aligned}
\] & & \[
\begin{aligned}
& +0.3 \\
& -10.0
\end{aligned}
\] & \[
\begin{aligned}
& \text { v } \\
& \text { v }
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { Output SOP } \\
& \text { Logic " } 1 \text { "" } \\
& \text { Logic " } 0 \text { " }
\end{aligned}
\] & 2 & \begin{tabular}{l}
\(V_{\text {OHSY }}\) \\
\(V_{\text {OLSY }}\)
\end{tabular} & \[
\begin{aligned}
& -12 \\
& V_{D D}
\end{aligned}
\] & & \[
{ }_{-4.2}^{V_{\mathrm{ss}}}
\] & \[
\begin{aligned}
& \text { v } \\
& \text { v }
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { Output Grids, Cursor, and Anodes } \\
& \text { Logic " } 1 \text { " }\left(l_{\text {load }}=10 \mathrm{~mA} 10939,2 \mathrm{~mA} 10938\right) \\
& \text { Logic " } 0 \text { ) }\left(l_{\text {load }}=0 \mathrm{~mA}\right)
\end{aligned}
\] & 1 & \(\mathrm{V}_{\mathrm{OH}}\) \(V_{\text {OL }}\) & \[
\begin{aligned}
& -1.5 \\
& \mathrm{~V}_{\mathrm{GG}}
\end{aligned}
\] & & \[
\stackrel{V_{\mathrm{SS}}}{0.95} \times \mathrm{V}_{\mathrm{GG}}
\] & \[
\begin{aligned}
& \text { v } \\
& \text { v }
\end{aligned}
\] \\
\hline
\end{tabular}

Notes: 1. Designates characteristics for both 10938 and 10939 2. Designates characterıstics for 10939

\section*{OPERATING CURRENTS}
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|c|}{Maximum} & Typical & Unit \\
\hline & Industrial
\[
\begin{gathered}
\mathrm{TA}=-40^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}}=-22 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}}=-50 \mathrm{Vdc}
\end{gathered}
\] & \[
\begin{gathered}
\text { Commercial } \\
\mathrm{TA}=0^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}}=-22 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}}=-50 \mathrm{Vdc}
\end{gathered}
\] & \[
\begin{aligned}
\mathrm{TA} & =25^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}} & =-20 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}} & =-50 \mathrm{Vdc}
\end{aligned}
\] & \\
\hline \[
\begin{gathered}
10938^{1} \\
I_{D D} \\
I_{G G} \\
\hline
\end{gathered}
\] & \[
\begin{array}{r}
4.5 \\
11.2
\end{array}
\] & \[
\begin{aligned}
& 3.6 \\
& 9.0 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 3.2 \\
& 8.0 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{mA} \\
& \mathrm{~mA}
\end{aligned}
\] \\
\hline \[
\begin{gathered}
10939 \text { (master) }^{2} \\
\mathrm{I}_{\mathrm{DD}} \\
\mathrm{I}_{\mathrm{GG}} \\
\hline
\end{gathered}
\] & \[
\begin{array}{r}
13.6 \\
1.0 \\
\hline
\end{array}
\] & \[
\begin{array}{r}
10.9 \\
0.8
\end{array}
\] & \[
\begin{aligned}
& 6.0 \\
& 0.5 \\
& \hline
\end{aligned}
\] & \[
\begin{gathered}
\mathrm{mA} \\
\mathrm{~mA}
\end{gathered}
\] \\
\hline \[
\begin{gathered}
10939 \text { (slave) }^{2} \\
\mathrm{I}_{\mathrm{DD}} \\
\mathrm{I}_{\mathrm{GG}} \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& 9.1 \\
& 1.0
\end{aligned}
\] & \[
\begin{aligned}
& 7.3 \\
& 0.8
\end{aligned}
\] & \[
\begin{aligned}
& 4.0 \\
& 0.5
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{mA} \\
& \mathrm{~mA}
\end{aligned}
\] \\
\hline
\end{tabular}

Notes.
1. The 10938 has 35 internal drivers which are brounht out \(I_{G G}\) is proportional to the number of drivers on. The values given are for all 35 drivers on. Divide \(I_{G G}\) shown by 35 to determine \(I_{G G}\) 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.

AC CHARACTERISTICS
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max & Unit \\
\hline \begin{tabular}{l}
GENERAL INTERFACE TIMING \\
Data Load (LD) \\
On Time \\
Off time \\
Commercial \\
Industrial \\
Cycle Time Commerical Industrial
\end{tabular} & \[
\begin{aligned}
& T_{\text {Idon }} \\
& T_{\text {ldoff }} \\
& T_{\text {ldayc }}
\end{aligned}
\] & \[
\begin{array}{r}
1.0 \\
40.0 \\
44.5 \\
60.0 \\
66.7
\end{array}
\] & & & \begin{tabular}{l}
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\)
\end{tabular} \\
\hline \begin{tabular}{l}
SERIAL INTERFACE TIMING \\
Serial Clock (D1) \\
On Time \\
Off Time \\
Cycle Time \\
Serial Clock (DO) \\
Set-up Time \\
Hold Time \\
Serial Clock to LD Time \\
LD to Serial Clock
\end{tabular} & \begin{tabular}{l}
\(\mathrm{T}_{\text {scon }}\) \\
\(\mathrm{T}_{\text {scoff }}\) \\
\(T_{\text {sccyc }}\) \\
\(\mathrm{T}_{\text {ssetup }}\) \\
\(\mathrm{T}_{\text {shold }}\) \\
\(\mathrm{T}_{\mathrm{sl}}\) \\
\(T_{\text {Is }}\)
\end{tabular} & \begin{tabular}{l}
\[
\begin{aligned}
& 1.0 \\
& 1.0 \\
& 2.0
\end{aligned}
\] \\
400 \\
400 \\
1.0 \\
1.0
\end{tabular} & & 20.0 & \begin{tabular}{l}
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
ns \\
ns \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\)
\end{tabular} \\
\hline \begin{tabular}{l}
PARALLEL INTERFACE TIMING \\
Parallel Data (D0-D7) \\
Set-up Time Hold Time
\end{tabular} & \[
T_{\text {psetup }}
\]
\[
\mathrm{T}_{\text {phold }}
\] & \[
\begin{array}{r}
0 \\
200
\end{array}
\] & & & \[
\begin{aligned}
& \text { ns } \\
& \text { ns }
\end{aligned}
\] \\
\hline
\end{tabular}

\section*{TIMING WAVEFORMS}


Serial Interface Timing Waveforms


Parallel Interface Timing Waveforms

\section*{FUNCTIONAL DESCRIPTION}

Once the display buffer has been loaded from the host processor, the 10938/10939 system generates all timing signals required to control the display.

Input data is loaded into the Display Data Buffer as a series of 8 -bit words via the Serial or Parallel Data Input channel on the 10939. Internal timing and control logic synchronize the digit output signals with the Serial Data and Load signals to the 10938 to provide the proper timing for the multiplexing operation. A \(128 \times 35\) bit PLA is provided for decoding the full 96 character ASCII set, plus 32 special characters.

The parallel data input mode is implemented by toggling any of data lines D2-D7 after POR has gone low. Once the parallel data load mode has been implemented, a power-on reset procedure must be performed to return to serial data load mode. Parallel data transfer is accomplished by putting the command or display data on the data lines, then pulsing the LD line. The load cycle time must be at least \(60 \mu \mathrm{~s}\) with the LD line set high for at least one \(\mu \mathrm{s}\) and held low for at least \(40 \mu \mathrm{~s}\).

The serial data input mode is implemented during the poweron reset procedure. In those systems using serial mode, ports D2-D7 should be tied low to prevent the inadvertent implementation of the parallel load mode. Serial data bytes are shifted into a data buffer MSB first on line DO using line D1 as the serial clock. The last eight bits clocked in are latched into the display controller by a pulse on the LD line. The cycle time for each data bit is \(2 \mu \mathrm{~s}\) and the load time for each byte is \(60 \mu \mathrm{~s}\).

Input data may be Control or Display data. The following paragraphs describe the format and functions of these control and display data words.

\section*{CONTROL DATA WORDS}

Control data words are used to select the operating parameters of the display controller. They must be preceded by a Control Prefix word (0000 0001, hexadecimal 01) to be distinguished from Display Data words.

\section*{Buffer Pointer Control}

The Buffer Pointer Control code sets the Display Data Buffer pointer. The lower 5 bits of the code are loaded into the buffer pointer (see Table 2).

\section*{Table 1. Control Word Assignments}
\begin{tabular}{|c|c|}
\hline Hex Value & Function \\
\hline 00 & Not used \\
\hline 01 & Load 01 Into Data Buffer \\
\hline 02 & Not used \\
\hline 03 & Not used \\
\hline 04 & Not used \\
\hline 05 & Set digit time to 16 cycles per grid \\
\hline 06 & Set digit time to 32 cycles per grid \\
\hline 07 & Set digit time to 64 cycles per grid \\
\hline 08 & Enable Normal Display Mode (MSB in data words is used for cursor control only) \\
\hline 09 & Enable Blank Mode (data words with MSB \(=1\) will be blanked and cursor will be on) \\
\hline OA & Enable Inverse Mode (data words with MSB = 1 will be "inversed" and cursor will be on) \\
\hline OB & Not used \\
\hline OC & Not used \\
\hline OD & Not used \\
\hline OE & Start Display Refresh Cycle (use only once after reset) \\
\hline OF & Not used \\
\hline 10-3F & Not used \\
\hline 40-4F & Load Duty Cycle Register with lower 6 bits (0-63) \\
\hline 80-9F & Load Digit Counter (80=32, \(81=1,82=2\), etc.) \\
\hline AO-BF & Not used \\
\hline C0-D3 & Load Buffer Pointer Register with lower 5 bits \\
\hline EO-FF & Not used \\
\hline
\end{tabular}

Table 2. Buffer Pointer Control Codes
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
Code \\
Value
\end{tabular} & \begin{tabular}{c} 
Pointer \\
Value
\end{tabular} & \begin{tabular}{c} 
Character \\
Position
\end{tabular} \\
\hline C0 & 00 & 0 \\
C1 & 01 & 1 \\
C2 & 02 & 2 \\
C3 & 03 & 3 \\
C4 & 04 & 4 \\
C5 & 05 & 5 \\
C6 & 06 & 6 \\
C7 & 07 & 7 \\
C8 & 08 & 8 \\
C9 & 09 & 9 \\
CA & \(0 A\) & 10 \\
CB & \(0 B\) & 11 \\
CC & 0 C & 12 \\
CD & \(0 D\) & 13 \\
CE & \(0 E\) & 14 \\
CF & OF & 15 \\
D0 & 10 & 16 \\
D1 & 11 & 17 \\
D2 & 12 & 18 \\
D3 & 13 & 19 \\
\hline \multicolumn{3}{|l|}{} \\
Note: \\
DO NOT USE CHARACTER POSITIONS 20-31 \\
(CODES D4-DF) & \\
\hline
\end{tabular}

\section*{Digit Counter Control}

The Digit Counter Control code defines the number of character positions (grids) to be controlled. This code is normally used only during initialization routines, but it may also be used in conjunction with the Duty Cycle Control code to extend the range of brightness control (see Table 3).

\section*{Duty Cycle Control}

The Duty Cycle Control code turns the display on and off, adjusts display brightness, and modifies display timing. The time slot for each character is 16,32 , or 64 cycles as selected by the Digit Time Control codes (see Table 3). The anode and grid drivers for each character are on for a maximum of 13,29 , or 61 cycles with a 3 cycle inter-digit off-time. The lower 6 bits of the Duty Cycle Control code are loaded into the Duty Cycle Register. Resultant duty cycles are shown in Table 4.

Table 3. Digit Counter Control Codes
\begin{tabular}{|c|c|c|}
\hline Code & \begin{tabular}{l}
Digit \\
Counter Value
\end{tabular} & No. of Grids Controlled \\
\hline 80 & 00 & 32 \\
\hline 81 & 01 & 1 \\
\hline 82 & 02 & 2 \\
\hline 83 & 03 & 3 \\
\hline 84 & 04 & 4 \\
\hline 85 & 05 & 5 \\
\hline 86 & 06 & 6 \\
\hline 87 & 07 & 7 \\
\hline 88 & 08 & 8 \\
\hline 89 & 09 & 9 \\
\hline 8A & OA & 10 \\
\hline 8B & OB & 11 \\
\hline 8 C & OC & 12 \\
\hline 8D & OD & 13 \\
\hline 8E & OE & 14 \\
\hline 8F & OF & 15 \\
\hline 90 & 10 & 16 \\
\hline 91 & 11 & 17 \\
\hline 92 & 12 & 18 \\
\hline 93 & 13 & 19 \\
\hline 94 & 14 & 20 \\
\hline 95 & 15 & 21 \\
\hline 96 & 16 & 22 \\
\hline 97 & 17 & 23 \\
\hline 98 & 18 & 24 \\
\hline 99 & 19 & 25 \\
\hline 9A & 1A & 26 \\
\hline 9 B & 1B & 27 \\
\hline 9 C & 1 C & 28 \\
\hline 9D & 1D & 29 \\
\hline 9 E & 1E & 30 \\
\hline 9F & 1F & 31 \\
\hline
\end{tabular}

\section*{Digit Time Select}

The Digit Time Select code sets the total time for each character during the refresh cycle. Three values can be set using the three codes shown in Table 1. The default value set at power-on is 64 cycles per grid. For displays with 40 or more characters, or under conditions where the display can be subjected to quick movements during viewing (e.g. portable or vehicle-mounted applications), it may be necessary to increase the refresh rate by selecting 16 or 32 cycles per grid with the appropriate control code.

Table 4. Duty Cycle Control Codes
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Code} & \multicolumn{2}{|l|}{Digit Time \(=16\)} & \multicolumn{2}{|l|}{Digit Time \(=32\)} & \multicolumn{2}{|l|}{Digit Time \(=64\)} \\
\hline & On & Off & On & Off & On & Off \\
\hline 40 & - & 16 & - & 32 & - & 64 \\
\hline 41 & - & 16 & - & 32 & - & 64 \\
\hline 42 & - & 16 & - & 32 & - & 64 \\
\hline 43 & 1 & 15 & 1 & 31 & 1 & 63 \\
\hline 44 & 2 & 14 & 2 & 30 & 2 & 62 \\
\hline 45 & 3 & 13 & 3 & 29 & 3 & 61 \\
\hline 46 & 4 & 12 & 4 & 28 & 4 & 60 \\
\hline 47 & 5 & 11 & 5 & 27 & 5 & 59 \\
\hline 48 & 6 & 10 & 6 & 26 & 6 & 58 \\
\hline 49 & 7 & 9 & 7 & 25 & 7 & 57 \\
\hline 4A & 8 & 8 & 8 & 24 & 8 & 56 \\
\hline 4B & 9 & 7 & 9 & 23 & 9 & 55 \\
\hline 4C & 10 & 6 & 10 & 22 & 10 & 54 \\
\hline 4D & 11 & 5 & 11 & 21 & 11 & 53 \\
\hline 4E & 12 & 4 & 12 & 20 & 12 & 52 \\
\hline 4F & 13 & 3 & 13 & 19 & 13 & 51 \\
\hline 50 & 13 & 3 & 14 & 18 & 14 & 50 \\
\hline 51 & 13 & 3 & 15 & 17 & 15 & 49 \\
\hline 52 & 13 & 3 & 16 & 16 & 16 & 48 \\
\hline 53 & 13 & 3 & 17 & 15 & 17 & 47 \\
\hline - & - & - & - & - & - & - \\
\hline - & - & - & - & - & - & - \\
\hline - & - & - & - & - & - & - \\
\hline 5B & 13 & 3 & 25 & 7 & 25 & 39 \\
\hline 5C & 13 & 3 & 26 & 6 & 26 & 38 \\
\hline 5D & 13 & 3 & 27 & 5 & 27 & 37 \\
\hline 5E & 13 & 3 & 28 & 4 & 28 & 36 \\
\hline 5F & 13 & 3 & 29 & 3 & 29 & 35 \\
\hline 60 & 13 & 3 & 29 & 3 & 30 & 34 \\
\hline 61 & 13 & 3 & 29 & 3 & 31 & 33 \\
\hline 62 & 13 & 3 & 29 & 3 & 32 & 32 \\
\hline - \({ }^{\text {b }}\) & - & - & - & - & - & - \\
\hline - & - & - & - & - & - & - \\
\hline - & , & - & - & - & & - \\
\hline 7C & 13 & 3 & 29 & 3 & 58 & 6 \\
\hline 7D & 13 & 3 & 29 & 3 & 59 & 5 \\
\hline 7E & 13 & 3 & 29 & 3 & 60 & 4 \\
\hline 7F & 13 & 3 & 29 & 3 & 61 & 3 \\
\hline
\end{tabular}

\section*{Display Mode Select}

Each ASCII character is represented by the lower seven bits of the 8 -bit value loaded into the 10939. The eighth (most significant) bit controls the cursor (see Cursor Control). This bit is known as the data byte control bit. If either Blank or Inverse mode is selected, a " 0 " in this bit causes a normal character display, while " 1 '" selects either Blank or Inverse mode, depending on which mode is enabled. Three control codes are provided (see Table 1) to Enable Blank Mode, Enable Inverse Mode, or Enable Normal Display Mode.

In the Blank mode, any character with the MSB = " 1 " will be blanked. In the Inverse mode, it will be displayed with all segment driver outputs inverted. On video displays, this is referred to as 'Inverse Video"' format. These controls allow individual characters or groups of characters to be blinked or blanked by simply changing the mode without changing the data in the Display Buffer.

\section*{Cursor Control}

The data byte control bit (MSB 8), besides selecting Blank, Inverse, or Normal mode, also controls the cursor output which is enabled on all characters with the MSB equal to one. Therefore, when the Normal mode is enabled and the MSB of the data byte is set to a one, the normal character is displayed with the cursor on. When the Blank mode is enabled and the MSB is set to a one, the character is blanked but the cursor is on. If Inverse mode is enabled and the MSB is set to a one, the inverse character is displayed and the cursor is on but not inversed.

\section*{Start Refresh}

At power on, the 10939 is held in an internal halt mode. The normal display refresh sequence starts upon receipt of a Start Refresh control code. This is particularly useful for synchronizing systems using more than one 10939. Only the Master 10939 in a multi-chip system will recognize the Start Refresh code. The Master starts the Slave(s) at the appropriate time, using the SOP signal.

\section*{INPUT DISPLAY DATA WORDS}

Display data words are loaded as 8 -bit codes. The eighth (most significant) bit specifies normal ( 0 ) or blank/inverse (1) display mode, depending on the blank/inverse mode selection (see Control data words 09 and 0A in Table 1). This bit also controls the cursor.

Twenty display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer automatically increments after each data word is stored in the buffer. To select a character position to be loaded out of sequence, use the Buffer Pointer control code. The Buffer Pointer will automatically reset to character position 0 when its value is equal to the programmed Digit Count.

\section*{POWER-ON RESET}

The Power-On Reset (POR) initializes the internal circuits of the 10939. This is normally accomplished when power ( \(V_{D D}\) ) is applied. The following conditions are established by application of POR:
a. The Grid Drivers (STR00-STR19) on the 10939 are in the off state.
b. The Anode Drivers (SG01-SG35) on the 10938 are in the off state.
c. The Duty Cycle is set to 0 .
d. The Digit Counter is set to 32.
e. The Buffer Pointer is set to 0 .
f. The Digit time is set to 64 .
g. The Normal display mode is set.
\(h\). DATA-LOAD is set to high impedance state.
i. SCLK-DIS is set to \(\mathrm{V}_{\text {OL }}\) to disable the anode drivers in the 10938.
j. SOP is set to \(V_{O L}\) to disable the sync pulse.

\section*{NOTE:}
1. When the POR signal is removed, SCLK-DIS is set to the high impedance state.
2. During the initial rise time of \(V_{D D}\) at power turn-on, the magnitude of \(\mathrm{V}_{\mathrm{GG}}\) should not exceed the magnitude of \(\mathrm{V}_{\mathrm{DD}}\).

\section*{GRID (DIGIT) DRIVERS (STR00-STR19) PLUS CURSOR}

The 20 Digit Drivers select each of the display character positions sequentially during a refresh scan. Display dots will be illuminated when both the Digit Drivers and Dot Drivers for a particular character are energized simultaneously. The cursor segment is generated by the 10939, but its timing characteristics are identical to the anode timing generated by the 10938.

\section*{ANODE (DOT) DRIVERS (SG01-SG35)}

35 Dot Drivers are provided in the 10938. The output states for each character pattern are internally decoded from the 8 -bit characters received from the 10939 by means of a \(128 \times 35\)-bit PLA. Data codes and the corresponding patterns are shown in Figure 1. Figure 2 shows the Dot Drivers (SG01-SG35) assignments as they relate to the \(5 \times 7\) dot matrix patterns.


\section*{TYPICAL SYSTEM HOOKUPS}

Figure 3 shows a 10938 and 10939 in a parallel interface with the host system driving a 20 character display. Figure 4 shows a 10938 and a 10939 in a serial interface with the host system driving a 20 character display. Figure 5 shows a 10938 and two 10939's in a parallel interface with the host system driving a 40 character display.
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline 00 & & 01 &  & 02 & \(\because \because\)
\(\because \because\) & 03 & \(\because\) & 04 & ":\% & 05 & ! \(\because \%\) & 06 & \(\cdots\) & 07 & \(\cdots\) \\
\hline 08 &  & 09 &  & OA & \(\cdots\) & 08 & :... \({ }^{\bullet}\) & OC &  & OD. & ".": & OE & :\%* & OF & ! \\
\hline 10 &  & 11 &  & 12 &  & 13 &  & 14 & ○:. & 15 & **.0! & 16 & \(\cdots\) & 17 & -••! \\
\hline 18 & \(\because *\) & 19 & ! & 1A & -•... & 1B & ! \({ }^{\text {© }}\) & 1C & & 1 D & " \({ }^{\bullet}\) ! \({ }^{\circ}\) & 1 E & ..... & 17 & \(\because \because\) \\
\hline 20 & & 21 &  & 22 & : : & 23 & ! ! & 24 & \(\because\) & 25 &  & 26 &  & 27 & \\
\hline 28 & ! \({ }^{\bullet \prime}\) & 29 &  & 2 A & \(\because\) & 2 B & - \(!\) & 2C & : & 2D & -*** & 2 E & : & 2 F & \(\bullet *\) \\
\hline 30 &  & 31 & ! & 32 &  & 33 &  & 34 &  & 35 &  & 36 & \({ }_{\text {! }}^{\cdots}\) & 37 &  \\
\hline 38 &  & 39 &  & 3A & & 38 & . & 3 C & \[
\because
\] & 3D & -..... & 3E &  & \(3 F\) &  \\
\hline ,40 & \(\cdots\) & 41 & :". & 42 & :"... & 43 &  & 44 & !""! & 45 & !....
\(\vdots\)
\(\vdots\)
\(\cdots\) & 46 & ! \({ }^{\prime \cdots}\) & 47 &  \\
\hline 48 & ! & 49 & -! & 4A & & 4B &  & 4C & ! & 4D &  & \(4 E\) &  & 4F & ! "\% \\
\hline 50 &  & 51 & ! ". & 52 &  & 53 &  & 54 & - \({ }^{\circ}\) & 55 & ! & 56 & ! \(\quad \vdots\) & 57 & \(\vdots 8\) \\
\hline 58 &  & 59 &  & 5A &  & 5B &  & 5C & & 50 &  & SE &  & 5F & - \\
\hline 60 & \(\bullet\) & 61 & \(\cdots\) & 62 &  & 63 & !.... & 64 & :....: & 65 & ***: & 66 &  & 67 & :...! \\
\hline 68 &  & 69 & \(\because\) & 6A & \(\because\) & 6B & \(\because\) & 6C & \(\vdots\) & 6 D &  & 6E & \(!^{* \prime}\) & \(6 F\) & \({ }^{\bullet \cdots}\) \\
\hline 70 &  & 71 & :**! & 72 &  & 73 & \(\cdots{ }^{\bullet \cdots}\) & 74 & !.. & 75 & ! & 76 & !. \(\vdots\) & 77 & ! ! \\
\hline 78 &  & 79 & \(\because::^{\bullet}\) & 7A &  & 78 &  & 7 C &  & 7 D &  & 7E & -.... & 7F & \(\begin{array}{r}48 \%: \% \\ !8 \% \% \\ 8: 8 \% \% \\ \hline\end{array}\) \\
\hline
\end{tabular}

Figure 1. \(5 \times 7\) Dot Matrix PLA Patterns


Figure 2. Anode (Dot) Driver 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

\section*{0 Rockwell}

\section*{10939, 10942, AND 10943 DOT MATRIX DISPLAY CONTROLLER}

\section*{DESCRIPTION}

The Rockwell 10939, 10942, and 10943 Dot Matrix Display Controller is a three-chip MOS/LSI general purpose display controller system designed to interface to dot matrix displays (vacuumfluorescent or LED).

The three-chip set will drive displays with up to 46 anodes (dots) and up to 20 grids (characters) plus a cursor. The chips can be cascaded to drive larger displays of up to 80 characters. An internal PLA-type decoder provides character decoding and dot pattern generation for the full 96 -character ASCII set and an additional 32 special characters.

\section*{ORDERING INFORMATION}
\begin{tabular}{|l|l|r|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range \(\left({ }^{\circ} \mathrm{C}\right)\)
\end{tabular} \\
\hline 10939 P & Plastic & 0 to +70 \\
\(10939 P E\) & Plastic & -40 to +85 \\
10942 P & Plastic & 0 to +70 \\
10942PE & Plastic & -40 to +85 \\
\(10943 P\) & Plastic & 0 to +70 \\
\(10943 P E\) & Plastıc & -40 to +85 \\
\hline
\end{tabular}

\section*{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
- Two \(128 \times 23\) PLAs provide decoding for full 96-character ASCII set plus 32 special characters
- Serial or parallel data input for 8 -bit display and control characters
- Brightness, refresh rate, and display mode controls
- 10939 provided in 40-pin DIP
- 10942 and 10943 provided in 28-pin DIP


Block Diagram of 10939, 10942, 10943

\section*{INTERFACE DESCRIPTION}

10942 and 10943 Pin Functions
\begin{tabular}{|l|c|l|}
\hline Signal Name & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline \(\mathrm{V}_{\mathrm{DD}}\) & 1 & DC Power \\
\(\mathrm{V}_{\mathrm{SS}}\) & 2 & Power and signal reference \\
SGO1-SG23 & 3-17, 19-26 & Anode (Dot) driver outputs \\
\(\mathrm{V}_{\mathrm{GG}}\) & 18 & Display voltage \\
SCLK-DIS & 27 & Serial data shift clock \\
DATA-LOAD & 28 & Serial data output/latch control \\
\hline
\end{tabular}


10942 and 10943
Pin Configurations

10939 Pin Functions
\begin{tabular}{|l|c|l|}
\hline Signal Name & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline V \(_{\text {SS }}\) & 36 & Power and signal reference \\
V \(_{\text {DD }}\) & 37 & DC Power \\
CLOCK & 38 & Synchronization Clock \\
CURSOR & 14 & Cursor driver output \\
MASTER & 39 & Master/Slave Mode control \\
SIP & 3 & Sync Input \\
SOP & 2 & Sync Output \\
D0-D7 & \(6-13\) & Serial or parallel data input \\
LD & 5 & Input data strobe \\
POR & 4 & Power-on reset \\
SCLK-DIS & 1 & Serial data shift clock \\
DATA-LOAD & 40 & Serial data output/latch control \\
STR00-STR19 & \(15-34\) & Digit (grid) driver outputs \\
V GG \(^{2}\) & 35 & Display voltage \\
\hline
\end{tabular}


10939 Pin Configurations

\section*{SPECIFICATIONS}

\section*{ABSOLUTE MAXIMUM RATINGS*}

Voltages are referenced to \(\mathrm{V}_{\mathrm{SS}}\), where \(\mathrm{V}_{\mathrm{SS}}=+5 \mathrm{Vdc}\)
\begin{tabular}{|c|c|c|c|}
\hline Parameter & Symbol & Value & Unit \\
\hline Operating Temperature Commercial Industrial Storage Temperature & \[
\begin{aligned}
& \mathrm{T}_{\mathrm{A}} \\
& \mathrm{~T}_{\mathrm{S}}
\end{aligned}
\] & \[
\begin{gathered}
0 \text { to }+70 \\
-40 \text { to }+85 \\
-55 \text { to }+125
\end{gathered}
\] & \[
\begin{aligned}
& { }^{\circ} \mathrm{C} \\
& { }^{\circ} \mathrm{C} \\
& { }^{\circ} \mathrm{C}
\end{aligned}
\] \\
\hline Operating Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & \[
\begin{aligned}
& -22 \text { to }-18 \\
& -20 \text { typical }
\end{aligned}
\] & Vdc \\
\hline Operating Display Voltage & \(\mathrm{V}_{\mathrm{GG}}\) & -50 & Vdc \\
\hline
\end{tabular}
*NOTE: Stresses above those listed under ABSOLUTE MAXIMUM RATINGS may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{DC CHARACTERISTICS}
\(\left(V_{D D}=-18.0\right.\) to \(-22 \mathrm{Vdc}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}\), unless otherwise noted. All voltages referenced to \(\mathrm{V}_{\mathrm{SS}}\).)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min. & Typical & Max. & Unit \\
\hline ```
10942 and 10943
    Output Anodes (Dots)
        Logic "1" ( LIOAD \(=2 \mathrm{~mA}\) )
        Logic " 0 " ( LLOAD \(=0 \mathrm{~mA}\) )
``` & \[
\begin{aligned}
& \mathrm{v}_{\mathrm{OH}} \\
& \mathrm{v}_{\mathrm{OL}}
\end{aligned}
\] & \[
\begin{aligned}
& -1.5 \\
& V_{G G} \\
& \hline
\end{aligned}
\] & & \[
\begin{gathered}
\mathrm{V}_{\mathrm{SS}} \\
0.95 \times \mathrm{V}_{\mathrm{GG}} \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& \mathrm{V} \\
& \mathrm{v}
\end{aligned}
\] \\
\hline ```
10939
    Input D0-D7, LD, SIP
        Logic "1"
        Logic "0"
    input POR
        Logic " 1 "
        Logic " 0 "
    Output SOP
        Logic " 1 "
        Logic " 0 "
    Output Digits, Cursor
        Logic "1" ( LLOAD \(=10 \mathrm{~mA}\) )
        Logic " 0 " ( \(\mathrm{l}_{\text {LOAD }}=0 \mathrm{~mA}\) )
``` & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IH}} \\
& \mathrm{~V}_{\mathrm{IL}} \\
& \mathrm{~V}_{\mathrm{IHPO}} \\
& \mathrm{~V}_{\mathrm{ILPO}} \\
& \mathrm{~V}_{\mathrm{OHSY}} \\
& \mathrm{~V}_{\mathrm{OLSY}} \\
& \mathrm{~V}_{\mathrm{OH}} \\
& \mathrm{~V}_{\mathrm{OL}}
\end{aligned}
\] & \[
\begin{aligned}
& -1.2 \\
& V_{D D} \\
& -3.0 \\
& V_{D D} \\
& -1.2 \\
& V_{D D} \\
& -1.5 \\
& V_{G G}
\end{aligned}
\] & & \[
\begin{gathered}
+0.3 \\
-4.2 \\
\\
+0.3 \\
-10.0 \\
V_{\mathrm{SS}} \\
-4.2 \\
\\
V_{\mathrm{SS}} \\
0.95 \times \mathrm{V}_{\mathrm{GG}}
\end{gathered}
\] & \[
\begin{aligned}
& \mathrm{v} \\
& \mathrm{v} \\
& \mathrm{v} \\
& \mathrm{v}
\end{aligned}
\]
\[
\begin{aligned}
& \text { v } \\
& \text { v }
\end{aligned}
\]
\[
\begin{aligned}
& \text { v } \\
& \text { v }
\end{aligned}
\] \\
\hline
\end{tabular}

Note: \(\mathrm{TA}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) (commercial) or \(-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\) (industrial), unless otherwise noted.

OPERATING CURRENTS
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multicolumn{2}{|c|}{Maximum} & Typical & \multirow[b]{2}{*}{Unit} \\
\hline & Industrial
\[
\begin{aligned}
\mathrm{TA} & =-40^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}} & =-22 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}} & =-50 \mathrm{Vdc}
\end{aligned}
\] & Commercial
\[
\begin{gathered}
\mathrm{TA}=0^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}}=-22 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}}=-50 \mathrm{Vdc}
\end{gathered}
\] & \[
\begin{gathered}
\mathrm{TA}=25^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}}=-20 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}}=-50 \mathrm{Vdc}
\end{gathered}
\] & \\
\hline \multicolumn{5}{|l|}{10942 or 10943} \\
\hline \(\mathrm{I}_{\mathrm{DD}}\) & 4.5 & 3.6 & 3.2 & mA \\
\hline \({ }_{1 \mathrm{IGG}^{1}}\) & 7.4 & 5.9 & 5.3 & mA \\
\hline \multicolumn{5}{|l|}{10939 (master)} \\
\hline \(\mathrm{I}_{\mathrm{DD}}\) & 13.6 & 10.9 & 6.0 & mA \\
\hline \(\mathrm{IGG}^{2}\) & 10 & 0.8 & 05 & mA \\
\hline \multicolumn{5}{|l|}{10939 (slave)} \\
\hline \(\mathrm{I}_{\mathrm{DD}}\) & 9.1 & 7.3 & 40 & mA \\
\hline \(\mathrm{IGG}^{2}\) & 10 & 0.8 & 0.5 & mA \\
\hline
\end{tabular}

Notes:
1 The 10942 and 10943 each have 23 driver outputs. \(I_{G G}\) is proportional to the number of drivers on. The values given are for all 23 drivers on. Divide \(\mathrm{I}_{\mathrm{GG}}\) shown by 23 to determine \(\mathrm{I}_{\mathrm{GG}}\) for one driver. Multiply \(\mathrm{I}_{\mathrm{GG}}\) by 2 to find total current requirements for all drivers on for both devices.
2 The 10939 will never have more than two drivers on at any one time; one grid driver and the cursor. The values shown are for two drivers on with \(100 \%\) duty cycle

AC CHARACTERISTICS
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min. & Typical & Max. & Unit \\
\hline Data Load (LD) On Time Off Time Commercial Industrial Cycle Time Commercial Industrial & \[
\begin{aligned}
& \mathrm{T}_{\text {Idon }} \\
& \mathrm{T}_{\text {Idoff }} \\
& \mathrm{T}_{\text {Idayc }}
\end{aligned}
\] & \[
\begin{array}{r}
1.0 \\
40.0 \\
44.5 \\
60.0 \\
66.7
\end{array}
\] & & & \[
\begin{aligned}
& \mu \mathrm{S} \\
& \mu \mathrm{~S} \\
& \mu \mathrm{~S} \\
& \mu \mathrm{~S} \\
& \mu \mathrm{~S} \\
& \mu \mathrm{~S}
\end{aligned}
\] \\
\hline \begin{tabular}{l}
SERIAL INTERFACE TIMING \\
Serial Clock (D1) \\
On Time \\
Off Time \\
Cycle Time \\
Serial Data (DO) \\
Set-up time \\
Hold Time \\
Serial Clock to LD Time \\
LD to Serial Clock
\end{tabular} & \begin{tabular}{l}
\(\mathrm{T}_{\text {scon }}\) \\
\(\mathrm{T}_{\text {scoff }}\) \\
\(\mathrm{T}_{\text {sccyc }}\) \\
\(\mathrm{T}_{\text {ssetup }}\) \\
\(\mathrm{T}_{\text {shold }}\) \\
\(\mathrm{T}_{\text {sI }}\) \\
\(T_{\text {Is }}\)
\end{tabular} & \[
\begin{gathered}
1.0 \\
1.0 \\
2.0 \\
400 \\
400 \\
1.0 \\
1.0
\end{gathered}
\] & & 20.0 & \[
\mu \mathrm{S}
\]
\[
\mu \mathrm{S}
\]
\[
\mu \mathrm{s}
\]
\[
\begin{aligned}
& \mathrm{ns} \\
& \mathrm{~ns} \\
& \mu \mathrm{~s} \\
& \mu \mathrm{~S}
\end{aligned}
\] \\
\hline \begin{tabular}{l}
PARALLEL INTERFACE TIMING \\
Parallel Data (D0-D7) \\
Set-up Time Hold Time
\end{tabular} & \[
\begin{aligned}
& T_{\text {psetup }} \\
& T_{\text {phold }}
\end{aligned}
\] & \[
\begin{array}{r}
0 \\
200
\end{array}
\] & & & \[
\begin{aligned}
& \mathrm{ns} \\
& \mathrm{~ns}
\end{aligned}
\] \\
\hline
\end{tabular}

TIMING WAVEFORMS


Serial Interface Timing Waveforms


Parallel Interface Timing Waveforms

\section*{FUNCTIONAL DESCRIPTION}

Once the display buffer has been loaded from the host processor, the 10939, 10942, and 10943 system generates all timing signals required to control the display.

Input data is loaded into the Display Data Buffer as a series of 8 -bit words via the Serial or Parallel Data Input channel on the 10939. Internal timing and control logic synchronize the digit output signals with the Serial Data and Load signals to the 10942/10943 to provide the proper timing for the multiplexing operation. Two \(128 \times 23\) bit PLAs, one in the 10942 and the other in the 10943, decode the full 96 -character ASCII set plus 32 special characters.

The parallel data input mode is implemented by toggling any of data lines D2-D7 after POR has gone low. Once the parallel data load mode has been implemented, a power-on reset procedure must be performed to return to serial data load mode. Parallel data transfer is accomplished by putting the command or display data on the data lines, then pulsing the LD line. The load cycle time must be at least \(60 \mu \mathrm{~s}\) with the LD line set high for at least one \(\mu \mathrm{s}\) and held low for at least \(40 \mu \mathrm{~s}\).

The serial data input mode is implemented during the poweron reset procedure. In those systems using serial mode, ports D2-D7 should be tied low to prevent the inadvertent implementation of the parallel load mode. Serial data bytes are shifted into a data buffer MSB first on line D0 using line D1 as the serial clock. The last eight bits clocked in are latched into the display controller by a pulse on the LD line. The cycle time for each data bit is \(2 \mu \mathrm{~S}\) and the load time for each byte is \(60 \mu \mathrm{~S}\).

Input data may be Control or Display data. The following paragraphs describe the format and functions of these control and display data words.

\section*{CONTROL DATA WORDS}

Control data words are used to select the operating parameters of the display controller. They must be preceded by a control prefix word (0000 0001, hexadecimal 01) to be distinguished from display data words.

\section*{Buffer Pointer Control}

The Buffer Pointer Control code sets the Display Data Buffer pointer. The lower 5 bits of the code are loaded into the buffer pointer (see Table 2).

\section*{Digit Counter Control}

The Digit Counter Control code defines the number of character positions (grids) to be controlled. This code is normally used only during initialization routines, but it may also be used in conjunction with the Duty Cycle Control code to extend the range of brightness control (see Table 3).

\section*{Duty Cycle Control}

The Duty Cycle Control code is used to turn the display on and off, to adjust display brightness, or to modify display timing. The
time slot for each character is 16,32 , or 64 cycles as selected by the Digit Time Control codes (see Table 1). The segment and digit drivers for each character are on for a maximum of 13, 29, or 61 cycles with a 3 cycle inter-digit off-time. The lower 6 bits of the Duty Cycle Control code are loaded into the Duty Cycle Register. Resultant duty cycles are shown in Table 4.

Table 1. Control Word Assignments
\begin{tabular}{|c|l|}
\hline Hex Value & \multicolumn{1}{|c|}{ Function } \\
\hline 00 & Not Used \\
01 & Load 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) \\
\(0 A\) & Enable Inverse Mode (data words with MSB = 1 will \\
& be "inversed") \\
\(0 B\) & Not used \\
\(0 C\) & Not used \\
\(0 D\) & Not used \\
\(0 E\) & Start Display Refresh Cycle (use only once after \\
& reset) \\
\(0 F\) & Not used \\
\(10-3 F\) & Not used \\
\(40-7 F\) & Load Duty Cycle Register \\
\(80-9 F\) & Load Digit Counter (80 = 32, 81 = 1, 82 = 2, etc.) \\
A0-BF & Not used \\
C0-DF & Load Buffer Pointer Register with lower 5 bits \\
E0-FF & Not used
\end{tabular}

Table 2. Buffer Pointer Control Codes
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
Code \\
Value
\end{tabular} & \begin{tabular}{c} 
Pointer \\
Value
\end{tabular} & \begin{tabular}{c} 
Character \\
Position
\end{tabular} \\
\hline C0 & 00 & 0 \\
C1 & 01 & 1 \\
C2 & 02 & 2 \\
C3 & 03 & 3 \\
C4 & 04 & 4 \\
C5 63 & 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 & OD & 13 \\
CF & \(0 E\) & 14 \\
D0 & \(0 F\) & 15 \\
D1 & 10 & 16 \\
D2 & 11 & 17 \\
D3 & 12 & 18 \\
Note: Do not use character positions \(20-31\) (Codes D4-DF) \\
\hline
\end{tabular}

Table 3. Digit Counter Control Codes
\begin{tabular}{|c|c|c|}
\hline Code & Digit Counter Value & No. of Grids Controlled \\
\hline 80 & 00 & 32 \\
\hline 81 & 01 & 1 \\
\hline 82 & 02 & 2 \\
\hline 83 & 03 & 3 \\
\hline 84 & 04 & 4 \\
\hline 85 & 05 & 5 \\
\hline 86 & 06 & 6 \\
\hline 87 & 07 & 7 \\
\hline 88 & 08 & 8 \\
\hline 89 & 09 & 9 \\
\hline 8A & OA & 10 \\
\hline 8B & OB & 11 \\
\hline 8 C & 0 C & 12 \\
\hline 8D & OD & 13 \\
\hline 8E & OE & 14 \\
\hline 8F & OF & 15 \\
\hline 90 & 10 & 16 \\
\hline 91 & 11 & 17 \\
\hline 92 & 12 & 18 \\
\hline 93 & 13 & 19 \\
\hline 94 & 14 & 20 \\
\hline 95 & 15 & 21 \\
\hline 96 & 16 & 22 \\
\hline 97 & 17 & 23 \\
\hline 98 & 18 & 24 \\
\hline 99 & 19 & 25 \\
\hline 9A & 1A & 26 \\
\hline 9B & 1B & 27 \\
\hline 9 C & 1 C & 28 \\
\hline 9D & 1D & 29 \\
\hline 9E & 1E & 30 \\
\hline 9F & 1F & 31 \\
\hline
\end{tabular}

\section*{Digit Time Select}

The Digit Time Select code sets the total time for each character during the refresh cycle. Three values can be set using the three codes shown in Table 1. The default value set at power-on is 64 cycles per grid. For displays with 40 or more characters,or under conditions where the display can be subjected to quick movements during viewing (e.g. portable or vehicle-mounted applications), it may be necessary to increase the refresh rate by selecting 16 or 32 cycles per grid with the appropriate control code.

\section*{Display Mode Select}

Each ASCII character is represented by the lower seven bits of the 8 -bit value loaded into the 10939. The eighth (most significant) bit is used to turn the cursor (see Cursor Control) on in Normal display mode. If either Blank or Inverse mode is selected, a " 0 " in this bit causes a normal character display mode, while a " 1 " selects either Blank or Inverse mode, depending on which mode is enabled. Three control codes are provided (see Table 1) to Enable Blank mode, Enable Inverse mode, or Enable Normal display mode.

In the Blank mode, any character with the MSB = " 1 " will be blanked. In the Inverse mode, it will be displayed with all segment driver outputs inverted. On video displays, this is referred to as "Inverse Video" format. These controls allow individual

Table 4. Duty Cycle Control Codes
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Code} & \multicolumn{2}{|l|}{Digit Time \(=16\)} & \multicolumn{2}{|l|}{Digit Time \(=32\)} & \multicolumn{2}{|l|}{Digit Time \(=\mathbf{6 4}\)} \\
\hline & On & Off & On & Off & On & Off \\
\hline 40 & - & 16 & - & 32 & - & 64 \\
\hline 41 & - & 16 & - & 32 & - & 64 \\
\hline 42 & - & 16 & - & 32 & - & 64 \\
\hline 43 & 1 & 15 & 1 & 31 & 1 & 63 \\
\hline 44 & 2 & 14 & 2 & 30 & 2 & 62 \\
\hline 45 & 3 & 13 & 3 & 29 & 3 & 61 \\
\hline 46 & 4 & 12 & 4 & 28 & 4 & 60 \\
\hline 47 & 5 & 11 & 5 & 27 & 5 & 59 \\
\hline 48 & 6 & 10 & 6 & 26 & 6 & 58 \\
\hline 49 & 7 & 9 & 7 & 26 & 7 & 57 \\
\hline 4A & 8 & 8 & 8 & 24 & 8 & 56 \\
\hline 4B & 9 & 7 & 9 & 23 & 9 & 55 \\
\hline 4C & 10 & 6 & 10 & 22 & 10 & 54 \\
\hline 4D & 11 & 5 & 11 & 21 & 11 & 53 \\
\hline 4E & 12 & 4 & 12 & 20 & 12 & 52 \\
\hline 4F & 13 & 3 & 13 & 19 & 13 & 51 \\
\hline 50 & 13 & 3 & 14 & 18 & 14 & 50 \\
\hline 51 & 13 & 3 & 15 & 17 & 15 & 49 \\
\hline 52 & 13 & 3 & 16 & 16 & 16 & 48 \\
\hline 53 & 13 & 3 & 17 & 15 & 17 & 47 \\
\hline . & . & , & - & . & . & . \\
\hline . & & & & & & \\
\hline 5B & 13 & 3 & 25 & 7 & 25 & 39 \\
\hline 5C & 13 & 3 & 26 & 6 & 26 & 38 \\
\hline 5D & 13 & 3 & 27 & 5 & 27 & 37 \\
\hline 5E & 13 & 3 & 28 & 4 & 28 & 36 \\
\hline 5F & 13 & 3 & 29 & 3 & 29 & 35 \\
\hline 60 & 13 & 3 & 29 & 3 & 30 & 34 \\
\hline 61 & 13 & 3 & 29 & 3 & 31 & 33 \\
\hline 62 & 13 & 3 & 29 & 3 & 32 & 32 \\
\hline - & & & & & . & . \\
\hline - & & . & & & . & - \\
\hline 7 C & 13 & 3 & 29 & 3 & 58 & 6 \\
\hline 7D & 13 & 3 & 29 & 3 & 59 & 5 \\
\hline 7E & 13 & 3 & 29 & 3 & 60 & 4 \\
\hline 7F & 13 & 3 & 29 & 3 & 61 & 3 \\
\hline
\end{tabular}
characters or groups of characters to be blinked or blanked by simply changing the mode without changing the data in the Display Buffer.

\section*{Cursor Control}

The data byte control (MSB 8), besides selecting Blank, Inverse, or Normal mode, also controls the cursor output which is enabled on all characters with the MSB equal to one. Therefore, when the Normal mode is enabled and the MSB of the data byte is set to a one, the normal character is displayed with the cursor on. When the Blank mode is enabled and the MSB is set to a one, the character is blanked but the cursor is on. If Inverse mode is enabled and the MSB is set to a one, the inverse character is displayed, and the cursor is on but not inversed.

\section*{Start Refresh}

At power on, the 10939 is held in an internal halt mode. The normal display refresh sequence starts upon receipt of a Start Refresh control code. This is particularly useful for synchronizing systems using more than one 10939. Only the Master 10939 in a multi-chip system will recognize the Start Refresh code. The Master starts the Slave(s) at the appropriate time, using the SOP signal.

\section*{INPUT DISPLAY DATA WORDS}

Display data words are loaded as 8 -bit codes. The eighth (most significant) bit is a dual purpose bit. This bit specifies normal (0) or blank/inverse (1) display mode, depending on the blank/inverse mode selection (see control data words 09 and OA in Table 1). It also controls the cursor output from the 10939; on (1) or off (0). Note, that this bit always controls the cursor no matter what display mode is selected.

Twenty display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer automatically increments after each data word is stored in the buffer. To select a character position to be loaded out of sequence, use the Buffer Pointer Control code command. The Buffer Pointer will automatically reset to character position 0 when its value is equal to the programmed Digit Counter.

\section*{DIGIT GRID DRIVERS (STR00-STR19) PLUS CURSOR}

The 20 Digit Drivers select each of the display character positions sequentially during a refresh scan. Display dots are illuminated when both the Digit Drivers and Anode (Dot) Drivers for a particular character are energized simultaneously. The Cursor output is generated by the 10939, but its timing characteristics are identical to the 46 segment outputs generated by the 10942 and the 10943.

\section*{ANODE (DOT) DRIVERS (SG01-SG23)}

A total of 46 Dot Drivers are provided by the 10942 and the 10943. The output states for each ASCII charcter pattern are internally decoded from the 8 -bit characters received from the 10939 by means of two \(128 \times 23\)-bit PLAs, one in the 10942 and the other in the 10943. Figure 1 shows the dot matrix drivers (SG01-SG23) as they relate to the 10942 and 10943. Data codes and the corresponding character patterns are also shown in Figure 1.

\section*{POWER-ON RESET}

The Power-On Reset (POR) initializes the internal circuits of the 10939. This is normally accomplished when power ( \(V_{D D}\) ) is applied. The following conditions are established by the application of POR:
a. The Grid Drivers (STR00-STR19) on the 10939 are in the off state.
b. The Anode Drivers, SG01-SG23 on the 10942 and SG01-SG23 on the 10943, are in the off state.
c. The Duty Cycle is set to 0 .
d. The Digit Counter is set to 32.
e. The Buffer Pointer is set to 0 .
f. The Digit time is set to 64 .
g. The Normal display mode is set.
h. DATA-LOAD is set to high impedance state.
i. SCLK-DIS is set to \(\mathrm{V}_{\mathrm{OL}}\) to disable the anode drivers in the 10942 and 10943.
j. SOP is set to \(V_{O L}\) to disable the sync pulse.

NOTE:
1. When th POR signal is removed, SCLK-DIS is set to the high impedance state.
2. During the initial rise time of \(V_{D D}\) at power turn-on, the magnitude of \(\mathrm{V}_{\mathrm{GG}}\) should not exceed the magnitude of \(\mathrm{V}_{\mathrm{DD}}\).

\section*{TYPICAL SYSTEM HOOKUPS}

Figure 2 shows a 10939, 10942, and a 10943 in a parallel interface with the host system driving a 20 -character display. Figure 3 shows a 10939, 10942, and a 10943 in a serial interface with the host system driving a 20 -character display. Figure 4 shows two 10939s, a 10942, and a 10943 in a parallel interface with the host system driving a 40-character display.
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline  &  &  &  &  &  &  &  &  &  &  &  &  &  &  &  \\
\hline 00 & & 01 &  & 02 &  & 03 &  & 04 &  & 05 &  & 06 &  & 07 & \(\because \because\) \\
\hline 08 &  & 09 & \(\vdots \vdots\) & OA &  & OB &  & OC &  & OD & \(\%_{.0}\) : & OE &  & OF & ! \\
\hline 10 &  & 11 &  & 12 &  & 13 &  & 14 &  & 15 &  & 16 &  & 17 & \(\square\)
\(\because \because\)
\(\square\) \\
\hline 18 &  & 19 & \(\vdots \vdots\) & 1A &  & 1B &  & 1 C &  & 1D &  & 1 E & \(\cdots \cdots\) & 1F &  \\
\hline 20 & & 21 &  & 22 & - & 23 &  & 24 &  & 25 &  & 26 &  & 27 & ! : \\
\hline 28 &  & 29 &  & 2 A &  & 2B & -! ! - & 2 C & : & 2D & -•••• & 2 E & : : & 2 F &  \\
\hline 30 & \(\vdots \vdots\) & 31 &  & 32 &  & 33 &  & 34 &  & 35 &  & 36 &  & 37 &  \\
\hline 38 &  & 39 &  & 3 A & : : & 3B & : \(:\) & 3 C &  & 3D & ...... & 3E &  & 3 F & \(\cdots:\) \\
\hline 40 & : \(\quad \because\) & 41 &  & 42 &  & 43 &  & &  & 45 & : \(\quad \cdots\)
\(\vdots \cdots\)
\(\vdots \cdots .\). & 46 & : \({ }^{\text {® }}\) & 47 &  \\
\hline 48 & \(\vdots\) ! & 49 &  & 4A & & 4B & \(\vdots \vdots\) & 4 C & ! & 4D &  & 4E & ! •• & 4F & \(\vdots^{\bullet \cdots} \vdots\) \\
\hline 50 &  & 51 & \(\cdots\) & 52 &  & 53 &  & 54 &  & 55 & ¢ \(\quad \begin{array}{r}\text { ¢ } \\ \vdots\end{array}\) & 56 &  & 57 & ¢ \begin{tabular}{rr} 
\\
\(\vdots\) \\
\(\vdots\) \\
\hline
\end{tabular} \\
\hline 58 &  & 59 &  & 5A &  & 5B &  & 5 C &  & 5D & - & 5E &  & 5F & - ! ! \\
\hline 60 & - & 61 & -••: & 62 &  & 63 &  & 64 & ¢ \(\quad \begin{array}{r}\text { ¢ }\end{array}\) & 65 & ㅂ.: & 66 &  & 67 & : \(\cdot \ldots\) \\
\hline 68 &  & 69 &  & 6A &  & 6B &  & 6C &  & 6D & \(\vdots^{\bullet} \vdots^{\bullet}!\) & 6E &  & 6F &  \\
\hline 70 &  & 71 & : \(\begin{array}{r}\text {. }\end{array}\) & 72 &  & 73 & \(\cdots\) & 74 &  & 75 & \(\vdots!\) & 76 & !.. & 77 & \(\vdots:\) \\
\hline 78 &  & 79 & ! & 7A &  & 7B &  & 7C & ! & 7D &  & 7E & : \(:\) & 7F &  \\
\hline
\end{tabular}

Segments Driven By 10942


Segments Driven By 10943

Figure 1. \(5 \times 12\) Dot Matrix PLA Patterns and Driver Assignments


Figure 2. Typical Display System with Parallel Interface to Host System


Figure 3. Typical Display System with Serial Interface to Host System


Figure 4. Typical Display System with Parallel Interface to Host and Two 10939 Devices

\section*{10941 AND 10939 ALPHANUMERIC AND BARGRAPH DISPLAY CONTROLLER}

\section*{DESCRIPTION}

The Rockwell 10939 and 10941 Alphanumeric and Bargraph Display Controller is a two-chip MOS/LSI general purpose display controller system designed to interface with bargraph and segmented displays (vacuum-fluorescent or LED).

The two-chip set will drive displays with up to 16 segments (plus decimal point and comma tail) and up to \(\mathbf{2 0}\) grids (characters) plus a cursor. The chips can be cascaded to drive larger displays of 80 characters. Segment decoding for ASCII characters and bargraph patterns is accomplished through an internal PLA.

ORDERING INFORMATION
\begin{tabular}{|l|l|r|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range \(\left({ }^{\circ} \mathrm{C}\right)\)
\end{tabular} \\
\hline 10941 P & Plastic & 0 to +70 \\
10941 PE & Plastic & -40 to +85 \\
10939 P & Plastic & 0 to +70 \\
10939 PE & Plastic & -40 to +85 \\
\hline
\end{tabular}

\section*{FEATURES}
- 20-character display driver cascadable to 80 characters
- Direct drive capability for vacuum-fluorescent displays
- \(128 \times 18\) PLA provides segment decoding for ASCII characters (all caps only) and bargraph patterns
- Serial or parallel data input for 8 -bit display and control characters
- Brightness, refresh rate, and display mode controls
- Separate cursor driver output
- 10939-40-pin DIP package
- 10941-24-pin DIP package


Block Diagram of 10941 and 10939

\section*{INTERFACE DESCRIPTION}
\begin{tabular}{|l|c|l|}
\multicolumn{2}{c|}{10941 Pin Functions } \\
\hline \multicolumn{1}{c|}{ Signal Name } & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline V \(_{\text {SS }}\) & 2 & Power and signal reference \\
SG01-SG16 & \(6-15,17-22\) & Segment driver outputs \\
SCLK-DIS & 23 & Serial data shift \\
DATA-LOAD & 24 & Serial data output/latch control \\
PNT & 4 & Decimal Point driver output \\
TAIL & 5 & Comma Tail driver output \\
\(V_{\text {DD }}\) & 1 & DC Power \\
\(V_{G G}\) & 16 & Display voltage \\
\hline
\end{tabular}


10941 Pin Configuration

\section*{SPECIFICATIONS}

ABSOLUTE MAXIMUM RATINGS:*
Voltages are referenced to \(\mathrm{V}_{\mathrm{SS}}\)
\begin{tabular}{|l|c|l|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & \multicolumn{1}{|c|}{ Value } & Unit \\
\hline Operating Temperature & & & \\
Commercial & & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
Industrial & TC & -40 to +85 & \({ }^{\circ} \mathrm{C}\) \\
Storage Temperature & TI & -55 to +125 & \({ }^{\circ} \mathrm{C}\) \\
\hline Operatıng Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & -22 to -18 & Vdc \\
& & -20 (typical) & \\
\hline Operating Display Voltage & \(\mathrm{V}_{\mathrm{GG}}\) & -50 & Vdc \\
\hline
\end{tabular}

\section*{DC CHARACTERISTICS}

All voltages referenced to \(V_{S S}\)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max & Unit \\
\hline ```
10941
    Output Segments
        Logic "1" (I load = 2 mA)
        Logic "1" (l'LOAD = 0 mA)
``` & \[
\begin{aligned}
& \mathrm{v}_{\mathrm{OH}} \\
& \mathrm{v}_{\mathrm{OL}}
\end{aligned}
\] & \[
\begin{aligned}
& -1.5 \\
& \mathrm{~V}_{\mathrm{GG}}
\end{aligned}
\] & & \[
\stackrel{V_{S S}}{0.95} \times \mathrm{V}_{G G}
\] & v \\
\hline ```
1 0 9 3 9
    Input DO-D7, LD, SIP
        Logic "1"
        Logic "0"'
``` & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IH}} \\
& \mathrm{~V}_{\mathrm{IL}}
\end{aligned}
\] & \[
\begin{aligned}
& -1.2 \\
& V_{D D}
\end{aligned}
\] & & \[
\begin{aligned}
& +03 \\
& -4.2
\end{aligned}
\] & v \\
\hline \begin{tabular}{l}
Input POR \\
Logic " 1 " \\
Logic " 0 "
\end{tabular} & \[
\begin{aligned}
& \mathrm{V}_{\text {IHPO }} \\
& \mathrm{V}_{\text {ILPO }}
\end{aligned}
\] & \[
\begin{aligned}
& -3.0 \\
& \mathrm{~V}_{\mathrm{DD}}
\end{aligned}
\] & & \[
\begin{aligned}
& +0.3 \\
& -10.0
\end{aligned}
\] & \[
\begin{aligned}
& \text { v } \\
& \text { v }
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { Output SOP } \\
& \text { Logic " } 1 \text { ", } \\
& \text { Logic " } 0 \text { " }
\end{aligned}
\] & \begin{tabular}{l}
\(V_{\text {OHSY }}\) \\
\(V_{\text {oLsy }}\)
\end{tabular} & \[
\begin{aligned}
& -1.2 \\
& V_{D D}
\end{aligned}
\] & & \[
\begin{gathered}
V_{\mathrm{SS}} \\
-4.2 \\
\hline
\end{gathered}
\] & \[
\begin{aligned}
& V \\
& v
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { Output Digits, Cursor } \\
& \text { Logic " } 1 \text { " }\left(l_{\text {load }}=10 \mathrm{~mA}\right) \\
& \text { Logic " } 0 \text { " ( }\left(l_{\text {load }}=0 \mathrm{~mA}\right)
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{OH}} \\
& \mathrm{~V}_{\mathrm{OL}}
\end{aligned}
\] & \[
\begin{aligned}
& -1.5 \\
& \mathrm{~V}_{\mathrm{GG}} \\
& \hline
\end{aligned}
\] & & \[
\begin{gathered}
V_{S S} \\
0.95 \times V_{G G}
\end{gathered}
\] & \[
\begin{aligned}
& \text { v } \\
& \text { v }
\end{aligned}
\] \\
\hline
\end{tabular}

\section*{OPERATING CURRENTS}
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Notes} & \multicolumn{2}{|c|}{Maximum} & Typical & \multirow[b]{2}{*}{Unit} \\
\hline & & Industrial
\[
\begin{aligned}
\mathrm{TA} & =-40^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}} & =-22 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}} & =-50 \mathrm{Vdc}
\end{aligned}
\] & Commercial
\[
\begin{gathered}
\mathrm{TA}=0^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}}=-22 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}}=-50 \mathrm{Vdc}
\end{gathered}
\] & \[
\begin{aligned}
T A & =25^{\circ} \mathrm{C} \\
\mathrm{~V}_{\mathrm{DD}} & =-20 \mathrm{Vdc} \\
\mathrm{~V}_{\mathrm{GG}} & =-50 \mathrm{Vdc}
\end{aligned}
\] & \\
\hline \[
\begin{gathered}
10941 \\
I_{D D} \\
I_{G G}
\end{gathered}
\] & 1 & \[
\begin{aligned}
& 4.5 \\
& 5.7
\end{aligned}
\] & \[
\begin{aligned}
& 3.6 \\
& 4.6
\end{aligned}
\] & \[
\begin{aligned}
& 32 \\
& 29
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{mA} \\
& \mathrm{~mA}
\end{aligned}
\] \\
\hline ```
10939 (master)
    IDD
    IGG
``` & 2 & \[
\begin{array}{r}
136 \\
1.0
\end{array}
\] & \[
\begin{array}{r}
10.9 \\
0.8
\end{array}
\] & \[
\begin{aligned}
& 60 \\
& 05
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{mA} \\
& \mathrm{~mA}
\end{aligned}
\] \\
\hline ```
10939 (slave)
    IDD
    IGG
``` & 2 & \[
\begin{aligned}
& 9.1 \\
& 1.0
\end{aligned}
\] & \[
\begin{array}{r}
7.3 \\
0.8 \\
\hline
\end{array}
\] & \[
\begin{aligned}
& 40 \\
& 0.5 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{mA} \\
& \mathrm{~mA}
\end{aligned}
\] \\
\hline
\end{tabular}

\section*{Notes:}
1. The 10941 has 18 internal drivers which are brought out \(I_{G G}\) is proportional to the number of drivers on. The values given are for all 18 drivers on. Divide \(I_{G G}\) shown by 18 to determine \(I_{G G}\) 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.

AC CHARACTERISTICS
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max & Unit \\
\hline \begin{tabular}{l}
GENERAL INTERFACE TIMING \\
Data Load (LD) \\
On Time \\
Off time Commercial Industrial \\
Cycle Time Commerical Industrial
\end{tabular} & \begin{tabular}{l}
\(T_{\text {idon }}\) \\
\(T_{\text {Idoff }}\) \\
\(T_{\text {Idcyc }}\)
\end{tabular} & \begin{tabular}{l}
1.0 \\
40.0 \\
44.5 \\
60.0 \\
66.7
\end{tabular} & & & \begin{tabular}{l}
\[
\because \mu \mathbf{S}
\] \\
\(\mu \mathrm{S}\) \(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \(\mu \mathrm{S}\)
\end{tabular} \\
\hline \begin{tabular}{l}
SERIAL INTERFACE TIMING \\
Serial Clock (D1) \\
On Time \\
Off Time Cycle Time \\
Serial Data (D0) \\
Set-up Time \\
Hold Time \\
Serial Clock to LD Time \\
LD to Serial Clock
\end{tabular} & \begin{tabular}{l}
\(T_{\text {scon }}\) \\
\(T_{\text {scoff }}\) \\
\(\mathrm{T}_{\text {sccyc }}\) \\
\(T_{\text {ssetup }}\) \\
\(T_{\text {shold }}\) \\
\(T_{s}\) \\
\(T_{\text {Is }}\)
\end{tabular} & \[
\begin{array}{r}
10 \\
1.0 \\
20 \\
400 \\
400 \\
10 \\
1.0
\end{array}
\] & & 20.0 & \begin{tabular}{l}
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
ns \\
ns \\
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\)
\end{tabular} \\
\hline \begin{tabular}{l}
PARALLEL INTERFACE TIMING Parallel Data (D0-D7) \\
Set-up Time Hold Time
\end{tabular} & \begin{tabular}{l}
\(T_{\text {psetup }}\) \\
\(T_{\text {phold }}\)
\end{tabular} & \[
\begin{array}{r}
0 \\
200
\end{array}
\] & & & \[
\begin{aligned}
& \text { ns } \\
& \text { ns }
\end{aligned}
\] \\
\hline
\end{tabular}

\section*{TIMING WAVEFORMS}


Serial Interface Timing Waveforms


Parallel Interface Timing Waveforms

\section*{FUNCTIONAL DESCRIPTION}

Once the display buffer has been loaded from the host processor, the 10941/10939 system generates all timing signals required to control the display.

Input data is loaded into the Display Data Buffer as a series of 8-bit words via the Serial or Parallel Data Input channel on the 10939. Internal timing and control logic synchronize the digit output signals with the Serial Data and Load signals to the 10941 to provide the proper timing for the multiplexing operation. A \(128 \times 18\) bit PLA is provided for decoding the character set and bargraph codes.

The parallel data input mode is implemented by toggling any of data lines D2-D7 after POR has gone low. Once the parallel data load mode has been implemented, a power-on reset procedure must be performed to return to serial data load mode. Parallel data transfer is accomplished by putting the command or display data on the data lines, then pulsing the LD line. The load cycle time must be at least \(60 \mu \mathrm{~s}\) with the LD line set high for at least one \(\mu \mathrm{s}\) and held low for at least \(40 \mu \mathrm{~s}\).

The serial data input mode is implemented during the poweron reset procedure. In those systems using serial mode, ports D2-D7 should be tied low to prevent the inadvertent implementation of the parallel load mode. Serial data bytes are shifted into a data buffer MSB first on line D0 using line D1 as the serial clock. The last eight bits clocked in are latched into the display controller by a pulse on the LD line. The cycle time for each data bit is \(2 \mu \mathrm{~S}\) and the load time for each byte is \(60 \mu \mathrm{~s}\).

Input data may be Control or Display data. The following paragraphs describe the format and functions of these control and display data words.

\section*{CONTROL DATA WORDS}

Control data words are used to select the operating parameters of the display controller. They must be preceded by a Control Prefix word ( 0000 0001, hexadecimal 01) to be distinguished from Display Data words. Table 1. shows the Control Word code assignments and functions.

\section*{Buffer Pointer Control}

The Buffer Pointer Control code sets the Display Data Buffer pointer. The lower 5 bits of the code are loaded into the buffer pointer (see Table 2).

Table 1. Control Word Assignments
\begin{tabular}{|c|c|}
\hline Hex Value & Function \\
\hline 00 & Not used \\
\hline 01 & Load 01 into Data Buffer \\
\hline 02 & Not used \\
\hline 03 & Not used \\
\hline 04 & Not used \\
\hline 05 & Set digit time to 16 cycles per grid \\
\hline 06 & Set digit time to 32 cycles per grid \\
\hline 07 & Set digit time to 64 cycles per grid \\
\hline 08 & Enable Normal Display Mode (MSB in data words is cursor control only) \\
\hline 09 & Enable Blank Mode (datal words with MSB \(=1\) will be blanked and cursor will be on) \\
\hline OA & Enable Inverse Mode (data words with MSB = 1 will be "inversed" and cursor will be on) \\
\hline OB & Not used \\
\hline \({ }^{0} \mathrm{C}\) & Not used \\
\hline OD & Not used \\
\hline OE & Start Display Refresh Cycle (use only once after reset) \\
\hline OF & Not used \\
\hline 10-3F & Not used \\
\hline 40-7F & Load Duty Cycle Register with lower 6 bits (0-63) \\
\hline 80-9F & Load Digit Counter ( \(80=32,81=1,82=2\), etc.) \\
\hline A0-BF & Not used \\
\hline CO-DF & Load Buffer Pointer Register with lower 5 bits \\
\hline EO-FF & Not used \\
\hline
\end{tabular}

Table 2. Buffer Pointer Control Codes
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
Code \\
Value
\end{tabular} & \begin{tabular}{c} 
Pointer \\
Value
\end{tabular} & \begin{tabular}{c} 
Character \\
Position
\end{tabular} \\
\hline C0 & 00 & 0 \\
C1 & 01 & 1 \\
C2 & 02 & 2 \\
C3 & 03 & 3 \\
C4 & 04 & 4 \\
C5 & 05 & 5 \\
C6 & 06 & 6 \\
C7 & 07 & 7 \\
C8 & 08 & 8 \\
C9 & 09 & 9 \\
CA & \(0 A\) & 10 \\
CB & \(0 B\) & 11 \\
CC & \(0 C\) & 12 \\
CD & \(0 D\) & 13 \\
CE & \(0 E\) & 14 \\
CF & \(0 F\) & 16 \\
D0 & 10 & 17 \\
D1 & 11 & 18 \\
D2 & 12 & 19 \\
D3 & 13 & \\
Note:
\end{tabular}

\section*{Digit Counter Control}

The Digit Counter Control code defines the number of character positions (grids) to be controlled. This code is normally used only during initialization routines, but it may also be used in conjunction with the Load Duty Cycle control code to extend the range of brightness control (see Table 3).

\section*{Duty Cycle Control}

The Duty Cycle Control code turns the display on and off, ad;justs display brightness, or modifies display timing. The time siot for each character is 16,32 , or 64 cycles as selected by the Digit Time Control 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 cycle inter-digit off-time. The lower 6 bits of the Duty Cycle Control code are loaded into the Duty Cycle Register. Resultant duty cycles are shown in Table 4.

\section*{Digit Time Select}

The Digit Time Select code sets the total time for each character during the refresh cycle. Three values can be set using the three codes shown in Table 1. The default value set at power-on is 64 cycles per grid. For displays with 40 or more character, or under conditions where the display can be subjected to quick movements during viewing (e.g. portable or vehicle-mounted applications), it may be necessary to increase the refresh rate by selecting 16 or 32 cycles per grid with the appropriate control code.

Table 3. Digit Counter Control Codes
\begin{tabular}{|c|c|c|c|}
\hline Code & \multicolumn{2}{|l|}{\begin{tabular}{l}
Digit \\
Counter Value
\end{tabular}} & No. of Grids Controlled \\
\hline 80 & 00 & ... & 32 \\
\hline 81 & 01 & & 1 \\
\hline 82 & 02 & & 2 \\
\hline 83 . & 03 & & 3 \\
\hline 84 & 04 & & 4 \\
\hline 85 & 05 & & 5 \\
\hline 86 & 06 & & 6 \\
\hline 87 & 07 & & 7 \\
\hline 88 & 08 & & 8 \\
\hline 89 & 09 & & 9 \\
\hline 8A & OA & & 10 \\
\hline 8B & OB & & 11 \\
\hline 8 C & OC & & 12 \\
\hline 8D & OD & & 13 \\
\hline 8E & OE & & 14 \\
\hline 8F & OF & & 15 \\
\hline 90 & 10 & & 16 \\
\hline 91 & 11 & & 17 \\
\hline 92 & 12 & & 18 \\
\hline 93 & 13 & & 19 \\
\hline 94 & 14 & & 20 \\
\hline 95 & 15 & & 21 \\
\hline 96 & - 16 & & 22 \\
\hline 97 & 17 & & 23 \\
\hline 98 & 18 & & 24 \\
\hline 99 & 19 & & 25 \\
\hline 9A & 1A & & 26 \\
\hline 9B & 1B & & 27 \\
\hline 9 C & 1 C & & 28 \\
\hline 9D & 1D & & 29 \\
\hline 9E & 1E & & 30 \\
\hline 9F & 1F & & 31 \\
\hline
\end{tabular}

\section*{Display Mode Select}

Each ASCII character is represented by the lower seven bits of the 8 -bit value loaded into the 10939. The eighth (most

Table 4. Duty Cycle Control Codes
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Code} & \multicolumn{2}{|l|}{Digit Time \(=16\)} & \multicolumn{2}{|l|}{Digit Time \(=32\)} & \multicolumn{2}{|l|}{Digit Time \(=64\)} \\
\hline & On & Off & On & Off & On & Off \\
\hline 40 & - & 16 & - & 32 & - & 64 \\
\hline 41 & - & 16 & - & 32 & - & 64 \\
\hline 42 & - & 16 & - & 32 & - & 64 \\
\hline 43 & - 1 & 15 & 1 & 31 & 1 & 63 \\
\hline 44 & 2 & - 14 & 2 & 30 & 2 & 62 \\
\hline . 45 . & 3 & 13. & 3 & 29 & 3 & 61 \\
\hline 46 & 4 & 12 & 4 & 28 & 4 & 60 \\
\hline 47 & 5 & 11 & 5 & 27 & 5 & 59 \\
\hline 48 & 6 & 10 & 6 & 26 & 6 & 58 \\
\hline 49 & 7 & 9 & 7 & 25 & 7 & 57 \\
\hline 4A & 8 & 8 & 8 & 24 & 8 & 56 \\
\hline 4B & 9 & 7 & 9 & 23 & 9 & 55 \\
\hline 4 C & 10 & 6 & 10 & 22 & 10 & 54 \\
\hline 4D & 11 & 5 & 11* & 21 & 11 & 53 \\
\hline 4E & 12 & 4 & 12 & 20 & 12 & 52 \\
\hline 4F & 13 & 3 & 13 & . 19 & 13 & 51 \\
\hline 50 & 13 & 3 & 14 & 18 & 14 & 50 \\
\hline 51 & 13 & 3 & 15 & 17 & 15 & 49 \\
\hline 52 & 13 & 3 & 16 & 16 & 16 & 48 \\
\hline 53 & 13 & 3 & 17 & 15 & 17 & 47 \\
\hline & & & & - & & \\
\hline 5B & 13 & 3 & 25 & 7 & 25 & 39 \\
\hline 5C & 13 & 3. & 26 & 6 & 26 & 38 \\
\hline 5D & 13 & 3 & 27 & 5 & 27 & 37 \\
\hline 5E & 13 & 3 & 28 & 4 & 28 & 36 \\
\hline 5F & 13 & 3 & 29 & 3 & 29 & 35 \\
\hline 60 & 13 & - 3 & 29 & 3 & 30 & 34 \\
\hline 61 & 13 & 3. & 29 & 3 & 31 & 33 \\
\hline 62 & 13 & 3 & 29 & 3 & 32 & 32 \\
\hline . & - & & & - & & \\
\hline 7 C & 13 & 3 & 29 & 3 & 58 & 6 \\
\hline 7D & 13 & 3 & 29 & 3 & 59 & 5 \\
\hline 7E & 13 & 3 & 29 & 3 & 60 & 4 \\
\hline 7F & 13 & 3 & 29 & 3 & 61 & 3 \\
\hline
\end{tabular}
significant) bit controls the cursor (see Cursor Control). This bit is known as the data byte control bit. If either Blank or Inverse mode is selected, a " 0 " in this bit causes a normal character display, while a " 1 " selects either Blank or Inverse mode, depending on which mode is enabled. Three control codes are provided' (see Table 1) to Enable Blank mode, Enable Inverse mode, or Enable Normal Display mode.

In the Blank mode, any character with the MSB = " 1 " will be blanked. In the Inverse mode, it will be displayed with all segment driver outputs inverted. On video displays, this is referred to as "Inverse Video" format. These controls allow individual characters or groups of characters to be blinked or blanked by simply changing the mode without changing the data in the Display Buffer.

\section*{Cursor Control}

The data byte control bit (MSB 8), besides selecting Blank, Inverse, or Normal mode, also controls the cursor output which is enabled on all characters with the MSB equal to one. Therefore, when the Normal mode is enabled and the MSB of the data byte is set to a one, the normal character is displayed with the cursor on. When the Blank mode is enabled and the MSB is set to a one, the character is blanked but the cursor is on. If Inverse mode is enabled and the MSB is set to a one, the inverse character is displayed and the cursor is on but not inversed.

\section*{Start Refresh}

At power on, the 10939 is held in an internal halt mode. The normal display refresh sequence starts upon receipt of a Start Refresh control code. This is particularly useful for synchronizing systems using more than one 10939. Only the Master 10939 in a multi-chip system will recognize the Start Refresh code. The Master starts the Slave(s) at the appropriate time, using the SOP signal.

\section*{INPUT DISPLAY DATA WORDS}

Display data words are loaded as 8 -bit codes. The eighth (most significant) bit specifies normal (0) or blank/inverse (1) display mode, depending on the blank/inverse mode selection (see Control data words 09 and 0A in Table 1). This bit also controls the cursor.

Twenty display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer automatically increments after each data word is stored in the buffer. To select a character position to be loaded out of sequence, use the Buffer Pointer control code. The Buffer Pointer will automatically reset to character position 0 when its value is equal to the programmed Digit Count.

\section*{POWER-ON RESET}

The Power-On Reset (POR) initializes the internal circuits of the 10939. This is normally accomplished when power ( \(\mathrm{V}_{\mathrm{DD}}\) ) is applied. The following conditions are established by application of POR:
a. The Grid Drivers (STR00-STR19) on the 10939 are in the off state.
b. The Segment Drivers (SG01-SG16) on the 10941 are in the off state.
c. The Duty Cycle is set to 0 .
d. The Digit Counter is set to 32 .
e. The Buffer Pointer is set to 0 .
f. The Digit time is set to 64 .
g. The Normal display mode is set.
h. DATA-LOAD is set to high impedance state.
i. SCLK-DIS is set to \(\mathrm{V}_{\mathrm{OL}}\) to disable the anode drivers in the 10941.
j. \(S O P\) is set to \(V_{O L}\) to disable the sync pulse.

\section*{Note:}
1. When the POR signal is removed, SCLK-DIS is set to the high impedance state.
2. During the initial rise time of \(V_{D D}\) at power turn-on, the magnitude of \(\mathrm{V}_{\mathrm{GG}}\) should not exceed the magnitude of \(\mathrm{V}_{\mathrm{DD}}\).

\section*{DIGIT (GRID) DRIVERS (STR00-STR19) PLUS CURSOR}

The 20 Digit (Grid) Drivers select each of the display character positions sequentially during a refresh scan. Display segments are illuminated when both the Digit Drivers and Segment Drivers for a particular character are energized simultaneously. The Cursor segment is generated by the 10939, but its timing characteristics are identical to the 16 segments generated by the 10941.

SEGMENT (ANODE) DRIVERS (SG01-SG16, PNT, TAIL)
Eighteen Segment (Anode) Drivers are provided in the 10941. The output states for each character pattern and each bargraph pattern are internally decoded from the 8 -bit characters received from the 10939 by means of a \(128 \times 18\)-bit PLA. Data codes and the corresponding segment patterns are shown in Figure 1. Data codes and the corresponding bargraph patterns are shown in Figure 2.



Figure 2. 16-Segment BarGraph Codes

\section*{TYPICAL SYSTEM HOOKUPS}

Figure 3 shows a 10941 and 10939 in a parallel interface with the host system driving a 20 character display. Figure 4 shows a 10941 and a 10939 in a serial interface with the host system
driving a 20 character display. Figure 5 shows a 10941 and two 10939's in a parallel interface with the host system driving a 40 character display.


Figure 3. Typical Display System with Parallel Interface to Host System


Figure 4. Typical Display System with Serial Interface to Host System


Figure 5. Typical Display System with Parallel Interface to Host and Two 10939 Devices

10951
BARGRAPH AND NUMERIC DISPLAY CONTROLLER

\author{
PRELIMINARY
}

\section*{DESCRIPTION}

The Rockwell 10951 Bargraph and Numeric Display Controller is an LSI general purpose display controller designed to interface to bargraph and numeric displays (vacuum fluorescent or LED).

The 10951 will drive 16-segment bargraph or seven-segment plus comma and decimal numeric displays with up to 16 display positions. The controller accepts command and data input words on a clocked serial input line. Commands control the on/off duty cycle, starting character position and number of characters to display. Encoded data words display bargraph position (single segment or increasing bar length), numbers, comma, decimal and selected upper and lower case letters. No external drive circuitry is required for displays that operate on 20 mA of drive current up to 50 volts. A \(64 \times 16\)-bit segment decoder provides character set decoding for the display.

\section*{ORDERING INFORMATION}
\begin{tabular}{|c|c|c|c|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \begin{tabular}{c} 
Drive \\
Voltage
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range \(\left({ }^{\circ}\right.\) C \()\)
\end{tabular} \\
\hline 10951P-40 & Plastıc & 40 V & 0 to +70 \\
10951P-50 & Plastic & 50 V & 0 to +70 \\
10951PE-40 & Plastic & 40 V & -40 to +85 \\
10951PE-50 & Plastic & 50 V & -40 to +85 \\
\hline
\end{tabular}

\section*{FEATURES}
- 16 segment drivers plus decimal point and comma tail drivers
- 16 digit drivers
- Up to 66 kHz data rate
- TTL compatible
- Direct digit drive of 20 mA for up to 50 volt displays
- Supports vacuum fluorescent or LED displays
- Serial data input for 8-bit display and control data words
- \(64 \times 16\)-bit PLA provides data decoding driving
- Any 1 of 16 bargraph segments
- 1 to 16 bargraph segments
- Ten seven-segment numeric characters (0-9)
- Comma and decimal
- Eight upper and lower case seven-segment characters
- Command functions
- On/off duty cycle
- Character position
- Number of characters
- 40-Pin DIP package


\section*{10951 Block Diagram}

\section*{INTERFACE DESCRIPTION}

10951 Pln Functions
\begin{tabular}{|l|c|l|}
\hline Signal Name & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline V SS & 1 & Power and signal reference \\
AD16-AD1 & \(2-17\) & Digits 16 through 1 driver outputs \\
V \(_{\text {DD }}\) & 18 & DC power connection \\
A & 19 & A clock output used for testing \\
POR & 20 & Power-on reset input \\
DATA & 21 & Serial data input \\
SCLK & 22 & Serial data clock input \\
SGA-SGP & \(23-38\) & Segments A through P driver outputs \\
TAIL & 39 & Comma tail driver output \\
PNT & 40 & Decimal point driver output \\
\hline
\end{tabular}

\section*{SPECIFICATIONS}

\section*{ABSOLUTE MAXIMUM RATINGS*}

All voltages are specified relative to \(\mathrm{V}_{\mathrm{SS}}\).
\begin{tabular}{|l|l|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & +0.3 to -20 & V \\
Operating Current & \(\mathrm{I}_{\mathrm{DD}}\) & 7 & mA \\
Input Voltage & \(\mathrm{V}_{\text {IN }}\) & +0.3 to -20 & V \\
Output Voltage & \(\mathrm{V}_{\text {OUT }}\) & +0.3 to -50 & V \\
Operating Temperature & & & \\
Commercial & \(\mathrm{T}_{\mathrm{C}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
Industrial & \(\mathrm{T}_{\mathrm{I}}\) & -40 to +85 & \({ }^{\circ} \mathrm{C}\) \\
Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +125 & \({ }^{\circ} \mathrm{C}\) \\
Input Capacitance & \(\mathrm{C}_{\text {IN }}\) & 5 & pF \\
Output Capacitance & \(\mathrm{C}_{\text {OUT }}\) & 10 & pF \\
\hline
\end{tabular}
\begin{tabular}{|c|c|}
\hline &  \\
\hline
\end{tabular}

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

\section*{DC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multicolumn{3}{|c|}{Limits ( \(\mathrm{V}_{\mathbf{S S}}=0\) )} & \multicolumn{3}{|c|}{Limits ( \(\mathrm{V}_{\mathrm{ss}}=+5 \mathrm{~V}\) )} & \multirow[b]{2}{*}{Condilions} & \multirow[b]{2}{*}{Unit} \\
\hline & Min & Typ & Max & Min & Typ & Max & & \\
\hline Supply Voltage ( \(V_{\text {DD }}\) ) & -16.5 & -15.0 & -13.5 & -11.5 & -10.0 & -8.5 & & V \\
\hline Input DATA,SCLK, & & & & & & & & \\
\hline Logic "1" & -1.0 & & +0.3 & +4.0 & & +5.3 & & v \\
\hline Logic "0" & \(V_{D D}\) & & -4.2 & \(V_{D D}\) & & +0.8 & & \\
\hline Input POR & & & & & & & & \\
\hline Logic "1" & -3.0 & & +0.3 & +2.0 & & +5.3 & & \\
\hline Logic " 0 " & \(V_{D D}\) & & -10.0 & \(V_{D D}\) & & -5.0 & & \\
\hline Output Digit and & & & & & & & & \\
\hline Segment Strobes & & & & & & & & \\
\hline Driver On & & & & & & & & \\
\hline Commercial & & & -1.5 & & & & & v \\
\hline Industrial & & & -1.7 & & & +3.3 \(\}\) & At 10 mA & v \\
\hline Driver Off 10951-40 & -40 & & -35 & -35 & & \(-30\}\) & Actual value & V \\
\hline Driver Off 10951-50 & -50 & & -45 & & & -40 \(\}\) & determined by external circuit & \\
\hline Output Leakage Input Leakage & & & \[
\begin{aligned}
& 10 \\
& 10
\end{aligned}
\] & & & \[
\left.\begin{array}{l}
10 \\
10
\end{array}\right\}
\] & Per driver at driver off & \[
\begin{aligned}
& \mu \mathrm{A} \\
& \mu \mathrm{~A}
\end{aligned}
\] \\
\hline \multicolumn{9}{|l|}{Note: All outputs require Pulldown Resistors.} \\
\hline
\end{tabular}

\section*{AC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Typ & Max & Unit \\
\hline \begin{tabular}{l}
SCLK Clock On Time On Time \\
Data Input Sample Time Before SCLK Clock Off After SCLK Clock Off
\end{tabular} & \[
\begin{aligned}
& T_{\text {on }} \\
& T_{\text {off }} \\
& T_{\text {boff }} \\
& T_{\text {aoff }}
\end{aligned}
\] & \[
\begin{array}{r}
1.0 \\
1.0 \\
200 \\
100
\end{array}
\] & & 20.0 & \begin{tabular}{l}
\(\mu \mathrm{S}\) \\
\(\mu \mathrm{S}\) \\
ns \\
ns
\end{tabular} \\
\hline
\end{tabular}


SCLK and Serial Data Timing
SCLK

SCLK and Serial Data (Control Word) Examples


Data Word LSB/MSB Timing


\section*{FUNCTIONAL DESCRIPTION}

The 10951 receives commands and data on a serial input line clocked externally by a separate clock input line. The controller decodes the commands from control data words, decodes the data words in accordance with an internal \(64 \times 16\)-bit programmable logic array (PLA) and turns on and off segment and digit output drivers. The segment output patterns are controlled by the decoded data words while the digit output and segment output timing are controlled by the decoded control words. All timing signals required to control the display are generated in the 10951 device without any refresh input from the host processor.

Input data is loaded into the Display Data Buffer via the Serial Data Input (Data) channel. Internal timing and control blocks synchronize the segment and digit output signals to provide the proper timing for the multiplexing operation. The \(16 \times 64\) PLA decodes 8 -bit data words to drive the 16 segment, comma and decimal point drivers. The decoded data words will drive 16 segments to display bargaph patterns (single segment and multiple segment for increasing length displays) or seven-segment patterns to display numbers, selected upper and lower case letters, comma and decimal point.

Input data is loaded into the 10951 as a series of 8 -bit words with the most significant bit (MSB), bit 7 first. If the MSB is a logic 1 (this bit is referred to as the control bit C), the loaded word is a control data word. If the C bit of any word is a logic 0 , the loaded word is a display data word. The following paragraphs describe the format and functions of these control and display data words.

\section*{INPUT CONTROL DATA WORDS}

When the C-Bit (bit 7) of the 8 -bit input word is a logic 1 , bits 5 and 6 are decoded into one of four control commands while data associated with the command are extracted from bits 0-4. There are four control codes which perform the following display functions:
- Load the Display Data Buffer pointer,
- Load the Digit Counter,
- Load the Duty Cycle register,
- Enter Test Mode.

Table 1 lists the control codes and their functions.

\section*{Buffer Pointer Control}

The Buffer Pointer Control code allows the Display Data Buffer pointer to be set to any digit position so that individual characters may be modified. The Buffer Pointer is loaded with a decimal equivalent value 2 less than the desired value (i.e., to point to the digit controlled by AD6 of the display, a value of 4 is entered). See Table 2 for a complete list of the Buffer Pointer values.

\section*{Digit Counter Control}

The Digit Counter Control code is normally used only during initialization routines to define the number of character positions to be controlled. This code maximizes the duty cycle for any display. If 16 characters are to be controlled, enter a value of 0 (zero). Otherwise, enter the value desired.

\section*{Duty Cycle}

The Duty Cycle Control code is used to turn the display on and off, and to adjust display brightness. As shown in the block diagram, the time slot for each character is 32 clock cycles. The Segment and digit drivers for each character are on for a maximum of 31 cycles with a 1 cycle inter-digit off-time. The Duty Cycle Control code contains a 5-bit numeric field which modifies the on-time for the driver outputs from 0 to 31 cycles. A duty cycle of 0 puts both the segment and digit drivers into the off state. Figure 1 shows the timing characteristics for the segment outputs.

\section*{Test Mode Enable}

The Test Mode Enable code is a device test function only. If executed, it will lock the device in the Test Mode. This mode can be disabled only by performing a power-on reset.

If this mode is activated, the digit time is reduced from 32 to 4 clock cycles to speed up the output driver sequencing time for ease in testing.

Table 1. Control Data Words


Table 2. Buffer Pointer Control Codes
\begin{tabular}{|c|c|c|}
\hline Hex Code & Pointer Value & Character Controlled By \\
\hline A0 & 16 & AD2 \\
A1 & 1 & AD3 \\
A2 & 2 & AD4 \\
A3 & 3 & AD5 \\
A4 & 4 & AD6 \\
A5 & 5 & AD7 \\
A6 & 6 & AD8 \\
A7 & 7 & AD9 \\
A8 & 8 & AD10 \\
A9 & 9 & AD11 \\
AA & 10 & AD12 \\
AB & 11 & AD13 \\
AC & 12 & AD14 \\
AD & 13 & AD15 \\
AE & 14 & AD16 \\
AF & 15 & AD1 \\
\hline
\end{tabular}

\section*{INPUT DISPLAY DATA WORDS}

Display data words are loaded as 8 -bit format codes. There are 64 codes available (with the C -bit set to 0 to indicate a display data word).

Sixteen display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer is automatically incremented before each data word is stored in the Display Buffer except for decimal point and comma words. The decimal point and comma words do not cause the Buffer Pointer to increment and thus are always associated with the previous character entered. To enter a character position out of the normal sequence, use the Buffer Pointer control command before entering the display data word. It is not necessary to use the Buffer Pointer control command to cycle back to position 1 when less than 16 character positions are being used (Digit Counter \(\neq 0\) ).

\section*{DIGIT DRIVERS (AD1-AD16)}

The sixteen Digit Drivers (AD1 - AD16) are used to select each of the display digits sequentially during a refresh scan. Display segments will be illuminated when both the Digit Drivers and Segment Drivers for a particular character are energized simultaneously. The timing characteristics of both the digits and segments are shown in Figure 1. See POR for the Power-On Reset state of these drivers.


Figure 1. Display Scan Timing Diagram (Duty Cycle)

\section*{POWER-ON RESET (POR)}

The Power-On Reset (POR) initializes the internal circuits of the 10951 when power \(\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 Duty Cycle is set to 0 .
d. The Digit Counter is set to 16 (a bit code value of 0 ).
e. The Buffer Pointer points to the character controlled by AD1.

\section*{SEGMENT DRIVERS (SGA-SGP)}

Sixteen (16) Segment Drivers are provided (SGA-SGP), plus the decimal point (PNT) and comma tail (TAIL). The segment, PNT and TAIL outputs are internally decoded from the 8 -bit characters in the Display Data Buffer by means of a \(64 \times 16\)-bit PLA. The driver allocations for the 16 -segment bargraph display and the seven-segment alphanumeric character plus comma and
decimal point are shown in Figure 2. The input codes associated with seven-segment alphanumeric, comma and decimal point display are also shown in Figure 2. The complete set of 8 -bit codes for the bargraph and alphanumeric display is shown in Table 3. Note that only segment drivers SGA-SGG are used to drive the seven-segment characters. Segment drivers SGH-SGP may be used for other purposes as decoded in accordance with Table 3. Figure 3 shows the total allocation of the 16 -segment drivers as they would appear on a 7 -segment display or a 16 -segment bargraph display. Timing characteristics for the segment outputs are shown in Figure 1. See POR for the Power-On Reset state of these drivers.

\section*{TYPICAL SYSTEM HOOK-UP}

Figure 4 shows the 10951 as it would be connected to a V-F display when driven by a host system. \(\mathrm{E}_{\mathrm{K}}\) is determined by the V-F display specifications and \(R_{C}\) is selected to provide proper biasing current for zeners. Pull down resistors \(R_{A}\) and \(R_{G}\) are determined by the interconnection capacitance between the 10951 and the display.

Table 3. 10951 Data Codes
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline & & & put & Co & & & & \multirow[b]{2}{*}{Function} & \multicolumn{18}{|c|}{Segment Driver Output Patterns (1 = On)} & \multirow[t]{2}{*}{} \\
\hline 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 & & SGA & SGB & SGC & SGD & SGE & SGF & SGG & SGH & SGI & SGJ & SGK & SGL & SGM & SGN & SGO & SGP & PNT & TAIL & \\
\hline 0 & X & 0 & 0 & 0 & 0 & 0 & 0 & Segment A On & 1 & & & & & & & & & & & & & & & & & & \multirow{15}{*}{Any 1 of 16 Segments} \\
\hline 0 & X & 0 & 0 & 0 & 0 & 0 & 1 & Segment B On & & 1 & & & & & & & & & & & & & & & & & \\
\hline 0 & X & 0 & 0 & 0 & 0 & 1 & 0 & Segment C On & & & 1 & & & & & & & & & & & & & & & & \\
\hline 0 & X & 0 & 0 & 0 & 0 & 1 & 1 & Segment D On & & & & 1 & & & & & & & & & & & & & & & \\
\hline 0 & X & 0 & 0 & 0 & 1 & 0 & 0 & Segment E On & & & , & & 1 & & & & & & & & & & & & & & \\
\hline 0 & X & 0 & 0 & 0 & 1 & 0 & 1 & Segment F On & & & & & & 1 & & & & & & & & & & & & & \\
\hline 0 & X & 0 & 0 & 0 & 1 & 1 & 0 & Segment G On & & & & & & & 1 & & & & & & & & & & & & \\
\hline 0 & X & 0 & 0 & 0 & 1 & 1 & 1 & Segment H On & & & & & & & & 1 & & & & & & & & & & & \\
\hline 0 & X & 0 & 0 & 1 & 0 & 0 & 0 & Segment I On & & & & & & & & & 1 & & & & & & & & & & \\
\hline 0 & X & 0 & 0 & 1 & 0 & 0 & 1 & Segment J On & & & & & & & & & & 1 & & & & & & & & & \\
\hline 0 & X & 0 & 0 & 1 & 0 & 1 & 0 & Segment K On & & & & & & & & & & & 1 & & & & & & & & \\
\hline 0 & X & 0 & 0 & 1 & 0 & 1 & 1 & Segment L On & & & & & & & & & & & & 1 & & & & & & & \\
\hline 0 & X & 0 & 0 & 1 & 1 & 0 & 0 & Segment M On & & & & & & & & & & & & & 1 & & & & & & \\
\hline 0 & X & 0 & 0 & 1 & 1 & 0 & 1 & Segment N On & & & & & & & & & & & & & & 1 & & & & & \\
\hline 0 & X & 0 & 0 & 1 & 1 & 1 & 0 & Segment O On & & & & & & & & & & & & & & & 1 & & & & \\
\hline 0 & X & 0 & 0 & 1 & 1 & 1 & 1 & Segment P On & & & & & & & & & & & & & & & & 1 & & & \multirow[t]{2}{*}{Bargraph Codes} \\
\hline 0 & X & 0 & 1 & 0 & 0 & 0 & 0 & Segment A On & 1 & & & & & & & & & & & & & & & & & & \\
\hline 0 & X & 0 & 1 & 0 & 0 & 0 & 1 & Segments A\&B On & 1 & 1 & & & & & & & & & & & & & & & & & \\
\hline 0 & X & 0 & 1 & 0 & 0 & 1 & 0 & Segment A-C On & 1 & 1 & 1 & & & & & & & & & & & & & & & & \\
\hline 0 & X & 0 & 1 & 0 & 0 & 1 & 1 & Segment A-D On & 1 & 1 & 1 & 1 & & & & & & & & & & & & & & & \\
\hline 0 & X & 0 & 1 & 0 & 1 & 0 & 0 & Segment A-E On & 1 & 1 & 1 & 1 & & & & & & & & & & & & & & & \\
\hline 0 & X & 0 & 1 & 0 & 1 & 0 & 1 & Segment A-F On & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & & & & & & & \\
\hline 0 & X & 0 & 1 & 0 & 1 & 1 & 0 & Segment A-G On & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & & & & & & \\
\hline 0 & X & 0 & 1 & 0 & 1 & 1 & 1 & Segment A-H On & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & & & & & 1 to 16 \\
\hline 0 & X & 0 & 1 & 1 & 0 & 0 & 0 & Segment A-I On & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & & & & Segments \\
\hline 0 & X & 0 & 1 & 1 & 0 & 0 & 1 & Segment A-J On & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & & & \\
\hline 0 & X & 0 & 1 & 1 & 0 & 1 & 0 & Segment A-K On & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & & \\
\hline 0 & X & 0 & 1 & 1 & 0 & 1 & 1 & Segment A-L On & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & \\
\hline 0 & X & 0 & 1 & 1 & 1 & 0 & 0 & Segment A-M On & 1 & 1 & 1 & 1 & & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & \\
\hline 0 & X & 0 & 1 & 1 & 1 & 0 & 1 & Segment A-N On & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & \\
\hline 0 & X & 0 & 1 & 1 & 1 & 1 & 0 & Segment A-C On & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & \\
\hline 0 & X & 0 & 1 & 1 & 1 & 1 & 1 & Segment A-P On & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 0 & 0 & 0 & 0 & 0 & Number 0 & 1 & 1 & 1 & 1 & 1 & 1 & & 1 & 1 & 1 & 1 & 1 & & & & & & & \\
\hline 0 & X & 1 & 0 & 0 & 0 & 0 & 1 & Number 1 & & 1 & 1 & & & & & 1 & 1 & 1 & 1 & 1 & & & & & & & \\
\hline 0 & X & 1 & 0 & 0 & 0 & 1 & 0 & Number 2 & 1 & 1 & & 1 & 1 & & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & \\
\hline 0 & X & 1 & 0 & 0 & 0 & 1 & 1 & Number 3 & 1 & 1 & 1 & 1 & & & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & \\
\hline 0 & X & 1 & 0 & 0 & 1 & 0 & 0 & Number 4 & & 1 & 1 & & & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & \\
\hline 0 & X & 1 & 0 & 0 & 1 & 0 & 1 & Number 5 & 1 & & 1 & 1 & & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & \\
\hline 0 & X & 1 & 0 & 0 & 1 & 1 & 0 & Number 6 & 1 & & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & \\
\hline 0 & X & 1 & 0 & 0 & 1 & 1 & 1 & Number 7 & 1 & 1 & 1 & & & & & 1 & 1 & 1 & 1 & 1 & & & & & & & \\
\hline 0 & X & 1 & 0 & 1 & 0 & 0 & 0 & Number 8 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & \\
\hline 0 & X & 1 & 0 & 1 & 0 & 0 & 1 & Number 9 & 1 & 1 & 1 & 1 & & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & \\
\hline 0 & X & 1 & 0 & 1 & 0 & 1 & 0 & Letter P & 1 & 1 & & & 1 & 1 & 1 & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 0 & 1 & 0 & 1 & 1 & Letter L & & & & 1 & 1 & 1 & & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 0 & 1 & 1 & 0 & 0 & Comma & & & & & & & & 1 & 1 & 1 & 1 & 1 & & & & & 1* & 1* & \\
\hline 0 & X & 1 & 0 & 1 & 1 & 0 & 1 & Blank & & & & & & & & 1 & 1 & 1 & 1 & 1 & & & & & & & \\
\hline 0 & X & 1 & 0 & 1 & 1 & 1 & 0 & Decrmal & & & & & & & & & & & & & 1 & 1 & 1 & 1 & 1 ** & & Alphanumeric \\
\hline 0 & X & 1 & 0 & 1 & 1 & 1 & 1 & Blank & & & & & & & & & & & & & 1 & 1 & 1 & 1 & & & and \\
\hline 0 & X & 1 & 1 & 0 & 0 & 0 & 0 & Number 0 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & & 1 & 1 & 1 & 1 & & & Special \\
\hline 0 & X & 1 & 1 & 0 & 0 & 0 & 1 & Number 1 & & 1 & 1 & & & & & & & & & & 1 & 1 & 1 & 1 & & & Codes \\
\hline 0 & X & 1 & 1 & 0 & 0 & 1 & 0 & Number 2 & 1 & 1 & & 1 & 1 & & 1 & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 1 & 0 & 0 & 1 & 1 & Number 3 & 1 & 1 & 1 & 1 & & & 1 & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 1 & 0 & 1 & 0 & 0 & Number 4 & & 1 & 1 & & & 1 & 1 & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 1 & 0 & 1 & 0 & 1 & Number 5 & 1 & & 1 & 1 & & 1 & 1 & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 1 & 0 & 1 & 1 & 0 & Number 6 & 1 & & 1 & 1 & 1 & 1 & 1 & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 1 & 0 & 1 & 1 & 1 & Number 7 & 1 & 1 & 1 & & & & & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 1 & 1 & 0 & 0 & 0 & Number 8 & 1 & 1 & 1 & 1 & 1 & 1 & 1 & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 1 & 1 & 0 & 0 & 1 & Number 9 & 1 & 1 & 1 & 1 & & 1 & 1 & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 1 & 1 & 0 & 1 & 0 & Letter A & 1 & 1 & 1 & & 1 & 1 & 1 & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 1 & 1 & 0 & 1 & 1 & Letter b & & & 1 & 1 & 1 & 1 & 1 & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 1 & 1 & 1 & 0 & 0 & Letter C & 1 & & & 1 & 1 & 1 & & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 1 & 1 & 1 & 0 & 1 & Letter d & & 1 & 1 & 1 & 1 & & 1 & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline 0 & X & 1 & 1 & 1 & 1 & 1 & 0 & Letter E & 1 & & & 1 & 1 & 1 & i & & & & & & i & i & 1 & 1 & & & \\
\hline 0 & X & 1 & 1 & 1 & 1 & 1 & 1 & Letter F & 1 & & & & 1 & 1 & 1 & & & & & & 1 & 1 & 1 & 1 & & & \\
\hline \multicolumn{27}{|c|}{Notes:} & \\
\hline
\end{tabular}

\footnotetext{
** Sets decimal output for last character entered
}


Figure 2. Segment Allocation and 7-Segment Alphanumeric Codes


Figure 3. Total Character Allocation for Bargraph or 7-Segment Displays


Figure 4. Partial System Schematic

\section*{Rockwell}

\section*{SEGMENTED DISPLAY CONTROLLER/DRIVER}

\section*{PRELIMINARY}

\section*{DESCRIPTION}

The 10955 Segmented Display/Driver is a MOS/LSI device capable of directly driving both the grids and anodes of multiplexed vacuum-fluorescent segmented displays. All timing circuits (including a clock generator) required to control the display drivers are contained within the device. The 10955 can drive segmented displays with 8 or 16 grids (characters) and 8, 16, or 24 anodes (segments). A serial interface allows for a host microprocessor to transmit commands and display data to the 10955 directly.

A \(128 \times 16\) bit PLA provides coding for both 16 -segment and 14 -segment alphanumeric ASCII code character sets (all caps only). The PLA is divided into lower 64 and upper 64 code sets. Only one set can be selected at a time. In lower set mode the 16 -segment display characters are selected. In upper set mode the 14 -segment display characters are selected. The PLA can also be bypassed so that data words from the host microprocessor are loaded directly into segment drivers without decoding by the PLA. This mode is especially useful for creating special display patterns such as bar graph displays. Bypass mode is limited to eight drivers per data word.

\section*{FEATURES}
- 8- or 16 -character display driver
- 8-, 16-, or 24 -segment drivers
- Average data rate 66 kHz
- Single character burst rate 500 kHz
- Direct digit drive of 20 ma for up to 40 or 50 volt vacuumfluorescent serial displays
- \(128 \times 16\)-bit PLA provides 16 - or 14 -segment alpha-numeric character set
- Internal clock generator circuit
- Serial host interface
- PLA bypass mode
- 40-pin DIP

\section*{ORDERING INFORMATION}
\begin{tabular}{|c|c|c|c|}
\hline \begin{tabular}{c} 
Part \\
Number
\end{tabular} & \begin{tabular}{c} 
Package \\
Type
\end{tabular} & \begin{tabular}{c} 
Drive \\
Voltage
\end{tabular} & \begin{tabular}{c} 
Temperature \\
Range \(\left({ }^{\circ} \mathrm{C}\right)\)
\end{tabular} \\
\hline \(10955 \mathrm{P}-40\) & Plastic & 40 V & 0 to +70 \\
\(10955 \mathrm{P}-50\) & Plastic & 50 V & 0 to +70 \\
\(10955 \mathrm{PE}-40\) & Plastic & 40 V & -40 to +85 \\
\(10955 \mathrm{PE}-50\) & Plastic & 50 V & -40 to +85 \\
\hline
\end{tabular}


\section*{INTERFACE DESCRIPTION}
\begin{tabular}{|l|c|l|}
\hline \multicolumn{1}{|c|}{ Signal Name } & Pin No. & \multicolumn{1}{|c|}{ Function } \\
\hline V SS \(^{\text {C12P }}\) & 1 & Power and signal reference \\
SCLK & 2 & Test clock-factory test \\
DATAIN & 3 & Serial input data clock \\
SEGA-SEGP & 4 & Serial data input \\
& \(5-20\) & Segments A through P driver \\
D7/STR15-D0/STR08 & \(21-28\) & outputs \\
& & Direct segment outputs or \\
STR07-STR00 & \(29-35,37\) & Strobe outputs \\
V GG & 36 & Display voltage \\
VDD & 38 & Logic supply voltage \\
POR & 39 & Power on reset \\
LD & 40 & Data Load Strobe \\
\hline
\end{tabular}

\section*{SPECIFICATIONS}

\section*{ABSOLUTE MAXIMUM RATINGS*}

All voltages are specified relative to \(V_{S S}\).
\begin{tabular}{|l|l|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & +03 to -25 & V \\
Operating Current & \(\mathrm{I}_{\mathrm{DD}}\) & 8 & mA \\
Input Voltage & \(\mathrm{V}_{\mathrm{IN}}\) & +0.3 to -25 & V \\
Display Voltage & \(\mathrm{V}_{\mathrm{GG}}\) & +0.3 to -50 & V \\
Operating Temperature & & & \\
Commercial & \(\mathrm{T}_{\mathrm{C}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
Industrial & \(\mathrm{T}_{1}\) & -40 to +85 & \({ }^{\circ} \mathrm{C}\) \\
Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +125 & \({ }^{\circ} \mathrm{C}\) \\
Input Capacitance & \(\mathrm{C}_{\mathrm{IN}}\) & 5 & pF \\
Output Capacitance & \(\mathrm{C}_{\mathrm{OUT}}\) & 10 & pF \\
\hline
\end{tabular}


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

\section*{DC CHARACTERISTICS}
\(\left(\mathrm{V}_{\mathrm{DD}}=-18.0\right.\) to \(-22.0 \mathrm{Vdc}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{TA}=0^{\circ} \mathrm{C}\) to \(+70^{\circ} \mathrm{C}\) (commercial) or \(-40^{\circ} \mathrm{C}\) to \(+85^{\circ} \mathrm{C}\) (industrial), unless otherwise noted.
All voltages referenced to \(\mathrm{V}_{\mathrm{SS}}\).)
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min. & Typical 3 & Max. & Unit \\
\hline Operating Current, Logic Commercial Industrial & \(I_{\text {dD }}\) & - & \[
\begin{aligned}
& 3.2 \\
& 4.0
\end{aligned}
\] & \[
\begin{aligned}
& 6.4 \\
& 8.0
\end{aligned}
\] & mA \\
\hline \begin{tabular}{l}
Operating Current Display \\
(1 strobe plus 24 segment) \\
Commercial Industrial \\
(1 strobe plus 16 segment) \\
Commercial Industrial \\
(All display drivers) \(V_{G G}\) and \(85^{\circ} \mathrm{C}\)
\end{tabular} & \(I_{G G}\) & \[
\begin{aligned}
& - \\
& -
\end{aligned}
\] & \[
\begin{aligned}
& - \\
& - \\
& - \\
& -
\end{aligned}
\] & \[
\begin{aligned}
& 6.5 \\
& 8.0 \\
& 4.3 \\
& 5.3 \\
& 320 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& \mathrm{mA} \\
& \mathrm{~mA} \\
& \mathrm{~mA} \\
& \mathrm{~mA} \\
& \mu \mathrm{~A} \\
& \hline
\end{aligned}
\] \\
\hline \[
\begin{aligned}
& \text { Display voltage } \\
& 10955-40 \\
& 10955-50
\end{aligned}
\] & \(\mathrm{V}_{\mathrm{GG}}\) & \[
\begin{aligned}
& -40.0 \\
& -50.0
\end{aligned}
\] & 二 & 二 & V \\
\hline Input Leakage (at -20V) & 111 & - & - & 10 & uA \\
\hline ```
Input (DATAIN, LD, SCLK)
    Logic "1"
    Logic "0"
``` & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{IH}} \\
& \mathrm{~V}_{\mathrm{IL}} \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& -1.2 \\
& \mathrm{~V}_{\mathrm{DD}} \\
& \hline
\end{aligned}
\] & \[
\begin{array}{r}
-05 \\
-6.0
\end{array}
\] & \[
\begin{aligned}
& +0.3 \\
& -4.2
\end{aligned}
\] & V \\
\hline \[
\begin{aligned}
& \hline \text { Input POR } \\
& \text { Logic '"'," } \\
& \text { Logic " } 0 \text { "' }
\end{aligned}
\] & \[
\begin{aligned}
& V_{\text {IHPO }} \\
& V_{\text {ILPO }} \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& -3.0 \\
& V_{D D} \\
& \hline
\end{aligned}
\] & \[
\overline{12.0}
\] & \[
\begin{array}{r}
+0.3 \\
-10.0 \\
\hline
\end{array}
\] & V \\
\hline \[
\begin{gathered}
\text { Output (C12P) } \\
\text { Logic "1"', } \\
\text { Logic " } 0 \text { " } \\
\hline
\end{gathered}
\] & \begin{tabular}{l}
\(V_{\text {OHSY }}\) \\
\(\mathrm{V}_{\text {OLSY }}\)
\end{tabular} & \[
\begin{aligned}
& -0.7 \\
& V_{D D}
\end{aligned}
\] & - & \[
+0.3
\] & V \\
\hline ```
Output (Strobe STR00-07, D0-D7, SGA-SGP)
    Logic " 1 " ( \(L_{\text {Load }}=10 \mathrm{~mA}\) )
    Logic " 1 " " (Looad \(=20 \mathrm{~mA})^{2}\)
    Logic " 0 "' (Load \(=0 \mathrm{~mA}\) )
``` & \[
\begin{aligned}
& \mathrm{V}_{\mathrm{OH}} \\
& \mathrm{~V}_{\mathrm{OH}}
\end{aligned}
\] & \[
\begin{gathered}
-1.5 \\
\frac{-}{\mathrm{V}_{\mathrm{GG}}}
\end{gathered}
\] & \[
\begin{gathered}
-1.0 \\
-2.0 \\
0.5+V_{G G}
\end{gathered}
\] & \[
\begin{gathered}
\mathrm{V}_{\mathrm{SS}} \\
\mathrm{~V}_{\mathrm{SS}} \\
0.95 \times \mathrm{V}_{\mathrm{GG}}
\end{gathered}
\] & V \\
\hline
\end{tabular}

\section*{Notes:}
1. Open drain driver. Requires external pull-down resistor for testing only.
3. Typical measured at \(\mathrm{V}_{\mathrm{DD}}=20.0 \mathrm{~V}\) and \(\mathrm{Y}_{\mathrm{A}}=25^{\circ} \mathrm{C}\).
2. STR00-STR07 only (also for D0-D7 when used as character drivers)

\section*{AC CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|}
\hline Characteristic & Symbol & Min. & Typical & Max. & Unit \\
\hline Clock Timing Cycle Time Commercial Industrial & \(\mathrm{t}_{\mathrm{CYC}}\) & \[
\begin{aligned}
& 6.66 \\
& 5.88
\end{aligned}
\] & & \[
\begin{aligned}
& 20.0 \\
& 22.2
\end{aligned}
\] & usec usec \\
\hline \multicolumn{6}{|l|}{HOST INTERFACE TIMING} \\
\hline \multicolumn{6}{|l|}{Serial Clock (SCLK)} \\
\hline On Time & \(\mathrm{t}_{\text {SCON }}\) & 1.0 & & 40.0 & usec \\
\hline Off Time & \(\mathrm{t}_{\text {SCOFF }}\) & 10 & & - & usec \\
\hline Cycle Tıme & \(\mathrm{t}_{\text {SCCYC }}\) & 2.0 & & - & usec \\
\hline \multicolumn{6}{|l|}{Serial Data (DATAIN)} \\
\hline Set-up Time & \(\mathrm{t}_{\text {SSETUP }}\) & 400 & & - & nsec \\
\hline Hold Time & \[
\mathrm{t}_{\text {SHOLD }}
\] & 400 & & - & nsec \\
\hline Serial Clock to LD Tıme & \(t_{\text {SL }}\) & 600 & & - & nsec \\
\hline LD to Serial Clock & \(t_{\text {LS }}\) & 400 & & - & nsec \\
\hline \multicolumn{6}{|l|}{Data Load (LD)} \\
\hline On Time & \(t_{\text {LDON }}\) & 1.0 & & - & usec \\
\hline Off Time (Commercial & \(t_{\text {LDOFF }}\) & 40.0 & & - & usec \\
\hline Off Time (Industrial) & \(\mathrm{t}_{\text {LDOFF }}\) & 44.5 & & - & usec \\
\hline Cycle Time (Commercial) & \(t_{\text {LDCYC }}\) & 60.0 & & - & usec \\
\hline Cycle Time (Industrial) & \(\mathrm{t}_{\text {LDCYC }}\) & 66.7 & & - & usec \\
\hline
\end{tabular}

Note:
\(t_{r}\) and \(t_{f}=\) rise and fall time of clockıng signals which are 10 to 30 nsec .


Serial Interface Timing Waveforms


\section*{Notes:}
1. \(\mathrm{t}_{\mathrm{CYC}}=2\) bit times.
2. Timing shown is for 16 characters with a duty cycle of 61 .

\section*{Display Scan Timing Diagram}

\section*{FUNCTIONAL DESCRIPTION}

All timing signals required to control the display are generated by the 10955 device after the display buffer and control registers have been loaded from the host processor. In the following functional description, refer to the 10955 block diagram.

Input data is loaded into the Display Data Buffer via the serial data input channel. Internal timing and control logic synchronize the digit output signals with the segment output signals to provide the proper timing for the multiplexing operation. The segment decoding is performed in a \(128 \times 16\) PLA character code set.

\section*{CHARACTER DRIVERS (STR00-STR07)}

The eight character (grid) drivers are used to select the display character positions sequentially during a refresh scan. Display characters are illuminated when both the character driver for a particular character position and the segment (anode) drivers are energized simultaneously.

\section*{DISCRETE DRIVERS (DO-D7)}

The function of these eight drivers depends on the display mode. In some modes these drivers act as segment (anode) drivers
loaded directly from the Data Buffer (RAM). In other modes these drivers are used as extra character (grid) drivers (STR8-STR15). See Display Modes for further discussion of these driver functions.

\section*{SEGMENT DRIVERS (SGA-SGP)}

Depending on the display mode, the sixteen segment drivers are loaded through an \(8 \times 16\) PLA decoder or directly from the Data Buffer RAM.

\section*{SYSTEM CLOCK}

Each 10955 device has its own on-board oscillator and clock generator.

\section*{POWER-ON RESET}

The Power-On Reset (POR) input initializes the internal circuits of the 10955. This is normally performed when power (VDD) is applied. The following conditions are established by application of POR:
a. The grid and anode drivers (STR00-STR07, D0-D7, and SGASGP) are in the off state.
b. Duty Cycle register is set to zero.
c. The Digit Counter is set to 32 digits.
d. The Buffer Pointer is set to zero.
e. The Digit Time is set to 64 .
f. The PLA Bypass/Sixteen Digit display mode is set.

At power on, the 10955 is held in an internal halt mode. This allows the host system to load the control registers and the data buffer without flashing invalid data on the display.

During the initial rise time of VDD at power turn-on, the magnitude of VGG should not exceed the magnitude of VDD.

\section*{HOST SYSTEM INTERFACE}

Input data is loaded into the 10955 via a serial data input channel as a series of nine-bit words.

After nine bits of data (with the most significant bit first) have been shifted into the data buffer, a pulse on the LD signal loads the data into an internal buffer and informs the 10955 that a new data word is available. After the LD pulse, a new data word may be shifted in while the 10955 is processing the first word.

The following sections describe the format and functions of the input words which may contain either control data or display data.

\section*{Input Display Data Words}

Display data words are loaded as nine bit codes. The lower eight bits (7-0) are data. The ninth bit (the most significant) is always a zero (0).

Sixteen display data words must be entered to completely load the Display Data Buffer. The Buffer Pointer is automatically incremented after each data word is stored in the buffer. To select the next character position to be loaded out of the normal 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.

\section*{Control Data Words}

Control data words are distinguished from display words by the fact that the most significant bit is always a one. Control words and their functions are defined below. The most significant bit is implied as always being a 1 for these functions.


\section*{Load Buffer Pointer}

The Load Buffer Pointer code sets the Display Data Buffer Pointer. The three most significant bits of the loaded code value are dropped and the five least significant bits are loaded into the Control Data Word to provide the character position data shown in Table 1.

Table 1. Load Buffer Pointer Codes
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
Load Code \\
Value
\end{tabular} & \begin{tabular}{c} 
Pointer \\
Value
\end{tabular} & \begin{tabular}{c} 
Character Position \\
Selected
\end{tabular} \\
\hline C0 & 00 & 0 \\
C1 & 01 & 1 \\
C2 & 02 & 2 \\
C3 & 03 & 3 \\
C4 & 04 & 4 \\
C5 & 05 & 5 \\
C6 & 06 & 6 \\
C7 & 07 & 7 \\
C8 & 08 & 8 \\
C9 & 09 & 9 \\
CA & OA & 10 \\
CB & OB & 11 \\
CC & OC & 12 \\
CD & OD & 13 \\
CE & OE & 14 \\
CF & OF & 15 \\
\hline
\end{tabular}

\section*{Load Digit Counter}

The Load Digit Counter command defines the number of character positions (grids) to be controlled. This code is normally used only during initialization routines, but it may also be used in conjunction with the Load Duty Cycle control code to extend the range of brightness control. The display should be set up with digit 0 on the left and digit 15 on the right. The number of positions to be controlled starts at position 0 and increases to position 15. If 17 through 32 grids are specified, extra time slots are generated for these phantom strobes. When the phantom strobes are active, strobes 0 through 15 are off so the displayed
data is not affected although the duty cycle is decreased as each phantom strobe is added. The code, digit counter value, and number of grids controlled by the Digit Counter are shown in Table 2.

Table 2. Load Digit Counter Control Codes
\begin{tabular}{|c|c|c|}
\hline Code & Digit Counter Value & No. of Grids Controlled \\
\hline 80 & 00 & 32 \\
\hline 81. & . 01 & - 1 \\
\hline 82 & - 02 & 2 \\
\hline 83 & 03 & 3 \\
\hline 84 & 04 & 4 \\
\hline 85 & 05 & 5 \\
\hline 86 & 06 : & 6 \\
\hline 87 & 07 & 7 \\
\hline 88 & 08 & 8 \\
\hline 89 & 09 & 9 \\
\hline 8A & OA & - 10 \\
\hline 8B & OB & 11 \\
\hline 8 C & OC & 12 \\
\hline 8D & - OD & 13 \\
\hline 8 E & OE & 14 \\
\hline 8 F & OF & 15 \\
\hline 90 & 10 & 16 \\
\hline 91 & 11 & 17 \\
\hline 92 & 12 & 18 \\
\hline 93 & 13 & 19 \\
\hline 94 & 14 & 20 \\
\hline 95 & 15 & 21 \\
\hline 96 & 16 & 22 \\
\hline 97 & 17 & 23 \\
\hline 98 & 18 & 24 \\
\hline 99 & 19 & 25 \\
\hline 9A & 1A & 26 \\
\hline 9 B & 1B & 27 \\
\hline 9 C & 1 C & 28 \\
\hline 9 D & 1 D & 29 \\
\hline 9 E & 1E & 30 \\
\hline 9F & 1F & 31 \\
\hline
\end{tabular}

\section*{Load Duty Cycle}

The Load Duty Cycle code is used to turn on and off the display, to adjust display brightness, or to modify display timing. The time slot for each character is \(8,16,32\), or 64 internal cycles (an internal cycle \(=1 / 2 \mathrm{t}_{\mathrm{CYC}}\) as selected by the Set Digit Time
codes. The segment and digit drivers for each character are on for a maximum of 13,29 , or 61 cycles with a 3 cycle inter-digit off time. The lower six bits of the Load Duty Cycle code are loaded into the Duty Cycle Register. Resultant duty cycles, on-times, and off-times are shown in Table 3.

Table 3. Load Duty Cycle Control Codes
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Code} & \multicolumn{2}{|l|}{Digit Time \(=8\)} & \multicolumn{2}{|r|}{Digit Time \(=16\)} & \multicolumn{2}{|l|}{Digit Time \(=32\)} & \multicolumn{2}{|l|}{Digit Time \(=64\)} \\
\hline & On & Off & On & Off & On & Off & On & Off \\
\hline 40 & - & 8 & - & 16 & - & 32 & - & 64 \\
\hline 41 & - & 8 & - & 16 & - & 32 & - & 64 \\
\hline 42 & - & 8 & - & 16 & - & 32 & - & 64 \\
\hline 43 & 1 & 7 & 1 & 15 & 1 & 31 & 1 & 63 \\
\hline 44 & 2 & 6 & 2 & 14 & 2 & 30 & 2 & 62 \\
\hline 45 & 3 & 5 & 3 & 13 & 3 & 29 & 3 & 61 \\
\hline 46 & 4 & 4 & 4 & 12 & 4 & 28 & 4 & 60 \\
\hline 47 & 5 & 3 & 5 & 11 & 5 & 27 & 5 & 59 \\
\hline 48 & 5 & 3 & 6 & 10 & 6 & 26 & 6 & 58 \\
\hline 49 & 5 & 3 & 7 & 9 & 7 & 25 & 7 & 57 \\
\hline 4A & 5 & 3 & 8 & 8 & 8 & 24 & 8 & 56 \\
\hline 4B & 5 & 3 & 9 & 7 & 9 & 23 & 9 & 55 \\
\hline 4C & 5 & 3 & 10 & 6 & 10 & 22 & 10 & 54 \\
\hline 4D & 5 & 3 & 11 & 5 & 11 & 21 & 11 & 53 \\
\hline 4E & 5 & 3 & 12 & 4 & 12 & 20 & 12 & 52 \\
\hline 4F & 5 & 3 & 13 & 3 & 13 & 19 & 13 & 51 \\
\hline 50 & 5 & 3 & - 13 & 3 & 14 & 18 & 14 & 50 \\
\hline 51 & 5 & 3 & 13 & 3 & 15 & 17 & 15 & 49 \\
\hline 52 & 5 & 3 & 13 & 3 & 16 & 16 & 16 & 48 \\
\hline 53 & 5 & 3 & 13 & 3 & 17 & 15 & 17 & 47 \\
\hline - & - & - & - & . & . & . & . & . \\
\hline - & - & - & . & - & . & . & - & - \\
\hline S & 5 & . & & & - & 7 & ' \(\cdot\) & S \\
\hline 5B & 5 & 3 & 13 & 3 & 25 & 7 & 25 & 39 \\
\hline 5C & 5 & 3 & 13 & 3 & 26 & 6 & 26 & 38 \\
\hline 5D & 5 & 3 & 13 & 3 & 27 & 5 & 27 & 37 \\
\hline 5E & 5 & 3 & 13 & 3 & 28 & 4 & 28 & 36 \\
\hline 5F & 5 & 3 & 13 & 3 & 29 & 3 & 29 & 35 \\
\hline 60 & 5 & 3 & 13 & 3 & 29 & 3 & 30 & 34 \\
\hline 61 & 5 & 3 & 13 & 3 & 29 & 3 & 31 & 33 \\
\hline 62 & 5 & 3 & 13 & 3 & 29 & 3 & 32 & 32 \\
\hline - & - & - & . & - & - & - & - & - \\
\hline - & - & - & . & - & - & . & - & - \\
\hline 70 & 5 & 3 & 13 & 3 & 0 & , & - & - \\
\hline 7 C & 5 & 3 & 13 & 3 & 29 & 3 & 58 & 6 \\
\hline 7D & 5 & 3 & 13 & 3 & 29 & 3 & 59 & 5 \\
\hline 7E & 5 & 3 & 13 & 3 & 29 & 3 & 60 & 4 \\
\hline 7F & 5 & 3 & 13 & 3 & 29 & 3 & 61 & 3 \\
\hline
\end{tabular}

\section*{Loaa Control Register}

There is a 5-bit control register, which can be loaded by the control word, 000XXXXX. The lower 5 bits of the control word is loaded into the control register.

The least significant two bits of the control register set the total Digit Time for each character during the refresh cycle. Four values can be set using the codes, \(8,16,32\), or 64 cycles per grid. The default value set at power-on is 64 cycles per grid. Under conditions where the display can be subjected to quick movements during viewing (e.g. portable or vehicle mounted applications) it may be necessary to increase the refresh rate by selecting 8, 16 or 32 cycles per grid with the appropriate control codes.

The middle bit of the 5 bit determines the sixteen digit or eight digit configurations. The last 2 bits select one of the four PLA Modes.

\section*{ENABLE DISPLAY MODE}

The 10955 can operate in one of eight display modes which control the maximum number of active strobes and segments and the manner in which the RAM Data Buffer is decoded onto the segment drivers.

\section*{16-Digit Configuration}

If the third bit of the control register is zero or is reset by the POR signal, the 16 -digit configuration is selected, in which case, a maximum of 16 segments and 16 strobes are provided. The 16 words in the RAM Data Buffer correspond to the 16 strobes. The 8 data bits of each word are sent to the PLA for decode.

\section*{8 Digit Configuration}

If the third bit of the control register is set, the 10955 is configured into 8 -digit mode, in which case, a maximum of 8 strobes and 24 segments are allowed. The 8 -bit words in the RAM Data Buffer are grouped into 8 word pairs which correspond to strobes STR0-STR7: 0-1, 2-3, 4-5, 6-7, 8-9, 10-11, 12-13, and 14-15. The data in the even-numbered word of each pair is loaded into the direct-output segment drivers (D0-D7), but the data in the oddnumbered word of each pair is decoded in the segment PLA decoder before being loaded into the 16 -segment output drivers (SGA-SGP).

\section*{PLA Bypass Mode}

If both of the most significant bits of the control register are zero, the PLA Bypass Mode is selected. In this mode, the PLA is bypassed. Each data word is loaded directly into the segment drivers without being decoded by the PLA. Since there are only 8 data bits but 16 drivers, each data bit is loaded into two
adjacent drivers which can be connected externally to provide twice the current drive of an individual driver. The data bits/segments selection allocation is as follows:
\begin{tabular}{|lcccccccc|}
\hline Data bit & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline Segments & \(\mathrm{O}, \mathrm{P}\) & \(\mathrm{M}, \mathrm{N}\) & \(\mathrm{K}, \mathrm{L}\) & \(\mathrm{I}, \mathrm{J}\) & \(\mathrm{G}, \mathrm{H}\) & \(\mathrm{E}, \mathrm{F}\) & \(\mathrm{C}, \mathrm{D}\) & \(\mathrm{A}, \mathrm{B}\) \\
\hline
\end{tabular}

\section*{Upper 64 PLA Mode (64U)}

In this mode (bit 5=1, bit \(4=0\) ) the Upper 64 out of the 128 codes are used, (i.e., 64 to 127). Since 64 codes can be specified by a 6 -bit word, the most significant two bits of the 8 -bit word from the RAM are not used. Another feature of this 64U-PLA mode is that the most significant two bits of the data can be brought out directly to SEGO and SEGP outputs. Therefore, the 64 codes can be decoded to the 16 -segment outputs, or only 14 -segment outputs leaving two for direct output from the RAM.

\section*{Lower 64 PLA Mode (64L)}

This mode (bit \(5=1\), bit \(4=1\) ) is similar to the Upper 64 PLA Mode, but only the lower 64 codes \((0-63)\) out of the 128 codes are used. The 64L and 64U PLA modes allow two independent sets of 64 codes to be programmed into one chip. In running the display, only one set can be selected at a time.

\section*{Fourth PLA Mode}

A fourth PLA mode is reserved for future expansion of the 10955. This code (bit \(5=0\), bit \(4=1\) ) should not be used. Selecting this PLA mode may result in non-defined characters appearing on the display.

\section*{PLA CHARACTER SET CODES}

Figure 1 shows the 16 -segment and 14 -segment driver assignments for the corresponding segmented displays. Figure 2 shows the 16 -segment and 14 -segment PLA character set patterns coded into the 10955.


Figure 1. Segment Driver Assignments
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline 00 &  & 01 & \[
\left|\begin{array}{l}
-- \\
--
\end{array}\right|
\] & 02 &  & 03 &  & 04 &  & 05 &  & 06 & \(\left.\right|_{1} ^{--}\) & 07 & \[
\left\lvert\, \begin{array}{ll}
- & - \\
1 & - \\
1 & -
\end{array}\right.
\] \\
\hline 08 & \(\mid 1--1\) & 09 &  & OA & \[
-1
\] & OB & \[
1-1
\] & OC &  & OD &  & OE &  & OF &  \\
\hline 10 & \(\left\lvert\, \begin{aligned} & -- \\ & ---1\end{aligned}\right.\) & 11 & \[
\left|\begin{array}{rr}
- & -1 \\
1 & 1
\end{array}\right|
\] & 12 &  & 13 & \[
\left|\begin{array}{l}
-\infty \\
-- \\
- \\
-
\end{array}\right|
\] & 14 &  & 15 &  & 16 & \(1 / 1\) & 17 &  \\
\hline 18 & \[
1 /
\] & 19 & \[
1 /
\] & 1A & \[
\begin{gathered}
-\pi \\
1 \\
1
\end{gathered}
\] & 1B & \[
\left.\right|_{-} ^{-}
\] & 1 C & \[
\searrow
\] & 1D & \[
\begin{array}{r}
-1 \\
-1 \\
-
\end{array}
\] & 1E & 1 & 1F & - - \\
\hline 20 & & 21 & \[
\bar{\nabla}
\] & 22 & 11 & 23 &  & 24 &  & 25 & \[
-1 /
\] & 26 & \[
\begin{aligned}
& -1 \\
& -\triangle \mid
\end{aligned}
\] & 27 & \(/\) \\
\hline 28 & ' 1 & 29 & \[
\begin{aligned}
& \ \\
& /
\end{aligned}
\] & 2A & \[
\frac{1 /}{1 /}
\] & 2 B & \(-1-\) & 2 C & \(/\) & 2D & - - & \(2 E\) & - & 2 F & \(1 /\) \\
\hline 30 & \(\left\lvert\, \begin{aligned} & 1-1 \\ & 1 \\ & -1\end{aligned}\right.\) & 31 & 1 & 32 & --
\(-\quad-1\)
--1 & 33 & \[
\left.\begin{aligned}
& - \\
& - \\
& - \\
& - \\
& -
\end{aligned} \right\rvert\,
\] & 34 & ---| & 35 & \begin{tabular}{|l|}
-- \\
--1 \\
--1
\end{tabular} & 36 &  & 37 & \(--1\) \\
\hline 38 & \[
\left|\begin{array}{ll}
- & - \\
- & - \\
- & -
\end{array}\right|
\] & 39 & \[
\left.\begin{array}{ll}
- & - \\
- & -1 \\
- & -
\end{array} \right\rvert\,
\] & 3A &  & 3B &  & 3 C & \(1 /\) & 3D & \[
\begin{aligned}
& -- \\
& --
\end{aligned}
\] & 3E & \[
\begin{aligned}
& 1 \\
& -- \\
& \hline
\end{aligned}
\] & \(3 F\) & --1
-1 \\
\hline
\end{tabular}

16-Segment PLA Patterns


14-Segment PLA Patterns
Figure 2. 16- and 14-Segment PLA Character Sets

\section*{PACKAGE DIMENSIONS}

\section*{40-PIN PLASTIC DIP}

\begin{tabular}{|c|c|c|c|c|}
\hline \multirow{3}{*}{} & \multicolumn{2}{|c|}{ MILLIMETERS } & \multicolumn{2}{|c|}{ INCHES } \\
\cline { 2 - 5 } DIM & MIN & MAX & MIN & MAX \\
\hline A & 5128 & 5232 & 2040 & 2060 \\
\hline B & 1372 & 1422 & 0540 & 0560 \\
\hline C & 355 & 508 & 0140 & 0200 \\
\hline D & 036 & 051 & 0014 & 0020 \\
\hline F & 102 & 152 & 0040 & 0060 \\
\hline G & 254 BSC & \multicolumn{2}{|c|}{0100 BSC } \\
\hline H & 165 & 216 & 0065 & 0085 \\
\hline J & 020 & 030 & 0008 & 0012 \\
\hline K & 305 & 356 & 0120 & 0140 \\
\hline L & 1524 & BSC & \multicolumn{2}{|c|}{0600} \\
\hline M & \(7^{\circ}\) & \(10^{\circ}\) & \multicolumn{2}{|c|}{\(7^{\circ}\)} \\
\hline N & 051 & 102 \\
\hline
\end{tabular}

\section*{SECTION 6 \\ MICROCOMPUTER DEVELOPMENT SYSTEMS}
Page
Product Family Overview ..... 6-2
RDC-1001/2 Multiple Target Development System (MTDS) ..... 6-3
RDC-3101/2 Low Cost Emulator (LCE) ..... 6-9
RDC-3XX Rockwell Design Center R6500/* Personality Set ..... 6-14
RDC-502, RDC-504 and RDC-509 Rockwell Design Center R6502-R65C02 Personality Set ..... 6-18
RDC-2000 R6500 Cross Assembler for Intel Development System ..... 6-22
RDC-2005 R6500 Cross Assembler for Intel Personal Development System ..... 6-24
RDC-1020, RDC-1022 and RDC-1024 Rockwell Design Center 8K/32K/64K Target RAM Module ..... 6-26
RDC-1030 Multiple Target Development System PROM Programmer Module ..... 6-30
Software Preparation System
SPS-200 Software Preparation System Peripheral Connector Module ..... 6-36

\section*{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 new Low Cost Emulator (LCE) system links popular personal computers (PCs) to your application. Code is developed on the PC, downloaded to LCE, and it runs in-circuit emulation in your application. LCE also accepts downloads from other manufacturers development systems via cross assemblers.

The AIM 65 microcomputer 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


Rockwell Design Center Development System
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.


Low Cost Emulator System

\title{
RDC-1001/2 MULTIPLE TARGET DEVELOPMENT SYSTEM (MTDS)
}

\section*{INTRODUCTION}

The Multiple Target Development System (MTDS) is a development system vertically integrated to support the entire R6500 family of microprocessors and microcomputers. The MTDS 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 MTDS is a disk-based system with two 96 TPI, doubled-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 ) for the target bus which supports the emulator device. Construction of the MTDS 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 MTDS 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 MTDS to enter the mode of operation desired.

\section*{SYSTEM FEATURES}
- Modular construction based on proven RM 65 architecture
- 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
- Separate system and target memory map
- Two serial ports-one for MTDS terminal interface-one for host system download
- Two parallel ports-one for MTDS 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
- Requires only Personality Set for complete in-circuit debugging

For users who already have an Intel Development System (IDS) with mass storage program management, an R6500 crossassembler is available. This allows the MTDS to function as a satellite, providing a powerful debug system. The MTDS 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 MTDS is a powerful emulation system for the complete family of Rockwell R6500/* one-chip microcomputers or NMOS R6502 and CMOS R65C02 families of microprocessors. The multiple target bus structure of the MTDS allows the user to emulate four devices concurrently, and at different speeds.


Multiple Target Development System (MTDS)
- Self-contained, disk-based operating system
- Softkey function access to menu-driven operational modes
- Disk based Text Editor
- Disk based R6500 Macro Assembler with all instruction subsets
- SYSGEN configurable to user environment
- Automatic power-up initialization of system and configurations
- Separate system and target memory map
- Allows Real-time in-circuit emulation, up to 4 MHz
- Five hardware breakpoints per target, 32-bits ( 16 addr, 8 data and 8 control) wide with "don't care" bits
- External trigger input allows TTL level to cause a user breakpoint
- Configurable as a satellite for an IDS host system or Rockwell System 65

\section*{PRODUCT OVERVIEW}

The MTDS 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.

\section*{FUNCTION DESCRIPTION}

\section*{Major Components and Interfaces}

The block diagram shows the architecture of the MTDS 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 MTDS system through one of the RS-232C ports (J3 connected to the ACIA module). The CRT interfaces with the MTDS system through a parallel port (J3 connected to the MPI module). The disk drives interface to the MTDS system through a separate port (J2 connected to the FDC module). All other control functions of the MTDS system interface directly through the MTDS system bus. Note that the Personality Set PMC module interfaces the MTDS system bus to the target bus.

\section*{Bus Structure}

The MTDS system operates through a multiple bus structure-a system bus and four target busses. The system bus contains 21 card slots to accommodate singe Eurocard modules or


MTDS 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 MTDS microcomputer system modules such as the 32K 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 \mathrm{~K} \times 8\), \(32 \mathrm{~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 MTDS 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 MTDS 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.


\section*{Operating Modes}

The MTDS 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
SYSGEN
HELP
These Softkey prompts represent the primary modes of operation for the MTDS 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 MTDS as a satellite to the host system (Intel ISIS II)

LOCAL -This mode provides the menus available to the user from within the MTDS 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:

\section*{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.

\section*{Software Command Overview}
\begin{tabular}{|ll|}
\hline \multicolumn{2}{|l|}{ SYSGEN FUNCTIONS } \\
BAUD & Select baud rate for host interface \\
WORD LEN & Select word length for host interface \\
PARITY & Select parity for host interface \\
STOP BITS & Select stop bits for host interface \\
TARGET & Select the processor type emulating for each of the targets \\
PROTOTYPE & Select areas to be mapped external for each target \\
PRINTER & Set up paging parameters for parallel pronter \\
BEEPER & Turn on or off the BELL to indicate errors \\
DISPLAY & Show the current sysgen setup parameters \\
KEEP & Save the current sysgen parameters onto system disk \\
UTILITY FUNCTIONS \\
COPY & Copy diskettes \\
BACKUP & Copies disk files \\
FORMAT & Format new diskette \\
INITIALIZE & Initalize diskette directory \\
DIRECTORY & List or Print diskette directory \\
LIST & List fole to printer, screen or disk file \\
DELETE & Remove disk file \\
RECOVER & Recover deleted disk file \\
RENAME & Rename disk file \\
EXEC & Executive a disk-based utility (i.e. Text Editor, Macro \\
& Assembler, etc.) \\
DOWNLOAD & Transfer object file from host computer (System 65 or Intel ISIS)
\end{tabular}

\section*{DEBUG FUNCTIONS}

DUMP Show an image of user memory (Hex and ASCII)
MODIFY Allow changes to user memory (Hex and ASCII)
DISASSM Disassemble selected area of user memory
LOAD Load selected area of user memory with object code file
SAVE Save selected area of user memory to disk file
VERIFY Verify contents of user memory with data in disk file
PROTECT Set and clear areas to be write protected
RUN Execute at normal speed until any breakpoint condition occurs
STEP Execute user program displaying every instruction and register
RESET Reset all debut parameters and hardware
REGISTER Show and accept changes to, load or save emulator registers
BREAKPOINT Show and accept changes to the breakpoint conditions

\section*{INTERFACE}

Interface between the MTDS 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 MTDS system through two cables with mating connectors on each end that are keyed
for proper installation. The MTDS 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 MTDS MAINFRAME CONNECTORS J1 THROUGH J4 AND HAVE CONNECTORS ON THE OTHER END THAT MATE TO THE MODULES.

MTDS Mainframe Internal/External RIbbon Cable Connections

\section*{SPECIFICATIONS}
\begin{tabular}{|c|c|c|c|}
\hline \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{MTDS Mainframe} & \multicolumn{2}{|c|}{MTDS Terminal} \\
\hline & & CRT/FDD & Keyboard \\
\hline \begin{tabular}{l} 
Dimenslons \\
Height \\
Width \\
Depth \\
\hline
\end{tabular} & 11 in. ( 2794 cm ) 20 in. ( 50.80 cm ) \(18 \mathrm{in} .(45.72 \mathrm{~cm})\) & 14 in. ( 35.56 cm ) 20 in . \((50.80 \mathrm{~cm}\) ) 16 in. ( 40.64 cm ) & 3 in. ( 7.62 cm ) 20 in. ( 50.80 cm ) 8 in. ( 20.32 cm ) \\
\hline Welght & 40 lbs . 18 Kg ) & \(42 \mathrm{lbs}.(19 \mathrm{Kg})\) & \(6 \mathrm{lbs} .(2.7 \mathrm{Kg})\) \\
\hline \begin{tabular}{l}
Electrical AC Input Voltage \\
AC Frequency Fuse Requirement
\end{tabular} & \begin{tabular}{l}
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)
\end{tabular} & \multicolumn{2}{|c|}{\begin{tabular}{l}
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)
\end{tabular}} \\
\hline \begin{tabular}{l}
Environmertai \\
Temperature With/Disk Media Humidity
\end{tabular} & \multicolumn{3}{|c|}{\(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} \\
\hline \multicolumn{4}{|c|}{NOTE: *Disk media maximum wet bulb temperature \(84.9{ }^{\circ} \mathrm{F}\left(29.4{ }^{\circ} \mathrm{C}\right)\)} \\
\hline
\end{tabular}

\section*{ORDERING INFORMATION}
\begin{tabular}{|l|l|}
\hline Part Number & \multicolumn{1}{c|}{ Description } \\
\hline RDC-1001 & MTDS System (100 Vac)(1) \\
RDC-1002 & MTDS System (220 Vac)(1) \\
RDC-1020 & 64K Target RAM Module \\
RDC-1022 & 32K Target RAM Module \\
RDC-1024 & 8K Target RAM Module \\
RDC-1030 & PROM Programmer Module \\
RDC-2000 & R6500 Cross Assembler for Intel IDS \\
\hline Order Number(2) & \multicolumn{1}{|c|}{ Document Title } \\
\hline RDC06 & RDC R6500/* Personality Set Data Sheet \\
RDC09 & R6500 Cross Assembler for IDS Data \\
& Sheet \\
RDC11 & RDC R6502-R65C02 Personality Set \\
& Data Sheet \\
RDC12 & MTDS PROM Programmer Data Sheet \\
\hline Notes: & \\
(1) Both system configurations are shipped with the following \\
components: \\
- MTDS Mainframe \\
- MTDS Terminal with 12" CRT and Dual 51/4" Floppy Disk \\
Drives and detached Keyboard \\
- Six System Control modules-ACIA, FDC, SBC, MPI, \\
and two 32K DRAM \\
- All Required Interface Cables \\
- Software Package (Utilities, Text Editor, Macro \\
Assembler) \\
- Documentation Package \\
(2) Documents provide further information about the MTDS system. \\
\hline
\end{tabular}

\section*{PERSONALITY SETS}

Personality Sets are available for the MTDS 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:
\begin{tabular}{|c|c|c|c|}
\hline - R6500/11P & - R6500/41P & R6502 & 07 \\
\hline - R6500/12P & - R6501Q & - R6506 & R6515 \\
\hline - R6541Q & - R65C112 & - R6514 & - R6500/15P \\
\hline - R65C102 & - R6505 & - R6500/1P & - R6500/16Q \\
\hline - R6504 & - R6513 & - R6511Q & \\
\hline - R6512 & - R6500/42P & - R65C02 & \\
\hline - R6500/13P & - R6500/43P & - R6503 & \\
\hline
\end{tabular}

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.

\section*{RDC-3101/2 LOW COST EMULATOR (LCE)}

\section*{INTRODUCTION}

The Low Cost Emulator (LCE) is a development system vertically integrated to support the entire R6500 family of microprocessors and microcomputers. The LCE allows emulation, development, and software debugging of microprocessors and microcomputers of the R6500 family.

A unique bus structure provides a separate system bus and target bus which can operate at different speeds (up to 4 MHz ) for the target bus which supports the emulator device. Construction of the LCE 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. Additional slots allow expansion.
Featuring Softkey function keys, the LCE 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 LCE to enter the mode of operation desired.

For users who already have an Intel development system with mass storage program management, an R6500 cross-assembler is available. This allows the LCE to function as a satellite, providing a powerful debug system. The LCE 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 LCE is a powerful emulation system for the complete family of Rockwell R6500/* onechip microcomputers or NMOS R6502 and CMOS R65C02 families of microprocessors.


Low Cost Emulator (LCE)

\section*{FEATURES}
- Compact desktop modular design construction allows future options
- SYSGEN configurable to user environment
- Front panel reset switch with 'warm' option to maintain SYSGEN parameters
- Two serial ports-one for terminal interface-one for host system download or other peripheral devices
- Serial port options for eight baud rates 110 to 19.2 K with choice of 7 - or 8 -bit word length
- Software allows choice of any baud rate, word length or parity options with full handshake signal support from the R6551 ACIA device
- Target emulation of any R6500 multichip or single-chip MPU device
- 24K-byte ROM includes system, debug and self-test firmware
- 10K-byte RAM with 8 K bytes for symbol table generation
- Internal default switch/LED panel with software for system troubleshooting
- Self-contained, ROM-based operating system
- Softkey function acress to menu-driven operational modes
- R6500 Assembler with all instruction subsets
- Separate system bus and target bus with independent processor
- Allows real-time in-circuit emulation, up to 4 MHz
- Five hardware breakpoints, 32-bits wide (16 address, 8 data 8 control) with "don't care" mask for each bit
- Two hardware matchpoints allow execution to continue with external TTL level trigger signals
- External trigger input allows TTL trigger to cause a user breakpoint
- Configurable as a satellite for any host system including the Rockwell System 65
- Designed for add-on PROM programmer option
- Requires only Personality Set and user supplied terminal for full operation

\section*{PRODUCT OVERVIEW}

The LCE mainframe contains the following components:
- The card cage/backplane with system bus and target bus
- Power supply and system cooling fan
- Single Board Computer (SBC) module (2K RAM, 8K ROM)
- Universal memory module for system memory (8K RAM, 16K ROM)
- Asynchronous Communications Interface Adapter (ACIA) module with 2 channels preconfigured for terminal and host interfaces
- 28-pin PROM socket for optional PROM Programmer module
- Personality Set Module Controller (PMC) with cables to connect a R6500/* or R6502-R65C02 Personality Set

\section*{FUNCTIONAL DESCRIPTION}

\section*{MAJOR COMPONENTS AND INTERFACES}

The block diagram shows the architecture of the LCE system and identifies the relationship between the system bus and the target busses.

\section*{Bus Structure}

The LCE system operates through a multiple bus structure-a system bus and target bus. The system bus contains 4 card slots to accommodate single eurocard modules and 2 card slots for 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 LCE microcomputer system modules such as the universal RAM, SBC, and ACIA.

The target bus contains two single card slots and two double slots shared with the system bus. The double card slots are intended for a Personality Module Controller (PMC) module and future growth up to an Analyzer module. The single card slot is intended for plugging in a target emulation RAM module ( 8 K \(\times 8,32 \mathrm{~K} \times 8\), or \(64 \mathrm{~K} \times 8\) depending upon the microcomputer to be emulated). The target bus is color coded red on the LCE card cage for easy identification of the division of the target bus segment.

A typical LCE configuration consists of an R6500/* or R6502-R65C02 Personality Set, Personality Pod, and Emulator Interface) and a target RAM module.


\section*{Operating Modes}

The LCE bootstrap ROM is initiated whenever the system is powered-up. The program then loads the SYSGEN data and system program from the system ROM. When the initialization is completed the console device displays a Softkey menu. It is this menu that prompts the user to select the mode of operation required. The Softkey prompts displayed at this time are:
\[
\begin{array}{llll}
\text { 1:SYSGEN } & \text { 2:MEMORY } & \text { 3:EMULATE } & \text { 4:SYMBOL } \\
\text { 5:TERMINAL } & \text { 6:PROM } & \text { 7:TRACE } & \text { 8:SPEED }
\end{array}
\]

These Softkey prompts represent the primary modes of operation for the LCE system. When the function key corresponding to the prompt location is pressed, one of the following modes is selected:

SYSGEN - This mode allows the user to modify the ROMstored system parameters on either a permanent (until another power-up condition) or a temporary basis.

MEMORY - This mode allows the user to display or modify the contents of Target as well as Prototype memory.

EMULATE - This mode provides all the functions for controlling run-time characteristics and emulation.

SYMBOL - This mode contains the functions which control the generation and use of symbol tables as it relates to MEMORY functions.

TERMINAL - This mode echoes each character entered from the console device to the host system.

PROM - This mode selects the command options for the optional PROM Programmer module.

TRACE - This mode selects the command options for the optional TRACE module.

SPEED - This mode selects the speed of dump and disassemble data being displayed to the console.

Each Softkey prompt, when selected by the number key, invokes a new set of Softkey prompts which further define the tasks to be performed by the mode. As an example, if the SYSGEN prompt is selected, a new Softkey prompt menu displays:
\begin{tabular}{llll} 
1:PORT1 & 2:PORT2 & 3:TARGET & \\
4:PROTECT & 5:BEEPER & 6:DISPLAY & 7:EXIT
\end{tabular}

If PROTECT is selected from this prompt, a new menu displays:

\section*{1:PROTECT 2:UNPROTECT 3:CLEARALL 4:DISPLAY}

This hierarchy continued 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 \(\emptyset\) or - (minus) key.


\section*{Software Command Overview}
\begin{tabular}{ll} 
SYSGEN FUNCTIONS & \\
BAUD & Select baud rate and parity options \\
WORD LEN & Select serial word length \\
DELAY & Set delay after linefeed between 0 to 99 mS \\
FORMAT & Set record format for data files (;,:, or Block) \\
START CHAR & Set start of file marker character \\
STOP CHAR & Set end of file marker character \\
SYSTEM & Select the system console port \\
TARGET & Select the processor type for emulation \\
PROTOTYPE & Select areas to mapped external of LCE target memory \\
PROTECT & Set and clear areas to be write protected \\
BEEPER & Turn on or off the BELL to indicate errors \\
DISPLAY & Show the current sysgen setup parameters \\
EXIT & Accept the current sysgen parameters and exit to primary menu
\end{tabular}

\section*{DEBUG FUNCTIONS}

DUMP Show a screen image at user memory (Hex and ASCII)
MODIFY Show user memory and allow changes (Hex or ASCII)
ASSEMBLER Assemble op code text into user memory
DISASSM Dissassemble op code image of user memory
LOAD . Load a file image into user memory
SAVE Save a file image of user memory
VERIFY Verify a file image with user memory
STEP Execute user program displaying every instruction and associated registers
RUN Execute user program at full speed until any break condition occurs
SNAPSHOT Execute user program displaying only breakpoint instructions and registers
MATCH Execute user program at full speed until a break condition (except BP1 or BP2)
RESET Reset all debug parameters and hardware
BREAK Show and accept changes to the breakpoint conditions

\section*{MISCELLANEOUS FUNCTIONS}
\begin{tabular}{ll} 
LIST & Show the user symbol table \\
CREATE & Adapt labels changes to the symbols tables \\
LOADSYM & Load a file image of the symbol table \\
SAVESYM & Save a file image of the symbol table \\
CLRSYM & Clear out the present user symbol table \\
SYMBOL & Turn on or off the user of labels in disassembly \\
OBJECT. & Turn on or off the creation of object code field in disassembly \\
SHOW & Show status of symbolic options \\
SPEED & Control the rate of display update \\
TERMINAL & Allow transfer between port 1 and port 2 directly \\
PROM & Future option-PROM Programmer module \\
TRACE & Future option-Trace module
\end{tabular}

\section*{INTERFACE}

Interface between the LCE system control modules and the port connectors on the front panel are made through ribbon cables. The ribbon cables are permanently attached to the port
connectors. The LCE Cable Interface figure shows how these cables are routed in the system. The Self-Test Panel mates to the SBC module I/O connector. The optional PROM programmer module connects to the PROM socket through a single ribbon cable.

\section*{SPECIFICATIONS}
\begin{tabular}{|c|c|}
\hline Parameter & LCE Mainframe \\
\hline \begin{tabular}{l}
Dimensions \\
Height \\
Width \\
Depth
\end{tabular} & \[
\begin{aligned}
& 5 \mathrm{in} .(12.7 \mathrm{~cm}) \\
& 14 \mathrm{in} .(35.56 \mathrm{~cm}) \\
& 10 \mathrm{in} .(25.4 \mathrm{~cm})
\end{aligned}
\] \\
\hline Weight & \(20 \mathrm{lbs} .(9 \mathrm{~kg}\) ) \\
\hline \begin{tabular}{l}
Electrical AC Input Voltage \\
AC Frequency Fuse Requirement
\end{tabular} & \begin{tabular}{l}
105 to 125 (RDC-3101) \\
210 to 250 (RDC-3102) \\
47 to 63 Hz \\
3 A slo-blo (RDC-3101) \\
1.5 A slo-blo (RDC-3102)
\end{tabular} \\
\hline Environmental Temperature With/Disk Media Humidity & \(59^{\circ} \mathrm{F}\) to \(104^{\circ} \mathrm{F}\left(15^{\circ}\right.\) to \(\left.40^{\circ} \mathrm{C}\right)\) operatıng \(-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.150^{\circ} \mathrm{C}\right)\) storage 20\% to 80\% non-condensing operating \(1 \%\) to \(95 \%\) non-condensing shipping \(1 \%\) to \(95 \%\) non-condensing storage \\
\hline
\end{tabular}

\section*{ORDERING INFORMATION}
\begin{tabular}{|l|l|}
\hline Part Number & \multicolumn{1}{|c|}{ Description } \\
\hline RDC-3101 & LCE System (100 Vac)(1) \\
RDC-3102 & LCE System (220 Vac)(1) \\
RDC-1020 & 64K Target RAM Module \\
RDC-1022 & 32K Target RAM Module \\
RDC-1024 & 8K Target RAM Module \\
RDC-3030 & PROM Programmer Module \\
RDC-2000 & R6500 Cross Assembler for IDS \\
RDC-2005 & R6500 Cross Assembler for PDS \\
\hline \multicolumn{1}{|c|}{ Document Title } \\
\hline \multicolumn{1}{|c|}{ RDC06 } & RDC R6500/* Personality Set Data Sheet \\
RDC11 & RDC R6502-R65C02 Personality Set Data \\
RDC09 & Sheet \\
RDC23 & R6500 Cross Assembler for IDS Data Sheet \\
R6500 Cross Assembler for PDS Data Sheet \\
\hline
\end{tabular} \begin{tabular}{l} 
Notes: \\
(1) Both system configurations are shipped with the following \\
components: \\
- LCE Mainframe \\
- Three System Control modules-ACIA, SBC, and Universal \\
RAM \\
- PMC and all Required Interface Cables \\
- Documentation Package \\
(2) Documents provide further information about the LCE system. \\
\hline
\end{tabular}

\section*{PERSONALITY SETS}

Personality Sets are available for the LCE that allow emulation, development, and software debugging of the complete family of R6500/* Microcomputers and R6502-R65C02 Microprocessors. The microcomputers and microprocessors supported by Personality Sets are:
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{2}{|c|}{R6500/*} & \multicolumn{2}{|l|}{R6502-R65C02} \\
\hline - R6500/1P & - R6500/41P & - R6502 & - R6512 \\
\hline - R6500/11P & - R6500/42P & - R6503 & - R6513 \\
\hline - R6500/12P & - R6500/43P & - R6504 & - R6514 \\
\hline - R6500/13P & - R6501Q & - R6505 & - R6515 \\
\hline - R6500/15P & - R6511Q & - R6506 & - R65C02 \\
\hline - R6500/16Q & - R6541Q & - R6507 & - R65C102 \\
\hline & & & - R65C112 \\
\hline
\end{tabular}

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.

\section*{TYPICAL SYSTEM CONFIGURATION}

A typical LCE order should consist of the following

(1) Refer to RDC06 for ordering information
(2) Refer to RDC11 for ordering information

These components and a user supplied terminal are all that is required for full in-circuit emulation.

\section*{0 Rockwell}

\title{
RDC-3XX ROCKWELL DESIGN CENTER (RDC) R6500/* PERSONALITY SET
}

\section*{INTRODUCTION}

The RDC R6500/* Personality Set is a Rockwell Design Center (RDC) option that allows the Multiple Target Development System (MTDS) or Low Cost Emulator (LCE) user to develop, debug and verify programs intended for use by any R6500 onechip 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 NMOS family of onechip microcomputers.

The basic MTDS 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 MTDS or LCE with a dual CPU capability. This added feature permits the MTDS or LCE CPU to maintain control and check for breakpoint conditions while the R6500/* CPU is executing a user 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 MTDS.

\section*{FEATURES}
- Disk-based debug monitor and macro assembler (MTDS)
- ROM-based debug monitor and assembler (LCE)
- Real-time in-circuit emulation up to 2 MHz
- Supports full 65K address range for user in prototype or target environment
- Five hardware breakpoints with 2 SYNC outputs for oscilliscope or logic analyzer triggers
- User defined input for external break signal
- Single step through interrupts
- Supports four target developments (MTDS)
- No zero page address conflicts between user and system
- Power down capability
- RAM write protection/detection on 16 byte boundaries
- User or system supplied power and clock
- Supports \(8 \mathrm{~K} / 32 \mathrm{~K} / 64 \mathrm{~K}\) target RAM for user emulation memory (optional)


RDC R6500/* Personality Set


System Interconnection

\section*{EXECUTION COMMAND SUMMARY}

The R6500/* Personality Set is designed to allow the R6500/* to execute independent of the MTDS or LCE. Thus, while the R6500/* is executing code, the MTDS or LCE CPU is still in operation. This allows certain functions to be performed by the MTDS or LCE CPU without disturbing the execution of the R6500/*.

The R6500/* Personality Set hardware supports the LCE and MTDS debug software in the following commands:

\section*{Memory Functions}

Dump memory in Hex and ACSII format
Modify or alter selected memory locations in Hex or ASCII
Examine/modify RAM and I/O one byte at a time (LCE)
Assemble or code text into text memory (LCE)
Disassemble or code image of user memory
Load an object code file into user memory
Save an object file from user memory
Verify an object file with memory
Write protect memory blocks
Select memory areas to be prototype or target environment

\section*{Execution Functions}

Step through a user program displaying instructions and registers
Run through a program at full execution speed stopping at at breakpoints
Run at full speed with breakpoint signals on Sync connectors (LCE)
Reset the debugger
Examine or alter the registers
Set or modify hardware breakpoints

\section*{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 LCE configurations do not include a PMC or interconnect cable set because these are already installed as part of the LCE system. The RDC Personality Sets are unbundled without the \(8 \mathrm{~K} / 32 \mathrm{~K} / 64 \mathrm{~K}\) Target RAM option. This option is needed with typical emulation configurations.

R6500/* Personality Sets
\begin{tabular}{|c|c|c|}
\hline \multicolumn{2}{|c|}{Part Number} & \multirow[b]{2}{*}{Description} \\
\hline MTDS & LCE & \\
\hline RDC-302 & RDC-309 & R6500/11, /15 Personality Set, 1 or 2 MHz \\
\hline RDC-312 & RDC-319 & R6500/12, /16 Personality Set, 1 or 2 MHz \\
\hline RDC-322 & RDC-329 & R6500/13 Personality Set, 1 or 2 MHz \\
\hline RDC-332 & RDC-339 & R6500/41 Personality Set, 1 or 2 MHz \\
\hline RDC-342 & RDC-349 & R6500/42 Personality Set, 1 or 2 MHz \\
\hline RDC-352 & RDC-359 & R6500/43 Personality Set, 1 or 2 MHz \\
\hline RDC-362 & RDC-369 & R6500/1 Personality Set, 1 or 2 MHz \\
\hline \multicolumn{3}{|l|}{Note: MTDS version includes PMC and cables.} \\
\hline
\end{tabular}


Typical R6500/* Personality Set Hardware Components

\section*{DEVICE ADAPTERS}

The Adapter/Emulator Devices are used to reconfigure RDC 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.
\begin{tabular}{|c|l|}
\hline Part Number & \multicolumn{1}{|c|}{ Description } \\
\hline RDC-212 & \begin{tabular}{l} 
Adapter/Emulator Device \\
(R6511AQ) for R6500/11/12/13/15/16, 1 or 2 MHz \\
RDC-222
\end{tabular} \\
\begin{tabular}{l} 
Adapter/Emulator Device \\
(R6541AQ) for R6500/41/42/43, 1 or 2 MHz
\end{tabular} \\
RDC-232 & \begin{tabular}{l} 
Adapter/Emulator Device \\
(R6500/1EAC) for R6500/1, 1 or 2 MHz
\end{tabular} \\
\hline
\end{tabular}

\section*{IN-CIRCUIT EMULATION PROBES}

The In-Circuit Emulation Probe assemblies used to reconfigure the RDC Personality Sets for use with other R6500/* Microcomputers are shown in the chart below.
\begin{tabular}{|l|l|}
\hline Part Number & \multicolumn{1}{|c|}{ Description } \\
\hline RDC-200 & 40-Pin Probe and cable for \\
& R6500/11P/15P. Prerequisite, RDC-212 \\
RDC-201 & 64-Pin Probe and cables for \\
& R6500/12Q/16Q. Prerequisite, RDC-212 \\
RDC-202 & 64-Pin Probe and cables for \\
& R6500/13Q. Prerequisite, RDC-212 \\
RDC-203 & 40-Pin Probe and cable for \\
& R6500/41P. Prerequisite, RDC-222 \\
RDC-204 & 64-Pin Probe and cables for \\
& R6500/42Q. Prerequisite, RDC-222 \\
RDC-205 & 64-Pin Probe and cables for \\
& R6500/43Q. Prerequisite, RDC-222 \\
RDC-206 & 40-Pin Probe and cable for \\
& R6500/1P. Prerequisite, RDC-232 \\
\hline
\end{tabular}

\section*{RDC-502, RDC-504 AND RDC-509 ROCKWELL DESIGN CENTER R6502-R65C02 PERSONALITY SET}

\section*{INTRODUCTION}

The RDC R6502-R65C02 Personality Set is a Rockwell Design Center (RDC) option that allows the Multiple Target Development System (MTDS) or Low Cost Emulator (LCE) user to develop, debug and verify programs intended for use by any R6500 one-chip microprocessor system. The R6502R65C02 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 MTDS R6502-R65C02 Personality Set includes a Personality Module Controller (PMC), two Personality Emulator Pod Modules, two emulator devices (R6502, and R65C02), two prototype-to-pod interface cables, an interconnect cable set, and the required software and support documentation.

The R6502-R65C02 Personality Set provides the MTDS and LCE with a dual CPU capability. This added feature permits the MTDS and LCE CPU to maintain control and check breakpoint conditions, even while the microprocessor is executing a user 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 MTDS.

\section*{FEATURES}
- ROM-based debug monitor and assembler (LCE)
- Disk-based debug monitor and macro assembler (MTDS)
- Real-time in-circuit emulation up to 4 MHz
- Supports full 65K address range for user in prototype or target environment
- Five hardware breakpoints with 2 SYNC outputs for oscilliscope or logic analyzer triggers
- User defined input for external break signal
- Single step through interrupts
- Supports four target developments (MTDS)
- No zero page address conflicts between user and system
- Power down capability
- RAM write protection/detection on 16 byte boundaries
- User or system supplied power and clock
- Supports \(8 \mathrm{~K} / 32 \mathrm{~K} / 64 \mathrm{~K}\) target RAM for user emulation in system (optional)


RDC R6502-R65C02 Personality Set


\section*{System Interconnection}

\section*{EXECUTION COMMAND SUMMARY}

The R6502-R65C02 Personality Set is designed to allow R650X, R651X or R65XXX devices to execute independent of the MTDS or LCE. Thus, while the emulator is executing code, the CPU is still in operation. This allows certain functions to be performed by the MTDS or LCE CPU without disturbing the execution of the emulator device.

The R65C02 Personality Set hardware supports the LCE and MTDS debug software in the following commands:

\section*{Memory Functions}

\footnotetext{
Dump memory in Hex and ACSII format
Modify or alter selected memory locations in Hex or ASCII
Examine/modify RAM and I/O one byte at a tıme (LCE)
Assemble or code text into text memory (LCE)
Disassemble or code image of user memory
Load an object code file into user memory
Save an object file from user memory
Verify an object file with memory
Write protect memory blocks
Select memory areas to be prototype or target environment
}

\section*{CONFIGURATIONS}

The RDC Personality Sets for the R6502-R65C02 Microprocessors, shown in the chart below, include 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. In the LCE configuration, the PMC and interconnect cables are already installed in the LCE as part of the system package.

R6502-R65C02 Personality Sets and Memory
\begin{tabular}{|c|l|}
\hline Part Number & \multicolumn{1}{|c|}{ Description } \\
\hline RDC-502 & R6502-R65C02 Personality Set, 1-2 MHz \\
RDC-509 & \begin{tabular}{l} 
R6502-R65C02 Personality Set, 1-2 MHz \\
(LCE only)
\end{tabular} \\
& RDC-1020 \\
64K RAM Target Memory, 1-3 MHz \\
RDC-1022 & 32K RAM Target Memory 1-3 MHz \\
RDC-1024 & 8K RAM Target Memory, 1-3 MHz only \\
\hline
\end{tabular}


Typical R6502-R65C02 Personality Set Hardware Components

R6502-R65C02 Personality Set Component List
\begin{tabular}{|c|c|c|}
\hline QUANTITY & ITEM & DESCRIPTION \\
\hline 1 & PMC Module & Controller module that plugs into the MTDS and LCE Mainframe. (MTDS only, PMC is installed in LCE when system is shipped.) \\
\hline 1 & Emulator Pod Module Assembly & Pod that contains EPM-1 and EPM-2, a short ribbon cable, a six-wire power cable, and the R6502 Emulator Device. \\
\hline 1 & Emulator Package & Package contains the R6512, R65C02, R65C102 and R65C112 Emulator devices and 5 jumper headers for the 28 -pin processors. \\
\hline 2 & PMC to Pod Interface Ribbon Cables (Long Length) & One cable with \(60-\mathrm{pin}\) connector on each end with one cable with a 50 -pin connector on each end. (MTDS only, cables installed in LCE prior to shipment). \\
\hline \multirow[t]{2}{*}{2} & Prototype-to-Pod Interface Cables (Medium Length) & \begin{tabular}{l}
One of two possible configurations: \\
a. One ribbon cable with 40 -pin connectors on each end. Used for emulating the R6502, R6512, R65C02, R65C102 or R65C112.
\end{tabular} \\
\hline & & b. One cable with a 28 -pin connector on each end. Used for emulating the R6503, R6504, R6505, R6506, R6507, R6513, R6514 or R6515. \\
\hline
\end{tabular}

\section*{RDC-2000 R6500 CROSS ASSEMBLER FOR INTEL DEVELOPMENT SYSTEM}

\section*{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 Multiple Target Development System (MTDS) or Target Emulator Workstation (TEW) 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), an arithmetic operator (if required) and an optional comment. Constants are 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.

\section*{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 MTDS or TEW 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 MTDS or TEW main frame to maximize the utility of one Intel Development System and MTDS or TEW. 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.

\section*{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 MTDS or TEW
- Operator selected assembly/error listing output
-Display/Printer
-Printer
-Floppy Disk
- Assembler directives
- Symbolic cross-reference
- Communications support-downloading of object code

\section*{ORDERING INFORMATION}
\begin{tabular}{|l|c|}
\hline Part No. & Description \\
\hline RDC-2000 & \begin{tabular}{c} 
R6500 Cross Assembler for Intel Development \\
System Disk (8" ISIS II compatible disk)
\end{tabular} \\
\hline Order No. & Description \\
\hline RDC02 & \begin{tabular}{c} 
R6500 Cross Assembler for Intel Development \\
System User's Manual (included with RDC-2000)
\end{tabular} \\
\hline
\end{tabular}

\section*{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 ( 14 K ) and the cross assembler (18K).

\section*{Assembler Directives}
\begin{tabular}{clll} 
Assembly Listing Control & & \\
.TTL & Title & .WIDTH & Line Length \\
.PAGE & Page & .SKIP & Skip \\
.LINE & Page Length & &
\end{tabular}

\section*{Data Storage}
.BYTE .WORD .DBYTE .SBYTE

\section*{Equate}
\(=\quad\) Assign value to symbol

\section*{Error Codes}

\section*{Pass 1}

1 OPERAND VALUE IS INVALID OR GT HEX FFF
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
11 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-\$ F F\) )
15 ILLEGAL INSTRUCTION FOR THIS ASSEMBLER

\section*{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
0 MISSING LABEL FOR EQUATE
1 OPERAND LABEL GREATER THAN 6 CHARACTERS LONG .MOD VALUE IS INCORRECT FOR THIS ASSEMBLER
OPERAND NOT BETWEEN 0-7
SYMBOL HAS ILLEGAL CHARACTER OR IS GREATER THAN ZIJFF
\begin{tabular}{|cl|}
\hline Operators & \\
Preflx Character & \multicolumn{1}{c|}{ Base } \\
(none) & 10 (Decimal) \\
\(\$\) & 16 (Hexadecimal) \\
\(@\) & 8 (Octal) \\
\(\%\) & 2 (Binary) \\
\hline
\end{tabular}
\begin{tabular}{|cl|}
\hline Constants (Prefix) & \\
Operator & \multicolumn{1}{c|}{ Operation } \\
+ & Addition \\
- & Subtraction \\
\(>\) & High-Byte Selection \\
Low-Byte Selection \\
\hline
\end{tabular}

\title{
RDC-2005 R6500 CROSS ASSEMBLER FOR INTEL PERSONAL DEVELOPMENT SYSTEM
}

\section*{CROSS ASSEMBLY}

The R6500 Cross Assembler provides the user with the capability of developing assembly language programs on the Intel Personal Development System (PDS) and downloading these programs to the Low Cost Emulator (LCE) 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), an arithmetic operator (if required) and an optional comment. Constants are 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.

\section*{PRODUCT OVERVIEW}

The R6500 Cross Assembler for the Intel Personal 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 LCE for program debugging and in-circuit validation using an R6500, R6500/* or R65C00 Personality Set. 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 checkıng, 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.

\section*{FEATURES}
- Intel Personal 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 LCE
- Operator selected assembly/error listing output
-Display/Printer
—Floppy Disk
- Assembler directives
- Symbolic cross-reference
- Communications support-downloadıng of object code

\section*{ORDERING INFORMATION}
\begin{tabular}{|l|c|}
\hline Part No. & Description \\
\hline RDC-2005 & \begin{tabular}{c} 
R6500 Cross Assembler for Intel Personal \\
Development System Dısk \\
\(\left(5-1 / 4^{\prime \prime}\right.\) ISIS II compatıble dısk)
\end{tabular} \\
\hline Order No. & Description \\
\hline RDC02 & \begin{tabular}{l} 
R6500 Cross Assembler for Intel Personal \\
Development System User's Manual \\
(included with RDC-2005)
\end{tabular} \\
\hline
\end{tabular}

\section*{Assembler Directives}
\begin{tabular}{lllll} 
Assembly Listing Control & & Data Storage & \\
.TTL & Title & WIDTH & Line Length & .BYTE
\end{tabular} \begin{tabular}{l} 
Initialize byte memory location \\
.PAGE \\
LINE \\
\\
\\
\\
Page Length
\end{tabular}
```

Error Codes
Pass 1
1 OPERAND VALUE IS INVALID OR GT HEX FFF
2 OPERAND VALUE IS GREATER THAN HEX FFFF
3 INCORRECT ADDRESSING MODE
4 SYMBOL NOT PREVIOUSLY DEFINED
5 \mp@code { N O ~ O P E R A N D }
6 ~ A S C I I ~ S T R I N G ~ N O T ~ P R O P E R L Y ~ E N C L O S E D ~
7 MISSING END STATEMENT
8 UNDEFINED ASSEMBLER DIRECTIVE
9 IMPROPER EQUATE FORMAT
10 UNRECOGNIZABLE ASTERISK DEFINITION
11 INDIRECT ADDRESSING OFF OF ZERO PAGE
12 INCORRECT FORM OF INDIRECT ADDRESSING, MISSING Y
1 3 INCORRECT FORM OF INDEX ADDRESSING, MISSING X
14 OPERAND MUST BE ON ZERO PAGE (00-\$FF)
1 5 ILLEGAL INSTRUCTION FOR THIS ASSEMBLER

```
\begin{tabular}{|cc|}
\hline Operators & \\
Prefix Character & Base \\
(none) & 10 (Decimal) \\
\(\$\) & 16 (Hexadecımal) \\
\(@\) & 8 (Octal) \\
\(\%\) & 2 (Binary) \\
\hline
\end{tabular}

\section*{Pass 2}

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
0 MISSING LABEL FOR EQUATE
OPERAND LABEL GREATER THAN 6 CHARACTERS LONG MOD VALUE IS INCORRECT FOR THIS ASSEMBLER OPERAND NOT BETWEEN 0-7
SYMBOL HAS ILIEGAL CHARACTER OR IS GREATER THAN ZIJFF

\section*{Constants (Prefix)}

Operator
\(+\)
+
-
\(-\)
\(>\)

Operation
Addition
Subtraction High-Byte Selection Low-Byte Selection

\section*{RDC-1020, RDC-1022 AND RDC-1024 ROCKWELL DESIGN CENTER (RDC) 8K/32K/64K TARGET RAM MODULE}

\section*{INTRODUCTION}

The \(8 \mathrm{~K} / 32 \mathrm{~K} / 64 \mathrm{~K}\) Target RAM Module is one of the hardware options available for the Rockwell Design Center Family of development systems.

The Target RAM Module supports memory operations in conjunction with the R6500/* and R6502-R65C02 Personality Sets used on both the Multiple Target Development System (MTDS) and Low Cost Emulator (LCE). The module in its 8 K byte configuration also supports the ROM and RAM area for the TEW operating system.


8K/32K/64K Target RAM Module

\section*{FEATURES}
- In the high speed mode, supports Multiple Target Development (MTDS) and Low Cost Emulator (LCE) 3 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 for up to 128K bytes of memory
- In the high speed mode, supports 8 K devices for up to 64K bytes of memory (refer to Devices Supported for part numbers)
- On-board header and shunt configure the module into a 2 K to 128K 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
- Compact size-100 mm \(\times 160 \mathrm{~mm}\) (approximately 3.9 in . \(\times 6.3 \mathrm{in}\).)
- Operates from a single +5 V power source
- Fully assembled (except for user-supplied memory devices), tested and warranted

\section*{OVERVIEW}

Two major capabilities are provided in the Target RAM 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 high-speed mode or a universal memory mode. Typical data-transfer rates are up to 3 MHz (to support the MTDS and LCE) 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 RAMs, ROMs, EPROMs, and EEPROMs.

\section*{ORDERING INFORMATION}
\begin{tabular}{|c|c|}
\hline Part No. & Description \\
\hline RDC-1020 & 64K RAM Module \((1\) to 3 MHz\()\) \\
RDC-1022 & 32K RAM Module \((1\) to 3 MHz\()\) \\
RDC-1024 & 8K RAM Module (1 to 3 MHz\()\) \\
\hline
\end{tabular}

\section*{FUNCTIONAL DESCRIPTION}

Data Bus Transceivers buffer and invert data signals BDO/ through BD7I. 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 \(\emptyset 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 BR/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 65K 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 65K 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 B0, are decoded by a 3:8 decoder to enable one of eight possible outputs. Each output signal in a low state indicates an 8K address boundary signal. Thus, the 8 K address boundaries are \(\$ 0000, \$ 2000, \$ 4000, \ldots\). \(\$ E 000\). 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 ( \(2 \mathrm{~K}, 4 \mathrm{~K}, 8 \mathrm{~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 E10 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.

\section*{DEVICES SUPPORTED}

In the universal memory mode, the following is a partial list of devices supported:

16 K of the following 2 K devices:
\begin{tabular}{ll} 
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
\end{tabular}

32K of the following 4 K devices:
\begin{tabular}{ll} 
R2332 & ROM-Rockwell \\
2732 A & ROM-Intel \\
\(2532(350 \mathrm{~ns})\) & ROM-TI
\end{tabular}

64 K of the following 8 K devices:
\begin{tabular}{ll} 
R2364A, R2364B & ROM-Rockwell \\
68A764 & EPROM-Motorola \\
68766 & EPROM-Motorola \\
2764 & EPROM-Intel \\
5564 & RAM-Toshiba \\
6264 & RAM-Hitachi \\
8464 & RAM-Fujitsu
\end{tabular}

128 K of the following 16 K devices:
\begin{tabular}{ll} 
R23128 & ROM-Rockwell \\
27128 & EPROM-Intel
\end{tabular}

In the high speed mode, the following is a partial list of devices supported:

64 K of the following 8 K devices:
\begin{tabular}{ll} 
R2364A, R2364B & ROM-Rockwell \\
68 A764 & EPROM-Motorola \\
68766 & EPROM-Motorola \\
2764 & EPROM-Intel (TEW) \\
5564 & RAM-Toshiba \\
6264 & RAM-Hitachi (MTDS and TEW) \\
8464 & RAM-Fujitsu
\end{tabular}

RM 65 Bus Pin Assignments
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{3}{|r|}{Bottom (Solder Side)} & \multicolumn{3}{|r|}{Top (Component Side)} \\
\hline Pin & Signal Mnemonic & Signal Name & Pin & Signal Mnemonic & Signal Name \\
\hline 1 a & GND & Ground & 1 c & +5V & +5 Vdc \\
\hline 2a & BADR/ & Buffered Bank Address & 2 c & BA15/ & Buffered, Address Bit 15 \\
\hline 3 a & GND & Ground & 3c & BA14/ & Buffered Address Bit, 14 \\
\hline 4a & BA13/ & Buffered Address Bit 13 & 4 c & BA12/ & Buffered Address Bit 12 \\
\hline 5a & BA11/ & Buffered Address Bit 11 & 5 c & GND & Ground \\
\hline 6a & BA10/ & Buffered Address Bit 10 & 6c & BA9/ & Buffered Address Bit 9 \\
\hline 7a & BA8/ & Buffered Address Bit. 8 & 7c & BA7/ & Buffered Address Bit 7 \\
\hline 8 a & GND & Ground & 8c & BA6/ & Buffered Address Bit 6 \\
\hline 9 a & BA5/ & Buffered Address Bit 5 & 9 c & BA4/ & Buffered Address Bit 4 \\
\hline 10a & BA3/ & Buffered Address Bit 3 & 10c & GND & Ground \\
\hline 11a & BA2/ & Buffered Address Bit 2 & 11c & BA1/ & Buffered Address Bit 1 \\
\hline 12a & BA0/ & Buffered Address Bit 0 & 12c & Bø1 & *Buffered Phase 1 Clock \\
\hline 13a & GND & Ground & 13c & BSYNC & *Buffered Sync \\
\hline 14a & BSO & *Buffered Set Overflow & 14c & BDRQ1/ & *Buffered DMA Request 1 \\
\hline 15a & BRDY & *Buffered Ready & 15c & GND & Ground \\
\hline 16a & & * User Spare 1 & 16c & : \(-12 \mathrm{~V} /-\mathrm{V}\) & *-12.Vdc/-V \\
\hline 17a & \(+12 \mathrm{~V} /+\mathrm{V}\) & * \(+12 \mathrm{Vdc} /+\mathrm{V}\) & 17c & & * User Spare 2 \\
\hline 18a & GND & Ground Line & 18c & BFLT/ & *Buffered Bus Float \\
\hline 19a & BDMT/ & *Buffered DMA Termınate & 19c & B \(\varnothing 0\) & *Buffered External Phase 0 Clock \\
\hline 20a & & *User Spare 3 & 20c & GND & Ground \\
\hline 21a & \(B R / W /\) & Buffered Read/Write "Not" & 21c & BDRQ2/ & *Buffered DMA Request 2 \\
\hline 22a & & *System Spare & 22c & BR/W & *Buffered Read/Write \\
\hline 23a & GND & Ground & 23c & BACT/ & Buffered Bus Active \\
\hline 24a & BIRQ/ & *Buffered Interrupt Request & 24c & BNMI/ & *Buffered Non-Maskable Interrupt \\
\hline 25a & Bø2/ & Buffered Phase 2 "Not" Clock & 25c & GND & Ground \\
\hline 26a & Bø2 & Buffered Phase 2 Clock & 26c & BRES/ & *Buffered Reset \\
\hline 27a & BD7/ & Buffered Data Bit 7 & 27c & BD6/ & Buffered Data Bit 6 \\
\hline 28a & GND & Ground & 28c & BD5/ & Buffered Data Bit 5 \\
\hline 29a & BD4/ & Buffered Data Bit 4 & 29c & BD3/ & Buffered Data Bit 3 \\
\hline 30a & BD2/ & Buffered Data Bit 2 & 30c & GND & Ground \\
\hline 31a & BD1/ & Buffered Data Bit 1 & 31 c & BDO/ & Buffered Data Bit 0 \\
\hline 32a & \(+5 \mathrm{~V}\) & +5 Vdc & 32c & GND & Ground \\
\hline e: *N & on this modu & & & & \\
\hline
\end{tabular}


\section*{SPECIFICATIONS}
\begin{tabular}{|c|c|}
\hline Parameter & Value \\
\hline \[
\begin{aligned}
& \text { Dimensions }{ }^{(1,2,3)} \\
& \text { Width } \\
& \text { Length } \\
& \text { Height }
\end{aligned}
\] & \[
\begin{aligned}
& 100 \mathrm{~mm}(3.94 \mathrm{in} .) \\
& 160 \mathrm{~mm}(6.3 \mathrm{in} .) \\
& 14 \mathrm{~mm}(0.55 \mathrm{in} .) \\
& \hline
\end{aligned}
\] \\
\hline Weight & 156 g (5.5 oz.) \\
\hline \begin{tabular}{l}
Environment \\
Operating Temperature Storage Temperature Relative Humidity
\end{tabular} & \[
\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 condensatıon) }
\end{aligned}
\] \\
\hline Power Requirements & 5 OV (420 ma. typical, 640 ma. maxımum with no memory devices installed) \\
\hline Connector RM 65 Bus Connector P1 & 64-pin plug ( 0.100 in centers) per DIN 41612 (Row b not installed)—mates with Burndy P196B32R00A00L-9 or equivalent \\
\hline
\end{tabular}

Notes
1 Height includes the maxımum values for component height above the board surface ( 04 in . for populated modules), printed circuit board thickness ( 0.062 in .), and pin extension through the bottom of the module ( 01 in .)
2. Length does not include the added extension due to the module ejector

3 Dimensions conform to DIN 41612


Module Dimensions

\section*{RDC-1030 \\ MULTIPLE TARGET DEVELOPMENT SYSTEM (MTDS) PROM PROGRAMMER MODULE}

\section*{INTRODUCTION}

The Multiple Target Development System (MTDS) is a development system vertically integrated to support the entire R6500 family of microprocessors and microcomputers. The MTDS 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 MTDS 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 MTDS is modular based on the proven RM 65 microcomputer module design using both single- and doublesized 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.

\section*{PRODUCT OVERVIEW}

The RDC-1030 PROM Programmer Module, in conjunction with the MTDS, programs industry standard 2 K -, 4 K - and 8 K -byte EPROMs (ultra-violet light erasable programmable read-only memories) and 2K-byte EEROMs (electrically erasable programmable read-only memories). The module consists of an RM 65 module and a 24 -inch ribbon cable. A 28 -pin and a 24 -pin Zero Insertion Force (ZIF) socket are mounted on the MTDS mainframe to allow installation of a 28 -pin or 24 -pin PROM.

\section*{FEATURES}
- Programs 2K-byte to 8K-byte UV EPROMs
-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
- Connects to PROM socket module installed in the MTDS with -28-pin and 24-pin Zero Insertion Force (ZIF) sockets
-Connecting 24 -inch cable to RM 65 module
- Easy-to-use interactive softkey commands
—PROM interface (check, program, read, verify)
-RAM preparation (alter and invert)
-Utility functions (PROM type selection, toggle verify mode, etc.)
- Verify during or after programming
- Compact size RM 65 module-about \(100 \mathrm{~mm} \times 160 \mathrm{~mm}\) ( \(4 \mathrm{in} . \times 61 / 4 \mathrm{in}\).)
- +5 V only operation (on-board DC/DC converter)
- Fully assembled and tested with one year warranty


RDC-1030 PROM Programmer Module

\section*{ORDERING INFORMATION}
\begin{tabular}{|l|c|}
\hline Part No. & \multicolumn{1}{c|}{ Description } \\
\hline RDC-1030 & MTDS PROM Programmer Module \\
\hline Order No. & Description \\
\hline RDC12 & MTDS PROM Programmer Module User's Manual* \\
\hline \begin{tabular}{l} 
Note: \\
*Included with RDC-1030. \\
\hline
\end{tabular} \\
\hline
\end{tabular}

\section*{FUNCTIONAL DESCRIPTION}

\section*{PROM PROGRAMMER 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 Transceivers 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 Enables 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).

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

\section*{PROM SOCKETS AND INTERFACE CABLE}

Both 28-pin and 24-pin Zero Insertion Force (ZIF) sockets are mounted on the front panel of the MTDS mainframe and connected to the PROM Programmer module by a 24 -inch ribbon cable.

\section*{PROM PROGRAMMER COMMANDS}

Computer program routines to operate the PROM Programmer module are provided on a diskette to be installed in the MTDS system. 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).

PROM Programmer commands are invoked from a command softkey software mode the same as used in the standard MTDS software. The commands listed 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
\begin{tabular}{|l|l|}
\hline Command & \multicolumn{1}{|c|}{ Function } \\
\hline CHECK & Check PROM \\
PROGRAM & Program PROM \\
READ & Read PROM \\
VERIFY & Verify PROM \\
MODIFY & Modify Memory \\
ALTER & Alter Memory \\
INVERT & Invert Memory \\
SAVE & Save Memory \\
ERASE & Erase EEROM \\
SELECT & Select PROM Type \\
TOG.VER & Toggle Verify Mode \\
CHEKSUM & Checksum Memory \\
LOAD & Load \\
DUMP & Dump \\
DIR & Display Disk Directory \\
RENAME & Rename File \\
DELETE & Delete File \\
RECOVER & Recover Deleted File \\
\hline
\end{tabular}


PROM Programmer Module Block Diagram

\section*{PROM Socket Pin Assignment}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline Connector J1 (P2) Pin No. & 24-pin PROM Socket Pin Number (1) & 28-pin PROM Socket Pin Number & Signal Symbol & Signal Name & Connector J1 (P2) Pin No. & \begin{tabular}{l}
24-pin PROM \\
Socket Pin Number (1)
\end{tabular} & 28-pin PROM Socket Pin Number & Signal Symbol & Signal Name \\
\hline 3, 5, 10, & 12 & 14 & GND & Ground & 16 & 9 & 11 & Q0 & Data Bit 0 \\
\hline 15, 24, 26, & & & & & 17 & 10 & 12 & Q1 & Data Bit 1 \\
\hline 28, 30, 32 & & & & & 18 & 11 & 13 & Q2 & Data Bit 2 \\
\hline 35, 37, 39 & & & & & 19 & 13 & 15 & Q3 & Data Bit 3 \\
\hline 1, 40 & - & 28 & VCC & PROM Supply Voltage & 20 & 14 & 16 & Q4 & Data Bit 4 \\
\hline 2 & - & 1 & VPP & Programming Voltage & 21 & 15 & 17 & Q5 & Data Bit 5 \\
\hline 4 & - & 2 & A12 & Address Bit 12 & 22 & 16 & 18 & Q6 & Data Bit 6 \\
\hline 6 & 1 & 3 & A7 & Address Bit 7 & 23 & 17 & 19 & Q7 & Data Bit 7 \\
\hline 7 & 2 & 4 & A6 & Address Bit 6 & 25 & 18 & 20 & \(\overline{C E}\) & Chip Enable \\
\hline 8 & 3 & 5 & A5 & Address Bit 5 & 27 & 19 & 21 & A10 & Address Bit 10 \\
\hline 9 & 4 & 6 & A4 & Address Bit 4 & 29 & 20 & 22 & \(\overline{\mathrm{OE}}\) & Output Enable \\
\hline 11 & 5 & 7 & A3 & Address Bit 3 & 31 & 21 & 23 & A11 & Address Bit 11 \\
\hline 12 & 6 & 8 & A2 & Address Bit 2 & 33 & 22 & 24 & A9 & Address Bit 9 \\
\hline 13 & 7 & 9 & A1 & Address Bit 1 & 34 & 23 & 25 & A8 & Address Bit 8 \\
\hline 14 & 8 & 10 & A0 & Address Bit 0 & 36 & 24 & 26 & A13/ \(\mathrm{V}_{\mathrm{cc}}(2)\) & Address Bit 13 \\
\hline & & & & & 38 & - & 27 & PGM & Program \\
\hline
\end{tabular}

Note: (1) Nomenclature applies to the recommended JEDEC Bytewide pin-out.
(2) Applies to 24-pin devices

RM 65 Bus Pin Assignments
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multicolumn{3}{|r|}{Bottom (Solder Side)} & \multicolumn{3}{|r|}{Top (Component Side)} \\
\hline Pin & Signal Mnemonic & Signal Name & Pin & Signal Mnemonic & Signal Name \\
\hline 1a & GND & Ground & 1 c & \(+5 \mathrm{~V}\) & + 5 Vdc \\
\hline 2a & BADR/ & Buffered Bank Address & 2 c & VA15/ & Buffered Address Bit 15 \\
\hline 3 a & GND & Ground & 3 c & BA14/ & Buffered Address Bit 14 \\
\hline 4a & BA13/ & Buffered Address Bit 13 & 4 c & BA12/ & Buffered Address Bit 12 \\
\hline 5 a & BA11/ & Buffered Address Bit 11 & 5 c & GND & Ground \\
\hline 6a & BA10/ & Buffered Address Bit 10 & 6 c & BA9/ & Buffered Address Bit 9 \\
\hline 7a & BA8/ & Buffered Address Bit 8 & 7 c & BA71 & Buffered Address Bit 7 \\
\hline 8 a & GND & Ground & 8 c & BA6/ & Buffered Address Bit 6 \\
\hline 9 a & BA5/ & Buffered Address Bit 5 & 9 c & BA4/ & Buffered Address Bit 4 \\
\hline 10a & BA3/ & Buffered Address Bit 3 & 10c & GND & Ground \\
\hline 11a & BA21 & Buffered Address Bit 2 & 110 & BA1/ & Buffered Address Bit 1 \\
\hline 12a & BAOI & Buffered Address Bit 0 & 12 c & B01 & *Buffered Phase 1 Clock \\
\hline 13a & GND & Ground & 13c & BSYNC & *Buffered Sync \\
\hline 14a & BSO & *Buffered Set Overflow & 14 c & BDRQ1/ & *Buffered DMA Request 1 \\
\hline 15a & BRDY & *Buffered Ready & 15c & GND & Ground \\
\hline 16a & & *User Spare 1 & 16c & -12VI-V & *-12 Vdc/-V \\
\hline 17a & \(+12 \mathrm{~V} /+\mathrm{V}\) & * + 12 Vdc & 17 c & & * User Spare 2 \\
\hline 18a & GND & Ground & 18c & BFLT/ & *Buffered Bus Float \\
\hline 19a & BDMT/ & *Buffered DMA Terminate & 19c & B00 & *Buffered External Phase 0 Clock \\
\hline 20a & & *User Spare 3 & 20c & GND & Ground \\
\hline 21a & BR/W/ & Buffered Read/Write "Not" & 21c & BDRQ2/ & *Buffered DMA Request 2 \\
\hline 22a & & *System Spare & 22c & BR/ \(\bar{W}\) & *Buffered Read/Write \\
\hline 23a & GND & Ground & 23c & BACT/ & Buffered Bus Active \\
\hline 24a & BIRQ/ & *Buffered Interrupt Request & 24 c & BNMI/ & *Buffered Non-Maskable Interrupt \\
\hline 25a & B021 & Buffered Phase 2 "Not" Clock & 25 c & GND & Ground \\
\hline 26a & B02 & *Buffered Phase 2 Clock & 26c & BRES/ & Buffered Reset \\
\hline 27a & BD71 & Buffered Data Bit 7 & 27c & BD6/ & Buffered Data Bit 6 \\
\hline 28a & GND & Ground & 28 c & BD5/ & Buffered Data Bit 5 \\
\hline 29a & BD4/ & Buffered Data Bit 4 & 29c & BD3/ & Buffered Data Bit 3 \\
\hline 30a & BD2/ & Buffered Data Bit 2 & 30 c & GND & Ground \\
\hline 31 a & BD1/ & Buffered Data Bit 1 & 31 c & BDO/ & Buffered Data Bit 0 \\
\hline 32a & \(+5 \mathrm{~V}\) & +5 Vdc & 32c & GND & Ground \\
\hline \multicolumn{6}{|l|}{\begin{tabular}{l}
Note: \\
*Not used on this module
\end{tabular}} \\
\hline
\end{tabular}

\section*{SPECIFICATIONS}
\begin{tabular}{|c|c|}
\hline Parameter & Value \\
\hline \begin{tabular}{l}
Dimensions PROM Programmer Module Width \\
Length \\
Height(1) \\
PROM Programmer Cable Length
\end{tabular} & \[
\begin{aligned}
& 100 \mathrm{~mm}(3.94 \mathrm{in} .) \\
& 167 \mathrm{~mm}(6.58 \mathrm{in} .) \\
& 14 \mathrm{~mm}(0.56 \mathrm{in} .) \\
& 610 \mathrm{~mm}(24 \mathrm{in} .)
\end{aligned}
\] \\
\hline Weight & \(184 \mathrm{~g} \quad\) (6.5 oz.) \\
\hline \begin{tabular}{l}
Environment \\
Operating Temperature \\
Storage Temperature \\
Relative Humidity
\end{tabular} & \[
\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}
\] \\
\hline Power Requirements & \[
\begin{aligned}
& +5 \mathrm{~V} \pm 5 \% \text { at } 1.1 \mathrm{~A} \text { typical } \\
& 2.0 \mathrm{~A} \text { maximum (average) } \\
& \text { 2.9 A maximum (peak) }
\end{aligned}
\] \\
\hline \begin{tabular}{l}
Connectors/Sockets \\
RM 65 Bus Connector (P1) \\
Socket Module Cable Connector (J1) \\
PROM Sockets
\end{tabular} & \begin{tabular}{l}
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 and 24 -pin
\end{tabular} \\
\hline \multicolumn{2}{|l|}{\begin{tabular}{l}
Note: \\
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 .).
\end{tabular}} \\
\hline
\end{tabular}


PROM Programmer Module Outline


RDC-1030 PROM Programmer Module

\section*{SPS-200 \\ SOFTWARE PREPARATION SYSTEM (SPS) PERIPHERAL CONNECTOR MODULE}

\section*{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 cassettes 20 mA current loop and parallel I/O devices such as the Rockwell 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-fưnction Peripheral Interface (MPI), and with the AIM 65/40 Microcomputer connector; e.g., User Parallel I/O, Display Interface and Printer Interface.

\section*{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

\section*{REFERENCE DOCUMENTS}

The following documents contain information regarding set-up and operation of SPS-200.
\begin{tabular}{|c|c|}
\hline Order No. & Title \\
\hline 2167 & \begin{tabular}{c} 
R6500 Software Preparation System (SPS) \\
User's Manual
\end{tabular} \\
209 & AIM 65 Mıcrocomputer User's Guide \\
\hline
\end{tabular}


SPS-200 Peripheral Connector Module

\section*{EXTERNAL PRINTER INTERFACE}

SPS Module Printer Connector
\begin{tabular}{|c|l|l|l|}
\hline Pin & Signal & Pin & Signal \\
\hline 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 & & \\
\hline
\end{tabular}


Interface Module Connector


Printer Interface Cable (User Supplied)
Centronics Type Connector Pin Assignment
\begin{tabular}{|l|l|l|l|}
\hline Pin & Signal & \multicolumn{1}{|c|}{ Pin } & Signal \\
\hline \(\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\) & \(\overline{\mathrm{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 \\
\hline
\end{tabular}


External Printer Connector

\section*{RS-232 INTERFACE}

RS-232 Connector Pin Assignments
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Pin} & \multirow[t]{2}{*}{Signal Mnemonic} & \multirow[b]{2}{*}{Signal Name} & \multicolumn{2}{|l|}{Input/Output} \\
\hline & & & Data Set & Data Term \\
\hline 1 & GND & Chassis Ground & & \\
\hline 2 & TD & Transmit Data & 1 & 0 \\
\hline 3 & \(\overline{\text { RD }}\) & Receive Data & 0 & 1 \\
\hline 5 & CTS & Clear to Send \({ }^{1}\) & +5V Always & +5V Always \\
\hline 6 & DSR & Data Set Ready \({ }^{1}\) & +5V Always & +5V Always \\
\hline 7 & GND & Signal Ground & & \\
\hline 8
9
\(9-25\) & DCD & Data Carrier Detected \({ }^{1}\) Not Used & +5V Always & +5V Always \\
\hline
\end{tabular}
\({ }^{1}\) This can be cut for a No Connect option


RS-232 Connector Pin Locations

\section*{20 mA CURRENT LOOP INTERFACE}


20 ma Current Loop Connector Pin Locations

\section*{PARALLEL I/O CONNECTOR INTERFACE}

Parallel I/O. Connector Pin Assignments
\begin{tabular}{|c|c|c|c|c|}
\hline Pin & \multicolumn{2}{|l|}{Mnemonic} & Signal Name & Input/Output \\
\hline 1* & CB2 & * & Port B, Control No. \({ }^{1}\) & 110 \\
\hline 2 & & & No Connect & \\
\hline 3* & CB1 & & Port B, Control No. 1 & I/O \\
\hline 5* & PB7 & & Port B, Bit 7 & I/O \\
\hline 7* & PB6 & & Port B, Bit 6 & \(1 / 0\) \\
\hline 9* & PB5 & & Port B, Bit 5 & 1/0 \\
\hline 11* & PB4 & & Port B, Bit 4 & 1/0 \\
\hline 13* & PB3 & & Port B, Bit 3 & 1/0 \\
\hline 15* & PB2 & & Port B, Bit 2 & \(1 / 0\) \\
\hline 17* & PB1 & & Port B, Bit 1 & 1/0 \\
\hline 19* & PB0 & & Port B, Bit 0 & 1/0 \\
\hline 21 & PA7 & & Port A, Bit 7 & I/O \\
\hline 23 & PA6 & & Port A, Bit 6 & 1/0 \\
\hline 25 & PA5 & & Port A, Bit 5 & 1/0 \\
\hline 27 & PA4 & & Port A, Bit 4 & 1/O \\
\hline 29 & PA3 & & Port A, Bit 3 & I/O \\
\hline 31 & PA2 & & Port A, Bit 2 & 1/0 \\
\hline 33 & PA1 & & Port A, Bit 1 & 1/0 \\
\hline 35 & PAO & & Port A, Bit 0 & 1/0 \\
\hline 37 & CA2 & & Port A, Control No. 2 & 1/0 \\
\hline 39
40 & CA1 & & Port A, Control No. 1 & 1/O \\
\hline \multicolumn{5}{|l|}{Note: Even Numbered pins connected to GND.} \\
\hline \multicolumn{5}{|l|}{\begin{tabular}{l}
*These signals are used by the Printer Interface. \\
\({ }^{1}\) This can be cut/jumpered to +5 V .
\end{tabular}} \\
\hline
\end{tabular}


Parallel I/O Connector Pin Locations

DATA SET/DATA TERMINAL SETUP


\section*{AUDIO CASSETTE RECORDER INTERFACE}


Audio Cassette Recorder Interface

\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*{INSTALLATION}

The PCM connects directly to the AIM 65 Master Module connector J1. The silk screened text on the module should be rightside up when installed as shown in Figure 3.


Figure 3. SPS Peripheral Connector Module Orientation

\section*{SECTION 7 INTEGRAL MODEMS}
Page
Product Family Overview ..... 7-2
Product Preview - High Speed Modems
R96FT/SEC 9600 BPS Fast Train Modem with Secondary Channel ..... 7-3
R144 Synchronous 14.4 KBS Modem ..... 7-4
R4875 4800/75 BPS Modem ..... 7-5
R208A/B 4800 BPS Modem ..... 7-6
High Speed
R96FAX 9600 BPS Fascimile Modem ..... 7-7
R96DP 9600 BPS Data Pump Modem ..... 7-20
R96FT 9600 BPS Fast Train Modem ..... 7-34
V96P/1 9600 BPS Modem ..... 7-47
R48DP 4800 BPS Data Pump Modem ..... 7-55
V27P/1 4800 BPS Modem ..... 7-69
Product Preview - Low to Medium Speed
R1212DS Modem Device Set (212A Compatible) ..... 7-76
R2424DS Modem Device Set ..... 7-77
R24DP 2400 BPS Modem (201C Compatible) ..... 7-78
Low to Medium Speed
R1212 1200 BPS Full Duplex Modem ..... 7-79
R1212/U 1200 BPS Full Duplex Modem with Internal USART ..... 7-94
R2424 2400 BPS Full Duplex Modem ..... 7-110
R24DC 2400 BPS Direct Connect Modem ..... 7-126
R24LL 2400 BPS Leased Line Modem ..... 7-134
R24 2400 BPS Integral Modem ..... 7-143
Modem Interfacing Products
RDAA Rockwell Data Access Arrangement Module ..... 7-151

\title{
INTEGRAL MODEMS \\ Highest Quality, Performance at the Most Competitive Price
}

Rockwell International's integral modems offer better performance and greater reliability than any modem products available today. They are the most cost effective and optimal product for computer-communication applications. That is why Rockwell produces more high-speed integral modem subsystems than any other company.

Chances are that if you're using high-speed data communication equipment, a Rockwell subsystem provides the basic modem functions. Practically every sub-minute facsimile machine uses our modems. Rockwell is the leading modem supplier to Japanese Group III facsimile equipment manufacturers.

As for performance, our modems do not lose a bit in a million, even over long distance lines of the public telephone network. Much of this is because of our signal processing capabilities, equalization and diagnostics. With \(99.7 \%\) of our subsystems accepted by incoming inspection, we have documented an MTBF of 200,000 hours, or about 23 years between service calls.

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. Using signal processor and integrated analog technology, Rockwell International provides the family of modems which are ideal for those original equipment manufacturers who are in step with the current communication trend. Today, we cover all speeds from 1200 to 9600 bps, with a 14,400 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 are on plug-compatible Eurocard-sized printed circuit boards, so you can switch communication speeds without expensive design changes.

In addition, they are optimized for specific communication products, stand alone modems and statistical multiplexers, facsimile equipment and personal computer or terminal applications.
They are low in price and readily available. Being the largest manufacturer allows us to pass our economical advantages on to our customers. We offer the best cost/performance OEM modems. No one else comes close.


Rockwell Integral Modems Lead The Industry

R96FT/SEC 9600 BPS FAST TRAIN MODEM WITH SECONDARY CHANNEL

\section*{PRODUCT PREVIEW}

\section*{INTRODUCTION}

The R96 Fast Train (FT) with 75 bps secondary channel 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/SEC is specifically optimized for use in a multipoint environment requiring a fast training sequence of 22 msec at 9600 bps and 21 msec at 4800 bps. The 75 bps 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/SEC is a member of Rockwell's family of plug compatible 9600/4800 bps modems.

Product availability is APRIL, 1985.

\section*{FEATURES}
- Configurations
-CCITT V.29, V. 27 bis/ter
- Fast Training Sequence \(22 \mathrm{msec} / 9600 \mathrm{bps}, 21 \mathrm{msec} /\) 4800 bps
- Ideal for Multipoint Applications
- Plug Compatible with Rockwell R96DP, R48DP Modems
- Secondary Channel, 75 bps
- Dynamic Range: -43 dBm to 0 dBm
- Equalization
-Automatic Adaptive
-Compromise Cable (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 mm \(\times 160 \mathrm{~mm}\left(3.64^{\prime \prime} \times 6.30^{\prime \prime}\right)\)
- Power Consumption-4 Watts typical
- TTL and CMOS Compatible

\section*{PRODUCT PREVIEW}

\section*{INTRODUCTION}

The Rockwell R144 is a synchronous 14.4 Kbps high performance modem capable of operation over either conditioned or unconditioned lines. This single board modem is designed to satisfy telecommunciation requirements specified in the CCITT Recommendation V.29. The modem is usable in 4 -wire full duplex operation and is plug compatible with Rockwell R96 spries modems. The R144 is designed for use in multipoint networks.

\section*{FEATURES}
- 14,400/9600/7200/4800 bps Modes
- V. 29 Compatible
- Single Printed Circuit Board- \(103 \mathrm{~mm} \times 160 \mathrm{~mm}\)
- TTL Compatible
- Full-Duplex (4-Wire)
- Maximum Digital LSI Signal Processing
- Automatic Adaptive Equalizer
- V. 54 Loops 2, 3, 4 Diagnostics
- 0 to -45 dBm Dynamic AGC Range
- Power Consumption-5 Watts typical
- Network Control Diagnostics
- 50 msec Training Time at 14.4 Kbps
- 22 msec Training Time at 9.6 Kbps
- Operates Over Unconditioned Lines

\section*{SPECIFICATIONS}

\section*{POWER REQUIREMENTS}

Voltages: \(\pm 5 \mathrm{~V}( \pm 5 \%)\) \(+12 \mathrm{~V}( \pm 5 \%)\)

\section*{ENVIRONMENTAL}

Operating temperature: \(-0^{\circ} \mathrm{C}\) to \(+60^{\circ} \mathrm{C}\)
Humidity: Up to \(90 \%\), noncondensing, or a wet bulb temperature up to \(35^{\circ} \mathrm{C}\), whichever is less.

\section*{R4875} 4800/75 BPS MODEM

\section*{PRODUCT PREVIEW}

\section*{INTRODUCTION}

The R4875 is a synchronous/asynchronous, serial 4800/75 bps modem suitable for operation over the general switched network. It satisfies the telecommunications requirements specified in CCITT Recommendation V. 27 ter. The 75 bps backward channel satisfies CCITT Recommendation V. 23 .

The R4875 is specifically optimized for use in switched network environments involving videotex transmission.

Data can be transferred to and from the modem serially over the CCITT V. 24 interface.

\section*{FEATURES}
- CCITT V. 27 ter-4800 bps forward channel
- CCITT V.23-75 bps backward channel
- Full duplex, 2-wire
- Videotex transmission per Nippon Telephone + Telegraph Captain System and British Telecom Picture Prestel Requirements
- Dynamic Range 0-40 dBm
- Equalization
-Automatic adaptive
-Compromise Cable
-Compromise link amplitude
- Interface: Two alternate ports -Microprocessor bus
—RS-232/CCITT V. 24
- Connector: \(26-\) Pin DIN
- TTL and CMOS compatible

\section*{SPECIFICATIONS}

\section*{BOARD DIMENSIONS}

Width \(=160 \mathrm{~mm}\)
Length \(=223 \mathrm{~mm}\)
Height \(=24 \mathrm{~mm}\)

\section*{POWER REQUIREMENTS}

Voltages: \(+5 \mathrm{Vdc}(+5 \%)\)
\(\pm 12 \mathrm{Vdc}(+5 \%)\)
Consumption: 7 Watts typical

\section*{ENVIRONMENTAL}

Operating Temperature \(0^{\circ}-60^{\circ} \mathrm{C}\)
Humidity: up to \(90^{\circ}\) noncondensing, or a wet bulb temperature up to \(35^{\circ} \mathrm{C}\), whichever is less

\section*{PRODUCT PREVIEW}

\section*{INTRODUCTION}

The R208A/B is a synchronous, serial, 4800/2400 bps modem designed for operation over dedicated unconditioned lines or with the general switched telephone network with appropriate line terminations, such as a Data Access Arrangement or transformer, provided externally.

The R208A/B satisfied the telecommunications requirements specified in Bell 208 A/B and CCITT V. 27 bis/ter for 4800 bps modems.

The R208A/B is optimized for point-to-point applications and suitable for network applications where the optimum in data transfer is needed. Its small size ( 100 mm by 120 mm ) and low power consumption (4W typical) offer the user flexibility in creating a 4800 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 R208A/B is a member of Rockwell's family of plug compatible modems.

Product availability is APRIL, 1985.

\section*{FEATURES}
- Configurations
-Bell 208 A/B
-CCITT V. 27 bis/ter
- Half-Duplex (2-wire), Full-Duplex (4-wire)
- Ideal for Point-to-Point Applications
- Plug Compatible with Rockwell R96DP, R48DP, R96FT Modems
- Programmable Tone Generation
- Dynamic Range: - 43 dBm to 0 dBm
- Equalization
- -Automatic Adaptive
-Compromise Cable (Selectable)
-Compromise Link (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
-Remote Digital
- Power Consumption-4 Watts Typical
- TTL and CMOS Compatible

\section*{SPECIFICATIONS}

\section*{POWER REQUIREMENTS}
```

+5 Vdc }\pm5%<500m
+12 Vdc }\pm5%<20\textrm{ma
-12 Vdc }\pm5%<80\textrm{ma

```

\section*{ENVIRONMENTAL}

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.

\section*{R96FAX 9600 BPS FACSIMILE MODEM}

\section*{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 .

\section*{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)
- Tone Detection
- Programmable Tone Generation and Detection
- Dynamic Range -47 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 \mathrm{dBm} \pm 1 \mathrm{~dB}\) )
- TTL and CMOS Compatible


\section*{R96FAX Modem}

\section*{TECHNICAL SPECIFICATIONS}

\section*{TRANSMITTER TONAL SIGNALING AND CARRIER FREQUENCIES}

\section*{T. 30 Tonal Signaling Frequencles}
\begin{tabular}{|l|c|}
\hline \multicolumn{1}{|c|}{ Function } & \begin{tabular}{c} 
Frequency \\
\((\mathbf{H z} \pm \mathbf{0 . 0 1 ~ H z )}\)
\end{tabular} \\
\hline Calling Tone (CNG) & 1100 \\
Answer Tone (CED) & 2100 \\
Group II Identification (C12) & 1850 \\
Group II Command (GC2) & 2100 \\
Group II Confirmation (CFR2, MCF2) & 1650 \\
Line Conditioning Signal (LCS) & 1100 \\
End of Message (EOM) & 1100 \\
Procedure Interrupt (PIS) & 462 \\
\hline
\end{tabular}

\section*{Carrier Frequencies}
\begin{tabular}{|l|c|}
\hline \multicolumn{1}{|c|}{ Function } & \begin{tabular}{c} 
Frequency \\
\((\mathbf{H z} \pm \mathbf{0 . 0 1 ~ H z})\)
\end{tabular} \\
\hline T.3 Carrier (Group II) & 2100 \\
V.27 ter Carrier & 1800 \\
V.29 Carrier & 1700 \\
\hline
\end{tabular}

\section*{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.

\section*{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.

\section*{SIGNALING AND DATA RATES}
\begin{tabular}{|l|c|}
\hline \multicolumn{2}{c|}{ Signaling/Data Rates } \\
\hline \multicolumn{1}{|c|}{ Parameter } & \begin{tabular}{c} 
Specification \\
\(( \pm 0.01 \%)\)
\end{tabular} \\
\hline Signaling Rate: & 2400 Baud \\
Data Rate: & 9600 bps, \\
& 7200 bps, \\
& 4800 bps \\
\hline Signaling Rate: & 1600 Baud \\
Date Rate: & 4800 bps \\
\hline Signaling Rate: & 1200 Baud \\
Data Rate: & 2400 bps \\
\hline
\end{tabular}

\section*{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.

\section*{EQUALIZERS}

The R96FAX provides the following 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.

\section*{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.

\section*{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.

\section*{RECEIVED SIGNAL 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}\).

\section*{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).

\section*{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.

\section*{TRANSMIT LEVEL}

The transmitter output level is fixed at \(+5 \mathrm{dBm} \pm 1 \mathrm{~dB}\). When driving a 600 ohm load the TXA output requires a 600 ohm series resistor to provide \(-1 \mathrm{dBm} \pm 1 \mathrm{~dB}\) to the load.

\section*{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.

\section*{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
\begin{tabular}{|r|c|c|c|l|}
\hline No. & v.29 & V.27 ter & \begin{tabular}{c} 
RTS-CTS \\
Time (ms)
\end{tabular} & \multicolumn{1}{|c|}{ Comments } \\
\hline 1 & 9600 bps & & 253 & \\
2 & 7200 bps & & 253 & \\
3 & 4800 bps & & 253 & \\
4 & & \(4800 \mathrm{bps}^{2}\) & 708 & \\
5 & & \(2400 \mathrm{bps}^{2}\) & 943 & \\
\hline 6 & 9600 bps & & 458 & Preceded \\
7 & 7200 bps & & 458 & By Echo \\
8 & 4800 bps & & 458 & Suppressor \\
9 & & \(4800 \mathrm{bps}^{2}\) & 913 & \\
10 & & \(2400 \mathrm{bps}^{2}\) & 1148 & Tone \\
\hline
\end{tabular}

\section*{Notes:}
1. Turn-on sequences six through ten are used on lines with protection against talker echo.
2. V. 27 ter long training sequence only.

\section*{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.

\section*{CLAMPING}

The following clamps are provided with the RG6FAX:
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 turn-off sequence.

\section*{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.

\section*{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 -52 dBm (RLSD off)

\section*{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 a modulated carrier signal applied to the receiver's audio input (RXA).

\section*{MODES OF OPERATION}

The R96FAX is capable of being operated in either a serial or a parallel mode of operation.

\section*{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 Functional Interconnect Diagram) illustrates this capability.

\section*{PARALLEL MODE}

The R96FAX has the capability of transferring channel data eight bits at a time via the microprocessor bus.

\section*{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.


R96FAX Functional Interconnect Diagram

\section*{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.

\section*{HARDWARE CIRCUITS}

Signal names and descriptions of the hardware circuits, including the microprocessor interface, are listed in the R96FAX Hardware Circuits table; the table column titled 'Type' refers to designations found in the Hardware Circuit Characteristics. 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 Circuits
\begin{tabular}{|l|l|c|l|}
\hline \multicolumn{1}{|c|}{ Name } & Type & Pin No. & \multicolumn{1}{|c|}{ Description } \\
\hline \multicolumn{4}{|c|}{ A. OVERHEAD: } \\
\hline Ground & GND & 14,39 & Power Supply Return \\
+ 5 volts & PWR & 3,4 & +5 volt supply \\
+ 12 volts & PWR & 26 & +12 volt supply \\
-12 volts & PWR & 37 & -12 volt supply \\
POR & I/OA & 36 & Power-on-reset \\
\hline
\end{tabular}

R96FAX Hardware Circuits (Cont.)
\begin{tabular}{|c|c|c|c|}
\hline Name & Type & Pin No. & Description \\
\hline \multicolumn{4}{|l|}{B. MICROPROCESSOR INTERFACE:} \\
\hline D7 & I/OA & 7 & \\
\hline D6 & I/OA & 5 & \\
\hline D5 & I/OA & 9 & \\
\hline D4 & I/OA & 31 & Data Bus (8 Bits) \\
\hline D3 & I/OA & 15 & \\
\hline D2 & I/OA & 28 & \\
\hline D1 & I/OA & 23 & \\
\hline D0 & I/OA & 29 & \\
\hline RS3 & IA & 30 & \\
\hline RS2 & IA & 8 & Register Select (4 Bits). \\
\hline RS1 & IA & 27 & Select Reg. 0-F \\
\hline RSO & IA & 10 & \\
\hline \(\overline{\text { CSO }}\) & IA & 6 & Chip Select Sample Rate Device \\
\hline CS1 & IA & 18 & Chip Select Baud Rate Device \\
\hline READ & IA & 1 & Read Enable \\
\hline WRITE & IA & 2 & Write Enable \\
\hline \(\overline{\mathrm{R} Q}\) & OB & 32 & Interrupt Request \\
\hline \multicolumn{4}{|l|}{C. V. 24 INTERFACE:} \\
\hline \(\overline{\text { DCLK }}\) & OC & 13 & Data Clock \\
\hline XCLK & IB & 22 & External Clock for Group II \\
\hline RTS & IB & 19 & Request-to-Send \\
\hline CTS & OC & 17 & Clear-to-Send \\
\hline TXD & IB & 20 & Transmitter Data \\
\hline RXD & OC & 21 & Receiver Data \\
\hline \(\overline{\text { RLSD }}\) & OC & 16 & Received Line Signal Detector \\
\hline \multicolumn{4}{|l|}{D. CABLE EQUALIZER:} \\
\hline CABS1 CABS2 & \[
\begin{aligned}
& \text { IC } \\
& \text { IC }
\end{aligned}
\] & \[
\begin{aligned}
& 33 \\
& 34
\end{aligned}
\] & Cable Select 1 Cable Select 2 \\
\hline
\end{tabular}
R96FAX Hardware Circuits (Cont.)
\begin{tabular}{|l|c|c|l|}
\hline \multicolumn{1}{|c|}{ Name } & Type & Pin No. & \multicolumn{1}{c|}{ Description } \\
\hline E. ANALOG SIGNALS: \\
\hline TXA & AA & 38 & Transmitter Analog Output \\
RXA & AB & 40 & Receiver Analog Input \\
AUXIN & AC & 35 & Auxiliary Analog Input \\
\hline \multicolumn{4}{|l|}{} \\
\hline F. DIAGNOSTIC: \\
\hline EYEX & OC & 24 & Eye Pattern Data - X Axis \\
EYEY & OC & 25 & Eye Pattern Data - Y Axis \\
EYECLK & OA & 11 & Eye Pattern Clock \\
EYESYNC & OA & 12 & Eye Pattern Synchronizing \\
\hline
\end{tabular}

\section*{Eye Pattern Generation}

The four hardware diagnostic circuits, identified in the preceding table, 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 obtained from registers 1:3 and 1:1 (see RAM Data Access) 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.

\section*{MICROPROCESSOR TIMING}


Microprocessor Interface Timing Diagram
Critical Timing Requirements
\begin{tabular}{|l|c|c|c|c|}
\hline \multicolumn{1}{|c|}{ Characteristic } & Symbol & Min & Max & Units \\
\hline\(\overline{\text { CSi, RSi setup time prıor }}\) & & & & \\
to Read or Write & TCS & 30 & - & NS \\
Data Access time after Read & TDA & - & 140 & NS \\
Data hold tıme after Read & TDH & 10 & 50 & NS \\
CSi, RSi hold time after & & & & \\
Read or Write & TCH & 10 & - & NS \\
Write data setup tıme & TWDS & 75 & - & NS \\
Write data hold tıme & TWDH & 10 & - & NS \\
Write strobe pulse width & TWR & 75 & - & NS \\
\hline
\end{tabular}

\section*{Cable Equalizer Selection}

Cable Equalizer Selection
\begin{tabular}{|c|c|c|}
\hline CABS 2 & CABS 1 & Length of 0.4mm Diameter Cable \\
\hline 0 & 0 & 0.0 \\
0 & 1 & 1.8 km \\
1 & 0 & 3.6 km \\
1 & 1 & 7.2 km \\
\hline
\end{tabular}

\section*{HARDWARE CIRCUIT CHARACTERISTICS}

\section*{Digital Interface Characteristics}

The digital interface characteristics are listed in the table on the following page.

\section*{Analog Interface Characteristics}

\section*{Analog Interface Characteristics}
\begin{tabular}{|l|c|l|}
\hline Name & Type & \multicolumn{1}{c|}{ Characteristics } \\
\hline TXA & AA & \begin{tabular}{l} 
The transmitter output is a low impedance \\
operational amplifier output. In order to \\
match to 600 ohms, an external 604 ohm \\
series resistor is required.
\end{tabular} \\
RXA & AB & \begin{tabular}{l} 
The receiver input impedance is \\
\(63.4 K\) ohms \(\pm 5 \%\).
\end{tabular} \\
AUXIN & AC & \begin{tabular}{l} 
The auxlliary analog input allows access \\
to the transmitter for the purpose of \\
interfacing with user provided equipment. \\
Because this is a sampled data input, any \\
signal above 4800 Hz will cause aliasing \\
errors. The input impedance is 1 K ohms, \\
and the gain to transmitter output is \\
\(-1 \mathrm{~dB} \pm 1 \mathrm{~dB}\).
\end{tabular} \\
\hline
\end{tabular}

\section*{SOFTWARE CIRCUITS}

The R96FAX comprises two signal processor chips. Each of these chips contains 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. The registers are referred to as interface memory. Register in chip 0 update at the modem sample rate ( 9600 bps ). Registers in chip 1 update at the selected baud rate.

Digital Interface Characteristics
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Units} & \multicolumn{8}{|c|}{Input/Output Type} \\
\hline & & & IA & IB & IC & OA & OB & OC & I/O A & I/O B \\
\hline \(\mathrm{V}_{\mathrm{IN}}\) & Input Voltage, High & V & 2.0 min . & 2.0 min . & 2.0 min & & & & 2.0 min . & \[
\begin{aligned}
& 5.25 \mathrm{max} . \\
& 2.0 \mathrm{~min} .
\end{aligned}
\] \\
\hline \(\mathrm{V}_{\text {IL }}\) & Input Voltage, Low & \(v\) & 0.8 max. & 0.8 max. & 0.8 max. & & & & 0.8 max. & 0.8 max. \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output Voltage, High & \(v\) & & & & 2.4 min. \({ }^{1}\) & & & 2.4 min. 1 & 2.4 min. \({ }^{3}\) \\
\hline \(\mathrm{V}_{\text {OL }}\) & Output Voltage, Low & V & & & & 0.4 max. \({ }^{2}\) & 0.4 max. \({ }^{2}\) & 0.4 max. \({ }^{2}\) & 0.4 max. \({ }^{2}\) & 0.4 max. \({ }^{2}\) \\
\hline \(\mathrm{I}_{\text {IN }}\) & Input Current, Leakage & \(\mu \mathrm{A}\) & \(\pm 2.5\) max. & & & & & & \(\pm 12.5\) max. \({ }^{4}\) & \\
\hline \(\mathrm{IOH}^{\mathrm{I}}\) & Output Current, High & mA & & & & -0.1 max. & & & & \\
\hline lol & Output Current, Low & mA & & & & 1.6 max. & 1.6 max. & 1.6 max. & & \\
\hline IL & Output Current, Leakage & \(\mu \mathrm{A}\) & & & & & \(\pm 10 \mathrm{max}\). & & & \\
\hline Ipu & Pull-up Current & \({ }_{\mu} \mathrm{A}\) & & - 240 max. & -240 max. & & & -240 max. & & -260 max. \\
\hline & (Short Circuit) & & & -10 min. & - 10 min . & & & -10 min. & & - 100 min . \\
\hline \(\mathrm{C}_{\mathrm{L}}\) & Capacitive Load
Capacitive Drive & pF & 5 & 5 & 20 & & & & 10 & 40 \\
\hline \(C_{\text {D }}\) & Capacitive Drive Circuit Type & pF & & & & \[
100
\] & \[
\begin{gathered}
100 \\
\text { Open-Drain }
\end{gathered}
\] & & & 100
Open-Drain \\
\hline & Circuit Type & & TTL & TTL w/Pull-up & TTL w/Pull-up & & Open-Drain & Open Drain w/Pull-up & 3 State Transceiver & Open-Drain w/Pull-up \\
\hline \multicolumn{11}{|l|}{Notes} \\
\hline \multicolumn{11}{|l|}{1. I load \(=-100 \mu \mathrm{~A}\)} \\
\hline \multicolumn{11}{|l|}{2. 1 load \(=1.6 \mathrm{~mA}\)} \\
\hline \multicolumn{11}{|l|}{3. 1 load \(=-40 \mu \mathrm{~A}\)} \\
\hline \multicolumn{11}{|l|}{4. \(\mathrm{V}_{\mathrm{IN}}=0.4\) to \(2.4 \mathrm{Vdc}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{Vdc}\)} \\
\hline
\end{tabular}

When information in these registers is being discussed, the format \(Y: Z: Q\) is used. The chip 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.

\section*{Status/Control Bits}

The operation of the R96FAX is affected by a number of software control inputs. These inputs are written into registers within the interface memory via the host microprocessor bus. 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 interface memory via the host microprocessor bus. All status and control bits are defined in the Interface Memory table. Bits designated by an ' \(R\) ' are reserved for modem use only and must not be changed by the host.

\section*{Ram Data Access}

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.

Two RAM access registers are provided in the interface memory to allow user access to various RAM locations within the modem. The access code stored in 0:F selects the source of data for the RAM data registers in chip 0 ( \(0: 0\) through \(0: 3\) ). Similarly, the access code stored in 1:F selects the source of data for registers 1:0 through 1:3. Reading is performed by storing the desired
access code in register 0:F (or 1:F), performing a read of 0:0 (or \(1: 0\) ) to reset \(0: \mathrm{E}: 0\) (or \(1: \mathrm{E}: 0\) ), then waiting for \(0: \mathrm{E}: 0\) (or \(1: \mathrm{E}: 0\) ) to return to a one. The data may now be read from 0:3 through 0:0 (or 1:3-1:0).

Data in registers 1:3 and 1:1 are presented serially on EYEX and EYEY, respectively.

\section*{RAM Access Codes}

The RAM access codes defined in the following table allow the host processor to read diagnostic information within the modem.

RAM Access Codes
\begin{tabular}{|r|l|c|c|r|}
\hline No. & \multicolumn{1}{|c|}{ Function } & Access & Chip & Reg. No. \\
\hline 1. & Received Signal Samples & 40 & 0 & 2,3 \\
2. & Demodulator Output & 42 & 0 & \(0,1,2,3\) \\
3. & Low Pass Filter Output & 54 & 0 & \(0,1,2,3\) \\
4. & Average Energy & 5 C & 0 & 2,3 \\
5. & AGC Gain Word & 01 & 0 & 2,3 \\
\hline 6. & Equalizer Input & 40 & 1 & \(0,1,2,3\) \\
7. & Equalizer Tap Coefficients & \(01-20\) & 1 & \(0,1,2,3\) \\
8. & Unrotated Equalizer Output & 61 & 1 & \(0,1,2,3\) \\
9. & Rotated Equalizer Output & 22 & 1 & \(0,1,2,3\) \\
& (Received Point-Eye Pattern) & & & \\
10. & Decision Points (Ideal) & 62 & 1 & \(0,1,2,3\) \\
11. & Error Vector & 63 & 1 & \(0,1,2,3\) \\
12. & Rotation Angle & 00 & 1 & 0,1 \\
13. & Frequency Correction & 28 & 1 & 2,3 \\
14. & EQM & \(2 B\) & 1 & 2,3 \\
15. & Group II Base Band Signal & 48 & 1 & 2,3 \\
16. & G2 AGC Gain Word & 2 D & 1 & 2,3 \\
\hline
\end{tabular}

R96FAX Interface Memory Chip 0 ( \(\overline{\mathbf{C S O}})\)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & PDM & \multicolumn{7}{|c|}{RAM ACCESS S} \\
\hline E & IAO & R & R & R & SETUP & IEO & R & DAO \\
\hline D & R & R & R & R & R & R & R & R \\
\hline C & R & R & R & R & R & R & R & R \\
\hline B & R & R & R & R & R & R & R & R \\
\hline A & R & R & R & R & R & R & R & R \\
\hline 9 & R & R & R & R & R & R & R & R \\
\hline 8 & R & R & R & R & R & R & R & R \\
\hline 7 & R & R & R & R & R & R & R & R \\
\hline 6 & R & R & R & R & R & R & R & R \\
\hline 5 & RTS & TDIS & X & X & EPT & SQEXT & T2 & LRTH \\
\hline 4 & \multicolumn{8}{|c|}{CONFIGURATION} \\
\hline 3 & \multicolumn{8}{|c|}{RAM DATA XSM; FREQM} \\
\hline 2 & \multicolumn{8}{|c|}{RAM DATA XSL; FREQL} \\
\hline 1 & \multicolumn{8}{|c|}{RAM DATA YSM} \\
\hline 0 & \multicolumn{8}{|c|}{RAM DATA YSL; TRANSCEIVER DATA} \\
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{9}{|l|}{\begin{tabular}{l}
\(\mathrm{X}=\) User available (not used by modem). \\
\(R=\) Reserved (modem use only).
\end{tabular}} \\
\hline
\end{tabular}

R96FAX Interface Memory Chip 1 ( \(\overline{\text { CS1 }}\) )
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & \multicolumn{8}{|c|}{RAM ACCESS B} \\
\hline E & IA1 & R & R & R & R & IE1 & R & DA1 \\
\hline D & X & TLE & RLE & J3L & X & X & X & R \\
\hline C & X & X & X & X & X & X & X & G2FGC \\
\hline B & F3 & F2 & F1 & R & A & R & R & R \\
\hline A & R & R & R & R & R & R & R & R \\
\hline 9 & R & R & R & R & R & R & R & R \\
\hline 8 & R & R & R & R & R & R & R & R \\
\hline 7 & R & PNDET & R & R & R & R & R & CDET \\
\hline 6 & R & R & R & R & R & R & R & R \\
\hline 5 & R & \(\overline{\text { FED }}\) & R & R & R & R & R & R \\
\hline 4 & R & R & R & R & R & \(\overline{\text { P2DET }}\) & R & R \\
\hline 3 & \multicolumn{8}{|c|}{RAM DATA XBM} \\
\hline 2 & \multicolumn{8}{|c|}{RAM DATA XBL} \\
\hline 1 & \multicolumn{8}{|c|}{RAM DATA YBM} \\
\hline 0 & \multicolumn{8}{|c|}{RAM DATA YBL} \\
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{9}{|l|}{\begin{tabular}{l}
\(\mathrm{X}=\) User available (not used by modem). \\
\(R=\) Reserved (modem use only).
\end{tabular}} \\
\hline
\end{tabular}

\section*{R96FAX Interface Memory Definitions}
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & Description \\
\hline \(\overline{\text { CDET }}\) & Carrier Detector & 1:7:0 & The zero state of \(\overline{C D E T}\) indicates passband energy is being detected, and a training sequence is not present. \(\overline{\text { CDET }}\) goes to zero at the start of the data state, and returns to one at the end of the received signal. \\
\hline \multirow[t]{23}{*}{(None)} & \multirow[t]{23}{*}{Configuration} & \multirow[t]{23}{*}{0:4:0-7} & \multirow[t]{2}{*}{The host processor configures the R96FAX by writing a control code into the configuration register in the interface memory space.} \\
\hline & & & \\
\hline & & & Configuration Control Codes \\
\hline & & & Control codes for the five available R96FAX configurations are: \\
\hline & & & Configuration Configuration Code (HEX) \\
\hline & & & V. 29960014 \\
\hline & & & V. 29720012 \\
\hline & & & V. 294800 \\
\hline & & & V. 274800 OA \\
\hline & & & V272400 09 \\
\hline & & & FSK 20 \\
\hline & & & Group II 40 \\
\hline & & & Tone Transmit 80 \\
\hline & & & Configuration Definitions \\
\hline & & & Definitions for the five available R96FAX configurations are: \\
\hline & & & 1. V.29. When any of the V. 29 configurations has been selected, the modem operates as specified in CCITT recommendation V. 29. \\
\hline & & & 2. V.27. When any of the V. 27 configurations has been selected, the modem operates as specified in CCITT recommendation V. 27 ter. \\
\hline & & & 3. FSK. The modem operates as a CCITT T30 compatible 300 bps FSK modem having characteristics of the CCITT V. 21 channel 2 modulation system \\
\hline & & & 4. Group II. The modem operates as a CCITT T. 3 compatıble AM modem. This permits transmission to and reception from Group II facsımile apparatus. A carrier frequency of 2100 Hz is used. A black signal is transmitted as no carrier. The phase of the carrier representing white is reversed after each transition through black. \\
\hline & & & 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 available on the microprocessor bus. \\
\hline & & & 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. \\
\hline & & & 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. \\
\hline & & & 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.146486 \mathrm{~Hz} \pm 0.01 \%\). The frequency generated is \(\mathfrak{f}=0.146486\) ( 256 FREQM + FREQL) \(\mathrm{Hz} \pm 0.01 \%\). \\
\hline DAO & Data Available (Zero) & O:E:O & DAO goes to one when the modem writes data into register 0:0. DAO goes to zero when the host processor reads data from register 0:0. DAO is used for parallel mode as well as for diagnostic data retrieval. \\
\hline DA1 & Data Available (One) & 1:E:0 & DA1 goes to one when the modem reads or writes register 1:0. DA1 goes to zero when the host processor reads data from, or writes data into, register 1:0. \\
\hline
\end{tabular}

R96FAX Interface Memory Definitions (continued)


R96FAX Interface Memory Definitions (continued)
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & Description \\
\hline \(\overline{\text { PNDET }}\) & \begin{tabular}{l}
Period 'N' \\
Detector
\end{tabular} & 1:7:6 & The zero state of \(\overline{\text { PNDET }}\) indicates a PN sequence has been detected. \(\overline{\text { PNDET }}\) sets to a one at the end of the PN sequence. \\
\hline \(\overline{\text { P2DET }}\) & \begin{tabular}{l}
Period '2' \\
Detector
\end{tabular} & 1:4:2 & The zero state of \(\overline{\text { P2DET indicates a P2 sequence has been detected. } \overline{\text { P2DET }} \text { sets to a one at the }}\) start of the PN sequence. \\
\hline (None) & RAM Access B & 1:F:0-7 & Contains the RAM access code used in reading or writing RAM locations in Chip 1 (baud rate device). \\
\hline (None) & RAM Access S & 0:F:0-6 & Contains the RAM access code used in reading RAM locations in Chip 0 (sample rate device). \\
\hline (None) & RAM Data XBL & 1:2:0-7 & Least significant byte of 16 -blt word x used in reading RAM locations In Chip 1 (baud rate device). \\
\hline (None) & RAM Data XBM & 1:3:0-7 & Most significant byte of 16-bit word x used in reading RAM locations in Chip 1 (baud rate device). \\
\hline (None) & RAM Data XSL & 0:2:0-7 & Least significant byte of 16 -bit word x used in reading RAM locations in Chip 0 (sample rate device). \\
\hline (None) & RAM Data XSM & 0:3:0-7 & Most significant byte of 16 -bit word x used in reading RAM locations in Chip 0 (sample rate device). \\
\hline (None) & RAM Data YBL & 1:0:0-7 & Least significant byte of 16 -bit word \(y\) used in reading or writing RAM locations in Chip 1 (baud rate device). See DA1. \\
\hline (None) & RAM Data YBM & 1:1:0-7 & Most significant byte of 16 -bit word y used in reading or writing RAM locations in Chip 1 (baud rate device). \\
\hline (None) & RAM Data YSL & 0:0:0-7 & Least significant byte of 16 -bit word \(y\) used in reading RAM locations in Chip 0 (sample rate device). Shared by parallel data mode for presenting channel data to the host microprocessor bus. See Transceiver Data and DAO. \\
\hline (None) & RAM Data YSM & 0:1:0-7 & Most significant byte of 16 -bit word y used in reading RAM locations in Chip 0 (sample rate device). \\
\hline RLE & Receiver Link Equalizer & 1:D:5 & The one state of RLE enables the link amplitude equalizer in the receiver. \\
\hline RTS & Request-to-Send & 0:5:7 & The one state of RTS begins a transmit sequence. The modem will continue to transmit until RTS is turned off, and the turn-off sequence has been completed. RTS parallels the operation of the hardware RTS control input. These inputs are "ORed" by the modem. \\
\hline SETUP & Setup & 0:E:3 & The one state of SETUP causes the modem to reconfigure to the control word in the configuration register, and to assume the options specifled for equalizer ( \(0: 5: 1\) ) and threshold ( \(0: 5: 0\) ). SETUP returns to zero when acted on by the modem. \\
\hline SQEXT & Squelch Extend & 0:5:2 & The one state of SQEXT inhibits reception of signals for 130 ms after the turn-off sequence. \\
\hline TDIS & Training Disable & 0:5:6 & If TDIS is a one in the receive state, the modem is prevented from entering the training phase. If TDIS is a one prior to RTS going on, the generation of a training sequence is prevented at the start of transmission. \\
\hline TLE & Transmitter Link Equalizer & 1:D:6 & The one state of TLE enables the link amplitude equalizer in the transmitter. \\
\hline (None) & Transceiver Data & 0:0:0-7 & In parallel data mode, the modem presents eight bits of channel data in register 0:0 for reading by the host microprocessor. After the eight blts have been accumulated they are transierred to 0:0 and bit \(0: E: 0\) goes to a one. When the host reads \(0: 0\), bit \(0: E: 0\) resets to a zero. The first blt of recelved data is not necessarily located in bit 0:0:0. The host must frame the received data by searching for message sync characters. Blt \(0: E: 0\) sets at one eighth the bit rate in parallel data mode rather than at the sample rate \((9600 \mathrm{~Hz})\) as it does when reading RAM locations. \\
\hline T2 & T/2 Equalizer Select & 0:5:1 & If T 2 is a one, an adaptive equalizer with two taps per baud is used. If T2 is a zero, an adaptlve equalizer with one tap per baud is used. The number of taps remains the same for both cases. \\
\hline
\end{tabular}

\section*{POWER-ON INITIALIZATION}

When power is applied to the R96FAX, a period of 50 to 350 ms is required for power supply settling. The power-on-reset signal (POR) remains low during this period. Approximately 10 ms after the low to high transition of POR, the modem is ready to be configured, and RTS may be activated. If the 5 Vdc power supply drops below 3.5 Vdc for more than 30 msec , the POR cycle is repeated.

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 be connected to a user supplied power-on-reset signal in a wire-or configuration. A low active pulse of \(3 \mu \mathrm{sec}\) or longer applied to the POR pin causes the modem to reset. The modem is ready to be configured 10 msec after the low active pulse is removed from POR.

\section*{PERFORMANCE}

Whether functioning as a V. 27 ter or V. 29 type modem, the R96FAX provides the user with unexcelled high performance.

\section*{BIT ERROR RATES}

The Bit Error Rate (BER) performance of the modem is specified


Typical Bit Error Rate
(Back to Back, T Equalizer, Level - \(20 \mathbf{d B m}\) )
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.

\section*{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 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 \(20^{\circ}\) peak-to-peak phase jitter at 30 Hz .

An example of the BER performance capabilities is given in the following diagrams:


Typical Bit Error Rate
(Unconditioned (3002) Line, T Equalizer, Level - 20 dBm )

The BER performance test set-up is shown in the following
diagram:


BER Performance Test Set-up

\section*{GENERAL SPECIFICATIONS}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{8}{c|}{ Power } \\
\hline Voltage & Tolerance & Current (Typical) @ 25 \({ }^{\circ} \mathbf{C}\) & Current (Max) \\
\hline+5 Vdc & \(\pm 5 \%\) & 400 mA & \(<500\) \\
+12 Vdc & \(\pm 5 \%\) & 5 mA & \(<10\) \\
-12 Vdc & \(\pm 5 \%\) & 20 mA & \(<50\) \\
\hline Note: All voltages must have ripple \(\leq 0.1\) volts peak-to-peak. & \\
\hline
\end{tabular}

\section*{Environmental}
\begin{tabular}{|c|c|}
\hline Parameter & \\
\hline 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 \(+80^{\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. \\
\hline
\end{tabular}

\section*{Mechanical}
\begin{tabular}{|l|l|}
\hline \multicolumn{1}{|c|}{ Parameter } & \multicolumn{1}{c|}{ Specification } \\
\hline Board Structure & Single PC board with single right angle header with 40 pins. Burndy FRS 40BS8P or equivalent \\
& mating connector. \\
Dimensions & Length- \(2.56 \mathrm{in} .(65 \mathrm{~mm})\) \\
& Width—3.94 in. \((100 \mathrm{~mm})\) \\
& Height-0.40 in. \((10.2 \mathrm{~mm})\) \\
Weight & Less than-2.6 oz. \((73 \mathrm{~g})\) \\
Lead Extrusion & Maximum-0.100 in. \((2.54 \mathrm{~mm})\) \\
\hline
\end{tabular}


R96FAX Pin Assignment and PCB Dimensions

\section*{Rockwell}

\section*{R96DP \\ 9600 BPS DATA PUMP MODEM}

\section*{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.

\section*{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
- Local Analog (V. 54 Loop 3)
- Remote Analog (Locally Activated)
- Remote Digital (Locally Activated V. 54 Loop 2)
- 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

\section*{TECHNICAL SPECIFICATIONS}

\section*{TRANSMITTER CARRIER FREQUENCIES}

Transmilter Carrier Frequencles
\begin{tabular}{|l|c|}
\hline Function & \begin{tabular}{c} 
Frequency \\
\((\mathbf{H z} \pm \mathbf{0 . 0 1 \% )}\)
\end{tabular} \\
\hline V. 27 bis/ter Carrier & 1800 \\
V. 29 Carrier & 1700 \\
\hline
\end{tabular}

\section*{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.

\section*{SIGNALING AND DATA RATES}

Signaling/Data Rates
\begin{tabular}{|l|l|}
\hline Parameter & \begin{tabular}{c} 
Specification \\
\(( \pm 0.01 \%)\)
\end{tabular} \\
\hline Signaling Rate: & 2400 Baud \\
Data Rate: & 9600 bps, \\
& 7200 bps, \\
& 4800 bps \\
\hline Signaling Rate: & 1600 Baud \\
Data Rate: & 4800 bps \\
\hline Signaling Rate: & 1200 Baud \\
Data Rate: & 2400 bps \\
\hline
\end{tabular}

\section*{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.

\section*{EQUALIZERS}

The R96DP provides equalization functions that improve performance when operating over low quality lines.

Cable Fquallipere - Selestahle nomprnmise oable 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.

Automatlc Adaptive Equalizer - An automatic adaptive equalizer is provided in the recelver circuit. The equalizer can be configured as either a \(T\) or a \(T / 2\) equalizer.

\section*{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 specifled by Part 68 of the FCC's rules, and typically exceed the requirements of foreign telephone regulatory bodies.

\section*{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.

\section*{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.

\section*{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).

\section*{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.

\section*{TRANSMIT LEVEL}

The transmitter output level is accurate to \(\pm 1.0 \mathrm{~dB}\) and is programmable from \(\mathbf{- 1 . 0} \mathrm{dBm}\) to \(\mathbf{- 1 5 . 0} \mathrm{dBm}\) in 2 dB steps.

\section*{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.

\section*{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 \(\pm 0.01 \%\) with a duty cycle of \(50 \% \pm 20 \%\).

\section*{TRAIN ON DATA}

When train on data is enabled, the receiver typically trains on data in less than 15 seconds for V. 29 and 3.5 seconds for V.27.

\section*{TURN-ON SEQUENCE}

A total of 14 selectable turn-on sequences can be generated as defined in the following table:
\begin{tabular}{|c|c|c|c|c|}
\hline No. & V. 29 & V. 27 bis/ter & \begin{tabular}{l}
CTS \\
Response Time (milliseconds)
\end{tabular} & Comments \\
\hline 1 & 9600 bps & & 253 & \\
\hline 2 & 7200 bps & & 253 & \\
\hline 3 & 4800 bps & & 253 & \\
\hline 4 & & 4800 bps long & 708 & \\
\hline 5 & & 2400 bps long & 943 & \\
\hline 6 & & 4800 bps short & 50 & \\
\hline 7 & & 2400 bps short & 67 & \\
\hline 8 & 9600 bps & & 458 & Preceded by \\
\hline 9 & 7200 bps & & 458 & Echo Protector \\
\hline 10 & 4800 bps & & 458 & Tone for lines \\
\hline 11 & & 4800 bps long & 913 & using echo \\
\hline 12 & & 2400 bps long & 1148 & supressors* \\
\hline 13 & & 4800 bps short & 255 & \\
\hline 14 & & 2400 bps short & 272 & \\
\hline \multicolumn{5}{|r|}{*For short echo protector tone, subtract 155 ms from values of CTS response time.} \\
\hline
\end{tabular}

\section*{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.

\section*{CLAMPING}

Received Data (RXD) is clamped to a constant mark (one) whenever the Received Line Signal Detector (RLSD) is off.

\section*{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 2 baud times.

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.

\section*{RECEIVED LINE SIGNAL DETECTOR (RLSD)}

For 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 \(\mathbf{- 2 1 d B m}\) (RLSD off)

\section*{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).

\section*{MODES OF OPERATION}

The R96DP is capable of being operated in either a serial or a parallel mode of operation.

\section*{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.

\section*{PARALLEL MODE}

The R96DP has the capability of transferring channel data up to eight bits at a time via the microprocessor bus.

\section*{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

\section*{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.

\section*{HARDWARE CIRCUITS}

Signal names and descriptions of the hardware circuits, including the microprocessor interface, are listed in the R96DP Hardware Circuits table. In the table, the column titled 'Type' refers to designations found in the Hardware Circuit Characteristics. 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 Circuits
\begin{tabular}{|c|c|c|c|}
\hline Name & Type & Pin No. & Description \\
\hline \multicolumn{4}{|l|}{A. OVERHEAD:} \\
\hline Ground (A) & AGND & 31C,32C & Analog Ground Return \\
\hline Ground (D) & DGND & 3C,8C,5A,10A & Digital Ground Return \\
\hline + 5 volts & PWR & 19C,23C,26C,30C & +5 volt supply \\
\hline + 12 volts & PWR & 15A & + 12 volt supply \\
\hline \(\frac{-12}{}\) volts & PWR & 12A & -12 volt supply \\
\hline \(\overline{\text { POR }}\) & I/OA & 13C & Power-on-reset \\
\hline \multicolumn{4}{|l|}{B. MICROPROCESSOR INTERFACE:} \\
\hline D7 & I/OA & 1 C & \\
\hline D6 & I/OA & & \\
\hline D5 & I/OA & 2 C & \\
\hline D4 & I/OA & & Data Bus (8 Bits) \\
\hline D3 & I/OA & & \\
\hline D2 & I/OA & 4 C & \\
\hline D1 & I/OA & & \\
\hline D0 & I/OA & 5 C J & \\
\hline RS3 & IA & 6 C & \\
\hline RS2 & IA & 6A & Register Select \\
\hline RS1 & IA & 7 C & (4 Bits) \\
\hline RSO & IA & 7 A & \\
\hline \(\overline{\text { cso }}\) & IA & 10 C & Chip Select \\
\hline & & & Transmitter Device \\
\hline \(\overline{\mathrm{CS} 1}\) & IA & 9 C & Chip Select Receiver Sample Rate Device \\
\hline \(\overline{\text { CS2 }}\) & IA & 9A & Chip Select Receiver Baud Rate Device \\
\hline READ & IA & 12 C & Read Enable \\
\hline WRITE & IA & 11A & Write Enable \\
\hline \(\overline{\mathrm{R} Q}\) & OB & 11C & Interrupt Request \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|r|}{R96DP Hardware Circuits (Cont.)} \\
\hline Name & Type & Pln No. & Description \\
\hline \multicolumn{4}{|l|}{C. V. 24 INTERFACE:} \\
\hline \(\overline{\text { RDCLK }}\) & OC & 21A & Recelve Data Clock \\
\hline TDCLK & 0 C & 23A & Transmit Data Clock \\
\hline XTCLK & IB & 22A & External Transmit Clock \\
\hline RTS & IB & 25A & Request-to-Send \\
\hline CTS & OC & 25 C & Clear-to-Send \\
\hline TXD & 18 & 24C & Transmitter Data \\
\hline RXD & OC & 22 C & Receiver Data \\
\hline RLSD & OC & 24A & Received Line Signal Detector \\
\hline \multicolumn{4}{|l|}{D. ANCILLARY CIRCUITS:} \\
\hline \[
\frac{\overline{\text { RBCLK }}}{\frac{\text { TBCLK }}{}}
\] & \[
\begin{aligned}
& \mathrm{OC} \\
& \mathrm{OC}
\end{aligned}
\] & \[
\begin{aligned}
& 26 A \\
& 27 C
\end{aligned}
\] & Receiver Baud Clock Transmitter Baud Clock \\
\hline \multicolumn{4}{|l|}{E. ANALOG SIGNALS:} \\
\hline TXA & AA & 31A & Transmitter Analog Output \\
\hline RXA & AB & 32A & Receiver Analog Input \\
\hline AUXIN & AC & 30A & Auxillary Analog Input \\
\hline \multicolumn{4}{|l|}{F. DIAGNOSTIC:} \\
\hline EYEX & OC & 15C & Eye Pattern Data-X Axis \\
\hline EYEY & \({ }^{\circ} \mathrm{C}\) & 14A & Eye Pattern Data-Y Axis \\
\hline EYECLK & OA & 14 C & Eye Pattern Clock \\
\hline EYESYNC & OA & 13A & Eye Pattern Synchronizing Signal \\
\hline
\end{tabular}

\section*{EYE PATTERN GENERATION}

The four hardware diagnostic circuits, identified in the preceding table, 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.

MICROPROCESSOR TIMING


Microprocessor Interface TIming Diagram

Critical Timing Requirements
\begin{tabular}{|l|c|c|c|c|}
\hline \multicolumn{1}{|c|}{ Characteristic } & Symbol & Min & Max & Unlts \\
\hline 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 \\
\hline
\end{tabular}

\section*{HARDWARE CIRCUIT CHARACTERISTICS}

\section*{Digital Interface Characteristics}

Digital Interface Characteristics
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Units} & \multicolumn{8}{|c|}{Input/Output Type} \\
\hline & & & IA & IB & IC & OA & OB & OC & I/O A & I/O B \\
\hline \(\mathrm{V}_{\mathrm{IH}}\) & Input Voltage, High & V & 2.0 Min. & 2.0 Min. & 2.0 Min. & & & & 2.0 Min. & \[
\begin{aligned}
& \text { 5.25 Max. } \\
& \text { 2.0 Min. }
\end{aligned}
\] \\
\hline \(\mathrm{V}_{\mathrm{IL}}\) & Input Voltage, Low & V & 0.8 Max. & 0.8 Max. & 0.8 Max. & & & & 08 Max. & 08 Max . \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output Voltage, High & V & & & & 2.4 Min. \({ }^{1}\) & & & 2.4 Min. \({ }^{1}\) & 2.4 Min \({ }^{3}\) \\
\hline \(\mathrm{V}_{\mathrm{OL}}\) & Output Voltage, Low & V & & & & 0.4 Max \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 04 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) \\
\hline \(\mathrm{I}_{\text {N }}\) & Input Current, Leakage & \(\mu \mathrm{A}\) & \(\pm\) 2.5 Max. & & & & & & \(\pm 2.5 \mathrm{Max} .^{4}\) & \\
\hline \(\mathrm{IOH}^{\text {I }}\) & Output Current, High & mA & & & & -0.1 Max. & & & & \\
\hline lOL & Output Current, Low & mA & & & & 1.6 Max & 1.6 Max. & 1.6 Max. & & \\
\hline IL & Output Current, Leakage & \(\mu \mathrm{A}\) & & & & & \[
\pm 10 \mathrm{Max}
\] &  & & \\
\hline \(\mathrm{I}_{\mathrm{PU}}\) & Pull-up Current (Short Circuit) & \(\mu \mathrm{A}\) & & \[
\begin{aligned}
& \text { - } 240 \text { Max. } \\
& \text { - } 10 \text { Min. }
\end{aligned}
\] & \[
\begin{aligned}
& \text { - } 240 \text { Max. } \\
& \text { - } 10 \text { Min. }
\end{aligned}
\] & & & \[
\begin{aligned}
& \text { - } 240 \text { Max. } \\
& \text { - } 10 \text { Min }
\end{aligned}
\] & & \[
\begin{aligned}
& \text { - } 260 \text { Max. } \\
& \text { - } 100 \text { Mın. }
\end{aligned}
\] \\
\hline \(\mathrm{C}_{\mathrm{L}}\) & Capacitive Load & pF & 5 & 5 & 20 & & & & 10 & 40 \\
\hline \(\mathrm{C}_{\mathrm{D}}\) & Capacitive Drive & pF & & & & 100 & 100 & 100 & 100 & 100 \\
\hline & Circuit Type & & TTL & TTL w/Pull-up & TTL w/Pull-up & TTL & Open-Drain & Open-Drain w/Pull-up & 3-State Transceiver & Open-Draın w/Pull-up \\
\hline & & & & & Notes & & & & & \\
\hline & & 1 Load & \(=-100 \mu \mathrm{~A}\) & & 3. 1 Load \(=\) & \(-40 \mu \mathrm{~A}\) & & & & \\
\hline & & I Load & \(=1.6 \mathrm{~mA}\) & & 4. \(\mathrm{V}_{\mathrm{IN}}=0\). & to 24 Vdc & c, \(V_{C C}=5.2\) & 5 Vdc & & \\
\hline
\end{tabular}

\section*{Analog Interface Characteristics}

Analog Interface Characteristics
\begin{tabular}{|l|l|l|}
\hline Name & Type & \multicolumn{1}{c|}{ Characteristics } \\
\hline TXA & AA & \begin{tabular}{l} 
The transmitter output is a low impedance \\
operational amplifier output. In order to match to \\
600 ohms, an external series resistor is required.
\end{tabular} \\
AUA & AB & \begin{tabular}{l} 
The receiver input impedance is 63.4 K ohms \\
\(\pm 5 \%\).
\end{tabular} \\
The auxiliary analog input allows access to the \\
transmitter for the purpose of interfacing with \\
user provided equipment. Because this is a \\
sampled data input, any signal above 4800 Hz \\
will cause aliasing errors. The input impedance \\
is 1K ohms, and the gain to transmitter output is \\
\(-1 \mathrm{~dB} \pm 1 \mathrm{~dB}\).
\end{tabular}

\section*{SOFTWARE CIRCUITS}

The R96DP comprises three signal processor chips. Each of these chips contains 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. The regisiers are referred to as interface memory. Registers in chip 1 update at half the modem sample rate ( 4800 bps ). Registers in chip 0 and 2 update at the selected baud rate.

When information in these registers is being discussed, the format \(Y: Z: Q\) is used. The chip is specified by \(Y(0-2)\), the register by \(Z(0-F)\), and the bit by \(Q(0-7,0=L S B)\).

\section*{Status Control Bits}

The operation of the R96DP is affected by a number of software control inputs. These inputs are written into registers within the interface memory via the host microprocessor bus. 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 interface memory via the host microprocessor bus. All status and control bits are defined in the Interface Memory table. Bits designated by an 'R' are reserved for modem use only and must not be changed by the host.

\section*{RAM Data Access}

The R96DP provides the user with access to much of the data stored in the modem's memories. This data is useful for performing certain diagnostic functions.
Two RAM access registers in chip 1 allow user access to RAM locations via the \(X\) word registers (1:3 and 1:2) and the \(Y\) word registers ( \(1: 1\) and \(1: 0\) ). Comparable registers in chip 2 provide access to chip 2 RAM locations. The access code stored in RAM ACCESS XS ( \(1: 5\) ) selects the source of data for RAM DATA XSM and RAM DATA XSL (1:3 and 1:2). Similarly, the access code stored in RAM ACCESS YS (1:4) selects the source of data for RAM DATA YSM and RAM DATA YSL (1:1 and 1:0). Chip 2 registers are associated in the same way.
Reading of RAM data is performed by storing the necessary access codes in 1:5 and 1:4 (or 2:5 and 2:4), reading 1:0 (or 2:0) to reset the associated data available bit (1:E:0 or 2:E:0), then waiting for the data available bit to return to a one. Data is now valid and may be read from 1:3 through 1:0 (or 2:3 through 2:0). The contents of registers 2:3 and 2:1 are also available serially on outputs EYEX and EYEY, respectively, unless the IFIX bit (1:6:7) is set to a one. When IFIX is a one, EYEX and EYEY remain fixed on the rotated equalizer output.

\section*{RAM Access Codes}

The RAM access codes defined in the following table allow the host processor to read diagnostic information within the modem.

RAM Access Codes.
\begin{tabular}{|c|c|c|c|c|c|}
\hline No. & Function & Chip & X Access & Y Access & Register \\
\hline 1 & Received Signal Samples & 1 & C0 & Not Used & 2,3 \\
\hline 2 & Demodulator Output & 1 & C2 & 42 & 0,1,2,3 \\
\hline 3 & Low Pass Filter Output & 1 & D4 & 54 & 0,1,2,3 \\
\hline 4 & Average Energy & 1 & Not Used & 04 & 0,1 \\
\hline 5 & AGC Gain Word & 1 & 81 & Not Used & 2,3 \\
\hline 6 & Equalizer Input & 2 & C0 & 40 & 0,1,2,3 \\
\hline 7 & Equalizer Tap Coefficients & 2 & 81 - AO & 01-20 & 0,1,2,3 \\
\hline 8 & Unrotated Equalizer Output & 2 & E1 & 61 & 0,1,2,3 \\
\hline 9 & Rotated Equalizer Output (Received Points) & 2 & A2 & 22 & 0,1,2,3 \\
\hline 10 & Decision Points (Ideal Data Points) & 2 & E2 & 62 & 0,1,2,3 \\
\hline 11 & Error & 2 & E3 & 63 & 0,1,2,3 \\
\hline 12 & Rotation Angle & 2 & Not Used & 00 & 0,1 \\
\hline 13 & Frequency Correction & 2 & AA & Not Used & 2,3 \\
\hline 14 & EQM & 2 & A7 & Not Used & 2,3 \\
\hline 15 & Dual Point & 2 & AE & 2E & 0,1,2,3 \\
\hline
\end{tabular}

\section*{NOTE}

In the interface memory tables that follow, those columns. marked by an ' \(X\) ' indicate a user available bit position that is not currently used by the R96DP. However, those columns marked by an ' \(R\) ' indicate reserved and are for modem use only.

Transmitter Interface Memory Chip 0 ( \(\overline{\text { CSO }}\) )
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & R & R & R & R & R & R & R & R \\
\hline E & TIA & R & R & R & TSB & TIE & R & TBA \\
\hline D & R & R & R & R & R & R & R & R \\
\hline C & R & R & R & R & R & R & R & R \\
\hline B & R & R & R & R & R & R & R & R \\
\hline A & R & R & R & R & R & R & R & R \\
\hline 9 & R & R & R & R & R & R & R & R \\
\hline 8 & R & R & R & R & R & R & R & R \\
\hline 7 & RTS & TTDIS & SDIS & MHLD & EPT & TPDM & XCEN & SEPT \\
\hline 6 & \multicolumn{8}{|c|}{TRANSMITTER CONFIGURATION} \\
\hline 5 & X & X & & EQ & LAEN & LDEN & A3L & D3L \\
\hline 4 & LЗACT & L4ACT & L4HG & & TLVL & & L2ACT & LCEN \\
\hline 3 & \multicolumn{8}{|c|}{FREQM} \\
\hline 2 & \multicolumn{8}{|c|}{FREQL} \\
\hline 1 & R & R & R & R & R & R & R & R \\
\hline 0 & \multicolumn{8}{|c|}{TRANSMITTER DATA} \\
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline
\end{tabular}

\section*{Receiver Interface Memory Chip 1 ( \(\overline{\text { CS1 }})\)}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \begin{tabular}{l}
Bit \\
Register
\end{tabular} & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & R & R & R & R & R & R & R & R \\
\hline E & RSIA & R & R & R & RSB & RSIE & R & RSDA \\
\hline D & R & R & R & R & R & R & R & R \\
\hline C & R & R & R & R & R & R & R & R \\
\hline B & R & PNDET & R & R & R & R & R & CDET \\
\hline A & R & R & R & R & R & R & R & R \\
\hline 9 & R & FED & R & R & R & R & R & R \\
\hline 8 & R & R & R & R & R & P2DET & R & R \\
\hline 7 & \multicolumn{2}{|c|}{RTH} & DDIS & RPDM & R & R & T2 & RTDIS \\
\hline 6 & IFIX & TOD & \multicolumn{6}{|c|}{RECEIVER CONFIGURATION} \\
\hline 5 & \multicolumn{8}{|c|}{RAM ACCESS XS} \\
\hline 4 & \multicolumn{8}{|c|}{RAM ACCESS YS} \\
\hline 3 & \multicolumn{8}{|c|}{RAM DATA XSM} \\
\hline 2 & \multicolumn{8}{|c|}{RAM DATA XSL} \\
\hline 1 & \multicolumn{8}{|c|}{RAM DATA YSM} \\
\hline 0 & \multicolumn{8}{|c|}{RAM DATA YSL; RECEIVER DATA} \\
\hline Register Bit & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline
\end{tabular}

Receiver Interface Memory Chip 2 (CS2)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline  & 7 & 6 & : 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & R & R & R & R & R & R & R & R \\
\hline E & RBIA & R & R & R & R & RBIE & R & RBDA \\
\hline D & R & R & R & R & R & R & R & R \\
\hline C & R & R & R & R & R & R & R & R \\
\hline B & R & R & R & R & R & R & R & R \\
\hline A & R & R & R & R & R & R & R & R \\
\hline 9 & R & R & R & R & R & R & R & R \\
\hline 8 & R & R & R & R & R & R & R & R \\
\hline 7 & R & R & R & R & R & R & R & R \\
\hline 6 & R & R & R & R & R & R & R & R \\
\hline 5 & \multicolumn{8}{|c|}{RAM ACCESS XB} \\
\hline 4 & \multicolumn{8}{|c|}{RAM ACCESS YB} \\
\hline 3 & \multicolumn{8}{|c|}{RAM DATA XBM} \\
\hline 2 & \multicolumn{8}{|c|}{RAM DATA XBL} \\
\hline 1 & \multicolumn{8}{|c|}{RAM DATA YBM} \\
\hline 0 & \multicolumn{8}{|c|}{RAM DATA YBL} \\
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline
\end{tabular}

R96DP Interface Memory Definitions


R96DP Interface Memory Definitions (Continued)
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & Description \\
\hline \multirow[t]{5}{*}{LAEN} & Link Amplitude Equalizer Enable & 0:5:3 & The link amplitude equalizer enable and select bits control an amplitude compromise equalizer in the receive path according to the following table: \\
\hline & & & LAEN A3L Curve Matched \\
\hline & & & 0 X No Equalizer \\
\hline & & & 10 U.S. Survey Long \\
\hline & & & 11 Japanese 3-Link \\
\hline LCEN & Loop Clock Enable & 0:4:0 & When control bit LCEN is a one, the transmitter clock tracks the receiver clock. \\
\hline \multirow[t]{3}{*}{LDEN} & Link Delay Equalizer Enable & 0:5:2 & The link delay equalizer enable and select bits control a delay compromise equalizer in the receive path according to the following table: \\
\hline & & & LDEN D3L Curve Matched \\
\hline & & & \begin{tabular}{lll}
0 & \(X\) & No Equalizer \\
1 & 0 & U.S. Survey Long \\
1 & 1 & Japanese 3-Link
\end{tabular} \\
\hline L2ACT & Remote Digital Loopback Activate & 0:4:1 & When control bit L2ACT is a one, the receiver digital output is connected to the transmitter digital input in accordance with CCITT recommendation V. 54 loop 2. \\
\hline L3ACT & \begin{tabular}{l}
Local Analog \\
Loopback Activate
\end{tabular} & 0:4:7 & When control bit L3ACT is a one, the transmitter analog output is coupled to the receiver analog input through an attenuator in accordance with CCITT recommendation V. 54 loop 3. \\
\hline L4ACT & Remote Analog Loopback Activate & 0:4:6 & When control bit L4ACT is a one, the receiver analog input is connected to the transmitter analog output through a variable gain amplifier in a manner similar to recommendation V. 54 loop 4. \\
\hline L4HG & Loop 4 High Gain & 0:4:5 & When control bit L4HG is a one, the loop 4 variable gain amplifier is set for +16 dB , and when at zero the gain is zero dB. \\
\hline MHLD & Mark Hold & 0:7:4 & When control bit MHLD is a one, the transmitter input data stream is forced to all marks (ones). \\
\hline PNDET & Period N Detector & 1:B:6 & When status bit \(\overline{\text { PNDET }}\) is a zero, it indicates a PN sequence has been detected. This bit sets to a one at the end of the PN sequence. \\
\hline \(\overline{\text { P2DET }}\) & Period Two Detector & 1:8:2 & When status bit \(\overline{\text { P2DET }}\) is a zero, it indicates that a P2 sequence has been detected. This bit sets to a one at the start of the PN sequence. \\
\hline (None) & RAM Access XB & 2:5:0-7 & Contains the RAM access code used in reading chip 2 RAM locations via word \(X\) (2:3 and 2:2). \\
\hline (None) & RAM Access XS & 1:5:0-7 & Contains the RAM access code used in reading chip 1 RAM locations via word \(X\) (1:3 and \(1: 2\) ). \\
\hline (None) & RAM Access YB & 2:4:0-7 & Contains the RAM access code used in reading chip 2 RAM locations via word Y (2:1 and 2:0). \\
\hline (None) & RAM Access YS & 1:4:0-7 & Contains the RAM access code used in reading chip 1 RAM locations via word Y (1:1 and 1:0). \\
\hline (None) & RAM Data XBL & 2:2:0-7 & Least significant byte of 16-bit word X used in reading RAM locations in chip 2. \\
\hline (None) & RAM Data XBM & 2:3:0-7 & Most significant byte of 16-bit word X used in reading RAM locations in chip 2 . \\
\hline (None) & RAM Data XSL & 1:2:0-7 & Least significant byte of 16-bit word X used in reading RAM locations in chip 1. \\
\hline (None) & RAM Data XSM & 1:3:0-7 & Most significant byte of 16-bit word X used in reading RAM locations in chip 1. \\
\hline
\end{tabular}

R96DP Interface Memory Definitions (Continued)


R96DP Interface Memory Definitions (Continued)


R96DP Interface Memory Definitions (Continued)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & \multicolumn{9}{|c|}{Description} \\
\hline (None) & Transmitter Data & 0:0:0-7 & \multicolumn{9}{|l|}{\begin{tabular}{l}
The host processor conveys output data to the transmitter in the parallel mode by writing a data byte to the transmitter data register. The data is divided on baud boundaries, as follows: \\
NOTE \\
Data is transmitted bit zero first.
\end{tabular}} \\
\hline & & & \multicolumn{9}{|c|}{Bits} \\
\hline & & & Configuration & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline & & & V. 299600 bps & \multicolumn{4}{|c|}{Baud 1} & \multicolumn{4}{|c|}{Baud 0} \\
\hline & & & V. 297200 bps & \multicolumn{2}{|l|}{Not Used} & \multicolumn{3}{|c|}{Baud 1} & \multicolumn{3}{|c|}{Baud 0} \\
\hline & & & V. 294800 bps & \multicolumn{2}{|r|}{Baud 3} & \multicolumn{2}{|l|}{Baud 2} & \multicolumn{2}{|c|}{Baud 1} & \multicolumn{2}{|c|}{Baud 0} \\
\hline & & & V. 274800 bps & \multicolumn{2}{|l|}{Not Used} & \multicolumn{3}{|c|}{Baud 1} & \multicolumn{3}{|c|}{Baud 0} \\
\hline & & & V. 272400 bps & \multicolumn{2}{|r|}{Baud 3} & \multicolumn{2}{|l|}{Baud 2} & \multicolumn{2}{|c|}{Baud 1} & \multicolumn{2}{|c|}{Baud 0} \\
\hline TSB & Transmitter Setup Bit & 0:E:3 & \multicolumn{9}{|l|}{When the host processor changes the transmitter configuration, the host must write a one in this control bit. TSB goes to a zero when the change becomes effective.} \\
\hline TTDIS & Transmitter Train Disable & 0:7:6 & \multicolumn{9}{|l|}{When control bit TTDIS is a one, the transmitter does not generate a training sequence at the start of transmission. With trainıng disabled, RTS/CTS delay is less than two baud times.} \\
\hline T2 & T/2 Equalizer Select & 1:7:1 & \multicolumn{9}{|l|}{When control bit T2 is a one, an adaptive equalizer with two taps per baud is used. When T2 is a zero, the equalizer has one tap per baud. The total number of taps remains the same for both cases.} \\
\hline XCEN & External Clock Enable & 0:7:1 & \multicolumn{9}{|l|}{When control bit XCEN is a zero, the transmitter timing is established by the external clock supplied at the hardware input XTCLK, pin 22A.} \\
\hline
\end{tabular}

\section*{POWER-ON INITIALIZATION}

When power is applied to the R96DP, a period of 50 to 350 ms is required for power supply settling. The power-on-reset signal (POR) remains low during this period. Approximately 10 ms after the low to high transition of POR, the modem is ready to be configured, and RTS may be activated. If the 5 Vdc power supply drops below 3.5 Vdc for more than 30 msec , the POR cycle is generated.

At POR time the modem defaults to the following configuration: V.29, \(9600 \mathrm{bps}, \mathrm{T} / 2\), standard echo protector tone, serial data mode, internal clock, cable equalizers disabled, link amplitude equalizer disabled, link delay equalizer disabled, transmitter output level set to \(-1 \mathrm{dBm} \pm 1 \mathrm{~dB}\), interrupts disabled, receiver threshold set to -43 dBm , eye pattern selectable, and train-ondata disabled.

POR can be ronnerted to a user supplied power-on-reset signal in a wire-or configuration. A low active pulse of \(3 \mu \mathrm{sec}\) or more applied to the POR pin causes the modem to reset. The modem is ready to be configured 10 msec after POR is removed

\section*{PERFORMANCE}

Whether functioning as a V. 27 ter or V. 29 type modem, the R96DP provides the user with unexcelled high performance.

\section*{BIT ERROR RATES}

The Bit Error Rate (BER) performance of the modem is specified for a test configuratio 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.

\section*{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 10 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 \(20^{\circ}\) peak-to-peak phase jitter at 30 Hz .

An example of the BER performance capabilities is given in the following diagram:


\section*{Worst Case BER Performance}
(Back-to-Back)

\section*{GENERAL SPECIFICATIONS}

Power
\begin{tabular}{|c|c|c|}
\hline Voltage & Tolerance & Current (Max) \\
\hline+5 Vdc & \(\pm 5 \%\) & \(<700 \mathrm{~mA}\) \\
+12 Vdc & \(\pm 5 \%\) & \(<20 \mathrm{~mA}\) \\
-12 Vdc & \(\pm 5 \%\) & \(<80 \mathrm{~mA}\) \\
\hline \multicolumn{2}{|c|}{ Note: All voltages must have ripple \(\leq 0.1\) volts peak-to-peak. } \\
\hline
\end{tabular}

Environmental
\begin{tabular}{|c|l|}
\hline Parameter & \multicolumn{1}{c|}{ Specification } \\
\hline Temperature & \(\begin{array}{l}0^{\circ} \mathrm{C} \text { to }+60^{\circ} \mathrm{C}\left(32 \text { to } 140^{\circ} \mathrm{F}\right) \\
\text { Operating } \\
\text { Storage }\end{array}\) \\
\hline Stored in heat sealed antistatic bag \\
and shipping container
\end{tabular}\(]\)\begin{tabular}{l} 
Relative Humidity: \\
\hline \begin{tabular}{l} 
Up to \(90 \%\) noncondensing, or a wet \\
bulb temperature up to \(35^{\circ} \mathrm{C}\), \\
whichever is less.
\end{tabular} \\
\hline
\end{tabular}

Mechanical
\begin{tabular}{|l|l|}
\hline \multicolumn{1}{|c|}{ Parameter } & \multicolumn{1}{c|}{ Speciflcation } \\
\hline Board Structure & \begin{tabular}{l} 
Single PC board with single right \\
angle header with 64 pins, Burndy \\
(P196B32R00A00Z1) or equivalent \\
mating connector.
\end{tabular} \\
\hline Dimensions & \begin{tabular}{l} 
Width-3.94 in. (100 mm\()\) \\
Length-4.72 in. (120 mm) \\
Height-0.4 in. (10.2 mm\()\)
\end{tabular} \\
\hline Weight & Less than 3.6 oz. (100g) \\
\hline
\end{tabular}

The BER performance test set-up is shown in the following diagram:



R96DP Circuit Board Dimensions

\section*{PRELIMINARY}

\section*{INTRODUCTION}

The Rockwell R96FT is a synchronous serial 9600 bps modem designed for multipoint and networking applications. The R96FT allows full-duplex operation over either four-wire dedicated unconditioned lines or half-duplex operation over the general switched telephone network.

Proprietary fast train configurations provide communication at 9600,7200 and 4800 bps with the ability to train in thirty milliseconds. For applications requiring operation with international standards, fallback configurations compatible with CCITT recommendation V. 29 at 9600,7200 and 4800 bps are available. These configurations require 253 milliseconds to train.

The small size and low power consumption of the R96FT offer the user flexibility in formulating a 9600 bps modem design customized for specific packaging and functional requirements.

\section*{FEATURES}
- User Compatibility:
- Proprietary Fast Train
- CCITT V. 29
- Train on Data
- Full-Duplex (4-Wire)
- Half-Duplex (2-Wire)
- 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
- Local Analog (V. 54 Loop 3)
- Remote Analog (Locally Activated)
— Remote Digital (Locally Activated V. 54 Loop 2)
- Small Size
\(-100 \mathrm{~mm} \times 120 \mathrm{~mm}(4.0 \mathrm{in} . \times 4.8 \mathrm{in}\).)
- Low Power Consumption
- 4 watts, typical
- Programmable Transmit Output Level
- TTL and CMOS Compatible


\section*{TECHNICAL SPECIFICATIONS}

\section*{TRANSMITTER CARRIER FREQUENCY}

The transmitter carrier frequency is \(1700 \mathrm{~Hz} \pm 0.01 \%\) for all configurations.

\section*{TONE GENERATION}

Under control of the host processor, the R96FT 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
Signaling/Data Rates
\begin{tabular}{|l|c|}
\hline Parameter & \begin{tabular}{c} 
Specification \\
\(( \pm \mathbf{0 . 0 1 \% )}\)
\end{tabular} \\
\hline Sıgnalıng Rate & 2400 Baud: \\
Data Rate: & 9600 bps, \\
& 7200 bps, \\
& 4800 bps \\
\hline
\end{tabular}

\section*{DATA ENCODING}

The data stream is encoded per CCITT V.29. At 9600 bps, the data stream is divided in groups of four-bits (quad-bits) 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. Signal structure, scrambler, and encoding are compatible with CCITT V.29.

\section*{EQUALIZERS}

The R96FT provides equilization 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 T equalizer is provided in the receiver circuit.

\section*{TRANSMITTED DATA SPECTRUM}

If the cable equalizer is not enabled, the transmitter spectrum is shaped by a square root of 20 percent raised cosine filter.

The out-of-band transmitter power limitations meet those specified by Part 68 of the FCC's rules.

\section*{SCRAMBLER/DESCRAMBLER}

The R96FT incorporates a self-synchronizing scrambler/ descrambler. This facility is in accordance with V.29.

\section*{RECEIVED SIGNAL FREQUENCY TOLERANCE}

The receiver circuit of the R96FT can adapt to received frequency error of up to \(\pm 10 \mathrm{~Hz}\) with less than 0.2 dB degradation in BER performance.
During fast train polling, frequency offset must be less than \(\pm 2 \mathrm{~Hz}\) for successful training.

\section*{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).

\section*{RECEIVE TIMING}

The R96FT 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.

\section*{TRANSMIT LEVEL}

The transmitter output level is accurate to \(\pm 1.0 \mathrm{~dB}\) and is programmable from \(\mathbf{- 1 . 0} \mathrm{dBm}\) to \(\mathbf{- 1 5 . 0 ~ d B m}\) in 2 dB steps.

\section*{TRANSMIT TIMING}

The R96FT provides a Transmit Data Clock (TDCLK) output with the following characteristics:
1. Frequency. Selected data rate of 9600,7200 , or 4800 Hz ( \(\pm 0.01 \%\) ).
2. Duty Cycle. \(50 \% \pm 1 \%\)

Input data presented on TXD is sampled by the R96FT 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.

\section*{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 (or a submultiple of the data rate) \(\pm 0.01 \%\) with a duty cycle of \(50 \% \pm 20 \%\).

\section*{TRAIN ON DATA}

When train on data is enabled (by setting a bit in the interface memory), the modem monitors the EQM signal. If EQM indicates a loss of equilization (i.e., BER approximately \(10^{-3}\) for 0.5 seconds) the modem attempts to retrain on the data stream. Retrain is accomplished in three to fifteen seconds depending on line conditions.

\section*{TURN-ON SEQUENCE}

Nine selectable turn-on sequences can be generated as follows:
Turn-On Sequences
\begin{tabular}{|c|c|c|l|}
\hline No. & Configuration & CTS Response Time & \multicolumn{1}{|c|}{ Comments } \\
\hline 1 & FT/9600 & 30 & \\
2 & FT/7200 & 30 & Proprietory Fast Train \\
3 & FT/4800 & 30 & \\
\hline 4 & V.29/9600 & 253 & CCITT Recommenda- \\
5 & V.29/7200 & 253 & tion V.29 \\
6 & V.29/4800 & 253 & \\
\hline 7 & V.29/9600 & 458 & V.29 preceded by \\
8 & V \(29 / 7200\) & 458 & echo protector tone \\
9 & V.29/4800 & 458 & for lines using echo \\
& & & suppressors* \\
\hline
\end{tabular}
*For short echo protector tone, subtract 155 msec . from values of CTS response time.

\section*{TURN-OFF SEQUENCE}

The turn-off sequence consists of approximately 5 ms of remaining data and scrambled 1's.

\section*{CLAMPING}

Received Data (RXD) is clamped to a constant mark (one) when the Received Line Signal Detector (RLSD) is off.

\section*{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 if used. These times are given in the Turn-On Sequences table. If training is not enabled, RTS/CTS delay is less than 2 baud times.

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.

\section*{RECEIVED LINE SIGNAL DETECTOR (RLSD)}

For the fast train configurations, RLSD is activated by an increase of approximately 15 dB or greater in line power. The RLSD signal 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 \(32 \pm 5 \mathrm{~ms}\). The RLSD signal is deactivated by a decrease of approximately 15 dB in line power. RLSD on-tooff response time is \(10 \pm 3 \mathrm{~ms}\).

For V. 29 configurations RLSD is activated by line power above a preset threshold. The RLSD signal 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. 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.

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} \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 a modulated carrier signal applied to the receiver's audio input (RXA).

\section*{MODES OF OPERATION}

The R96FT is capable of being operated in either a serial or a parallel mode of operation.

\section*{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.

\section*{PARALLEL MODE}

The R96FT has the capability of transferring channel data 8 bits at a time via the microprocessor bus in 9600 or 4800 bps configurations, 6 bits at a time in 7200 bps configuration.

\section*{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 R96FT is configured by the host processor via the microprocessor bus.


R96FT Functional Interconnect Diagram

\section*{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.

\section*{HARDWARE CIRCUITS}

Signal names and descriptions of the hardware circuits, including the microprocessor interface, are listed in the R96FT Hardware Circuits table. In the table, the column titled 'Type' refers to designations found in the Hardware Circuit Characteristics. 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.

R96FT Hardware Circuits
\begin{tabular}{|c|c|c|c|}
\hline Name & Type & Pin No. & Description \\
\hline \multicolumn{4}{|l|}{A. OVERHEAD:} \\
\hline \begin{tabular}{l}
Ground (A) \\
Ground (D) \\
+5 volts \\
+12 volts \\
\(\frac{-12}{P O R}\) volts \\
\(\overline{\text { POR }}\)
\end{tabular} & AGND DGND PWR PWR PWR I/OA & \begin{tabular}{|c|}
\(31 C, 32 C\) \\
\(3 C, 8 C, 5 A, 10 A\) \\
\(19 C, 23 C, 26 C, 30 C\) \\
\(15 A\) \\
\(12 A\) \\
\(13 C\)
\end{tabular} & Analog Ground Return Digital Ground Return +5 volt supply +12 volt supply -12 volt supply Power-on-reset \\
\hline \multicolumn{4}{|l|}{B. MICROPROCESSOR INTERFACE:} \\
\hline D7
D6
D6
D4
D3
D2
D1
D0 & I/OA
I/OA
I/OA
I/OA
I/OA
I/OA
I/OA
I/OA & \[
\begin{aligned}
& \hline 1 \mathrm{C} \\
& 1 \mathrm{~A} \\
& 2 \mathrm{C} \\
& 2 \mathrm{~A} \\
& 3 \mathrm{~A} \\
& 4 \mathrm{C} \\
& 4 \mathrm{~A} \\
& 5 \mathrm{C}
\end{aligned}
\] & Data Bus (8 Bits) \\
\hline \[
\begin{aligned}
& \text { RS3 } \\
& \text { RS2 } \\
& \text { RS1 } \\
& \text { RS0 }
\end{aligned}
\] & IA
IA
IA
IA & \[
\begin{aligned}
& 6 C \\
& 6 A \\
& 7 C \\
& 7 A
\end{aligned}
\] & Register Select (4 Bits) \\
\hline \(\overline{\text { CSO }}\) & IA & 10 C & Chip Select Transmitter Device \\
\hline \(\overline{\text { CS1 }}\) & IA & 9 C & Chip Select Receiver Sample Rate Device \\
\hline \(\overline{\text { CS2 }}\) & IA & 9 A & Chip Select Receiver Baud Rate Device \\
\hline READ & IA & 12 C & Read Enable \\
\hline \[
\frac{\text { WRITE }}{\text { IRQ }}
\] & \[
\begin{aligned}
& I A \\
& O B
\end{aligned}
\] & \[
\begin{aligned}
& 11 \mathrm{~A} \\
& 11 \mathrm{C}
\end{aligned}
\] & Write Enable Interrupt Request \\
\hline \multicolumn{4}{|l|}{C. V. 24 INTERFACE:} \\
\hline \[
\begin{array}{|l}
\hline \overline{\text { RDCLK }} \\
\text { TDCLK } \\
\text { XTCLK } \\
\hline \text { RTS } \\
\hline \text { CTS } \\
\text { TXD } \\
\text { RXD } \\
\hline \text { RLSD } \\
\hline
\end{array}
\] & OC
OC
IB
IB
OC
IB
OC
OC & 21A
\(23 A\)
\(22 A\)
\(25 A\)
25 C
24 C
22 C
24 A & Receive Data Clock Transmit Data Clock External Transmit Clock Request-to-Send Clear-to-Send Transmitter Data Receiver Data Received Line Signal Detector \\
\hline \multicolumn{4}{|l|}{D. ANCILLARY CIRCUITS:} \\
\hline \[
\overline{\overline{\text { RBCLK }}}
\] & \[
\begin{aligned}
& \mathrm{OC} \\
& \mathrm{OC}
\end{aligned}
\] & \[
\begin{aligned}
& 26 \mathrm{~A} \\
& 27 \mathrm{C} \\
& 29 \mathrm{~A} \\
& 18 \mathrm{C} \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
Receiver Baud Clock Transmitter Baud Clock (Future Use) \\
(Future Use)
\end{tabular} \\
\hline \multicolumn{4}{|l|}{E. ANALOG SIGNALS:} \\
\hline TXA RXA AUXIN & \[
\begin{aligned}
& \mathrm{AA} \\
& \mathrm{AB} \\
& \mathrm{AC}
\end{aligned}
\] & \[
\begin{aligned}
& 31 A \\
& 32 A \\
& 30 A
\end{aligned}
\] & Transmitter Analog Output Receiver Analog Input Auxiliary Analog Input \\
\hline
\end{tabular}

R96FT Hardware Circuits (Continued)
\begin{tabular}{|l|c|c|l|}
\hline \multicolumn{1}{|c|}{ Name } & Type & Pin No. & \multicolumn{1}{|c|}{ Description } \\
\hline F. DIAGNOSTIC: \\
\hline EYEX & OC & 15C & Eye Pattern Data-X Axis \\
EYEY & OC & 14 A & Eye Pattern Data-Y Axis \\
EYECLK & OA & 14 C & Eye Pattern Clock \\
EYESYNC & OA & 13 A & \begin{tabular}{l} 
Eye Pattern Synchronizing \\
Signal
\end{tabular} \\
\hline
\end{tabular}

\section*{EYE PATTERN GENERATION}

The four hardware diagnostic circuits, identified in the preceding table, 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.

\section*{MICROPROCESSOR TIMING}


Microprocessor Interface TIming Dlagram
Critical Timing Requirements
\begin{tabular}{|l|c|c|c|c|}
\hline \multicolumn{1}{|c|}{ Characterlstic } & Symbol & Min & Max & Units \\
\hline\(\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 \\
\hline
\end{tabular}

\section*{HARDWARE CIRCUIT CHARACTERISTICS}

\section*{Digital Interface Characteristics}

Digital Interface Characteristics
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Units} & \multicolumn{8}{|c|}{Input/Output Type} \\
\hline & & & IA & IB & IC & OA & OB & OC & I/O A & I/O B \\
\hline \(\mathrm{V}_{\mathrm{IH}}\) & Input Voltage, High & v & 2.0 Min. & 2.0 Min. & 2.0 Min. & & & & 2.0 Min. & \[
\begin{aligned}
& \text { 5.25 Max. } \\
& \text { 2.0 Min. }
\end{aligned}
\] \\
\hline \(\mathrm{V}_{\mathrm{IL}}\) & Input Voltage, Low & v & 0.8 Max. & 0.8 Max. & 0.8 Max. & & & & 0.8 Max. & 0.8 Max. \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output Voltage, High & V & & & & 2.4 Min. \({ }^{1}\) & & & 2.4 Min. \({ }^{1}\) & 2.4 Min. \({ }^{3}\) \\
\hline \(\mathrm{V}_{\mathrm{OL}}\) & Output Voltage, Low & v & & & & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) \\
\hline IN & Input Current, Leakage & \(\mu \mathrm{A}\) & \(\pm 2.5 \mathrm{Max}\). & & & & & & \(\pm 2.5\) Max. \({ }^{4}\) & \\
\hline \(\mathrm{IOH}^{\text {O }}\) & Output Current, High & mA & & & & -0.1 Max. & & & & \\
\hline 1 OL & Output Current, Low & mA & & & & 1.6 Max. & 1.6 Max. & 1.6 Max. & & \\
\hline IL & Output Current, Leakage & \(\mu \mathrm{A}\) & & & & & \(\pm 10\) Max. & & & \\
\hline \(\mathrm{I}_{\mathrm{PU}}\) & Pull-up Current (Short Circuit) & \({ }_{\mu} \mathrm{A}\) & & \[
\begin{aligned}
& -240 \mathrm{Max} . \\
& -10 \mathrm{Min} .
\end{aligned}
\] & \[
\begin{aligned}
& -240 \mathrm{Max} . \\
& -10 \mathrm{Min} .
\end{aligned}
\] & & & \[
\begin{aligned}
& -240 \mathrm{Max} . \\
& -10 \mathrm{Min} .
\end{aligned}
\] & & \[
\begin{aligned}
& \text { - } 260 \mathrm{Max} . \\
& \text { - } 100 \mathrm{Min} .
\end{aligned}
\] \\
\hline \(\mathrm{C}_{\mathrm{L}}\) & Capacitive Load & pF & 5 & 5 & 20 & & & & 10 & 40 \\
\hline \(C_{0}\) & Capacitive Drive & pF & & & & 100 & 100 & 100 & 100 & 100 \\
\hline & Circuit Type & & TTL & TTL w/Pull-up & TTL w/Pull-up & TTL & Open-Drain & Open-Drain w/Pull-up & \[
\begin{array}{c|}
\text { 3-State } \\
\text { Transceiver }
\end{array}
\] & Open-Drain w/Pull-up \\
\hline \multicolumn{11}{|c|}{\multirow[t]{3}{*}{\(\begin{array}{ll}\text { 1. } 1 \text { Load }=-100 \mu \mathrm{~A} & \text { Notes } \\ \text { 2. } 1 \text { Load }=1.6 \mathrm{~mA} & \text { 3. } 1 \text { Load }=-40 \mu \mathrm{~A} \\ \text { 4. } & \text { 4. } \mathrm{V}_{\text {IN }}=0.4 \text { to } 2.4 \mathrm{Vdc}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{Vdc}\end{array}\)}} \\
\hline & & & & & & & & & & \\
\hline & & & & & & & & & & \\
\hline
\end{tabular}

\section*{Analog Interface Characteristics}

Analog Interface Characteristics
\begin{tabular}{|l|l|l|}
\hline Name & Type & \multicolumn{1}{c|}{ Characteristics } \\
\hline RXA & AA & \begin{tabular}{l} 
The transmitter output is a low impedance \\
operational amplifier output. In order to match to \\
600 ohms, an external series resistor is required.
\end{tabular} \\
AUXIN & AB & \begin{tabular}{l} 
The receiver input impedance is 63.4 K ohms \\
\(\pm 5 \%\). \\
The auxiliary analog input allows access to the \\
transmitter for the purpose of interfacing with \\
user provided equipment. Because this is a \\
sampled data input, any signal above 4800 Hz \\
will cause aliasing errors. The input impedance \\
is 1K ohms, and the gain to transmitter output is \\
\(-1 \mathrm{~dB} \pm 1 \mathrm{~dB}\).
\end{tabular} \\
\hline
\end{tabular}

\section*{SOFTWARE CIRCUITS}

The R96FT comprises three signal processor chips. Each of these chips contains 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. The registers are referred to as interface memory. Registers in chip 1 update at half the modem sample rate ( 4800 bps ). Registers in chip 0 and 2 update at the selected baud rate.

When information in these registers is being discussed, the format \(Y: Z: Q\) is used. The chip is specified by \(Y(0-2)\), the register by \(Z(0-F)\), and the bit by \(Q(0-7,0=L S B)\).

\section*{Status Control Bits}

The operation of the R96FT is affected by a number of software control inputs. These inputs are written into registers within the interface memory via the host microprocessor bus. 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 interface memory via the host microprocessor bus. All status and control bits are defined in the Interface Memory table. Bits designated by an ' R ' are reserved for modem use only and must not be changed by the host.

\section*{RAM Data Access}

The R96FT provides the user with access to much of the data stored in the modem's memories. This data is useful for performing certain diagnostic functions.
Two RAM access registers in chip 1 allow user access to RAM locations via the \(X\) word registers (1:3 and 1:2) and the \(Y\) word registers ( \(1: 1\) and 1:0). Comparable registers in chip 2 provide access to chip 2 RAM locations. The access code stored in RAM ACCESS XS (1:5) selects the source of data for RAM DATA XSM and RAM DATA XSL (1:3 and 1:2). Similarly, the access code stored in RAM ACCESS YS (1:4) selects the source of data for RAM DATA YSM and RAM DATA YSL (1:1 and 1:0). Chip 2 registers are associated in the same way.
Reading of RAM data is performed by storing the necessary access codes in 1:5 and 1:4 (or 2:5 and 2:4), reading 1:0 (or 2:0) to reset the associated data available bit ( \(1: \mathrm{E}: 0\) or \(2: \mathrm{E}: 0\) ), then waiting for the data available bit to return to a one. Data is now valid and may be read from 1:3 through 1:0 (or 2:3 through 2:0). The contents of registers 2:3 and 2:1 are also available serially on outputs EYEX and EYEY, respectively, unless the IFIX bit (1:6:7) is set to a one. When IFIX is a one, EYEX and EYEY remain fixed on the rotated equalizer output.

\section*{RAM Access Codes}

The RAM access codes defined in the following table allow the host processor to read diagnostic information within the modem.

RAM Access Codes
\begin{tabular}{|r|l|c|c|c|r|}
\hline No. & \multicolumn{1}{|c|}{ Function } & Chip & X Access & Y Access & Register \\
\hline 1 & Received Signal Samples & 1 & E1 & Not Used & 2,3 \\
2 & Demodulator Output & 1 & C0 & 40 & \(0,1,2,3\) \\
3 & Low Pass Filter Output & 1 & F2 & 62 & \(0,1,2,3\) \\
4 & Average Energy & 1 & Not Used & 25 & 0,1 \\
5 & AGC Gain Word & 1 & A1 & Not Used & 2,3 \\
\hline 6 & Equalizer Input & 2 & C0 & 40 & \(0,1,2,3\) \\
7 & Equalizer Tap Coefficients & 2 & \(80-9 F\) & \(00-1 F\) & \(0,1,2,3\) \\
8 & Unrotated Equalizer & 2 & E1 & 61 & \(0,1,2,3\) \\
& Output & & & & 0,1 \\
9 & Rotated Equalizer Output & 2 & E2 & 62 & \(0,1,2,3\) \\
10 & (Received Points) & & & & \\
10 & Decision Points & 2 & E8 & 68 & \(0,1,2,3\) \\
11 & (Ideal Data Points) & & & & \\
12 & Rrror & 2 & E4 & 64 & \(0,1,2,3\) \\
13 & Fration Angle & 2 & A7 & Not Used & 2,3 \\
14 & EQM & 2 & A5 Correction & Not Used & 2,3 \\
15 & Dual Point & 2 & BC & Not Used & 2,3 \\
\hline
\end{tabular}

Transmitter Interface Memory Chip 0 ( \(\overline{\mathbf{C S O}}\) )
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline Register & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & R & R & R & R & R & R & R & R \\
\hline E & TIA & R & R & R & TSB & TIE & R & TBA \\
\hline D & R & R & R & R & R & R & R & R \\
\hline C & R & R & R & R & R & R & R & R \\
\hline B & R & R & R & R & R & R & R & R \\
\hline A & R & R & R & R & R & R & R & R \\
\hline 9 & R & R & R & R & R & R & R & R \\
\hline 8 & R & R & R & R & R & R & R & R \\
\hline 7 & RTS & TTDIS & SDIS & MHLD & EPT & TPDM & XCEN & SEPT \\
\hline 6 & \multicolumn{8}{|c|}{TRANSMITTER CONFIGURATION} \\
\hline 5 & X & X & & EQ & LAEN & LDEN & A3L & D3L \\
\hline 4 & LЗACT & L4ACT & L4HG & & TLVL & & L2ACT & LCEN \\
\hline 3 & \multicolumn{8}{|c|}{FREQM} \\
\hline 2 & \multicolumn{8}{|c|}{FREQL} \\
\hline 1 & R & R & R & R & R & R & R & R \\
\hline 0 & \multicolumn{8}{|c|}{TRANSMITTER DATA} \\
\hline \begin{tabular}{l}
Register \\
Bit
\end{tabular} & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{9}{|l|}{\begin{tabular}{l}
(X) indicates user available. \\
\((\mathrm{R})\) indicates reserved for modem use only.
\end{tabular}} \\
\hline
\end{tabular}

Receiver Interface Memory Chip 1 (CS1)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & R & R & R & R & R & R & R & R \\
\hline E & RSIA & R & R & R & RSB & RSIE & R & RSDA \\
\hline D & R & R & R & R & R & R & R & R \\
\hline C & R & R & R & R & R & R & R & R \\
\hline B & R & \(\overline{\text { PNDET }}\) & R & R & R & R & R & \(\overline{\mathrm{CDET}}\) \\
\hline A & R & R & R & R & R & R & R & R \\
\hline 9 & R & R & R & R & R & R & R & R \\
\hline 8 & R & R & R & R & R & R & R & R \\
\hline 7 & \multicolumn{2}{|r|}{RTH} & DDIS & RPDM & R & R & R & R \\
\hline 6 & IFIX & TOD & \multicolumn{6}{|c|}{RECEIVER CONFIGURATION} \\
\hline 5 & \multicolumn{8}{|c|}{RAM ACCESS XS} \\
\hline 4 & \multicolumn{8}{|c|}{RAM ACCESS YS} \\
\hline 3 & \multicolumn{8}{|c|}{RAM DATA XSM} \\
\hline 2 & \multicolumn{8}{|c|}{RAM DATA XSL} \\
\hline 1 & \multicolumn{8}{|c|}{RAM DATA YSM} \\
\hline 0 & \multicolumn{8}{|c|}{RAM DATA YSL; RECEIVER DATA} \\
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{9}{|l|}{\begin{tabular}{l}
\((X)\) indicates user available. \\
\((R)\) indicates reserved for modem use only.
\end{tabular}} \\
\hline
\end{tabular}

Receiver Interface Memory Chip 2 ( \(\overline{\text { CS2 }}\) )
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & R & R & R & R & R & R & R & R \\
\hline E & RBIA & R & R & R & R & RBIE & R & RBDA \\
\hline D & R & R & R & R & R & R & R & R \\
\hline C & R & R & R & R & R & R & R & R \\
\hline B & R & R & R & R & R & R & R & R \\
\hline A & R & R & R & R & R & R & R & R \\
\hline 9 & R & R & R & R & R & R & R & R \\
\hline 8 & R & R & R & R & R & R & R & R \\
\hline 7 & R & R & R & R & R & R & R & R \\
\hline 6 & R & R & R & R & R & R & R & R \\
\hline 5 & \multicolumn{8}{|c|}{RAM ACCESS XB} \\
\hline 4 & \multicolumn{8}{|c|}{RAM ACCESS YB} \\
\hline 3 & \multicolumn{8}{|c|}{RAM DATA XBM} \\
\hline 2 & \multicolumn{8}{|c|}{RAM DATA XBL} \\
\hline 1 & \multicolumn{8}{|c|}{RAM DATA YBM} \\
\hline 0 & \multicolumn{8}{|c|}{RAM DATA YBL} \\
\hline Register Bit & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{9}{|l|}{\begin{tabular}{l}
(X) indicates user available. \\
( R ) indicates reserved for modem use only.
\end{tabular}} \\
\hline
\end{tabular}

\section*{R96FT Interface Memory Definitions}


R96FT Interface Memory Definitions (Continued)
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & \begin{tabular}{l}
Memory \\
Location
\end{tabular} & Description \\
\hline \multirow[t]{4}{*}{LAEN} & Link Amplitude Equalizer Enable & 0:5:3 & The link amplitude equalizer enable and select bits control an amplitude compromise equalizer in the receive path according to the following table: \\
\hline & & & LAEN A3L Curve Matched \\
\hline & & & 0 X No Equalizer \\
\hline & & & \begin{tabular}{l}
10 \\
U.S. Survey Long
\end{tabular} \\
\hline LCEN & Loop Clock Enable & 0:4:0 & When control bit LCEN is a one, the transmitter clock tracks the receiver clock. \\
\hline LDEN & Link Delay Equalizer Enable & 0:5:2 & The link delay equalizer enable and select bits control a delay compromise equalizer in the receive path according to the following table: \\
\hline & & & LDEN D3L Curve Matched \\
\hline & & & \begin{tabular}{lll}
0 & \(X\) & No Equalizer \\
1 & 0 & U.S. Survey Long \\
1 & 1 & Japanese 3-Lınk
\end{tabular} \\
\hline L2ACT & Remote Digital Loopback Activate & 0:4:1 & When control bit L2ACT is a one, the receiver digital output is connected to the transmitter digital input in accordance with CCITT recommendation V. 54 loop 2 \\
\hline L3ACT & Local Analog Loopback Activate & 0.4:7 & When control bit L3ACT is a one, the transmitter analog output is coupled to the receiver analog input through an attenuator in accordance with CCITT recommendation V. 54 loop 3. \\
\hline L4ACT & Remote Analog Loopback Activate & 0:4:6 & When control bit L4ACT is a one, the receiver analog input is connected to the transmitter analog output through a variable gain amplifier in a manner sımilar to recommendation V. 54 loop 4. \\
\hline L4HG & Loop 4 High Gain & 0:4:5 & When control bit L4HG is a one, the loop 4 variable gain amplifier is set for +16 dB , and when at zero the gain is zero dB . \\
\hline MHLD & Mark Hold & 0:7:4 & When control bit MHLD is a one, the transmitter input data stream is forced to all marks (ones). \\
\hline \(\overline{\text { PNDET }}\) & Period N Detector & 1:B:6 & When status bit \(\overline{\text { PNDET }}\) is a zero, it indicates a PN sequence has been detected. This bit sets to a one at the end of the PN sequence \\
\hline (None) & RAM Access XB & 2:5:0-7 & Contains the RAM access code used in readıng chip 2 RAM locatıons via word X (2:3 and 2:2) \\
\hline (None) & RAM Access XS & 1:5:0-7 & Contans the RAM access code used in reading chip 1 RAM locatıons via word X (1:3 and 1:2). \\
\hline (None) & RAM Access YB & 2:4:0-7 & Contains the RAM access code used in reading chip 2 RAM locations via word Y (2:1 and \(2 \cdot 0\) ). \\
\hline (None) & RAM Access YS & 1:4:0-7 & Contains the RAM access code used in reading chip 1 RAM locations via word Y (1:1 and \(1: 0\) ). \\
\hline (None) & RAM Data XBL & 2:2:0-7 & Least signticant byte of 16-bit word X used in reading RAM locations in chip 2. \\
\hline (None) & RAM Data XBM & 2:3:0-7 & Most significant byte of 16-bit word X used in readıng RAM locatıons in chip 2. \\
\hline (None) & RAM Data XSL & 1:2:0-7 & Least significant byte of 16 -bit word X used in reading RAM locations in chip 1 \\
\hline (None) & RAM Data XSM & 1:3:0-7 & Most significant byte of 16 -bit word X used in reading RAM locations in chip 1. \\
\hline
\end{tabular}

R96FT Interface Memory Definitions (Continued)
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & \begin{tabular}{l}
Memory \\
Location
\end{tabular} & Description \\
\hline (None) & RAM Data YBL & 2:0:0-7 & Least significant byte of 16-bit word Y used in reading RAM locations in chip 2. \\
\hline (None) & RAM Data YBM & 2:1:0-7 & Most significant byte of 16-bit word Y used in reading RAM locations in chip 2. \\
\hline (None) & RAM Data YSL & 1:0:0-7 & Least significant byte of 16 -bit word \(Y\) used in reading RAM locations in chip 1. Shared by parallel data mode for presenting channel data to the host microprocessor bus. See 'Receiver Data.' \\
\hline (None) & RAM Data YSM & 1:1:0-7 & Most significant byte of 16-bit word Y used in reading RAM locations in chip 1. \\
\hline RBDA & Receiver Baud Data Available & 2:E:0 & Status bit RBDA goes to a one when the receiver writes data into register 2:0. The bit goes to a zero when the host processor reads data from register 2:0. \\
\hline RBIA & Receiver Baud Interrupt Active & 2:E:7 & This status bit is a one whenever the receiver baud rate device is driving \(\overline{\mathrm{RQ}}\) low. \\
\hline Rbie & Receiver Baud Interrupt Enable & 2:E:2 & When the host processor writes a one in the RBIE control bit, the \(\overline{\mathrm{RQ} Q}\) line of the hardware interface is driven to zero when status bit RBDA is a one. \\
\hline \multirow[t]{9}{*}{(None)} & \multirow[t]{9}{*}{Receiver Configuration} & \multirow[t]{9}{*}{1:6:0-5} & The host processor configures the receiver by writing a control code into the receiver configuration field in the interface memory space (see RSB). \\
\hline & & & Receiver Configuration Control Codes \\
\hline & & & Control codes for the modem receiver configuration are: \\
\hline & & & Configuration Configuration Code (Hex) \\
\hline & & & \begin{tabular}{ll} 
FT/9600 & 1 C \\
FT/7200 & 1 A
\end{tabular} \\
\hline & & & FT/4800 19 \\
\hline & & & V.29/9600 14 \\
\hline & & & V.29/7200 12 \\
\hline & & & V.29/4800 11 \\
\hline (None) & Receiver Data & 1:0:0-7 & The host processor obtains input data from the receiver in the parallel data mode by reading a data byte from the receiver data register. The data is divided on baud boundaries as is the transmitter data. When using receiver parallel data mode, the registers 1:3 through 1:0 can not be used for reading the chip 1 RAM. \\
\hline RPDM & Receiver Parallel Data Mode & 1:7:4 & When control bit RPDM is a one, the receiver supplies data to the receiver data register (1:0) as well as to the hardware serial data output. \\
\hline RSB & Receiver Setup Bit & 1:E:3 & When the host processor changes the receiver configuration (or the RTH field), the host processor must write a one in the RSB control bit. RSB goes to zero when the changes become effective. \\
\hline RSDA & Receiver Sample Data Available & 1:E:0 & Status bit RSDA goes to a one when the receiver writes data to register 1:0. RSDA goes to a zero when the host processor reads data from register 1:0. \\
\hline RSIA & Receiver Sample Interrupt Active & 1:E:7 & This status bit is a one whenever the receiver sample rate device is driving \(\overline{\operatorname{RQ}}\) to zero. \\
\hline RSIE & Receiver Sample Interrupt Enable & 1:E:2 & When the host processor writes a one in the RSIE control bit, the \(\overline{\mathrm{RQQ}}\) line of the hardware interface is driven to zero when status bit RSDA is at a one. \\
\hline \multirow[t]{5}{*}{RTH} & \multirow[t]{5}{*}{Receiver Threshold Field} & \multirow[t]{5}{*}{1:7:6,7} & The receiver energy detector threshold is set by the RTH field according to the following codes (see RSB): \\
\hline & & & RTH RLSD On RLSD Off \\
\hline & & & \(0 \quad>-43 \mathrm{dBm}\) \\
\hline & & &  \\
\hline & & & 3 l \\
\hline
\end{tabular}

R96FT Interface Memory Definitions (Continued)


R96FT Interface Memory Definitions (Continued)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & \multicolumn{9}{|c|}{Description} \\
\hline \multirow[t]{7}{*}{(None)} & \multirow[t]{7}{*}{Transmitter Data} & \multirow[t]{7}{*}{0:0:0-7} & \multicolumn{9}{|l|}{\multirow[t]{2}{*}{\begin{tabular}{l}
The host processor conveys output data to the transmitter in the parallel mode by writing a data byte to the transmitter data register. The data is divided on baud boundaries, as follows: \\
NOTE
\end{tabular}}} \\
\hline & & & & & & & & & & & \\
\hline & & & & & & & & & & & \\
\hline & & & Configuration & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline & & & 9600 bps & & & & & & & & \\
\hline & & & 7200 bps & & & & aud & & & ud & \\
\hline & & & 4800 bps & & & & & & & & \\
\hline TSB & Transmitter Setup Bit & 0:E:3 & \multicolumn{9}{|l|}{When the host processor changes the transmitter configuration, the host must write a one in this control bit. TSB goes to a zero when the change becomes effective.} \\
\hline TTDIS & Transmitter Train Disable & 0:7:6 & \multicolumn{9}{|l|}{When control bit TTDIS is a one, the transmitter does not generate a training sequence at the start of transmission. With training disabled, RTS and CTS delay is less than two baud times.} \\
\hline XCEN & External Clock Enable & 0:7:1 & \multicolumn{9}{|l|}{When control bit XCEN is a zero, the transmitter timing is established by the external clock supplied at the hardware input XTCLK, pin 22A.} \\
\hline
\end{tabular}

\section*{POWER-ON INITIALIZATION}

When power is applied to the R96FT, a period of 50 to 350 ms is required for power supply settling. The power-on-reset signal (POR) remains low during this period. Approximately 10 ms after the low to high transition of POR, the modem is ready to be configured, and RTS may be activated. If the 5 Vdc power supply drops below 3.5 Vdc for more than 30 msec , the POR cycle is generated.

At POR time the modem defaults to the following configuration: fast train, 9600 bps , no echo protect tone, serial data mode, internal clock, cable equalizers disabled, link amplitude equalizer disabled, link delay equalizer disabled, transmitter output level set to \(-1 \mathrm{dBm} \pm 1 \mathrm{~dB}\), interrupts disabled, receiver threshold set to -26 dBm , eye pattern selectable, and train-on-data disabled.

POR can be connected to a user supplied power-on-reset signal in a wire-or configuration. A low active pulse of \(3 \mu \mathrm{sec}\) or more applied to the POR pin causes the modem to reset. The modem is ready to be configured 10 msec after POR is removed.

\section*{PERFORMANCE}

Whether functioning in V. 29 or the proprietary fast train configurations, the R96FT provides the user with unexcelled high performance.

\section*{POLLING SUCCESS}

In fast train configuration the modem achieves a 98\% success rate over unconditioned 3002 lines for a signal-to-noise ratio of 26 dB.

\section*{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.

\section*{PHASE JITTER}

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 \(20^{\circ}\) peak-to-peak phase jitter at 30 Hz .

An example of the BER performance capabilities is given in the following diagram:


Worst Case BER Performance (Back-to-Back)


BER Performance Test Set-up

\begin{tabular}{|r|r|}
\hline Inches & MM \\
\hline .119 & 3 \\
156 & 4 \\
483 & 12 \\
3.275 & 83 \\
3.700 & 94 \\
3.937 & 100 \\
4100 & 104 \\
4.725 & 120 \\
\hline
\end{tabular}

R96FT Circuit Board Dimensions

\section*{V96P/1 \\ HIGH SPEED 9600 BPS MODEM}

\section*{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.

\section*{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 \(\mathbf{- 4 5 d B m}\) dynamic AGC
- LSI signal processing
- High reliability
- Low power consumption:
-Typically 3.5 watts
- Automatic training sequence for receiver


\section*{FUNCTIONAL SPECIFICATIONS}


\section*{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}
\]

\section*{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.

\section*{Data Signalling and Modulation Rate}

At 2400 baud:

Signalling 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}
\]

At 1600 baud:
Signalling Rate-

\section*{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.

\section*{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 16point, 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.

\section*{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.

\section*{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 establish 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

\section*{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 dBm : D109 ON
\[
\text { Less than }-48 \mathrm{dBm}: \quad \text { D109 OFF }
\]
2) Greater than -26 dBm : D109 ON

Less than - 31 dBm : 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.
\begin{tabular}{cll} 
dB Level & \multicolumn{1}{c}{ THRESH1 } & \multicolumn{1}{c}{ 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
\end{tabular}

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

\section*{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
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline No. & Configuration & Transmitter ITC (1P-5P) (Octal Code) & \[
\begin{gathered}
\text { Recelver } \\
\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) \\
\hline 1. & 2400 Baud DIAL & 02 & 00 & 0,1,2 & & 320 & 1706 2/3 \\
\hline 2. & 2400 Baud DIAL - T/2 & 02 & 01 & 0,1,2 & 9600 & 320 & 1706 2/3 \\
\hline 3. & 2400 Baud P-P & 00 & 00 & 0,1,2 & 7200 & 280 & 1706 2/3 \\
\hline 4. & 2400 Baud P-P - T/2 & 00 & 01 & 0,1,2 & 4800 & 280 & 1706 2/3 \\
\hline 5. & 2400 Baud V29 & 01 & 02 & 0,1,2 & & 233 & 1700 \\
\hline 6. & 2400 Baud V29 - T/2 & 01 & 03 & 0,1,2 & & 233 & 1700 \\
\hline 7. & 1600 Baud DIAL, CCITT DIAL & 22 & 22 & 1,3 & 4800 & 181 & NOTE \\
\hline 8. & 1600 Baud DIAL - T/2 & 22 & 36 & 1,3 & 4800 & 181 & NOTE \\
\hline 9. & 1600 Baud DIAL Slow & 36 & 22 & 1,3 & 4800 & 221 & NOTE \\
\hline 10. & 1600 Baud P-P & 20 & 20 & 1,3 & 4800 & 141 & NOTE \\
\hline 11. & 1600 Baud P-P - T/2 & 20 & 32 & 1,3 & 4800 & 141 & NOTE \\
\hline 12. & 1600 Baud Echo & 34 & 34 & 1,3 & 4800 & 480 & NOTE \\
\hline 13. & 1600 Baud Manual CCITT & 32 & 30 & 3 & 4800 & 20 (V. 27 Sync Sequence) & 1800 \\
\hline 14. & 1600 Baud Manual CCITT & 30 & 30 & 3 & 4800 & 50 (V. 27 Sync Sequence) & 1800 \\
\hline 15. & 1600 Baud V27 DIAL/P-P & 23 & 23 & 3 & 4800 & 708 & 1800 \\
\hline 16. & 1600 Baud V27 DIALP-P EP & 27 & 23 & 3 & 4800 & 923 & 1800 \\
\hline 17. & 1600 Baud V27 DIAL/P-P - T/2 & 23 & 33 & 3 & 4800 & 708 & 1800 \\
\hline 18. & 1600 Baud V27 DIALP-P - T/2 EP & 27 & 33 & 3 & 4800 & 923 & 1800 \\
\hline 19. & 1600 Baud V27 Multipoint - T/2 & 21 & 27 & 3 & 4800 & 50 & 1800 \\
\hline 20. & 1600 Baud V27 Resync (use with configuration 15) & 21 & 25 & 3 & 4800 & 50 & 1800 \\
\hline 21. & 1600 Baud V27 Resync EP (use with configuration 16) & 25 & 25 & 3 & 4800 & 265 & 1800 \\
\hline 22. & 1600 Baud V27 Resync - T/2 (use with configuration 17) & 21 & 35 & 3 & 4800 & 50 & 1800 \\
\hline 23. & 1600 Baud V27 Resync - T/2 EP (use with configuration 18) & 25 & 35 & 3 & 4800 & 265 & 1800 \\
\hline 24. & 1600 Baud V27 Echo & 23 & 37 & 3 & 4800 & 708 & 1800 \\
\hline 25. & 1600 Baud V27 Echo EP & 27 & 37 & 3 & 4800 & 923 & 1800 \\
\hline 26. & 1200 Baud DIAL & 14 & 10 & 3 & 2400 & 170 & 1800 \\
\hline 27. & 1200 Baud P-P & 10 & 10 & 3 & 2400 & 117 & 1800 \\
\hline 28. & 1200 Baud V27 DIALP-P & 13 & 11 & 3 & 2400 & 943 & 1800 \\
\hline 29. & 1200 Baud V27 DIAL/P-P EP & 17 & 11 & 3 & 2400 & 1158 & 1800 \\
\hline 30. & 1200 Baud V27 Multipoint & 11 & 15 & 3 & 2400 & 66 & 1800 \\
\hline 31. & 1200 Baud V27 Resync (use with configuration 28) & 11 & 13 & 3 & 2400 & 66 & 1800 \\
\hline 32. & 1200 Baud V27 Resync EP (use with configuration 29) & 15 & 13 & 3 & 2400 & 281 & 1800 \\
\hline
\end{tabular}

\section*{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:

\section*{- 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.

\section*{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


BER Performance Test Set-up
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.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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, 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 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.

\section*{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.

\section*{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.

\section*{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

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{SPECIFICATIONS}

\section*{V96P/1 Specifications}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{DC Voltages} \\
\hline Voltage & Tolerance & Current (Typical) & Current (Max) \\
\hline \begin{tabular}{l}
+5 volt \\
+12 volt \\
-12 volt
\end{tabular} & \[
\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}
\] \\
\hline \multicolumn{4}{|l|}{NOTE: All voltages must have ripple \(\leqslant 0.1\) volts peak-to-peak.} \\
\hline \multicolumn{4}{|c|}{Environment} \\
\hline \begin{tabular}{l}
Temperature: \\
Relative Humidity:
\end{tabular} & \multicolumn{3}{|r|}{\begin{tabular}{l}
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 \(+80^{\circ} \mathrm{C}\left(-40\right.\) to \(\left.176^{\circ} \mathrm{F}\right)\) \\
(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.
\end{tabular}} \\
\hline \multicolumn{4}{|c|}{Mechanical} \\
\hline \begin{tabular}{l}
Board Structure: \\
Mating Connector: \\
Dimensions: \\
Weight:
\end{tabular} & \multicolumn{3}{|r|}{\begin{tabular}{l}
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. \\
Width-9.188 in ( 23.338 cm ) Depth-6.288 in (15.972 cm) \\
Less than \(0.45 \mathrm{lbs}(0.20 \mathrm{~kg})\)
\end{tabular}} \\
\hline
\end{tabular}

\section*{0 Rockwell}

\section*{R48DP 4800 BPS DATA PUMP MODEM}

\section*{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.

\section*{FEATURES}
- User Compatibility: - CCITT V. 27 bis/ter
- Full-Duplex (4-Wire)
- Half-Duplex
- Programmable Tone Generation
- Dynamic Range \(\mathbf{- 4 3} \mathrm{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
- Local Analog (V. 54 Loop 3)
- Remote Analog (Locally Activated)
- Remote Digital (Locally Activated V. 54 Loop 2)
- 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


\section*{TECHNICAL SPECIFICATIONS}

\section*{TRANSMITTER CARRIER FREQUENCIES}

Transmitter Carrier Frequencies
\begin{tabular}{|c|c|}
\hline Function & \begin{tabular}{c} 
Frequency \\
(Hz \(\pm \mathbf{0 . 0 1 \% )}\)
\end{tabular} \\
\hline V.27 bis/ter Carrier & 1800 \\
\hline
\end{tabular}

\section*{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.

\section*{SIGNALING AND DATA RATES}
\begin{tabular}{|l|c|}
\multicolumn{2}{|c|}{ Signaling/Data Rates } \\
\hline Parameter & \begin{tabular}{c} 
Specification \\
\(( \pm \mathbf{0 . 0 1 \% )}\)
\end{tabular} \\
\hline Signaling Rate: & 1600 Baud \\
Data Rate: & 4800 bps \\
\hline Signaling Rate: & 1200 Baud \\
Data Rate: & 2400 bps \\
\hline
\end{tabular}

\section*{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.

\section*{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.

\section*{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.

\section*{SCRAMBLER/DESCRAMBLER}

The R48DP incorporates a self-synchronizıng scrambler/ descrambler. This facility is in accordance with V. 27 bis/ter.

\section*{RECEIVED SIGNAL \\ FREQUENCY TOLERANCE}

The receiver curcuit 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.

\section*{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).

\section*{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.

\section*{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.

\section*{TRANSMIT TIMING}

The R48DP provides a Transmit Data Clock (TDCLK) output with the following characteristics:
1. Frequency. Selected data rate of 4800 or 2400 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.

\section*{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 \(\pm 0.01 \%\) with a duty cycle of \(50 \% \pm 20 \%\).

\section*{TRAIN ON DATA}

When train on data is enabled, the receiver trains on data in less than 3.5 seconds.

\section*{TURN-ON SEQUENCE}

A total of 8 selectable turn-on sequences can be generated as defined in the following table:

Turn-On Sequences
\begin{tabular}{|c|c|c|l|}
\hline No. & V.27 bis/ter & \begin{tabular}{c} 
CTS \\
Response Time \\
(milliseconds)
\end{tabular} & \multicolumn{1}{|c|}{ Comments } \\
\hline 1 & 4800 bps long & 708 & \\
2 & 2400 bps long & 943 & \\
3 & 4800 bps short & 50 & \\
4 & 2400 bps short & 67 & \\
\hline 5 & 4800 bps long & 913 & Preceded by \\
6 & 2400 bps long & 1148 & Echo Protector \\
7 & 4800 bps short & 255 & Tone for lines \\
8 & 2400 bps short & 272 & using echo \\
& & & supressors \({ }^{\star}\) \\
\hline
\end{tabular}
*For short echo protector tone, subtract 155 ms from values of CTS response time.

\section*{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.

\section*{CLAMPING}

Received Data (RXD) is clamped to a constant mark (one) whenever the Received Line Signal Detector (RLSD) is off.

\section*{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 2 baud times.

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.

\section*{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 -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).

\section*{MODES OF OPERATION}

The R48DP is capable of being operated in either a serial or a parallel mode of operation.

\section*{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.

\section*{PARALLEL MODE}

The R48DP has the capability of transferring channel data up to eight bits at a time via the microprocessor bus.

\section*{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

\section*{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.

\section*{HARDWARE CIRCUITS}

Signal names and descriptions of the hardware circuits, including the microprocessor interface, are listed in the R48DP Hardware Circuits table. In the table, the column titled 'Type' refers to designations found in the Hardware Circuit Characteristics. 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 Circuits
\begin{tabular}{|c|c|c|c|}
\hline Name & Type & Pin No. & Description \\
\hline \multicolumn{4}{|l|}{A. OVERHEAD:} \\
\hline Ground (A) & AGND & 31C,32C & Analog Ground Return \\
\hline Ground (D) & DGND & 3C,8C,5A,10A & Digital Ground Return \\
\hline + 5 volts & PWR & 19C,23C,26C,30C & + 5 volt supply \\
\hline + 12 volts & PWR & 15A & + 12 volt supply \\
\hline -12 volts & PWR & 12A & -12 volt supply \\
\hline POR & I/OA & 13C & Power-on-reset \\
\hline \multicolumn{4}{|l|}{B. MICROPROCESSOR INTERFACE:} \\
\hline D7 & I/OA & 1C & \\
\hline D6 & I/OA & 1 A & \\
\hline D5 & I/OA & 2 C & \\
\hline D4 & I/OA & 2A & Data Bus (8 Bits) \\
\hline D3 & I/OA & 3A & \\
\hline D2 & I/OA & 4C & \\
\hline D1 & I/OA & 4A & \\
\hline D0 & I/OA & 5 C & \\
\hline RS3 & IA & 6C & \\
\hline RS2 & IA & 6A & Register Select \\
\hline RS1 & IA & 7 C & (4 Bits) \\
\hline RS0 & IA & 7A & \\
\hline \(\overline{\text { CSO }}\) & IA & 10C & Chip Select Transmitter Device \\
\hline \(\overline{\text { CS1 }}\) & IA & 9C & Chip Select Receiver Sample Rate Device \\
\hline \(\overline{\mathrm{CS} 2}\) & IA & 9A & Chip Select Receiver Baud Rate Device \\
\hline READ & IA & 12C & Read Enable \\
\hline WRITE & IA & 11A & Write Enable \\
\hline \(\overline{\mathrm{IRQ}}\) & OB & 11C & Interrupt Request \\
\hline
\end{tabular}

R48DP Hardware Circuits (Cont.)
\begin{tabular}{|c|c|c|c|}
\hline Name & Type & Pin No. & Description \\
\hline \multicolumn{4}{|l|}{C. V. 24 INTERFACE:} \\
\hline RDCLK & OC & 21A & Receive Data Clock \\
\hline TDCLK & OC & 23A & Transmit Data Clock \\
\hline XTCLK & IB & 22A & External Transmit Clock \\
\hline RTS & IB & 25A & Request-to-Send \\
\hline CTS & OC & 25C & Clear-to-Send \\
\hline TXD & IB & 24C & Transmitter Data \\
\hline RXD & OC & 22 C & Receiver Data \\
\hline \(\overline{\text { RLSD }}\) & OC & 24A & Received Line Signal Detector \\
\hline \multicolumn{4}{|l|}{D. ANCILLARY CIRCUITS:} \\
\hline \(\overline{\text { RBCLK }}\) & OC & 26A & Receiver Baud Clock \\
\hline TBCLK & OC & 27C & Transmitter Baud Clock \\
\hline \multicolumn{4}{|l|}{E. ANALOG SIGNALS:} \\
\hline TXA & AA & 31A & Transmitter Analog Output \\
\hline RXA & AB & 32A & Receiver Analog Input \\
\hline AUXIN & AC & 30A & Auxiliary Analog Input \\
\hline \multicolumn{4}{|l|}{F. DIAGNOSTIC:} \\
\hline EYEX & OC & 15C & Eye Pattern Data-X Axis \\
\hline EYEY & OC & 14A & Eye Pattern Data-Y Axis \\
\hline EYECLK & OA & 14C & Eye Pattern Clock \\
\hline EYESYNC & OA & 13A & Eye Pattern Synchronizing Signal \\
\hline
\end{tabular}

\section*{EYE PATTERN GENERATION}

The four hardware diagnostic circuits, identified in the preceding table, 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.

\section*{MICROPROCESSOR TIMING}


Microprocessor Interface Timing Diagram

Critical Timing Requirements
\begin{tabular}{|l|c|c|c|c|}
\hline \multicolumn{1}{|c|}{ Characteristic } & Symbol & Min & Max & Units \\
\hline\(\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 \\
\hline
\end{tabular}

\section*{HARDWARE CIRCUIT CHARACTERISTICS}

\section*{Digital Interface Characteristics}

Digital Interface Characteristics
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Units} & \multicolumn{8}{|c|}{Input/Output Type} \\
\hline & & & IA & IB & IC & OA & OB & OC & I/O A & I/O B \\
\hline \(\mathrm{V}_{\mathrm{IH}}\) & Input Voltage, High & V & 2.0 Min. & 2.0 Min. & 2.0 Min. & & & & 2.0 Min. & 5.25 Max. 2.0 Min. \\
\hline \(\mathrm{V}_{\text {IL }}\) & Input Voltage, Low & V & 0.8 Max. & 0.8 Max. & 0.8 Max. & & & & 0.8 Max. & 0.8 Max. \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output Voltage, High & V & & & & 2.4 Min. \({ }^{1}\) & & & 2.4 Min. \({ }^{1}\) & 2.4 Min. \({ }^{3}\) \\
\hline \(\mathrm{V}_{\mathrm{OL}}\) & Output Voltage, Low & V & & & & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) \\
\hline \(\mathrm{I}_{\mathrm{N}}\) & Input Current, Leakage & \(\mu \mathrm{A}\) & \(\pm 2.5\) Max. & & & & & & \(\pm 2.5\) Max. \({ }^{4}\) & \\
\hline \(\mathrm{I}_{\mathrm{OH}}\) & Output Current, High & mA & & & & -0.1 Max. & & & & \\
\hline \(\mathrm{IOL}^{\text {L }}\) & Output Current, Low & mA & & & & 1.6 Max. & 1.6 Max. & 1.6 Max. & & \\
\hline \(I_{L}\) & Output Current, Leakage & \(\mu \mathrm{A}\) & & & & & \[
\pm 10 \text { Max. }
\] & & & \\
\hline \(I_{P U}\) & Pull-up Current (Short Circuit) & \(\mu \mathrm{A}\) & & \[
\begin{aligned}
& \text { - } 240 \text { Max. } \\
& \text { - } 10 \text { Min. }
\end{aligned}
\] & \[
\begin{aligned}
& \text { - } 240 \text { Max. } \\
& \text { - } 10 \text { Min. }
\end{aligned}
\] & & & \[
\begin{aligned}
& \text { - } 240 \text { Max. } \\
& -10 \mathrm{Min} .
\end{aligned}
\] & & \[
\begin{aligned}
& \text { - } 260 \text { Max. } \\
& \text { - } 100 \text { Min. }
\end{aligned}
\] \\
\hline \(\mathrm{C}_{\mathrm{L}}\) & Capacitive Load & pF & 5 & 5 & 20 & & & & 10 & 40 \\
\hline \(\mathrm{C}_{\mathrm{D}}\) & Capacitive Drive & pF & & & & 100 & 100 & 100 & 100 & 100 \\
\hline & Circuit Type & & TTL & TTL w/Pull-up & TTL w/Pull-up & TTL & Open-Drain & Open-Drain w/Pull-up & 3-State Transceiver & Open-Drain w/Pull-up \\
\hline & & & & & Notes & & & & & \\
\hline & & I Load & \(=-100 \mu \mathrm{~A}\) & & 3. 1 Load = & \(-40 \mu \mathrm{~A}\) & & & & \\
\hline & & I Load & \(=1.6 \mathrm{~mA}\) & & 4. \(\mathrm{V}_{\mathrm{IN}}=0.4\) & to 2.4 Vdc & , \(\mathrm{V}_{\mathrm{CC}}=5.25\) & Vdc & & \\
\hline
\end{tabular}

\section*{Analog Interface Characteristics}

Analog Interface Characteristics
\begin{tabular}{|l|l|l|}
\hline Name & Type & \multicolumn{1}{c|}{ Characteristics } \\
\hline TXA & AA & \begin{tabular}{l} 
The transmitter output is a low impedance \\
operational amplifier output. In order to match to \\
600 ohms, an external series resistor is required. \\
The receiver input impedance is 63.4 K ohms \\
\(\pm 5 \%\).
\end{tabular} \\
AUXIN & AC & \begin{tabular}{l} 
The auxiliary analog input allows access to the \\
transmitter for the purpose of interfacing with \\
user provided equipment. Because this is a \\
sampled data input, any signal above 4800 Hz \\
will cause aliasing errors. The input impedance \\
is 1 K ohms, and the gain to transmitter output is \\
\(-1 \mathrm{~dB} \pm 1 \mathrm{~dB}\).
\end{tabular} \\
\hline
\end{tabular}

\section*{SOFTWARE CIRCUITS}

The R48DP comprises three signal processor chips. Each of these chips contains 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. The registers are referred to as interface memory. Registers in chip 1 update at half the modem sample rate ( 4800 bps ). Registers in chip 0 and 2 update at the selected baud rate.

When information in these registers is being discussed, the format \(Y: Z: Q\) is used. The chip is specified by \(Y(0-2)\), the register by \(Z(0-F)\), and the bit by \(Q(0-7,0=L S B)\).

\section*{Status Control Bits}

The operation of the R48DP is affected by a number of software control inputs. These inputs are written into registers within the interface memory via the host microprocessor bus. 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 interface memory via the host microprocessor bus. All status and control bits are defined in the Interface Memory table. Bits designated by an 'R' are reserved for modem use only and must not be changed by the host.

\section*{RAM Data Access}

The R48DP provides the user with access to much of the data stored in the modem's memories. This data is useful for performing certain diagnostic functions.
Two RAM access registers in chip 1 allow user access to RAM locations via the \(X\) word registers (1:3 and 1:2) and the Y word registers (1:1 and 1:0). Comparable registers in chip 2 provide access to chip 2 RAM locations. The access code stored in RAM ACCESS XS (1:5) selects the source of data for RAM DATA XSM and RAM DATA XSL (1:3 and 1:2). Similarly, the access code stored in RAM ACCESS YS (1:4) selects the source of data for RAM DATA YSM and RAM DATA YSL (1:1 and 1:0). Chip 2 registers are associated in the same way.
Reading of RAM data is performed by storing the necessary access codes in 1:5 and 1:4 (or 2:5 and 2:4), reading 1:0 (or 2:0) to reset the associated data available bit ( \(1: \mathrm{E}: 0\) or 2:E:0), then waiting for the data available bit to return to a one. Data is now valid and may be read from 1:3 through 1:0 (or 2:3 through 2:0). The contents of registers 2:3 and 2:1 are also available serially on outputs EYEX and EYEY, respectively, unless the IFIX bit ( \(1: 6: 7\) ) is set to a one. When IFIX is a one, EYEX and EYEY remain fixed on the rotated equalizer output.

\section*{RAM Access Codes}

The RAM access codes defined in the following table allow the host processor to read diagnostic information within the modem.

RAM Access Codes
\begin{tabular}{|r|l|c|c|c|r|}
\hline No. & \multicolumn{1}{|c|}{ Function } & Chip & X Access & Y Access & Register \\
\hline 1 & Received Signal Samples & 1 & C0 & Not Used & 2,3 \\
2 & Demodulator Output & 1 & C2 & 42 & \(0,1,2,3\) \\
3 & Low Pass Filter Output & 1 & D4 & 54 & \(0,1,2,3\) \\
4 & Average Energy & 1 & Not Used & 04 & 0,1 \\
5 & AGC Gain Word & 1 & 81 & Not Used & 2,3 \\
\hline 6 & Equalizer Input & 2 & C0 & 40 & \(0,1,2,3\) \\
7 & Equalizer Tap Coefficients & 2 & \(81-\) AO & \(01-20\) & \(0,1,2,3\) \\
8 & Unrotated Equalizer & & & & \\
& Output & 2 & E1 & 61 & \(0,1,2,3\) \\
9 & Rotated Equalizer Output & 2 & A2 & 22 & \(0,1,2,3\) \\
& (Received Points) & & & & \\
10 & Decision Points & 2 & E2 & 62 & \(0,1,2,3\) \\
& (Ideal Data Points) & & & & \\
11 & Error & 2 & E3 & 63 & \(0,1,2,3\) \\
12 & Rotatıon Angle & 2 & Not Used & 00 & 0,1 \\
13 & Frequency Correction & 2 & AA & Not Used & 2,3 \\
14 & EQM & 2 & A7 & Not Used & 2,3 \\
15 & Dual Point & 2 & AE & \(2 E\) & \(0,1,2,3\) \\
\hline
\end{tabular}

\section*{NOTE}

In the interface memory tables that follow, those columns marked by an ' \(X\) ' indicate a user available bit position that is not currently used by the R48DP. However, those columns marked by an ' \(R\) ' indicate reserved and are for modem use only.

Transmitter Interface Memory Chip 0 (CSO)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline Bit
Register & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & R & R & R & R & R & R & R & R \\
\hline E & TIA & R & R & R & TSB & TIE & R & TBA \\
\hline D & R & R & R & R & R & R & R & R \\
\hline C & R & R & R & R & R & R & R & R \\
\hline B & R & R & R & R & R & R & R & R \\
\hline A & R & R & R & R & R & R & R & R \\
\hline 9 & R & R & R & R & R & R & R & R \\
\hline 8 & R & R & R & R & R & R & R & R \\
\hline 7 & RTS & TTDIS & SDIS & MHLD & EPT & TPDM & XCEN & SEPT \\
\hline 6 & \multicolumn{8}{|c|}{TRANSMITTER CONFIGURATION} \\
\hline 5 & X & X & & Q & LAEN & LDEN & A3L & D3L \\
\hline 4 & LЗACT & L4ACT & L4HG & & TLVL & & L2ACT & LCEN \\
\hline 3 & \multicolumn{8}{|c|}{FREQM} \\
\hline 2 & \multicolumn{8}{|c|}{FREQL} \\
\hline 1 & R & R & R & R & R & R & R & R \\
\hline 0 & \multicolumn{8}{|c|}{TRANSMITTER DATA} \\
\hline \begin{tabular}{l}
Register \\
Bit
\end{tabular} & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline
\end{tabular}

Receiver Interface Memory Chip 1 (CS1)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \[
\begin{array}{r}
\text { Bit } \\
\text { Register }
\end{array}
\] & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & R & R & R & R & R & R & R & R \\
\hline E & RSIA & R & R & R & RSB & RSIE & R & RSDA \\
\hline D & R & R & R & R & R & R & R & R \\
\hline C & R & R & R & R & R & R & R & R \\
\hline B & R & PNDET & R & R & R & R & R & \(\overline{\mathrm{CDET}}\) \\
\hline A & R & R & R & R & R & R & R & R \\
\hline 9 & R & \(\overline{\mathrm{FED}}\) & R & R & R & R & R & R \\
\hline 8 & R & R & R & R & R & \(\overline{\text { P2DET }}\) & R & R \\
\hline 7 & \multicolumn{2}{|r|}{RTH} & DDIS & RPDM & R & R & T2 & RTDIS \\
\hline 6 & IFIX & TOD & \multicolumn{6}{|c|}{RECEIVER CONFIGURATION} \\
\hline 5 & \multicolumn{8}{|c|}{RAM ACCESS XS} \\
\hline 4 & \multicolumn{8}{|c|}{RAM ACCESS YS} \\
\hline 3 & \multicolumn{8}{|c|}{RAM DATA XSM} \\
\hline 2 & \multicolumn{8}{|c|}{RAM DATA XSL} \\
\hline 1 & \multicolumn{8}{|c|}{RAM DATA YSM} \\
\hline 0 & \multicolumn{8}{|c|}{RAM DATA YSL; RECEIVER DATA} \\
\hline \begin{tabular}{l}
Register \\
Bit
\end{tabular} & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline
\end{tabular}

Receiver Interface Memory Chip 2 ( \(\overline{\mathbf{C S 2})}\)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \[
\begin{array}{|r|}
\hline \text { Bit } \\
\text { Register }
\end{array}
\] & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & R & R & R & R & R & R & R & R \\
\hline E & RBIA & R & R & R & R & RBIE & R & RBDA \\
\hline D & R & R & R & R & R & R & R & R \\
\hline C & R & R & R & R & R & R & R & R \\
\hline B & R & R & R & R & R & R & R & R \\
\hline A & R & R & R & R & R & R & R & R \\
\hline 9 & R & R & R & R & R & R & R & R \\
\hline 8 & R & R & R & R & R & R & R & R \\
\hline 7 & R & R & R & R & R & R & R & R \\
\hline 6 & R & R & R & R & R & R & R & R \\
\hline 5 & \multicolumn{8}{|c|}{RAM ACCESS XB} \\
\hline 4 & \multicolumn{8}{|c|}{RAM ACCESS YB} \\
\hline 3 & \multicolumn{8}{|c|}{RAM DATA XBM} \\
\hline 2 & \multicolumn{8}{|c|}{RAM DATA XBL} \\
\hline 1 & \multicolumn{8}{|c|}{RAM DATA YBM} \\
\hline 0 & \multicolumn{8}{|c|}{RAM DATA YBL} \\
\hline Register Bit & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline
\end{tabular}

R48DP Interface Memory Definitions


\section*{R48DP Interface Memory Definitions (Continued)}
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & Description \\
\hline \multirow[t]{5}{*}{LAEN} & Link Amplitude Equalizer Enable & 0:5:3 & The link amplitude equalizer enable and select bits control an amplitude compromise equalizer in the receive path acording to the following table: \\
\hline & & & LAEN A3L Curve Matched \\
\hline & & & 0 X No Equalizer \\
\hline & & & 10 U.S. Survey Long \\
\hline & & & 11 Japanese 3-Link \\
\hline LCEN & Loop Clock Enable & 0:4:0 & When control bit LCEN is a one, the transmitter clock tracks the receiver clock. \\
\hline \multirow[t]{4}{*}{LDEN} & Link Delay Equalizer Enable & 0:5:2 & The link delay equalizer enable and select bits control a delay compromise equalizer in the receive path according to the following table: \\
\hline & & & LDEN D3L Curve Matched \\
\hline & & &  \\
\hline & & & 11 Japanese 3-Link \\
\hline L2ACT & Remote Digıtal Loopback Activate & 0:4•1 & When control bit L2ACT is a one, the receiver digital output is connected to the transmitter digital input in accordance with CCITT recommendatıon V 54 loop 2. \\
\hline L3ACT & \begin{tabular}{l}
Local Analog \\
Loopback Activate
\end{tabular} & 0.4:7 & When control bit L3ACT is a one, the transmitter analog output is coupled to the receiver analog input through an attenuator in accordance with CCITT recommendation V. 54 loop 3. \\
\hline L4ACT & Remote Analog Loopback Activate & 0:4:6 & When control bit L4ACT is a one, the receiver analog input is connected to the transmitter analog output through a variable gain amplifier in a manner similar to recommendation V. 54 loop 4. \\
\hline L4HG & Loop 4 High Gain & 0:4:5 & When control bit L4HG is a one, the loop 4 variable gain amplifier is set for +16 dB , and when at zero the gain is zero dB . \\
\hline MHLD & Mark Hold & 0:7:4 & When control bit MHLD is a one, the transmitter input data stream is forced to all marks (ones). \\
\hline PNDET & Period N Detector & 1:B:6 & When status bit PNDET is a zero, it indicates a PN sequence has been detected. This bit sets to a one at the end of the PN sequence. \\
\hline \(\overline{\text { P2DET }}\) & Period Two Detector & 1-8:2 & When status bit P2DET is a zero, it indicates that a P2 sequence has been detected. This bit sets to a one at the start of the PN sequence. \\
\hline (None) & RAM Access XB & 2:5:0-7 & Contains the RAM access code used in reading chip 2 RAM locations via word \(X\) (2:3 and 2:2). \\
\hline (None) & RAM Access XS & 1.5:0-7 & Contains the RAM access code used in reading chip 1 RAM locations via word \(\times(1 \cdot 3\) and 1:2). \\
\hline (None) & RAM Access YB & 2-4:0-7 & Contains the RAM access code used in reading chip 2 RAM locations via word Y (2•1 and \(2: 0\) ). \\
\hline (None) & RAM Access YS & 1:4:0-7 & Contains the RAM access code used in reading chip 1 RAM locations via word Y (1:1 and 1:0). \\
\hline (None) & RAM Data XBL & 2:2:0-7 & Least significant byte of 16-bit word X used in reading RAM locations in chip 2. \\
\hline (None) & RAM Data XBM & 2:3:0-7 & Most signıficant byte of 16-bit word X used in reading RAM locations in chip 2. \\
\hline (None) & RAM Data XSL & 1:2:0-7 & Least significant byte of 16 -bit word X used in reading RAM locatıons in chip 1 \\
\hline (Norie) & RAM Data XSM & 1:3:0-7 & Most significant byte of 16-bit word X used in reading RAM locations in chip 1. \\
\hline
\end{tabular}

\section*{R48DP Interface Memory Definitions (Continued)}
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & Description \\
\hline (None) & RAM Data YBL & 2:0:0-7 & Least significant byte of 16-bit word \(Y\) used in reading RAM locations in chip 2. \\
\hline (None) & RAM Data YBM & 2:1:0-7 & Most significant byte of 16-bit word Y used in reading RAM locations in chip 2. \\
\hline (None) & RAM Data YSL & 1:0:0-7 & Least significant byte of 16 -bit word \(Y\) used in reading RAM locations in chip 1 . Shared by parallel data mode for presenting channel data to the host microprocessor bus. See 'Receiver Data.' \\
\hline (None) & RAM Data YSM & 1:1:0-7 & Most significant byte of 16-bit word Y used in reading RAM locations in chip 1. \\
\hline RBDA & Receiver Baud Data Available & 2:E•0 & Status bit RBDA goes to a one when the receiver writes data into register 2:0. The bit goes to a zero when the host processor reads data from register 2:0. \\
\hline RBIA & Receiver Baud Interrupt Active & 2:E:7 & This status bit is a one whenever the receiver baud rate device is driving \(\overline{\mathrm{RRQ}}\) low. \\
\hline RBiE & Receiver Baud Interrupt Enable & 2:E:2 & When the host processor writes a one in the RBIE control bit, the \(\overline{\mathrm{RQ}}\) line of the hardware interface is driven to zero when status bit RBDA is a one. \\
\hline \multirow[t]{7}{*}{(None)} & Receiver Configuration & 1:6:0-5 & The host processor configures the receiver by writing a control code into the receiver configuration field in the interface memory space (see RSB). \\
\hline & & & Receiver Configuration Control Codes \\
\hline & & & \begin{tabular}{l}
Control codes for the modem receiver configuration are: \\
Configuration \\
Configuration Code (Hex)
\end{tabular} \\
\hline & & & V. 274800 Long 22 \\
\hline & , & & V. 272400 Long 21 \\
\hline & & & V. 274800 Short 02 \\
\hline & & & V. 272400 Short 01 \\
\hline (None) & Receiver Data & 1:0:0-7 & The host processor obtains channel data from the receiver in the parallel data mode by reading a data byte from the receiver data register. The data is divided on baud boundaries as is the transmitter data. When using receiver parallel data mode, the registers \(1: 3\) through 1:0 can not be used for reading the chip 1 RAM. \\
\hline RPDM & Receiver Parallel Data Mode & 1:7:4 & When control bit RPDM is a one, the receiver supplies channel data to the receiver data register (1:0) as well as to the hardware serial data output. (See Receiver Data) \\
\hline RSB & Receiver Setup Bit & 1:E:3 & When the host processor changes the receiver configuration or the RTH field, the host processor must write a one in the RSB control bit. RSB goes to zero when the changes become effective. \\
\hline RSDA & Receiver Sample Data Available & 1:E:0 & Status bit RSDA goes to a one when the receiver writes data to register 1:0. RSDA goes to a zero when the host processor reads data from register 1:0. \\
\hline RSIA & Receiver Sample Interrupt Active & 1:E:7 & This status bit is a one whenever the receiver sample rate device is driving \(\overline{\mathbb{R} Q}\) to zero. \\
\hline RSIE & Receiver Sample Interrupt Enable & 1:E:2 & When the host processor writes a one in the RSIE control bit, the \(\overline{\operatorname{RQ}}\) line of the hardware interface is driven to zero when status bit RSDA is a one. \\
\hline RTDIS & Receiver Training Disable & 1:7:0 & When control bit RTDIS is a one, the receiver is prevented from recognizing a trainıng sequence and entering the training state \\
\hline \multirow[t]{6}{*}{RTH} & Receiver Threshold Field & 1:7:6,7 & The receiver energy detector threshold is set by the RTH field according to the following codes (see RSB): \\
\hline & & & RTH RLSD On RLSD Off \\
\hline & & &  \\
\hline & & &  \\
\hline & & &  \\
\hline & & &  \\
\hline
\end{tabular}

R48DP Interface Memory Definitions (Continued)


R48DP Interface Memory Definitions (Continued)


\section*{POWER-ON INITIALIZATION}

When power is applied to the R48DP, a period of 50 to 350 ms is required for power supply settling. The power-on-reset signal (POR) remains low during this period. Approximately 10 ms after the low to high transition of POR, the modem is ready to be configured, and RTS may be activated. If the 5 Vdc power supply drops below 3.5 Vdc for more than 30 msec , the POR cycle is generated.

At POR time the modem defaults to the following configuration: V. 274800 bps, short train, T/2, no echo protector tone, serial data mode, internal clock, cable equalizers disabled, link amplitude equalizer disabled, link delay equalizer disabled, transmitter output level set to \(-1 \mathrm{dBm} \pm 1 \mathrm{~dB}\), interrupts disabled, receiver threshold set to -43 dBm , eye pattern selectable, and train-on-data disabled.

POR can be connected to a user supplied power-on-reset signal in a wire-or configuration. A low active pulse of \(3 \mu \mathrm{sec}\) or more applied to the POR pin causes the modem to reset. The modem is ready to be configured 10 msec after \(P O R\) is removed.

\section*{PERFORMANCE}

Functioning as a V. 27 bis/ter type modem, the R48DP provides the user with unexcelled high performance.

\section*{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 \(\mathbf{- 2 0} \mathrm{dBm}\) as illustrated.

\section*{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 .

\section*{GENERAL SPECIFICATIONS}
\begin{tabular}{|c|c|c|}
\hline \multicolumn{3}{c|}{ Power } \\
\hline Voltage & Tolerance & Current (Max) \\
\hline+5 Vdc & \(\pm 5 \%\) & \(<700 \mathrm{~mA}\) \\
+12 Vdc & \(\pm 5 \%\) & \(<20 \mathrm{~mA}\) \\
-12 Vdc & \(\pm 5 \%\) & \(<80 \mathrm{~mA}\) \\
\hline Note: All voltages must have ripple \(\leq 0.1\) volts peak-to-peak. \\
\hline
\end{tabular}

Environmental
\begin{tabular}{|l|l|}
\hline Parameter & \multicolumn{1}{|c|}{ Specification } \\
\hline 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 & \begin{tabular}{l} 
Stored in heat sealed antistatic bag \\
and shipping container
\end{tabular} \\
\hline Relative Humidity & \begin{tabular}{l} 
Up to \(90 \%\) noncondensing, or a wet \\
bulb temperature up to \(35^{\circ} \mathrm{C}\), \\
whichever is less
\end{tabular} \\
\hline
\end{tabular}

Mechanical
\begin{tabular}{|l|l|}
\hline \multicolumn{1}{|c|}{ Parameter } & \multicolumn{1}{c|}{ Specification } \\
\hline Board Structure & \begin{tabular}{l} 
Single PC board with single right \\
angle header with 64 pıns, Burndy \\
(P196B32R00A00Z1) or equivalent \\
matıng connector.
\end{tabular} \\
\hline Dimensions & \begin{tabular}{l} 
Width-3.94 in. \((100 \mathrm{~mm})\) \\
Length-4.72 in. \((120 \mathrm{~mm})\) \\
Height-0.4 in. \((10.2 \mathrm{~mm})\)
\end{tabular} \\
\hline Weight & Less than \(3.6 \mathrm{oz} .(100 \mathrm{~g})\) \\
\hline
\end{tabular}

The BER performance test set-up is shown in the following diagram:

\section*{Worst Case BER Performance \\ (Back-to-Back)}


\begin{tabular}{|r|r|}
\hline Inches & MM \\
\hline .119 & 3 \\
.156 & 4 \\
.483 & 12 \\
3.275 & 83 \\
3.700 & 94 \\
3.937 & 100 \\
4.100 & 104 \\
4.725 & 120 \\
\hline
\end{tabular}

R48DP Circuit Board Dimensions

\section*{V27P/1 \\ HIGH SPEED 4800 BPS MODEM}

\section*{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 V27P/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 functıonally compatıble with those enhanced specifications available in the Rockwell V27P and M48P modem series.

\section*{FEATURES}
- Single printed circuit card
- 4800/2400 bps modes
- Full-duplex or half-duplex
- Dedicated or general switched network lines operation
- Ulıımate 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
- Automatıc training sequence for receiver


\section*{FUNCTIONAL SPECIFICATIONS}


\section*{Transmit Carrier and Signalling Frequencies}

Carrier Frequency Codex

Compatible QAM:
Carrier Frequency V.27:
Echo Suppression Frequencies:
Signalling Frequencies of T.30:

\section*{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.

\section*{Data Signalling and Modulation Rate}

At 1600 baud:
\begin{tabular}{lr} 
Signalling Rate- & 1600 baud \(\pm 0.01 \%\) \\
Data Rate- & 4800 bps \(\pm 0.01 \%\) \\
At 1200 baud: & \\
Signalling Rate- & 1200 baud \(\pm 0.01 \%\) \\
Data Rate- & 2400 bps \(\pm 0.01 \%\)
\end{tabular}

\section*{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.

\section*{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.

\section*{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.

\section*{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 traıning 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

\section*{V27P/1 Configurations}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline No. & Configuration & \begin{tabular}{l}
Transmitter ITC (1P-5P) \\
(Octal Code)
\end{tabular} & \[
\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) \\
\hline 1. & 1600 Baud DIAL, CCITT DIAL & 22 & 22 & 1,3 & 4800 & 181 & NOTE \\
\hline 2. & 1600 Baud DIAL - T/2 & 22 & 36 & 1,3 & 4800 & 181 & NOTE \\
\hline 3. & 1600 Baud DIAL Slow & 36 & 22 & 1,3 & 4800 & 221 & NOTE \\
\hline 4. & 1600 Baud P-P & 20 & 20 & 1,3 & 4800 & 141 & NOTE \\
\hline 5. & 1600 Baud P-P - T/2 & 20 & 32 & 1,3 & 4800 & 141 & NOTE \\
\hline 6. & 1600 Baud Manual CCITT & 32 & 30 & 3 & 4800 & \[
\begin{aligned}
& 20 \text { (Sync } \\
& \text { Sequence) }
\end{aligned}
\] & 1800 \\
\hline 7. & 1600 Baud Manual CCITT & 30 & 30 & 3 & 4800 & 50 (Sync Sequence) & 1800 \\
\hline 8. & 1600 Baud V27 DIAL/P-P & 23 & 23 & 3 & 4800 & 708 & 1800 \\
\hline 9. & 1600 Baud V27 DIALP-P EP & 27 & 23 & 3 & 4800 & 923 & 1800 \\
\hline 10. & 1600 Baud V27 DIAL/P-P - T/2 & 23 & 33 & 3 & 4800 & 708 & 1800 \\
\hline 11. & 1600 Baud V27 DIALP-P - T/2 EP & 27 & 33 & 3 & 4800 & 923 & 1800 \\
\hline 12. & 1600 Baud V27 Multipoint - T/2 & 21 & 27 & 3 & 4800 & 50 & 1800 \\
\hline 13. & 1600 Baud V27 Resync (use with configuration 8) & 21 & 25 & 3 & 4800 & 50 & 1800 \\
\hline 14. & 1600 Baud V27 Resync EP (use with configuration 9) & 25 & 25 & 3 & 4800 & 265 & 1800 \\
\hline 15. & 1600 Baud V27 Resync - T/2 (use with configuration 10) & 21 & 35 & 3 & 4800 & 50 & 1800 \\
\hline 16 & 1600 Baud V27 Resync - T/2 EP (use with configuration 11) & 25 & 35 & 3 & 4800 & 265 & 1800 \\
\hline 17 & 1200 Baud DIAL & 14 & 10 & 3 & 2400 & 170 & 1800 \\
\hline 18. & 1200 Baud P-P & 10 & 10 & 3 & 2400 & 117 & 1800 \\
\hline 19. & 1200 Baud V27 DIAL/P-P & 13 & 11 & 3 & 2400 & 943 & 1800 \\
\hline 20. & 1200 Baud V27 DIALP-P EP & 17 & 11 & 3 & 2400 & 1158 & 1800 \\
\hline 21. & 1200 Baud V27 Multıpoınt & 11 & 15 & 3 & 2400 & 66 & 1800 \\
\hline 22. & 1200 Baud V27 Resync (use with configuration 19) & 11 & 13 & 3 & 2400 & 66 & 1800 \\
\hline 23. & 1200 Baud V27 Resync EP (use with configuration 20) & 15 & 13 & 3 & 2400 & 281 & 1800 \\
\hline Note & Carrier frequency is \(17062 / 3 \mathrm{~Hz}\) w Carrier frequency is 1800 Hz when & \(n\) IRSS (1P-2P RSS \((1 P-2 P)\) is & a 1 (8-point). (8-phase DPSK) & & & & \\
\hline
\end{tabular}

\section*{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 : D109 ON
Less than -48 dBm : D109 OFF
2) Greater than -26 dBm :
Less than -31 dBm :
D109 ON
D109 OFF
3) Greater than -16 dBm:
Less than -21 dBm:

The three threshold options are controlled by the condition of the THRESH1 and THRESH2 control lines as indicated below.
\begin{tabular}{cll} 
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
\end{tabular}

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\) ).

\section*{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.


\section*{Suggested Interface Circults for Controling THRESH1 and THRESH2 Input Lines}

\section*{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

\section*{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.

\section*{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.

\section*{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 trainıng sequence requires that there be sufficient signal energy and that the receiver's carrier frequency variable be within 30 Hz of nominal.

\section*{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 \(\mathrm{V} .27 \mathrm{bis} / \mathrm{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.

\section*{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.

\section*{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 Baiud 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.

\section*{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.

\section*{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.

\section*{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

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{SPECIFICATIONS}

V27P/1 Specifications
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|c|}{DC Voltages} \\
\hline Voltage & Tolerance & Current (Typical) & Current (Max) \\
\hline \[
\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}
\] \\
\hline \multicolumn{4}{|l|}{Note: All voltages must have ripple \(\leqslant 0.1\) volts peak-to-peak.} \\
\hline \multicolumn{4}{|c|}{Environment} \\
\hline \begin{tabular}{l}
Temperature: \\
Relative Humidity:
\end{tabular} & \multicolumn{3}{|r|}{\begin{tabular}{l}
Operating: \(0^{\circ} \mathrm{C}\) to \(+60^{\circ} \mathrm{C}\) ( 32 to \(140^{\circ} \mathrm{F}\) ) \\
Storage: \(-40^{\circ} \mathrm{C}\) to \(+80^{\circ} \mathrm{C}\left(-40\right.\) to \(\left.176^{\circ} \mathrm{F}\right)\) \\
(Stored in heat sealed antistatic bag and shippıng container) \\
Up to \(90 \%\) noncondensing, or a wet bulb temperature up to \(35^{\circ} \mathrm{C}\), whichever is less.
\end{tabular}} \\
\hline \multicolumn{4}{|c|}{Mechanical} \\
\hline \begin{tabular}{l}
Board Structure: \\
Mating Connector: \\
Dimensions: \\
Weight:
\end{tabular} & \multicolumn{3}{|r|}{\begin{tabular}{l}
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. \\
Width-9.188 in ( 23.338 cm ) Depth—6.288 in (15.972 cm) \\
Less than \(0.45 \mathrm{lbs}(0.20 \mathrm{~kg})\)
\end{tabular}} \\
\hline
\end{tabular}

\title{
R1212DS MODEM DEVICE SET (212A COMPATIBLE)
}


\section*{PRODUCT PREVIEW}

\section*{INTRODUCTION}

The R1212DS is a high performance \(1200 / 300 \mathrm{bps}\), full duplex modem device set. Utilizing state-of-the-art LSI and signal processing technology, the R1212DS provides the user with enhanced performance and reliability.

The R1212DS is ideal for designing products for data transmission over the 2-wire dial-up telephone network. CCITT V. 22 A, B, Bell 212A and 103 compatible, the R1212DS can handle virtually all applications for full duplex 1200 bps (synchronous or asynchronous) and 0 to 300 bps asynchronous data transmission over the switched network.

Test features such as local analog loopback, remote digital loopback, and a self test configuration offer the user flexibility in creating a 1200 bps modem design customized for specific packaging and functional requirements.

For detail information, reference R1212 Modem Device Set Manual Order No. 652.

Product is available NOW.

\section*{FEATURES}
- Bell 212A and 103 Compatible
- CCITT V. 22 A, B Compatible
- Operation-2-Wire Full-Duplex
- Adaptive and Fixed Compromise Equalization
- Outstanding Performance Over Unconditioned Lines
- Test Configurations
-Local Analog Loopback
-Remote Digital Loopback
-Self Test
- Busy Out Option
- Auto/Manual Answer
- Auto/Manual Dial -Tone or Pulse Dial
- Synchronous-1200 bps, 600 bps Fallback
- Asynchronous-1200 bps, \(600 \mathrm{bps} \pm .01 \%, 0-300 \mathrm{bps}\) -Character length 8, 9, 10, or 11 bits
- Eye Pattern Generation Capability
- Power Consumption-3 Watts typical
- Power Requirements: \(+5 \mathrm{Vdc}, \pm 12 \mathrm{Vdc}\)
- Guard Tone Generation (CCITT Configurations) -Selectable 1800 Hz and 550 Hz
- 3 Integrated Circuits Provide Total Modem Functions

R2424DS
MODEM DEVICE SET 2400 BPS FULL DUPLEX MODEM

\section*{PRODUCT PREVIEW}

\section*{INTRODUCTION}

The Rockwell R2424DS is a high performance 2400/1200/ 300 bps full duplex modem device set. Utilizing state-of-the-art VLSI and signal processing technology, the R2424DS provides the user with enhanced performance and reliability.

The R2424DS is ideal for data transmission over the 2-wire dial-up telephone network. CCITT V. 22 bis, V. 22 A, B, Bell 212A and 103 compatible, the R2424DS can handle virtually all applications for full-duplex 2400 and 1200 bps fallback (synchronous and asynchronous) and 0 to 300 bps asynchronous data transmission over the switched network.

Test features such as local analog loopback, remote digital loopback, and a self test configuration offer the user flexibility in creating a 2400/1200 bps modem design customized for specific packaging and functional requirements.

For detail information, reference R2424 Modem Device Set Manual Order No. 651.

Product is available NOW.

\section*{FEATURES}
- CCITT V. 22 bis Compatible
- CCITT V. 22 A, B Compatible
- Bell 212A and 103 Compatible
- Operation-2-Wire Full-duplex
- Adaptive and Fixed Compromise Equalization
- Outstanding Performance Over Unconditioned Lines
- Test Configurations
-Local Analog Loopback
-Remote Digital Loopback
-Self Test
- Auto/Manual Answer
- Auto/Manual Dial
-Tone or Pulse Dial
- Synchronous-2400 bps, \(1200 \mathrm{bps}, 600 \mathrm{bps} \pm .01 \%\)
- Asynchronous-2400 bps, 1200 bps, 600 bps +1\%, -2.5\% 0-300 bps
-Character length 8, 9, 10, or 11 bits
- Eye Pattern Generation Capability
- Power Consumption-3 Watts typical
- Guard Tone Generation (CCITT Configurations)
-Selectable 1800 Hz and 550 Hz
- 3 Integrated circuits provide total modem functions


\section*{PRODUCT PREVIEW}

\section*{INTRODUCTION}

The R24 Data Pump is a synchronous, serial, 2400 bps modem designed for operation over dedicated unconditioned lines or with the general switched telephone network with appropriate line terminations, such as a Data Access Arrangement or transformer, provided externally.

The R24DP satisfies the telecommunications requirements specified in CCITT V. 27 bis/ter and Bell 208 A/B for 4800 bps modems.

The R24DP is optimized for point-to-point applications and suitable for network applications where the optimum in data transfer is needed. Its small size ( 100 mm by 120 mm ) and low power consumption ( 2.5 W typical) offer the user flexibility in creating a 2400 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 R24DP is a member of Rockwell's family of plug compatible modems.

Product availability is APRIL, 1985.

\section*{FEATURES}
- Configurations
—Bell 201C
-CCITT V. 26
- Half-Duplex (2-Wire), Full-Duplex (4-Wire)
- Ideal for Point-to-Point Applications
- Plug Compatible with Rockwell R96DP, R48DP, R96FT Modems
- Programmable Tone Generation
- Dynamic Range: -43 dBm to 0 dBm
- Equalization
-Automatic Adaptive
-Compromise Cable (Selectable)
-Compromise Link (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
-Remote Digital
- Power Consumption-2.5 Watts typical
- TTL and CMOS Compatible

\section*{SPECIFICATIONS}

\section*{POWER REQUIREMENTS}
\(+5 \mathrm{Vdc} \pm 5 \%<500 \mathrm{ma}\)
\(+12 \mathrm{Vdc} \pm 5 \%<20 \mathrm{ma}\)
\(-12 \mathrm{Vdc} \pm 5 \%<80 \mathrm{ma}\)

\section*{ENVIRONMENTAL}

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.

\section*{R1212 \\ 1200 BPS FULL-DUPLEX MODEM}

\section*{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.

\section*{FEATURES}
- CCITT V. 22 A, B Compatible
- Bell 212A and 103 Compatible
- Synchronous: 1200 bps, 600 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 (Configuration/Control) and RS-232-C Interface (Data/Control)
-Electrically: TTL Compatible
- Operation: 2-wire full-duplex
- Adaptive and Fixed Compromise 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: R1212DC (Direct Connect) with FCC approved DAA Part 68 Interface and R1212M (Module) without DAA

\section*{TECHNICAL SPECIFICATIONS}

TRANSMITTER CARRIER AND SIGNALING FREQUENCIES

\section*{Transmitter Carrier and Signaling Frequencies Specifications}
\begin{tabular}{|l|c|}
\hline \multicolumn{1}{|c|}{ Frequency } & \begin{tabular}{c} 
Specification \\
\((\mathbf{H z} \pm 0.01 \%)\)
\end{tabular} \\
\hline 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 \\
\hline
\end{tabular}

\section*{TONE GENERATION}

The specifications for tone generation are as follows:
1. Answer Backtones: The R1212 generates 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 is \(6 \pm 1 \mathrm{~dB}\) below the level of the data power in the main channel. The total power transmitted to the line is the same whether or not a guard tone is enabied. If a 553.846 Hz guard is used, its transmitted power is \(3 \pm 1 \mathrm{~dB}\) below the level of the main channel power, and again the overall power transmitted to the line will 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 generates dual tone multifrequency 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 the dial digit register with the appropriate digit as shown in the following table:

Dial Digits/Tone Pairs
\begin{tabular}{|l|l|l|l|c|cc|}
\hline \multicolumn{4}{|c|}{ BCD } & Dlal Diglts & \multicolumn{2}{c|}{ Tone Pairs } \\
\hline 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 \\
\hline
\end{tabular}

\section*{TONE DETECTION}

The R1212 can detect tones in the \(340 \pm 5 \mathrm{~Hz}\) to \(640 \pm 5 \mathrm{~Hz}\) band.

Detection Level: 0 to -45 dBm
Response Time: \(17 \pm 2 \mathrm{~ms}\)

\section*{SIGNALING AND DATA RATES}

The signaling and data rates for the R1212 are defined in the table below:

SIgnaling and Data Rates
\begin{tabular}{|l|c|c|}
\hline Operating Mode & Signallng Rate (Baud) & Data Rate \\
\hline \begin{tabular}{l} 
V.22: \\
(Alternative A) \\
Mode i
\end{tabular} & 600 & \(1200 \mathrm{bps} \pm 0.01 \%\) Synchronous \\
Mode iii & 600 & \(600 \mathrm{bps} \pm 0.01 \%\) Synchronous \\
(Alternative B) & & \\
Mode i & 600 & \(1200 \mathrm{bps} \pm 0.01 \%\) Synchronous \\
Mode iii & 600 & \(600 \mathrm{bps} \pm 0.01 \%\) Synchronous \\
Mode ii & 600 & 1200 bps Asynchronous \\
Mode iv & & \(8,9,10\), or 11 Bits Per Character \\
& 600 & 800 bps Asynchronous \\
\hline Bell 212A & 0 to 300 & 1200 bps \(\pm 0.01 \%\) \\
& & Synchronous/Asychronous \\
\hline
\end{tabular}

\section*{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.

\section*{EQUALIZERS}

The R1212 provides equalization functions that improve performance when operating over low quality 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 equalization is provided in the transmitter.

\section*{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 900 to 1500 Hz (low channel) and 2100 to 2700 Hz (high channel).

\section*{SCRAMBLER/DESCRAMBLER}

The R1212 incorporates a self-synchronizing scrambler/ descrambler. In accordance with the CCITT V. 22 and the Bell 212A recommendations. This function cannot be disabled.

\section*{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.

\section*{RECEIVE LEVEL}

The receiver circuit of the R1212 satisfies all specified performance requirements for the received line signals from 0 dBm to -45 dBm . The received line signal is measured at the receiver analog input RXA.

\section*{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.035 \%\) (relative) frequency error in the associated transmit timing source.

\section*{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.

\section*{PERMISSIVE/PROGRAMMABLE CONFIGURATIONS}

The R1212M transmit level is +6 dBm to allow a DAA to be used. The DAA then determines the permissive or programmable configuration.

The R1212DC transmit level is strapped in the permissive mode so that the maximum output level is \(-10 \mathrm{dBm} \pm 1.0 \mathrm{dBm}\).

\section*{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.

\section*{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.

\section*{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.

\section*{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 telephone company 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. (Note: All time measurements without a tolerance have a \(\pm 0.5 \mathrm{~ms}\) tolerance.)

\section*{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.

\section*{AUTOMATIC RECONFIGURATION}

The R1212 is capable of automatically configuring itself to the compatibility of a remote modem. The R1212 can be in either the answer or originate mode for this to occur. The compatibilities
that the R1212 is limited to adapt to are V.22A/B, Bell 212, and Bell 103. If the R1212 is to originate in a specific configuration, the MODE bits must be set.

\section*{RECEIVE/TRANSMIT CIRCUITS}

The receiver and transmitter circuits are defined in the following block diagrams:


R1212 Receiver/Equalizer Block Diagram


\section*{MODES OF OPERATION}

The R1212 is capable of being operated in either a serial or a parallel mode of operation.

\section*{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 Functional Interconnect Diagram) illustrates this capability.

\section*{PARALLEL MODE}

The R1212 has the capability of modem control via the microprocessor bus. Data transfer is maintained over the serial V. 24 channel.

\section*{MODE SELECTION}

Selection of either the serial ( \(\overline{\mathrm{DTR}}, \overline{\mathrm{RTS}}, \overline{\mathrm{TLK}}, \overline{\mathrm{ORG}}\) ) or parallel (DTR, RTS, DATA, ORG) control is by means of the BUS bits ([0,1]:D:7). To enable the parallel control, the BUS bits must be
set to a one. The modem automatically defaults to the serial mode at power-on. In either mode the R1212 is configured by the host processor via the microprocessor bus.

\section*{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.

\section*{HARDWARE CIRCUITS}

Signal names and descriptions of the hardware circuits, including the microprocessor interface, are listed in the R1212 Hardware Circuits table. In the table, the column titled 'Type' refers to designations found in the Hardware Circuit Characteristics. 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.


R1212 Hardware Circuits
\begin{tabular}{|c|c|c|c|}
\hline Name & Type & Pin No. & Description \\
\hline \multicolumn{4}{|l|}{A. OVERHEAD:} \\
\hline Ground (A) & AGND & 31C,32C & Analog Ground Return \\
\hline Ground (D) & DGND & 3C,8C,5A,10A & Digital Ground Return \\
\hline + 5 volts & PWR & 19C,23C,26C,30C & + 5 volt supply \\
\hline + 12 volts & PWR & 15A & + 12 volt supply \\
\hline -12 volts & PWR & 12A & -12 volt supply \\
\hline \(\overline{\text { POR }}\) & I/OB & 13C & Power-On-Reset \\
\hline \multicolumn{4}{|l|}{B. MICROPROCESSOR INTERFACE:} \\
\hline D7 & I/OA & 1 C ) & \\
\hline D6 & I/OA & & \\
\hline D5 & I/OA & & \\
\hline D4 & I/OA & 2 A & Data Bus (8 Bits) \\
\hline D3 & I/OA & 3A & \\
\hline D2 & I/OA & 4 C & \\
\hline D1 & I/OA & & \\
\hline D0 & I/OA & 5 C J & \\
\hline RS3 & IA & 6C & \\
\hline RS2 & IA & 6 A & Register Select \\
\hline RS1 & IA & 7 C & (4 Bits) \\
\hline RSO & IA & 7 A & \\
\hline \(\overline{\text { cso }}\) & IA & 10 C & Chip Select Receiver Baud Rate Device \\
\hline \(\overline{\mathrm{CS} 1}\) & IA & 9 C & Chip Select Transmitter Sample Rate Device \\
\hline READ & IA & 12 C & Read Enable \\
\hline WRITE & IA & 11A & Write Enable \\
\hline \(\overline{\mathrm{IRQ}}\) & OB & 11 C & Interrupt Request \\
\hline \multicolumn{4}{|l|}{C. V. 24 INTERFACE:} \\
\hline XTCLK & IB & 22A & External Transmit Clock \\
\hline TDCLK & OC & 23A & Transmit Data Clock \\
\hline RDCLK & OC & 21A & Receive Data Clock \\
\hline RTS & IB & 25A & Request-to-Send \\
\hline CTS & OC & 25C & Clear-to-Send \\
\hline TXD & IB & 24 C & Transmit Data \\
\hline RXD & OC & 22 C & Receive Data \\
\hline \(\overline{\text { RLSD }}\) & OC & 24A & Received Line Signal Detector \\
\hline \(\overline{\text { DTR }}\) & IB & 21 C & Data Terminal Ready \\
\hline \(\overline{\text { DSR }}\) & OC & 20A & Data Set Ready \\
\hline RI & OC & 18A & Ring Indicator \\
\hline \multicolumn{4}{|l|}{D. ANALOG SIGNALS (R1212M ONLY):} \\
\hline RXA & IB & 32A & Receive Analog Input \\
\hline TXA & OC & 31A & Transmit Analog Output \\
\hline \multicolumn{4}{|l|}{E. SIGNALS TO DAA (R1212M ONLY):} \\
\hline \(\overline{\mathrm{RD}}\) & IB & 27A & Ring Detect \\
\hline RCCT & OC & 28A & Request Coupler Cut Through \\
\hline \(\overline{\text { CCT }}\) & IB & 29 C & Coupler Cut Through \\
\hline OH & OC & 29A & Off-Hook Relay Control \\
\hline \multicolumn{4}{|l|}{F. ANCILLARY CIRCUITS:} \\
\hline TBCLK & OC & 27C & Transmit Baud Clock \\
\hline RBCLK & OC & 26A & Receive Baud Clock \\
\hline TLK & IC & 28 C & Talk (TLK = Data) \\
\hline \(\overline{\text { ORG }}\) & IB & 16 C & Originate (ORG = Answer) \\
\hline
\end{tabular}

\section*{MICROPROCESSOR TIMING}


Microprocessor Interface Timing Diagram

Critical Timing Requirements
\begin{tabular}{|l|c|c|c|c|}
\hline \multicolumn{1}{|c|}{ Characteristic } & Symbol & Min & Max & Units \\
\hline\(\overline{\text { CSi, RSi setup time prior }} \quad\) & & & & \\
\(\quad\) to Read or \(\overline{\text { 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 & & & & \\
\(\quad\) Read or \(\overline{\text { Write }}\) & TCH & 10 & - & NS \\
Write data setup time & TWDS & 75 & - & NS \\
Write data hold tıme & TWDH & 10 & - & NS \\
Write strobe pulse width & TWR & 75 & - & NS \\
\hline
\end{tabular}

\section*{hardware circuit characteristics}

\section*{Digital Interface Characteristics}

Digital Interface Characteristics
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Units} & \multicolumn{8}{|c|}{Input/Output Type} \\
\hline & & & IA & IB & IC & OA & OB & OC & 1/0 A & 1/0 B \\
\hline \(\mathrm{V}_{\mathrm{IH}}\) & Input Voltage, High & v & 2.0 Min. & 2.0 Min. & 2.0 Min. & & & & 2.0 Min. & \[
\begin{aligned}
& \text { 5.25 Max. } \\
& \text { 2.0 Min. }
\end{aligned}
\] \\
\hline \(\mathrm{V}_{\text {IL }}\) & Input Voltage, Low & v & 0.8 Max. & 0.8 Max. & 0.8 Max. & & & & 0.8 Max. & 0.8 Max. \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output Voltage, High & v & & & & 2.4 Min. \({ }^{1}\) & & & 2.4 Min. \({ }^{1}\) & 2.4 Min. \({ }^{3}\) \\
\hline \(\mathrm{V}_{\text {OL }}\) & Output Voltage, Low & v & & & & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) \\
\hline \(\mathrm{I}_{\mathrm{N}}\) & Input Current, Leakage & \(\mu \mathrm{A}\) & \(\pm 2.5\) Max. & & & & & & \(\pm 2.5\) Max. \({ }^{4}\) & \\
\hline \(\mathrm{IOH}^{\text {O }}\) & Output Current, High & mA & & & & -0.1 Max. & & & & \\
\hline loL & Output Current, Low & mA & & & & 1.6 Max. & 1.6 Max. & 1.6 Max. & & \\
\hline L & Output Current, Leakage & \(\mu \mathrm{A}\) & & & & & \(\pm 10\) Max. & & & \\
\hline Ipu & Pull-up Current (Short Circuit) & \(\mu \mathrm{A}\) & & \[
\begin{aligned}
& \text { - } 240 \mathrm{Max} . \\
& -10 \mathrm{Min} .
\end{aligned}
\] & \[
\begin{aligned}
& -240 \mathrm{Max} \\
& -10 \mathrm{Min} .
\end{aligned}
\] & & & \[
\begin{array}{|l}
-240 \text { Max. } \\
-10 \mathrm{Min} .
\end{array}
\] & & \[
\begin{aligned}
& \text { - } 260 \mathrm{Max} . \\
& \text { - } 100 \mathrm{Min} .
\end{aligned}
\] \\
\hline \(C_{L}\) & Capacitive Load & pF & 5 & 5 & 20 & & & & 10 & 40 \\
\hline \(C_{0}\) & Capacitive Drive & pF & & & & 100 & 100 & 100 & 100 & 100 \\
\hline & Current Type & & TTL & TTL w/Pull-up & TTL w/Pull-up & TTL & Open-Drain & Open-Drain w/Pull-up & 3-State Transceiver & Open-Drain w/Pull-up \\
\hline
\end{tabular}

Notes
1. 1 Load \(=-100 \mu \mathrm{~A}\)
2. 1 Load \(=1.6 \mathrm{~mA}\)
3. 1 Load \(=-40 \mu \mathrm{~A}\)
4. \(\mathrm{V}_{\mathrm{IN}}=0.4\) to \(2.4 \mathrm{Vdc}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{Vdc}\)

\section*{Analog Interface Characteristics}

TXA - The (Type OC) transmitter output is a low impedance operational amplifier output in series with a 604 ohm resistor. In order to have a 0 dBm output, an external 600 ohm resistor to ground is required.

RXA - The (Type IB) receiver input impedance is 63.4 K ohms \(\pm 5\) percent.

\section*{Transmission Line Interface Characteristics}

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 two RJ11 jacks. The pin designations are shown in the table below:

R1212DC Network Interface
\begin{tabular}{|c|c|c|c|}
\hline Connection Type & Telco & Mnemonic & Function \\
\hline VSOC & 1 & & \\
RJ11 & 2 & & \\
Jack & 3 & R & \begin{tabular}{l} 
Ring-one side of \\
telephone line
\end{tabular} \\
& 4 & T & \begin{tabular}{l} 
Tip-one side of \\
telephone line
\end{tabular} \\
& 5 & & \\
\hline
\end{tabular}

Ring Indicator - The R1212 provides a ring indicator (有) 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{RI}}\) 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
\begin{tabular}{|c|c|}
\hline RI Transition & Response Time \\
\hline Off-to-On & 170 ms to \(\pm 50 \mathrm{~ms}\) \\
On-to-Off & 110 ms to \(\pm 50 \mathrm{~ms}\) \\
\hline
\end{tabular}

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 - 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{R D}-\overline{R D}\) 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{\text { CCT }}\) - An on (low) signal to the \(\overline{\text { CCT lead indicates to the }}\) R1212M that the data transmission path through the DAA is connected.

\section*{AUDIO INTERFACE INPUT IMPEDANCE CHARACTERISTICS}

Audio Interface Input Impedance Characteristics
\begin{tabular}{|c|l|}
\hline On/Off Hook & \multicolumn{1}{c|}{ Measurement } \\
\hline On-Hook (DC) & \begin{tabular}{l} 
The DC resistance between Tip and \\
Ring, and between either Tip or Ring \\
and signal ground is greater than \\
10 megohms for DC voltages up to \\
100 volts.
\end{tabular} \\
\hline On-Hook (AC) & \begin{tabular}{l} 
The on-hook AC impedance measured \\
between Tip and Ring is less than \\
40K ohms (15.3 Hz minimum).
\end{tabular} \\
\hline Off-Hook (DC) & \begin{tabular}{l} 
Less than 200 ohms. \\
\hline Off-Hook (AC) \\
\hline \begin{tabular}{l}
600 ohms nominal when measured \\
between Tip and Ring.
\end{tabular} \\
\hline
\end{tabular} \\
\hline
\end{tabular}

\section*{SOFTWARE CIRCUITS}

The R1212 comprises two signal processor chips. Each of these chips contains 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. The registers are referred to as interface memory. Registers in chip 0 update at the modem baud rate (bps) (except RAM Access and RAM Data Update where operation is at sample rate). Registers in chip 1 update at the sample rate ( 7200 bps ).

When information in these registers is being discussed, the format \(Y: Z: Q\) is used. The chip is specified by \(Y(0\) or 1\()\), the register by \(Z(0-F)\), and the bit by \(Q(0-7,0=L S B)\).

\section*{Status Control Bits}

The operation of the R1212 is affected by a number of software control inputs. These inputs are written into registers within the interface memory via the host microprocessor bus. 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 interface memory via the host microprocessor bus. All status and control bits are defined in the Interface Memory table. Bits designated by an 'R' are reserved for modem use only and must not be changed by the host.

\section*{RAM Data Access}

The R1212 provides the user with access to much of the data stored in the modem's memories. This data is useful for performing certain diagnostic functions.

Two RAM access registers are provided in the interface memory to allow user access to various RAM locations within chip 0 and chip 1. The access code stored in \(0: F\) selects the source of data for the RAM data registers in chip 0 ( \(0: 5\) through 0:2). Similarly, the access code stored in 1:F selects the source of data for registers \(1: 5\) through 1:2. Reading is performed by first storing the desired access code in register 0:F (or 1:F). The data may then be read from 0:5 through 0:2 (or 1:5 through 1:2).

\section*{RAM Access Codes}

The RAM access codes defined in the following table allow the host processor to read diagnostic information within the modem.

RAM Access Codes (Chip 0)
\begin{tabular}{|l|c|c|}
\hline \multicolumn{1}{|c|}{ Function } & \begin{tabular}{c} 
Access \\
Code
\end{tabular} & \begin{tabular}{c} 
Register \\
No.
\end{tabular} \\
\hline Self Test Error Counter & 00 & \(2,34,5\) \\
Equalizer Tap Coefficients & \(01-0 \mathrm{D}\) & \(2,3,4,5\) \\
Phase Error & 10 & 2,3 \\
Rotated Equalizer Output & 11 & \(2,3,4,5\) \\
(Received Point Eye Pattern) & 12 & 4,5 \\
Rotated Angle & 40 & \(2,3,4,5\) \\
Low Pass Filter Output & \(41-4 \mathrm{D}\) & \(2,3,4,5\) \\
Input Signal to Equalizer Tap Coefficients & 51 & \(2,3,4,5\) \\
Decision Points (Ideal Eye Pattern) & 52 & \(2,3,4,5\) \\
Rotated Error & 53 & \(2,3,4,5\) \\
Equalizer Output & 56 & \(2,3,4,5\) \\
Demodulator Output &
\end{tabular}

\section*{Auto Dial Sequence}

The following flow chart defines the auto dial sequence via the microprocessor interface memory.


Auto Dial Sequence Flow Diagram
R1212 Receiver Interface Memory Chip 0 ( \(\overline{\text { CSO }}\) )
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & \multicolumn{8}{|c|}{RAM Access B} \\
\hline E & IRQ & ENSI & NEWS & R & NEWC & R & R & R \\
\hline D & BUS & CRQ & X & X & X & LCD & RSD & X \\
\hline C & X & X & X & & HAR & X & X & X \\
\hline B & X & X & X & X & X & X & X & AL \\
\hline A & ERDL & RDL & DL & ST & \multicolumn{4}{|c|}{MODE} \\
\hline 9 & X & X & \multicolumn{2}{|l|}{SPEED} & X & X & X & X \\
\hline 8 & TONE & X & X & X & X & X & TM & RLSD \\
\hline 7 & R & R & R & R & R & R & R & R \\
\hline 6 & R & R & R & R & R & R & R & R \\
\hline 5 & \multicolumn{8}{|c|}{RAM Data YBM} \\
\hline 4 & \multicolumn{8}{|c|}{RAM Data YBL} \\
\hline 3 & \multicolumn{8}{|c|}{RAM Data XBM} \\
\hline 2 & \multicolumn{8}{|c|}{RAM Data XBL} \\
\hline 1 & R & R & R & R & R & R & R & R \\
\hline 0 & R & R & R & R & R & R & R & R \\
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \begin{tabular}{l}
\((\mathrm{X})\) indicates \\
(R) indicates
\end{tabular} & user av reserve & vailable ed for &  & use & & & & \\
\hline
\end{tabular}

Note: The modem timing for the auto dialer accounts for interdigit delay for pulses and tones.

The timing for the pulses and tones are as follows:
\[
\begin{aligned}
\text { Pulses - } & \text { Relay open } 64 \mathrm{~ms} \\
& \text { Relay closed } 36 \mathrm{~ms} \\
& \text { Interdigit delay } 750 \mathrm{~ms} \\
\text { Tones - } & \text { Tone duration } 71 \mathrm{~ms} \\
& \text { Interdigit delay } 71 \mathrm{~ms} \\
& \text { Output Level } 1.5 \pm 1 \mathrm{dBm}
\end{aligned}
\]

R1212 Transmitter Interface Memory Chip 1 ( \(\overline{\mathbf{C S} 1)}\)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline \begin{tabular}{|r} 
\\
Register
\end{tabular} & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & \multicolumn{8}{|c|}{RAM Access S} \\
\hline E & IRQ & ENSI & NEWS & R & NEWC & DDEI & R & DDRE \\
\hline D & BUS & CRQ & DATA & AAE & DTR & X & X & SSD \\
\hline C & DSRA & & CLK & & HAR & X & X & X \\
\hline B & \multicolumn{3}{|c|}{TX LEVEL} & GTE & GTS & 3DB & DTMF & AL \\
\hline A & ERDL & RDL & DL & ST & \multicolumn{4}{|c|}{MODE} \\
\hline 9 & BRK & X & ORG & LL & RTS & CC & X & X \\
\hline 8 & DLO & CTS & DSR & RI & X & X & X & X \\
\hline 7 & R & R & R & R & R & R & R & R \\
\hline 6 & R & R & R & R & R & R & R & R \\
\hline 5 & \multicolumn{8}{|c|}{RAM Data YSM} \\
\hline 4 & \multicolumn{8}{|c|}{RAM Data YSL} \\
\hline 3 & \multicolumn{8}{|c|}{RAM Data XSM} \\
\hline 2 & \multicolumn{8}{|c|}{RAM Data XSL} \\
\hline 1 & R & R & R & R & R & R & R & R \\
\hline 0 & \multicolumn{8}{|c|}{Dial Digit Regıster} \\
\hline Register & & & & & & & & \\
\hline Bit & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \begin{tabular}{l}
( X ) indicates \\
(R) indicates
\end{tabular} & user av reserve & vailable ed for &  & \begin{tabular}{l}
e \\
use
\end{tabular} & & & & \\
\hline
\end{tabular}

R1212 Interface Memory Definitions
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & Description \\
\hline AAE & Auto Answer Enable & 1:D:4 & When control bit AAE goes to a one, the modem will automatically answer when a singing signal is present on the line. \\
\hline AL & Analog Loopback & \((0,1): 8: 0\) & When control bit AL is a one, the modem is placed in (V. 54 Loop 3) local analog loopback. In this loop, the transmitter's analog output is coupled to the recelver'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 attenuated \(14 \pm 1 \mathrm{dBm}\). \\
\hline BRK & Break & 1:9:7 & When control bit BRK goes to a one, the modem transmits \(2 \mathrm{M}+3\) bits of start polarity. ( \(M\) is equal to the number of bits per character in the selected format.) BRK will reset to zero after the sequence is sent. \\
\hline BuS & Bus Select & (0,1):D:7 & When control bit BUS goes to a one, the modem is placed in the parallel control mode, and when zero the modem is configured for the serial control mode. BUS can be in either state to configure the modem. \\
\hline CC & Controlled Carrier & 1:9:2 & When control bit CC goes to a one, the modem is placed in controlled carrier operation; and when zero, the modem is configured for constant carrier operation. \\
\hline \multirow[t]{3}{*}{CHAR} & \multirow[t]{3}{*}{Character Length Select} & \multirow[t]{3}{*}{\((0,1): C:(3,4)\)} & These character length bits select either 8, 9, 10, or 11 bit characters, as shown below: \\
\hline & & & Conflguration Conflguration Word \\
\hline & & & \begin{tabular}{rll}
8 bits & 0 & 0 \\
9 bits & 0 & 1 \\
10 bits & 1 & 0 \\
11 bits & 1 & 1
\end{tabular} \\
\hline CRQ & Call Request & (0,1):D:6 & When control bit CRQ goes to a one, it places the transmitter in auto dial and the receiver in tone detect mode. The data placed in the dial digit is then treated as digits to be dialed. After the last digit has been dialed, FF (HEX) should be loaded into the dial digit register to tell the modem to go to the data state. CRQ in the transmitter (chip 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 on-hook. CRQ in the receiver (chip 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. \\
\hline CTS & Clear-to-Send & 1:8:6 & When status bit CTS is a one, it indicates to the terminal equipment that the modem will transmit any data which are present at TXD. \\
\hline , & & & CTS response times from an on or off condition of RTS are shown below: \\
\hline DATA & Talk/Data & 1:D:5 & When control bit DATA goes to a one, it places the modem in data state and when zero in the talk state. \\
\hline DDEI & Dial Digit Empty Interrupt & 1:E:2 & When control bit DDEI goes to a one, it causes an interrupt to occur when the dial digit register ( \(1: 0\) ) is empty ( \(\mathrm{DDRE}=1\) ). \\
\hline DDR & Dial Digit Register & 1:0:(0-7) & DDR is used to load the digits to be dialed. Example: If a 4 is to be dialed, a 04 (HEX) should be loaded. This action also causes the interrupt to be cleared. DDR is a write only register. \\
\hline DDRE & Dial Digit Register Empty & 1:E:0 & When status bit DDRE is a one, it indicates that the dial digit register is empty and can be loaded with a new digit to be dialed. After the register is loaded, DDRE goes to zero. \\
\hline DL & Digital Loopback (Manual) & \((0,1): A: 5\) & When control bit DL is a one, the modem is manually placed in remote digital loopback. DL should be set during the data mode. DSA and CTS will be at zero. 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 reset to zero. The local modem will then return to the normal data mode with control reverting the DTE's, DTR. \\
\hline
\end{tabular}

R1212 Interface Memory Definitions (Continued)
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & Description \\
\hline DLO & Data Line Occupied & 1:8:7 & When status bit DLO is a one, it indicates that the modem is in the auto dial state, i.e., CRQ is at a one and the modem is off-hook and ready to dial. \\
\hline DSR & Data Set Ready & 1:8:5 & When status bit DSR is a one, it indicates that the answerback tone has been detected, the modem handshake 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 at zero in all test states (except optionally for analog loopback) and when the channel is being used for voice communication (talk). \\
\hline DSRA & \begin{tabular}{l}
Data Set Ready \\
In Analog \\
Loopback
\end{tabular} & \(1: C: 7\) & When control bit DSRA goes to a one, it causes DSR to be set to a one during analog loopback. \\
\hline DTMF & Touch Tones/ Pulse Dialıng & 1:B:1 & When control bit DTMF goes to a one, it tells the modem to auto dial using tones, and when zero the modem will dial using pulses. \\
\hline DTR & Data Termınal Ready & 1:D:3 & Control bit DTR must be a one, before the modem will enter the data state, either manually or automatically. DTR must also be at a one in order for the modem to automatically answer an incoming call. \\
\hline ENSI & Enable New Status Interrupt & \((0,1): E: 6\) & When control bit ENSI goes to a one, it causes an interrupt to occur when the status bits in registers ( \(0:[8,9]\) ) and \((1: 8)\) are updated. (NEWS \(=1\) ) \\
\hline ERDL & Enable Response to Remote Digital Loopback & \((0,1): A \cdot 7\) & When control bit ERDL goes to a one, it enables the modem to respond to another modem's remote digital loopback request, thus going into loopback. \\
\hline GTE & Guard Tone Enable & 1:B:4 & When control bit GTE goes to a one, it causes the specified guard tone to be transmitted (CCITT Configurations only). \\
\hline GTS & Guard Tone Select & 1:B:3 & When control bit GTS goes to zero, it selects the 1800 Hz tone and when a one it selects the 550 Hz tone. \\
\hline IRQ & Interrupt Request & \((0,1): E: 7\) & When status bit IRQ is a one, it indicates that an interrupt has been generated. \\
\hline LCD & Loss of Carrier Disconnect & 0:D:2 & When control bit LCD goes to a one, the modem terminates a call when a loss of received carrier energy is detected after 400 msec . After the first 40 ms of loss of carrier, RLSD goes off. 360 ms later if no carrier is detected, CTS goes off. LCD is not disabled in leased line operation. \\
\hline LL & Leased Line & 1:9•4 & When control bit LL goes to a one, it places the modem in leased line operation; a when zero switched line operation. \\
\hline \multirow[t]{9}{*}{MODE} & \multirow[t]{9}{*}{Mode Select} & \multirow[t]{9}{*}{\((0,1): A:(0-3)\)} & These bits select the compatibility at which the modem is to operate, as shown below: \\
\hline & & & Configuration Configuration Word \\
\hline & & & Bell 212A 1200 Sync. 0 \\
\hline & & & Bell 212A 1200 Async. 0000 \\
\hline & & & Bell 212A 300 Async. 00 \\
\hline & & & V.22A 1200 Sync. 110000 \\
\hline & & & \(\begin{array}{llllll}\text { V.22B } & 1200 \text { Async. } & 1 & 0 & 0 & 1\end{array}\) \\
\hline & & & V.22A 600 Sync. 10010 \\
\hline & & & V.22B 600 Async. 1 \\
\hline NEWC & New Configuration & \((0,1): E: 3\) & When status bit NEWC is a one, it 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. \\
\hline
\end{tabular}

R1212 Interface Memory Definitions (Continued)
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & Description \\
\hline NEWS & New Status & (0,1) : E:5 & When status bit NEWS is a one, it tells the user that there has been a change of status in the status registers. The user must write a zero into NEWS to reset it. This action also causes the interrupt to be cleared. \\
\hline ORG & Originate/Answer & 1:9:5 & When status bit ORG is a one, it tells the modem that it is originating a call and when a zero answering a call. (This is only valid in manual originate/answer and analog loopback.) \\
\hline (None) & RAM Access B & 0:F:0-7 & Contains the RAM access code used in reading RAM locations in chip 0 (baud rate device). \\
\hline (None) & RAM Access S & 1:F:0-7 & Contains the RAM access code used in reading RAM locations in chip 1 (sample rate device). \\
\hline (None) & RAM Data XBL & 0:2:0-7 & Least significant byte of 16 -bit word X used in reading RAM locations in chip 0 . \\
\hline (None) & RAM Data XBM & 0:3:0-7 & Most significant byte of 16 -bit word X used in reading RAM locations in chip 0 . \\
\hline (None) & RAM Data XSL & 1:2:0-7 & Least significant byte of 16 -bit word X used in reading RAM locations in chip 1. \\
\hline (None) & RAM Data XSM & 1:3:0-7 & Most significant byte of 16-bit word X used in reading RAM locations in chip 1. \\
\hline (None) & RAM Data YBL & 0:4:0-7 & Least significant byte of 16 -bit word \(Y\) used in reading RAM locations in chip 0 . \\
\hline (None) & RAM Data YBM & 0:5:0-7 & Most significant byte of 16-bit word \(Y\) used in reading RAM locations in chip 0 . \\
\hline (None) & RAM Data YSL & 1:4:0-7 & Least significant byte of 16-bit word Y used in reading RAM locations in chip 1. \\
\hline (None) & RAM Data YSM & 1:5:0-7 & Most significant byte of 16-bit word Y used in reading RAM locations in chip 1. \\
\hline RDL & Remote Digital Loopback & (0,1).A: 6 & When control bit RDL goes to a one, it causes the modem to initiate a request for the remote modem to go into digital loopback. \\
\hline RI & Ring Indıcator & 1:8:4 & When status bit RI is a one, it indicates that a ringing signal is being detected. \\
\hline \multirow[t]{2}{*}{RLSD} & \multirow[t]{2}{*}{Received Line Signal Detector} & \multirow[t]{2}{*}{0:8:0} & When status bit RLSD is a one, it indicates that the carrier has successfully been received. RLSD will not respond to the \(550,1800,2100\), or 2225 Hz tones. \\
\hline & & & \begin{tabular}{l}
RLSD response times are given below: \\
Note: \\
1. After handshake has occurred.
\end{tabular} \\
\hline RSD & Receive Space Disconnect & 0:D:1 & When control bit RSD goes to a one, it causes the modem to go on-hook after receiving approximately 1.6 seconds of continuous spaces. \\
\hline \multirow[t]{7}{*}{RTS} & \multirow[t]{7}{*}{Request-to-Send} & \multirow[t]{7}{*}{1:9:3} & When control bit RTS goes to a one, it allows the modem to transmit data when CTS becomes active. Responses to RTS are shown below: \\
\hline & & & Assume DTR is on, Talk/Data is set to Data (CRQ or AAE is set for a dial line) and the modem is connected to the line (off-hook). \\
\hline & & & Leased or Dial Line \({ }^{1}\) RTS Off RTS On \\
\hline & & & \begin{tabular}{lll} 
Controlled Carrier & CTS Off & Carrier On \\
& Carrier Off & 275 ms Scambled 1's \\
& & Transmitted \\
& CTS On
\end{tabular} \\
\hline & & & \begin{tabular}{lll} 
Constant Carrier & CTS Off & CTS On \\
& Carrier On & Carrier On \\
& Scrambled 1's & Data Transmitted \\
& Transmitted &
\end{tabular} \\
\hline & & & \begin{tabular}{l}
Note: \\
1. After handshake is complete.
\end{tabular} \\
\hline & & & For ease of use in constant carrier mode, RTS should be turned on the same time as DTR. \\
\hline SPEED & Speed Indication & \(0 \cdot 9 \cdot(4,5)\) & \[
\begin{array}{ll}
00=300 \mathrm{bps} & 10=1200 \mathrm{bps} \\
01=600 \mathrm{bps} &
\end{array}
\] \\
\hline SSD & Send Space Disconnect & 1:D:0 & When control bit SSD goes to a one, it causes the modem to transmit approximately 4 seconds of spaces before disconnecting, when DTR is at zero. \\
\hline
\end{tabular}

R1212 Interface Memory Definitions (Continued)
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & Description \\
\hline ST & Self Test (Continued) & \((0,1)\) : A: 4 & \begin{tabular}{l}
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-toend test.
\end{tabular} \\
\hline 3 DB & 3 dB Loss to Receive Signal & 1:B:2 & When control of bit 3 DB is a one, it attenuates the received signal 3 dB . This is only used if the R1212M will see 0 dBm or greater line signal at the receiver input. Insertion of the 3 dB loss will then prevent saturation. This bit is not needed with the R1212DC. \\
\hline TM & Test Mode & 0:8:1 & When status bit TM is a one, it indicates that the modem has completed the handshake and is in one of the following test modes: AL, RDL, or DL. \\
\hline TONE & Tone Detect & 0:8:7 & TONE follows the energy detected in the 340 to 640 Hz frequency band. The user must determine which tone is present on the line by determining the duty cycle of the TONE bit. TONE is active only when CRQ in chip 0 is a one. \\
\hline \multirow[t]{6}{*}{TXCLK} & \multirow[t]{6}{*}{Transmit Clock Select} & \multirow[t]{6}{*}{\(1: C:(5,6)\)} & TXCLK allows the user to designate the origin of the transmitter data clock, as shown below: \\
\hline & & & Transmit Clock Configuration Word \\
\hline & & & Internal 00 \\
\hline & & & Not Used 01 \\
\hline & & & External 10 \\
\hline & & & Slave 11 \\
\hline TX LEVEL & \multirow[t]{10}{*}{Transmit Level} & \multirow[t]{10}{*}{\(1: B:(5-7)\)} & TX LEVEL allows the user to change the R2424M transmitter output level, assuming the modem is transmitting into a 600 ohm load. \\
\hline & & & 1.0 dBm) Configuration Word \\
\hline & & & 0 dBm - 000 \\
\hline & & & -2 dBm 0001 \\
\hline & & & -4 dBm 010 \\
\hline & & & -6 dBm - 0011 \\
\hline & & & -8 dBm \(\quad 100\) \\
\hline & & & -10 dBm - 1001 \\
\hline & & & -12 dBm 110 \\
\hline & & & -14 dBm 111 \\
\hline
\end{tabular}

\section*{POWER-ON INITIALIZATION}

When power is applied to the R1212, a period of 50 to 300 ms is required for power supply settling. The power-on-reset signal (POR) remains low during this period. Approximately 10 ms after the low to high transition of POR, the modem is ready to be configured, and RTS may be activated. If the 5 Vdc power supply drops below 3.5 Vdc for more than 30 msec , the POR cycie is repeated.

At POR time the modem automatically defaults to Bell 212A 1200 bps, answer state using serial start-stop data 10 bits per character, constant carrier, dial line.

POR can be connected to a user supplied power-on-reset signal in a wire-or configuration. A low active pulse of \(3 \mu \mathrm{sec}\) or more applied to the POR pin causes the modem to reset. The modem is ready to be configured 10 msec after the low active pulse is removed from POR.

\section*{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.

\section*{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 .


BER Performance Test Set-up

\section*{GENERAL SPECIFICATIONS}
\begin{tabular}{|c|c|c|}
\hline \multicolumn{3}{|c|}{ Power } \\
\hline Voltage & Tolerance & Current (Max) \\
\hline+5 Vdc & \(\pm 5 \%\) & \(<500 \mathrm{~mA}\) \\
+12 Vdc & \(\pm 5 \%\) & \(<10 \mathrm{~mA}\) \\
-12 Vdc & \(\pm 5 \%\) & \(<50 \mathrm{~mA}\) \\
\hline Note: All voltages must have ripple \(\leq 0.1\) volts peak-to-peak. \\
\hline
\end{tabular}

Environmental
\begin{tabular}{|l|l|}
\hline Parameter & \multicolumn{1}{|c|}{ Specification } \\
\hline \begin{tabular}{l} 
Temperature \\
Operating- \\
Storage-
\end{tabular} & \begin{tabular}{l}
\(0^{\circ} \mathrm{C}\) to \(+60^{\circ} \mathrm{C}\left(32\right.\) to \(\left.140^{\circ} \mathrm{F}\right)\) \\
\(-40^{\circ} \mathrm{C}\) to \(+80^{\circ} \mathrm{C}\left(-40\right.\) to \(\left.176^{\circ} \mathrm{F}\right)\)
\end{tabular} \\
\hline Relative Humidity & \begin{tabular}{l} 
Up to \(90 \%\) noncondensing, or a wet \\
bulb temperature up to \(35^{\circ} \mathrm{C}\), \\
whichever is less.
\end{tabular} \\
\hline Altitude & -200 to \(+10,000\) feet \\
\hline \begin{tabular}{l} 
*PCB's are stored in heat sealed antistatic bags and shipping \\
containers
\end{tabular} \\
\hline
\end{tabular}

Mechanical
\begin{tabular}{|l|l|}
\hline Board Structure & \begin{tabular}{l} 
Single PC board with right angle \\
male DIN connector.
\end{tabular} \\
\hline Mating Connector & \begin{tabular}{l} 
Female 3 row 64 pin Euroconnector \\
(DIN) with rows A and C populated. \\
Recommended mating connector: \\
Winchester 96S-6043-0531-1 or \\
equivalent.
\end{tabular} \\
\hline PCB Dimensions & \\
R1212DC Version & Width \(3.94 \mathrm{in} .(100 \mathrm{~mm}) \times\) Length \\
& \(4.725 \mathrm{in} .(120 \mathrm{~mm}) \times\) Height \\
& \(0.75 \mathrm{in} .(19 \mathrm{~mm})\) \\
R1212M Version & Width \(3.94 \mathrm{in} .(100 \mathrm{~mm}) \times\) Length \\
& \(3.23 \mathrm{in} .(82 \mathrm{~mm}) \times\) Height 0.40 \\
& in. 10 mm\()\) \\
\hline Weight & Less than \(0.45 \mathrm{lbs} .(0.20 \mathrm{~kg})\). \\
\hline Lead Extrusion & \(0.100 \mathrm{in} .(2.54 \mathrm{~mm})\) max. \\
\hline
\end{tabular}


R1212 Printed Circuit Board Dimensions

\section*{INSTALLATION}

\section*{IMPORTANT NOTICE TO USER}

The R1212DC 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.

\section*{INTRODUCTION}

The Rockwell R1212/U is a high performance full-duplex 1200 bps modem. Using state-of-the-art VLSI and signal processing technology, the R1212/U provides the user with enhanced performance and reliability on a single printed circuit board of less than 19 square-inches-overall size.

The R1212/U 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.

\section*{FEATURES}
- CCITT V. 22 A, B Compatible
- Bell 212A and 103 Compatible
- Synchronous: 1200 bps, 600 bps \(\pm 0.01 \%\)
- Asynchronous: 1200 bps, 600 bps +1\%, -2.5\%, 0-300 bps -Character length \(8,9,10\), or 11 bits
- USART Internal
- DTE Interface
-Functionally: Microprocessor Bus (Data/Configuration/ Control)

RS-232-C Interface (Data/Control)
-Electrically: TTL Compatible
- Operation: 2-wire full-duplex
- Adaptive and Fixed Compromise 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: R1212DC/U (Direct Connect) with FCC approved DAA Part 68 Interface and R1212M/U (Module) without DAA


R1212/U Full-Duplex Modem

\section*{TECHNICAL SPECIFICATIONS}

\section*{transmitter carrier and signaling FREQUENCIES}

Transmitter Carrier and Signaling Frequencies Specifications
\begin{tabular}{|l|c|}
\hline \multicolumn{1}{|c|}{ Frequency } & \begin{tabular}{c} 
Specification \\
\((\mathbf{H z} \pm \mathbf{0 . 0 1 \% )}\)
\end{tabular} \\
\hline V. 22 low channel, Orignate Mode & 1200 \\
V.22 high channel, Answer Mode & 200 \\
Bell 212A high channel Answer Mode & 2400 \\
Bell 212A low channel Originate Mode & 1200 \\
Bell 103/113 Orıginating Mark & 1270 \\
Bell 103/113 Origınatıng Space & 1070 \\
Bell 103/113 Answer Mark & 2225 \\
Bell 103/113 Answer Space & 2025 \\
\hline
\end{tabular}

\section*{TONE GENERATION}

The specifications for tone generation are as follows:
1. Answerback Tones: The R1212/U is capable of generating echo disabling tones for 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 is \(6 \pm 1 \mathrm{~dB}\) below the level of the data power in the main channel. The total power transmitted to the line is the same whether or not a guard tone is enabled. If a 553.846 Hz guard is used, its transmitted power \(3 \pm 1 \mathrm{~dB}\) below the level of the main channel power, and again the overall power transmitted to the line will 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/U generates dual tone multifrequency 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 the transmitter data register with the appropriate digit as shown in the following table:

Dial Digits/Tone Pairs
\begin{tabular}{|l|l|l|l|c|cc|}
\hline \multicolumn{4}{|c|}{ BCD } & Dial Digits & \multicolumn{2}{c|}{ Tone Pairs } \\
\hline 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 \\
\hline
\end{tabular}

\section*{TONE DETECTION}

The R1212/U can detect tones in the \(340 \pm 5 \mathrm{~Hz}\) to \(640 \pm 5 \mathrm{~Hz}\) band.

Detection Level: 0 to -45 dBm
Response Time: \(17 \pm 2 \mathrm{~ms}\)

\section*{SIGNALING AND DATA RATES}

The signaling and data rates for the R1212/U are defined in the table below:

Signaling and Data Rates
\begin{tabular}{|c|c|c|}
\hline Operating Mode & Signaling Rate (Baud) & Data Rate \\
\hline \begin{tabular}{l} 
V.22. \\
(Alternative A) \\
Mode i
\end{tabular} & 600 & \(1200 \mathrm{bps} \pm 0.01 \%\) Synchronous \\
Mode ill & 600 & \(600 \mathrm{bps} \pm 0.01 \%\) Synchronous \\
\begin{tabular}{c} 
(Alternative B) \\
Mode i \\
Mode iii \\
Mode ii
\end{tabular} & 600 & \(1200 \mathrm{bps} \pm 0.01 \%\) Synchronous \\
Mode iv & 600 & \(600 \mathrm{bps} \pm 0.01 \%\) Synchronous \\
& 600 & 1200 bps Asynchronous \\
\hline Bell 212A & & \(8,9,10\), or 11 Bits Per Character \\
& 600 & 800 bps Asynchronous \\
\hline
\end{tabular}

\section*{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.

\section*{EQUALIZERS}

The R1212/U provides equalization functions that improve performance when operating over low quality 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 equalization is provided in the transmitter.

\section*{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 900 to 1500 Hz (low channel) and 2100 to 2700 Hz (high channel).

\section*{SCRAMBLER/DESCRAMBLER}

The R1212/U incorporates a self-synchronizing scrambler/ descrambler in accordance with the CCITT V. 22 and the Bell 212A recommendations. This function cannot be disabled.

\section*{RECEIVED SIGNAL FREQUENCY TOLERANCE}

The receiver circuit of the R1212/U can adapt to recelved frequency errors of up to \(\pm 7 \mathrm{~Hz}\) with less than a 0.2 dBm degradation in BER performance.

\section*{RECEIVE LEVEL}

The receiver circuit of the R1212/U satisfies all specified performance requirements for the received line signals from 0 dBm to -45 dBm . The received line signal is measured at the receiver analog input RXA.

\section*{RECEIVE TIMING}

The R1212/U 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.035 \%\) (relative) frequency error in the associated transmit timing source.

\section*{TRANSMIT LEVEL}

The R1212M/U output control circultry contains a variable gain buffer which reduces the modem output level. The R1212M/U can be strapped via the host interface memory to accomplish this.

\section*{PERMISSIVE/PROGRAMMABLE CONFIGURATIONS}

The R1212M/U transmit level is +6 dBm to allow a DAA to be used. The DAA then determines the permissive or programmable configuration.

The R1212DC/U transmit level is strapped in the permissive mode so that the maximum output level is \(-10 \mathrm{dBm} \pm 1.0 \mathrm{dBm}\).

\section*{TRANSMIT TIMING}

The R1212/U provides a Transmit Data Clock (TDCLK) output with the following characteristics:
1. Frequency. Selected data rate of 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.

\section*{CLAMPING}

The following clamp is provided with the R1212/U:
1. Receive Data (RXD). RXD is clamped to a constant mark (1) whenever RLSD is off.

\section*{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.

\section*{DATA SET READY}

The on condition of the R1212/U 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 circults-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, l.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 telephone company 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. (Note: All time measurements without a tolerance have a \(\pm 0.5 \mathrm{~ms}\) tolerance.)

\section*{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.

\section*{AUTOMATIC RECONFIGURATION}

The R1212/U is capable of automatically configuring itself to the compatibility of a remote modem. The R1212/U can be in either the answer or originate mode for this to occur. The compatibilities that the R1212/U is limited to adapt to are V.22A/B, Bell 212, and Bell 103. If the R1212/U is to originate in a specific configuration, the MODE bits must be set.

\section*{RECEIVE/TRANSMIT CIRCUITS}

The receiver and transmitter circuits are defined in the following block diagrams:


R1212/U Receiver/Equalizer Block Diagram


\section*{MODES OF OPERATION}

The R1212/U is capable of being operated in either a serial or a parallel mode of operation.

\section*{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 Functional Interconnect Diagram) illustrates this capability.

\section*{PARALLEL MODE}

The R1212/U has the capability of transferring channel data up to 8 bits at a time via the microprocessor bus. Both asynchronous and synchronous operation is available over the parallel bus.

\section*{MODE SELECTION}

Selection of either the serial or parallel mode is by means of the BUS bits ( \([0,1]: D: 7\) ). To enable the parallel mode, the bus bits must be set to a one. Serial mode can use only serial control inputs ( \(\overline{\mathrm{DTR}}, \overline{\mathrm{RTS}}, \overline{\mathrm{TLK}}, \overline{\mathrm{ORG}}\) ). Parallel mode requires the use of the register control bits (DTR, RTS, DATA, ORG). Both
the register and serial outputs are available concurrently, so either can be used in both modes. The modem automatically defaults to the serial mode at power-on. In either mode the R1212/U is configured by the host processor via the microprocessor bus.

\section*{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.

\section*{HARDWARE CIRCUITS}

Signal names and descriptions of the hardware circuits, including the microprocessor interface, are listed in the R1212/U Hardware Circuits table. In the table, the column titled 'Type' refers to designations found in the Hardware Circuit Characteristics. 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.


R1212/U Functional Interconnect Diagram

R1212/U Hardware Circuits
\begin{tabular}{|l|c|c|l|}
\hline \multicolumn{1}{|c|}{ Name } & Type & Pin No. & \multicolumn{1}{c|}{ Description } \\
\hline \multicolumn{3}{|c|}{ A. OVERHEAD: } \\
\hline Ground (A) & AGND & \(31 \mathrm{C}, 32 \mathrm{C}\) & Analog Ground Return \\
Ground (D) & DGND & \(3 C, 8 \mathrm{C}, 5 \mathrm{~A}, 10 \mathrm{~A}\) & Digital Ground Return \\
+5 volts & PWR & \(19 \mathrm{C}, 23 \mathrm{C}, 26 \mathrm{C}, 30 \mathrm{C}\) & +5 volt supply \\
+12 volts & PWR & 15 A & +12 volt supply \\
-12 volts & PWR & 12 A & -12 volt supply \\
\hline POR & /OB & 13 C & Power-On-Reset \\
\hline
\end{tabular}
B. MICROPROCESSOR INTERFACE:
\begin{tabular}{|c|c|c|c|}
\hline D7 & I/OA & 1 C & \\
\hline D6 & I/OA & 1A & \\
\hline D5 & I/OA & 2 C & \\
\hline D4 & I/OA & 2 A & Data Bus (8 Bits) \\
\hline D3 & I/OA & 3A & \\
\hline D2 & I/OA & 4 C & \\
\hline D1 & I/OA & 4A & \\
\hline D0 & I/OA & 5 C & \\
\hline RS3 & IA & 6C & \\
\hline RS2 & IA & 6A & Register Select \\
\hline RS1 & IA & 7 C & (4 Bits) \\
\hline RS0 & IA & 7A & \\
\hline \(\overline{\text { CSO }}\) & IA & 10 C & Chip Select Receiver Baud Rate Device \\
\hline \(\overline{\text { CS1 }}\) & IA & 9 C & Chip Select Transmitter Sample Rate Device \\
\hline READ & IA & 12 C & Read Enable \\
\hline WRITE & IA & 11A & Write Enable \\
\hline \(\overline{\mathrm{R} Q}\) & OB & 11C & Interrupt Request \\
\hline \multicolumn{4}{|l|}{C. V. 24 INTERFACE:} \\
\hline XTCLK & IB & 22A & External Transmit Clock \\
\hline TDCLK & OC & 23A & Transmit Data Clock \\
\hline RDCLK & OC & 21A & Receive Data Clock \\
\hline RTS & IB & 25A & Request-to-Send \\
\hline CTS & OC & 25C & Clear-to-Send \\
\hline TXD & IB & 24 C & Transmit Data \\
\hline RXD & OC & 22 C & Receive Data \\
\hline RLSD & OC & 24A & Received Line Signal Detector \\
\hline \(\overline{\text { DTR }}\) & IB & 21C & Data Terminal Ready \\
\hline \(\overline{\text { DSR }}\) & OC & 20A & Data Set Ready \\
\hline \(\overline{\mathrm{RI}}\) & OC & 18A & Ring Indicator \\
\hline \multicolumn{4}{|l|}{D. ANALOG SIGNALS (R1212M/U ONLY):} \\
\hline RXA & IB & 32A & Receive Analog Input \\
\hline TXA & OC & 31A & Transmit Analog Output \\
\hline
\end{tabular}

\section*{E. SIGNALS TO DAA (R1212M/U ONLY):}
\begin{tabular}{|l|c|l|l|}
\hline\(\overline{R D}\) & IB & \(27 A\) & \begin{tabular}{l} 
Ring Detect \\
Request Coupler Cut \\
RCCT
\end{tabular} \\
OC & \(28 A\) & \begin{tabular}{l} 
Through \\
Coupler Cut Through
\end{tabular} \\
\hline\(\overline{C C T}\) & IB & 29 C & \begin{tabular}{l} 
Off-Hook Relay Control
\end{tabular} \\
\hline OH & OC & 29 A & On \\
\hline
\end{tabular}
F. ANCILLARY CIRCUITS:
\begin{tabular}{|l|l|l|l|}
\hline TBCLK & OC & \(27 C\) & Transmit Baud Clock \\
\hline RBCLK & OC & 26 A & Receive Baud Clock \\
\hline TLK & IC & 28 C & Talk (TLK = Data) \\
\hline ORG & IB & 16 C & \begin{tabular}{l} 
Originate (ORG \(=\) \\
\\
\hline
\end{tabular} \(\mathrm{Answer)}\) \\
\hline
\end{tabular}

\section*{HARDWARE CIRCUIT CHARACTERISTICS}

\section*{Digital Interface Characteristics}

Digital Interface Characteristics
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Units} & \multicolumn{8}{|c|}{Input/Output Type} \\
\hline & & & IA & IB & IC & OA & OB & OC & I/O A & I/O B \\
\hline \(\mathrm{V}_{\mathrm{HH}}\) & Input Voltage, High . & v & 2.0 Min. & 2.0 Min. & 2.0 Min. & & & & 2.0 Min. & \[
\begin{aligned}
& \text { 5.25 Max. } \\
& \text { 2.0 Min. }
\end{aligned}
\] \\
\hline \(\mathrm{V}_{\text {IL }}\) & Input Voltage, Low & v & 0.8 Max. & 0.8 Max. & 0.8 Max. & & & & 0.8 Max. & 0.8 Max. \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output Voltage, High * & v & & & & 2.4 Min. \({ }^{1}\) & & & 2.4 Min. \({ }^{1}\) & 2.4 Min. \({ }^{3}\) \\
\hline \(\mathrm{V}_{\mathrm{OL}}\) & Output Voltage, Low & v & & & & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) & 0.4 Max. \({ }^{2}\) \\
\hline \(\mathrm{I}_{1}\) & Input Current, Leakage & \(\mu \mathrm{A}\) & \(\pm 2.5 \mathrm{Max}\). & & & & & & \(\pm 2.5\) Max. \({ }^{4}\) & \\
\hline \(\mathrm{IOH}^{\text {O}}\) & Output Current, High & mA & & & & -0.1 Max. & & & & \\
\hline 1 OL & Output Current, Low & mA & & & & 1.6 Max. & 1.6 Max. & 1.6 Max. & & \\
\hline IL & Output Current, Leakage & \(\mu \mathrm{A}\) & & & & & \(\pm 10 \mathrm{Max}\). & & & \\
\hline Ipu & Pull-up Current (Short Circuit) & \(\mu \mathrm{A}\) & & \[
\begin{aligned}
& -240 \mathrm{Max} . \\
& -10 \mathrm{Min} .
\end{aligned}
\] & \[
\begin{aligned}
& \text { - } 240 \mathrm{Max} . \\
& -10 \mathrm{Min} .
\end{aligned}
\] & & & \[
\begin{aligned}
& \text { - } 240 \text { Max. } \\
& \text { - } 10 \mathrm{Min} .
\end{aligned}
\] & & \[
\begin{aligned}
& \text { - } 260 \mathrm{Max} . \\
& \text { - } 100 \mathrm{Min} .
\end{aligned}
\] \\
\hline \(\mathrm{C}_{\mathrm{L}}\) & Capacitive Load & pF & 5 & 5 & 20 & & & & 10 & 40 \\
\hline \(\mathrm{C}_{\mathrm{D}}\) & Capacitive Drive & pF & & & & 100 & 100 & 100 & 100 & 100 \\
\hline & Current Type & & TTL & TTL w/Pull-up & TTL w/Pull-up & TTL & Open-Drain & Open-Drain w/Pull-up & 3-State Transceiver & Open-Drain w/Pull-up \\
\hline \multicolumn{11}{|l|}{Notes} \\
\hline \multicolumn{2}{|l|}{\multirow[t]{2}{*}{\begin{tabular}{l}
1. I Load \(=-100 \mu \mathrm{~A}\) \\
2. 1 Load \(=1.6 \mathrm{~mA}\)
\end{tabular}}} & \multicolumn{9}{|l|}{\multirow[t]{2}{*}{\begin{tabular}{l}
3. I Load \(=-40 \mu \mathrm{~A}\) \\
4. \(\mathrm{V}_{\mathrm{IN}}=0.4\) to \(2.4 \mathrm{Vdc}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{Vdc}\)
\end{tabular}}} \\
\hline & & & & & & & & & & \\
\hline
\end{tabular}

\section*{Analog Interface Characteristics}

TXA - The (Type OC) transmitter output is a low impedance operational amplifier output in series with a 604 ohm resistor. In order to have a 0 dBm output, an external 600 ohm to ground is required.

RXA - The (Type IB) receiver input impedance is 63.4 K ohms \(\pm 5\) percent.

\section*{Transmission Line Interface Characteristics}

The R1212DC/U 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/U only) is bi-directional as required by 2-wire full-duplex circuits.

Connection to the telephone line interface pins of the R1212DC/U to the network are made via two RJ11 jacks. The pin designations are shown in the table below:

R1212DC/U Network Interface
\begin{tabular}{|c|c|c|c|}
\hline Connection Type & Telco & Mnemonic & Function \\
\hline VSOC & 1 & & \\
RJ11 & 2 & & \\
Jack & 3 & R & \begin{tabular}{l} 
Ring-one side of \\
telephone line
\end{tabular} \\
& 4 & T & \begin{tabular}{l} 
Tip-one side of \\
telephone line
\end{tabular} \\
& 5 & & \\
\hline
\end{tabular}

Ring Indicator - The R1212/U 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{RI}}\) is not disabled by an off condition on Data Terminal Ready.

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
\begin{tabular}{|c|c|}
\hline RI Transition & Response TIme \\
\hline Off-to-On & \(170 \pm 50 \mathrm{~ms}\) \\
On-to-Off & \(110 \pm 50 \mathrm{~ms}\) \\
\hline
\end{tabular}

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 - The R1212M/U 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{R D}\) indicates to the R1212M/U 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.

CCT - An on (low) signal to the CCT lead indicates to the R1212M/U that the data transmission path through the DAA is connected.

\section*{AUDIO INTERFACE INPUT IMPEDANCE CHARACTERISTICS}

Audio Interface Input Impedance Characteristics
\begin{tabular}{|l|l|}
\hline On/Off Hook & \multicolumn{1}{c|}{ Measurement } \\
\hline On-Hook (DC) & \begin{tabular}{l} 
The DC resistance between Tip and \\
Ring, and between either Tip or Ring \\
and signal ground is greater than \\
10 megohms for DC voltages up to \\
100 volts.
\end{tabular} \\
\hline On-Hook (AC) & \begin{tabular}{l} 
The on-hook AC impedance measured \\
between Tip and Ring is less than \\
40 K ohms (15.3 Hz minimum).
\end{tabular} \\
\hline Off-Hook (DC) & Less than 200 ohms. \\
\hline Off-Hook (AC) & \begin{tabular}{l}
600 ohms nominal when measured \\
between Tip and Ring.
\end{tabular} \\
\hline
\end{tabular}

\section*{SOFTWARE CIRCUITS}

The R1212/U comprises two signal processor chips. Each of these chips contains 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. The registers are referred to as interface memory. Registers in chip 0 update at the modem baud rate (bps) (except RAM Access and RAM Data Update where operation is at sample rate). Registers in chip 1 update at the sample rate ( 7200 bps ).

When information in these registers is being discussed, the format \(Y: Z: Q\) is used. The chip is specified by \(Y(0\) or 1\()\), the register by \(Z(0-F)\), and the bit by \(Q(0-7,0=L S B)\).

\section*{Status Control Blts}

The operation of the R1212/U is affected by a number of software control inputs. These inputs are written into registers within the interface memory via the host microprocessor bus. 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 interface memory via the host microprocessor bus. All status and control bits are defined in the Interface Memory table. Bits designated by an ' \(R\) ' are reserved for modem use only and must not be changed by the host.

\section*{RAM Data Access}

The R1212/U provides the user with access to much of the data stored in the modem's memories. This data is useful for performing certain diagnostic functions.

Two RAM access registers are provided in the interface memory to allow user access to various RAM locations within chip 0 and chip 1. The access code stored in \(0: F\) selects the source of data for the RAM data registers in chip 0 (0:5 through 0:2). Similarly, the access code stored in 1:F selects the source of data for registers 1:5 through 1:2. Reading is performed by first storing the desired access code in register 0:F (or 1:F). The data may then be read from 0:5 through 0:2 (or 1:5 through 1:2).

\section*{RAM Access Codes}

The RAM access codes defined in the following table allow the host processor to read diagnostic information within the modem.

\section*{RAM Access Codes (Chip 0)}
\begin{tabular}{|l|c|c|}
\hline \multicolumn{1}{|c|}{\(\quad\) Function } & \begin{tabular}{c} 
Access \\
Code
\end{tabular} & \begin{tabular}{c} 
Register \\
No.
\end{tabular} \\
\hline Self Test Error Counter & 00 & 2,3 \\
Equalizer Tap Coefficients & \(01-0 \mathrm{D}\) & \(2,3,4,5\) \\
Phase Error & 10 & 2,3 \\
Rotated Equalizer Output & 11 & \(2,3,4,5\) \\
(Received Point Eye Pattern) & 12 & 4,5 \\
Rotated Angle & 40 & \(2,3,4,5\) \\
Low Pass Fllter Output & \(41-4 \mathrm{D}\) & \(2,3,4,5\) \\
Input Signal to Equalizer Tap Coefficients & 51 & \(2,3,4,5\) \\
Decision Points (Ideal Eye Pattern) & 52 & \(2,3,4,5\) \\
Rotated Error & 53 & \(2,3,4,5\) \\
Equalizer Output & 56 & \(2,3,4,5\) \\
\hline Demodulator Output & & \\
\hline
\end{tabular}

\section*{Auto Dial Sequence}

The following flow chart defines the auto dial sequence via the microprocessor interface memory.


\section*{Auto Dial Sequence Flow Diagram}

R1212/U Receiver Interface Memory Chip 0 ( \(\overline{\text { CSO }}\) )
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & \multicolumn{8}{|c|}{RAM Access B} \\
\hline E & IRQ & ENSI & NEWS & R & NEWC & ERFI & R & RDRF \\
\hline D & BUS & CRQ & x & X & X & LCD & RSD & X \\
\hline C & X & X & X & & HAR & PEN & PO & SBN \\
\hline B & X & X & X & X & X & X & X & AL \\
\hline A & ERDL & RDL & DL & ST & \multicolumn{4}{|c|}{MODE} \\
\hline 9 & X & X & \multicolumn{2}{|l|}{SPEED} & PE & FE & OVRN & X \\
\hline 8 & TONE & X & X & X & X & X & TM & RLSD \\
\hline 7 & R & R & R & R & R & R & R & R \\
\hline 6 & R & R & R & R & R & R & R & R \\
\hline 5 & \multicolumn{8}{|c|}{RAM Data YBM} \\
\hline 4 & \multicolumn{8}{|c|}{RAM Data YBL} \\
\hline 3 & \multicolumn{8}{|c|}{RAM Data XBM} \\
\hline 2 & \multicolumn{8}{|c|}{RAM Data XBL} \\
\hline 1 & R & R & R & R & R & R & R & R \\
\hline 0 & \multicolumn{8}{|c|}{Receiver Data Register} \\
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \begin{tabular}{l}
(X) indicates \\
( R ) indicates
\end{tabular} & user reserv & available ed for & e. modem & & & & & \\
\hline
\end{tabular}

\section*{Auto Dial Sequence Flow Diagram}

Note: The modem timing for the auto dialer accounts for interdigit delay for pulses and tones.

The timing for the pulses and tones are as follows:
\begin{tabular}{|c|}
\hline Pulses - Relay open 64 ms Relay closed 36 ms Interdigit delay 750 ms \\
\hline es - Tone duration 71 ms Interdigit delay 71 ms Output level \(1.5 \pm 1 \mathrm{~dB}\) \\
\hline
\end{tabular}

R1212/U Transmitter Interface Memory Chip 1 ( \(\overline{\mathrm{CS} 1)}\)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & \multicolumn{8}{|c|}{RAM Access S} \\
\hline E & IRQ & ENSI & NEWS & R & NEWC & ETEI & R & TDRE \\
\hline D & BUS & CRQ & DATA & AAE & DTR & X & X & SSD \\
\hline C & DSRA & & CLK & & HAR & PEN & PO & SBN \\
\hline B & \multicolumn{3}{|c|}{TX LEVEL} & GTE & GTS & 3DB & DTMF & AL \\
\hline A & ERDL & RDL & DL & ST & \multicolumn{4}{|c|}{MODE} \\
\hline 9 & BRK & x & ORG & LL & RTS & CC & X & X \\
\hline 8 & DLO & CTS & DSR & RI & X & X & X & X \\
\hline 7 & R & R & R & R & R & R & R & R \\
\hline 6 & R & R & R & R & R & R & R & R \\
\hline 5 & \multicolumn{8}{|c|}{RAM Data YSM} \\
\hline 4 & \multicolumn{8}{|c|}{RAM Data YSL} \\
\hline 3 & \multicolumn{8}{|c|}{RAM Data XSM} \\
\hline 2 & \multicolumn{8}{|c|}{RAM Data XSL} \\
\hline 1 & R & R & R & R & R & R & R & R \\
\hline 0 & \multicolumn{8}{|c|}{Transmitter Data Register} \\
\hline  & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \begin{tabular}{l}
(X) indicates \\
(R) indicates
\end{tabular} & user reserv & availabl ed for &  & \[
\mathrm{n} \text { use }
\] & only. & & & \\
\hline
\end{tabular}

R1212/U Interface Memory Definitions
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & \begin{tabular}{l}
Memory \\
Location
\end{tabular} & Description \\
\hline AAE & Auto Answer Enable & 1:D:4 & When control bit AAE goes to a one, the modem will automatically answer when a singıng signal is present on the line. \\
\hline AL & Analog Loopback & \((0,1): B: 0\) & When control bit AL is a one, the modem is placed in (V. 54 Loop 3) local analog loopback. 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 attenuated \(14 \pm 1 \mathrm{dBm}\). \\
\hline BRK & Break & 1:9:7 & When control bit BRK goes to a one, the modem transmits \(2 M+3\) bits of start polarity. ( \(M\) is equal to the number of bits per character in the selected format.) BRK will reset to zero after the sequence is sent \\
\hline BUS & Bus Select & (0,1) : D: 7 & When control bit BUS goes to a one, the modem is placed in the parallel mode, and when zero the modem is configured for the serial mode. BUS can be in either state to configure the modem. \\
\hline CC & Controlled Carrier & 1:9:2 & When control bit CC goes to a one, the modem is placed in controlled carrier operation; and when zero, the modem is configured for constant carrier operation. \\
\hline \multirow[t]{6}{*}{CHAR} & Character Length Select & \((0,1)\) : C : \((3,4)\) & These character length bits select either 8, 9, 10, or 11 bit characters, as shown below: \\
\hline & & & \begin{tabular}{l}
Configuration \\
Configuration Word
\end{tabular} \\
\hline & & & 8 bits 0 \\
\hline & & & 9 bits 0 \\
\hline & & & 10 bits 10 \\
\hline & & & 11 bits 1 \\
\hline CRQ & Call Request & \((0,1): D: 6\) & When control bit CRQ goes to a one, it places the transmitter in auto dial and the receiver in tone detect mode. The data placed in the dial digit is then treated as digits to be dialed. After the last digit has been dialed, FF (HEX) should be loaded into the dial digit register to tell the modem to go to the data state. CRQ in the transmitter (chip 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 on-hook. CRQ in the receiver (chip 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. \\
\hline \multirow[t]{4}{*}{CTS} & \multirow[t]{4}{*}{Clear-to-Send} & \multirow[t]{4}{*}{1:8:6} & When status bit CTS is a one, it indicates to the terminal equipment that the modem will transmit any data which are present at TXD. \\
\hline & & & CTS response times from an on or off conditıon of RTS are shown below: \\
\hline & & & CTS Transitions Constant Carrier Controlled Carrier \\
\hline & & & \begin{tabular}{lll} 
Off to On & \(<2 \mathrm{~ms}\) & 275 ms \\
On to Off & \(<2 \mathrm{~ms}\) & \(<2 \mathrm{~ms}\)
\end{tabular} \\
\hline DATA & Talk/Data & 1:D:5 & When control bit DATA goes to a one, it places the modem in data state and when zero in the talk state. \\
\hline DL & Digital Loopback (Manual) & \((0,1)\) : A: 5 & When control bit DL is a one, the modem is manually placed in remote digital loopback. DL should be set during the data mode. DSA and CTS will be at zero. 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, ali intertace circuits behave normaily as in the data mode. Ai the conciusion of the test, DL must be reset to zero. The local modem will then return to the normal data mode with control reverting the DTE's, DTR. \\
\hline DLO & Data Line Occupied & 1:8.7 & When status bit DLO is a one, it indicates that the modem is in the auto dial state, i.e., \(C R Q\) is at a one and the modem is off-hook and ready to dial. \\
\hline
\end{tabular}

\section*{R1212/U Interface Memory Definitions (Continued)}


R1212/U Interface Memory Definitions (Continued)
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & Description \\
\hline NEWC & New Configuration & \((0,1)\) : E: 3 & When status bit NEWC is a one, it 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 confıguration 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. \\
\hline NEWS & New Status & \((0,1): E: 5\) & When status bit NEWS is a one, it tells the user that there has been a change of status in the status registers. The user must write a zero into NEWS to reset it. This action also causes the interrupt to be cleared \\
\hline ORG & Orıgınate/Answer & 1:9:5 & When status bit ORG is a one, it tells the modem that it is originating a call and when a zero answering a call. (This is only valid in manual originate/answer and analog loopback.) \\
\hline OVRN & Overrun & 0:9.1 & When on, OVRN signifies that the receiver data register ( 0.0 ) was written over due to the user not reading it in the required interval. \\
\hline PE & Parity Error & 0.93 & When on, PE indicates that a parity error occurred during parallel asynchronous communication. \\
\hline PEN & Parıty Enable & \((0,1): C: 2\) & When on, PEN allows the generation of parity bits and tells the receiver that the data includes parity. \\
\hline PO & Parity Odd & \((0,1) \cdot \mathrm{C}: 1\) & When on, PO conditions the modem, when \(\mathrm{PEN}=1\), to generate and expect odd parity \(\mathrm{PO}=0\) generates even parity \\
\hline (None) & RAM Access B & 0.F.O-7 & Contains the RAM access code used in reading RAM locations in chip 0 (baud rate device). \\
\hline (None) & RAM Access S & \(1 \cdot F \cdot 0-7\) & Contains the RAM access code used in reading RAM locations in chip 1 (sample rate device). \\
\hline (None) & RAM Data XBL & 0:2:0-7 & Least significant byte of 16 -bit word X used in readıng RAM locations in chip 0 . \\
\hline (None) & RAM Data XBM & 0:3:0-7 & Most significant byte of 16-bit word X used in reading RAM locations in chip 0 . \\
\hline (None) & RAM Data XSL & 1:2:0-7 & Least significant byte of 16-bit word \(X\) used in readıng RAM locations in chip 1. \\
\hline (None) & RAM Data XSM & 1:3:0-7 & Most significant byte of 16 -bit word \(X\) used in reading RAM locations in chip 1. \\
\hline (None) & RAM Data YBL & 0:4:0-7 & Least significant byte of 16-bit word \(Y\) used in reading RAM locatıons in chip 0. \\
\hline (None) & RAM Data YBM & 0:5:0-7 & Most signıficant byte of 16-bit word Y used in reading RAM locations in chip 0. \\
\hline (None) & RAM Data YSL & 1:4.0-7 & Least significant byte of 16-bit word \(Y\) used in reading RAM locations in chip 1. \\
\hline (None) & RAM Data YSM & 1:5:0-7 & Most significant byte of 16-bit word \(Y\) used in reading RAM locations in chip 1. \\
\hline RDL & Remote Digital Loopback & \((0,1)\) : A : 6 & When control bit RDL goes to a one, it causes the modem to initiate a request for the remote modem to go into digital loopback. \\
\hline RDR & Receiver Data Register & 0:0:0-7 & RDR is used to read received data. RDR is a read only register. Reading this register causes the receives interrupt to be cleared. \\
\hline RI & Rıng Indicator & \(1 \cdot 8 \cdot 4\) & When status bit RI is a one, it indicates that a ringing signal is being detected. \\
\hline \multirow[t]{3}{*}{RLSD} & \multirow[t]{3}{*}{Received Line Signal Detector} & \multirow[t]{3}{*}{0.80} & \begin{tabular}{l}
When status bit RLSD is a one, it indicates that the carrier has successfully been received. RLSD will not respond to the \(550,1800,2100\), or 2225 Hz tones. \\
र̄LS̄̄ response umes are given delow.
\end{tabular} \\
\hline & & & \begin{tabular}{ccc} 
RLSD Transitions \({ }^{1}\) & Constant Carrier & Controlled Carrier \\
Off to On & 40 to 65 ms & 40 to 65 ms \\
On to Off & 40 to 65 ms & 40 to 65 ms
\end{tabular} \\
\hline & & & \begin{tabular}{l}
Note: \\
1. After handshake has occurred.
\end{tabular} \\
\hline
\end{tabular}

R1212 Interface Memory Definitions (Continued)


R1212 Interface Memory Definitions (Continued)
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & Description \\
\hline TDRE & Transmitter Data Register Empty & 1:E:0 & When on, TDRE indicates that the transmitter data register is empty and can be loaded with new data whether it is dial digits or data to be transmitted In synchronous operation the user must load the transmitter data register within 8 bit tımes after TDRE turns on to maıntain synchronization. After the register is loaded, TDRE goes off. \\
\hline 3 DB & 3 dB Loss to Receive Signal & 1:B:2 & When control of bit 3 DB is a one, it attenuates the received signal 3 dB . This is only used if the R1212M/U will see 0 dBm or greater line signal at the receiver input. Insertion of the 3 dB loss will then prevent saturation. This bit is not needed with the R1212DC/U. \\
\hline TM & Test Mode & 0.81 & When status bit TM is a one, it indicates that the modem has completed the handshake and is in one of the following test modes: AL, RDL, or DL. \\
\hline 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 of the TONE bit. TONE is active only when CRQ in chip 0 is a one. \\
\hline \multirow[t]{6}{*}{TXCLK} & \multirow[t]{6}{*}{Transmıt Clock Select} & \multirow[t]{6}{*}{1:C: \((5,6)\)} & TXCLK allows the user to designate the origin of the transmitter data clock, as shown below: \\
\hline & & & Transmit Clock Configuration Word \\
\hline & & & Internal 00 \\
\hline & & & Not Used 0 \\
\hline & & & External 10 \\
\hline & & & Slave 1 \\
\hline \multirow[t]{10}{*}{\begin{tabular}{l}
TX \\
LEVEL
\end{tabular}} & \multirow[t]{10}{*}{Transmıt Level} & \multirow[t]{10}{*}{\(1: B:(5-7)\)} & \multirow[t]{2}{*}{\begin{tabular}{l}
TX LEVEL allows the user to change the R2424M transmitter output level, assuming the modem is transmitting into a 600 ohm load. \\
Transmit Level \\
( \(\pm 1.0 \mathrm{dBm}\) ) \\
Configuration Word
\end{tabular}} \\
\hline & & & \\
\hline & & & 0 dBm O 00 \\
\hline & & & -2 dBm 0001 \\
\hline & & & -4 dBm - 010 \\
\hline & & & -6 dBm - 011 \\
\hline & & & -8 dBm \(\quad 100\) \\
\hline & & & -10 dBm - 1001 \\
\hline & & & -12 dBm 110 \\
\hline & & & \(-14 \mathrm{dBm} \quad 1 \begin{array}{lll}1 & 1\end{array}\) \\
\hline
\end{tabular}

\section*{POWER-ON INITIALIZATION}

When power is applied to the R1212/U, a period of 50 to 300 ms is required for power supply settling. The power-on-reset signal (POR) remains low during this period. Approximately 10 ms after the low to high transition of POR, the modem is ready to be configured, and RTS may be activated. If the 5 Vdc power supply drops below 3.5 Vdc for more than 30 msec , the POR cycle is repeated.

At POR time the modem automatically defaults to Bell 212A 1200 bps, answer state using serial start-stop data 10 bits per characier, consiant carrier, diai line.

POR can be connected to a user supplied power-on-reset signal in a wire or configuration. A low active pulse of \(3 \mu \mathrm{sec}\) or more applied to the POR pin causes the modem to reset. The modem is ready to be configured 10 msec after the low active pulse is removed from POR.

\section*{PERFORMANCE}

Whether functioning as a V.22, or Bell 212A type modem, and regardless of simulated line condition or introduced line impairment, the R1212/U provides unexcelled high performance to the user.

\section*{BIT ERROR RATES}

The Bit Error Rate (BER) performance of the R1212/U 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 .


\section*{BER Performance Test Set-up}

\section*{GENERAL SPECIFICATIONS}
\begin{tabular}{|c|c|c|}
\hline Power \\
\hline Voltage & Tolerance & Current (Max) \\
\hline+5 Vdc & \(\pm 5 \%\) & \(<500 \mathrm{~mA}\) \\
+12 Vdc & \(\pm 5 \%\) & \(<10 \mathrm{~mA}\) \\
-12 Vdc & \(\pm 5 \%\) & \(<50 \mathrm{~mA}\) \\
\hline Note: All voltages must have ripple \(\leq 0.1\) volts peak-to-peak. \\
\hline
\end{tabular}

Environmental
\begin{tabular}{|l|l|}
\hline Parameter & \multicolumn{1}{|c|}{ Specification } \\
\hline \begin{tabular}{l} 
Temperature \\
Operating- \\
Storage-
\end{tabular} & \begin{tabular}{l}
\(0^{\circ} \mathrm{C}\) to \(+60^{\circ} \mathrm{C}\left(32\right.\) to \(\left.140^{\circ} \mathrm{F}\right)\) \\
\(-40^{\circ} \mathrm{C}\) to \(+80^{\circ} \mathrm{C}\left(-40\right.\) to \(\left.1766^{\circ} \mathrm{F}\right)\)
\end{tabular} \\
\hline Relative Humidity & \begin{tabular}{l} 
Up to \(90 \%\) noncondensing, or a wet \\
bulb temperature up to \(35^{\circ} \mathrm{C}\), \\
whichever is less.
\end{tabular} \\
\hline Altitude & -200 to \(+10,000\) feet \\
\hline *PCB's are stored in heat sealed antistatic bags and shipping \\
\begin{tabular}{l} 
containers.
\end{tabular} \\
\hline
\end{tabular}

Mechanical
\begin{tabular}{|l|l|}
\hline Board Structure & \begin{tabular}{l} 
Single PC board with right angle \\
male DIN connector.
\end{tabular} \\
\hline Mating Connector & \begin{tabular}{l} 
Female 3 row 64 pin Euroconnector \\
(DiN) with rows A and C populated. \\
\\
\\
Recommended mating connector: \\
Winchester 96S-6043-0531-1 or \\
equivalent.
\end{tabular} \\
\hline PCB Dimensions & \\
R1212DC/U Version & Width \(3.94 \mathrm{in}.(100 \mathrm{~mm}) \times\) Length \\
& \(4.725 \mathrm{in} .(120 \mathrm{~mm}) \times\) Height \\
& \(0.75 \mathrm{in} .(19 \mathrm{~mm})\) \\
R1212M/U Version & Width \(3.94 \mathrm{in}.(100 \mathrm{~mm}) \times\) Length \\
& \(3.23 \mathrm{in} .(82 \mathrm{~mm}) \times\) Height \\
& 0.40 in. \((10 \mathrm{~mm})\) \\
\hline Weight & Less than \(0.45 \mathrm{lbs} .(0.20 \mathrm{~kg})\). \\
\hline Lead Extrusion & \(0.100 \mathrm{in} .(2.54 \mathrm{~mm}) \mathrm{max}\). \\
\hline
\end{tabular}


R1212/U Printed Circuit Board Dimensions

\section*{INSTALLATION}

\section*{IMPORTANT NOTICE TO USER}

The R1212DC/U 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.

\section*{R2424 \\ 2400 BPS FULL-DUPLEX MODEM}

\section*{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.

\section*{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 bps
-Character length 8, 9, 10, or 11 bits
- DTE Interface
-Functionally: Microprocessor Bus (Configuration/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


\section*{TECHNICAL SPECIFICATIONS}

\section*{TRANSMITTER CARRIER AND SIGNALING FREQUENCIES}

Transmitter Carrier and Signaling Frequencies Specifications
\begin{tabular}{|l|c|}
\hline \multicolumn{1}{|c|}{ Frequency } & \begin{tabular}{c} 
Specification \\
(Hz \(\pm \mathbf{0 . 0 1 \% )}\)
\end{tabular} \\
\hline V.22 bis low channel, Origınate Mode & 1200 \\
V. 22 low channel, Originate Mode & 1200 \\
V. 22 high bis channel, Answer Mode & 2400 \\
V.22 high channel, Answer Mode & 2400 \\
Bell 212A hıgh 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 \\
\hline
\end{tabular}

\section*{TONE GENERATION}

The specifications for tone generation are as follows:
1. Answer Backtones: The R2424 generates 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 is 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 is \(6 \pm 1 \mathrm{~dB}\) below the level of the data power in the main channel. The total power transmitted to the line is the same whether or not a guard tone is enabled. If a 553.846 Hz guard is used, its transmitted power is \(3 \pm 1 \mathrm{~dB}\) below the level of the main channel power, and again the overall power transmitted to the line will 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 generates dual tone multifrequency 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 the dial digit register with the appropriate digit as shown in the following table:

Dial Digits/Tone Pairs
\begin{tabular}{|l|l|l|l|c|cc|}
\hline \multicolumn{4}{|c|}{ BCD } & \begin{tabular}{c} 
Dial \\
Digits
\end{tabular} & \multicolumn{2}{|c|}{ Tone Pairs } \\
\hline 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 \\
\hline
\end{tabular}

\section*{TONE DETECTION}

The R2424 detects tones in the \(340 \pm 5 \mathrm{~Hz}\) to \(640 \pm 5 \mathrm{~Hz}\) band.
Detection Level: 0 to -45 dBm
Response Time: \(17 \pm 2 \mathrm{~ms}\)

\section*{SIGNALING AND DATA RATES}

The signaling and data rates for the R2424 are defined in the table below:

Signaling and Data Rates
\begin{tabular}{|c|c|c|}
\hline Operating Mode & Signaling Rate (Baud) & Data Rate \\
\hline V. 22 bis: & \[
600
\] & Synchronous/Asynchronous 2400 bps \(\pm 0.01 \%\) \\
\hline V. 22 bis: & 600 & Synchronous/Asynchronous \(1200 \mathrm{bps} \pm 0.01 \%\) \\
\hline \begin{tabular}{l}
V.22: \\
(Alternative A) Mode i \\
Mode iii \\
(Alternative B) \\
Mode i \\
Mode iii \\
Mode ii \\
Mode iv
\end{tabular} & \begin{tabular}{l}
600 \\
600 \\
600 \\
600
\end{tabular} & \begin{tabular}{l}
1200 bps \(\pm 0.01 \%\) Synchronous 600 bps \(\pm 0.01 \%\) Synchronous \\
1200 bps \(\pm 0.01 \%\) Synchronous 600 bps \(\pm 0.01 \%\) Synchronous \\
1200 bps Asynchronous \\
8, 9, 10, or 11 Bits Per Character \\
600 bps Asynchronous \\
8, 9, 10, or 11 Bits Per Character
\end{tabular} \\
\hline Bell 212A: & \[
\begin{gathered}
600 \\
0 \text { to } 300
\end{gathered}
\] & \begin{tabular}{l}
\[
1200 \mathrm{bps} \pm 0.01 \%
\] \\
Synchronous/Asynchronous 0 to 300 bps Asynchronous
\end{tabular} \\
\hline
\end{tabular}

\section*{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.

\section*{EQUALIZERS}

The R2424 provides equalization functions that improve performance when operating over low quality 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.

\section*{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 900 to 1500 Hz (low channel) and 2100 to 2700 Hz (high channel).

\section*{SCRAMBLER/DESCRAMBLER}

The R2424 incorporates a self-synchronizing scrambler/ descrambler. In accordance with the CCITT V. 22 bis, V. 22 and the Bell 212A recommendations.

\section*{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.

\section*{RECEIVE LEVEL}

The receiver circuit of the R2424 satisfies all specified performance requirements for the received line signals from 0 dBm to -45 dBm . The received line signal is measured at the receiver analog input RXA.

\section*{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 .035 \%\) (relative) frequency error in the associated transmit timing source.

\section*{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.

\section*{PERMISSIVE/PROGRAMMABLE CONFIGURATIONS}

The R2424M transmit level is +6 dBm to allow a DAA to be used. The DAA then determines the permissive or programmable configuration.

The R2424DC transmit level is strapped in the permissive mode so that the maximum output level is \(-10 \mathrm{dBm} \pm 1.0 \mathrm{dBm}\).

\section*{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.

\section*{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.

\section*{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.

\section*{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 telephone company 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. (Note: All time measurements without a tolerance have a \(\pm 0.5 \mathrm{~ms}\) tolerance.)

\section*{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.

\section*{AUTOMATIC RECONFIGURATION}

The R2424 is capable of automatically configuring itself to the compatibility of a remote modem. The R2424 can be in either the answer or originate mode for this to occur. The compatibilities that the R2424 are limited to adapt to are V. 22 bis, V. 22 A/B ( 1200 bps ), Bell 212, and Bell 103. If the R2424 is to originate in a specific configuration, the MODE bits must be set.

\section*{RECEIVE/TRANSMIT CIRCUITS}

The receiver and transmitter circuits are defined in the follow-
ing block diagrams:


R2424 Receiver/Equalizer Block Diagram


R2424 Transmitter Block Diagram

\section*{MODES OF OPERATION}

The R2424 is capable of being operated in either a serial or a parallel mode of operation.

\section*{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 Functional Interconnect Diagram) illustrates this capability.

\section*{PARALLEL MODE}

The R2424 has the capability of modem control via the microprocessor bus. Data transfer is maintained over the serial V. 24 channel.

\section*{MODE SELECTION}

Selection of either the serial ( \(\overline{\mathrm{DTR}}, \overline{\mathrm{RTS}}, \overline{\mathrm{TLK}}, \overline{\mathrm{ORG}}\) ) or parailel (DTR, RTS, DATA, ORG) control is by means of the BUS bits ([0,1]:D:7). To enable the parallel control, the BUS bits must be set to a one. The modem automatically defaults to the serial mode at power-on. In either mode, the R2424 is configured by the host processor via the microprocessor bus.

\section*{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.

\section*{HARDWARE CIRCUITS}

Signal names and descriptions of the hardware circuits, including the microprocessor interface, are listed in the R2424 Hardware Circuits table. In the table, the column titled 'Type' refers to designations found in the Hardware Circuit Characteristics. 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.

R2424 Hardware Circuits
\begin{tabular}{|c|c|c|c|}
\hline Name & Type & Pin No. & Description \\
\hline \multicolumn{4}{|l|}{A. OVERHEAD} \\
\hline Ground (A) & AGND & 31C, 32C & Analog Ground Return \\
\hline Ground (D) & DGND & 3C, 8C, 5A, 10A & Digital Ground Return \\
\hline +5 volts & PWR & \[
\begin{aligned}
& 19 \mathrm{C}, 23 \mathrm{C}, \\
& 26 \mathrm{C}, 30 \mathrm{C}
\end{aligned}
\] & + 5 volt supply \\
\hline + 12 volts & PWR & 15A & + 12 volt supply \\
\hline \(\frac{-12}{P O R}\) volts & PWR & 12 A & - 12 volt supply \\
\hline POR & I/OB & 13C & Power-On-Reset \\
\hline
\end{tabular}


R2424 Functional Interconnect Diagram
\begin{tabular}{|c|c|c|c|}
\hline & 424 & Cir & (Continued) \\
\hline Name & Type & Pin No. & Description \\
\hline \multicolumn{4}{|l|}{B. MICROPROCESSOR INTERFACE:} \\
\hline D7 & I/OA & 1 C 7 & \\
\hline D6 & I/OA & 1A & \\
\hline D5 & I/OA & 2 C & \\
\hline D4 & I/OA & & Data Bus (8-Bits) \\
\hline D3 & I/OA & 3A & \\
\hline D2 & I/OA & 4 C & \\
\hline D1 & I/OA & 4 A & \\
\hline DO & I/OA & 5 C & \\
\hline RS3 & IA & 6 C 7 & \\
\hline RS2 & IA & 6 A & Regıster Select (4-Bits) \\
\hline RS1 & IA & 7 C , & \\
\hline RSO & IA & 7A & \\
\hline CSO & IA & 10 C & Chip Select Receiver Baud Rate Device \\
\hline \(\overline{\text { CS1 }}\) & IA & 9 C & Chip Select Transmitter Sample Rate Device \\
\hline READ & IA & 12 C & Read Enable \\
\hline WRITE & IA & 11A & Write Enable \\
\hline \(\overline{\mathrm{IRQ}}\) & OB & 11 C & Interrupt Request \\
\hline \multicolumn{4}{|l|}{C. V. 24 INTERFACE} \\
\hline XTCLK & IB & 22A & External Transmit Clock \\
\hline TDCLK & OC & 23A & Transmit Data Clock \\
\hline RDCLK & OC & 21A & Receive Data Clock \\
\hline RTS & IB & 25A & Request-to-Send \\
\hline CTS & OC & 25C & Clear-to-Send \\
\hline TXD & IB & 24 C & Transmit Data \\
\hline RXD & OC & 22 C & Receive Data \\
\hline \(\overline{\text { RLSD }}\) & OC & 24A & Received Line Signal Detector \\
\hline \(\overline{\text { DTR }}\) & IB & 21 C & Data Terminal Ready \\
\hline \(\overline{\text { DSR }}\) & OC & 20A & Data Set Ready \\
\hline \(\overline{\mathrm{RI}}\) & OC & 18A & Ring Indicator \\
\hline \multicolumn{4}{|l|}{D. ANALOG SIGNALS (R2424M ONLY):} \\
\hline RXA & IB & 32A & Receive Analog Input \\
\hline TXA & OC & 31A & Transmıt Analog Output \\
\hline \multicolumn{4}{|l|}{E SIGNALS TO DAA (R2424M ONLY):} \\
\hline \(\overline{\mathrm{RD}}\) & IB & 27A & Ring Detect \\
\hline RCCT & OC & 28A & Request Coupler Cut Through \\
\hline \(\overline{\text { CCT }}\) & IB & 29 C & Coupler Cut Through \\
\hline OH & OC & 29A & Off-Hook Relay Control \\
\hline \multicolumn{4}{|l|}{F. ANCILLARY CIRCUITS} \\
\hline TBCLK & OC & 27 C & Transmit Baud Clock \\
\hline RBCLK & OC & 26A & Receive Baud Clock \\
\hline TLK & IC & 28 C & Talk (TLK = Data) \\
\hline \(\overline{\text { ORG }}\) & IB & 16C & \begin{tabular}{l}
Originate \\
(ORG = Answer)
\end{tabular} \\
\hline
\end{tabular}

MICROPROCESSOR TIMING


Microprocessor Interface Timing Diagram

Critical Timing Requirements
\begin{tabular}{|l|c|c|c|c|}
\hline \multicolumn{1}{|c|}{ Characteristic } & Symbol & Min & Max & Units \\
\hline\(\overline{\text { CSII, RSi setup time prıor }}\) & & & & \\
to Read or Write & TCS & 30 & - & NS \\
Data Access time after Read & TDA & - & 140 & NS \\
Data hold tıme after Read & TDH & 10 & 50 & NS \\
\(\overline{\text { CSI, RSI hold time after }}\) & & & & \\
Read or Write & TCH & 10 & - & NS \\
Write data setup tıme & TWDS & 75 & - & NS \\
Write data hold time & TWDH & 10 & - & NS \\
Write strobe pulse width & TWR & 75 & - & NS \\
\hline
\end{tabular}

\section*{HARDWARE CIRCUIT CHARACTERISTICS}

\section*{Digital Interface Characteristics}

Digital Interface Characteristics
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Symbol} & \multirow[b]{2}{*}{Parameter} & \multirow[b]{2}{*}{Units} & \multicolumn{8}{|c|}{Input/Output Type} \\
\hline & & & IA & IB & IC & OA & OB & OC & I/O A & I/O B \\
\hline VIN & Input Voltage, High & V & 2.0 min . & 2.0 min. & 2.0 mın & & & & 2.0 min . & \[
\begin{aligned}
& 5.25 \text { max. } \\
& 2.0 \mathrm{~min} .
\end{aligned}
\] \\
\hline \(\mathrm{V}_{\text {IL }}\) & Input Voltage, Low & V & 0.8 max. & 0.8 max. & 0.8 max. & & & & 0.8 max. & 0.8 max. \\
\hline \(\mathrm{V}_{\mathrm{OH}}\) & Output Voltage, High & V & & & & 2.4 min. \({ }^{1}\) & & & 2.4 min. 1 & 2.4 min. \({ }^{3}\) \\
\hline \(\mathrm{V}_{\mathrm{OL}}\) & Output Voltage, Low & V & & & & 0.4 max. \({ }^{2}\) & 0.4 max. \({ }^{2}\) & 0.4 max. \({ }^{2}\) & 0.4 max. \({ }^{2}\) & 0.4 max. \(^{2}\) \\
\hline \(\mathrm{I}_{\mathrm{N}}\) & Input Current, Leakage & \(\mu \mathrm{A}\) & \(\pm 2.5\) max. & & & & & & \(\pm 2.5\) max. \({ }^{4}\) & \\
\hline \(\mathrm{IOH}^{\text {I }}\) & Output Current, High & mA & & & & \[
-0.1 \text { max. }
\] & & & & \\
\hline \(\mathrm{IOL}^{\text {l }}\) & Output Current, Low & mA & & & & 1.6 max. & 1.6 max. & 1.6 max. & & \\
\hline \(l_{L}\) & Output Current, Leakage & \(\mu \mathrm{A}\) & & & & & \(\pm 10\) max. & & & \\
\hline \(I_{\text {PU }}\) & Pull-up Current & \(\mu \mathrm{A}\) & & -240 max. & - 240 max. & & & -240 max. & & - 260 max. \\
\hline & (Short Circuit) & & & - 10 min . & - 10 min . & & & -10 min. & & - 100 min . \\
\hline \(\mathrm{C}_{\mathrm{L}}\) & Capacitive Load & pF & 5 & 5 & 20 & & & & 10 & 40 \\
\hline \(\mathrm{C}_{\text {D }}\) & Capacitive Drive & pF & & & & 100 & 100 & 100 & 100 & 100 \\
\hline & Circuit Type & & TTL & TTL w/Pull-up & TTL w/Pull-up & TTL & Open-Drain & Open Dran w/Pull-up & 3 State Transceiver & Open-Drain w/Pull-up \\
\hline
\end{tabular}

\section*{Notes}
1. 1 load \(=-100 \mu \mathrm{~A}\)
2. 1 load \(=1.6 \mathrm{~mA}\)
3. 1 load \(=-40 \mu \mathrm{~A}\)
4. \(\mathrm{V}_{\mathrm{IN}}=0.4\) to \(2.4 \mathrm{Vdc}, \mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{Vdc}\)

\section*{Analog Interface Characteristics}

TXA-The (Type OC) transmitter output is a low impedance operational amplifier output in series with a 604 ohm resistor. In order to have a 0 dBm output, an external 600 ohm resistor to ground is required.

RXA-The (Type IB) receiver input impedance is 63.4 K ohms \(\pm 5\) percent.

\section*{Transmission Line Interface Characteristics}

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 two RJ11 jacks. The pin designations are shown in the table below:

R2424DC Network Interface
\begin{tabular}{|c|c|c|l|}
\hline Connection Type & Telco & Minemonic & \multicolumn{1}{|c|}{ Function } \\
\hline VSOC & 1 & & \\
RJ11 & 2 & & \\
Jack & 4 & R & \begin{tabular}{l} 
Ring-one side of \\
telepone line
\end{tabular} \\
& 4 & T & \begin{tabular}{l} 
Tip-one side of \\
telephone line
\end{tabular} \\
& 5 & & \\
\hline
\end{tabular}

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{\mathrm{RI}}\) 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
\begin{tabular}{|c|c|}
\hline RI Transition & Response Time \\
\hline Off-to-On & \(170 \pm 50 \mathrm{~ms}\) \\
On-to-Off & \(110 \pm 50 \mathrm{~ms}\) \\
\hline
\end{tabular}

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-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{\mathbf{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 signalling.
CCT-An on (low) signal to the \(\overline{C C T}\) lead indicates to the R2424M that the data transmission path through the DAA is connected.

\section*{AUDIO INTERFACE INPUT IMPEDANCE CHARACTERISTICS}

Audio Interface Input Impedance Characteristics
\begin{tabular}{|c|l|}
\hline On/Off Hook & \multicolumn{1}{c|}{ Measurement } \\
\hline On-Hook (DC) & \begin{tabular}{l} 
The DC resistance between Tip and \\
Ring, and between either Tip or Ring \\
and signal ground is greater than \\
10 megohms for DC voltages up to 100 volts.
\end{tabular} \\
\hline On-Hook (AC) & \begin{tabular}{l} 
The on-hook AC ımpedance measured \\
between Tıp and Ring is less than \\
\(40 K\) ohms (153 Hz minımum).
\end{tabular} \\
\hline Off-Hook (DC) & Less than 200 ohms. \\
\hline Off-Hook (AC) & \begin{tabular}{l}
600 ohms nominal when measured \\
between Tip and Rıng.
\end{tabular} \\
\hline
\end{tabular}

\section*{SOFTWARE CIRCUITS}

The R2424 comprises two signal processor chips. Each of these chips contains 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 date into these registers. The registers are referred to as interface memory. Registers in chip 0 update at the modem baud rate ( 600 bps ) (except RAM access and RAM Data Update where operation is at sample rate). Registers in chip 1 update at the sample rate ( 7200 bps ).

When information in these registers is being discussed, the format \(Y: Z: Q\) is used. The chip is specified by \(Y(0\) or 1\()\), the register by \(Z(0-F)\), and the bit by \(Q(0-7,0=L S B)\).

\section*{STATUS/CONTROL BITS}

The operation of the R2424 is affected by a number of software control inputs. These inputs are written into registers within the interface memory via the host microprocessor bus. 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 interface memory via the host microprocessor bus. All status and controi bits are defined in the interiace Memory table. Bits designated by an ' \(R\) ' are reserved for modem use only and must not be changed by the host.

\section*{RAM Data Access}

The R2424 provides the user with access to much of the data stored in the modem's memories. This data is useful for performing certain diagnostic functions.

Two RAM access registers are provided in the interface memory to allow user access to various RAM locations within chip 0 and chip 1. The access code stored in 0:F selects the source of data for the RAM data registers in chip 0 ( \(0: 5\) through \(0: 2\) ). Similarly, the access code stored in 1:F selects the source of data for registers \(1: 5\) through 1:2. Reading is performed by first storing the desired access code in register 0:F (or 1:F). The data may then be read from 0:5 through 0:2 (or 1:5 through 1:2).

\section*{RAM Access Codes}

The RAM access codes defined in the following table allow the host processor to read diagnostic information within the modem.

RAM Access Codes (Chip 0)
\begin{tabular}{|l|c|c|}
\hline \multicolumn{1}{|c|}{ Function } & \begin{tabular}{c} 
Access \\
Code
\end{tabular} & \begin{tabular}{c} 
Register \\
No.
\end{tabular} \\
\hline Self Test Error Counter & 00 & 2,3 \\
Equalizer Tap Coefficients & \(01-0 \mathrm{D}\) & \(2,3,4,5\) \\
Phase Error & 10 & 2,3 \\
Rotated Equalızer Output & 11 & \(2,3,4,5\) \\
\(\quad\) (Received Poınt Eye Pattern) & 12 & 4,5 \\
Rotated Angle & 40 & \(2,3,4,5\) \\
Low Pass Filter Output & \(41-4 \mathrm{D}\) & \(2,3,4,5\) \\
Input Signal to Equalizer Tap Coefficıents & 51 & \(2,3,4,5\) \\
Decision Points (Ideal Eye Pattern) & 52 & \(2,3,4,5\) \\
Rotated Error & 53 & \(2,3,4,5\) \\
Equalizer Output & 56 & \(2,3,4,5\) \\
Demodulator Output &
\end{tabular}

\section*{Auto Dial Sequence}

The following flow chart defines the auto dial sequence via the microprocessor interface memory.


\section*{Auto Dial Sequence Flow Diagram}

Note: The modem timing for the auto dialer accounts for interdigit delay for pulses and tones.

The timing for the pulses and tones are as follows:
\begin{tabular}{cc} 
Pulses - Relay open 64 ms & Tones - Tone duration \\
Relay closed 36 ms & 71 ms \\
Interdigit delay & Interdigit delay \\
750 ms & 71 ms
\end{tabular}

R2424 Receiver Interface Memory Chip 0 ( \(\overline{\text { CSO }}\) )


> Output Level \[ 1.5 \pm 1 \mathrm{dBm} \]

R2424 Transmitter Interface Memory Chip 1 (CS1)
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline - & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline F & \multicolumn{8}{|c|}{RAM Access S} \\
\hline E & IRQ & ENSI & NEWS & R & NEWC & DDEI & R & DDRE \\
\hline D & BUS & CRQ & DATA & AAE & DTR & X & X & SSD \\
\hline C & DSRA & TXC & CLK & & HAR & X & X & X \\
\hline B & \multicolumn{3}{|c|}{TX LEVEL} & GTE & GTS & 3DB & DTMF & AL \\
\hline A & ERDL & RDL & DL & ST & \multicolumn{4}{|c|}{MODE} \\
\hline 9 & BRK & RTRN & ORG & LL & RTS & CC & X & X \\
\hline 8 & DLO & CTS & DSR & RI & X & X & X & X \\
\hline 7 & R & R & R & R & R & R & R & R \\
\hline 6 & R & R & R & R & R & R & R & R \\
\hline 5 & \multicolumn{8}{|c|}{RAM Data YSM} \\
\hline 4 & \multicolumn{8}{|c|}{RAM Data YSL} \\
\hline 3 & \multicolumn{8}{|c|}{RAM Data XSM} \\
\hline 2 & \multicolumn{8}{|c|}{RAM Data XSL} \\
\hline 1 & R & R & R & R & R & R & R & R \\
\hline 0 & \multicolumn{8}{|c|}{Dial Digit Register} \\
\hline Register & 7 & 6 & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline \multicolumn{9}{|c|}{Note} \\
\hline
\end{tabular}

R2424 Interface Memory Definitions
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & Description \\
\hline AAE & Auto Answer Enable & 1:D:4 & When control bit AAE goes to a one, the modem will automatically answer when a ringing signal is present on the line. \\
\hline AL & Analog Loopback & (0,1):B:0 & When control bit AL is a one, the modem is placed in (V. 54 Loop 3) local analog loopback. 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 attenuated \(14 \pm 1 \mathrm{dBm}\). \\
\hline BRK & Break & 1:9:7 & When control bit BRK goes to a one, the modem transmits \(2 \mathrm{M}+3\) bits of start polarity. ( \(M\) is equal to the number of bits per character in the selected format.) BRK will reset to zero after the sequence is sent. \\
\hline Bus & Bus Select & (0,1):D:7 & When control bit BUS goes to a one, the modem is placed in the parallel control mode, and when zero the modem is configured for the serial control mode. BUS can be in either state to configure the modem. \\
\hline
\end{tabular}

\section*{R2424 Interface Memory Definitions (Continued)}
\begin{tabular}{|c|c|c|c|}
\hline Mnemonic & Name & Memory Location & Description \\
\hline cc & Controlled Carrier & 1:9:2 & When control bit CC goes to a one, the modem is placed in controlled carrier operation; and when zero, the modem is configured for constant carrier operation. \\
\hline CHAR & Character Length Select & \((0,1): C:(3,4)\) & These character length bits select either 8, 9, 10, or 11 bit characters, as shown below: \\
\hline & & & \begin{tabular}{cc} 
Configuration & Conflguration Word \\
8 bits & 0 \\
9 bits & 0 \\
10 bits & 1 \\
11 bits & 1 \\
1
\end{tabular} \\
\hline CRQ & Call Request & (0,1):D:6 & When control bit CRQ goes to a one, it places the transmitter in auto dial and the receiver in tone detect mode. The data placed in the dial digit register is then treated as digits to be dialed. After the last digit has been dialed, FF (HEX) should be loaded into the dial digit register to tell the modem to go to the data state. CRQ in the transmitter (chip 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 on-hook. CRQ in the receiver (chip 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. \\
\hline CTS & Clear-to-Send & 1:8:6 & \begin{tabular}{l}
When status bit CTS is a one, it indicates to the terminal equipment that the modem will transmit any data which are present at TXD. \\
CTS response times from an on or off condition of RTS are shown below:
\end{tabular} \\
\hline DATA & Talk/Data & 1:D:5 & When control bit DATA goes to a one, it places the modem in data state and when zero in the talk state. \\
\hline DDEI & Dial Digit Empty Interrupt & 1:E:2 & When control bit DDEI goes to a one, it causes an interrupt to occur when the dial digit register ( \(1: 0\) ) is empty (DDRE \(=1\) ). \\
\hline DDR & Dial Digit Register & 1:0:(0-7) & DDR is used to load the digits to be dialed. Example: If a 4 is to be dialed, a 04 (HEX) should be loaded. This action also causes the interrupt to be cleared. DDR is a write only register. \\
\hline DDRE & Dial Digit Register Empty & 1:E:0 & When status bit DDRE is a one, it indicates that the dial digit register is empty and can be loaded with a new digit to be dialed. After the register is loaded, DDRE goes to a zero. \\
\hline DL & Digital Loopback (Manual) & \((0,1): A: 5\) & When control bit \(\mathfrak{V L}\) is a one, the modem is manually placed in remote digital loopback. DL should be set during the data mode. DSR and CTS will be at zero. 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 reset to zero. The local modem will then return to the normal data mode with control reverting the DTEs, DTR. \\
\hline DLO & Data Line Occupied & 1:8:7 & When status bit DLO is a one, it indicates that the modem is in the auto dial state, l.e, CRQ is at a one and the modem is off-hook and ready to dial. \\
\hline DSR & Data Set Ready & 1:8:5 & When status bit DSR is a one, it indicates that the answerback tone has been detected, the modem handshake 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 at zero in all test states (except optionally for analog loopback) and when the channel is being used for voice communication (talk). \\
\hline
\end{tabular}

R2424 Interface Memory Definitions (Continued)
\begin{tabular}{|c|c|c|c|}
\hline Mnemonlc & Name & Memory Location & Description \\
\hline DSRA & Data Set Ready In Analog Loopback & 1:C:7 & When control bit DSRA goes to a one, It causes DSR to be set to a one during analog loopback. \\
\hline DTMF & Touch Tones/ Pulse Dialing & 1:B:1 & When control bit DTMF goes to a one, it tells the modem to auto dial using tones, and when zero the modem will dial using pulses. \\
\hline DTR & Data Terminal Ready & 1:D:3 & Control bit DTR must be a one, before the modem will enter the data state, either manually or automtically. DTR must also be at a one in order for the modem to automatically answer an incoming call. \\
\hline ENSI & Enable New Status Interrupt & \((0,1): E ; 6\) & When control bit ENSI goes to a one, it causes an interrupt to occur when the status bits in registers \((0:[8,9])\) and \((1: 8)\) are updated.
\[
(\text { NEWS }=1)
\] \\
\hline ERDL & Enable Response to Remote Digital Loopback & \((0,1): A: 7\) & When control bit ERDL goes to a one, it enables the modem to respond to another modem's remote digital loopback request, thus going into loopback. \\
\hline GTE & Guard Tone Enable & 1:B:4 & When control bit GTE goes to a one, it causes the specified guard tone to be transmitted (CCITT Configurations only). \\
\hline GTS & Guard Tone Select & 1:8:3 & When control bit GTS goes to zero, it selects the 1800 Hz tone and when a one it selects the 550 Hz tone. \\
\hline IRQ & Interrupt & \((0,1)\) :E:7 & When status bit IRQ is a one, it indicates that an interrupt has been generated. \\
\hline LCD & Loss of Carrier Disconnect & 0:D:2 & \begin{tabular}{l}
When control bit LCD goes to a one, the modem terminates a call when a loss of received carrier energy is detected after 400 msec . After the first 40 ms of loss of carrier, RLSD goes off. 360 ms later if no carrier is detected, CTS goes off. \\
LCD is not disabled in leased line operation.
\end{tabular} \\
\hline LL & Leased Line & 1:9:4 & When control bit LL goes to a one, it places the modem in leased line operation; and when zero, switched line operation. \\
\hline \multirow[t]{13}{*}{MODE} & \multirow[t]{13}{*}{Mode Select} & \multirow[t]{13}{*}{\((0,1): A:(0,3)\)} & These bits select the compatibility at which the modem is to operate, as shown below: \\
\hline & & & Configuration Configuration Word \\
\hline & & & Bell 212A 1200 Sync. 0 \\
\hline & & & Bell 212A 1200 Async. 000001 \\
\hline & & & \(\begin{array}{llllll}\text { Bell 212A } & 300 \text { Async. } & 0 & 1 & 0 & 0\end{array}\) \\
\hline & & & \(\begin{array}{llllll}\text { V.22A } & 1200 \text { Sync. } & 1 & 0 & 0 & 0\end{array}\) \\
\hline & & & \(\begin{array}{llllll}\text { V.22B } & 1200 \text { Async. } & 1 & 0 & 0 & 1\end{array}\) \\
\hline & & &  \\
\hline & & & V.22B 600 Async. 1 \\
\hline & & & \(\begin{array}{llllllllll}V .22 & \text { bis } & 2400 \text { Sync. } & 1 & 1 & 0 & 0\end{array}\) \\
\hline & & & \(\begin{array}{llllll}\text { V. } 22 \text { bis } 2400 \text { Async. } 1 & 1 & 1 & 0 & 1\end{array}\) \\
\hline & & & \(\begin{array}{llllllllll}\text { V. } 22 \text { bis } 1200 \text { Sync. } & 1 & 1 & 1 & 0\end{array}\) \\
\hline & & & \(\begin{array}{llllll}\text { V. } 22 \text { bis } 1200 \text { Async. } & 1 & 1 & 1 & 1\end{array}\) \\
\hline NEWC & New Configuration & \((0,1)\) :E:3 & When status bit NEWC is a one, it 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. \\
\hline NEWS & New Status & \((0,1)\) :E:5 & When status bit NEWS is a one, it tells the user that there has been a change of status in the status registers. The user must write a zero into NEWS to reset it. This action also causes the interrupt to be cleared. \\
\hline
\end{tabular}

R2424 Interface Memory Definitions (Continued)


R2424 Interface Memory Definitions (Continued)

\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{4}{|r|}{R2424 Interface Memory Definitions (Continued)} \\
\hline Mnemonic & Name & Memory Location & Description \\
\hline TXCLK & Transmit Clock Select & 1:C:(5,6) & TXCLK allows the user to designate the origin of the transmitter data clock, as shown below: \\
\hline TX LEVEL & Transmit Level & 1:B.(5-7) & TX LEVEL allows the User to change the R2424M transmitter output level, assuming the modem is transmitting into a 600 ohm load. \\
\hline
\end{tabular}

\section*{POWER-ON INITIALIZATION}

When power is applied to the R2424, a period of 50 to 300 ms is required for power supply settling. The power-on reset signal (POR) remains low during this period. Approximately 10 ms after the low to high transition of POR, the modem is ready to be configured, and RTS may be activated. If the 5 Vdc power supply drops below 3.5 Vdc for more than 30 msec , the POR cycle is repeated.

At POR time the modem automatically defaults to V. 22 bis 2400 bps, answer state using serial start-stop data, 10 bits per character, constant carrier, dial line.

POR can be connected to a user supplied power-on-reset signal in a wire or configuration. A low active pulse of \(3 \mu \mathrm{sec}\) or more applied to the POR pin causes the modem to reset. The modem
is ready to be configured 10 msec after the low active pulse is removed from POR.

\section*{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.

\section*{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 .


GENERAL SPECIFICATIONS
Power
\begin{tabular}{|c|c|c|}
\hline Voltage* & Tolerance & Current (Max) \\
\hline+5 Vdc & \(\pm 5 \%\) & \(<500 \mathrm{ma}\) \\
+12 Vdc & \(\pm 5 \%\) & \(<10 \mathrm{ma}\) \\
-12 Vdc & \(\pm 5 \%\) & \(<50 \mathrm{ma}\) \\
\hline \multicolumn{2}{|c|}{ All voltages must have ripple \(\leq 0.1\) volts peak-to-peak. } \\
\hline
\end{tabular}

Environmental
\begin{tabular}{|c|l|}
\hline Parameter & \multicolumn{1}{c|}{ Specification } \\
\hline \begin{tabular}{c} 
Temperature \\
Operating \\
Storage*
\end{tabular} & \begin{tabular}{l}
\(0^{\circ} \mathrm{C}\) to \(+60^{\circ} \mathrm{C}\left(32\right.\) to \(\left.140^{\circ} \mathrm{F}\right)\) \\
\(-40^{\circ} \mathrm{C}\) to \(+80^{\circ} \mathrm{C}\left(-40\right.\) to \(\left.176{ }^{\circ} \mathrm{F}\right)\)
\end{tabular} \\
\hline Relative Humidity & \begin{tabular}{l} 
Up to \(90 \%\) noncondensing, or a wet \\
bulb temperature up to \(35^{\circ} \mathrm{C}\), \\
whichever is less.
\end{tabular} \\
\hline Altitude & -200 to +10,000 feet \\
\hline \begin{tabular}{l} 
*PCB's are stored in heat sealed antistatic bags and shipping \\
containers.
\end{tabular} \\
\hline
\end{tabular}

R2424 Printed Circuit Board Dimensions

\section*{INSTALLATION}

\section*{IMPORTANT NOTICE TO USER}

The R2424DC 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.

\section*{R24DC 2400 BPS DIRECT CONNECT MODEM}

\section*{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.

\section*{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

\section*{FUNCTIONAL SPECIFICATIONS}


R24DC Functional Block Dlagram

Transmitter Carrier Frequency \(-1800 \mathrm{~Hz} \pm 0.01 \%\)
Echo Suppression and Answering Tone Frequencles \(2100 \mathrm{~Hz} \pm 0.01 \%\) or \(2025 \mathrm{~Hz} \pm 0.01 \%\).

Recelved 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 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
\begin{tabular}{|c|r|r|}
\hline \multicolumn{2}{|c|}{2400 BPS } \\
\hline \multirow{3}{*}{ DIBIT } & \multicolumn{2}{|c|}{ PHASE CHANGE } \\
\cline { 2 - 3 } & V.26A & V.26B/BeII 201 \\
\hline 00 & \(0^{\circ}\) & \(+45^{\circ}\) \\
01 & \(+90^{\circ}\) & \(+135^{\circ}\) \\
11 & \(+180^{\circ}\) & \(+225^{\circ}\) \\
10 & \(+270^{\circ}\) & \(+315^{\circ}\) \\
\hline
\end{tabular}
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 a


Reference Line Signal Dlagram (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.
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|c|}{1200 BPS} \\
\hline E!T & PHASE CHANGE \\
\hline 0 & \(+90^{\circ}\) \\
1 & \(+270^{\circ}\) \\
\hline
\end{tabular}

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.
\begin{tabular}{|c|c|c|c|c|}
\hline TYPE OF LINE SIONAL & SEGMENT 1 & SEGMENT 2 & TOTAL OF SECMENTS 1, 2 & \\
\hline TURN-ON SEQUENCE NUMBER & CONTINUOUS UNSCRAMBLED ONES & CONTINUOUS SCRAMBLED 1 ONES & NOMINAL TOTAL TURN ON SEQUENCE TIME \({ }^{2}\) & COMMENTS \\
\hline \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5 \\
& 6
\end{aligned}
\] & \[
\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}
\] & \begin{tabular}{l}
90 ms \\
90 ms \\
148.3 ms \\
148.3 ms \\
220 ms \\
220 ms
\end{tabular} & \begin{tabular}{l}
\(\mathrm{V} .26, \mathrm{~V} .26 \mathrm{bis}\) (scrambler inserted) \\
Bell 201C \\
(scrambler inserted) \\
V. 26 bis \\
(scrambler inserted)
\end{tabular} \\
\hline
\end{tabular}

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.
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{TURN-ON SEQUENCE NUMBER} & \multicolumn{2}{|l|}{CLEAR-TO-SEND RESPONSE TIMES \({ }^{1}\)} & \multirow[b]{2}{*}{COMMENTS} \\
\hline & OFF.TO-ON & ON-TO-OFF & \\
\hline 1 & 90 ms & 0 ms & V. 26 bls \\
\hline 2 & 90 ms & 0 ms & V. 26 bis w/scrambler \\
\hline 3 & 148.3 ms & 0 ms & Bell 201C \\
\hline 4 & 148.3 ms & 0 ms & Bell 201 C w/scrambler \\
\hline 5 & 220 ms & 0 ms & V .26 bis \\
\hline 6 & 220 ms & 0 ms & V. 26 bis w/scrambler \\
\hline \multicolumn{4}{|l|}{The tolerence on each Off-to-On and On-to-Off response time is \((+3.4,-0.1) \mathrm{ms}\).} \\
\hline
\end{tabular}

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 recelved 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
\begin{tabular}{|l|l|}
\hline \multicolumn{1}{|c|}{ Received Level } & \multicolumn{1}{c|}{ Carrier Detect } \\
\hline \begin{tabular}{l} 
Greater than -43 dBm \\
Less than -48 dBm
\end{tabular} & \begin{tabular}{l} 
On (Line signal present) \\
Off (Line signal not present)
\end{tabular} \\
\hline
\end{tabular}

Carrier Detect Response Time
\begin{tabular}{|c|c|}
\hline Carrier Detect Transition & Response Time \\
\hline Off-to-On & \(14 \pm 1 \mathrm{~ms}\) \\
On-to-Off & \(8 \pm 3 \mathrm{~ms}\) \\
\hline
\end{tabular}

Clamping - The following clamps are provided:
1. Received Data. The Recelved Data output is clamped to a mark when Carrier Detect is off. This action prevents disturbances on the line from getting through the receiver circult 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 optlon 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 recelver circult 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.

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

Recelve 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 answering 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
\begin{tabular}{|c|c|}
\hline \begin{tabular}{c} 
INPUT \\
SELECT 1 \\
(P1-34)
\end{tabular} & \begin{tabular}{c} 
ANSWERING TONE \\
FREQUENCY
\end{tabular} \\
\hline High & 2100 Hz \\
Low & 2025 Hz \\
\hline
\end{tabular}

Satellite Option and DSR Selection
\begin{tabular}{|c|c|c|}
\hline \begin{tabular}{c} 
Satellite \\
Option
\end{tabular} & \begin{tabular}{c} 
DSR (P1-30) \\
During Analog \\
Loopback
\end{tabular} & \begin{tabular}{c} 
AL-DSR Enable \\
(P1-12)
\end{tabular} \\
\hline Yes & \begin{tabular}{c} 
OFF (High) \\
No (Low) \\
Yes \\
No
\end{tabular} & \begin{tabular}{c} 
High \\
ON Low) \\
OFF (High)
\end{tabular}
\end{tabular} \begin{tabular}{c} 
Wired to Analog Loopback \\
Wired to Analog Loopback 1.
\end{tabular}

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.

\section*{Data Structure}
\begin{tabular}{|c|l|l|}
\hline \multicolumn{2}{|c|}{ INPUT } & \\
\hline \begin{tabular}{c} 
DATA \\
SIGNALLING \\
RATE \\
SELECTOR \\
(P1-16)
\end{tabular} & \multicolumn{2}{|c|}{\begin{tabular}{c} 
V.26 A/B \\
(P1-14)
\end{tabular}} \\
\hline Low & Low & \multirow{2}{*}{ DATA STRUCTURE } \\
Low & High & \begin{tabular}{l} 
2400 bps Alternate A \\
2400 bps V.26 Alternate B \\
(Bell 201C) \\
High
\end{tabular} \\
Low or High & 1200 bps \\
\hline
\end{tabular}

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.

\section*{Carrier Detect Squelch}
\begin{tabular}{|c|c|c|l|}
\hline \multicolumn{3}{|c|}{ INPUTS } & \\
\hline \begin{tabular}{c} 
ANALOG \\
LOOPBACK \\
(P1-33)
\end{tabular} & \begin{tabular}{c} 
SELECT 2 \\
(P1-35)
\end{tabular} & \begin{tabular}{c} 
REQUEST- \\
TOSEND \\
(P1-11)
\end{tabular} & \multirow{2}{*}{ SQUELCH STATUS \({ }^{1}\)} \\
\hline Low & Low or High & Low or High & No Squelch \\
High & Low or High & Low & Squelch \\
High & High & Low \(\rightarrow\) High & Extended Squelch \({ }^{2}\) \\
High & Low & Low \(\rightarrow\) High & No Extended Squelch \\
\hline
\end{tabular}
"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
\begin{tabular}{|c|c|c|c|c|c|}
\hline \multirow[b]{3}{*}{TURN-ON SEQUENCE} & \multicolumn{3}{|c|}{INPUTS} & \multicolumn{2}{|c|}{\multirow[t]{2}{*}{CLEAR-TOSEND RESPONSE TIME1 (ms)}} \\
\hline & \multirow[b]{2}{*}{\[
\begin{aligned}
& \text { SELECT } 1 \\
& \text { (P1-34) }
\end{aligned}
\]} & \multirow[t]{2}{*}{SCRAMBLER ENABLE (P1-15)} & \multirow[b]{2}{*}{\[
\begin{gathered}
\text { SELECT } 2 \\
\text { (P1-35) }
\end{gathered}
\]} & & \\
\hline & & & & OFF-TO-ON & ON-TO-OFF \\
\hline 1 & High & Low & Low & 90 & 0 \\
\hline 2 & High & High & Low & 90 & 0 \\
\hline 3 & Low & Low & Low or High & 148.3 & 0 \\
\hline 4 & Low & High & Low or High & 148.3 & 0 \\
\hline 5 & High & Low & High & 220 & 0 \\
\hline 6 & High & High & High & 220 & 0 \\
\hline
\end{tabular}

The tolerance on each Off-to-On and On-to-Off response is ( \(-3.4,-0.1 \mathrm{~ms}\) ).

\section*{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.


\section*{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.


\section*{Manual Originate Mode Sequence}

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.


\section*{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.


\section*{Automatic Answer Mode Sequence}

\section*{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
\begin{tabular}{|c|c|}
\hline Input Logic State & Allowed Input Voltage Levels \\
\hline Low & \begin{tabular}{l}
0.0 V to 0.8 V sinking \(<10 \mu \mathrm{~A}\) \\
\(+4.0 \mathrm{~V}(\mathrm{VSS}-1 \mathrm{~V})\) to +5.0 V (VSS) \\
sourcing \(<10 \mu \mathrm{~A}\)
\end{tabular} \\
\hline
\end{tabular} \begin{tabular}{l} 
The digital inputs are directly CMOS compatible. The \\
capacitive loading on each input is 25 pF (maximum).
\end{tabular}

Digital Output Characteristics
\begin{tabular}{|c|l|}
\hline Ouput Logic State & Allowed Output Voltage Levels \\
\hline \multicolumn{2}{|c|}{ Low } \\
High & \begin{tabular}{l}
0.0 V to 0.4 V sinking 0.36 mA \\
\\
\\
\\
sourcing \(100 \mu \mathrm{~A}\)
\end{tabular} \\
\hline \multicolumn{2}{|c|}{ The digital outputs are directly CMOS or low-power Schottky } \\
TTL compatible.
\end{tabular}

\section*{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:
\begin{tabular}{|c|c|}
\hline Output Logic State & Allowed Output Voltage Levels \\
\hline Low & 0.0 V to 0.4 V sinking 0.36 mA \\
High & 2.4 V to 5.0 V (VSS) sourcing \(100 \mu \mathrm{~A}\) \\
\hline
\end{tabular}

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
\begin{tabular}{|c|c|}
\hline Parameter & Specification \\
\hline On-Hook DC & DC resistance between Tip and Ring, and between either Tip or Ring and signal ground is greater than 10 megohms for DC voltages up to 100 volts. \\
\hline On-Hook AC & On-hook AC impedance measured between Tip and Ring is less than 40 K ohms ( 15.3 Hz minimum) \\
\hline Off-Hook DC & Less than \(\mathbf{2 0 0}\) ohms \\
\hline Off-Hock AC & 600 ohms nominal when measured between Tip and Ring \\
\hline Longitudinal Balance & Meets requirements of FCC Rules, Part 68 \\
\hline \multicolumn{2}{|l|}{FCC Registration Number AMQ9SQ-68813-DM-R Ringer Equivalence. 09B} \\
\hline
\end{tabular}

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.

\section*{Analog Interface Circuits}
\begin{tabular}{|c|c|c|}
\hline TERM & \begin{tabular}{l}
PIN \\
NUMBER
\end{tabular} & DESCRIPTION \\
\hline +12V & P1-40 & +12V Power Supply \\
\hline -12V & P1-38 & -12V Power Supply \\
\hline +5V & P1-1 & +5V Power Supply \\
\hline COMMON & \[
\begin{aligned}
& \text { P1-2, } \\
& \text { P1-4 }
\end{aligned}
\] & Ground (signal and power return) \\
\hline Receiver Analog & P1-32 & \begin{tabular}{l}
Low impedance output of R24DC receive filter. Gain from Tip and Ring to Receiver Analog is nominally 12.7 dB \\
TELEPHONE INTERFACE LEADS
\end{tabular} \\
\hline TIP & P2-9 & Telephone Line Leads \\
\hline RING & P2-10 & \\
\hline PR & P2-2 & Leads to external wall jack resistor \\
\hline PC & P2-4 & for programmable mode \\
\hline MI & P2-3 & Leads routed to contact on exclu- \\
\hline MIC & P2-1 & sion key of associated telephone set \\
\hline
\end{tabular}


Typical R24DC to OEM Interconnections for Half-Duplex Applications


\section*{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
\begin{tabular}{|l|l|l|}
\hline \begin{tabular}{c} 
Type/ \\
Manufacturer
\end{tabular} & P1 (DTE) Connector & \multicolumn{1}{|c|}{\begin{tabular}{c} 
P2 (Telephone Line) \\
Connector
\end{tabular}} \\
\hline Type: & \begin{tabular}{l}
40 pin \\
0.100 in. spacing \\
20 pins per side
\end{tabular} & \begin{tabular}{l}
10 pin \\
0.100 in. spacing \\
20 pins per side
\end{tabular} \\
\hline Winchester: & \(53-40-0\) & \(53-10-0\) \\
T\&B Ansley: & \(609-4015 \mathrm{M}\) \\
Spectra-Strip: & \(807-4005-001\) & \(609-1015 \mathrm{M}\) \\
& & \(807-1005-001\) \\
\hline
\end{tabular}

\section*{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\% p-p for an input signal-to-noise ratio of 12 dB .
Bit Error Rate - The following graph represents typical R24DC performance.


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 circult, a numerical value can be derived to indicate the quality of recelved data. This numerical value can be directly correlated to bit error rate performance. The required test circult 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 circult, 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 quallty under actual operation.

\section*{POWER REQUIREMENTS}
\begin{tabular}{|c|c|c|}
\hline Voltage & Ripple & \begin{tabular}{c} 
Maximum \\
Current
\end{tabular} \\
\hline+5 VDC \(\pm 5 \%\) & \(100 \mathrm{mV} p-p\) & 110 mA \\
+12 VDC \(\pm 5 \%\) & \(50 \mathrm{mV} p-\mathrm{p}\) & 70 mA \\
-12 VDC \(\pm 5 \%\) & \(50 \mathrm{mV} p-\mathrm{p}\) & 140 mA \\
\hline
\end{tabular}

\section*{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 \(\mathbf{3 , 0 4 9}\) meters)
Burn-In: 96 hours at \(70^{\circ} \mathrm{C}\)

\section*{MAXIMUM DIMENSIONS}

Width: 4.988 in . ( 12.669 cm )
Length: 7,900 in. ( 20.066 cm )
Height: \(0.500 \mathrm{in} .(1.270 \mathrm{~cm})\)

\section*{0 \\ Rockwell}

\section*{R24LL \\ 2400 BPS MODEM}

\section*{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.

\section*{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 Compatibility
- 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 \mathrm{Vdc}\)



\section*{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-ine 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.


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.
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|c|}{ Data Encoding } \\
\hline \multicolumn{2}{|c|}{1200 BPS } \\
\hline Blt & Phase Change \\
\hline 0 & \(+90^{\circ}\) \\
1 & \(+270^{\circ}\) \\
\hline
\end{tabular}

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 transmilter 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 assoclated 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.

Carrler Detect Threshoids
\begin{tabular}{|l|l|}
\hline Recelved Level & \multicolumn{1}{c|}{ Carrier Detect } \\
\hline \begin{tabular}{ll} 
Greater than -43 dBm \\
Less than -48 dBm
\end{tabular} & \begin{tabular}{l} 
On (line signal present) \\
Off (line signal not present)
\end{tabular} \\
\hline
\end{tabular}

Carrier Detect Response TIme
\begin{tabular}{|c|c|}
\hline Carrier Detect Tranaltion & Response Time \\
\hline Off-to-On & \(14 \pm 1 \mathrm{~ms}\) \\
On-to-Off & \(8 \pm 3 \mathrm{~ms}\) \\
\hline
\end{tabular}

Turn-On Sequences
\begin{tabular}{|c|c|c|c|c|}
\hline Type of Line SIgnal & Segment 1 & Segment 2 & Total of Segments 1, 2 & \multirow[b]{2}{*}{Comments} \\
\hline Turn-On Sequence Number & Continuous Unscrambled Ones & Continuous Scrambled \({ }^{1}\) Ones & Nominal Total Turn On Sequence Time \({ }^{2}\) & \\
\hline \[
\begin{array}{r}
1 \\
2 \\
3 \\
4 \\
4 \\
5 \\
6 \\
7 \\
8 \\
9 \\
10 \\
11 \\
12 \\
13
\end{array}
\] & \[
\begin{gathered}
0 \mathrm{~ms} \\
6.67 \mathrm{~ms} \\
8.33 \mathrm{~ms} \\
30 \mathrm{~ms} \\
8.33 \mathrm{~ms} \\
90 \mathrm{~ms} \\
8.33 \mathrm{~ms} \\
148.3 \mathrm{~ms} \\
8.33 \mathrm{~ms} \\
220 \mathrm{~ms} \\
8.33 \mathrm{~ms} \\
800 \mathrm{~ms} \\
8.33 \mathrm{~ms}
\end{gathered}
\] & \[
\begin{gathered}
0 \mathrm{~ms} \\
0 \mathrm{~ms} \\
0 \mathrm{~ms} \\
0 \mathrm{~ms} \\
21.67 \mathrm{~ms} \\
0 \mathrm{~ms} \\
81.67 \mathrm{~ms} \\
0 \mathrm{~ms} \\
140 \mathrm{~ms} \\
0 \mathrm{~ms} \\
211.7 \mathrm{~ms} \\
0 \mathrm{~ms} \\
791.7 \mathrm{~ms}
\end{gathered}
\] & \[
\begin{gathered}
0 \mathrm{~ms} \\
6.67 \mathrm{~ms} \\
8.33 \mathrm{~ms} \\
30 \mathrm{~ms} \\
30 \mathrm{~ms} \\
90 \mathrm{~ms} \\
90 \mathrm{~ms} \\
148.3 \mathrm{~ms} \\
148.3 \mathrm{~ms} \\
220 \mathrm{~ms} \\
220 \mathrm{~ms} \\
800 \mathrm{~ms} \\
800 \mathrm{~ms}
\end{gathered}
\] & \begin{tabular}{l}
V. 26 \\
(scrambler inserted) \\
V.26, V. 26 bis \\
(scrambler inserted) \\
(scrambler inserted) \\
V. 26 bis \\
(scrambler inserted) \\
V. 26 bis \\
(scrambler inserted)
\end{tabular} \\
\hline \multicolumn{5}{|c|}{Notes:} \\
\hline \multicolumn{5}{|l|}{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.} \\
\hline
\end{tabular}

Clear-To-Send Response Times
\begin{tabular}{|c|c|c|c|}
\hline \multirow[t]{2}{*}{\begin{tabular}{l}
Turn-On \\
Sequence Number
\end{tabular}} & \multicolumn{2}{|l|}{Clear-To-Send Response Times*} & \multirow[t]{2}{*}{Comments} \\
\hline & Off-to-On & On-to-Off & \\
\hline 1 & 0 ms & 0 ms & \\
\hline 2 & 6.67 ms & 0 ms & \begin{tabular}{l}
switched carrier \\
4-wire (BELL 201)
\end{tabular} \\
\hline 3 & 8.33 ms & 0 ms & switched carrier 4-wire \\
\hline 4 & 30 ms & 0 ms & CCITT 4-wire \\
\hline 5 & 30 ms & 0 ms & CCITT 4-wire with scrambler \\
\hline 6 & 90 ms & 0 ms & CCITT 2-wire \\
\hline 7 & 90 ms & 0 ms & CCITT 2-wire with scrambler \\
\hline 8 & 1433 ms & 0 ms & switched carrier 2-wire \\
\hline 9 & 143.3 ms & 0 ms & switched carrier 2-wire with scrambler \\
\hline 10 & 220 ms & 0 ms & CCITT 2-wire echo protection \\
\hline 11 & 220 ms & 0 ms & switched 2-wire echo protection with scrambler \\
\hline 12 & 800 ms & 0 ms & CCITT 2-wire auto call \\
\hline 13 & 800 ms & 0 ms & CCITT 2-wire auto call with scrambler \\
\hline \multicolumn{4}{|l|}{*The tolerance on each Off-to-On and On-to-Off response time is \((+.9,-.1) \mathrm{ms}\).} \\
\hline
\end{tabular}

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 previous message for some time after it has ended-this may interfere with resynchronization on recelpt 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.

\section*{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 \(\mathbb{N}\) 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 \(\mathbb{N}\) 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.


\section*{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:

Digital Input Characteristics
\begin{tabular}{|c|l|}
\hline Input Logic State & \multicolumn{1}{|c|}{ Allowed Input Voltage Levels } \\
\hline Low & \begin{tabular}{l}
\(-12 \mathrm{~V}\left(\mathrm{~V}_{\mathrm{DO}}\right)\) to 0.8 V sinking \(<10 \mu \mathrm{~A}\) \\
\(+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 \\
\\
\hline High
\end{tabular} \\
\hline \multicolumn{2}{|c|}{ The digital inputs are directly CMOS compatible. The capacitive } \\
loading on each input is 25 pF (maximum). \\
\hline
\end{tabular}
\begin{tabular}{l} 
Digital Output Characteristics \\
\begin{tabular}{|c|l|}
\hline Output Logic State & \multicolumn{1}{|c|}{ Allowed Output Voltage Levels } \\
\hline Low & \begin{tabular}{l}
0.0 V to \(0.4 \mathrm{~V}(-0.4 \mathrm{~V}\) to +0.4 V for RLSD) \\
sinking 0.36 mA \\
\(+4.0 \mathrm{~V}\left(\mathrm{~V}_{\text {ss }}-1 \mathrm{~V}\right)\) to \(+5.0 \mathrm{~V}\left(\mathrm{~V}_{\text {ss }}\right)\) sourcing \\
\(100 \mu \mathrm{~A}\)
\end{tabular} \\
\hline High & \\
\hline \begin{tabular}{l} 
The digital outputs are directly CMOS or low-power Schottky TTL \\
compatible.
\end{tabular} \\
\hline
\end{tabular} \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|}
\hline \multicolumn{3}{|r|}{Digital Interchange Circuits} \\
\hline Term & Pin Number & Description \\
\hline TONA & P1-A5 & Output indicating completion of answering tone. \\
\hline 800MS & P1-A6 & Input affecting Clear-to-Send response time. \\
\hline TC06 & P1-A7 & Input affecting Clear-to-Send response time. \\
\hline K & P1-A8 & Input affecting Ready-for-Sending response time. \\
\hline X & P1-A9 & Input affecting T109 Squelch. \\
\hline CAUTO & P1-A10 & Input initiation transmission of answering tone. \\
\hline New Sync (NSYNC) & P1-A13 & Input affecting T109 Squelch. \\
\hline CLAMP & P1-A15 & Input forcing squelch of T109. \\
\hline Fast Energy Detector (RLSD) & P1-A17 & Input generating T109. \\
\hline Fast Sync (RSYC) & P1-A18 & Input determining whether fast sync feature (fast resynchronization upon recovery of received line signal following momentary dropout) is enabled. \\
\hline S8GR & P1-A19 & Input determining whether the modulo 8 pattern guard will be incorporated into the scrambler facility. \\
\hline
\end{tabular}

DCP
\begin{tabular}{lll} 
R2W/4W & P1-A22 & \begin{tabular}{l} 
Input affecting state of THRH \\
output.
\end{tabular} \\
\begin{tabular}{l} 
Receiver Baud Clock \\
(RBCK)
\end{tabular} & P1-A23 & For 2400 bps operation. \\
PBS & P1-A24 & \begin{tabular}{l} 
Input determining T109 On-to-Off \\
response time.
\end{tabular} \\
TH09 & P1-A25 & \begin{tabular}{l} 
Input affecting state of THRH \\
output.
\end{tabular} \\
Transmitted Data & P1-A29 & \begin{tabular}{l} 
Input for digital data to be \\
transmitted.
\end{tabular} \\
(T103)
\end{tabular}

A

1
THRH

V26A/B
\begin{tabular}{lll} 
CP15 & P1-B20 & \begin{tabular}{l} 
Input selecting optional clamping \\
of Receive Clock (T115).
\end{tabular} \\
RCVDS & P1-B21 \\
SYC & \begin{tabular}{l} 
P1-B22 \\
Digital outputs enabling user to \\
PE \\
generate eye pattern and phase \\
error diagnostic information.
\end{tabular} \\
TC09 & P1-B24 & \begin{tabular}{l} 
Input determining T109 Off-to-On \\
response time.
\end{tabular} \\
CP04 & P1-B25 & \begin{tabular}{l} 
Input determining T104 damping.
\end{tabular} \\
\begin{tabular}{l} 
External Transmit \\
Clock (T113)
\end{tabular} & P1-B29 & \begin{tabular}{l} 
Input providing modem with trans- \\
mitted signal element timing \\
information.
\end{tabular} \\
\begin{tabular}{l} 
Request-to-Send \\
(T105)
\end{tabular} & P1-B30 & \begin{tabular}{l} 
Input to transmitter.
\end{tabular} \\
\begin{tabular}{ll} 
Received Data \\
(T104)
\end{tabular} & P1-B31 & \begin{tabular}{l} 
Digital data output from modem \\
receiver.
\end{tabular} \\
\begin{tabular}{ll} 
Transmit Clock \\
(T114)
\end{tabular} & P1-B33 & \begin{tabular}{l} 
Output providing user with trans- \\
mitted signal element timing \\
information.
\end{tabular} \\
Carrier Detect & P1-B24 & \begin{tabular}{l} 
Output indicating presence of sig- \\
nal energy on receiver line.
\end{tabular} \\
(T109) & &
\end{tabular}

P1-A21 Digital output enabling user to generate eye pattern and phase error diagnostic information.
Input affecting state of THRH output.

Input determining T109 On-to-Off ponse time. output. transmitted. cept data for transmission.

Input determining whether transmata rate is 2400 bps or Output providing received signal lement timing information. mponse tim T109 Squelch Input affecting Ready-for-Sending response time and answering tone requency.

P1-B11 Digital output enabling user to generate eye pattern and phase error diagnostic information.
P1-B15 Input determining whether scrambler is to be inserted.
P1-B18 Output used in conjunction with carrier detect circuitry to implement T109 threshold set select function.
P1-B19 Input selecting dibit encoding at 2400 bps operation as per V. 26 Alternate A or V. 26 Alternate B. Input selecting optional clamping of Receive Clock (T115).
Digital outputs enabling user to eye pattern and phase nput determining T109 Off-to-On esponse time.

Input providing modem with transmitted signal element timing information.

The following P 1 connector pin locations should be left open and unconnected:
A4, A11, A12, A14, A16, A20, A35, B1, B12, B13, B14, B17, B32, and B35.
\begin{tabular}{|c|c|c|}
\hline \multicolumn{3}{|c|}{Data Structure} \\
\hline \multicolumn{2}{|l|}{Input} & \multirow[b]{2}{*}{Data Structure} \\
\hline Data Signalling Rate Selector (P1-A32) & \[
\begin{gathered}
\text { V26 A/B } \\
\text { (P1-B19) }
\end{gathered}
\] & \\
\hline \[
\begin{aligned}
& \text { Low } \\
& \text { Low }
\end{aligned}
\] & \[
\begin{aligned}
& \text { Low } \\
& \text { High }
\end{aligned}
\] & 2400 bps Alternate A 2400 bps V. 26 Alternate B (Bell 201C) \\
\hline High & Don't Care & 1200 bps \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|l|}
\multicolumn{4}{c|}{ Tone Generation } \\
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{2}{|c|}{ Inputs } & \multicolumn{2}{c|}{ Outputs } \\
\hline CAUTO & \multicolumn{1}{|c|}{\(\mathbf{Y}\)} & TONA & \\
(P1-A10) & \multicolumn{1}{|c|}{ (P1-B8) } & (P1-A5) & \multicolumn{1}{c|}{ Transmitted Signal } \\
\hline 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 \\
\hline
\end{tabular}
\end{tabular}

Selection of Clear-To-Send Response Times
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Turn-On Sequence} & \multicolumn{7}{|c|}{Inputs} & \multicolumn{2}{|l|}{Clear-To-Send Response Times (ms)} \\
\hline & \[
\begin{gathered}
Y \\
(\mathrm{P} 1-\mathrm{B8})
\end{gathered}
\] & \[
\begin{aligned}
& \text { 800MS } \\
& \text { (P1-A6) }
\end{aligned}
\] & \[
\begin{gathered}
K \\
(P 1-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}
1 \\
(\mathrm{P} 1-\mathrm{B} 15)
\end{gathered}
\] & \[
\begin{gathered}
\mathrm{E} \\
(\mathrm{P} 1-\mathrm{B6})
\end{gathered}
\] & Off-to-On & On-to-Off \\
\hline 1 & Low & High & Don't Care & Don't Care & High & Low & Don't Care & 6.67 & 0 \\
\hline 2 & High & High & Low & High & High & Low & Don't Care & 8.33 & 0 \\
\hline 3 & High & High & Low & Low & High & Low & Don't Care & 30 & 0 \\
\hline 4 & High & High & Low & Don't Care & High & High & Don't Care & 30 & 0 \\
\hline 5 & High & High & Don't Care & High & Low & Low & Low & 90 & 0 \\
\hline 5 & High & High & High & High & High & Low & Don't Care & 90 & 0 \\
\hline 6 & High & High & Don't Care & High & Low & High & Low & 90 & 0 \\
\hline 6 & High & High & High & High & High & High & Don't Care & 90 & 0 \\
\hline 7 & Low & High & Don't Care & Don't Care & Low & Low & Don't Care & 148.3 & 0 \\
\hline 8 & Low & High & Don't Care & Don't Care & Don't Care & High & Don't Care & 148.3 & 0 \\
\hline 9 & High & High & High & Low & Don't Care & Low & Don't Care & 220 & 0 \\
\hline 9 & High & High & Don't Care & Don't Care & Low & Low & High & 220 & 0 \\
\hline 9 & High & High & Don't Care & Low & Low & Low & Don't Care & 220 & 0 \\
\hline 10 & High & High & High & Low & Don't Care & High & Don't Care & 220 & 0 \\
\hline 10 & High & High & Don't Care & Don't Care & Low & High & - High & 220 & 0 \\
\hline 10 & High & High & Don't Care & Low & Low & High & Don't Care & 220 & 0 \\
\hline 11 & High & Low & Don't Care & Don't Care & Don't Care & Low & Don't Care & 220 & 0 \\
\hline 12 & High & Low & Don't Care & Don't Care & Don't Care & High & Don't Care & 800 & 0 \\
\hline
\end{tabular}

Carrier Detect Squelch
\begin{tabular}{|l|l|l|l|l|l|}
\hline \multicolumn{5}{|c|}{\begin{tabular}{|l|l|l|l|}
\hline \(\mathbf{X}\) \\
(P1-A9)
\end{tabular}} & \begin{tabular}{c} 
T2W/4W \\
(P1-B7)
\end{tabular}
\end{tabular}
\begin{tabular}{l} 
Carrier Detect Threshold Selection \\
\begin{tabular}{|l|c|c|}
\hline THRH & \begin{tabular}{c} 
Gain \\
Strap
\end{tabular} & \begin{tabular}{c} 
Selected \\
Threshold Sot
\end{tabular} \\
\hline \begin{tabular}{l} 
High Impedance \\
High Impedance \\
Low impedance \\
to ground
\end{tabular} & G1 & \(-43 \mathrm{dBm},-48 \mathrm{dBm}\) \\
\hline \multicolumn{3}{|c|}{ G1 or G2 }
\end{tabular} \\
\hline
\end{tabular}

\section*{THRH Operation}
\begin{tabular}{|c|c|c|}
\hline \multicolumn{2}{|c|}{ Input } & \multirow{2}{*}{ THRH } \\
\hline TH09 & R2W/4W & \\
\hline Low & Low & \begin{tabular}{c} 
High Impedance \\
High \\
Ligh Impedance \\
High
\end{tabular} \\
Low & High & High Impedance \\
How Impedance
\end{tabular}

Scrambler/Descrambler
\begin{tabular}{|l|l|l|}
\hline \multicolumn{2}{|c|}{ Input } & \multicolumn{2}{c|}{\begin{tabular}{c} 
Serambler/Descrambler \\
Conflguration
\end{tabular}} \\
\hline \begin{tabular}{c} 
I \\
(P1-B15)
\end{tabular} & \begin{tabular}{c} 
S8QR \\
(P1-A19)
\end{tabular} & \\
\hline Low & Don't Care & \begin{tabular}{l} 
No Scrambler \\
High
\end{tabular} \\
Low & \begin{tabular}{l} 
Scrambler V.27 bis, ter \\
(modulo 8 pattern guard)
\end{tabular} \\
High & High & (no modulo 8 pattern guard) \\
\hline
\end{tabular}

Analog Interface CIrculte-The analog interface circults 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.

Analog Interface Circults
\begin{tabular}{|c|c|c|}
\hline Term & Pin Number & Description \\
\hline +12V & P1-B5, B9 & +12V Power Supply \\
\hline \(-12 \mathrm{~V}\) & P1-A1 & -12V Power Supply \\
\hline +5V & P1-A2, B2 & +5V Power Supply \\
\hline COMMON & P1-A3, A31, B3 & Ground (signal and power return) \\
\hline T1 & P1-A34 & T1 is the low impedance transmitter analog output (line signal). The T1 allows the user the flexiblility needed to customize his output impedance (to compensate for transformer losses, for instance). \\
\hline SECONDARY \(\mathbb{N}\) & P1-B4 & Secondary channel input from the DTE. \\
\hline REC IN & P1-B36 & Recelve filter input. Input impedance is a resistive 15.8 \(K\) ohms \(\pm 1 \%\). \\
\hline
\end{tabular}

Audio Interface-The audio interface includes the R24LL's interface with the transmission network.

The recelver and transmitter line interfaces are single-ended (non-transformer coupled) signals with the following characteristics:

\section*{Transmilter Volce 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.


\section*{Recelver Volce 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.

\section*{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\% p -p for an input signal-to-noise ratio of 12 dB .

Blt Error Rate—The following graph represents typical R24LL 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 accepptance testing, product evaluation, and observation of line signal quality under actual operation.

\section*{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

\section*{POWER REQUIREMENTS}
\begin{tabular}{|c|c|c|}
\hline Voltage & Ripple & \begin{tabular}{c} 
Maximum \\
Current
\end{tabular} \\
\hline\(+5 \mathrm{VDC} \pm 5 \%\) & \(100 \mathrm{mV} p-\mathrm{p}\) & 102 mA \\
\(+12 \mathrm{VDC} \pm 5 \%\) & 50 mV p-p & 64 mA \\
-12 VDC \(\pm 5 \%\) & \(50 \mathrm{mV} p-\mathrm{p}\) & 142 mA \\
\hline
\end{tabular}

\section*{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)

\section*{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.

\section*{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.

\section*{MODEM OPERATION MODES}

In general, the modules can be configured to operate in the following modes:
\begin{tabular}{ll} 
Simplex - Transmit only: & \begin{tabular}{l} 
Only the transmitter module \((T)\) is \\
used.
\end{tabular} \\
Simplex - Receive only: & \begin{tabular}{l} 
R1 and R2 modules are used to \\
implement a complete receiver \\
function.
\end{tabular} \\
Half Duplex (2-Wire): & \begin{tabular}{l} 
Requires both transmit and receive \\
functions (although not simul- \\
taneously), therefore, all three \\
modules are used.
\end{tabular} \\
Full Duplex (4-Wire): & \begin{tabular}{l} 
Requires both transmit and receive \\
functions simultaneously, again all \\
three modules are used.
\end{tabular}
\end{tabular}

\section*{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.


R24 Integral Modem


\section*{R24 Functional Diagram}

\section*{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:
\begin{tabular}{|c|c|c|}
\hline \multicolumn{2}{|c|}{ 2400 BPS } \\
\hline \multirow{2}{*}{ DIBIT } & \multicolumn{2}{|c|}{ PHASE CHANGE } \\
\cline { 2 - 3 } & \(\mathbf{V . 2 6 A}\) & V.26B/Bell 201 \\
\hline & 0 & \(0^{\circ}\) \\
0 & \(+90^{\circ}\) & \(+45^{\circ}\) \\
11 & \(+180^{\circ}\) & \(+135^{\circ}\) \\
10 & \(+270^{\circ}\) & \(+225^{\circ}\) \\
& & \(+315^{\circ}\) \\
\hline
\end{tabular}


ALTERNATIVE B \({ }_{+45^{\circ}}\)


Line Signal Diagram (V. 26 A \& 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.
\begin{tabular}{|c|c|}
\hline \multicolumn{2}{|c|}{1200 BPS} \\
\hline BIT & PHASE CHANGE \\
\hline 0 & \(+90^{\circ}\) \\
1 & \(+270^{\circ}\) \\
\hline
\end{tabular}

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 tımes are determined by the modem configuration selected and its associated turn on sequence.
\begin{tabular}{|c|c|c|}
\hline Turn On Sequence Number & Ready for Sending Response Time & Configuration and Carrier Type \\
\hline 1 & 667 msec & Switched Carrier - 4-Wire (Bell 201) \\
\hline 2 & 833 msec & Switched Carrier - 4-Wire \\
\hline 3 & 30 msec & CCITT - 4-Wire \\
\hline 4 & 30 msec & CCITT - 4-Wire with Scrambler \\
\hline 5 & 90 msec & CCITT - 2-Wire \\
\hline 6 & 90 msec & CCITT - 2-Wire with Scrambler \\
\hline 7 & 1483 msec & Switched Carrier - 2-Wire \\
\hline 8 & 1483 msec & Switched Carrier - 2-Wire with Scrambler \\
\hline 9 & 220 msec & CCITT - 2-Wire Echo Protection \\
\hline 10 & 220 msec & Switched 2-Wire Echo Protection with Scrambler \\
\hline 11 & 800 msec & CCITT - 2-Wire Auto Call \\
\hline 12 & 800 msec & CCITT - 2-Wire Auto Call with Scrambler \\
\hline \multicolumn{3}{|l|}{Response Time tolerance ( \(+09,-0.1\) ) msec} \\
\hline
\end{tabular}

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.
\(\left.\begin{array}{|c|r|}\hline \begin{array}{c}\text { Carrier Detect } \\ \text { Transition }\end{array} & \text { Response Time } \\ \hline \text { OFF to ON } & 6 \pm 1 \mathrm{~ms} \\ \text { (connection) } & 14 \pm 1 \mathrm{~ms}\end{array}\right\}\) Selectable

Receive Level - The modem receives line signals from 0 to -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.

\section*{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.

\section*{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

\section*{MODEM OPERATION - \\ HALF OR FULL-DUPLEX}

Figure 3 indicates the module interconnections necessary for half-duplex operation. For full-duplex operation, the transmitter/ receiver interconnections are similar to the half-duplex case with the exception that "REC IN" is not connected to T2 or T1. In full-duplex operations, the transmission and receiver paths are independent.

As shown, 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:


\section*{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.

\section*{INTERFACE DESCRIPTION}

STANDARD DIGITAL INTERCHANGE
\begin{tabular}{|c|c|c|c|c|}
\hline Term (CCITT V 24 Equivalent) & EIA RS232C Equivalent & \[
\frac{\text { Module }}{\text { Input }}
\] & \[
\frac{\text { nterface }}{\text { Output }}
\] & Description \\
\hline T103 & BA & T-9 & & Transmitted Data \\
\hline T104 & BB & & R2-5 & Received Data \\
\hline T105 & CA & T-8 & & Request to Send \\
\hline T106 & CB & & T-6 & Ready for Sending (Clear to Send) \\
\hline T109 & CF & R1-4 & R2-22 & Data Channel Received Line Signal Detector (Carrier Detect) \\
\hline T111 & CH & \[
\begin{aligned}
& \text { T-12, } \\
& \text { R2-9 }
\end{aligned}
\] & & Data Signalling Rate Selector Selects 2400 bps or 1200 bps Mode \\
\hline T113 & DA & T. 7 & & \begin{tabular}{l}
External Transmit Clock \\
(Transmitted Sıgnal Element Tımıng)
\end{tabular} \\
\hline T114 & DB & & T-10 & Transmit Clock (Transmitted Sıgnal Element Tımıng) \\
\hline T115 & DD & & R2-6 & Receive Clock (Receive Signal Element Timıng) \\
\hline
\end{tabular}

ANALOG LINE INTERFACES
\begin{tabular}{ccll}
\hline Term & \multicolumn{2}{c}{\begin{tabular}{c} 
Module Interface \\
\\
Input
\end{tabular}} & Output
\end{tabular}
\begin{tabular}{|c|c|c|c|}
\hline \multicolumn{3}{|l|}{\multirow[t]{2}{*}{Term \(\frac{\text { Module }}{\text { Interface }}\)}} & \multirow[b]{2}{*}{Description} \\
\hline & & & \\
\hline V26A & \[
\begin{gathered}
\text { T-16 } \\
\text { R2-13 }
\end{gathered}
\] & & Selects V 26A or V 26B Dibit Encodıng \\
\hline S8GR &  & & Controls for Scramble Operation \\
\hline NSYNC & \[
\begin{gathered}
\text { T-14 } \\
\text { R2-11 }
\end{gathered}
\] & & Controls T109 to Force Rapid Resynchronization of the Receiver \\
\hline CLAMP & R2-10 & T-13 & Implements Squelch for Carrier Detect (T109) \\
\hline
\end{tabular}

TRANSMITTER DIGITAL CONTROLS


TRANSMITTER ANALOG CONTROLS
\begin{tabular}{|c|c|c|c|}
\hline Term & \[
\begin{gathered}
\text { Module } \\
\hline \text { Input } \\
\hline
\end{gathered}
\] & \[
\frac{\text { Interface }}{\text { Output }}
\] & Description \\
\hline DAC OUT & & T-22 & Output of Digital to Analog Converter \\
\hline TFIL & T-23 & & Input to Low Pass Filter DAC OUT is Normally Connected to TFIL Unless Additional Filtering or an Equalizer is to be Inserted \\
\hline TIN & T-31 & & These Nine Signals Implement the \\
\hline -1dBm & & T-39 & Transmitter Output Level Attenuator One of \\
\hline -3dBm & & T-38 & the Signals \(-1 \mathrm{dBm}, \quad,-15 \mathrm{dBm}\) is \\
\hline -5dBm & & T-37 & Strapped to TIN to Set the Desired Output \\
\hline -7dBm & & T-36 & Level \\
\hline -9dBm & & T-35 & \\
\hline - 11dBm & & T-34 & \\
\hline - 13dBm & & T-33 & \\
\hline - 15dBm & & T-32 & \\
\hline
\end{tabular}

RECEIVER DIGITAL CONTROLS
\begin{tabular}{|c|c|c|c|}
\hline \multirow[b]{2}{*}{Term} & \multicolumn{2}{|l|}{Module Interface} & \multirow[b]{2}{*}{Description} \\
\hline & Input & Output & \\
\hline RBCK & R1-1 & R2.25 & Receıver Baud Clock \\
\hline \[
\begin{gathered}
\text { RLSD } \\
\text { THRH } \\
\text { R2W/4W } \\
\text { TH09 }
\end{gathered}
\] & \[
\begin{gathered}
\text { R2-24 } \\
\text { R1-3 } \\
\text { R2-8 } \\
\text { R2-18 }
\end{gathered}
\] & \[
\left.\begin{array}{r}
\mathrm{R} 1-2 \\
\mathrm{R} 2-23
\end{array}\right\}
\] & Control Signals to Generate Carrier Detect (T109) and Implement T109 Threshold Set Select Function \\
\hline TC09 & R2-15 & & Determınes Carrier Detect (T109) Off-to-On Response \\
\hline PBS & R2-16 & & Determınes Carrier Detect (T109) On-to-Off Response \\
\hline CP04 & R2-17 & & Clamps Received Data (T104) to a mark or space when Carrier Detect (T109) is Off \\
\hline CP15 & R2-19 & & Optıonal Clampıng of Received Clock (T115) \\
\hline FSYC & R2-20 & & Fast Sync Optıonal Fast Resynchronızatıon Procedure \\
\hline
\end{tabular}

RECEIVER DIGITAL DIAGNOSTICS
\begin{tabular}{cccc}
\hline & \multicolumn{2}{c}{ Module Interface } & \\
\cline { 2 - 3 } Term & Input & Output & \\
\hline 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 &
\end{tabular}

RECEIVER ANALOG CONTROLS
\begin{tabular}{ccll}
\hline & \multicolumn{2}{c}{ Module Interface } & \\
\cline { 2 - 3 } Term & Input & Output & \multicolumn{1}{c}{ Description } \\
\hline REC OUT & R1-7 & & Receive Filter Ouput \\
EQ IN & R1-8 & & Equalizer Input
\end{tabular}

\section*{MODEM PERFORMANCE}

The R24 is a high performance synchronous 2400 bps DPSK modem, utilizing a coherent demodulation technique to achieve reliable operation over the switched network or unconditioned lines. This section contains a quantitative discussion of the R24's typical performance under varying test conditions.

Timing Jitter - The maximum steady state timing jitter of "receive clock" with respect to "transmit clock" is less than 10\% \(\mathrm{p}-\mathrm{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.

\section*{ELECTRICAL CHARACTERISTICS}

POWER REQUIREMENTS
\begin{tabular}{|c|c|c|c|}
\hline Module & Voltage & Ripple & Maximum Current \\
\hline \multirow[t]{3}{*}{T} & +5 Vdc \(\pm 5 \%\) & 100 mV p-p & 38 mA \\
\hline & +12 Vdc \(\pm 5 \%\) & 50 mV p-p & 16 mA \\
\hline & \(-12 \mathrm{Vdc} \pm 5 \%\) & 50 mV p-p & 48 mA \\
\hline \multirow[t]{2}{*}{R1} & +12 Vdc \(\pm 5 \%\) & 50 mV p-p & 23 mA \\
\hline & \(-12 \mathrm{Vdc} \pm 5 \%\) & 50 mV p-p & 16 mA \\
\hline \multirow[t]{3}{*}{R2} & +5 Vdc \(\pm 5 \%\) & 100 mV p-p & 64 mA \\
\hline & +12 Vdc \(\pm 5 \%\) & 50 mV p-p & 25 mA \\
\hline & \(-12 \mathrm{Vdc} \pm 5 \%\) & 50 mV p-p & 78 mA \\
\hline
\end{tabular}

Maximum total power consumption approximately 3 watts. Typical total power consumption approximately 2 watts.

\section*{DIGITAL INTERFACE}

The R24 provides LS TTL or CMOS compatible logic levels that are functionally equivalent to EIA RS232/449 and CCITT V.24.
\begin{tabular}{|c|c|}
\hline \begin{tabular}{l} 
Input \\
Logic
\end{tabular} & Allowed Input Voltage Levels \\
\hline Low & \begin{tabular}{c}
-12.0 V to +0.8 V Sinking \(<10 \mu \mathrm{~A}\) \\
+4.0 V to +5.0 V Sourcing \(<10 \mu \mathrm{~A}\)
\end{tabular} \\
\hline
\end{tabular}

Digital inputs are directly CMOS compatible. Interfacing with standard TTL or low-power Schottky TTL requires an external pull-up resistor.
\begin{tabular}{|c|c|}
\hline \begin{tabular}{c} 
Output \\
Logic
\end{tabular} & Allowed Output Voltage Levels \\
\hline Low & \begin{tabular}{l}
0.0 V to +0.4 V Sinking 0.36 mA \\
+4.0 V to +5.0 V Sourcing \(100 \mu \mathrm{~A}\)
\end{tabular} \\
\hline
\end{tabular}

Digital outputs are directly CMOS or low-power Schottky TTL compatible.

\section*{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{~dB} \mathrm{~m}\)
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

\section*{MECHANICAL SPECIFICATIONS}


NOTE: This cross-section is common to all modules.


Transmilter Module Package


Receiver - R1 Module Package


Receiver - R2 Module Package
NOTES: 1) Dimensions in inches (millimeters).
2) Component side shown

\section*{PRINTED CIRCUIT BOARD MOUNTING OPTIONS FOR THE R24 MODULES}

Three methods of mounting are commonly used. Each configuration has certain distinct advantages.
\begin{tabular}{|l|l|l|}
\hline \multicolumn{1}{|c|}{\begin{tabular}{c} 
Mounting \\
Method
\end{tabular}} & \multicolumn{1}{|c|}{\begin{tabular}{c} 
Type of Connection \\
or Connector Used
\end{tabular}} & \multicolumn{1}{|c|}{\begin{tabular}{c} 
Basic \\
Advantage
\end{tabular}} \\
\hline \begin{tabular}{l} 
Standard Flush \\
PCB Component \\
Mount
\end{tabular} & \begin{tabular}{l} 
Wave Soldered Into Standard \\
PCB Eyelets
\end{tabular} & \begin{tabular}{l} 
Lowest Height \\
Profile
\end{tabular} \\
\begin{tabular}{ll} 
Above Board \\
Low Profile \\
Socket
\end{tabular} & \begin{tabular}{l} 
Connectors (SAE Serles \\
3000 or Methode Series 1000) \\
These Sockets are Wave \\
Soldered Into Standard \\
PCB Eyelets
\end{tabular} & \begin{tabular}{l} 
Plug-in Capa- \\
bility at Low \\
Cost
\end{tabular} \\
PCB Plug-in & \begin{tabular}{l} 
Connectors (AMP Miniature \\
Sockets (Bullets)
\end{tabular} & \begin{tabular}{l} 
Spring Sockets.) \\
Pin Sockets are Individually \\
Soldered Into PCB Eyelets
\end{tabular} \\
& & \begin{tabular}{l} 
Lile for Plug-in \\
Capability
\end{tabular} \\
\hline
\end{tabular}

\section*{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}\)

\section*{Ordering Information}

When ordering, specify products as follows:
R24 - Set of 3 modules (T, R1, R2)
R24MEB - Modem Evaluation Board

\section*{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. RDAA ROCKWELL DATA ACCESS ARRANGEMENT MODULE

\section*{PRELIMINARY}

\section*{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.

\section*{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.

\section*{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^{\prime \prime}\) 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.

\section*{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.

\section*{RDAA DIMENSIONS}

The dimensions for the RDAA Module are given in Figure 2.

\section*{MATING CONNECTORS}

The mating connectors of the RDAA are as follows:
1. Two row ( 14 pins) ribbon type connectors . \(1^{1 "}\) spacing between pins.


Figure 2. RDAA Module Dimensions

\section*{SECTION 2 - INTERFACE DESCRIPTION}

\section*{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
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Lead Designation} & \multicolumn{3}{|c|}{Signal Direction To:} & \multirow[b]{2}{*}{Function} \\
\hline & User & RDAA & Both & \\
\hline \begin{tabular}{l}
R, T \\
MI, MIC \\
PR, PC
\end{tabular} & & & \[
\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. \\
\hline \(+5 \mathrm{~V},+12 \mathrm{~V},-12 \mathrm{~V}\) & & X & & DC power required. \\
\hline \[
\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 \\
& x
\end{aligned}
\] & \[
\begin{aligned}
& x \\
& x \\
& x \\
& x
\end{aligned}
\] & X & \begin{tabular}{l}
Signal ground required. \\
Ringing signal present indication. \\
To request data transmission path cut through. \\
To control Off-Hook relay \\
Status of telephone set switch hook. \\
Transmission path cut through indication. \\
Lead to modem output. \\
Lead to modem input.
\end{tabular} \\
\hline
\end{tabular}

\section*{SG}

The SG (Signal Ground) is the common reference for all modem interface signals.

\section*{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
\begin{tabular}{|c|c|}
\hline \begin{tabular}{c} 
Output \\
Logic State
\end{tabular} & Output Levels \\
\hline LOW & 0.0 to 04 V while sınkıng \(<1.6 \mathrm{ma}\) \\
HIGH & 2.4 to 5.0 V while sourcing \(<40 \mu \mathrm{~A}\) \\
\hline
\end{tabular}

\section*{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
\begin{tabular}{|c|c|}
\hline \begin{tabular}{c} 
Input \\
Logic State
\end{tabular} & Input Levels \\
\hline 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}\) \\
\hline
\end{tabular}

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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.

\section*{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).

\section*{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).

\section*{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 \(\mathbf{T}\) and \(\mathbf{R}=\) (input amplitude at TXA \(-7 \mathrm{~dB}+\) (Programmed level set by wall jack resistor).
B. For Permissive mode: output level across \(T\) and \(R=\) (input amplitude at TXA) -16 dB .

\section*{IMPEDANCE SPECIFICATIONS}
\begin{tabular}{ll} 
On-Hook DC: & \begin{tabular}{l} 
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.
\end{tabular} \\
On-Hook AC: & \begin{tabular}{l} 
The on-hook AC impedance \\
measured between T and R is less \\
than 40K ohms (15.3 Hz minimum).
\end{tabular} \\
Off-Hook DC: & \begin{tabular}{l} 
Less than 100 ohms.
\end{tabular} \\
Off-Hook AC: & \begin{tabular}{l}
600 ohms nominal when measured \\
between T and \(R\). \\
2 megohms typical (operational \\
amplifier voltage follower input \\
impedance).
\end{tabular} \\
TXA and GND: & \begin{tabular}{l} 
75 ohms typical (operational amplifier \\
voltage follower output impedance).
\end{tabular}
\end{tabular}

\section*{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*{SECTION 3 - INSTALLATION/CHECKOUT}

\section*{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.)

\section*{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)

\section*{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
\begin{tabular}{|c|c|c|c|c|c|}
\hline Output Configuration & Optional Telephone Set & \[
\begin{gathered}
\text { FCC } \\
\text { Reg. No. }
\end{gathered}
\] & Ringer Equivalent & Telephone Jack USOC No. & Telephone Set USOC No. \\
\hline Programmable
Permissive & \begin{tabular}{l}
With \\
Telephone Set \\
Without \\
Telephone Set \\
With \\
Telephone Set \\
Without \\
Telephone Set
\end{tabular} & \begin{tabular}{l}
AMQ9SQ \\
67943 \\
DP-E \\
AMQ9SQ \\
67943 \\
DP-E \\
AMQ9SQ \\
67943 \\
DP-E \\
AMQ9SQ \\
67943 \\
DP-E
\end{tabular} & \begin{tabular}{l}
.8B \\
.8B \\
.8B \\
.8B
\end{tabular} & \begin{tabular}{l}
\({ }^{1}\) RJ36X and \\
\({ }^{2.3} \mathrm{RJ} 45 \mathrm{~S}\) \\
\({ }^{2.3}\) RJ45S \\
\({ }^{1}\) RJ36X and RJ16X or \\
\({ }^{4}\) RJA2X and RJ11C RJ11C
\end{tabular} & \begin{tabular}{l}
RTC or 502 with exclusion key \\
N.A. \\
RTC or 502 with exclusion key N.A.
\end{tabular} \\
\hline \multicolumn{6}{|l|}{\begin{tabular}{l}
Notes: \\
1. RJ36X is an 8 position miniature jack into which the telephone plugs. Rather than using an RJ36X jack, the telephone company may use a connecting block to connect the telephone set and data jack to the telephone line. \\
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. \\
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. \\
4. RJA2X is the adapter shown in Figure 2-1. The use of the RJ36X and RJ16X jacks is recommended.
\end{tabular}} \\
\hline
\end{tabular}


Figure 5. Transmit and Receive (Half Duplex) and (Full Duplex)

\section*{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.

\section*{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).

\section*{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
\begin{tabular}{|c|c|c|}
\hline Type Interface Circuit & RDAA Connectors/ Pin No. & Interface Circuit/Signal \\
\hline \begin{tabular}{l}
DTE \\
Interface \\
Connections
\end{tabular} & \begin{tabular}{l}
P2-1 P2-2 \\
P2-3 \\
P2-4 \\
P2-5 \\
P2-6 \\
P2-7 \\
P2-8 \\
P2-9 \\
P2-10 \\
P2-11 \\
P2-12 \\
P2-13 \\
P2-14
\end{tabular} & CCT/
RXA
TXA
OH
RCCT
RD/
-12 V
SH
GND
TP2 EXCESSIVE
POWER DETECT
+12 V
+5 V
N/U
TP1 BILLING
DELAY TIME \\
\hline \begin{tabular}{l}
Telephone \\
Line \\
Interface \\
Connections
\end{tabular} & \[
\begin{gathered}
\text { P1-4 } \\
\text { P1-3 } \\
\text { P1-1 } \\
\text { P1-2 } \\
\text { P1-(5-8) \& (11-12) } \\
\text { P1-9, } 10 \\
\text { P1-13, } 14
\end{gathered}
\] & PC
PR
MIC
MI
(Not Used)
R
T \\
\hline
\end{tabular}

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.

\section*{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.

\section*{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.

\section*{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.

\section*{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 orily in the automatic dial mode (refer to paragraph 4.3).

\section*{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.

\section*{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.

\section*{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.

\section*{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:
1. The FCC requires that the following label be prominently displayed on an outside surface of the OEM's end product.

Unit contains Regıstered Protective Circuitry which complies with Part 68 FCC Rules

FCC Registration Number:
Ringer Equivalence: .8B
2. The size of the label should be such that all the required information is legible without magnification.

\section*{SECTION 4 - OPERATING INSTRUCTIONS}

\section*{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

\section*{AUTOMATIC DIAL}

\section*{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.


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.

\section*{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 OH 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.

*DA MAY BE PERMANENTLY ON,
**ALTERNATIVELY, USER MAY TIME FOR 3 SECONDS TO ENSURE DIAL TONE PRESENT.
*** ANSWER TONE DETECTION CIRCUITRY IS NOT PROVIDED WITHIN THE RDAA

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.

\section*{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 ACU 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.

\section*{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*{SECTION 5 - FAULT ISOLATION}

\section*{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 also recommended.

\section*{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*{SECTION 8 \\ T-1 AND T-1/CEPT PULSE CODE MODULATION PROTOCOL DEVICES}
Page
Product Family Overview ..... 8-2
R8040 Tri-Port Memory ..... 8-3
R8050 T-1 Serial Transmitter ..... 8-9
R8060 T-1 Serial Receiver ..... 8-17
R8070 T-1/CEPT Pulse Code Modulation Transceiver ..... 8-23

\title{
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

\section*{R8040 \\ T-1 TRI-PORT MEMORY}

\section*{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.

\section*{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)

\section*{APPLICATIONS}

Time-Division Multiplex (TDM) digital switching data and control stores
- TDM sequential machines
- Elastic stores
- Hardware/Software control interfaces
- I/O Buffers

\section*{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 WE determines whether or not the data on lines \(A\) through \(H\) will be written into memory. Data will only be written into memory when WE 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

*NOTE: PIN 34 HAS AN OUTPUT SIGNAL APPLICABLE ONLY TO ROCKWELL TESTING, MAKE NO CONNECTION TO THIS PIN.

\section*{Pin Configuration}
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 \(\overline{\text { 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 \(\overline{R R E}\) 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
become valid 80 ns after the negative transition of \(\overline{\text { RRE. The }}\) random accessed data outputs will cease to be valid 100 ns after a positive transition of \(\overline{\text { 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 \(\overline{W E}\), 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.

\section*{RECOMMENDED OPERATING CONDITIONS}

\section*{Minimum Setup/Hold Times}
\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{Signal} & \multicolumn{2}{|c|}{Setup} & \multicolumn{2}{|c|}{Hold} \\
\hline & Measure to & ns & Measure to & ns \\
\hline SCLK 1 & \(\overline{\text { WE ! }}\) & 300 & \(\overline{\text { WE }}\) ! & 0 \\
\hline WSEL & WE! & 280 & WE \({ }^{\text {W }}\) & 0 \\
\hline R01-R32 & WE ! & 250 & WE \({ }^{\text {W }}\) & 0 \\
\hline A-H & WE 1 & 150 & WE \({ }^{\text {¢ }}\) & 100 \\
\hline \(\overline{\text { RST }}\) & SCLK ! & 180 & SCLK 1 & 0 \\
\hline
\end{tabular}

\section*{Minimum Pulse Widths}
\begin{tabular}{|c|c|}
\hline Signal & Minimum Pulse Width \\
\hline\(\overline{\mathrm{WE}}(=0)\) & 170 ns \\
SCLK & 220 ns \\
\hline
\end{tabular}


Sequential Counter Reset Setup and Hold Timing


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.

Read Outputs at Same Location as Write (All Other Inputs Stable)


Write Setup and Hold Timing


Random Read ( \(\overline{\operatorname{RRE}}=0, \overline{\mathrm{WE}}=1\) )


Sequential Read \(\overline{(\overline{S R E}}=0, \overline{\mathrm{WE}}=1)\)


8

Read Port Enable/Disable (Address Stable, \(\overline{\mathrm{WE}}=1\) )

\section*{Propagation Delays}
\begin{tabular}{|l|c|c|c|c|}
\hline Parameter & Symbol & Min & Max & Unit \\
\hline Random Read Access Time & \(\mathrm{t}_{\mathrm{RA}}\) & 0 & 380 & ns \\
Sequential Read Access Time & \(\mathrm{t}_{\mathrm{SA}}\) & 0 & 430 & ns \\
Read Port Disable (to HI-Z) & \(\mathrm{t}_{\mathrm{PD}}\) & 0 & 100 & ns \\
Read Port Enable & 0 & 80 & ns \\
Same-Location Read After Write & \(\mathrm{t}_{\mathrm{SL}}\) & 0 & 340 & ns \\
\hline
\end{tabular}


\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & +4.75 to +5.25 & V \\
\hline Operating Temperature & \(\mathrm{T}_{\mathrm{OP}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{ELECTRICAL CHARACTERISTICS}
\(\left(V_{D D}=+5 \mathrm{~V} \pm 5 \%, V_{S S}=0 V T_{A}=25^{\circ} \mathrm{C}\right)\)
\begin{tabular}{|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Max & Unit \\
\hline Input Logic " 1 " Voltage & \(\mathrm{V}_{1 \mathrm{H}}\) & 2.0 & & V \\
\hline Input Logic " 0 "' Voltage & \(\mathrm{V}_{\mathrm{IL}}\) & & 0.8 & V \\
\hline Input Logic " 1 " Voltage & \(\mathrm{V}_{\text {OL }}\) & 2.4 & & V \\
\hline Output Logic '0" Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & & 0.4 & V \\
\hline Output Source Current & \(\mathrm{IOH}^{\text {l }}\) & -100 & & \(\mu \mathrm{A}\) \\
\hline Output Sink Current & lOL & 400 & & \(\mu \mathrm{A}\) \\
\hline Input Capacitance & \(\mathrm{C}_{1}\) & & 5 & pF \\
\hline Output Capacitance & \(\mathrm{C}_{0}\) & & 25 & pF \\
\hline Power Dissipation (at \(25^{\circ} \mathrm{C}\) ) & \(\mathrm{P}_{\text {DSS }}\) & & 300 & mW \\
\hline
\end{tabular}

\section*{PACKAGE DIMENSIONS}


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

R8050
T-1 SERIAL TRANSMITTER

\section*{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 minımal external logic, via the multiframe alignment signal ( \(F_{\mathrm{s}}\) ) 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 B70PTN controls the particulars of the insertion method.

Two types of transmit formats are provided, a binary output and a parred unipolar output. The unipolar pair provides a means to externally create a single bipolar output with minimal logic.


Pin Configuration

\section*{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.


Figure 1. T-1 Serial Transmitter

\section*{T-1 TRANSMITTER INPUTS}

Any input \(\leq 0.8 \mathrm{~V}=\) logic 0 , low. Any input \(\geq 2.0 \mathrm{~V}=\operatorname{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.

\section*{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 FRYSYNC 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.

\section*{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.

\section*{TEST: ROCKWELL DEVICE TEST INPUT}

Used only for Rockwell device testing. Keep this input grounded.

\section*{CLOCK: T-1 CLOCK}

Maximum frequency \(=1.6 \mathrm{MHz}\)
Minimum pulse width \(=275 \mathrm{~ns}\)
The \(\mathrm{T}-1\) bit period is bounded by the rising edges of this input.

\section*{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 INH is low.

\section*{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.

\section*{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.

\section*{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.

\section*{S-BIT: MULTIFRAME SIGNALLING BIT}

SBIT, in conjunction with CCIS, provides an alternate way to control the multiframe signalling bit ( \(\mathrm{F}_{\mathrm{S}}\) ) transmission. The S-Bit input is transmitted as the multiframe signalling bit \(\left(\mathrm{F}_{\mathrm{S}}\right)\) if CCIS is held high. Refer to Table 2.

\section*{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.

\section*{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.

\section*{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.

\section*{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

\section*{T-1 TRANSMITTER OUTPUTS}

Low power TTL Schottky compatible. " 1 " \(\geq 2.4 \mathrm{Vdc}\), " 0 " \(\leq\) \(0.4 \mathrm{Vdc}, \mathrm{CMOS}-12 \mathrm{~K} \Omega\) pullup to \(\mathrm{V}_{\mathrm{DD}}\) required.

\section*{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 ( \(F_{\mathrm{T}}\) ) is serially transmitted, and will return low as each multiframe alignment signal ( \(F_{S}\) ) is transmitted. Refer to Figure 2.

\section*{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 7. SYNOUT is the only output determined by the falling edge of CLOCK.

\section*{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.

\section*{BINOUT: SERIAL DATA OUTPUT, BINARY FORMATTED}

BINOUT is the binary formatted serial conversion of the parallel input data. The programmed format of BINOUT follows 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.

\section*{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


Table 2. Framing Bit ( \(F_{T} \& F_{S}\) ) Output Data
\begin{tabular}{|c|c|c|c|}
\hline \multirow{2}{*}{\begin{tabular}{c} 
Frame \\
Number
\end{tabular}} & \begin{tabular}{c} 
Processed \\
Bit
\end{tabular} & \multicolumn{2}{|c|}{ Binout } \\
\cline { 3 - 4 } & & \(F_{T}\) & 1 \\
\hline 1 & \(F_{S}\) & 0 & CCIS \(=\mathbf{0}\) \\
\hline 2 & \(F_{T}\) & 0 & 1 \\
\hline 3 & \(F_{S}\) & 0 & SBIT \\
\hline 4 & \(F_{T}\) & 1 & 0 \\
\hline 5 & \(F_{S}\) & 1 & SBIT \\
\hline 6 & \(F_{T}\) & 0 & 1 \\
\hline 7 & \(F_{S}\) & 1 & SBIT \\
\hline 8 & \(F_{T}\) & 1 & 0 \\
\hline 9 & \(F_{S}\) & 1 & SBIT \\
\hline 10 & \(F_{T}\) & 0 & 1 \\
\hline 11 & \(F_{S}\) & 0 (NOTE 1) & SBIT \\
\hline 12 & & & 0 \\
\hline
\end{tabular}

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


CCIS

(SEE NOTE)

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
\begin{tabular}{|c|l|c|c|c|}
\hline Symbol & \multicolumn{1}{|c|}{ Parameter } & Min & Max & Unit \\
\hline \(\mathrm{t}_{1 \mathrm{~s}}\) & Buffered Data Setup Time & 450 & & ns \\
\hline \(\mathrm{t}_{1 \mathrm{H}}\) & Buffered Data Hold Time & 0 & & ns \\
\hline \(\mathrm{t}_{2 \mathrm{~S}}\) & Control Input Setup Time & 400 & & ns \\
\hline \(\mathrm{t}_{2 \mathrm{H}}\) & Control Input Hold Time & 20 & & ns \\
\hline \(\mathrm{t}_{3 \mathrm{~S}}\) & Asynchronous Control Input Setup Time & 350 & & ns \\
\hline \(\mathrm{t}_{3 \mathrm{H}}\) & Asynchronous Control Input Hold Time & 20 & & ns \\
\hline \(\mathrm{t}_{4 \mathrm{~S}}\) & SYNCIN Setup Time & 200 & ns \\
\hline \(\mathrm{t}_{4 \mathrm{H}}\) & SYNCIN Hold Time & 20 & ns \\
\hline & SYNCIN Pulse Width & 100 & ns \\
\hline \(\mathrm{t}_{5 \mathrm{~S}}\) & Frame Sync Setup Time (Return to Zero) & 250 & & ns \\
\hline \(\mathrm{t}_{5 \mathrm{H}}\) & Frame Sync Hold Time (Return to Zero) & 20 & ns \\
\hline & Frame Sync Pulse Width & 200 & & ns \\
\hline \(\mathrm{t}_{5 \mathrm{~S}}\) & Frame Sync Setup Time (Non-Return to Zero) & 525 & & ns \\
\hline \(\mathrm{t}_{5 \mathrm{H}}\) & Frame Sync Hold Time (Non-Return to Zero) & 20 & & \\
\hline
\end{tabular}

Table 4. Output Propagation Delay, Worst Case
(Measured from Rising Edge of Clock Unless Stated Otherwise)
\begin{tabular}{|c|c|c|}
\hline Output & Max Delay & Unit \\
\hline SSTB & 500 & ns \\
SYNOUT & 500 & ns \\
Ref from Falling & & \\
Edge of Clock & 500 & ns \\
CHCLKF & 500 & ns \\
BINOUT & 500 & ns \\
UNPLRA & 500 & ns \\
UNPLRB & & \\
\hline
\end{tabular}

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & +4.75 to +5.25 & Vdc \\
\hline Operating Temperature & \(\mathrm{T}_{\mathrm{OP}}\) & 0 to 70 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\text {STG }}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{ELECTRICAL CHARACTERISTICS}
( \(V_{D D}=5.0 \pm 5 \%\) )
\begin{tabular}{|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Max & Unit \\
\hline Logical " 1 " input Voltage & \(\mathrm{V}_{\mathrm{OH}}\) & 20 & \(V_{D D}+03\) & V \\
\hline Logicical " 0 '" Input Voltage & \(\mathrm{V}_{\text {IL }}\) & -03 & 0.8 & V \\
\hline Logicical "1" Output Voltage & \(\mathrm{V}_{\mathrm{OH}}\) & 24 & - & V \\
\hline Logıc " 0 " Output Voitage & \(\mathrm{V}_{\mathrm{OL}}\) & - & 04 & V \\
\hline Output Source Current & IOH & -100 & - & \(\mu \mathrm{A}\) \\
\hline Output Sink Current & \(\mathrm{l}_{\mathrm{OL}}\) & 400 & - & \(\mu \mathrm{A}\) \\
\hline Capacitance Load (any output) & C & - & 25 & pF \\
\hline Input Capacitance (any input) & \(\mathrm{C}_{\text {IN }}\) & - & 5 & pF \\
\hline Clock Frequency & & - & 1.6 & MHz \\
\hline Power Dissipation & \(P_{\text {D }}\) & - & 250 & mW \\
\hline
\end{tabular}

\section*{PACKAGE DIMENSIONS}


\section*{R8060 T-1 SERIAL RECEIVER}

\section*{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 ( \(\mathrm{F}_{\mathrm{T}}\) ) alternating every 386 bits. Loss of frame sync is indicated if a frame bit error occurs within two to four F-Bit frames since the previous frame bit error.
A loss of carrier is indıcated if 31 consecutive bit tımes yield "zeros" at \(^{\text {t }}\) 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.

\section*{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


\section*{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.

\section*{TCLK: T-1 CLOCK}

Typical clock frequency is 1.544 MHz . Maximum clock frequency is 1.85 MHz . The \(\mathrm{T}-1\) bit period is bounded by the rising edges of TCLK. Input levels must be \(>2.4\) volts for LOGIC 1 and \(\leq 0.8\) volts for LOGIC 0 .

\section*{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.

\section*{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.

\section*{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.

\section*{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

\section*{T-1 RECEIVER OUTPUTS}

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.

\section*{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.

\section*{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.

\section*{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.

\section*{TESTO: ROCKWELL DEVICE TEST OUTPUT}

Designed to aid in Rockwell device testing. No connection required for normal operation.

\section*{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.

\section*{MAXCNT: MAXIMUM COUNT OF 386 MODULUS}
\(\overline{\text { 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.

\section*{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.

\section*{S-BIT: SIGNALING BIT OUTPUT}

The S-Bit output will have the same digital level as 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.

\section*{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.

\section*{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.

\section*{B2ALRM: BIT 2 ALARM}

B2ALRM goes high, detecting a remote alarm condition, if 255 consecutive channel data samples are received with Bit 2 low. B2ALRM returns low upon the receipt of any channel sample with Bit 2 high.

\section*{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.

\section*{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).

\section*{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 \(\mathrm{F}_{\mathrm{T}}\) Frame (F-BIT)


Figure 5. Multiframe Signal Relationships

Table 1. Output Propagation Delay Worst Case, From Rising Edge of TCL.K
\begin{tabular}{|l|c|}
\hline OUTPUT & MAX DELAY (NS) \\
\hline CHCLK & 300 \\
CHSYNC & 300 \\
WIHBT & 300 \\
MAAKCNT & 300 \\
SBCLK & 400 \\
SBIT & 400 \\
SIGFR & 475 \\
SBALRM & 475 \\
B2ALRM & 450 \\
CALRM & 300 \\
FRALRM & 900 \\
CDB (1-8) & 400 \\
\hline
\end{tabular}

Packaging Diagram

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline \multicolumn{1}{|c|}{ Parameter } & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{DD}}\) & +4.75 to +5.25 & V \\
\hline Operating Temperature Range & \(\mathrm{T}_{\mathrm{OP}}\) & 0 to +70 & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature Range & \(\mathrm{T}_{\mathrm{STG}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{ELECTRICAL CHARACTERISTICS}
\(\left(V_{D D}=+5 \mathrm{~V} \pm 5 \%, \mathrm{~T}_{\mathrm{A}}=25^{\circ} \mathrm{C}\right.\) )
\begin{tabular}{|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Max & Unit \\
\hline Input Logic "1" Voltage & \(\mathrm{V}_{\mathrm{IH}}\) & 2.0 & \(V_{D D}+0.3\) & V \\
\hline Input Logic "0'" Voltage & \(\mathrm{V}_{\text {IL }}\) & -0.3 & 0.8 & V \\
\hline Output Logic " 1 " Voltage & \(\mathrm{V}_{\mathrm{OH}}\) & 2.4 & & V \\
\hline Output Logic ' 0 " Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & & 0.4 & V \\
\hline Output Source Current & \(\mathrm{IOH}^{\text {r }}\) & -100 & & \(\mu \mathrm{A}\) \\
\hline Output Sink Current & \(\mathrm{l}_{\mathrm{OL}}\) & 400 & & \(\mu \mathrm{A}\) \\
\hline Clock Frequency & \(\mathrm{T}_{\text {CLK }}\) & & 1.85 & MHz \\
\hline Input Capacitance & \(\mathrm{C}_{1}\) & & 5 & pF \\
\hline Output Capacitance & \(\mathrm{C}_{0}\) & & 25 & pF \\
\hline Power Dissipation & \(\mathrm{P}_{\text {DSS }}\) & & 550 & mW \\
\hline
\end{tabular}

\section*{R8070 \\ T-1/CEPT PCM TRANSCEIVER}

\section*{INTRODUCTION}

The R8070 is a monolithic silicon gate CMOS device designed to implement PCM transmitter and receiver functions applied in primary-rate digital carrier systems worldwide. Both the transmitter and receiver contain appropriate circuitry for synchronization, channel monitoring and signalling extraction.

The R8070 supports CCITT recommendations G 732, G. 733 and applicable sections of G.703, as well as Bell System technical advisories on clear channel capability and extended framing format. This device provides the interfaces between the multiplexed digital signals of the subscriber loop and the PCM highway in a digital telephone switching system. The device operates from a single power supply of 5 volts and a sampling clock of 1.544 to 2.048 MHz , depending on the mode of operation.

Packaged in a 64-pin QUIP (quad in-line package), the R8070 requires less real-estate and provides flexibility in system integration and manufacturing. Specific support of both types of operation modes (parallel/serial) allows the application of the R8070 in virtually every type of voice/data system using either T-1, T-1C, or CEPT specification.

\section*{FEATURES}
- Autonomous Transmit and Receive Sections in a single chip
- Low Power CMOS 100mw (Operating)
- 5 Volts Single Supply Voltage
- 64-pin QUIP
- Meets CCITT G.732, G 733, and applicable sections of G. 703 Specifications and AT\&T Advisories
- Operates with EXTENDED FRAMING, CLEAR CHANNEL, and/or CEPT formats
- Supports Multiplex/Demultiplex T-1C, Mode 1 (Synchronous) Operations
- Uses a clock of 1.544 (T-1), 1.576 ( \(1 / 2\) T-1C) or 2.048 (CEPT) MHz, depending on operation mode
- Selectable Serial or Parallel Digital Data Interface
- Reframe Time 10 ms (Mode Dependent)
- TTL/CMOS Compatible Inputs and Outputs


\section*{FUNCTIONAL CHARACTERISTICS}

\section*{TRANSMIT SECTION}

The transmit section of the R8070 (refer to the R8070 Functional Block Diagram) formats data to be serially transmitted according to CCITT G.732, G.733, applicable sections of G.703, and Bell technical advisories on clear channel capability and extended framing format. The 8-bit PCM data is clocked out by the transmit clock, which can vary between 1.544 and 2.049 MHz , depending on the selected mode of operation. Input signals TSSYNC and TMSYNC provide external synchronization to the R8070 frame counters.

Depending on the mode of operation when a yellow alarm is received, the R8070 is capable of sending idle messages in all message channels by activating the TIDLE input. A TLOOP is provided to aid testing user's applications by connecting internally TNEG and TPOS to RNEG and RPOS. Yellow alarm signalling to remote equipment is conveyed by stuffing or manipulating the appropriate bits in the various data channels, depending on the mode of operation.

Transmit output signals (i.e., TCHCLK, TCHSYNC and TMAX) are provided as a means to synchronize external equipment to the internal bit counters. Two types of data output formats are provided by virtue of pins TNRZ, TPOS and TNEG. TPOS and TNEG can be configured with minimal external circuitry to create a bipolar output. When configured in a parallel mode, the transmit channel data bits T1-T8 are sampled by the rising edges of TCLK. When used in a serial transmit mode, input control signal TSA allows advancement by one bit time of the transitions on TSQ and TSIGSQ. TSIGMD identifies the input source for transmit signalling information. Transmit output signals, designated by TSQ1 through TSQ5, are provided and can be used in decoding schemes to address individual channel cards residing in channel banks, according to D1D or D2 sequential code format.

Various mode dependent signals are used to provide control and signalling to the transmitted data stream. Transmit link input signal, TLINK, is used to input link information at various bit rates, depending on the mode of operation. Provision for insertion of error patterns in the \(F\) position is made possible through input TFSIG. In the 193E and S modes, robbed bit signalling information is provided and controlled through inputs TA(C) and TB(D). In the 256S mode, the serial bit stream containing the transmit signalling information is provided at TABCD and sampled at an 8 kHz rate. Repetitive transmission of a certain code sequence in a given channel on TNRZ or TPOS and TNEG provides a 0 dBm 1 KHz signal. When decoded in a properly aligned
receiving terminal, this signal is referred to as digital milliwatt. A multiplexed framing pattern generator signal, which is the result of the composite of an externally supplied S BIT and an internally generated data link CRC check bit, is provided at TFGEN. TI1S, TN1S, and TX1S are provisions for inputs that are dedicated for use in the 256 modes and are typically applied in handshaking applications between the transmit and receive terminals. Many other signals are used on different assignments, depending on the selected operating mode, and are described in detail in this document. These input and output signals are used to provide the hooks and handles that are associated with each mode.

\section*{RECEIVE SECTION}

In the receive section (refer to R8070 Functional Block Diagram), the received unipolar data is processed serially by the rising edge of RCLK at a rate of 1.544 to 2.048 MHz , depending on the mode of operation (Bell or CCITT). Synchronization is accomplished by locating the \(F_{t}\) bit (framing bit) through a five-stage process, thus eliminating erroneous bit candidates that could cause false synchronization. In the 193 N and S modes, synchronization is achieved in less than 5 ms , while in the other modes, it is achieved in less than 10 ms .

Output signals such as RSYNC, RSRCH, RRED, and RMAX are dependent on the synchronizer receive master state and may be used for status reporting or external processing of the received data. Remote alarm monitoring (yellow alarm) is reported by RYEL in a format appropriate to the transmission mode.

Similar to the transmitter, a provision that allows insertion of idle channel data in the received bit stream is invoked by activating the RIDLE input. RMW input is provided for trunk alignment, causing a 1 kHz milliwatt generator to be substituted for all received message channels.

Receive output signals (i.e., RCHSYNC, RCHCLK, and RWIHBT) are provided for synchronization of external counters to the PCM frame rate and strobing the received data into external memory if necessary. Additional output signals are provided to indicate the status of the received data, the type of alarm received and a bipolar violation indication when it is manifested in the data pattern. Serial mode receive outputs (i.e., RSQ1-RSQ5) are used in a decoding scheme to select channel units residing in channel banks. Receive framing mode dependent signals OA through OJ are used for monitoring of signalling information, error reporting, synchronization reporting and many useful alarm reporting signals.


\section*{OPERATIONAL MODES}

The R8070 is configurable in a parallel or serial operation. The R8070 is mode selectable. By strapping input lines M1-M4, eleven data formats are provided to meet the user's requirements.

The P/S (Parallel/Serial) mode straps are as follows:
1. Parallel \(P / \bar{S}=1\)
2. Serial \(P / \bar{S}=0\)

The permissible modes that may be selected are illustrated.


\section*{Mode Selection}

\section*{INTERFACE CRITERIA}

\section*{PARALLEL/SERIAL MODE-DEPENDENT INPUTS}

Parallel Mode-Dependent Inputs
\begin{tabular}{|c|c|l|}
\hline Pin & Name & Description \\
\hline PSI1 & T1 & \\
PSI2 & T2 & \\
PSI3 & T3 & \\
PSI4 & T4 & Transmit Channel \\
PSI5 & T5 & Data Bits 1-8 \\
PSI6 & T6 & \\
PSI7 & T7 & \\
PSI8 & T8 & \\
\hline
\end{tabular}

Serial Mode-Dependent Inputs
\begin{tabular}{|l|l|l|}
\hline Pin & \multicolumn{1}{|c|}{ Name } & \multicolumn{1}{|c|}{ Description } \\
\hline PSI1 & TSER & Transmit Serial Input \\
PSI2 & TSIGMD & Transmit Signalling Mode \\
PSI3 & TABCD & Transmit Signalling Input \\
PSI4 & TSA & Transmit Sequence Advance \\
PSI5 & RSHIFT & Receive Shift \\
PSI6 & D1D & D1D Sequence \\
PSI7 & D2 & D2 Sequence \\
PSI8 & RSR & Receiver Sequence Retard \\
\hline
\end{tabular}

PARALLEL/SERIAL MODE-DEPENDENT OUTPUTS
Parallel Mode-Dependent Outputs
\begin{tabular}{|l|l|l|}
\hline Pin & \multicolumn{1}{|c|}{ Name } & Description \\
\hline PSO1 & R1 & \\
PSO2 & R2 & \\
PSO3 & R3 & Receive Channel Data Bits 1-8 \\
PSO4 & R4 & \\
PSO5 & R5 & \\
PSO6 & R6 & \\
PSO7 & R7 & Transmit Channel Clock \\
PSO8 & R8 & Transmit Channel Sync \\
PSO9 & TCHCLK & Receive Channel Clock \\
PSO10 & TCHSYNC & Receive Channel Sync \\
PSO11 & RCHCLK & Receive Write Inhibit \\
PSO12 & RCHSYNC & PSO13 \\
RWIHBT & \\
\hline
\end{tabular}

Serial Mode-Dependent Outputs
\begin{tabular}{|c|c|c|c|}
\hline Pin & Name & \multicolumn{2}{|c|}{Description} \\
\hline PSO1 & RSQ1 & \multicolumn{2}{|l|}{\multirow[t]{3}{*}{Receive Sequence Code Bits 1-5}} \\
\hline PSO2 & RSQ2 & & \\
\hline PSO3 & RSQ3 & & \\
\hline PSO4 & RSQ4 & \multicolumn{2}{|l|}{Receive Sequence Code Bits 1-5} \\
\hline PSO5 & RSQ5 & & \\
\hline PSO6 & TSIGSQ/TNSYNC* & & \\
\hline PSO7 & RSIGSQ/RIBITS* & & \\
\hline RSO8 & R8/RABCD & & \\
\hline PSO9 & TSQ1 & & \\
\hline PSO10 & TSQ2 & \multicolumn{2}{|l|}{\multirow[b]{2}{*}{Transmit Sequence Code Bits 1-5}} \\
\hline PSO11 & TSQ3 & & \\
\hline PSO12 & TSQ4 & & \\
\hline PSO13 & TSQ5 & & \\
\hline \multicolumn{4}{|c|}{Notes} \\
\hline \multicolumn{3}{|l|}{*Mode ( Transmit Signalling Square Wave} & (PSO6) \\
\hline 193 or & \multicolumn{2}{|l|}{Receive Signalling Square Wave} & (PSO7) \\
\hline 197 & \multicolumn{2}{|l|}{(Receive Channel Data Bit 8} & (PSO8) \\
\hline \multirow[t]{3}{*}{*Mode} & \multicolumn{2}{|l|}{(TNSYNC Transmit National Sync} & (PSO6) \\
\hline & \(\{\) RIBITS Receive & Internatıonal & (PSO8) \\
\hline & RABCD & Signalling & (PSO8) \\
\hline
\end{tabular}

\section*{INPUT/OUTPUT SIGNAL CHARACTERISTICS}

\section*{R8070 Input/Output Signal Characteristics}
\begin{tabular}{|c|c|c|}
\hline Mnemonic & Definition & Function \\
\hline \multicolumn{2}{|l|}{SERIAL MODE COMMON INPUTS:} & \\
\hline D1D, D2 & Code Select Modes & These signals, D1D and D2, permit the generation of transmit and receive serial codes, according to CCITT or the D1D and D2 channel assignment format:
\[
\begin{array}{lll}
\mathrm{D} 1 \mathrm{D}=0, & \mathrm{D} 2=0 & \mathrm{CCITT} \\
\mathrm{D} 1 \mathrm{D}=1, & \mathrm{D} 2=0 & \mathrm{D} 1 \mathrm{D} \\
\mathrm{D} 1 \mathrm{D}=0, & \mathrm{D} 2=1 & \mathrm{D} 2
\end{array}
\] \\
\hline \multicolumn{2}{|l|}{COMMON RECEIVE INPUT SIGNALS:} & \\
\hline PUP & Power-Up & \begin{tabular}{l}
This signal initializes the R8070. It can also be used as a "hands off' restart. \\
After power is applied and RCLK and TCLK are active, PUP must be held low for at least 16 clock cycles to ensure output predictability (refer to Power-Up Timing Requirement Diagram).
\end{tabular} \\
\hline RCLK & Receive Clock & An external tımıng source is input via the RCLK pin to provide the master tımıng for the receive function \\
\hline RIDLE & Receive Idle Control & When RIDLE is high and RMW is low, idle codes are substituted for all received message channels; this signal is sampled channel-by-channel \\
\hline RMRST & Receive Master Reset & When RMRST is high, it forces the master state controller to go into a "WAIT" state, if a continuous level is maintained, and holds off entry to "INIT"' ("WAIT" = the initial step of the synchronization process). \\
\hline RMW & Receive Milliwatt & When RMW is high and RIDLE is low, RMW causes the internal 1 kHz milliwatt generator to be substituted for all received message channels. This signal is sampled channel-by-channel. \\
\hline RPOS, RNEG & Receive Unipolar Positive and Negative & \begin{tabular}{l}
Input data to the receiver which may be of RZ or NRZ nature. When RPOS is strapped to RNEG it causes: \\
1. B8ZS or HDB3 modes to become transparent for transmit functions and receive functions. \\
2. Disabling of the bipolar violation detector.
\end{tabular} \\
\hline RSRCH & Receive Search Control & When low, RSRCH holds off entry to "INIT", the second step of the initialization process. When RRED and RSRCH are active low during the first time slot of the first frame of the multiframe, bit 5 is skipped. \\
\hline \multicolumn{2}{|l|}{COMMON RECEIVE OUTPUT SIGNALS:} & \\
\hline RRED & Receive Red Alarm & \begin{tabular}{l}
RRED is high when the receiver is not synchronized. \\
RRED when low indicates that the receiver is frame synchronized. It may or may not be multiframe synchronized.
\end{tabular} \\
\hline RSER & Receive Serial Data & RSER represents the received serial data bit stream, including any B8ZS or HDB3 corrections. \\
\hline RSYNC & \begin{tabular}{l}
Receive \\
Synchronization State Indicator
\end{tabular} & \begin{tabular}{l}
RSYNC provides a SYNC output that is dependent upon the receive master state. \\
1. SYNC (North American): Single pulse coinciding with the first ' \(F\) ' bit for each new multiframe, as shown in the North American Mode Receive Synchronization Timing Diagram. \\
2. SYNC (European): Single pulse coinciding with bit one of each new multiframe, as shown in the European Receive Synchronization Timıng Diagram.
\end{tabular} \\
\hline RVLL & Bipolar Violation, Loss of Carrier & RVLL reports bipolar violations as a high-level coincident with the emergence of the accused bit at RSER. Also, RVLL reports failure to receive carrier. \\
\hline RYEL & Receive Yellow Alarm & RYEL conveys yellow alarm information appropriate to mode. RYEL transitions occur one bit time after the bit that triggered the alarm merges out RSER. \\
\hline
\end{tabular}

R8070 Input/Output Signal Characteristics (Continued)
\begin{tabular}{|c|c|c|}
\hline Mnemonic & Definition & Function \\
\hline \multicolumn{2}{|l|}{PARALLEL MODE RECEIVE OUTPUT SIGNALS:} & \\
\hline RCHCLK & Receive Channel Clock & RCHCLK is high during the output of bits 1 through 4 of the channel data on RSER. RCHCLK is low elsewhere. \\
\hline RCHSYNC & Receive Channel Synchronization & RCHSYNC is suitable for synchronizing external counters to the T-1 or CEPT frame rate. Transitions on RCHSYNC are mode dependent. \\
\hline R1-R8 & Receive Channel Data Bits 1-8 & R1-R8 are valid with the current channel data nominally for 8 bit times and extend to 9 or 10 bit times in cases where an ' \(F\) ' and/or link bit occur Transitions conncide with the output of Bit 1 on RSER. Refer to the Parallel Mode Receive Signals Timıng Diagram. \\
\hline RWIHBT & Receive Write Inhibit & RWIHBT covers the parallel channel data transition period. It goes high-active before, during, and after the transitions on R1-R8. \\
\hline \multicolumn{2}{|l|}{SERIAL MODE RECEIVE INPUT SIGNALS:} & \\
\hline RSHIFT & Receive Shift & When RSHIFT is high, it causes the RSQ codes to be shifted. \\
\hline RSR & Receive Sequence Retard & When RSR is high, the RSQ codes and RSIGSQ transitions are delayed by one bit time from their nominal positions. \\
\hline \multicolumn{2}{|l|}{SERIAL MODE RECEIVE OUTPUT SIGNALS:} & \\
\hline RSIGSQ & Receive Signalling Square Wave & RSIGQ exhibits a high-to-low transition during the output of the F-bit at RSER for frames carrying " \(B\) " (D) signalling and low-to-high transition during the output of the F-bit at RSER for frames carrying " \(A\) " (C) signalling. It is affected by RSR in the same manner as the RSQ leads. \\
\hline RSQ1, RSQ2, RSQ3, RSQ4 and RSQ5 & Receive Sequence Code Bits 1 through 5 & \begin{tabular}{l}
RSQ1 through RSQ5 encode the current channel number according to CCITT convention. During the occurrence of framing, link and CRC bits, special codes are observed. \\
Refer to the 197 Mode Receive Sequence Code Timıng Diagram.
\end{tabular} \\
\hline \multicolumn{2}{|l|}{MODE DEPENDENT RECEIVE OUTPUT SIGNALS} & \\
\hline RABCD & Receive ABCD & RABCD represents a serial bit stream containing the most recently received signalling bits for each of the 30 channels. RABCD is channel-aligned with RSER. \\
\hline RIBITS (OB) & Receive International Bits & RIBITS goes high to indicate that the international bit is present at serial output RSER, as shown in the National and International Bits Timing Diagram. \\
\hline RNBITS (OE) & Receive National Bits & RNBITS is active-high coincident with the emergence of bits 4 through 8 of TSO not containing the frame alignment signal. \\
\hline RTS16 (OC) & Receive Time Slot 16 & RTS16 is high for the duration of TS16 bits 1 through 8 emergıng from output RSER \\
\hline RXBITS (OG) & Recerve Extra Bits & RXBITS is active-high when RSER contains bits 5, 7 and 8 of TS16 containing the multiframe alignment signal \\
\hline \multicolumn{2}{|l|}{MODE DEPENDENT RECEIVE ERROR OUTPUT SIGNALS:} & \\
\hline CKERR (OC) & Cyclic Redundancy Check Bit Error & CKERR pulses high with the emergence of the " \(F\) " CRC bit at RSER if a cyclic bit error is detected. \\
\hline ERR (OD) & Error Signal & ERR pulses high for one bit time upon detection of a framing error or check sum error. \\
\hline FERR (OD) & Framing Error & This signal pulses high for one bit tıme, upon detection of a framing or check sum error. Response varies according to mode. Applicable to 193A, S \& N, 197S \& N, \& 256N modes. \\
\hline
\end{tabular}

R8070 Input/Output Signal Characteristics (Continued)
\begin{tabular}{|c|c|c|}
\hline Mnemonic & Definition & Function \\
\hline \multicolumn{2}{|l|}{MODE DEPENDENT RECEIVE ERROR OUTPUT SIGNALS (Continued):} & \\
\hline FMERR (OD) & Receive Frame Multiframe Error & FMERR pulses high for one bit time to indicate detection of either frame or multiframe errors. Applicable to 256 S mode. \\
\hline RMRED (OC) & Receive Multiframe Red & RMRED is active-high when two consecutive multiframe alignment errors have occurred or if all TS16 data bits are low for a complete multiframe. When RMRED is high, the transmitter transmits a multiframe yellow alarm in bit 6 of TS16, contaning the multiframe alignment signal. \\
\hline RMYEL (OF) & Receive Multiframe Yellow & RMYEL contains the extracted bit 6 of TS16 that represents the multiframe alignment signal. \\
\hline SERR (OE) & S-Bit Errors & SERR pulses high for one bit time each time an error is observed in the received \(S\)-bit pattern. \\
\hline \multicolumn{2}{|l|}{MODE DEPENDENT RECEIVE SIGNALLING OUTPUT SIGNALS:} & \\
\hline MS1, MS2 (OF, OG) & Master State Sequence Code & The two least significant bits MS1 and MS2 are of the master state sequence code. \\
\hline RLCLK (OG) & Receive Lınk Clock & RLCLK represents a square clock at the data rate of RLINK. \\
\hline RLINK (OF) & Receive Data Link & RLINK reports data extracted from the "Received Link Data," occurring at the rates corresponding to the various transmıssion modes (refer to 256 N mode Receive Link Data Tıming Diagram). \\
\hline RLINK1 (OC) & Receive Lınk 1 & An active-high level indicates the reception of 255 consecutive ones in time slot 16. \\
\hline RMFA (OA)-193F mode RMFA (OB)-256S mode & Receive Multıframe Alignment & RMFA is high for the duration of frame 24. Transitions coincide with the emergence of the "F" bits at RSER. \\
\hline & & In the 256S mode, RMFA is active-high for the duration of the frame which contains the multiframe alignment signal. \\
\hline RSBCLK (OC) & Receive S-Bit Clock & RSBCLK is a 4 kHz square clock whose low to high transition occurs 1 bit after the emergence of RSBIT ( \(F_{\mathrm{S}}\) ) at RSER. \\
\hline RSIG (OA) & Receive Signalling Frame & RSIG is active-high during the receipt of signalling frames. Activity is suspended if recent errors have been observed in the F-bit or S-bit.mode dependent signal. \\
\hline RSIGBD (OB) & Receive Signalling B or D & RSIGBD represents a 2 kHz square wave with low-to-high transitions occurring during frames containing the A or C signalling, and high-to-low transitions occurring during frames containing \(B\) or \(D\) signalling. \\
\hline RSIGCD (OC) & Receive Signalling C or D & RSIGCD represents a \(1 / 3 \mathrm{kHz}\) square clock with transitions coinciding with the emerging \(F\)-bit at RSER. \\
\hline RSBIT (OB) & Receive SignallingFraming Bit & RSBIT is the most current received S-bit coincident with the emergence of the S-bit at RSER and is mode dependent. \\
\hline \multicolumn{2}{|l|}{COMMON TRANSMIT INPUT SIGNALS:} & \\
\hline TCLK & Transmit Clock & All inputs of the transmit section are sampled on the rising edge of TCLK. \\
\hline TFSYNC & Transmit Frame Sync & TFSYNC synchronously restarts the transmitter to the beginning of a frame TFSYNC reinforces the internal count cycle when pulsed once per frame. \\
\hline
\end{tabular}

R8070 Input/Output Signal Characteristics (Continued)
\begin{tabular}{|c|c|c|}
\hline Mnemonic & Definition & Function \\
\hline \multicolumn{2}{|l|}{COMMON TRANSMIT INPUT SIGNALS (Continued):} & \\
\hline TIDLE & Transmit Idle & When high, TIDLE causes the transmitter to output idle code in all message channels via TNRZ, TPOS and TNEG. \\
\hline TLOOP & Transmit Loop & When high, TLOOP causes the transmitter to alternately transmit ones on TPOS and TNEG, and the transmitter internal TPOS and TNEG signals to be routed to the receive function in place of RPOS and RNEG. TLOOP does not affect TNRZ. \\
\hline TMSYNC & Transmit Multiframe Sync & When active-high, it synchronously sets the internal frame counter to the first frame of a multiframe. \\
\hline TYEL & Transmit Yellow Alarm & High level on TYEL activates the transmission of a yellow alarm and is mode dependent. \\
\hline \multicolumn{2}{|l|}{COMMON TRANSMIT OUTPUTS:} & \\
\hline TMAX & Transmit Maximum & TMAX pulses high for one bit time coincident with the sampling of the last serial bit of a multiframe. \\
\hline TNRZ & Transmit Non-Return to Zero & This output contains the non-return-to-zero bit stream of the transmitter. TNRZ is not affected by TLOOP, HDB3 or B8ZS functions. \\
\hline TPOS, TNEG & Transmit Positive, Negative & TPOS and TNEG contain the transmit output bit stream conditioned for alternate mark inversion. This sequence of steering alternate ones for each of these outputs is deliberately broken when a B8ZS or HDB3 substitution takes place. \\
\hline \multicolumn{2}{|l|}{PARALLEL MODE TRANSMIT OUTPUT:} & \\
\hline TCHCLK & Transmit Channel Clock & TCHCLK indicates times when parallel data has been sampled. \\
\hline TCHSYNC & Transmit Channel Sync & TCHSYNC is an 8-bit signal active prior to the sampling of parallel data for the first message channel. \\
\hline \multicolumn{2}{|l|}{SERIAL MODE RECEIVE INPUT SIGNALS:} & \\
\hline TSA & Transmit Sequence Advance & When TSA is high, transitions on TSQ1-TSQ5 and TSIGSQ are advanced one bit time Refer to the Transmit Seqence Code Timing Diagram. \\
\hline TSIGMD & Transmit Signalling Mode & TSIGMD indıcates that signalling is included within the serially input bit stream or through dedicated signalling inputs. The effect of TSIGMD varies for different modes. \\
\hline TABCD & Transmit Signalling ABCD & TABCD consists of a serial bit stream containing transmit signalling sampled at an 8 kHz rate for each of the 30 channels, applicable to the 256 S mode \\
\hline TSER & Transmit Serial & TSER is a serial bit stream containing the message data \\
\hline \multicolumn{2}{|l|}{SERIAL MODE RECEIVE OUTPUT SIGNALS•} & \\
\hline TSIGSQ & Transmit Signalling Square & TSIGSQ is a \(2 / 3 \mathrm{kHz}\) square wave aligned to cause certain per-channel codecs to insert A and B signalling into TSER. \\
\hline TSQ1-TSQ5 & Transmit Sequence Code Bits 1-5 & TSQ1-TSQ5 represent the transmit sequence codes with coding identical to RSQ When TSA is high, these transitions occur an additional bit time earlier \\
\hline \multicolumn{2}{|l|}{PARALLEL MODE TRANSMIT INPUTS:} & \\
\hline T1-T8 & Transmit Channel Data Bits 1-8 & T1-T8 are sampled by the rising edge of the TCLK These inputs should be applied when TCHCLK is low \\
\hline
\end{tabular}

R8070 Input/Output Signal Characteristics (Continued)
\begin{tabular}{|c|c|c|}
\hline Mnemonic & Definition & Function \\
\hline \multicolumn{2}{|l|}{FRAMING MODE DEPENDENT TRANSMIT INPUT SIGNALS:} & \\
\hline TDATIS (IC) & Transmit Data Ones & A high level on TDATIS triggers the transmission of all ones in tıme slot 16. \\
\hline TLNKMD (ID) & Transmit Lınk Mode & A one or zero level on TLNKMD selects between data or Link information to be transmitted in TS16 (applicable to 256 N mode). \\
\hline TA(C), TB(D), IA, IB & Transmit TA(C) and & These signals provide \(A(C)\) and \(B(D)\) robbed-bit signalling \\
\hline & TB(D) Signalling & \(A\) and \(B\) are selected when TSIGSEL \(=0\). \(C\) and \(D\) are selected when TSIGSEL \(=1\). \\
\hline & & These conditions are applicable to the 193E. \\
\hline TA, TB, IA and IB & Transmit A and B Signailing & TA and TB are sampled at the beginning of a channel time to provide \(A\) and \(B\) robbedbit signalling (applicable to the 193S and 197S modes). \\
\hline TIBITS, TNBITS, TXBITS & Transmit international, national and extra bits & These signals allow the transmission of the international, national and extra bits Applicable to modes 256 S\&N. \\
\hline TFSIG (ID) & Framing-Bit Signal & TFSIG input provides the \(F_{T}\) and \(F_{S}\) bits (mode dependent) The input is sampled concident with the sampling of channel one parallel data. \\
\hline TLINK (IC) & Transmit Link & Provides a serial data link input at etther 4, 32, or 64 Kbps , depending on mode (equivalent to the rates on RLINK). \\
\hline YELMD (IC) & Yellow Alarm & YELMD input selects method for Transmission and detection of yellow Alarm if low, yellow Alarm will be transmitted as the inhibit of bit 2 If high, yellow Alarm is identified as the \(F_{S}\) bit for frame 12 \\
\hline TSBIT (IA) & Transmit S-bit & In modes 193 N and 197N, this input is sampled to provide the transmitted S-bit to control the S-bit transmission \\
\hline \multicolumn{2}{|l|}{FRAMING MODE DEPENDENT TRANSMIT OUTPUT SIGNALS:} & \\
\hline TTS16 (OJ) & Transmit Tıme Slot 16 & Actıve for 8 bit tımes prıor to the sampling of TS16 data at TSER. \\
\hline TMFA (OH) & Transmit Multiframe Alignment & TMFA is active during sampling of data for frames contaınıng the multiframe alıgnment sıgnal \\
\hline TNSYNC & Transmit National Bit-Sync & TNSYNC is active-high during samplıng of the natıonai bits (bits 4 through 8) of TSO for frames not containıng frame alignment \\
\hline TFGEN (OJ) & Framing-Bit Generator & This signal is the composite framing pattern generator. It is the result of multiplexing externally-supplied S-bit data with the internally-generated framing pattern, the data link and the CRC check bits appropriate to the operating mode \\
\hline TFR24 (OE) & Transmit Frame 24 & A high level on TFR24 indicates that frame 24 is being processed. \\
\hline TLCLK (OH) & Transmit Lınk Clock & TLCLK represents a square clock at the data rate of TLINK. \\
\hline TSBCLK (OE) & Framıng-Bit Generator & TSBCLK is a 4 kHz square wave whose rising edge occurs two bit times after the TSBIT input has been sampled. \\
\hline TSIGSEL (OE) & Transmit Signalling Select & When low, it indicates that \(A\) and \(B\) channels are being sampled When high, it indicates that \(C\) and \(D\) channels are being sampled Transitions coincide with the sampling time of the "F" bits \\
\hline
\end{tabular}


Power Up Timing Requirement


North American 193 Mode Receive Synchronization Timing

RCLK



European Receive Synchronization Timing

RCHCLK \(\qquad\)

R1-R8 CHANNEL 23 CHAC CHANNEL 1
\[
\text { RSER } \times 1 \times 2 \times 3 \times 4 \times 5 \times 6 \times 7 \times 8 \times 1 \times 2 \times 3 \times 4 \times 5 \times 6 \times 7 \times 8 \times F \times 1 \times 2 \times 3 \times 4 \times 5 \times 6 \times 7 \times 8 \times 1 \times 2 \times
\]


RCHSYNC \(\qquad\)

NOTE: ABOVE TIMING IS APPLICABLE
TO ALL 193 MODES.

Parallel Mode Receive Signals Timing


197 Mode Receive Sequence Code Timing


National and International Bit Timing


RTS16


256N Mode Receive Link Data Timing


\section*{FRAMING MODE SUMMARY}

The framing mode dependent signals are summarized in the table below. Inputs IA-ID and output OA-OJ are functionally related to the various modes of operation as previously discussed.

\section*{Framing Mode-Dependent Signals}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline Inputs & \multicolumn{8}{|c|}{Modes} \\
\hline & 193N & 1935 & 197N & 197S & 193E & 193F & 256N & \(256 S\) \\
\hline IA & TSBIT & TA & TSBIT & TA & TA(C) & * & TIBITS & TIBITS \\
\hline IB & & TB & & TB & TB(D) & * & TNBITS & TNBITS \\
\hline IC & & YELMD & TLINK & TLINK & TLINK & TLINK & TLINK & tDAIS \\
\hline ID & TFSIG & TFSIG & TFSIG & TFSIG & TFSIG & TFSIG & TLNKMD & TXBITS \\
\hline Outputs & \multicolumn{8}{|c|}{Modes} \\
\hline OA & RSIG & RSIG & RSIG & RSIG & RSIG & RMFA & RTS16 & RTS16 \\
\hline OB & RSBIT & RSBIT & RSBIT & RSBIT & RSIGBD & ** & RIBITS & RMFA \\
\hline OC & RSBCLK & RSBCLK & RSBCLK & RSBCLK & RSIGCD & CKERR & RLINK1 & RMRED \\
\hline OD & FERR & FERR & FERR & FERR & ERR & FERR & FERR & FMERR \\
\hline OE & TSBCLK & SERR & TSBCLK & SERR & TSIGSEL & TFR24 & RNBITS & RNBITS \\
\hline OF & MS1 & MS1 & RLINK & RLINK & RLINK & RLINK & RLINK & RMYEL \\
\hline OG & MS2 & MS2 & RLCLK & RLCLK & RLCLK & RLCLK & RLCLK & RXBITS \\
\hline OH & ** & ** & TLCLK & TLCLK & TLCLK & TLCLK & TLCLK & TMFA \\
\hline OJ & TFGEN & TFGEN & TFGEN & TFGEN & TFGEN & TFGEN & TTS16 & TTS 16 \\
\hline
\end{tabular}

\section*{INPUT/OUTPUT SETUP/HOLD TIMES}

Input/Output Setup/Hold Times
\begin{tabular}{|l|c|c|}
\hline \begin{tabular}{c} 
Output \\
(Transmitter/Receiver)
\end{tabular} & \begin{tabular}{c} 
Maximum \\
Delay
\end{tabular} & Unit \\
\hline \begin{tabular}{l} 
(Measured from rising edge \\
of clock unless stated \\
otherwise)
\end{tabular} & 100 & ns \\
\hline Input (Transmitter/Receiver) & \begin{tabular}{c} 
Minımum \\
Setup \\
Tıme
\end{tabular} & Unit \\
\hline Input Setup and Hold Times & 60 & ns \\
\hline
\end{tabular}

\section*{Timing Requirements}
\(t_{\text {UPH }}\) (power up hold time) \(=16\) clock periods minimum
\(\mathrm{t}_{\text {SQS }}\) (TSQ setup time) \(=1\) clock period or 2 depending on TSA
\(t_{\text {DST }}(\) transmit data setup time \()=60 \mathrm{~ns}\) minimum
\(t_{R D}\) (receive data ouput delay) \(=100 \mathrm{~ns}\) maximum \(t_{\text {SNW }}(\) RSYNC pulse width) \(=1\) clock period \(t_{\text {RW }}\) (write inhibit pulse width) \(=2\) clock periods typical \(\mathrm{t}_{\text {SNW }}\) (RSYNC pulse width) \(=1\) clock period typical \(t_{\text {SQA }}\) (TSQ advance time) \(=1\) clock period \(t_{D O D}\) (transmit data output delay) \(=100 \mathrm{~ns}\) maximum \(t_{\text {RST }}\) (receive input setup time) \(=60 \mathrm{~ns}\) minimum \(\mathrm{t}_{\mathrm{RHT}}\) (receive input hold time) \(=60 \mathrm{~ns}\) minimum

\section*{MAXIMUM RATINGS*}
\begin{tabular}{|l|c|c|c|}
\hline Parameter & Symbol & Value & Unit \\
\hline Supply Voltage & \(\mathrm{V}_{\mathrm{CC}}\) & +4.75 to 5.25 & Vdc \\
\hline \begin{tabular}{l} 
Operating Temperature \\
Commercial \\
Industrial
\end{tabular} & \(\mathrm{T}_{\mathrm{OPC}}\) & \begin{tabular}{c}
0 to +70 \\
-40 to +85
\end{tabular} & \({ }^{\circ} \mathrm{C}\) \\
\hline Storage Temperature & \(\mathrm{T}_{\mathrm{OPI}}\) & -55 to +150 & \({ }^{\circ} \mathrm{C}\) \\
\hline
\end{tabular}
*NOTE: Stresses above those listed may cause permanent damage to the device. This is a stress rating only and functional operation of the device at these or any other conditions above those indicated in the other sections of this document is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

\section*{ELECTRICAL CHARACTERISTICS}
\begin{tabular}{|c|c|c|c|c|c|}
\hline Parameter & Symbol & Min & Max & Unit & Test Condition \\
\hline Input Logic "1" Voltage & \(\mathrm{V}_{\mathrm{IH}}\) & 2.0 & \(V_{c c}+0.3\) & V & \\
\hline Input Logic " 0 ' Voltage & \(\mathrm{V}_{\text {IL }}\) & - & 08 & V & \\
\hline Output Logic "1" Voltage & \[
\begin{gathered}
\mathrm{T} 2 \mathrm{~L} \\
\mathrm{~V}_{\mathrm{OH}} \mathrm{CMOS}
\end{gathered}
\] & \[
\begin{aligned}
& 24 \\
& 35
\end{aligned}
\] & - & V & \[
\begin{aligned}
& I_{\text {LOAD }}=-16 \mathrm{~mA} \\
& \mathrm{I}_{\text {LOAD }}=-100 \mu \mathrm{~A}
\end{aligned}
\] \\
\hline Output Logic "0' Voltage & \(\mathrm{V}_{\mathrm{OL}}\) & - & 04 & V & \(I_{\text {LOAD }}=+1.6 \mathrm{~mA}\) \\
\hline Output Source Current & IOH & -100 & & \(\mu \mathrm{A}\) & \(\mathrm{V}_{\mathrm{OH}}=2.4 \mathrm{~V}\) \\
\hline Output Sink Current & \(\mathrm{IOL}^{\text {L }}\) & & +1.6 & mA & \(\mathrm{V}_{\mathrm{OL}}=04 \mathrm{~V}\) \\
\hline Clock Frequency & \(\mathrm{T}_{\text {CLK }}\) & 100 kHz & 2.049 & MHz & \\
\hline Input Capacitance & \(\mathrm{C}_{\text {IN }}\) & & 5 & pF & \\
\hline Output Capacitance & \(\mathrm{C}_{\text {OUt }}\) & & 50 & pF & \\
\hline Power Dissipation & \(\mathrm{P}_{\text {WD }}\) & & 100 & mw & \\
\hline
\end{tabular}

\section*{REFERENCE DATA}

For detail information refer to the R8070 T-1/CEPT PCM Transceiver Designer's Guide. Order Number 313.

\section*{PACKAGE DIMENSIONS}

\section*{64 PIN PLASTIC QUIP}

\begin{tabular}{|c|c|c|c|c|}
\hline \multirow[b]{2}{*}{DIM} & \multicolumn{2}{|l|}{MILLIMETERS} & \multicolumn{2}{|l|}{INCHES} \\
\hline & MIN & MAX & MIN & MAX \\
\hline A & 4115 & 4166 & 1620 & 1640 \\
\hline B & 1702 & 1753 & 0670 & 0690 \\
\hline C & 305 & 456 & 0120 & 0180 \\
\hline D & 038 & 051 & 0024 & 0020 \\
\hline \(F\) & 127 & BSC & 0050 & BSC \\
\hline G & 254 & BSC & 0100 & BSC \\
\hline H & 102 & 114 & 0040 & 0045 \\
\hline J & - & \(7^{\circ}\) & - & \(7{ }^{\circ}\) \\
\hline K & 279 & 432 & 0110 & 0170 \\
\hline L & 1892 & 1981 & 0745 & 0755 \\
\hline M & 2337 & 2362 & 0920 & 0930 \\
\hline
\end{tabular}


\section*{SEMICONDUCTOR PRODUCTS DIVISION REGIONAL ROCKWELL SALES OFFICES}

HOME OFFICE
Semiconductor Products Division
Rockwell International
4311 Jamboree Rd
P.O Box C, MS 501-300

Newport Beach, CA 92658-8902
(714) 833-4700

TWX. 910 591-1698
UNITED STATES
Semiconductor Products Division
Rockwell International
1842 Reynolds
Irvine, CA 92714
714) 833-4655

ELS 62108710
TWX 910 595-2518
Semiconductor Products Division
Rockwell International
3375 Scott Blvd., Suite 410
Santa Clara, CA 95054
(408) 980-1900

TLX 756560

Semiconductor Products Division
Rockwell International
2001 N. Collins Blvd., Suite 103
Richardson, TX 75080
(214) 996-6500

TLX. 501258
TWX: 910 997-6855
Semiconductor Products Division
Rockwell International
10700 West Higgıns Rd, Suite 102
Rosemont, IL 60018
(312) 297-8862

TWX 910 233-0179 (RI MED ROSM)
Semiconductor Products Division
Rockwell International
5001 B Greentree
Executive Campus, Rt 73
Marlton, NJ 08053
(609) 596-0090

TWX 710 940-1377

EUROPE
Semiconductor Products Division Rockwell International GmbH
Fraunhoferstrasse 11B
D-8033 Munchen-Martinsried
Germany
089) 857-6016

Telex' 0521/2650 rimd d
Semiconductor Products Division
Rockwell International LImited
Heathrow House, Bath Rd.
Cranford, Hounslow,
Middlesex, England TW5 9QW
(01) 759-2366

Telex• 851-25463
Semiconductor Products
Rockwell Collins Italiana S.P.A.
Via Boccaccio, 23
20123 Milano, Italy
(39-2) 498-7479
Telex 316562 RCIMIL

Semiconductor Products Division
Rockwell International
Immeuble de Bureaux Evry 2
523, Place des Terasses
91034 Evry Cedex, France
0782888

\section*{FAR EAST}

Semiconductor Products Division
Rockwell International
Overseas Corp.
Itohpia Hirakawa-cho Bldg
7-6, 2-chome, Hirakawa-cho
Chiyoda-ku, Tokyo 102, Japan
(03) 265-8806

Telex. J22198
Rockwell-Collins Int'l.
Tas Sang Commercial Bidg
11th Floor
23-34 Hennessy Rd.
Hong Kong
(5) 274-321

TLX. 74071 HK

UNITED STATES / CANADA SALES REPRESENTATIVES


IDAHO
Caruso \& Northcutt
(See Bellevue, Washington)
ILLINOIS
Rosemont
Rockwell Internatıonal
(312) 297-8862

INDIANA
Fort Wayne
Robert O Whitesell \& Associates (219) 432-5591

Indianapolis
Robert O Whitesell \& Associates (317) 359-9283

Kokomo
Robert O Whitesell \& Associates (317) 457-9127

\section*{IOWA}

Cedar Rapids
Dy-Tronix Inc
(319) 377-8275

KANSAS
Dry-Tronix Inc.
(See Cedar Rapids, lowa)
(See Bridgeton, Missouri)
KENTUCKY
Loussville
Robert O Whitesell \& Associates (502) 426-7696

LOUISIANA
Robert O. Whitesell \& Associates (See Huntsville, Alabama)

\section*{MAINE}

Kitchen \& Kutchin, Inc.
(See Burlington, Massachusetts)
MARYLAND
Mt. Airy
Beacon North, Inc
(703) 591-1300
(800) 336-3747 (MD)

Randalistown
Beacon North, Inc
(800) 336-3747 (MD, DE)
(703) 591-1300

Currie, Peak and Frazier, Inc
(404) 449-7662

MASSACHUSETTS
Burlington
Kitchen \& Kutchin, Inc
(617) 229-2660

\section*{MICHIGAN}

Grand Rapids
Robert O. Whitesell \& Associates
(616) 942-5420

\section*{Southfield}

Robert O Whitesell \& Associates
(313) 559-5454

St. Joseph
Robert O Whitesell \& Associates
(616) 983-7337

\section*{MINNESOTA}

Eden Prairie
Electronic Innovators, Inc
(612) 941-0830

\section*{MISSISSIPPI}

Robert O. Whitesell \& Associates
(See Huntsville, Alabama)
MISSOURI
Bridgeton
Dy-Tronıx Inc
(314) 291-4777
ndependence
Dy-Tronix Inc
(816) 373-6600

\section*{MONTANA}

Rockwell International
(See Rosemont, llinois)
NEBRASKA
Rosemont
Semiconductor Products Division
Rockwell International
(312) 297-8862

\section*{NEVADA}

Thresum Associates, Inc.
(See Cupertıno, California)
NEW HAMPSHIRE
Kitchen \& Kutchin, Inc.
(See Burlıngton, Massachusetts)

\section*{NEW JERSEY}

Boonton
PAF Associates, Inc
(201) 335-0680

Mariton
Naudaın Assoc, Inc
(609) 983-5300

NEW MEXICO
Albuquerque
Hecht Henschen \& Associates
(505) 821-3979

\section*{NEW YORK}

Rochester
Ossmann Component Sales Corp
(716) 424-4460

\section*{Syracuse}

Ossmann Component Sales Corp
(315) 455-6611

Smithtown, L.I
PAF Associates, Inc
(516) 360-0940

\section*{Vestal}

Ossmann Component Sales Corp
(607) 754-3264

\section*{NORTH CAROLINA}

\section*{Greensboro}

Currie, Peak and Frazier, Inc
(919) 373-0380

NORTH DAKOTA
Rockwell International
(See Rosemont, Illinois)
OHIO
Cincinnati
Robert O Whitesell \& Associates
(513) 521-2290

Cleveland
Robert O Whitesell \& Associates
(216) 447-9020

Columbus
Robert O Whitesell \& Associates
(614) 888-9396

Dayton
Robert O Whitesell \& Associates
(513) 298-9546

OKLAHOMA
Tulsa
Norcom, Inc
(810) 802-7747

\section*{SALES REPRESENTATIVES (Continued)}

\section*{PENNSYLVANIA}

Naudain Assoc., Inc.
(See Mariton, New Jersey)
Plttsburgh
Robert O. Whitesell \& Associates (412) 963-6161

RHODE ISLAND
KItchen \& Kutchin, Inc.
(See Burlington, Massachusetts)

\section*{SOUTH CAROLINA}

Columbla
Currie, Peak and Frazier, Inc. (803) 254-1971

SOUTH DAKOTA
Rockwell Internationa
(See Rosemont, Illinois)
TENNESSEE
Knoxville
Robert O. Whitesell \& Associates
(615) \(694-9476\)
TEXAS
Austin
Norcom, Inc.
(512) \(451-2757\)
Dallas
Norcom, Inc.
(214) \(386-4888\)
Houston
Norcom, inc.
(713) 778-0392
UTAH
Quorum 3
(See Denver, Colorado)

\section*{NNESSE}

Robert O. Whitesell \& Associates (615) 694-9476

TEXAS
Austin
Norcom, Inc.
(512) 451-2757

Dallas
Norcom, Inc.
Houston
Norcom, Inc.
(713) 778-0392

Quorum 3
(See Denver, Colorado)

VERMONT
Kltchen \& Kutchin, Inc. (See Burlington, Massachusetts)

\section*{VIRGINIA}

Fairfax
Beacon North, Inc.
(703) 591-1300
(800) 336-3747 (MD DEL)

Forest
Beacon North, Inc.
(804) 239-8486

WASHINGTON, D.C.
Beacon North, Inc.
(See Fairfax, Virginia)

WEST VIRGINIA
Robert O. Whitesell \& Associates
(See Cincinnati, Ohio)
WISCONSIN
Wauwatosa
Larsen Associates Inc
(414) 258-0529

\section*{WYOMING}

Quorum 3
(See Denver, Colorado)
CANADA
Willowdale, Ontario
Renmark Electronics Limited
(416) 494-5445

\section*{Nepean, Ottawa}

Renmark Electronics Limited
(613) 727-0320

\section*{INDUSTRIAL DISTRIBUTORS UNITED STATES / CANADA}

\section*{UNITED STATES}

\section*{ALABAMA}

Huntsville
Hamilton/Avnet Electronics
(205) 837-7210

\section*{Huntsville}

Contact Electronics
(205) 881-9321

\section*{ARIZONA}

\section*{Scottsdale}

Western Micro Technology Inc (602) 948-4240

\section*{Tempe}

Hamilton/Avnet Electronics (602) 231-5100

\section*{Tempe}

Bell industries
(602) 966-7800

\section*{CALIFORNIA}

Chatsworth
Hamilton/Avnet Electronics (818) 700-6500

Chatsworth
Hamilton Electro Sales (818) 700-2600

\section*{Costa Mesa}

Avnet Electronics
(714) 754-6111

\section*{Costa Mesa}

Hamilton Electro Sales OC
(714) 641-4100

Culver City
Hamilton Electro Sales
(213) 558-2121

\section*{Culver City}

Hamilton/Avnet Electronics
(213) 558-2441

Cupertino
Western Micro Technology Inc
(408) 725-1660

Garden Grove
Bell Industries
(714) 220-0681

Sacramento
Hamilton/Avnet Electronics (916) 925-2216

San Diego
Hamilton/Avnet Electronics (619) 571-7510

Sunnyvale
Bell Industries
(408) 734-8570

\section*{Sunnyvale}

Hamilton/Avnet Electronics
(408) 743-3355

\section*{Santee}

Mouser Electronics
(619) 449-2229

Thousand Oaks
Bell Industries
(805) 499-6821

\section*{Torrance}

Hamilton/Avnet Electronics
(213) 615-3931

Tustin
Image Electronics
(714) 730-0303
colorado
Inglewood
Hamilton/Avnet Electronics
(303) 740-1000

Wheatridge
Bell Industries, Inc
(303) 424-1985

\section*{CONNECTICUT}

Danbury
Hamilton/Avnet Electronics
(203) 797-2800

East Haven
JV Electronics
(203) 469-2321

\section*{Hamden}

Almo Electronics
(203) 288-6556

\section*{FLORIDA}

Fort Lauderdale
Hamilton/Avnet Electronics
(305) 971-2900

Largo
Graham Electronics
(813) 541-4433

\section*{Orlando}

Hammond Electronics
(305) 849-6060

St. Petersburg
Hamilton/Avnet Electronics
(813) 576-3930

Winter Park
Hamilton/Avnet Electronics
(305) 628-3888

\section*{GEORGIA}

Norcross
Hamilton/Avnet Electronics
(404) 447-7500

\section*{Norcross}

Hammond Electronics
(404) 449-1996

\section*{ILLINOIS}

Bensenville
Hamilton/Avnet Electronics (312) 860-8522

\section*{Chicago}

Bell Industries
(312) 982-9210

\section*{Rosemont}

Advent Electronics
(312) 298-4210

\section*{INDIANA}

\section*{Carmel}

Hamilton/Avnet
(317) 844-9333

Fort Wayne
Graham Electronics
(219) 423-3422

Indianapolis
Advent Electronics
(317) 872-4910

Indianapolis
Graham Electronics
(317) 634-8202

\section*{IOWA}

Cedar Rapids
Advent Electronics
(319) 363-0221

KANSAS
Cedar Rapids
Bell Industries
(319) 395-0730

Overland Park
Hamilton/Avnet Electronics
(913) 888-8900

\section*{MARYLAND}

Columbia
Hamilton/Avnet Electronics (301) 995-3550

\section*{Hopkinton}

Interface Electronics Corp (617) 435-6858

\section*{Rockville}

Almo Electronics Corp
(301) 792-9197

\section*{MASSACHUSETTS}

Canton
Almo Electronics
(617) 821-1450

Westboro
Future Electronics Corp
(617) 366-2400

Wilmington
R C Components, Inc
(617) 273-1860

Woburn
Hamilton/Avnet Electronics
(617) 273-7500

MICHIGAN
Farmington Hills
Advent Electronics
(313) 477-1650

Grand Rapids
Hamilton/Avnet Electronics
(616) 243-8805

\section*{Livonia}

Hamilton/Avnet Electronics
(313) 522-4700

Livonia
Reptron
(313) 525-2700

MINNESOTA

\section*{Fridley}

Voyager Electronics Corporation
(612) 571-7766

Minnetonka
Hamilton/Avnet Electronics
(612) 932-0600

MISSOURI
Earth City
Hamilton/Avnet Electronics
(314) 344-1200

\section*{NEW JERSEY}

\section*{Berlin}

General Components, Inc (609) 768-6767

\section*{Bloomingdale}

Pan American Electronics
(201) 839-0077

Cherry Hill
Hamilton/Avnet Electronics
(609) 424-0110

Fairfield
Hamilton/Avnet Electronics
(201) 575-3390

Fairfield
Semispecialists of America Inc (201) 227-7444

\section*{NEW MEXICO}

Albuquerque
Hamilton/Avnet Electronics
(505) 765-1500

Albuquerque
Bell Industries
(505) 292-2700

\section*{NEW YORK}

East Syracuse
Hamilton/Avnet Electronics
(315) 437-2641

Hauppauge, LI
Hamilton/Avnet Electronics
(516) 231-9800

Farmingdale
Semispecialists of America Inc
(516) 293-2710

Liverpool
Future Electronics
(315) 451-2371

Rochester
CAM/RPC
(716) 865-2080

Rochester
Hamilton/Avnet Electronics
(716) 475-9140

\section*{NORTH CAROLINA}

\section*{Greensboro}

Hammond Electronics
(919) 275-6391

\section*{Raleigh}

Hamilton/Avnet Electronics
(919) 878-0810

\section*{OHIO}

Cincinnati
Graham Electronics
(513) 772-1661

\section*{Cleveland}

CAM/RPC
(216) 461-4700

\section*{Cleveland}

Hamilton/Avnet Electronics
(216) 831-3500

\section*{Columbus}

Graham Electronics
(614) 895-1590

Dayton
Hamilton/Avnet Electronics
(513) 433-0610

\section*{Dayton}

Bell Industries
(513) 434-8231

Westerville
Hamilton/Avnet Electronics
(614) 436-4158

\section*{OKLAHOMA}

Tulsa
Quality Components, Inc
(918) 664-8812

\section*{INDUSTRIAL DISTRIBUTORS (Continued)}

\section*{OREGON}

Beaverton
Western Micro Technology Inc (503) 629-2082

\section*{Lake Oswego}

Bell Industries
(503) 241-4115

Lake Oswego
Hamilton/Avnet Electronics
(503) 635-8157

PENNSYLVANIA
Philadelphia
Almo Electronics
(215) 698-4000

Pittsburgh
Almo Electronics
(412) 931-5990

Pittsburgh
CAM/RPC
(412) 782-3770

York
EC.I
(717) 843-8971

\section*{TENNESSEE}

Nashville
Graham Electronics
(615) 242-2682

TEXAS
Addison
Quality Components, Inc. (214) 733-4300

\section*{Austin}

Quality Components, Inc.
(512) 835-0220

\section*{Austin}

Hamilton/Avnet Electronics (512) 837-8911

Irvine (Dallas)
Hamilton/Avnet Electronics
(214) 659-4111

Houston
Hamilton/Avnet Electronics
(713) 780-1771

Sugarland
Quality Components, Inc (713) 491-2255

UTAH
Salt Lake City
Hamilton/Avnet Electronics
(801) 972-2800

WASHINGTON

Bellevue
Bell Industries
(206) 747-1515

Bellevue
Hamilton/Avnet Electronics
(206) 643-3950

Redmond
Western Micro Technology Inc (206) 881-6737

\section*{WISCONSIN}

Milwaukee
Industrial Electronics Corp (414) 276-1212

New Berlin
Hamilton/Avnet Electronics
(414) 784-4510

Waukesha
Bell Industries
(414) 784-0235

CANADA
Caigary, Alberta
Cardinal Industrial Electronics Ltd
(403) 259-6817

Calgary, Alberta
Hamilton/Avnet Electronics
(403) 230-3586

Downsview, Ontario
Future Electronics Inc.
(416) 663-5563

Edmonton, Alberta
Cardinal Industrial Electronics Ltd.
(403) 483-6266

Mississauga, Ontario
Hamilton/Avnet Electronics
(416) 677-7432

Montreal, Quebec
Future Electronics Inc
(514) 694-7710

Nepean, Ontario
Hamilton/Avnet Electronics
(613) 226-1700

Ottawa, Ontario
Future Electronics Inc (613) 820-8313

St. Laurent, Montreal, Quebec
Hamilton/Avnet Electronics Ltd. (514) 335-1000

Toronto, Ontario
Canadian General Electric
(416) 530-2921

Vancouver, B.C.
Future Electronics, Inc
(604) 438-5545```


[^0]:    *With external pullup resistor of $1.1 \mathrm{k} \Omega$

[^1]:    SISR
    4 CTSLVL -Clear to Send Level.
    CTS input level is negated (high).
    CTS input level is asserted (low).

[^2]:    $\overline{\text { RES }}$
    The $\overline{\text { RES }}$ active-low input signal initializes all internal scan counter circuits. When $\overline{\text { RES }}$ is low, all internal counters stop and clear, all scan and videc outputs go low and control registers are unaffected. $\overline{\text { RES }}$ must stay low for at least one CCLK period. All scan timıng inıtiates when $\overline{\text { RES }}$ goes high. In this way, $\overline{\text { RES }}$ can synchronize display frame timing with line frequency. $\overline{\text { RES }}$ may also synchronize multiple CRTC's in horizontal and/or vertical split screen operatıon.

[^3]:    MC

    UM(T) —Update/Read Mode (Transparent Mode)
    Update occurs during horizontal and vertical blanking times with update strobe.
    Update interleaves during $\varnothing 2$ portion of cycle.
    MC
    US(T) —Update Strobe (Transparent Mode)
    Pin 34 functions as memory address.
    Pin 34 functions as memory address.

    MC
    $\frac{5}{0}$

    ## CSK -Cursor Skew

    No delay
    1 Delays Cursor one character time.
    MC
    $\begin{array}{ll}\frac{4}{0} & \text { DES -Display Enable Skew }\end{array}$
    1 Display Enable delays one character time.

[^4]:    TIMING (TIM)
    RESET LEFT ( $\overline{\mathrm{RL}} / \mathrm{RL}$ )
    RESET RIGHT ( $\overline{R R}$ )

[^5]:    Notes:
    **RESET $=$ Register contents upon power up or $\overline{\text { RES }}$.

[^6]:    RSR

    | 7 | RDA -Receiver Data Available. (RSR only). |
    | :--- | :--- |
    | The RxFIFO is empty (i.e., no received data is |  |


    | RSR |  |
    | :---: | :---: |
    | 6 <br> 0 | EOF |
    | 1 | 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. No CRC or parity error detected. |
    | 0 |  |
    | 1 | CRC error detected (BOP, BSC), Parity error detected |
    | 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 |  |  |
    | :---: | :---: | :--- |
    | $\frac{1}{1}$ | RA/B | -Receiver Abort/Break. |
    | 1 | Normal Operation. |  |
    |  | ABORT detected after an opening flag (BOP), ENQ <br> detected in a block of text data (BSC), or BREAK ended |  |
    |  | (ASYNC). |  |


    | RSR |  |
    | :---: | :---: |
    | $\mathbf{0}$ <br> 0 | RIDLE $\quad$ Receiver not idle. |
    | 1 | 15 or more consecutive " 1 ' $s$ " have been received and <br> 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}$ | $\mathbf{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 | 0 | RABEN | RRES |

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

    | $\begin{gathered} \text { RCR } \\ 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 $\overline{\text { DSR }}$. |
    | RCR |  |
    | 3 | STRSYN -Strip SYN Character (COP only). |
    | 0 | Do not strip SYN character. |
    | 1 | Strip SYN character. |
    | RCR |  |
    | 2 | MUST BE ZERO |
    | 0 |  |

    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
    $\begin{array}{ll}0 & \text { RRES } \quad \text {-Receiver Reset Command. } \\ 0 & \text { Enable normal receiver operation. }\end{array}$
    1 Reset receiver. Resets the receiver section including the RxFIFO and the RSR (but not the RCR). RRES is set by 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 RES.

    Receiver Data Register (RDR)

    | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
    | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
    | MSB | Received Data (RxFIFO) |  |  |  |  |  |  |

    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 .

    Recelver 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 $=\$ 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

    | $\mathbf{7}$ | RDA IE | -Receiver Data Avallable Interrupt <br> Enable. |
    | :---: | :---: | :---: |
    | 0 | Disable RDA Interrupt. |  |
    | 1 | Enable RDA Interrupt. |  |
    | RIER |  |  |
    | $\frac{6}{6}$ | EOF IE | Disable EOF Interrupt. |
    | 1 | Enable EOF Interrupt. |  |

    ## RIER

    $5 \quad$-Not used.

    ```
    RIER
    4
        Disable C/PERR Interrupt.
        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.
    O 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```

