



# R65C00/21 DUAL CMOS MICROCOMPUTER AND R65C29 DUAL CMOS MICROPROCESSOR

## PRELIMINARY INTRODUCTION

### FEATURES

- Two enhanced CMOS R6502 CPU's in one device
  - Common memory and I/O
  - Shared data and subroutines
  - Independent CPU registers and interrupt vectors
  - Independent reset operation and programs
  - R6502 software and timing compatible
- 10 new instructions for faster and smaller programs
  - Unsigned Multiply (MUL)
  - Set and Reset Memory Bit (SMB and RMB)
  - Branch on Bit Set and Reset (BBS and BBR)
  - Unconditional Branch (BRA)
  - Push and Pull Index Registers (PHX, PHY, PLX, PLY)
- Microcomputer/microprocessor/peripheral controller operation
  - Stand-alone microcomputer
    - 2048 × 8 mask programmable ROM
    - 128 × 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 MHz/128)
- System clock rates from 10 KHz to 4 MHz
- 5V ± 10% power supply
- 64-pin QUILP

3

### 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 Read-Only Memory (ROM), 128 bytes of Random Access Memory (RAM) and versatile interface circuitry. The interface circuitry consists of two multimode programmable 16-bit counter/timers and 52 general purpose input/output lines. Some of these input/output lines may be used as address, data and control lines for expanded systems or as data and control lines when the R65C00/21 is used as a programmable peripheral controller.

The two CPU's in the R65C00/21 are functionally independent. Each has its own set of registers, its own reset and interrupt vectors and operates under control of its own program. The two CPU's do, however, share the same memory and system I/O resources. This allows direct communication between the two CPU's and allows sharing of subroutines and common data areas where desired. Programming and system design for applications which require simultaneous control of two or more independent asynchronous processes is thus simplified because one CPU may control one process while the other controls

another one. Consequently, complex programming usually needed to interleave the control functions or to implement an interrupt driven system, is not required.

In a multiple computer approach, both processors may need the same subroutines so that some portions of memory must be duplicated in both systems. The dual CPU's share the same program memory, therefore only one set of subroutines is required and both CPU's may even be using them at the same time without interference.

In addition to the dual CPU's, the R65C00/21 also has the innovative architecture and the demonstrated high performance of the well established R6502 CPU, flexible input/output which provides improvements over the R6522 Versatile Interface Adapter (VIA) device, and production efficient on-chip ROM and RAM. These features make the R65C00/21 a leading candidate for most imbedded microcomputer applications.

A system using the R65C00/21 Dual CMOS Microcomputer will be simpler in design, use less program memory, require fewer components, reduce circuit board sizes, simplify test requirements, and minimize field maintenance—all contributing to lower production and support costs. In addition, simpler designs shorten development effort and time—leading to reduced development costs and faster product to market.

The R65C29 Dual CMOS Microprocessor, a ROM-less version of the R65C00/21 with permanently extended data and address bus, is also available. The R65C29 is ideal for dual CPU applications requiring changeable ROM and/or extended RAM, ROM or I/O, and can also be used for R65C00/21 prototype circuit development. The R65C00/21 can also operate in an emulation mode, like the R65C29, with its internal ROM disabled.

## DEVELOPMENT SYSTEM SUPPORT

Prototype circuit and software development support are available using the Rockwell Design Center (RDC) and R65C00/21 Personality Module. Program development and debugging aids such as text editing, symbolic assembly with conditionals and macros at the absolute and relocatable/linking level, and single/multiple step execution with instruction/data tracing are provided. Real-time in-circuit emulation in the target environment is also supported.

### NOTE

All descriptions of R65C00/21 operation in this document also apply to the R65C29 except for internal ROM, and as otherwise noted.

## ORDERING INFORMATION

The R65C00/21 Dual CMOS Microcomputer can be ordered in volume quantities with the following speed capability and mask option indicated in the R65C00/21 ROM Code Order Form (Document Order No. 2134)

- 1, 2, 3, or 4 MHz system clock (02)
- Crystal/master clock or slaved clock input mask option

The R65C29 Dual CMOS Microprocessor has the following characteristics:

- Crystal/master clock input
- 8-bit data bus and 16-bit address bus extension
- No internal ROM

# INTERFACE

The interfaces for the R65C00/21 and R65C29 are illustrated in Figure 1.

The pin assignments for the R65C00/21 and the R65C29 are shown in Figure 2. The R65C29 pin assignments are the same as the R65C00/21 except that bus expansion functions are permanently assigned instead of general purpose ports D and E.

The interface signals for the R65C00/21 and R65C29 are described in Table 2. The descriptions of the selectable bus expansion pins (16-bit address mode) for the R65C00/21 apply to permanent bus expansion pins for the R65C29.

3



|       | XTAL0 | 1  | 64 | Vcc  |      |
|-------|-------|----|----|------|------|
| XTAL1 | 02    | 2  | 63 | RES  |      |
| QA    | EMS   | 3  | 62 | NMIA | NMIB |
| SYNC  | R/W   | 4  | 61 | PG0  | PG1  |
| PE7   |       | 6  | 60 | PG2  | PG3  |
| PE6   |       | 7  | 59 | PD0  | PD1  |
| PE5   |       | 8  | 58 | PD2  | PD3  |
| PE4   |       | 9  | 57 | PD4  | PD5  |
| PE3   |       | 10 | 56 | PD6  | PD7  |
| PE2   |       | 11 | 55 | PC0  | PC1  |
| PE1   |       | 12 | 53 | PC2  | PC3  |
| PF7   |       | 13 | 52 | PC4  | PC5  |
| PF6   |       | 14 | 51 | PC6  | PC7  |
| PF5   |       | 15 | 50 | PB0  | PB1  |
| PF4   |       | 16 | 49 | PB2  | PB3  |
| PF3   |       | 17 | 48 | PB4  | PB5  |
| PF2   |       | 18 | 47 | PB6  | PB7  |
| PF1   |       | 19 | 46 |      |      |
| PA7   |       | 20 | 45 |      |      |
| PA6   |       | 21 | 44 |      |      |
| PA5   |       | 22 | 43 |      |      |
| PA4   |       | 23 | 42 |      |      |
| PA3   |       | 24 | 41 |      |      |
| PA2   |       | 25 | 40 |      |      |
| PA1   |       | 26 | 39 |      |      |
| PA0   |       | 27 | 38 |      |      |
| Vss   |       | 28 | 37 |      |      |
|       |       | 29 | 36 |      |      |
|       |       | 30 | 35 |      |      |
|       |       | 31 | 34 |      |      |
|       |       | 32 | 33 |      |      |

  

|       | XTAL0 | 1  | 64 | Vcc   |       |
|-------|-------|----|----|-------|-------|
| XTAL1 | 02    | 2  | 63 | RES   |       |
| QA    | EMS   | 3  | 62 | NMIA  | NMIB  |
| SYNC  | R/W   | 4  | 61 | PG0   | PG1   |
| A15   | A14   | 6  | 59 | PG2   | PG3   |
| A13   | A12   | 7  | 58 | A0/D0 | A1/D1 |
| A11   | A10   | 8  | 57 | A2/D2 | A3/D3 |
| A9    | A8    | 9  | 56 | A4/D4 | A5/D5 |
| PF7   | PF6   | 10 | 55 | A6/D6 | A7/D7 |
| PF5   | PF4   | 11 | 54 | PC0   | PC1   |
| PF3   | PF2   | 12 | 53 | PC2   | PC3   |
| PF1   | PF0   | 13 | 52 | PC4   | PC5   |
| PA7   | PA6   | 14 | 51 | PC6   | PC7   |
| PA5   | PA4   | 15 | 50 | PB0   | PB1   |
| PA3   | PA2   | 16 | 49 | PB2   | PB3   |
| PA1   | PA0   | 17 | 48 | PB4   | PB5   |
| Vss   |       | 18 | 47 | PB6   | PB7   |
|       |       | 19 | 46 |       |       |
|       |       | 20 | 45 |       |       |
|       |       | 21 | 44 |       |       |
|       |       | 22 | 43 |       |       |
|       |       | 23 | 42 |       |       |
|       |       | 24 | 41 |       |       |
|       |       | 25 | 40 |       |       |
|       |       | 26 | 39 |       |       |
|       |       | 27 | 38 |       |       |
|       |       | 28 | 37 |       |       |
|       |       | 29 | 36 |       |       |
|       |       | 30 | 35 |       |       |
|       |       | 31 | 34 |       |       |
|       |       | 32 | 33 |       |       |

Figure 2. R65C00/21 and R65C29 Pin Assignments

Table 1. R65C00/21 Pin Description

| Signal Name             | Pin No. | I/O | Description                                                                                                                                                                                        |
|-------------------------|---------|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PA0-PA7                 | 31-24   | I/O | <b>Port A.</b> General purpose 8-bit I/O Port A.                                                                                                                                                   |
| PB0-PB7                 | 40-33   | I/O | <b>Port B.</b> General purpose 8-bit I/O Port B.                                                                                                                                                   |
| PC0-PC7                 | 48-41   | I/O | <b>Port C.</b> General purpose 8-bit I/O Port C. Host Data Bus in Host Mode.                                                                                                                       |
| PD0-PD7                 | 56-49   | I/O | <b>Port D.</b> General purpose 8-bit I/O Port D. Multiplexed lower address (A0 to A7) and Data Bus (D0-D7) when Bus Extension Mode is selected.                                                    |
| PE0-PE7                 | 15-8    | O   | <b>Port E.</b> General purpose 8-bit output Port E. Upper address (A8 to A11 or A8 to A15) when Bus Expansion Mode is selected.                                                                    |
| PF0-PF7                 | 23-16   | I/O | <b>Port F.</b> General purpose 8-bit I/O Port F. Under software control, each line has alternate functions as follows:                                                                             |
| PF0NEG (PF0)            | 23      | I   | <b>PF0 Positive Edge Detect.</b> Maskable CPU interrupt on PF0 Positive Transition.                                                                                                                |
| PF1POS (PF)             | 22      | I   | <b>PF1 Negative Edge Detect.</b> Maskable CPU interrupt on PF1 Negative Transition.                                                                                                                |
| PF2LOW (PF2)            | 21      | I   | <b>PF2 Low Level Detect.</b> Maskable CPU interrupt on PF2 Low (external IRQ).                                                                                                                     |
| TIMA (PF3)              | 20      | I/O | <b>Timer A External Input/Output.</b>                                                                                                                                                              |
| TIMB (PF4)              | 19      | I/O | <b>Timer B External Input/Output.</b>                                                                                                                                                              |
| HINT (PF7)              | 16      | O   | <b>Host Interrupt.</b> Active-low maskable interrupt request to Host.                                                                                                                              |
| PG0-PG3                 | 60-57   | I   | <b>Port G.</b> General purpose 4-bit input Port G. Under software control, Port G serves as the Host Control Bus as follows:                                                                       |
| H $\bar{O}$ 2/HRD (PG0) | 60      | I   | <b>Host Bus Clock/Read Strobe Input.</b> $\bar{O}$ 2 for 6500/6800 bus; Read Strobe for Z80/8080 bus.                                                                                              |
| HR/W/HWR (PG1)          | 59      | I   | <b>Host Bus Read-Write/Write Strobe Input.</b> R/W for 6500/6800 bus; Write Strobe for Z80/8080 bus.                                                                                               |
| HRS (PG2)               | 58      | I   | <b>Host Bus Register Select Input.</b> Low selects Data Buffer; high selects Status Flags.                                                                                                         |
| CS (PG3)                | 57      | I   | <b>Host Bus Active-Low Chip Select Input.</b> Low selects Host Bus operation depending on HRS and HR/W/HWR coding and Host Control and Status Register contents; high disables Host Bus interface. |
| RES                     | 63      | I   | <b>Reset.</b> Active-low Reset input initializes R65C00/21 to initial conditions—resets all registers and I/O lines.                                                                               |
| NMIA                    | 62      | I   | <b>CPU A Non-Maskable Interrupt.</b> Non-maskable negative edge sensitive interrupt input to CPU A.                                                                                                |
| NMIB                    | 61      | I   | <b>CPU B Non-Maskable Interrupt.</b> Non-maskable negative edge sensitive interrupt input to CPU B.                                                                                                |
| EMS                     | 5       | O   | <b>External Memory Strobe.</b> Active-low.                                                                                                                                                         |
| $\bar{O}$ 2             | 3       | O   | <b>System Phase 2 Clock Output.</b> Maskable as system clock input for slave operation.                                                                                                            |
| R/W                     | 7       | O   | <b>Read/Write.</b> Read/write control output. High during read, low during write.                                                                                                                  |
| SYNC                    | 6       | O   | <b>Sync.</b> Instruction sync output. High When Op Code fetched                                                                                                                                    |
| $\bar{O}$ A             | 4       | O   | <b>Phase A.</b> Phase A clock output. High during CPU A bus cycle, low during CPU B bus cycle.                                                                                                     |
| XTAL0                   | 1       | O   | <b>Crystal/Master Clock Return.</b> Output connection to crystal (or no connection if external master clock connected to XTAL1). Input frequency is two times system clock ( $\bar{O}$ 2) rate.    |
| XTAL1                   | 2       | I   | <b>Crystal/Master Clock Input.</b> Input connection from crystal (or external master clock).                                                                                                       |
| VCC                     | 64      |     | <b>Power.</b> 5.0 Vdc.                                                                                                                                                                             |
| VSS                     | 32      |     | <b>GND.</b> Signal and power ground.                                                                                                                                                               |

## FUNCTIONAL DESCRIPTION

The R65C00/21 consists of two central processor units (CPU's), a  $2048 \times 8$  read-only memory (ROM), a  $128 \times 8$  random access memory (RAM), five 8-bit parallel I/O ports, one 8-bit output port, one 4-bit input port, two 16-bit counter/timer systems, a variety of I/O control registers, and an independent interrupt control system for each CPU. All of the ROM, RAM, I/O, internal buses, and the arithmetic logic unit (ALU) are shared by the two CPU's. A memory map of the system is shown in Figure 3. An overall block diagram of the R65C00/21 is shown in Figure 4.

### NOTE

Throughout this document, unless specified otherwise, all memory or register address locations are specified in hexadecimal notation.

## INTERNAL MEMORY

### INTERNAL READ-ONLY-MEMORY (ROM)

The ROM in the R65C00/21 consists of 2048 (2K) bytes of mask programmable memory with an address space from F800 to FFFF. ROM locations FFF2 through FFFF are assigned to interrupt and reset vectors for the two CPU's.

### INTERNAL RANDOM ACCESS MEMORY (RAM)

The internal RAM consists of 128 bytes of read/write memory with assigned page zero addresses of 0080 through 00FF.

## EXTERNAL MEMORY

External memory can be addressed by selecting the Bus Expansion Mode in the Bus Control Register. Address space from 0200 through EFFF may be accessed for either RAM, ROM, or I/O purposes as the particular application requires it. In addition, there are 32 bytes from 0020 through 003F which may be used for I/O expansion and 256 bytes from 0100 through 01FF which may be external RAM.

## CPU LOGIC

Each CPU in the R65C00/21 is effectively a standard R6502 CPU with 10 extra instructions utilizing 40 operation codes which are unused in the R6502. Therefore, each CPU has an 8-bit accumulator, two 8-bit index registers (X and Y), an 8-bit Stack 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.

## ACCUMULATORS

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

## INDEX REGISTERS

Each CPU has two index registers, X and Y. Each index register may be used as a modifier to a base address supplied as a part of the instruction being processed. The resulting effective address is usually the sum of the base address plus the contents of the indicated index register. The index registers are used in a number of the addressing modes including zero page indexed, absolute indexed, post-indexed indirect and pre-indexed indirect. Each index register also has a family of instructions which allow loading, storing, incrementing, decrementing, and comparing the contents of the register. These are discussed thoroughly in the R6500 Programming Manual (Order No. 202).

| ADDRESS (HEX) |                                                                  |
|---------------|------------------------------------------------------------------|
| 0000          | I/O AND CONTROL REGISTERS                                        |
| 001F          |                                                                  |
| 0020          |                                                                  |
| 003F          | EXTERNAL I/O EXPANSION <sup>2</sup>                              |
| 0040          |                                                                  |
| 007F          | NOT ACCESSIBLE                                                   |
| 0080          |                                                                  |
| 00FF          | INTERNAL RAM (128 BYTES) <sup>1</sup><br>(SHARED WITH 0180-01FF) |
| 0100          |                                                                  |
| 017F          | EXTERNAL RAM EXPANSION <sup>2</sup>                              |
| 0180          |                                                                  |
| 01FF          | INTERNAL RAM (128 BYTES) <sup>1</sup><br>(SHARED WITH 0080-00FF) |
| 0200          |                                                                  |
| EFFF          | EXTERNAL MEMORY AND<br>I/O EXPANSION <sup>2</sup>                |
| F000          |                                                                  |
| F7FF          | NOT ACCESSIBLE                                                   |
| F800          | INTERNAL ROM (2048 BYTES)                                        |
| FFF1          | NMIB VECTOR                                                      |
| FFF2          |                                                                  |
| FFF3          |                                                                  |
| FFF4          | RESB VECTOR                                                      |
| FFF5          |                                                                  |
| FFF6          | IRQB VECTOR                                                      |
| FFF7          |                                                                  |
| FFF8          | NOT USED                                                         |
| FFF9          |                                                                  |
| FFFA          | NMIA VECTOR                                                      |
| FFFB          |                                                                  |
| FFFC          | RESA VECTOR                                                      |
| FFFD          |                                                                  |
| FFFE          | IRQA VECTOR                                                      |
| FFFF          |                                                                  |

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

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

### ARITHMETIC AND LOGIC UNIT (ALU)

All arithmetic and logic operations for both CPU's take place in a shared ALU. Incrementing and decrementing of the index registers and memory also take place here. The ALU stores data for only one cycle. Consequently, data placed on the inputs at the beginning of a cycle are processed and gated to one of the registers, or to memory, during the next cycle.

Each bit of the ALU has two inputs. These inputs may be tied to various internal buses or to a logic zero; the ALU then generates the function (AND, OR, SUM, etc.) using the data on the two inputs.

### PROGRAM COUNTERS

The 16-bit program counters for each CPU provide addresses that step each processor through sequential instructions in a stored program. The program counter for each CPU is initially set to the value stored as the reset vector in CPU A (RESA at

FFF0) 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 NMIB, an internal interrupt request, an external interrupt request via PF2 (see Port F description) or reset (RES) occurs.

### INSTRUCTION REGISTERS AND INSTRUCTION DECODE

Instructions selected by the program counter are fetched from ROM or RAM (or Port D if in Expanded Bus Mode) and gated onto the internal data bus. These instructions are latched into the proper instruction register and then decoded using common decoding circuits for both CPU's. Timing, status bits, and interrupt controls are interpreted together with the instruction code to generate control signals for the various registers in the appropriate CPU.

### INTERRUPT LOGIC

Each CPU has its own logic which controls the sequencing of three types of interrupts: RES, NMI, and IRQ. The same RESET (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 (NMIA and 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 PF0, PF1 and PF2, respectively. Internally, IRQ conditions can be generated by time-out of either of the two 16-bit 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 (IRQ) is generated. Each CPU has its own Processor Status Register (PSRA and PSRB) with the capability of disabling IRQ interrupts when its own "I flag" bit is a 1.

## NEW AND MODIFIED INSTRUCTIONS

In addition to the standard R6502 instruction set, ten new instructions have been added and minor timing and other changes have been made to a few other instructions. All of these additions and changes are discussed in this section. Refer to the Instruction Set Op Code Matrix for the operation codes and addressing modes of all instructions. The times indicated for each instruction are given in terms of CPU clock-times.

### UNSIGNED MULTIPLY (MUL)

The 10 clock-time hardware multiply instruction multiplies the 8-bit contents of the Y register by the 8-bit contents of the A register to give a 16-bit product. At the completion of the multiply operation, the most significant half of the product resides in the A register and the least significant half in the Y register. This operation uses unsigned numbers only. This instruction uses the implied addressing mode and, consequently, requires one byte for the op code.

### SET MEMORY BIT (SMB m, ADDRESS.)

This instruction uses zero page addressing only and requires five cycle times. It sets the designated bit in the addressed memory cell or I/O port to a 1. The first byte of the two-byte instruction identifies the operation and the bit to be set while the second byte designates the address of the word in which the bit is to be set. Eight op codes are used for the eight bit locations in a byte.

### RESET MEMORY BIT (RMB m, ADDRESS.)

This instruction operates in the same way as the SMB instruction except that the bit is set to 0.

### BRANCH ON BIT SET RELATIVE (BBS m, ADDRESS, DESTINATION)

This instruction tests one of eight bits designated by a three-bit immediate field within the first byte of the instruction. The second byte designates the address of the byte to be tested within the zero page address range (memory or I/O ports). The third byte of the instruction specifies the 8-bit relative address to which the

instruction branches if the bit tested is a 1. If the bit tested is not set to a 1, the next sequential instruction is executed. This instruction requires five cycles if the branch is not executed, six cycles if the branch executes to the same page, or seven cycles if it branches to a different page.

### BRANCH ON BIT RESET RELATIVE (BBR m, ADDRESS, DESTINATION)

This instruction is similar to the BBS instruction except that the branch takes place if the bit tested is a 0.

### INDEX REGISTER STACK OPERATIONS (PHX, PLX, PHY, AND PLY)

These instructions are similar to the PHA and PLA instructions in the conventional R6502 except that they push or pull the X or Y registers to and from the stack, respectively. The push instructions require three instruction cycles and the pull instructions require four cycles.

### UNCONDITIONAL BRANCH (BRA)

This unconditional branch is a branch always instruction. It operates similar to the conditional branches of the R6502 except that the relative branch always occurs. It executes in three cycles if the branch is to the same page or four cycles if it is not. Two bytes are required, one for the op code and the other for the relative address.

### INSTRUCTION DIFFERENCES FROM R6502

Decimal add and decimal subtract instructions on the R65C00/21 require one cycle time longer than their binary equivalents. The add and subtract times are the same for both decimal and binary operation on the R6502.

The decimal mode flag (D) in the processor status registers default to binary (D=0) operation when the R65C00/21 is RESET, whereas this bit is uninitialized on the R6502.

The indirect jump instruction increments the page address when the indirect pointer crosses a page boundary, whereas on the R6502 it does not.

## PROCESSOR STATUS REGISTERS

Each CPU has its own 8-bit Processor Status Register. Each register contains seven status flags. Some of these flags are controlled by the user program; others may be controlled both by the user's program and the appropriate CPU. The R65C00/21 instruction set contains a number of conditional branch instructions which are designed to allow testing of these flags.

### CARRY BIT (C)

The carry bit (C) can be considered the ninth bit of an arithmetic operation. It is set to a 1 if a carry from the eighth bit has occurred, or it is cleared to 0 if no carry has occurred, as a result of arithmetic or shift operations.

The carry bit may be set or cleared under program control by use of the Set Carry (SEC) or Clear Carry (CLC) instructions, respectively. Other operations which affect the carry bit are ADC, ASL, CMP, CPX, CPY, LSR, PLP, ROL, ROR, RTI, and SBC.

### ZERO BIT (Z)

The zero bit (Z) is set to a 1 by the CPU during any data movements, or calculations, which sets all eight bits of the result to zero for that CPU. This bit is cleared to a 0 when all eight bits of a data movement, or calculation, operations are not all zero for that CPU. The R6500 instruction set contains no instruction to specifically set or clear the Z flag bit. The Z flag bit is, however, affected by the following instructions: ADC, AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LSR, ORA, PLA, PLP, PLX, PLY, ROL, ROR, RTI, SBC, TAX, TAY, TXA, TSX, and TYA.

### INTERRUPT DISABLE BIT (I)

The interrupt disable bit (I) controls the servicing of an interrupt request (IRQ). If the I bit is set to a 0 in the Processor Status Register of one, or both, of the CPU's, the IRQ 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 IRQ signal will be ignored by that CPU. Each CPU will set its interrupt disable bit to a 1 if a RES, an IRQ, or its non-maskable interrupt (NMI) signal is detected. Interrupting one processor does not affect the other one unless it is programmed to respond to the same interrupt.

The I bit is cleared for each CPU when that CPU executes a Clear Interrupt Disable (CLI) instruction and is set under software control by a Set Interrupt Disable (SEI) instruction. This bit is also set by the Break (BRK) instruction. The Return From Interrupt (RTI) and Pull Processor Status (PLP) instructions also affect the I bit by setting it to the value which was stored on the stack.

### DECIMAL MODE BIT (D)

The decimal mode bit (D) controls the arithmetic mode of its CPU. When this bit is set to a 1, the adder operates as a decimal adder for the Add with Carry (ADC) and the Subtract With Carry (SBC) instructions. These instructions, in the decimal mode, require one additional CPU cycle time compared with binary mode or the decimal mode in the conventional R6500. (In the conventional R6500, the decimal and binary arithmetic operations are the same speed.) When the bit is a 0, the arithmetic is performed in straight binary. The decimal mode is controlled only by the programmer for each of the CPU's. The Set Decimal Mode (SED) instruction causes decimal arithmetic to be performed and the Clear Decimal Mode (CLD) instruction causes binary arithmetic to be performed by that CPU. The PLP and RTI instructions also affect the decimal mode bit.

The D bit for each CPU is automatically set to the zero state (binary mode) when the R65C00/21 is reset by RES.

### BREAK BIT (B)

The break bit (B) determines the type of condition which caused the IRQ service routine to be entered. If the IRQ service routine was entered because a BRK instruction was executed by its CPU, the B bit is set to a 1. If the service routine was entered because of an IRQ signal being generated, the B is set to a 0. There are no instructions which directly set or clear this bit.

### OVERFLOW BIT (V)

The overflow bit (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 I/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.

**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 instructions which produce a result that affects the state of the N bit are AND, ASL, BIT, CMP, CPX, CPY, DEC, DEX, DEY, EOR, INC, INX, INY, LDA, LDX, LDY, LSR, ORA, PLA, PLP, PLX, PLY, ROL, ROR, RTI, SBC, TAX, TAY, TSX, TXA, and TYA.

**Processor Status Registers (PSRA and PSRB)**

| 7          | 6           | 5           | 4          | 3          | 2                  | 1           | 0            |
|------------|-------------|-------------|------------|------------|--------------------|-------------|--------------|
| NEG<br>(N) | OVFL<br>(V) | NOT<br>USED | BRK<br>(B) | DEC<br>(D) | IRQ<br>ENBL<br>(I) | ZERO<br>(Z) | CARRY<br>(C) |

3

|              |                                         |
|--------------|-----------------------------------------|
| <u>Bit 7</u> | <b>Negative (N)<sup>1</sup></b>         |
| 1            | Negative Value                          |
| 0            | Positive Value                          |
| <u>Bit 6</u> | <b>Overflow (0)<sup>1</sup></b>         |
| 1            | Overflow Set                            |
| 0            | Overflow Clear                          |
| <u>Bit 5</u> | <b>Not Used</b> (Don't care value)      |
| <u>Bit 4</u> | <b>Break Command (B)<sup>1</sup></b>    |
| 1            | Break Command                           |
| 0            | Non-break Command                       |
| <u>Bit 3</u> | <b>Decimal Mode (D)<sup>3</sup></b>     |
| 1            | Decimal Mode                            |
| 0            | Binary Mode                             |
| <u>Bit 2</u> | <b>Interrupt Enable (I)<sup>2</sup></b> |
| 1            | IRQ Interrupt Disable                   |
| 0            | IRQ Interrupt Enable                    |
| <u>Bit 1</u> | <b>Zero (Z)<sup>1</sup></b>             |
| 1            | Zero Result                             |
| 0            | Non-Zero Result                         |
| <u>Bit 0</u> | <b>Carry (C)<sup>1</sup></b>            |
| 1            | Carry Set                               |
| 0            | Carry Clear                             |

## Notes:

1. Not initialized by RES.
2. Set logic 1 by RES.
3. Cleared to logic 0 by RES.
4. There are two Processor Status Registers, one for each CPU.

# INPUT/OUTPUT AND CONTROL/STATUS REGISTERS

## REGISTER ADDRESSES

Table 2 shows the input/output, control/status and timer/counter registers which are addressed on page zero from locations 00 through 1D. Some of the registers combine other functions when they are read or written. The table lists both the primary and secondary types of functions. Table 3 summarizes the register formats.

All control/status registers and data direction registers are cleared to zero by a 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**

| Address | Read                        | Write                                        | Register Names/Notes                                                       |
|---------|-----------------------------|----------------------------------------------|----------------------------------------------------------------------------|
| 00      | PA Data                     | PA Data                                      | Port A Data I/O                                                            |
| 01      | PB Data                     | PB Data                                      | Port B Data I/O                                                            |
| 02      | PC Data, 0→IBF <sup>3</sup> | PC Data, 1→OBE, 0→RSO <sup>3</sup>           | Port C Data I/O                                                            |
| 03      | PC Data, 0→IBF <sup>3</sup> | PC Data, 1→OBE, 1→RSO <sup>3</sup>           | Port C Data I/O                                                            |
| 04      | PD Data <sup>1</sup>        | PD Data <sup>1</sup>                         | Port D Data I/O                                                            |
| 05      | —                           | PE Data <sup>1</sup>                         | Port E Data Output Only                                                    |
| 06      | PF Data                     | PF Data                                      | Port F Data I/O                                                            |
| 07      | PG Data                     | —                                            | Port G Data Input Only                                                     |
| 08      | —                           | PA Direction                                 | Port A Direction                                                           |
| 09      | —                           | PB Direction                                 | Port B Direction                                                           |
| 0A      | —                           | PC Direction                                 | Port C Direction                                                           |
| 0B      | —                           | PC Direction                                 | Port C Direction                                                           |
| 0C      | —                           | PD Direction <sup>1</sup>                    | Port D Direction                                                           |
| 0D      | —                           | —                                            | —                                                                          |
| 0E      | —                           | PF Direction                                 | Port F Direction                                                           |
| 0F      | —                           | —                                            | —                                                                          |
| 10      | BCR                         | BCR                                          | Bus Control Register                                                       |
| 11      | HCSR                        | HCSR                                         | Host Control and Status Register                                           |
| 12      | ICSR                        | ICSR                                         | Interrupt Control and Status Register                                      |
| 13      | —                           | CIFR                                         | Clear Interrupt Flags Register                                             |
| 14      | —                           | IPCIR                                        | Inter-Processor Communication Interrupt Register                           |
| 15      | PCR                         | PCR                                          | Power Control Register                                                     |
| 16      | TACSR                       | TACSR                                        | Timer A Control and Status Register                                        |
| 17      | LCA, UCA→SLA                | LLA                                          | Timer A Lower Counter (LCA)/Lower Latch (LLA)                              |
| 18      | SLA                         | ULA                                          | Timer A Snapshot Latch (SLA)/Upper Latch (ULA)                             |
| 19      | SLA, 0→UFA <sup>2</sup>     | ULA, ULA→UCA,<br>LLA→LCA, 0→UFA <sup>2</sup> | Timer A Snapshot Latch (SLA)/Upper Latch,<br>Download and Start Timer      |
| 1A      | TBCSR                       | TBCSR                                        | Timer B Control and Status Register                                        |
| 1B      | LCB                         | LLB                                          | Timer B Lower Counter (LCB)/Lower Latch (LLB)                              |
| 1C      | UCB                         | ULB                                          | Timer B Upper Counter (UCB)/Upper Latch (ULB)                              |
| 1D      | UCB, 0→UFB <sup>2</sup>     | ULB, ULB→UCB, LLB→LCB, 0→UFB <sup>2</sup>    | Timer B Upper Counter (UCB)/Upper Latch (ULB),<br>Download and Start Timer |
| 1E      | —                           | —                                            | —                                                                          |
| 1F      | —                           | —                                            | —                                                                          |

**Notes:**

1. Addressed externally when in expanded bus mode.
2. Counter/Timer underflow flags:  
UFA = Timer A Underflow Flag bit in TACSR  
UFB = Timer B Underflow Flag bit in TBCSR

3. R65C00/21 to/from Host data transfer bits in HCSR:

IBF = Input Buffer Full flag bit

OBE = Output Buffer Empty flag bit

RSI = Register Select Input bit

RSO = Register Select Output bit

4. — = Not used—indeterminate data when read

Table 3. Control/Status Registers Formats Summary

| Address<br>(Hex) | Bit Number                                  |                                             |                                     |                                   |                                             |                           |                           |                              | Bus<br>Control<br>Register<br>(BCR)                                   |  |
|------------------|---------------------------------------------|---------------------------------------------|-------------------------------------|-----------------------------------|---------------------------------------------|---------------------------|---------------------------|------------------------------|-----------------------------------------------------------------------|--|
|                  | 7                                           | 6                                           | 5                                   | 4                                 | 3                                           | 2                         | 1                         | 0                            |                                                                       |  |
| 10               | CPU A<br>ACTIVE                             | NOT USED                                    |                                     | PAGE<br>ONE<br>EXT                | PORT A<br>NIBBLE<br>MODE                    |                           | BUS<br>EXTENSION<br>MODE  |                              | HOST<br>CONTROL AND<br>STATUS<br>REGISTER<br>(HCSR)                   |  |
| 11               | O/P<br>BUFF<br>FULL<br>INT<br>FLAG<br>(OBF) | I/P<br>BUFF<br>FULL<br>INT<br>FLAG<br>(IBF) | I/O<br>REG<br>SEL<br>(RSI)<br>(RSO) | NOT<br>USED                       | I/OA<br>INT<br>ENBL                         | HOST<br>INT<br>ENBL       | HOST<br>BUS<br>ENBL       | HOST<br>BUS<br>TYPE          |                                                                       |  |
| 12               | IPCA<br>INT<br>FLAG                         | PF2<br>LOW<br>INT<br>FLAG                   | PF1<br>NEG<br>EDGE<br>INT<br>FLAG   | PF0<br>POS<br>EDGE<br>INT<br>FLAG | IPCA<br>INT<br>ENBL                         | PF2A<br>INT<br>ENBL       | PF1A<br>INT<br>ENBL       | PF0A<br>INT<br>ENBL          |                                                                       |  |
| 13               | IPCB<br>INT<br>FLAG                         |                                             | CLR<br>PF1<br>NEG<br>INT<br>FLAG    |                                   | IPCB<br>INT<br>ENBL                         | IPCB<br>INT<br>ENBL       | PF1B<br>INT<br>ENBL       | PF0B<br>INT<br>ENBL          |                                                                       |  |
| 14               | CLR<br>IPCA<br>INT<br>FLAG                  | NOT<br>USED                                 | CLR<br>PF0<br>POS<br>INT<br>FLAG    | CLR<br>PF0<br>POS<br>INT<br>FLAG  | NOT USED                                    |                           |                           |                              |                                                                       |  |
| 15               | CLR<br>IPCB<br>INT<br>FLAG                  |                                             | NOT<br>USED                         |                                   | WRITE ONLY REGISTER—NO SPECIFIC BIT (IPCIR) |                           |                           | LOW<br>PWR<br>CPU B<br>(LPB) | LOW<br>PWR<br>CPU A<br>(LPA)                                          |  |
| 16               | TMR A<br>UNFL<br>FLAG<br>(UFA)              | PF3<br>LEVEL<br>IND                         | NOT<br>USED                         | TMR A<br>INT<br>ENBL              | TMR A<br>CLK<br>PRESC<br>SEL                | TIMER A<br>MODE<br>SELECT |                           |                              | INTER-<br>PROCESSOR<br>COMMUNICATION<br>INTERRUPT<br>REGISTER (IPCIR) |  |
| 1A               | TMR B<br>UNFL<br>FLAG<br>(UFB)              | PF4<br>LEVEL<br>IND                         | NOT<br>USED                         | TMR B<br>INT<br>ENBL              | NOT USED                                    |                           | TIMER B<br>MODE<br>SELECT |                              |                                                                       |  |

Note: All control and status registers are cleared to zero by RES

### INTERRUPT CONTROL AND STATUS

Unlike other R6500 family devices, the R65C00/21 does not concentrate the interrupt flags into a single register. The R65C00/21, in general, places the interrupt flags in registers which also have to do with the control of the particular function which can cause the interrupt.

Interrupt enable control is located in the following registers:

HCSR Host Control and Status Register  
ICSR Interrupt Control and Status Register

TACSR Timer A Control and Status Register  
TBCSR Timer B Control and Status Register

Portions of each of these registers relating to interrupt enables are duplicated for each of the two CPU's. However, only one memory address has been allocated so that each CPU uses the same address to select its own interrupt enables. The specific details of the usage of the interrupt control bits are discussed in the corresponding functional area.

## CLOCK CIRCUITS

### CLOCK OSCILLATOR

The internal clock oscillator generates the system clock ( $\phi_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  $\phi_2$  clock is normally routed externally to clock external memory operations in the extended bus mode. A mask option allows the  $\phi_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 (XTAL1) is grounded and crystal output (XTAL0) is left open as shown in Figure 5.

### LOW POWER OPERATION

The divide-by-128 clock prescaler operates in one of three ways (see Figure 6). One is the prescaler switched completely out which gives a system clock rate ( $\phi_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 ( $\phi_{2PS}$ ). This reduces the device power requirements and also reduces the counting rate of both counter/timers by a factor of 128. The third operating mode for the prescaler is to use it for prescaling Timer A only. This mode is discussed under the Counter/Timer Operation.

### POWER CONTROL REGISTER (PCR)

Two bits in the Power Control Register (PCR) determine operation of the clock prescaler. Each CPU can set its own power control bit and read both of them. When both power control bits are a 1, the system switches to the low power operation at a clock rate of  $\phi_2/128$  ( $\phi_{2PS}$ ). 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.

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

| 7        | 6 | 5 | 4 | 3 | 2 | 1                   | 0                   |
|----------|---|---|---|---|---|---------------------|---------------------|
| NOT USED |   |   |   |   |   | LOW PWR CPU B (LPB) | LOW PWR CPU A (LPA) |

Bits 7-2      Not Used (Don't care)

Bit 1      Low Power Mode Select for CPU B (LPB)

- 1      Low power mode requested by CPU B
- 0      Normal power mode requested by CPU B

Bit 0      Low Power Mode Select for CPU A (LPA)

- 1      Low power mode requested by CPU A
- 0      Normal power mode requested by CPU A

#### Notes:

1. Both CPU's can read both bits.
2. Each CPU can only write its power control bit.
3. Both bits must be set to enable low power mode.



Figure 5. Master/Slave Clock Connection



Figure 6. System Clock Operation

## PARALLEL INPUT/OUTPUT PORTS

The R65C00/21 parallel input/output interface consists of five 8-bit, bidirection input/output ports, one 8-bit output only port, and one 4-bit input only port.

### BIDIRECTIONAL PORTS A, B, C, D AND F

The five 8-bit bidirectional ports (Ports A, B, C, D and F) each have an associated data direction register which configures individual data ports for either input or output. Port E is output only and port G is input only, therefore, no data direction registers are required for these two ports.

#### OUTPUT MODE

If the data direction register for a particular bit position in a bidirectional port is a 1, that bit is defined as an output pin. The information written into each bit position of the data word is loaded into a latch. The information will remain in that latch until new data is transmitted to the data word or the power is shut off. The output latches are individually connected to output drivers for each bit position for which a corresponding bit in the data direction register is a 1. The output drivers are double-ended, push-pull type. The drivers force the output pins high ( $\geq 2.4V$ ) if the output data bit is a 1, or low ( $\geq 0.4V$ ) if the output data bit is a 0. The output drivers are TTL compatible.

#### INPUT MODE

If the data direction register for a particular bit position in a bidirectional port is 0, that bit position is defined as an input pin. When the input/output port is read via an LDA, LDX, LDY, ADC, SBC, ORA, AND, EOR, or a BIT instruction, all of the information on that port's pins are read into the corresponding register and processed as directed by the instruction. Since the input signal lines are at a "float" state, the logic level on them will be read as either a 1 or a 0 for that pin position. A low ( $\geq 0.8V$ ) input causes a logic 0 to be read and a high ( $\geq 2.0V$ ) 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  $\phi_2$  and gated onto the internal bus when selected.

#### PORT A NIBBLE ADDRESSING

Whenever a port is shared as an output, care must be exercised that one CPU does not destroy the other CPU's output data. In general, this can be avoided by allocating complete output ports to each CPU so that there is no possibility of conflict. However, there may be some situations where at least one port must be shared for outputs to get the proper mix for the required application. Port A is slightly different from the other bidirectional ports to allow port A to be safely shared as an output port by both CPU's.

Port A is divided into two 4-bit "nibble ports". Each half (nibble) of Port A may be independently addressed by each CPU as defined by two bits in the Bus Control Register (BCR2 and BCR3) as described in Bus Extension and Host Interface section. Depending upon the control bits, either CPU may be

assigned to write to both halves, write to neither half (only read—the other CPU writes to the whole register), write to top half, or write to bottom half. When a mode has been selected for writing to only one-half of the port, the other half is unaffected.

#### ALTERNATIVE MODES OF OPERATION

Bidirectional Ports C, D, and F all have alternative modes of operation which may be selected in lieu of the bidirectional port capabilities.

Port C is a data bus for a host computer when the R65C00/21 is being used as a programmable peripheral device. This is discussed in more detail under Bus Extension and Host Interface.

Port D is a multiplexed data bus (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.

#### 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 inter-processor communication interrupts.

When the PF0 edge-sensitive circuit detects a positive transition, bit 4 of the ICSR is set to a 1. An internal interrupt request (IRQ) is generated to a CPU whenever this bit is set and the corresponding PF0 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 (IRQ) 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 IRQ'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 IRQ will be honored.

The Port F signals PF3 and PF4 can be used as external interfaces for Counter/Timers A and B, respectively (refer to the Counter/Timers description). Finally, PF7 can be used as an active-low interrupt to a host processor. The operation of the R65C00/21 with a host processor is discussed under Bus Extension mode.

The Inter-Processor Communication Interrupt (IPCA and IPCB) bit in the ICSR allows each CPU to interrupt the other CPU if all of the other normal IRQ conditions are correct. CPU A sets the IPCB Interrupt Flag in CPU B's Interrupt Control and Status Register and CPU B sets the IPCA Interrupt Flag in CPU A by any write to location 0014, the Inter-Processor communications Interrupt Register. This is not an actual register, but writing any value here sets the other CPU IPCI flag. This inter-processor communications is illustrated in Figure 7.

#### Interrupt Control And Status Register (ICSR)

| 7                   | 6                         | 5                                 | 4                                 | 3                   | 2                   | 1                   | 0                   |
|---------------------|---------------------------|-----------------------------------|-----------------------------------|---------------------|---------------------|---------------------|---------------------|
| IPCA<br>INT<br>FLAG | PF2<br>LOW<br>INT<br>FLAG | PF1<br>NEG<br>EDGE<br>INT<br>FLAG | PF0<br>POS<br>EDGE<br>INT<br>FLAG | IPCA<br>INT<br>ENBL | PF2A<br>INT<br>ENBL | PF1A<br>INT<br>ENBL | PF0A<br>INT<br>ENBL |
| IPCB<br>INT<br>FLAG |                           |                                   |                                   | IPCB<br>INT<br>ENBL | PF2B<br>INT<br>ENBL | PF1B<br>INT<br>ENBL | PF0B<br>INT<br>ENBL |

##### Bit 7 Inter-Processor Communication (IPC) Interrupt Flag (A or B)

- 1 An inter-processor interrupt is requested by the other CPU
- 0 No internal interrupt is requested

##### Bit 6 PF2 Low Interrupt Flag (A and B)

- 1 PF2 is low
- 0 PF2 is high

##### Bit 5 PF1 Negative Edge Detect Interrupt Flag

- 1 A positive-to-negative transition on PF1 occurred
- 0 No positive-to-negative transition on PF1 occurred

##### Bit 4 PF0 Positive Edge Detect Interrupt Flag

- 1 A positive-to-negative transition on PF0 occurred
- 0 No positive-to-negative transition on PF0 occurred

##### Bit 3 Inter-Processor Communication Interrupt Enable (A or B)

- 1 Enables inter-processor communication interrupt (bit 7)
- 0 Disables inter-processor communication interrupt (bit 7)

##### Bit 2 PF2 Interrupt Enable (A or B)

- 1 Enables PF2 interrupt (bit 6)
- 0 Disables PF2 interrupt (bit 6)

##### Bit 1 PF1 Interrupt Enable (A or B)

- 1 Enables PF1 interrupt (bit 5)
- 0 Disables PF1 interrupt (bit 5)

##### Bit 0 PF0 Interrupt Enable (A or B)

- 1 Enables PF0 interrupt (bit 4)
- 0 Disables PF0 interrupt (bit 4)



Figure 7. Inter Processor Communication

#### CLEAR INTERRUPT FLAGS REGISTER (CIFR)

The Clear Interrupt Flags Register (CIFR) is similar to the ICSR in that only one address is used but the bit pattern operates only on the status bits for its own processor. Thus only CPU A may clear IPCA but either may clear the edge detection flag bits. Bit 6 will only be cleared when the signal on PF2 goes high. Actually, the Clear Interrupt Flags Register is not a register at all, but addressing a bit pattern to this location performs the function. Any bit to which a zero is written will clear the corresponding interrupt flag. A read of this word returns logic one's so that the new Reset Memory Bit instructions may be used to clear these flags.

#### Clear Interrupt Flags Register (CIFR)

| 7                          | 6 | 5                                | 4                                | 3 | 2 | 1 | 0 |
|----------------------------|---|----------------------------------|----------------------------------|---|---|---|---|
| CLR<br>IPCA<br>INT<br>FLAG |   | CLR<br>PF1<br>NEG<br>INT<br>FLAG | CLR<br>PF0<br>POS<br>INT<br>FLAG |   |   |   |   |
| NOT<br>USED                |   | NOT<br>USED                      |                                  |   |   |   |   |

##### Bit 7 Clear Inter-Processing Communication Interrupt Flag

- 1 Has no effect on the IPC Flag
- 0 Clears the IPC Interrupt Flag (specific CPU, A or B)

##### Bit 6 Not Used

##### Bit 5 Clear PF1 Interrupt Flag

- 1 Has no effect on the PF1 Interrupt Flag
- 0 Clears the PF1 Interrupt Flag (either CPU)

##### Bit 4 Clear PF0 Interrupt Flag

- 1 Has no effect on the PF0 Interrupt Flag
- 0 Clears the PF0 Interrupt Flag (either CPU)

##### Bit 3-0 Not Used

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

#### INPUT ONLY PORT G

The input characteristics of the 4-bit Port G are the same as a bidirectional 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.

## COUNTER/TIMERS

There are two separate 16-bit counter/timer systems in the R65C00/21: Counter/Timer A and Counter/Timer B. The block diagram of the counter/timers (also referred to as the timers, the counters, Timer A, or Timer B) is shown in Figure 8. Timer A has eight operating modes and five registers while Timer B has four operating modes and four registers. Both counter/timers have a 16-bit counter comprised of two 8-bit segments: Lower

Counter (LCA and LCB, where A and B refer to Counter/Timer A and B) and Upper Counter (UCA and UCB). Both counter/timers also have a 16-bit latch section consisting of two 8-bit segments: Lower Latch (LLA and LLB) and Upper Latch (ULA and ULB). In addition, only Timer A has an 8-bit Snapshot Latch (SLA) register.



Figure 8. Counter/Timer Block Diagram

Data are written to the latches which act as holding registers for loading or reloading the initial counter/timer values upon mode initiation or counter/timer restart.

Both timers count down from the pre-set latch value and set an appropriate underflow flag when the counter counts through zero. The counter actually never counts below zero. At the time the counter would go negative, the contents of the latches replace the count value with no time delay.

Each counter/timer has three addresses for accessing the five (Counter/Timer A) or four (Counter/Timer B) 8-bit registers in its system. Consequently, the R/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 ( $\phi_2$ ) or an external event clock rate. In addition, Timer A can operate with a prescaled  $\phi_2/128$  clock rate.

## COUNTER/TIMER A (TA)

Counter/Timer A, with its four additional modes and Snapshot Latch, is generally more flexible than Counter/Timer B.

The Snapshot Latch (SLA) solves a problem which sometimes occurs when a timer is read. The problem is that between the time when the low byte of the 16-bit counter is read and the time when the high byte is read it is possible for the high byte to have been decremented. The resulting 16-bit value would, in this case be incorrect. In many modes of timer, the values are not actually read but the zero count transition is important. These types of applications do not require the use of the Snapshot Latch register. If the timer count value is to be used directly from a running timer, however, the Timer A Snapshot Latch should be used.

Timer A overcomes the problem stated above by sampling the value of the upper counter byte into the Snapshot Latch every time the lower counter byte is read. The value of the Upper Counter can be obtained by first reading the Lower Counter at address 0017, then reading the Snapshot Latch at address 0018 or 0019. Note that reading address 0019 also resets the Timer A Underflow (UFA) flag.

A second architectural difference between the two timers is that Timer A can have its clock input scaled down by a factor of 128 during normal power operation. This allows Timer A to measure longer periods of time internally while the microcomputer is operating at the  $\phi_2$  system clock rate. With a 4 MHz system clock, more than two second time intervals (up to 2.097 seconds) can be measured directly without any software intervention. Without the prescaler, 16.384 ms is the longest time interval at 4 MHz.

## Timer A Mode Control

The operation of Timer A is controlled and monitored by the Timer A Control and Status Register (TACRS).

Bits 0-2 select the Timer A mode of operation.

Bit 3, when set to a 1, causes the clock prescaler to be switched into the circuit so that the timer may count longer intervals in modes which allow it.

**Timer A Interrupt Enable**, TACSR bit 4, if set to a 1 by a CPU, enables generation of an internal IRQ 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 IRQ interrupt if bit 4 of the TACSR is set to a 1. The UFA flag is reset to a 0 by reading SLA or writing ULA at address 0019.

3

Timer A Control And Status Register (TACSR)

| 7                              | 6                   | 5           | 4                    | 3                            | 2                         | 1 | 0 |
|--------------------------------|---------------------|-------------|----------------------|------------------------------|---------------------------|---|---|
| TMR A<br>UNFL<br>FLAG<br>(UFA) | PF3<br>LEVEL<br>IND | NOT<br>USED | TMR A<br>INT<br>ENBL | TMR A<br>CLK<br>PRESC<br>SEL | TIMER A<br>MODE<br>SELECT |   |   |

### Bit 7      Timer A Underflow Flag (UFA)

1      Underflow condition occurred  
0      No underflow

### Bit 6      Port F Bit 3 (PF3) Level

1      PF3 High  
0      PF3 Low

### Bit 5      Not Used (Don't care)

### Bit 4      Timer A Interrupt Enable

Enable Timer A Interrupt

Disable Timer A Interrupt

### Bit 3      Timer A Clock Prescaler Enable<sup>1</sup>

Enable Clock Prescaler ( $\phi_2/128$ )  
Disable Clock Prescaler ( $\phi_2$ )

### Bits 2 to 0      Timer A Mode Select (TAMS)

|             |                                                    |
|-------------|----------------------------------------------------|
| 2    1    0 | Timer A Off                                        |
| 0    0    0 | Free-Run Event Counter Mode <sup>1</sup>           |
| 0    0    1 | Free-Run Pulse Width Measurement Mode <sup>1</sup> |
| 0    1    0 | Retriggerable One-Shot Timer Mode <sup>1</sup>     |
| 0    1    1 | One-Shot Interval Timer Mode                       |
| 1    0    0 | Free-Run Interval Timer Mode                       |
| 1    0    1 | One-Shot Pulse Generation Mode                     |
| 1    1    0 | Free-Run Pulse Generation Mode                     |
| 1    1    1 |                                                    |

Note:

- Prescaler must be disabled (bit 3=0) for Free-Run Event Counter Mode, Free-Run Pulse Width Measurement Mode, and Retriggerable One-Shot Timer Mode. These three modes do not allow prescaling.

### Timer A Operating Modes

The Timer A mode of operation is selected by setting bits 0-2 of the Timer A Control and Status Register (TACSR) to the appropriate code.

#### Timer A Off, Mode 0

Timer A is turned off in this mode. The Timer A Underflow Flag (UFA) stays at its current state. The counter holds its current value and may be read. Writing to the registers performs the usual functions associated with that address but the counter remains stopped. This is the default condition.

#### Timer A Free-Run Event Counter, Mode 1

The Timer A Upper Counter (UCA) and Lower Counter (LCA) is loaded with the Timer A Upper Latch (ULA) and Lower Latch (LLA) value when the data is written to the Timer A Upper Latch at address 0019. Timer A then decrements by 1 at each negative transition of the signal on input Port PF3. (The Port F data direction register must have a 0 in bit 3.) The Timer A Underflow Flag (UFA) is set to 1 when the counter decrements below zero. At this same time, the latch value is reloaded into UCA and LCA. The maximum rate of the signal on PF3 which may be detected is one-half of the  $\phi_2$  system clock rate.

#### Timer A Free-Run Pulse Width Measurement, Mode 2

Writing to ULA at 0019 transfers the 16-bit latch to the counter which operates as a timer in this mode. The initial value in the timer is decremented at the  $\phi_2$  rate when the PF3 signal is low. Otherwise, the counter holds its value. Counting stops when the PF3 signal goes high and will resume if the signal goes low again. If the counter counts below zero, the counter initial value is reloaded from the latches and the UFA flag is set.

#### Timer A One-Shot Retriggerable Timer, Mode 3

This mode is similar to Mode 4 except that the timer restarts each time PF3 goes through a high-to-low transition and counts down until the counter goes through zero. A second difference is that the clock prescaler may not be used with this mode. The data direction register bit 3 (PF3) must be zero to select input.

#### Timer A One-Shot Interval Timer, Mode 4

Writing to ULA at 0019 transfers the initial value from the latches and starts the timer. The timer counts at either the  $\phi_2$ , or scaled  $\phi_2$  ( $\phi_2/128$ ), rate. When the counter counts through zero, the latch value is transferred to the counter, the UFA flag is set and the counter stops counting.

#### Timer A Free-Run Interval Timer, Mode 5

Writing ULA at 0019 transfers the 16-bit latch value to the timer and starts it running. The counter counts down at either the  $\phi_2$ , or the scaled  $\phi_2$  ( $\phi_2/128$ ), rate. When the counter counts through zero the UFA flag is set, the value in the latches is transferred to the counter, and the counter continues to count down.

### Timer A One-Shot Pulse Generation, Mode 6

The PF3 data direction register bit must be set to a 1 before starting this mode to initially force a high output. Writing ULA at 0019 starts the timer and clears the PF3 data output bit to a 0 causing a low output. The PF3 output remains low until the timer counts through zero. At this time, the PF3 output goes high until the mode is restarted or a new mode is selected. The UFA flag is also set at this time and the counter is stopped. The timer counts at either the  $\phi_2$ , or the scaled  $\phi_2$  ( $\phi_2/128$ ), rate.

### Timer A Free-Run Pulse Generation, Mode 7

The data direction register for PF3 must be set to a 1 to select the PF3 output before starting this mode. Writing to ULA at 0019 sets PF3 to 0 forcing a low output and starts the timer. Each time the timer counts through zero, the PF3 output changes state to generate a square wave at a rate dependent upon the latch value. The timer counts at either  $\phi_2$ , or the scaled  $\phi_2$  ( $\phi_2/128$ ), rate. Each time the counter counts through zero, the latch contents are automatically transferred to the timer registers and the UFA flag is set.

## COUNTER/TIMER B (TB)

Timer B is a simpler timer than Timer A but it still retains great flexibility. Unlike Timer A, there is no "off" mode (the default mode is the Free-Run Interval Timer Mode) and there is no separate selectable clock prescaler. All counting (except for counting external events) is done either at the  $\phi_2$  clock rate or  $\phi_2/128$  rate (when low power mode is selected). Another difference is that Timer B does not have the snapshot latch register for freezing the upper timer byte for reading. However, in its normal modes the counter counts through zero to set the Underflow Flag B (UFB) so that a snapshot latch register is not required.

#### Timer B Mode Control

The operation of Timer B is controlled and monitored by the Timer B Control and Status Register (TBCSR).

Bits 0-1 select the Timer B operating mode.

Timer B Interrupt Enable, bit 4, when set to a 1 by a CPU, enables generation of an internal interrupt request (IRQ) 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 IRQ interrupt if bit 4 of the TBCSR is set to a 1. The UFB bit is reset by either reading UCB or writing to ULB at address 001D.

#### Timer B Control and Status Register (TBCSR)

| 7                              | 6                   | 5           | 4                    | 3        | 2 | 1                         | 0 |
|--------------------------------|---------------------|-------------|----------------------|----------|---|---------------------------|---|
| TMR B<br>UNFL<br>FLAG<br>(UFB) | PF4<br>LEVEL<br>IND | NOT<br>USED | TMR B<br>INT<br>ENBL | NOT USED |   | TIMER B<br>MODE<br>SELECT |   |

|                 |                                           |
|-----------------|-------------------------------------------|
| <u>Bit 7</u>    | <b>Timer B Underflow Flag (UFB)</b>       |
| 1               | Underflow condition occurred              |
| 0               | No underflow                              |
| <u>Bit 6</u>    | <b>Port F Bit 4 (PF4) Level Indicator</b> |
| 1               | PF4 High                                  |
| 0               | PF4 Low                                   |
| <u>Bit 5</u>    | <b>Not Used (Don't care)</b>              |
| <u>Bit 4</u>    | <b>Timer B Interrupt Enable</b>           |
| 1               | Enable Timer B Interrupt                  |
| 0               | Disable Timer B Interrupt                 |
| <u>Bits 3-2</u> | <b>Not Used (Don't care)</b>              |
| <u>Bits 1-0</u> | <b>Timer B Mode Select (TMS)</b>          |
| 1 0             | Free-Run Interval Timer Mode              |
| 0 0             | Free-Run Pulse Generator Mode             |
| 0 1             | Event Counter Mode                        |
| 1 0             | Event Counter Mode                        |
| 1 1             | Pulse Width Measurement Mode              |

### Timer B Operating Modes

The Timer B operating mode is selected by setting bits 0 and 1 in the TBCSR to the appropriate code.

### Timer B Free-Run Interval Timer, Mode 0

Writing to Timer B Upper Latch (ULB) at 001D transfers the 16-bit latch value to the timer and starts it running. The counter counts down at the  $\phi_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.

### 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  $\phi_2$  rate. Each time the counter counts through zero, the latch values are automatically transferred to the timer registers and the UFB flag is set to a 1.

### Timer B Event Counter, Mode 2

The data direction register bit for PF4 must be set to a 0 to select PF4 input prior to selecting this mode. The counter is loaded with the latch value when the ULB data is written to address 001D. Timer B then decrements by 1 at each negative transition on input Port PF4. The Timer B Underflow Flag (UFB) is set to a 1, when Counter B counts through zero. At this same time, the latch value is reloaded into Timer B. The maximum rate of the signal on PF4 which may be detected is one-half of the  $\phi_2$  clock rate.

### Timer B Pulse Width Measurement, Mode 3

Writing to ULB at 001D transfers the 16-bit latch value to the counter. The initial value in the timer is decremented at the  $\phi_2$  rate when the PF4 signal is low. Each time the PF4 signal goes high, the counter stops and then continues when the signal is low again. If the counter counts through zero, the UFB flag is set to 1 and the latch value transfers to reinitialize the counter and the countdown continues as long as PF4 is low.

## BUS EXTENSION

In addition to its application as a single-chip microcomputer, the bus extension mode allows the R65C00/21 to operate as a microprocessor with external memory and I/O.

### BUS EXTENSION MODE

When the R65C00/21 is used as a single-chip microcomputer, all of the output ports may be used as input or output ports. However, to use the R65C00/21 with external ROM, RAM, or I/O, a number of the ports act as extensions of the internal address and data buses. Specifically, Port D becomes dedicated as a multiplexed 8-bit data and address bus. Port D provides both the data bus (D0 through D7) and the low bits of the address (A0 through A7) on pins PD0 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 active-low External Memory Select ( $\overline{EMS}$ ) strobe signal at the time the address bits are available. The  $\overline{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 16-bit 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 PE0 through PE7, respectively. If the 12-bit bus extension is selected, then the address lines A8 through A11 appear on PE0 through PE3. In this case, PE4 through PE7 have their usual output function.

Since Port D is multiplexed, it is necessary that external latches be supplied to hold the lower eight bits of the address bus. The EMS output is low when the address is being supplied from Port D. All of the other necessary control bus signals are also provided; these include  $\overline{Q}_2$  and R/W. The SYNC and  $\overline{Q}_A$  signals are also brought out for use by development systems and bus analyzers for system debugging.

In a one-chip configuration, the 128 bytes of internal page one RAM (address 0180 through 01FF), is logically combined with page (0080-00FF). However, when an extended bus is used, the stack page may be addressed in its normal range in external memory (0100-01FF). When bit 4 of the Bus Control Register is a 0, page one is internal and shared with page zero; when it is a 1, page one is external allowing full 256 bytes available to the two stacks.

Figure 9 is an overall block diagram of a system using the R65C00/21 in the bus extension mode.

The CPU A Active signal (bit 7 of the BCR) is high when CPU A is controlling the system bus, and low when CPU B is active. This bit copies the state of the  $\overline{Q}_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.5K bytes of external memory map, or external memory may be shared.

**Bus Control Register (BCR)**

| 7            | 6        | 5            | 4                  | 3                  | 2 | 1 | 0 |
|--------------|----------|--------------|--------------------|--------------------|---|---|---|
| CPU A ACTIVE | NOT USED | PAGE ONE EXT | PORT A NIBBLE MODE | BUS EXTENSION MODE |   |   |   |

Bit 7      **CPU A Active**

- 1      CPU A active
- 0      CPU B active

Bits 6-5      **Not Used (Don't Care)**

Bit 4      **Page One External/Internal Mapping**

- 1      Page One External
- 0      Page One Internal

Bits 3-2      **Port A Write Nibble Control\***

- |        |                                                                             |
|--------|-----------------------------------------------------------------------------|
| 3    2 | CPU A writes to both halves (PA0-PA7).                                      |
| 0    0 | CPU A writes to upper half (PA4-PA7); CPU B writes to lower half (PA0-PA3). |
| 0    1 | CPU A writes to lower half (PA0-PA3); CPU B writes to upper half (PA4-PA7). |
| 1    0 | CPU B writes to both halves (PA0-PA7).                                      |
| 1    1 |                                                                             |

Bits 1-0      **Bus Extension Mode**

- |        |                                                     |
|--------|-----------------------------------------------------|
| 1    0 | Bus Extension Mode not selected.                    |
| 0    0 | 8-bit Address Extension Mode. Range equals 256.     |
| 0    1 | 12-bit Address Extension Mode. Range equals 4096.   |
| 1    0 | 16-bit Address Extension Mode. Range equals 65,536. |
| 1    1 |                                                     |

Note:

\*Either CPU may read the full port at any time.



NOTE:  
\*UPPER ADDRESS EXTENSION MAY BE 0, 4 OR 8 LINES.

Figure 9. Bus Extension Mode Block Diagram

## PROGRAMMABLE PERIPHERAL TO A HOST MODE

An overall block diagram of a system using an R65C00/21 as an intelligent controller is shown in Figure 10.

In this configuration, three of the R65C00/21 input/output ports have special significance. Port C becomes the interface with the host data bus (Port C's Data Direction Register must specify as the input; i.e., all zeros). Pin PF7 becomes an active-low Host Interrupt (HINT) 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 RD (H<sub>02</sub>) and PG1 is the input for the host R/W (HRW) control lines.

When operating in the Z80/8080 mode, PG0 accepts the host RD (HRD) control and PG1 provides the host WR (HWR) control.

In both cases, PG2 serves as a register select (HRS) and PG3 acts as an active-low chip select (CS) from the host. HRS is used in conjunction with the CS and 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

| <u>CS</u><br>(PG3) | <u>HRS</u><br>(PG2) | <u>HRW</u><br>(PG1) | <u>H<sub>02</sub></u><br>(PG0) | Host Function<br>(6500/6800 Mode)                 |
|--------------------|---------------------|---------------------|--------------------------------|---------------------------------------------------|
| H                  | —                   | —                   | —                              | Host Interface Deselected                         |
| L                  | L                   | L                   | H                              | Write Input Buffer,<br>HCSR5 RSI cleared, set IBF |
| L                  | L                   | H                   | H                              | Read Output Buffer, Clear OBF                     |
| L                  | H                   | L                   | H                              | Write Input Buffer,<br>HCSR5 RS1 set, set IBF     |
| L                  | H                   | H                   | H                              | Read upper 3 bits of HCSR;<br>OBF, IBF & RSO      |
| <u>CS</u><br>(PG3) | <u>HRS</u><br>(PG2) | <u>HWR</u><br>(PG1) | <u>HRD</u><br>(PG0)            | Host Function<br>(8080/Z80 Mode)                  |
| H                  | —                   | —                   | —                              | Deselected                                        |
| L                  | L                   | L                   | H                              | Write Input Buffer,<br>HCSR5 RSI cleared, set IBF |
| L                  | L                   | H                   | L                              | Read Output Buffer, Clear OBF                     |
| L                  | H                   | L                   | H                              | Write Input Buffer,<br>HCSR5 RS1 set, set IBF     |
| L                  | H                   | H                   | L                              | Read upper 3 bits of HCSR;<br>OBF, IBF & RSO      |

Host Control and Status Register (HCSR)

| 7                                           | 6                                           | 5                                   | 4           | 3                   | 2                   | 1                   | 0                   |
|---------------------------------------------|---------------------------------------------|-------------------------------------|-------------|---------------------|---------------------|---------------------|---------------------|
| O/P<br>BUFF<br>FULL<br>INT<br>FLAG<br>(OBE) | I/O<br>BUFF<br>FULL<br>INT<br>FLAG<br>(IBF) | I/O<br>REG<br>SEL<br>(RSI)<br>(RSO) | NOT<br>USED | I/OA<br>INT<br>ENBL | I/OB<br>INT<br>ENBL | HOST<br>INT<br>ENBL | HOST<br>BUS<br>ENBL |

Bit 7      **Output Buffer Empty (OBE) Flag**

- 1      Output Buffer Full
- 0      Output Buffer Empty

Bit 6      **Input Buffer Full (IBF) Flag**

- 1      Input Buffer Full
- 0      Input Buffer Empty

Bit 5      **Register Select**

Distinguishes commands from data. Host reads RSO and R65C00/21 reads RSI. Selection of 1 or 0 to represent commands or data is user defined.

Bit 4      **Not Used. (Don't care)**

Bit 3      **Input/Output Buffer Interrupt Enable**

- 1      Enable IRQ IBF = 1
- 0      Disable IRQ

Bit 2      **Host Interrupt (HINT) Output Enable**

- 1      Disable HINT Output to Host
- 0      Enable HINT Output to Host (OBF = 1)

Bit 1      **Host Bus Enable**

- 1      Disable Host Bus
- 0      Enable Host Bus

Bit 0      **Host Bus Type**

- 1      Host Bus is Z80/8080
- 0      Host Bus is 6500/6800

Note:

Register is cleared to all zeros by RES.



Figure 10. Host Mode Block Diagram

## 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 ( $\overline{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  $\phi_2$  output clock signal to the  $\overline{RES}$  input pin.

# INSTRUCTION SET IN ALPHABETIC SEQUENCE

The following table contains a summary of the R65C00/21 and R65C29 CPU instruction set. For detailed information, consult the R6502 Microcomputer System Programming Manual, Order No. 202.

The instructions notated with a \* are added instructions for the R65C00/21 and R65C29 which are not part of the standard 6502 instruction set.

**Instruction Set In Alphabetic Sequence**

| Mnemonic | Description                                | Mnemonic | Description                                  |
|----------|--------------------------------------------|----------|----------------------------------------------|
| ADC      | Add Memory to Accumulator with Carry       | LDA      | Load Accumulator with Memory                 |
| AND      | "AND" Memory with Accumulator              | LDX      | Load Index X with Memory                     |
| ASL      | Shift Left One Bit (Memory or Accumulator) | LDY      | Load Index Y with Memory                     |
| *BRA     | Branch Always                              | LSR      | Shift One Bit Right (Memory or Accumulator)  |
| *BBR     | Branch on Bit Reset Relative               | *MUL     | Multiply                                     |
| *BBS     | Branch on Bit Set Relative                 | NOP      | No Operation                                 |
| BCC      | Branch on Carry Clear                      | ORA      | "OR" Memory with Accumulator                 |
| BCS      | Branch on Carry Set                        | PHA      | Push Accumulator or Stack                    |
| BEQ      | Branch on Result Zero                      | PHP      | Push Processor Status on Stack               |
| BIT      | Test Bits in Memory with Accumulator       | *PHX     | Push Index X                                 |
| BMI      | Branch on Result Minus                     | *PHY     | Push Index Y                                 |
| BNE      | Branch on Result not Zero                  | PLA      | Pull Accumulator from Stack                  |
| BPL      | Branch on Result Plus                      | PLP      | Pull Processor Status from Stack             |
| BRK      | Force Break                                | *PLX     | Pull Index X                                 |
| BVC      | Branch on Overflow Clear                   | *PLY     | Pull Index Y                                 |
| BVS      | Branch on Overflow Set                     | *RMB     | Reset Memory Bit                             |
| CLC      | Clear Carry Flag                           | ROL      | Rotate One Bit Left (Memory or Accumulator)  |
| CLD      | Clear Decimal Mode                         | ROR      | Rotate One Bit Right (Memory or Accumulator) |
| CLI      | Clear Interrupt Disable Bit                | RTI      | Return from Interrupt                        |
| CLV      | Clear Overflow Flag                        | RTS      | Return from Subroutine                       |
| CMP      | Compare Memory and Accumulator             | SBC      | Subtract Memory from Accumulator with Borrow |
| CPX      | Compare Memory and Index X                 | SEC      | Set Carry Flag                               |
| CPY      | Compare Memory and Index Y                 | SED      | Set Decimal Mode                             |
| DEC      | Decrement Memory by One                    | SEI      | Set Interrupt Disable Status                 |
| DEX      | Decrement Index X by One                   | *SMB     | Set Memory Bit                               |
| DEY      | Decrement Index Y by One                   | STA      | Store Accumulator in Memory                  |
| EOR      | "Exclusive-Or" Memory with Accumulator     | STX      | Store Index X in Memory                      |
| INC      | Increment Memory by One                    | STY      | Store Index Y in Memory                      |
| INX      | Increment Index X by One                   | TAX      | Transfer Accumulator to Index X              |
| INY      | Increment Index Y by One                   | TAY      | Transfer Accumulator to Index Y              |
| JMP      | Jump to New Location                       | TSX      | Transfer Stack Pointer to Index X            |
| JSR      | Jump to New Location Saving Return Address | TXA      | Transfer Index X to Accumulator              |
|          |                                            | TXS      | Transfer Index X to Stack Register           |
|          |                                            | TYA      | Transfer Index Y to Accumulator              |

# **INSTRUCTION SET SUMMARY**

**Notes:**

1. Add 1 to N if page boundary is crossed
  2. Add 1 to N if branch occurs to same page
  3. Add 2 to N if branch occurs to different page
  4. Carry not ( $\bar{C}_n$ ) = Borrow
  5. If in decimal mode Z flag is invalid  
Accumulator must be checked on zero result.

Effects 8-bit data field of the specified memory address

|                |                               |
|----------------|-------------------------------|
| -              | Add                           |
| -              | Subtract                      |
| -              | And                           |
| -              | Or                            |
| -              | Exclusive or                  |
| -              | Number of cycles              |
| -              | Number of bytes               |
| -              | #                             |
| X              | Index X                       |
| Y              | Index Y                       |
| A              | Accumulator                   |
| M              | Memory per effective address  |
| M <sub>s</sub> | Memory per stack pointer      |
| M <sub>b</sub> | Selecter zero page memory bit |
| M <sub>r</sub> | Memory Bit 7                  |
| M <sub>l</sub> | Memory Bit 1                  |

3

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

|     |                          | LSD                     |                        |                        |                     |                     |                   |                       |                       |                       |                       |                     |                        |                       |                       |                      |                     |   |
|-----|--------------------------|-------------------------|------------------------|------------------------|---------------------|---------------------|-------------------|-----------------------|-----------------------|-----------------------|-----------------------|---------------------|------------------------|-----------------------|-----------------------|----------------------|---------------------|---|
|     |                          | 0                       | 1                      | 2                      | 3                   | 4                   | 5                 | 6                     | 7                     | 8                     | 9                     | A                   | B                      | C                     | D                     | E                    | F                   |   |
| MSD |                          | BRK<br>Implied<br>1 7   | ORA<br>(IND, X)<br>2 6 | MUL<br>Implied<br>1 10 |                     |                     | ORA<br>ZP<br>2 3  | ASL<br>ZP<br>2 5      | RMB0<br>ZP<br>2 5     | PHP<br>Implied<br>1 3 | ORA<br>IMM<br>2 2     | ASL<br>Accum<br>1 2 |                        |                       | ORA<br>ABS<br>3 4     | ASL<br>ABS<br>3 6    | BBR0<br>ZP<br>3 5** | 0 |
| 1   | BPL<br>Relative<br>2 2** | ORA<br>(IND, Y)<br>2 5* |                        |                        | ORA<br>ZP, X<br>2 4 | ASL<br>ZP, X<br>2 6 | RMB1<br>ZP<br>2 5 | CLC<br>Implied<br>1 2 | ORA<br>ABS, Y<br>3 4* |                       |                       |                     |                        |                       | ORA<br>ABS, X<br>3 4* | ASL<br>ABS, X<br>3 7 | BBR1<br>ZP<br>3 5** | 1 |
| 2   | JSR<br>Absolute<br>3 6   | AND<br>(IND, X)<br>2 6  |                        | BIT<br>ZP<br>2 3       | AND<br>ZP<br>2 3    | ROL<br>ZP<br>2 5    | RMB2<br>ZP<br>2 5 | PLP<br>Implied<br>1 4 | AND<br>IMM<br>2 2     | ROL<br>Accum<br>1 2   |                       |                     |                        | BIT<br>ABS<br>3 4     | AND<br>ABS<br>3 4     | ROL<br>ABS<br>3 6    | BBR2<br>ZP<br>3 5** | 2 |
| 3   | BMI<br>Relative<br>2 2** | AND<br>(IND, Y)<br>2 5* |                        |                        | AND<br>ZP, X<br>2 4 | ROL<br>ZP, X<br>2 6 | RMB3<br>ZP<br>2 5 | SEC<br>Implied<br>1 2 | AND<br>ABS, Y<br>3 4* |                       |                       |                     |                        |                       | AND<br>ABS, X<br>3 4* | ROL<br>ABS, X<br>3 7 | BBR3<br>ZP<br>3 5** | 3 |
| 4   | RTI<br>Implied<br>1 6    | EOR<br>(IND, X)<br>2 6  |                        |                        | EOR<br>ZP<br>2 3    | LSR<br>ZP<br>2 5    | RMB4<br>ZP<br>2 5 | PHA<br>Implied<br>1 3 | EOR<br>IMM<br>2 2     | LSR<br>Accum<br>1 2   |                       |                     | JMP<br>ABS<br>3 3      | EOR<br>ABS<br>3 4     | LSR<br>ABS<br>3 6     | BBR4<br>ZP<br>3 5**  | 4                   |   |
| 5   | BVC<br>Relative<br>2 2** | EOR<br>(IND, Y)<br>2 5* |                        |                        | EOR<br>ZP, X<br>2 4 | LSR<br>ZP, X<br>2 6 | RMB5<br>ZP<br>2 5 | CLI<br>Implied<br>1 2 | EOR<br>ABS, Y<br>3 4* | PHY<br>Implied<br>1 3 |                       |                     |                        | EOR<br>ABS, X<br>3 4* | LSR<br>ABS, X<br>3 7  | BBR5<br>ZP<br>3 5**  | 5                   |   |
| 6   | RTS<br>Implied<br>1 6    | ADC<br>(IND, X)<br>2 6  |                        |                        | ADC<br>ZP<br>2 3    | ROR<br>ZP<br>2 5    | RMB6<br>ZP<br>2 5 | PLA<br>Implied<br>1 4 | ADC<br>IMM<br>2 2     | ROR<br>Accum<br>1 2   |                       |                     | JMP<br>Indirect<br>3 5 | ADC<br>ABS<br>3 4     | ROR<br>ABS<br>3 6     | BBR6<br>ZP<br>3 5**  | 6                   |   |
| 7   | BVS<br>Relative<br>2 2** | ADC<br>(IND, Y)<br>2 5* |                        |                        | ADC<br>ZP, X<br>2 4 | ROR<br>ZP, X<br>2 6 | RMB7<br>ZP<br>2 5 | SEI<br>Implied<br>1 2 | ADC<br>ABS, Y<br>3 4* | PLY<br>Implied<br>1 4 |                       |                     |                        | ADC<br>ABS, X<br>3 4* | ROR<br>ABS, X<br>3 7  | BBR7<br>ZP<br>3 5**  | 7                   |   |
| 8   | BRA<br>Relative<br>2 3*  | STA<br>(IND, X)<br>2 6  |                        | STY<br>ZP<br>2 3       | STA<br>ZP<br>2 3    | STX<br>ZP<br>2 3    | SMB0<br>ZP<br>2 5 | DEY<br>Implied<br>1 2 |                       | TXA<br>Implied<br>1 2 |                       |                     | STY<br>ABS<br>3 4      | STA<br>ABS<br>3 4     | STX<br>ABS<br>3 4     | BBS0<br>ZP<br>3 5**  | 8                   |   |
| 9   | BCC<br>Relative<br>2 2** | STA<br>(IND, Y)<br>2 6  |                        | STY<br>ZP, X<br>2 4    | STA<br>ZP, X<br>2 4 | STX<br>ZP, Y<br>2 4 | SMB1<br>ZP<br>2 5 | TYA<br>Implied<br>1 2 | STA<br>ABS, Y<br>3 5  | TXS<br>Implied<br>1 2 |                       |                     |                        | STA<br>ABS, X<br>3 5  |                       |                      | BBS1<br>ZP<br>3 5** | 9 |
| A   | LDY<br>IMM<br>2 2        | LDA<br>(IND, X)<br>2 6  | LDX<br>IMM<br>2 2      |                        | LDY<br>ZP<br>2 3    | LDA<br>ZP<br>2 3    | LDX<br>ZP<br>2 3  | SMB2<br>ZP<br>2 5     | TAY<br>Implied<br>1 2 | LDA<br>IMM<br>2 2     | TAX<br>Implied<br>1 2 |                     |                        | LDY<br>ABS<br>3 4     | LDA<br>ABS<br>3 4     | LDX<br>ABS<br>3 4    | BBS2<br>ZP<br>3 5** | A |
| B   | BCS<br>Relative<br>2 2** | LDA<br>(IND, Y)<br>2 5* |                        | LDY<br>ZP, X<br>2 4    | LDA<br>ZP, X<br>2 4 | LDX<br>ZP, Y<br>2 4 | SMB3<br>ZP<br>2 5 | CLV<br>Implied<br>1 2 | LDA<br>ABS, Y<br>3 4* | TSX<br>Implied<br>1 2 |                       |                     | LDY<br>ABS, X<br>3 4*  | LDA<br>ABS, X<br>3 4* | LDX<br>ABS, Y<br>3 4* | BBS3<br>ZP<br>3 5**  | B                   |   |
| C   | CPY<br>IMM<br>2 2        | CMP<br>(IND, X)<br>2 6  |                        | CPY<br>ZP<br>2 3       | CMP<br>ZP<br>2 3    | DEC<br>ZP<br>2 5    | SMB4<br>ZP<br>2 5 | INY<br>Implied<br>1 2 | CMP<br>IMM<br>2 2     | DEX<br>Implied<br>1 2 |                       |                     | CPY<br>ABS<br>3 4      | CMP<br>ABS<br>3 4     | DEC<br>ABS<br>3 6     | BBS4<br>ZP<br>3 5**  | C                   |   |
| D   | BNE<br>Relative<br>2 2** | CMP<br>(IND, Y)<br>2 5* |                        |                        | CMP<br>ZP, X<br>2 4 | DEC<br>ZP, X<br>2 6 | SMB5<br>ZP<br>2 5 | CLD<br>Implied<br>1 2 | CMP<br>ABS, Y<br>3 4* | PHX<br>Implied<br>1 3 |                       |                     |                        | CMP<br>ABS, X<br>3 4* | DEC<br>ABS, X<br>3 7  | BBS5<br>ZP<br>3 5**  | D                   |   |
| E   | CPX<br>IMM<br>2 2        | SBC<br>(IND, X)<br>2 6  |                        | CPX<br>ZP<br>2 3       | SBC<br>ZP<br>2 3    | INC<br>ZP<br>2 5    | SMB6<br>ZP<br>2 5 | INX<br>Implied<br>1 2 | SBC<br>IMM<br>2 2     | NOP<br>Implied<br>1 2 |                       |                     | CPX<br>ABS<br>3 4      | SBC<br>ABS<br>3 4     | INC<br>ABS<br>3 6     | BBS6<br>ZP<br>3 5**  | E                   |   |
| F   | BEQ<br>Relative<br>2 2** | SBC<br>(IND, Y)<br>2 5* |                        |                        | SBC<br>ZP, X<br>2 4 | INC<br>ZP, X<br>2 6 | SMB7<br>ZP<br>2 5 | SED<br>Implied<br>1 2 | SBC<br>ABS, Y<br>3 4* | PLX<br>Implied<br>1 4 |                       |                     |                        | SBC<br>ABS, X<br>3 4* | INC<br>ABS, X<br>3 7  | BBS7<br>ZP<br>3 5**  | F                   |   |

0

|                       |
|-----------------------|
| BRK<br>Implied<br>1 7 |
|-----------------------|

—OP Code

—Addressing Mode

—Instruction Bytes; Machine Cycles



—New Opcode

\*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.

## I/O PORT WAVEFORMS—ALL PORTS



## I/O PORT TIMING—ALL PORTS

| Parameter                                    | Symbol   | 2 MHz |     |  |  | Min | Max |
|----------------------------------------------|----------|-------|-----|--|--|-----|-----|
|                                              |          | Min   | Max |  |  |     |     |
| Input Data Setup Time                        | $t_{PS}$ | 50    | —   |  |  | 35  | —   |
| Input Data Hold Time (Port D)                | $t_{PH}$ | 10    | —   |  |  | 10  | —   |
| Input Data Hold Time<br>(All ports except D) |          | 25    | —   |  |  | 25  | —   |
| Output Data Delay Time                       | $t_{PD}$ | —     | 120 |  |  | —   | 100 |

**EXPANSION BUS TIMING**(V<sub>CC</sub> = 5.0V ± 10%, T<sub>A</sub> = 0°C to 70°C)

| Parameter                                                                                                                                                                          | Symbol           | 2 MHz |            | 4 MHz |            | Unit |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------|------------|-------|------------|------|
|                                                                                                                                                                                    |                  | Min.  | Max.       | Min.  | Max.       |      |
| <b>Clock/Control Timing</b>                                                                                                                                                        |                  |       |            |       |            |      |
| Ø2 Cycle Time                                                                                                                                                                      | t <sub>CYC</sub> | 500   | See Note 1 | 250   | See Note 1 | ns   |
| Pulse Width Ø2 Low                                                                                                                                                                 | t <sub>PWL</sub> | 235   | 265        | 115   | 135        | ns   |
| Pulse Width Ø2 High                                                                                                                                                                | t <sub>PWH</sub> | 235   | 265        | 115   | 135        | ns   |
| ØA Delay Time — Ø2 to Ø2A                                                                                                                                                          | t <sub>2AD</sub> | 0     | 60         | 0     | 50         | ns   |
| EMS Delay Time — Address Valid to EMS Low                                                                                                                                          | t <sub>EMA</sub> | 10    | —          | 10    | —          | ns   |
| EMS Delay Time — Ø2 to EMS Low                                                                                                                                                     | t <sub>EMD</sub> | —     | 150        | —     | 115        | ns   |
| EMS Hold Time                                                                                                                                                                      | t <sub>EMH</sub> | 10    | —          | 10    | —          | ns   |
| RW Delay Time                                                                                                                                                                      | t <sub>RWD</sub> | 20    | 100        | 10    | 80         | ns   |
| PE Address Delay Time                                                                                                                                                              | t <sub>AED</sub> | 20    | 100        | 10    | 80         | ns   |
| PD Address Delay Time                                                                                                                                                              | t <sub>ADD</sub> | 20    | 120        | 10    | 100        | ns   |
| <b>Write Timing</b>                                                                                                                                                                |                  |       |            |       |            |      |
| Data Delay Time — Write                                                                                                                                                            | t <sub>DDW</sub> | —     | 120        | —     | 100        | ns   |
| Data Hold Time — Write                                                                                                                                                             | t <sub>DHW</sub> | 20    | —          | 20    | —          | ns   |
| <b>Read Timing</b>                                                                                                                                                                 |                  |       |            |       |            |      |
| PD Address Hold Time — Read                                                                                                                                                        | t <sub>ADH</sub> | 0     | 80         | 0     | 60         | ns   |
| Data Setup Time — Read                                                                                                                                                             | t <sub>DSR</sub> | 50    | —          | 35    | —          | ns   |
| Data Hold Time — Read                                                                                                                                                              | t <sub>DHR</sub> | 10    | —          | 10    | —          | ns   |
| Note: 1. The Ø2 clock should never be held static at a dc level. The maximum cycle time (t <sub>CYC</sub> ) that guarantees no data loss to internal registers is 20 microseconds. |                  |       |            |       |            |      |

## EXPANSION BUS WRITE CYCLE WAVE FORMS



3

## EXPANSION BUS READ CYCLE WAVE FORMS



**MAXIMUM RATINGS\***

| Parameter             | Symbol    | Value                  | Unit |
|-----------------------|-----------|------------------------|------|
| Supply Voltage        | $V_{CC}$  | -0.3 to +7.0           | Vdc  |
| Input Voltage         | $V_{IN}$  | -0.3 to $V_{CC}$ + 0.3 | Vdc  |
| Operating Temperature | $T_A$     | 0 to +70               | °C   |
| Storage Temperature   | $T_{STG}$ | -55 to +150            | °C   |

\*NOTE: This device contains circuitry to protect the inputs against damage due to high static voltages, however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this circuit.

**DC CHARACTERISTICS**

$V_{CC} = +5.0V \pm 10\%$ ,  $T_A = 0^\circ C$  to  $70^\circ C$  (unless otherwise specified)

| Parameter                                                        | Symbol    | Min        | Max        | Unit       | Test Condition                                     |
|------------------------------------------------------------------|-----------|------------|------------|------------|----------------------------------------------------|
| Input High Voltage                                               | $V_{IH}$  | +2.0       | —          | V          |                                                    |
| Input Low Voltage                                                | $V_{IL}$  | —          | +0.8       | V          |                                                    |
| Output High Voltage                                              | $V_{OH}$  | +2.4       | —          | V          | $V_{CC} = 4.5V$<br>$I_{LOAD} = -100\mu A$          |
| Input Leakage Current                                            | $I_{IN}$  | —          | $\pm 10$   | $\mu A$    | $V_{IN} = 0V$ or $V_{CC} = 0V$                     |
| Output Low Voltage                                               | $V_{OL}$  | —          | +0.4       | V          | $V_{CC} = 4.5V$<br>$I_{LOAD} = 1.6 mA$             |
| Output Low Current<br>(All ports except Port C)                  | $I_{OUT}$ | —          | -1.6       | mA         | $V_{OL} = 0.4V$                                    |
| Input Capacitance<br>(XTAL0, XTAL1)<br>(All Others)              | $C_{IN}$  | —          | 25<br>5    | pF<br>pF   | $V_{CC} = 5V$<br>$f = 2 MHz$<br>$T_A = 25^\circ C$ |
| Output Capacitance                                               | $C_{OUT}$ | —          | 10         | pF         |                                                    |
| Operating Frequency<br>Crystal or Master Clock<br>$\phi_2$ Clock | —         | .02<br>.01 | 8.0<br>4.0 | MHz<br>MHz |                                                    |
| Power Dissipation                                                | $P_D$     | —          | 40         | mW         | $V_{CC} = 5V$<br>$f = 2 MHz$<br>$T_A = 25^\circ C$ |

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

## PACKAGE DIMENSIONS

64 PIN PLASTIC QUIP (QUAD IN-LINE PACKAGE)



| DIM | MILLIMETERS |       | INCHES    |       |
|-----|-------------|-------|-----------|-------|
|     | MIN         | MAX   | MIN       | MAX   |
| A   | 41.15       | 41.66 | 1.620     | 1.640 |
| B   | 17.02       | 17.53 | 0.670     | 0.690 |
| C   | 3.05        | 4.57  | 0.120     | 0.180 |
| D   | 0.38        | 0.51  | 0.024     | 0.020 |
| F   | 1.27 BSC    |       | 0.050 BSC |       |
| G   | 2.54 BSC    |       | 0.100 BSC |       |
| H   | 1.02        | 1.14  | 0.040     | 0.045 |
| J   | —           | 7°    | —         | 7°    |
| K   | 2.79        | 4.32  | 0.110     | 0.170 |
| L   | 18.92       | 19.81 | 0.745     | 0.755 |
| M   | 23.37       | 23.62 | 0.920     | 0.930 |

