## **Product Preview**

## TERMINAL ASSIGNMENT

| RESET -    |   | 1  | 40 | - v <sub>DD</sub> |  |  |  |
|------------|---|----|----|-------------------|--|--|--|
| TRO -      |   | 2  | 39 | - osci            |  |  |  |
| NUM -      | _ | 3  | 38 | - oscz            |  |  |  |
| PA7 -      |   | 4  | 37 | TIMER             |  |  |  |
| PA6 -      |   | 5  | 36 | PD7               |  |  |  |
| PA5 -      |   | 6  | 35 | PD6               |  |  |  |
| PA4 -      |   | 7  | 34 | - PD5             |  |  |  |
| PA3 -      |   | 8  | 33 | PD4               |  |  |  |
| PA2 -      | - | 9  | 32 | PD3               |  |  |  |
| PAI -      |   | 10 | 31 | PD2               |  |  |  |
| PAO -      |   | 11 | 30 | PD1               |  |  |  |
| PB0 -      |   | 12 | 29 | - PD0             |  |  |  |
| P81 -      |   | 13 | 28 | - PCO             |  |  |  |
| PB2 -      |   | 14 | 27 | - PC1             |  |  |  |
| P83 -      |   | 15 | 26 | PC2               |  |  |  |
| P84 -      | - | 16 | 25 | PC 3              |  |  |  |
| P85 -      |   | 17 | 24 | PC4               |  |  |  |
| P86 -      |   | 18 | 23 | PC5               |  |  |  |
| P87 -      |   | 19 | 55 | - PC6             |  |  |  |
| Vss *      |   | 20 | 21 | PC7               |  |  |  |
| 92C5-34974 |   |    |    |                   |  |  |  |
|            |   |    |    |                   |  |  |  |
| TOP VIEW   |   |    |    |                   |  |  |  |

# CMOS High-Performance Silicon-Gate 8-Bit Microcomputer

## Features:

- Typical full speed operating power of 12 mW at 5 V
- Typical WAIT mode power of 4 mW
- Typical STOP mode power of 5 μW
- Fully static operation
- 112 bytes of on-chip RAM
- 2106 bytes of on-chip ROM
- 32 bidirectional I/O lines
- Biah current drive <sup>-</sup>
- Internal 8-bit timer with software programmable 7-bit prescaler
- External timer input
- External and timer interrupts
- Self-check mode
- Master reset and power-on reset
- Single 3 to 6 volt supply
- On-chip oscillator with RC or crystal mask options
- True bit manipulation

-

Addressing modes with indexed addressing for tables

The CDP6805G2 Microcomputer Unit (MCU) belongs to the CDP6805 Family of Microcomputers This 8-bit MCU contains on-chip oscillator CPU, RAM, ROM, I/O, and Timer. The fully static design allows operation at frequencies down to DC, further reducing its already low-power consumption. It is a low-power processor designed for lowend to mid-range applications in the consumer, automotive, industrial, and communications markets where very low power consumption constitutes an important factor.



File Number 1364

MAXIMUM RATINGS (Voltages Referenced to VSS)

| Ratings                                     | Symbol           | Value                                        | Unit |
|---------------------------------------------|------------------|----------------------------------------------|------|
| Supply Voltage                              | VDD              | -0.3 to +8                                   | V    |
| All Input Voltages Except OSC1              | Vin              | V <sub>SS</sub> -0.5 to V <sub>DD</sub> +0.5 | V    |
| Current Drain Per Pin Excluding VDD and VSS | 1                | 10                                           | mA   |
| Operating Temperature Range                 |                  | TL TH                                        |      |
| CDP6805G2                                   | TA               | 0 to +70                                     | °C   |
| CDP6805G2C                                  |                  | -40 to +85                                   |      |
| Storage Temperature Range                   | T <sub>stg</sub> | -55 to +150                                  | °C   |
| Current Drain Total (PD4-PD7 only)          | ЮН               | 40                                           | mA   |

#### THERMAL CHARACTERISTICS

Port

| Characteristics                          | Symbol          | Value     | Unit |  |
|------------------------------------------|-----------------|-----------|------|--|
| Thermal Resistance<br>Plastic<br>Ceramic | θ <sub>JA</sub> | 100<br>50 | °c/w |  |

R<sub>2</sub>

R<sub>1</sub>

This device contains circuitry to protect the inputs against damage due to high static voltages of electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit. For proper operation it is recommended that  $V_{in}$  and  $V_{Out}$  be constrained to the range  $V_{SS} \leq (V_{in} \text{ or } V_{Out}) \leq V_{DD}$ . Reliability of operation is enhanced if unused inputs except OSC2 and NUM are tied to an appropriate logic voltage level (e.g., either V\_{SS} or  $V_{DD}$ ).



330

DC ELECTRICAL CHARACTERISTICS (VDD=3 Vdc, VSS=0 Vdc, TA=TL to TH, unless otherwise noted)

| Characteristics                                            | Symbol          | Min                 | Max | Unit |
|------------------------------------------------------------|-----------------|---------------------|-----|------|
| Output Voltage I <sub>Load</sub> ≤ 1 µA                    | VOL             |                     | 01  | V    |
|                                                            | ∨он             | V <sub>DD</sub> -01 | -   | V    |
| Output High Voltage                                        |                 |                     |     |      |
| (I <sub>Load</sub> = - 50 µA) PB0-PB7, PC0-PC7             | ∨он             | 1.4                 | -   | v    |
|                                                            | ∨он             | 1.4                 | -   | V    |
| (ILoad = -2 mA) PD4-PD7                                    | VOH             | 1.4                 | _   | v    |
| Output Low Voltage                                         |                 |                     |     |      |
| (ILoad = 300 $\mu$ A) All Ports                            | VOL             | -                   | 03  | V V  |
| PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7                         |                 |                     |     |      |
| Input High Voltage                                         |                 |                     |     |      |
| Ports PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7                   | VIH             | 2.7                 | VDD | V    |
| TIMER, IRQ, RESET                                          | VIH             | 2.7                 | VDD | V    |
| OSC1                                                       | VIH             | 2.7                 | VDD | V    |
| Input Low Voltage All Inputs                               | VIL             | VSS                 | 0.3 | V    |
| Total Supply Current (no dc Loads, t <sub>Cyc</sub> =5 µs) |                 |                     |     |      |
| RUN (measured during self-check, VIL=0.1 V, VIH=VDD-0.1 V) | ססו             | _                   | 0.5 | mA   |
| WAIT (See Note)                                            |                 | 1 - 1               | 200 | μA   |
| STOP (See Note)                                            | IDD             | - 1                 | 100 | μΑ   |
| I/O Ports Input Leakage                                    |                 | 1                   |     | 1    |
| PA0-PA7, PB0- PB7, PC0-PC7, PD0-PD7                        | կլ              | -                   | 5   | μΑ   |
| Input Current                                              |                 |                     |     |      |
| RESET, IRQ, TIMER, OSC1                                    | lin             |                     | ±1  | μΑ   |
| Capacitance                                                |                 |                     |     | _    |
| Ports                                                      | Cout            |                     | 12  | pF   |
| RESET, IRQ, TIMER, OSC1                                    | C <sub>in</sub> | -                   | 8   | pF   |

# DC ELECTRICAL CHARACTERISTICS (VDD=5 Vdc $\pm$ 10%, VSS=0 Vdc, TA=TL to TH, unless otherwise noted)

| Characteristics                                                                                    | Symbol          | Min                                       | Max        | Unit      |
|----------------------------------------------------------------------------------------------------|-----------------|-------------------------------------------|------------|-----------|
| Output Voltage I <sub>Load</sub> ≤10,µA                                                            | VOL             | - 1                                       | 01         | V         |
|                                                                                                    | Voн             | V <sub>DD</sub> -01                       | -          | V         |
| Output High Voltage                                                                                |                 |                                           |            |           |
| (I <sub>Load</sub> = - 100 µA) PB0-PB7, PC0-PC7                                                    | ∨он             | 2 4                                       | -          | V V       |
| (I <sub>Load</sub> = -2 mA) PA0-PA7, PD0-PD3                                                       | Voн             | 2 4                                       | -          | v         |
| (I <sub>Load</sub> = -8 mA) PD4-PD7                                                                | Vон             | 2.4                                       | -          | V         |
| Output Low Voltage<br>(I <sub>Load</sub> = 800 μA) All Ports<br>PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7 | VOL             | -                                         | 0.4        | v         |
| Input High Voltage                                                                                 | N               | N== 2                                     | VDD        | V         |
| Ports PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7<br>TIMER, IRQ, RESET, OSC1                                | ViH<br>ViH      | V <sub>DD</sub> -2<br>V <sub>DD</sub> -08 | VDD<br>VDD | 1 V       |
| Input Low Voltage All Inputs                                                                       |                 | VSS                                       | 0.8        | i v       |
| Total Supply Current (Ci = 50 pF                                                                   | VIL             |                                           | 00         | · · · · · |
| on Ports, no dc Loads, $t_{CVC} = 1 \mu s$ )                                                       |                 |                                           |            |           |
| RUN (measured during self-check,                                                                   | · ·             |                                           |            |           |
| $V_{1L} = 0.2 V, V_{1H} = V_{DD} - 0.2 V$                                                          | IDD             | -                                         | 4          | mA        |
| WAIT (See Note)                                                                                    | IDD             | -                                         | 1.5        | mA        |
| STOP (See Note)                                                                                    | IDD             | -                                         | 150        | μA        |
| I/O Ports Input Leakage<br>PA0-PA7, PB0- PB7, PC0-PC7, PD0-PD7                                     | կլ              | -                                         | ± 10       | μA        |
| nput Current<br>RESET, IRO, TIMER, OSC1                                                            | l <sub>in</sub> | -                                         | ±1         | μΑ        |
| Capacitance                                                                                        |                 |                                           |            |           |
| Ports                                                                                              | Cout            |                                           | 12         | pF        |
| RESET, IRQ, TIMER, OSC1                                                                            | C <sub>in</sub> | -                                         | 8          | pF        |

NOTE: Test conditions for IDD are as follows.

All ports programmed as inputs

VIL = 0 2 V (PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7)

 $\label{eq:ViH} VIH = V_{DD} - 0.2 \ V \ for \ \overline{RESET}, \ \overline{IRO}, \ TIMER \\ OSC1 \ input \ is a \ squarewave \ from \ 0.2 \ V \ to \ V_{DD} - 0 \ 2 \ V \\ OSC2 \ output \ load \ = \ 20 \ pF \ (wait \ I_{DD} \ is \ affected \ linearly \ by \ the \ V_{DD} \ bar{s}$ 

OSC2 capacitance)

TABLE 1 - CONTROL TIMING

 $(V_{DD} = 5 \text{ Vdc} \pm 10\%, V_{SS} = 0, T_A = T_L \text{ to } T_H, f_{OSC} = 4 \text{ MHz})$ 

| Characteristics                                            | Symbol                           | Min  | Max | Unit |
|------------------------------------------------------------|----------------------------------|------|-----|------|
| Crystal Oscillator Startup Time (Figure 5)                 | tOXOV                            | -    | 100 | mis  |
| Stop Recovery Startup Time (Crystal Oscillator) (Figure 6) | tillCH                           | -    | 100 | ms   |
| Timer Pulse Width (Figure 4)                               | tTH, tTL                         | 0.5  | _   | tcýc |
| Reset Pulse Width (Figure 5)                               | tRL                              | 1.5  | -   | tcyc |
| Timer Period (Figure 4)                                    | tTLTL                            | 1    | -   | tcyc |
| Interrupt Pulse Width Low (Figure 15)                      | tilih                            | 1    | -   | tcyc |
| Interrupt Pulse Period (Figure 15)                         | tilil                            | *    | -   | tcyc |
| OSC1 Pulse Width                                           | <sup>t</sup> OH, <sup>t</sup> OL | 100  |     | ns   |
| Cycle Time                                                 | tcyc                             | 1000 | -   | ns   |
| Frequency of Operation<br>Crystal                          | f <sub>osc</sub>                 | _    | 4   | MHz  |
| External Clock                                             | fosc                             | DC   |     | MHz  |

\*The minimum period tiLiL should not be less than the number of toyc cycles it takes to execute the interrupt service routines plus 20 toyc cycles







Fig. 5 – Power-on RESET and RESET.



\*\* REPRESENTS THE INTERNAL GATING OF THE OSCI INPUT PIN.

9205-38101

Fig. 6 - Stop recovery and power-on RESET.

# FUNCTIONAL PIN DESCRIPTION

#### VDD and VSS

Power is supplied to the MCU using these two pins.  $V_{\mbox{DD}}$  is power and  $V_{\mbox{SS}}$  is ground.

## **IRQ** (MASKABLE INTERRUPT REQUEST)

IRQ is mask option selectable with the choice of interrupt sensitivity being both level- and negative-edge or negative-edge only. The MCU completes the current instruction before it responds to the request. If IRQ is low and the interrupt mask bit (I bit) in the condition code register is clear, the MCU begins an interrupt sequence at the end of the current instruction.

If the mask option is selected to include level sensitivity, then the  $\overline{\text{IRQ}}$  input requires an external resistor to  $V_{DD}$  for "wire-OR" operation. See the Interrupt section for more detail

#### RESET

The RESET input is not required for start-up but can be used to reset the MCU's internal state and provide an orderly software start-up procedure. Refer to the Reset section for a detailed description

## TIMER

The TIMER input may be used as an external clock for the on-chip timer. Refer to Timer section for a detailed description.

#### NUM - NON-USER MODE

This pin is intended for use in self-check only. User applications should connect this pin to ground through a 10  $k\Omega$  resistor

# OSC1, OSC2

The CDP6805G2 can be configured to accept either a crystal input or an RC network. Additionally, the internal clocks can be derived by either a divide-by-two or divide-by-four of the external frequency (fOSC). Both of these options are mask selectable.

 $\mathbf{RC}$  – If the RC oscillator option is selected, then a resistor is connected to the oscillator pins as shown in Figure 7(b) The relationship between R and f<sub>OSC</sub> is shown in Figure 8.

**CRYSTAL** — The circuit shown in Figure 7(a) is recommended when using a crystal. The internal oscillator is designed to interface with an AT-cut parallel resonant quartz crystal resonator in the frequency range specified for  $f_{OSC}$  in the electrical characteristics table. Using an external CMOS oscillator is suggested when crystal and components should be mounted as close as possible to the input pins to minimize output distortion and start-up stabilization time Crystal frequency limits are also affected by VDD. Refer to Control Timing Characteristics for limits. See Table 1

**EXTERNAL CLOCK** — An external clock should be applied to the OSC1 input with the OSC2 input not connected, as shown in Figure 7(c). An external clock may be used with either the RC or crystal oscillator mask option.  $t_{OXOV}$  or  $t_{ILCH}$  do not apply when using an external clock input.

|       | 1 MHz | 4 MHz | Units |
|-------|-------|-------|-------|
| RSMAX | 400   | 75    | Ω     |
| CO    | 5     | 7     | pF    |
| C1    | 0 008 | 0 012 | μF    |
| COSC1 | 15-40 | 15-30 | рF    |
| COSC2 | 15-30 | 15-25 | рF    |
| RP    | 10    | 10    | MΩ    |
| Q     | 30    | 40    | -     |

## **Crystal Parameters**







Equivalent Crystal Circuit

(a)





(b) RC Oscillator Connection



Fig. 7 - Oscillator connections.



Fig. 8 - Typical frequency vs. resistance for RC oscillator option only.

## PA0-PA7

These eight I/O lines comprise Port A The state of any pin is software programmable Refer to Input/Output Programming section for a detailed description

#### **PB0-PB7**

These eight lines comprise Port B The state of any pin is software programmable Refer to Input/Output Programming section for a detailed description

#### PC0-PC7

These eight lines comprise Port C The state of any pin is software programmable Refer to the Input/Output Programming section for a detailed description

#### PD0-PD7

These eight lines comprise Port D PD4-PD7 also are capable of driving LED's directly. The state of any pin is software programmable. Refer to the Input/Output Programing section for a detailed description

## INPUT/OUTPUT PROGRAMMING

Any port pin may be software programmed as an input or output by the state of the corresponding bit in the port Data Direction Register (DDR) A pin is configured as an output if its corresponding DDR bit is set to a logic '1 ' A pin is configured as an input if its corresponding DDR bit is cleared to a logic '0 ' At reset, all DDRs are cleared, which configures all port pins as inputs A port pin configured as an output will output the data in the corresponding bit of its port data latch Refer to Figure 9 and Table 2



Fig. 9 – Typical port I/O circuitry.

#### TABLE 2 - I/O PIN FUNCTIONS

| R/W | DDR | 1/O Pin Function                                                         |  |  |  |
|-----|-----|--------------------------------------------------------------------------|--|--|--|
| 0   | 0   | The I/O pin is in input mode. Data is written into the output data latch |  |  |  |
| 0   | 1   | Data is written into the output data latch and output to the I/O pin     |  |  |  |
| 1   | 0   | The state of the I/O pin is read                                         |  |  |  |
| 1   | 1   | The I/O pin is in an output mode. The output data latch is read          |  |  |  |

# SELF-CHECK

The CDP6805G2 self-check is performed using the circuit in Figure 10. Self-check is initiated by tying NUM and TIMER pins to a logic 1 then executing a reset. After reset, five subroutines are called that execute the following tests:

I/O-Functionally exercise port A, B, C, D

RAM-Walking bit test

ROM - Exclusive OR with odd 1's parity result

Timer - Functionally exercise timer

Interrupts – Functionally exercise external and timer interrupts

Self-check results are shown in Table 3. The following subroutines are available to user programs and do not require any external hardware

### RAM SELF-CHECK SUBROUTINE

Returns with the Z-bit clear if any error is detected; otherwise the Z-bit is set

The RAM test must be called with the stack pointer at \$07F When run, the test checks every RAM cell except for \$07F and \$07E which are assumed to contain the return address.

A and X are modified. All RAM locations except the top 2 are modified. (Enter at location \$1F80.)

### ROM CHECKSUM SUBROUTINE

Returns with Z-bit cleared if any error was found, otherwise Z = 1. X = 0 on return, and A is zero if the test passed. RAM locations \$040-\$043 are overwritten. (Enter at location \$1F9B.)

#### TIMER TEST SUBROUTINE

Return with Z-bit cleared if any error was found; otherwise Z = 1.

This routine runs a simple test on the timer In order to work correctly as a user subroutine, the internal clock must be the clocking source and interrupts must be disabled. Also, on exit, the clock will be running and the interrupt mask not set so the caller must protect himself from interrupts if necessary

A and X register contents are lost; this routine counts how many times the clock counts in 128 cycles. The number of counts should be a power of two since the prescaler is a power of two. If not, the timer probably is not counting correctly. The routine also detects if the timer is running at all. (Enter at location \$1FB5.)

### MEMORY

The CDP6805G2 has a total address space of 8192 bytes of memory and I/O registers. The address space is shown in Figure 11.



Fig. 10 - Self-check circuit.

## TABLE 3 - SELF-CHECK RESULTS

| PD3 | PD2   | PD1    | PD0       | Remarks                       |
|-----|-------|--------|-----------|-------------------------------|
| 1   | 0     | 1      | 0         | Bad I/O                       |
| 1   | 0     | 1      | 1         | Bad Timer                     |
| 1   | 1     | 0      | 0         | Bad RAM                       |
| 1   | 1     | 0      | 1         | Bad ROM                       |
| 1   | 1     | 1      | 0         | Bad Interrupt or Request Flag |
|     | All C | ycling | Good Part |                               |
|     | All O | thers  |           | Bad Part                      |



\*Reads of unused locations undefined

Fig. 11 - Address map.

The first 128 bytes of memory (first half of page zero) is comprised of the I/O port locations, timer locations, and 112 bytes of RAM. The next 2096 bytes comprise the user ROM The 10 highest address bytes contain the reset and interrupt vectors.

The stack pointer is used to address data stored on the stack Data is stored on the stack during interrupts and subroutine calls At power-up, the stack pointer is set to \$007F and it is decremented as data is pushed on the stack. When data is removed from the stack, the stack pointer is incremented A maximum of 64 bytes of RAM is available for stack usage Since most programs use only a small part of the allocated stack locations for interrupts and/or subroutine stacking purposes, the unused bytes are usable for program data storage

# REGISTERS

The CDP6805G2 contains five registers as shown in the programming model in Figure 12. The interrupt stacking order is shown in Figure 13.

## ACCUMULATOR (A)

This accumulator is an 8-bit general purpose register used for arithmetic calculations and data manipulations

#### INDEX REGISTER (X)

The X register is an 8-bit register which is used during the indexed modes of addressing. It provides an 8-bit operand which is used to create an effective address. The index register is also used for data manipulations with the read/modify/write type of instructions and as a temporary storage register when not performing addressing operations.

#### **PROGRAM COUNTER (PC)**

The program counter is a 13-bit register that contains the address of the next instruction to be executed by the processor

## STACK POINTER (SP)

The stack pointer is a 13-bit register containing the address of the next free location on the stack. When accessing memory, the seven most-significant bits are permanently set to 0000001. These seven bits are appended to the six least-significant register bits to produce an address within the range of \$007F to \$0040. The stack area of RAM is used to store the return address on subroutine calls and the



Fig. 13 - Stacking order.

machine state during interrupts During external or poweron reset, and during a "reset stack pointer" instruction, the stack pointer is set to its upper limit (\$007F). Nested interrupts and/or subroutines may use up to 64 (decimal) locations, beyond which the stack pointer "wraps around" and points to its upper limit thereby losing the previously stored information. A subroutine call occupies two RAM bytes on the stack, while an interrupt uses five bytes

## CONDITION CODE REGISTER (CC)

The condition code register is a 5-bit register which indicates the results of the instruction just executed. These bits can be individually tested by a program and specific action taken as a result of their state. Each bit is explained in the following paragraphs.

HALF CARRY BITS (H) — The H-bit is set to a one when a carry occurs between bits 3 and 4 of the ALU during an ADD or ADC instruction. The H-bit is useful in binary coded decimal subroutines

**INTERRUPT MASK BIT (I)** — When the l-bit is set, both the external interrupt and the timer interrupt are disabled Clearing this bit enables the above interrupts. If an interrupt occurs while the l-bit is set, the interrupt is latched and is processed when the l-bit is next cleared.

**NEGATIVE (N)** — Indicates that the result of the last arithmetic, logical, or data manipulation is negative (bit 7 in the result is a logical one)

**ZERO (Z)** — Indicates that the result of the last arithmetic, logical, or data manipulation is zero.

 $\label{eq:carrybor} \begin{array}{l} \mbox{CARRY/BORROW (C)} & - \mbox{ indicates that a carry or borrow} \\ \mbox{out of the arithmetic logic unit (ALU) occurred during the} \\ \mbox{last arithmetic operation} & \mbox{This bit is also affected during bit} \\ \mbox{test and branch instructions, shifts, and rotates} \end{array}$ 

## RESETS

The CDP6805G2 has two reset modes: an active low external reset pin (RESET) and a power-on reset function; refer to Figure 5.

#### RESET

The  $\overline{RESET}$  input pin is used to reset the MCU to provide an orderly software start-up procedure. When using the external reset mode, the  $\overline{RESET}$  pin must stay low for a minimum of one  $t_{CYC}$ . The  $\overline{RESET}$  pin is provided with a Schmitt Trigger input to improve its noise immunity.

#### POWER-ON RESET

The power-on reset occurs when a positive transition is detected on V<sub>DD</sub>. The power-on reset is used strictly for power turn-on conditions and should not be used to detect any drops in the power supply voltage. There is no provision for a power-down reset. The power-on circuitry provides for a 1920 t<sub>CVC</sub> delay from the time of the first oscillator operation. If the external RESET pin is low at the end of the 1920 t<sub>CVC</sub> time out, the processor remains in the reset condition.

# CDP6805G2, CDP6805G2C

Either of the two types of reset conditions causes the following to occur

- $-\,{\rm Timer}$  control register interrupt request bit TCR7 is cleared to a ''0 ''
- Timer control register interrupt mask bit TCR6 is set to a "1 "
- All data direction register bits are cleared to a "0" All ports are defined as inputs
- Stack pointer is set to \$007F
- The internal address bus is forced to the reset vector (\$1FFE, \$1FFF)
- Condition code register interrupt mask bit (I) is set to a  $^{\prime\prime1}$   $^{\prime\prime}$
- -STOP and WAIT latches are reset
- External interrupt latch is reset

All other functions, such as other registers (including output ports), the timer, etc., are not cleared by the reset conditions

# INTERRUPTS

The CDP6805G2 may be interrupted by one of three different methods: either one of two maskable hardware interrupts (external input or timer) or a nonmaskable software interrupt (SWI). Systems often require that normal processing be interrupted so that some external event may be serviced.

Interrupts cause the processor registers to be saved on the stack and the interrupt mask (I bit) set to prevent additional interrupts. The RTI instruction causes the register contents to be recovered from the stack followed by a return to normal processing. The stack order is shown in Figure 13.

Unlike RESET, hardware interrupts do not cause the current instruction execution to be halted, but are considered pending until the current instruction execution is complete.

#### Note

The current instruction is considered to be the one already fetched and being operated on.

When the current instruction is complete, the processor checks all pending hardware interrupts and if unmasked (I bit clear), proceeds with interrupt processing; otherwise, the next instruction is fetched and executed. Note that masked interrupts are latched for later interrupt service.

If both an external interrupt and a timer interrupt are pending at the end of an instruction execution, the external interrupt is serviced first. The SWI is executed the same as any other instruction and as such takes precedence over hardware interrupts only if the I bit is set (hardware interrupts masked). Refer to Figure 14 for the interrupt and instruction processing sequence.

Table 4 shows the execution priority of the RESET, IRQ and timer interrupts, and instructions (including the software interrupts, SWI). Two conditions are shown, one with the I bit set and the other with I bit clear; however, in either case RESET has the highest priority of execution. If the I bit is set as per Table 4(a), the second highest priority is assigned to any instruction including SWI. This is illustrated in Figure 14 which shows that the IRQ or Timer interrupts are not executed when the I bit is set. If the I bit is cleared as per Table 4(b), the priorities change in that the next instruction (SWI or other instruction) is not fetched until after the IRQ and Timer interrupts have been recognized (and serviced). Also, when the I bit is clear, if both IRQ and Timer interrupts are pending, the IRQ interrupt is always serviced before the Timer interrupt.

<sup>\*</sup>Any current instruction including SWI



Fig. 14 - RESET and INTERRUPT processing flowchart.

TABLE 4 - INTERRUPT/INSTRUCTION EXECUTION PRIORITY AND VECTOR ADDRESS

(a) I Bit Set

| Interrupt/Instruction      | Priority | Vector<br>Address |
|----------------------------|----------|-------------------|
| RESET                      | 1        | \$1FFE-\$1FFF     |
| SWI (or Other Instruction) | 2        | \$1FFC-\$1FFD     |

NOTE: IRQ and Timer Interrupts are not executed when the I bit is set; therefore, they are not shown.

| ( | (b) | I. | Bit | CI | ear |  |
|---|-----|----|-----|----|-----|--|
|   |     |    |     |    |     |  |
|   |     |    |     |    |     |  |

| Interrupt/Instruction      | Priority | Vector<br>Address |
|----------------------------|----------|-------------------|
| RESET                      | 1        | \$1FFE-\$1FFF     |
| IRQ                        | 2        | \$1FFA-\$1FFB     |
| Timer                      | 3        | \$1FF8-\$1FF9     |
|                            |          | \$1FF6-\$1FF7*    |
| SWI (or other Instruction) | 4        | \$1FFC-\$1FFD     |

\* The Timer vector address from the WAIT mode is \$1FF6-\$1FF7.

#### Note

Processing is such that at the end of the current instruction execution, the I bit is tested and if set the next instruction (including SWI) is fetched. If the I bit is cleared, the hardware interrupt latches are tested, and if no hardware interrupt is pending, the program falls through and the next instruction is fetched.

#### TIMER INTERRUPT

If the timer interrupt mask bit (TCR6) is cleared, then each time the timer decrements to zero (transitions from \$01 to \$00) an interrupt request is generated. The actual processor interrupt is generated only if the interrupt mask bit of the condition code register is also cleared. When the interrupt is recognized, the current state of the machine is pushed onto the stack and the interrupt mask bit in the condition code register is set. This masks further interrupts until the present one is serviced. The processor now vectors to the timer interrupt service routine. The address for this service routine is specified by the contents of \$1FF8 and \$1FF9 unless the processor is in a WAIT mode in which case the contents of \$1FF6 and \$1FF7 specify the timer service routine address. Software must be used to clear the timer interrupt request bit (TCR7). At the end of the timer interrupt service routine, the software normally executes an RTI instruction which restores the machine state and starts executing the interrupted program.

#### EXTERNAL INTERRUPT

If the interrupt mask bit of the condition code register is cleared and the external interrupt pin  $(\overline{IRQ})$  is low,

then the external interrupt occurs. The action of the external interrupt is identical to the timer interrupt with the exception that the service routine address is specified by the contents of \$1FFA and \$1FFB. Either a level- and edge-sensitive trigger (or edge-sensitive only) are available as mask options. Figure 15 shows both a functional diagram and timing for the interrupt line. The timing diagram shows two different treatments of the interrupt line (IRQ) to the processor. The first method is single pulses on the interrupt line spaced far enough apart to be serviced. The minimum time between pulses is a function of the length of the interrupt service routine. Once a pulse occurs, the next pulse should not occur until the MPU software has exited the routine (an RTI occurs). This time (tiLIL) is obtained by adding 20 instruction cycles (tcyc) to the total number of cycles is takes to complete the service routine including the RTI instruction; refer to Figure 15. The second configuration shows many interrupt lines "wire-ORed" to form the interrupts at the processor. Thus, if after servicing an interrupt the IRQ remains low, then the next interrupt is recognized.

#### SOFTWARE INTERRUPT (SWI)

The software interrupt is an executable instruction. The action of the SWI instruction is similar to the hardware interrupts. The SWI is executed regardless of the state of the interrupt mask in the condition code register. The service routine address is specified by the contents of memory locations \$1FFC and \$1FFD. See Figure 14 for interrupt and instruction processing flowchart.



#### STOP

The STOP instruction places the CDP6805G2 in its lowest power consumption mode. In the STOP function the internal oscillator is turned off, causing all internal processing and the timer to be halted; refer to Figure 16.

During the STOP mode, timer control register (TCR) bits 6 and 7 are altered to remove any pending timer interrupt requests and to disable any further timer interrupts. The timer prescaler is cleared External interrupts are enabled in the condition code register. All other registers and memory remain unaltered All I/O lines remain unchanged.



Fig. 16 - Stop function flowchart.

WAIT

The WAIT instruction places the CDP6805G2 in a low power consumption mode, but the WAIT mode consumes somewhat more power than the STOP mode. In the WAIT mode, the internal clock is diabled from all internal circuitry except the timer circuit; refer to Figure 17. Thus, all internal processing is halted; however, the timer continues to count normally.

During the Wait mode, the I-bit in the condition code register is cleared to enable interrupts. All other registers, memory, and I/O lines remain in their last state. The timer may be enabled to allow a periodic exit from the Wait mode. If an external and a timer interrupt occur at the same time, the external interrupt is serviced first; then, if the timer interrupt routine, the normal timer interrupt (not the timer Wait interrupt) is serviced since the MCU is no longer in the WAIT mode.

# TIMER

The MCU timer contains a 8-bit software programmable counter with7-bit software selectable prescaler. The counter may be present under program control and decrements towards zero. When the counter decrements to zero, the timer interrupt request bit, i.e., bit 7 of the timer control register (TRC), is set. Then, if the timer interrupt is not masked, i.e., bit 6 of the TCR and the I-bit in the condition code register are both cleared, the processor receives an interrupt. After completion of the current instruction, the processor proceeds to store the appropriate registers on the stack, and then fetches the timer vector address from locations \$1FF8 and \$1FF9 (or \$1FF6 and \$1FF7 if in the WAIT mode) in order to beging servicing.

The counter continues to count after it reaches zero, allowing the software to determine the number of internal or external input clocks since the timer interrupt request bit was set. The counter may be read at any time by the processor without disturbing the count. The contents of the counter becomes stable prior to the read portion of a cycle and does not change during the read. The timer interrupt request bit remains set until cleared by the software. If a read occurs before the timer interrupt is serviced, the interrupt is lost. TCR7 may also be used as a scanned status bit in a noninterrupt mode of operation (TCR6=1).

The prescaler is a 7-bit divider which is used to extend the maximum length of the timer. Bit 0, bit 1, and bit 2 of the TCR are programmed to choose the appropriate prescaler output which is used as the counter input. The processor cannot write into or read from the prescaler; however, its contents are cleared to all "0's" by the write operation into TCR when bit 3 of the written data equals 1. This allows for truncation-free counting.

The timer input can be configured for three different operating modes, plus a disable mode depending on the value written to the TCR4, TCR5 control bits. Refer to the Timer Control Register section.

#### TIMER INPUT MODE 1

If TCR4 and TCR5 are both programmed to a "0," the input to the timer is from an internal clock and the TIMER input pin is disabled. The internal clock mode can be used for periodic interrupt generation, as well as a reference in frequency and event measurement. The internal clock is the instruction cycle clock. During a WAIT instruction, the internal clock to the timer continues to run at its normal rate.



Fig. 17 - Wait function flowchart.

#### TIMER INPUT MODE 2

With TCR4=1 and TCR5=0, the internal clock and the TIMER input pin are ANDed together to form the timer input signal. This mode can be used to measure external pulse widths. The external pulse simply turns on the internal clock for the duration of the pulse. The resolution of the count in this mode is  $\pm 1$  clock and, therefore, accuracy improves with longer input pulse widths.

#### TIMER INPUT MODE 3

If TCR4 = 0 and TCR5 = 1, then all inputs to the Timer are disabled

#### TIMER INPUT MODE 4

If TCR4=1 and TCR5=1, the internal clock input to the Timer is disabled and the TIMER input pin becomes the input to the Timer. The timer can, in this mode, be used to count external events as well as external frequencies for generating periodic interrupts. The counter is clocked on the falling edge of the external signal.

Figure 18 shows a block diagram of the Timer subsystem. Power-on Reset and the STOP instruction cause the counter to be set to \$F0.



2 Counter is written to during Data Strobe (DS) and counts down continuously.

92CM- 38034R1

Fig. 18 - Simplified timer control logic block diagram.

#### Timer Control Register (TCR)

| 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |  |
|------|------|------|------|------|------|------|------|--|
| TCR7 | TCR6 | TCR5 | TCR4 | TCR3 | TCR2 | TCR1 | TCRO |  |

All bits in this register except bit 3 are Read/Write bits.

**TCR7** - Timer interrupt request bit: bit used to indicate the timer interrupt when it is logic "1".

- 1 Set whenever the counter decrements to zero, or under program control.
- 0 Cleared on external reset, power-on reset, STOP instruction, or program control.

**TCR6** – Timer interrupt mask bit when this bit is a logic "1" it inhibits the timer interrupt to the processor.

- Set on external reset, power-on reset, STOP instruction, or program control.
- 0 Cleared under program control

TCR5 - External or internal bit selects the input clock source to be either the external timer pin or the internal clock. (Unaffected by RESET)

- 1 Select external clock source.
- 0 Select internal clock source (AS).

TCR4 – External enable bit control bit used to enable the external timer pin. (Unaffected by RESET.)

- 1 Enable external timer pin.
- 0 Disable external timer pin

# TCR5 TCR4

|   | 0 |   | Internal clock to Timer         |
|---|---|---|---------------------------------|
|   | 0 |   | AND of internal clock and TIMER |
|   |   |   | pin to Timer                    |
| 1 | 1 | 0 | Inputs to Timer disabled        |
|   | 1 | 1 | TIMER pin to Timer              |
|   |   |   |                                 |

Refer to Figure 18 for Logic Representation.

**TCR3** – Timer Prescaler Reset bit: writing a "1" to this bit resets the prescaler to zero. A read of this location always indicates a "0". (Unaffected by  $\overline{\text{RESET}}$ .)

TCR2, TCR1, TCR0 - Prescaler select bits: decoded to select one of eight taps on the prescaler. (Unaffected by  $\overrightarrow{\text{RESET.}}$ )

|      | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ |      |        |  |  |  |  |  |  |  |  |  |
|------|-------------------------------------------------------|------|--------|--|--|--|--|--|--|--|--|--|
| TCR2 | TCR1                                                  | TCR0 | Result |  |  |  |  |  |  |  |  |  |
| 0    | 0                                                     | 0    | + 1    |  |  |  |  |  |  |  |  |  |
| 0    | 0                                                     | 1    | + 2    |  |  |  |  |  |  |  |  |  |
| 0    | 1                                                     | 0    | + 4    |  |  |  |  |  |  |  |  |  |
| 0    | 1                                                     | 1    | + 8    |  |  |  |  |  |  |  |  |  |
| 1    | 0                                                     | 0    | + 16   |  |  |  |  |  |  |  |  |  |
| 1    | 0                                                     | 1    | + 32   |  |  |  |  |  |  |  |  |  |
| 1    | 1                                                     | 0    | ÷ 64   |  |  |  |  |  |  |  |  |  |
| 1    | 1                                                     | 1    | - 128  |  |  |  |  |  |  |  |  |  |

# **INSTRUCTION SET**

The MCU has a set of 61 basic instructions They can be divided into five different types: register/memory, read/modify/write, branch, bit manipulation, and control. The following paragraphs briefly explain each type. All the instructions within a given type are presented in individual tables

#### **REGISTER/MEMORY INSTRUCTIONS**

Most of these instructions use two operands. One operand is either the accumulator or the index register. The other operand is obtained from memory using one of the addressing modes. The operand for the jump unconditional (JMP) and jump to subroutine (JSR) instructions is the program counter. Refer to Table 5.

#### READ/MODIFY/WRITE INSTRUCTIONS

These instructions read a memory location or a register, modify or test its contents, and write the modified value back to memory or to the register. The test for negative or zero (TST) instruction is an exception to the read/modify/write sequence since it does not modify the value. Refer to Table 6.

#### **BRANCH INSTRUCTIONS**

Most branch instructions test the state of the Condition Code Register and if certain criteria are met, a branch is executed This adds an offset between + 128 and - 127 to the current program counter. Refer to Table 7.

#### **BIT MANIPULATION INSTRUCTIONS**

The MPU is capable of setting or clearing any bit which resides in the first 256 bytes of the memory space, where all port registers, port DDR's, timer, timer control, and on-chip RAM reside. An additional feature allows the software to test and branch on the state of any bit within these 256 locations. The bit set, bit clear and bit test and branch functions are all implemented with a single instruction. For the test and branch instructions the value of the bit tested is also placed in the carry bit of the Condition Code Register. Refer to Table 8 for instruction cycle timing.

#### CONTROL INSTRUCTIONS

These instructions are register reference instructions and are used to control processor operation during program execution. Refer to Table 9 for instruction cycle timing.

## ALPHABETICAL LISTING

The complete instruction set is given in alphabetical order in Table 11.

#### OPCODE MAP

Table 10 is an opcode map for the instructions used on the MCU.

### ADDRESSING MODES

The MCU uses ten different addressing modes to give the programmer an opportunity to optimize the code to all situations. The various indexed addressing modes make it possible to locate data tables, code conversion tables and scalling tables anywhere in the memory space. Short indexed accesses are single byte instructions, while the longest instructions (three bytes) permit tables throughout memory. Short

# CDP6805G2, CDP6805G2C

and long absolute addressing is also included. One and two byte direct addressing instructions access all data bytes inmost applications. Extended addressing permits jump instructions to reach all memory. Table 11 shows the addressing modes for each instruction, with the effects each instruction has on the Condition Code Register. An opcode map is shown in Table 10.

The term "Effective Address" (EA) is used in describing the various addressing modes, which is defined as the byte address to or from which the argument for an instruction is fetched or stored. The ten addressing modes of the processor are described below. Parentheses are used to indicate "contents of," an arrow indicates "is replaced by" and a colon indicates concatenation of two bytes.

#### INHERENT

In inherent instructions all the information necessary to execute the instruction is contained in the opcode. Operations specifying only the index register or accumulator, and no other arguments, are included in this mode.

#### IMMEDIATE

In immediate addressing, the operand is contained in the byte immediately following the opcode. Immediate addressing is used to access constants which do not change during program execution (e.g., a constant used to initialize a loop counter).

$$EA = PC + 1; PC \leftarrow PC + 2$$

#### DIRECT

In the direct addressing mode, the effective address of the argument is contained in a single byte following the opcode byte. Direct addressing allows the user to directly address the lowest 256 bytes in memory with a single two byte instruction. This includes all on-chip RAM and I/O registers and 128 bytes of on-chip ROM. Direct addressing is efficient in both memory and time.

#### EA = (PC + 1); PC - PC + 2Address Bus High - 0; Address Bus Low - (PC + 1) EXTENDED

In the extended addressing mode, the effective address of the argument is contained in the two bytes following the opcode. Instructions with extended addressing modes are capable of referencing arguments anywhere in memory with a single three byte instruction.

$$EA = (PC + 1):(PC + 2); PC \leftarrow PC + 3$$
  
Address Bus High  $\leftarrow (PC + 1);$  Address Bus Low  $\leftarrow (PC + 2)$ 

#### INDEXED, NO-OFFSET

In the indexed, no offset addressing mode, the effective address of the argument is contained in the 8-bit index register. Thus, this addressing mode can access the first 256 memory locations. These instructions are only one byte long and therefore are more efficient. This mode is used to move a pointer through a table or to address a frequency referenced RAM or I/O location.

EA = X; PC ← PC + 1 Address Bus High ← 0; Address Bus Low ← X

## INDEXED, 8-BIT OFFSET

Here the EA is obtained by adding the contents of the byte following the opcode to that of the index register. The operand is therefore located anywhere within the lowest 511 memory locations. For example, this mode of addressing is useful for selecting the m-th element in an n element table. All instructions are two bytes. The contents of the index register (X) is not changed. The contents of (PC + 1) is an unsigned 8-bit integer. One byte offset indexing permits look-up tables to be easily accessed in either RAM or ROM.

EA = X + (PC + 1); PC-PC + 2

Address Bus High  $\leftarrow$  K, Address Bus Low  $\leftarrow$  X + (PC + 1) Where K = The carly from the addition of X + (PC + 1)

#### INDEXED, 16-BIT OFFSET

In the indexed, 16-bit offset addressing mode the effective address is the sum of the contents of the unsigned 8-bit index register and the two unsigned bytes following the opcode. This addressing mode can be used in a manner similar to indexed 8-bit offset, except that this three byte instruction allows tables to be anywhere in memory (e.g., jump tables in ROM).

 $\begin{aligned} \mathsf{EA} &= \mathsf{X} + [(\mathsf{PC}+1) \ (\mathsf{PC}+2)], \ \mathsf{PC} \leftarrow \mathsf{PC}+3 \\ & \mathsf{Address} \ \mathsf{Bus} \ \mathsf{High} \leftarrow (\mathsf{PC}+1) + \mathsf{K}, \\ & \mathsf{Address} \ \mathsf{Bus} \ \mathsf{Low} \leftarrow \mathsf{X} + (\mathsf{PC}+2) \end{aligned}$  Where  $\mathsf{K} &= \mathsf{The} \ \mathsf{carry} \ \mathsf{from the} \ \mathsf{addition} \ \mathsf{of} \ \mathsf{X} + (\mathsf{PC}+2) \end{aligned}$ 

### RELATIVE

Relative addressing is only used in branch instructions. In relative addressing the contents of the 8-bit signed byte following the opcode (the offset) is added to the PC if and only if the branch condition is true. Otherwise, control proceeds to the next instruction. The span of relative addressing is limited to the range of -126 to +129 bytes from the branch instruction opcode location.

## BIT SET/CLEAR

Direct addressing and bit addressing are combined in instructions which set and clear individual memory and I/O bits. In the bit set and clear instructions, the byte is specified as a direct address in the location following the opcode. The first 256 addressable locations are thus accessed. The bit to be modified within that byte is specified with three bits of the opcode. The bit set and clear instructions occupy two bytes, one for the opcode (including the bit number) and the second to address the byte which contains the bit of interest

 $EA = (PC + 1), PC \leftarrow PC + 2$ 

Address Bus High ← 0, Address Bus Low ← (PC + 1)

#### BIT TEST AND BRANCH

Bit test and branch is a combination of direct addressing, bit addressing and relative addressing. The bit address and condition (set or clear) to be tested is part of the opcode. The address of the byte to be tested is in the single byte immediately following the opcode byte (EA1). The signed relative 8-bit offset is in the third byte (EA2) and is added to the PC if the specified bit is set or clear in the specified memory location. This single three byte instruction allows the program to branch based on the condition of any bit in the first 256 locations of memory.

EA1 = (PC + 1)Address Bus High-0, Address Bus Low-(PC + 1) EA2 = PC + 3 + (PC + 2), PC - EA2 if branch taken,otherwise PC-PC+3

### **TABLE 5 - REGISTER/MEMORY INSTRUCTIONS**

|                                             |          |            | Addressing Modes |             |            |            |             |            |            |             |                        |            |             |                           |            |             |            |                     |             |
|---------------------------------------------|----------|------------|------------------|-------------|------------|------------|-------------|------------|------------|-------------|------------------------|------------|-------------|---------------------------|------------|-------------|------------|---------------------|-------------|
|                                             |          | 1          | mmediat          | e           |            | Direct     |             | Extended   |            |             | Indexed<br>(No Offset) |            |             | Indexed<br>(8-Bit Offset) |            |             |            | Indexed<br>Bit Off: |             |
| Function                                    | Mnemonic | Op<br>Code | #<br>Bytes       | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code             | #<br>Bytes | #<br>Cycles | Op<br>Code                | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes          | #<br>Cycles |
| Load A from Memory                          | LDA      | A6         | 2                | 2           | B6         | 2          | 3           | C6         | 3          | 4           | F6                     | 1          | 3           | E6                        | 2          | 4           | D6         | 3                   | 5           |
| Load X from Memory                          | LDX      | AE         | 2                | 2           | BE         | 2          | 3           | CE         | 3          | 4           | FE                     | 1          | 3           | EE                        | 2          | 4           | DE         | 3                   | 5           |
| Store A in Memory                           | STA      | -          | -                | -           | B7         | 2          | 4           | C7         | 3          | 5           | F7                     | 1          | 4           | E7                        | 2          | 5           | D7         | 3                   | 6           |
| Store X in Memory                           | STX      | -          | -                | -           | BF         | 2          | 4           | CF         | 3          | 5           | FF                     | 1          | 4           | EF                        | 2          | 5           | DF         | 3                   | 6           |
| Add Memory to A                             | ADD      | AB         | 2                | 2           | BB         | 2          | 3           | СВ         | 3          | 4           | FB                     | 1          | 3           | EB                        | 2          | 4           | DB         | 3                   | 5           |
| Add Memory and<br>Carry to A                | ADC      | A9         | 2                | 2           | В9         | 2          | 3           | С9         | 3          | 4           | F9                     | 1          | 3           | E9                        | 2          | 4           | D9         | 3                   | 5           |
| Subtract Memory                             | SUB      | A0         | 2                | 2           | BO         | 2          | 3           | CO         | 3          | 4           | F0                     | 1          | 3           | E0                        | 2          | 4           | D0         | 3                   | 5           |
| Subtract Memory from<br>A with Borrow       | SBC      | A2         | 2                | 2           | B2         | 2          | 3           | C2         | 3          | 4           | F2                     | 1          | 3           | E2                        | 2          | 4           | D2         | 3                   | 5           |
| AND Memory to A                             | AND      | A4         | 2                | 2           | B4         | 2          | 3           | C4         | 3          | 4           | F4                     | 1          | 3           | E4                        | 2          | 4           | D4         | 3                   | 5           |
| OR Memory with A                            | ORA      | AA         | 2                | 2           | BA         | 2          | 3           | CA         | 3          | 4           | FA                     | 1          | 3           | EA                        | 2          | 4           | DA         | 3                   | 5           |
| Exclusive OR Memory<br>with A               | EOR      | A8         | 2                | 2           | B8         | 2          | 3           | C8         | 3          | 4           | F8                     | 1          | 3           | E8                        | 2          | 4           | D8         | 3                   | 5           |
| Arithmetic Compare A<br>with Memory         | СМР      | A1         | 2                | 2           | B1         | 2          | 3           | C1         | 3          | 4           | F1                     | 1          | 3           | E1                        | 2          | 4           | D1         | 3                   | 5           |
| Arithmetic Compare X<br>with Memory         | СРХ      | A3         | 2                | 2           | В3         | 2          | 3           | C3         | 3          | 4           | F3                     | 1          | 3           | E3                        | 2          | 4           | D3         | 3                   | 5           |
| Bit Test Memory with<br>A (Logical Compare) | віт      | A5         | 2                | 2           | B5         | 2          | 3           | C5         | 3          | 4           | F5                     | 1          | 3           | E5                        | 2          | 4           | D5         | 3                   | 5           |
| Jump Unconditional                          | JMP      | -          | -                | -           | BC         | 2          | 2           | сс         | 3          | 3           | FC                     | 1          | 2           | EC                        | 2          | 3           | DC         | 3                   | 4           |
| Jump to Subroutine                          | JSR      | -          | -                | -           | BD         | 2          | 5           | CD         | 3          | 6           | FD                     | 1          | 5           | ED                        | 2          | 6           | DD         | 3                   | 7           |

## TABLE 6 - READ/MODIFY/WRITE INSTRUCTIONS

|                              |          |              | Addressing Modes |             |            |            |             |            |            |             |                        |            |             |                           |            |             |
|------------------------------|----------|--------------|------------------|-------------|------------|------------|-------------|------------|------------|-------------|------------------------|------------|-------------|---------------------------|------------|-------------|
|                              |          | Inherent (A) |                  |             | ir         | herent (   | X)          | Direct     |            |             | Indexed<br>(No Offset) |            |             | Indexed<br>(8-Bit Offset) |            |             |
| Function                     | Mnemonic | Op<br>Code   | #<br>Bytes       | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code             | #<br>Bytes | #<br>Cycles | Op<br>Code                | #<br>Bytes | #<br>Cycles |
| Increment                    | INC      | 4C           | 1                | 3           | 5C         | 1          | 3           | 3C         | 2          | 5           | 7C                     | 1          | 5           | 6C                        | 2          | 6           |
| Decrement                    | DEC      | 4A           | 1                | 3           | 5A         | 1          | 3           | 3A         | 2          | 5           | 7A                     | 1          | 5           | 6A                        | 2          | 6           |
| Clear                        | CLR      | 4F           | 1                | 3           | 5F         | 1          | 3           | 3F         | 2          | 5           | 7F                     | 1          | 5           | 6F                        | 2          | 6           |
| Complement                   | COM      | 43           | 1                | 3           | 53         | 1          | 3           | 33         | 2          | 5           | 73                     | 1          | 5           | 63                        | 2          | 6           |
| Negate<br>(2's Complement)   | NEG      | 40           | 1                | 3           | 50         | 1          | 3           | 30         | 2          | 5           | 70                     | 1          | 5           | 60                        | 2          | 6           |
| Rotate Left Thru Carry       | ROL      | 49           | 1                | 3           | 59         | 1          | 3           | 39         | 2          | 5           | 79                     | 1          | 5           | 69                        | 2          | 6           |
| Rotate Right Thru<br>Carry   | ROR      | 46           | 1                | 3           | 56         | 1          | 3           | 36         | 2          | 5           | 76                     | 1          | 5           | 66                        | 2          | 6           |
| Logical Shift Left           | LSL      | 48           | 1                | 3           | 58         | 1          | 3           | 38         | 2          | 5           | 78                     | 1          | 5           | 68                        | 2          | 6           |
| Logical Shift Right          | LSR      | 44           | 1                | 3           | 54         | 1          | 3           | 34         | 2          | 5           | 74                     | 1          | 5           | 64                        | 2          | 6           |
| Arithmetic Shift Right       | ASR      | 47           | 1                | 3           | 57         | 1          | 3           | 37         | 2          | 5           | 77                     | 1          | 5           | 67                        | 2          | 6           |
| Test for Negative<br>or Zero | TST      | 4D           | 1                | 3           | 5D         | 1          | 3           | 3D         | 2          | 4           | 7D                     | 1          | 4           | 6D                        | 2          | 5           |

ω

# TABLE 7 - BRANCH INSTRUCTIONS

|                                        |          | Relative   | Addressin  | ng Mode     |
|----------------------------------------|----------|------------|------------|-------------|
| Function                               | Mnemonic | Op<br>Code | #<br>Bytes | #<br>Cycles |
| Branch Always                          | BRA      | 20         | 2          | 3           |
| Branch Never                           | BRN      | 21         | 2          | 3           |
| Branch IFF Higher                      | вні      | 22         | 2          | 3           |
| Branch IFF Lower or Same               | BLS      | 23         | 2          | 3           |
| Branch IFF Carry Clear                 | BCC      | 24         | 2          | 3           |
| (Branch IFF Higher or Same)            | (BHS)    | 24         | 2          | 3           |
| Branch IFF Carry Set                   | BCS      | 25         | 2          | 3           |
| (Branch IFF Lower)                     | (BLO)    | 25         | 2          | 3           |
| Branch IFF Not Equal                   | BNE      | 26         | 2          | 3           |
| Branch IFF Equal                       | BEQ      | 27         | 2          | 3           |
| Branch IFF Half Carry Clear            | BHCC     | 28         | 2          | 3           |
| Branch IFF Half Carry Set              | BHCS     | 29         | 2          | 3           |
| Branch IFF Plus                        | BPL      | 2A         | 2          | 3           |
| Branch IFF Minus                       | BMI      | 2B         | 2          | 3           |
| Branch IFF Interrupt Mask Bit is Clear | BMC      | 2C         | 2          | 3           |
| Branch IFF Interrupt Mask Bit is Set   | BMS      | 2D         | 2          | 3           |
| Branch IFF Interrupt Line is Low       | BIL      | 2E         | 2          | 3           |
| Branch IFF Interrupt Line is High      | ВІН      | 2F         | 2          | 3           |
| Branch to Subroutine                   | BSR      | AD         | 2          | 6           |

# TABLE 8 - BIT MANIPULATION INSTRUCTIONS

|                           |                   | Addressing Modes |            |             |                 |            |             |  |  |  |  |  |  |
|---------------------------|-------------------|------------------|------------|-------------|-----------------|------------|-------------|--|--|--|--|--|--|
|                           |                   | -8               | t Set/Cle  | Bit Te      | Test and Branch |            |             |  |  |  |  |  |  |
| Function                  | Mnemonic          | Op<br>Code       | #<br>Bytes | #<br>Cycles | Op<br>Code      | #<br>Bytes | #<br>Cycles |  |  |  |  |  |  |
| Branch IFF Bit n is Set   | BRSET n (n = 0 7) | -                | -          | -           | 2•n             | 3          | 5           |  |  |  |  |  |  |
| Branch IFF Bit n is Clear | BRCLR n (n = 0 7) | -                | -          | -           | 01+2•n          | 3          | 5           |  |  |  |  |  |  |
| Set Bit n                 | BSET n (n = 0 7)  | 10+2•n           | 2          | 5           | -               | -          | -           |  |  |  |  |  |  |
| Clear Bit n               | BCLR n (n=0 7)    | 11+2•n           | 2          | 5           | -               | -          | -           |  |  |  |  |  |  |

## **TABLE 9 - CONTROL INSTRUCTIONS**

|                          |          |            | Inherent   |             |
|--------------------------|----------|------------|------------|-------------|
| Function                 | Mnemonic | Op<br>Code | #<br>Bytes | #<br>Cycles |
| Transfer A to X          | TAX      | 97         | 1          | 2           |
| Transfer X to A          | TXA      | 9F         | 1          | 2           |
| Set Carry Bit            | SEC      | 99         | 1          | 2           |
| Clear Carry Bit          | CLC      | 98         | 1          | 2           |
| Set Interrupt Mask Bit   | SEI      | 9B         | 1          | 2           |
| Clear Interrupt Mask Bit | CLI      | 9A         | 1          | 2           |
| Software Interrupt       | SWI      | 83         | 1          | 10          |
| Return from Subroutine   | RTS      | 81         | 1          | 6           |
| Return from Interrupt    | RTI      | 80         | 1          | 9           |
| Reset Stack Pointer      | RSP      | 9C         | 1          | 2           |
| No-Operation             | NOP      | 9D         | 1          | 2           |
| Stop                     | STOP     | 8E         | 1          | 2           |
| Wait                     | WAIT     | 8F         | 1          | 2           |

|           | 0 BRE TO<br>3 BSE TO<br>BSE TO<br>3 BSE TO<br>BSE TO<br>5 BSE TO<br>BSC TO<br>BSC TO<br>5 STO<br>BSC TO<br>5 STO<br>STO<br>STO<br>STO<br>STO<br>STO<br>STO<br>STO<br>STO<br>STO |                |                   |                                | Read/Modify/Write |                    |                     |          |                    |           | Control Register/Memory |                   |                      |              |                     |           |           |  |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|-------------------|--------------------------------|-------------------|--------------------|---------------------|----------|--------------------|-----------|-------------------------|-------------------|----------------------|--------------|---------------------|-----------|-----------|--|
|           | BTB                                                                                                                                                                             | BSC            | REL               | DIR                            | INH               | INH                | IX1                 | IX       | INH                | INH       | IMM                     | DIR               | EXT                  | 1X2          | IX1                 | <u>IX</u> |           |  |
| Low       | 0000                                                                                                                                                                            | 0001           | 0010              | 0011                           | 0100              | 0101               | 6<br>0110           | 0111     | 8<br>1000          | 9<br>1001 | A<br>1010               | B<br>1011         | C<br>1100            | D<br>1101    | E<br>1110           | 1111      | Hi Low    |  |
|           | BRSETO                                                                                                                                                                          | BSETO          |                   | NEG 5<br>2 DIR                 | NEG               | NEG<br>1 INH       | 0<br>2 NEG<br>2 IX1 | NEG 1    | 9<br>RTI<br>1 INH  |           | SUB 2<br>2 IMM          | 3<br>SUB<br>2 DIR | SUB<br>3 EXT         | 3 SUB 3 IX2  | SUB<br>2 IX1        |           | 0000      |  |
|           |                                                                                                                                                                                 |                | 2 REL             |                                |                   |                    |                     |          | RTS<br>1 INH       |           | CMP 2<br>2 IMM          | 2 CMP 2 DIR       | CMP 3 EXT            | CMP 3 1X2    | CMP 2 1X1           |           | 1<br>0001 |  |
| 2<br>0010 |                                                                                                                                                                                 |                |                   |                                |                   |                    |                     |          |                    |           | SBC 2<br>2 IMM          | SBC 3<br>2 DIR    | SBC<br>3 EXT         | SBC 3 IX2    | SBC 4<br>2 IX1      |           | 2<br>0010 |  |
|           |                                                                                                                                                                                 |                | BLS<br>2 REL      | COM<br>2 DIR                   |                   |                    | 2 COM 6             | COM 5    | 10<br>SWI<br>1 INH |           | CPX 2<br>2 IMM          | CPX 3<br>2 DIR    | CPX<br>3 EXT         | CPX 3 1X2    | CPX 4               | CPX 3     | 3<br>0011 |  |
|           |                                                                                                                                                                                 |                | BCC 3             | LSR<br>2 DTR                   | LSRA<br>1 INH     | LSRX 3             | LSR<br>2 IX1        |          |                    |           | AND 2 IMM               | AND<br>2 DIR      | AND<br>3 EXT         |              | AND 2 1X1           |           | 4<br>0100 |  |
|           |                                                                                                                                                                                 |                |                   | 5                              |                   | 3                  |                     | 5        |                    |           | BIT 2                   | BIT 2 DIR         | BIT<br>3 EXT         | BIT 3 1X2    | BIT 4<br>2 IX1<br>4 | BIT 3     | 5<br>0101 |  |
| 6<br>0110 |                                                                                                                                                                                 | BSET3<br>2 BSC | BNE 3<br>2 REL 3  | ROR 2 DIR                      |                   |                    | ROR 2 1X1           |          |                    |           | LDA 2<br>2 IMM          |                   | LDA<br>3 EXT         |              | LDA 2 1X1           |           | 6<br>0110 |  |
|           |                                                                                                                                                                                 |                | BEQ               | ASR <sup>3</sup><br>2 DIR<br>5 |                   |                    | ASR 2 1X1           | ASR 1 IX |                    |           |                         | STA 2             | STA<br>3 EXT         | STA<br>3 1X2 | STA                 |           | 7<br>0111 |  |
|           |                                                                                                                                                                                 |                | 2 BHCC 3          |                                |                   |                    | 2 LSL 1             |          |                    |           |                         |                   | 3 EOR                | EOR          | EOR                 |           | 8<br>1000 |  |
| 9<br>1001 |                                                                                                                                                                                 |                | BHCS              |                                |                   |                    | ROL 2 1X1           |          |                    | SEC 1     |                         | ADC 2 DIR         |                      | ADC 3        | ADC IX1             |           | 9<br>1001 |  |
|           |                                                                                                                                                                                 |                | BPL<br>2 REL      | DEC DIR                        |                   |                    | 2 DEC               |          |                    |           |                         | ORA<br>2 DIR      | ORA                  | ORA 3        | ORA 2 IX1           |           | A<br>1010 |  |
| B<br>1011 | BRCLR5                                                                                                                                                                          | BCLR5<br>2 BSC | BMI<br>2 REL<br>3 | 5                              | 3                 |                    | 6                   | 5        |                    |           | ADD 2 IMM               |                   | ADD<br>3 EXT         | ADD IX2      | ADD<br>2 1×1<br>3   |           | B<br>1011 |  |
| C<br>1100 | BRSET6<br>3 BTB                                                                                                                                                                 | BSET6<br>2 BSC | BMC<br>2 REL<br>3 | INC<br>2 DIR<br>4              |                   | INCX<br>1 INH<br>3 | INC 2 1X1 5         |          |                    | RSP 1 INH | 6                       | JMP 2 DIR         | JMP<br>3 EXT         | JMP<br>3 1X2 | JMP                 |           | C<br>1100 |  |
| D<br>1101 | BRCLR6<br>3 BTB                                                                                                                                                                 | BCLR6<br>2 BSC | BMS<br>2 REL      | TST<br>2 DIR                   | TSTA<br>1 INH     | TSTX<br>1 INH      | 2 IX1               |          | 2                  |           | BSR<br>2 REL<br>2       | JSR<br>2 DIR      | JSR<br><u>3 _EXT</u> | JSR<br>3 IX2 | JSR                 |           | D<br>1101 |  |
| E<br>1110 |                                                                                                                                                                                 | BSET7<br>2 BSC | BIL<br>2 REL<br>3 | 5                              |                   | 3                  | 6                   | 5        |                    |           | LDX 2 IMM               | LDX<br>2 DIR      | LDX<br>3 EXT         | LDX<br>3 IX2 | LDX 2 1X1           |           | E<br>1110 |  |
| F<br>1111 | BRCLR7<br>3 BTB                                                                                                                                                                 | BCLR7<br>2 BSC | BIH               | CLR                            |                   | CLRX               | CLR                 |          |                    |           |                         | STX<br>2 DIR      | STX<br>3 EXT         | 3 STX        | STX                 | 1 STX     | F 1111    |  |

#### Abbreviations for Address Modes

| INH | Inherent |
|-----|----------|
|     |          |

- IMM Immediate DIR Direct
- EXT
- Extended REL Relative
- BSC Bit Set/Clear
- BTB Bit Test and Branch
- IX Indexed (No Offset)
- IX1 Indexed, 1 Byte (8-Bit) Offset
- IX2
- Indexed, 2 Byte (16-Bit) Offset

LEGEND



TABLE 11 - INSTRUCTION SET

|             |          |                |                | A           | ddressing | Modes                  |                     |                      |                      |                         | Cor | ndit     | ion | Co                        | des           |
|-------------|----------|----------------|----------------|-------------|-----------|------------------------|---------------------|----------------------|----------------------|-------------------------|-----|----------|-----|---------------------------|---------------|
| Mnemonic    | Inherent | Immediate      | Direct         | Extended    | Relative  | Indexed<br>(No Offset) | Indexed<br>(8 Bits) | Indexed<br>(16 Bits) | Bit<br>Set/<br>Clear | Bit<br>Test &<br>Branch | н   | I        | N   | z                         | с             |
| ADC         |          | ×              | X              | X           |           | x                      | X                   | Х                    |                      |                         | Λ   |          | Λ   | Λ                         |               |
| ADD         |          | X              | X              | X           |           | x                      | X                   | X                    |                      |                         | Λ   | ٠        |     | ۸                         |               |
| AND         |          | ×              | X              | ×           |           | X                      | X                   | X                    |                      |                         | •   | ٠        |     | ۸                         |               |
| ASL         | <u> </u> |                | X              |             |           | X                      | X                   |                      |                      |                         | •   | ٠        |     | Λ                         | Λ             |
| ASR         | X        |                | X              |             |           | x                      | X                   |                      |                      |                         | •   | •        |     | 1                         | <u>A</u>      |
| BCC         |          |                |                |             | X         |                        |                     |                      |                      |                         | •   | •        | •   | •                         | •             |
| BCLR        |          |                |                |             |           |                        |                     |                      | X                    |                         | •   | •        | •   | •                         | •             |
| BCS         |          |                |                |             | X         |                        |                     |                      |                      |                         | •   | •        |     | •                         | •             |
| BEQ<br>BHCC |          |                |                |             | x         |                        |                     |                      | l                    |                         | •   | •        | •   | •                         | •             |
| BHCS        |          |                |                |             | x         |                        |                     |                      |                      |                         | •   | -        |     | •                         | -             |
| BHI         |          |                |                |             | x         |                        |                     |                      |                      |                         | •   |          | •   | •                         |               |
| BHS         |          |                |                |             | x         |                        |                     |                      |                      |                         | •   |          |     |                           | -             |
| BIH         |          |                |                |             | - Â       |                        |                     |                      |                      |                         | •   | -        |     | •                         |               |
| BIL         |          | ·              |                | <u>+</u>    | x x       |                        |                     |                      |                      |                         |     | •        |     | •                         | 1.            |
| BIT         |          | x              | ×              | x           | <u> </u>  | x                      | x                   | ×                    |                      |                         |     |          | Λ   | Λ                         |               |
| BLO         |          | <u> </u>       | <u>+^</u>      | <u> </u>    | x         | <u> </u>               | <u> </u>            | <u> </u>             | I                    |                         | •   | •        | •   | •                         |               |
| BLO         | ·        |                |                | +           | x         |                        |                     | ·                    |                      |                         | ÷   | -        |     | •                         |               |
| BLS         |          |                |                | <u> </u>    | X         |                        |                     |                      | 1                    |                         | •   |          |     |                           |               |
| BMIC        |          |                |                | <u>+</u>    | x         |                        |                     |                      | 1                    |                         | •   |          | •   | •                         | •             |
| BMS         |          |                |                | ł           | X         |                        |                     |                      |                      |                         | •   |          |     |                           |               |
| BNE         |          |                |                |             | x         |                        |                     |                      |                      |                         |     |          | -   |                           |               |
| BPL         |          |                |                |             | x         |                        |                     |                      |                      |                         | •   |          | •   | •                         |               |
| BRA         |          |                |                |             | x         |                        |                     |                      |                      |                         | •   | •        |     | •                         | •             |
| BRN         |          |                |                |             | x         |                        |                     |                      |                      |                         | •   |          |     | •                         | -             |
| BRCLR       |          |                |                |             | ·^        |                        |                     |                      |                      | x                       |     |          |     | •                         | -             |
|             |          |                |                |             |           |                        |                     |                      |                      | x                       | •   | •        | •   | •                         | Λ             |
| BRSET       |          |                |                |             |           |                        |                     |                      | x                    | ···· ^                  | •   |          |     | •                         | •             |
| BSET        |          |                |                |             | x         |                        |                     |                      | ^                    |                         |     |          |     | •                         | -             |
| BSR         | ~        |                |                |             | <u>^</u>  |                        |                     |                      |                      |                         |     | <u> </u> |     | •                         | 0             |
| CLC         | x        |                |                |             |           |                        |                     |                      |                      |                         | •   | •        | •   | •                         | i             |
| CLI<br>CLR  | x        |                |                |             |           | x                      | x                   |                      |                      |                         | •   | •        | 0   | 1                         |               |
| CMP         | <u>^</u> | x              | x              |             |           | x                      | x                   | x                    |                      |                         |     | •        |     | 1                         |               |
| COM         | x        | <u>^</u>       | <del>Î</del> x | ×           |           | x                      | x                   | <u>^</u>             |                      |                         | •   | •        | Λ   | $\Lambda$                 | <u>Λ</u>      |
| CPX         | ^        | ×              | <del>x</del>   | ×           |           | x                      | - Â                 | X                    |                      |                         | •   | •        | A   |                           | Ι <u>Λ</u>    |
| DEC         | x        | <u>^</u>       | - Â            | ·^          |           | x                      | x                   | ^^                   |                      |                         | •   | •        | A   | Λ                         |               |
| EOR         | <u>^</u> | ×              | <del>x</del>   | ×           |           | x                      | x                   | x                    |                      |                         | •   | •        | A   | A                         |               |
| INC         | x        | ^              | x x            | <u>^</u>    |           | - Â                    | - Â                 | <u>^</u>             |                      |                         | •   |          | Λ   | A                         |               |
| JMP         | <u> </u> |                | x              | ×           |           | x                      | - Â                 | x                    |                      |                         | •   | •        |     |                           |               |
| JSR         |          |                | x x            | x           |           | <del>x</del>           | x                   | x                    |                      |                         | •   | •        | •   | •                         | •             |
| LDA         |          | ×              | <del>x</del>   | x           |           | x                      | - Â                 | <del>x</del>         |                      |                         | •   | •        | Λ   | Λ                         |               |
| LDA         |          | X              | x              | X           |           | x                      | - x                 | - Â                  |                      |                         | •   | •        | Λ   | $\frac{\Lambda}{\Lambda}$ |               |
| LDX         | x        | ·              | <del>x</del>   | <u> </u>    |           | x                      | x                   | <u> </u>             |                      |                         | -   | •        | Λ   | Λ                         | -             |
| LSL         | x        | ·              | x x            |             |           | - Â                    | - Â                 |                      |                      |                         | •   | •        | 0   | Λ                         | $\Lambda$     |
| NEG         | x        |                | x              |             |           | - Â                    | - x                 |                      |                      |                         | i   | 1.       | Ā   | A                         |               |
| NOP         | x        |                | <u>├^</u>      | t           |           | ^^                     | <u> </u>            |                      |                      |                         |     |          | •   | •                         | 1             |
| ORA         | ^        | ×              | x              | x           |           | x                      | x                   | x                    | 1                    |                         | -   |          |     |                           | -             |
| ROL         | ×        | <b>├</b> ──^── | - Â            | <u> </u>    |           | - Â                    | ⊢ <del>^</del>      | <u>^</u>             |                      |                         |     |          |     | A                         | A             |
| ROR         | X        |                | ×              | <b>+</b>    |           | X                      | - Â                 |                      | +                    |                         | •   | •        | Λ   | A<br>A                    | A             |
| RSP         | x        |                | <u> </u>       | <u> </u>    |           | ^                      | <u> </u>            |                      | +                    |                         | •   |          |     |                           | 1             |
| RTI         | x        |                |                | +           |           |                        |                     |                      | l                    |                         | 7   | + 7      | -   | 7                         | +-            |
| RTS         | x        |                |                |             |           |                        |                     |                      |                      |                         | •   | •        | Í   | é                         | 6             |
| SBC         | <u> </u> | x              | x              | x           |           | x                      | x                   | x                    | +                    |                         |     | -        |     |                           |               |
| SEC         | x        | <u>├──^</u> ── | <u> </u>       | <u>+ ^ </u> |           | <u> </u>               | <u> </u>            | ·^                   |                      |                         |     | •        |     |                           | $\frac{1}{1}$ |
| SEL         | x        |                |                | t           |           |                        |                     |                      | 1                    |                         | •   | 11       | -   | •                         | 1.            |
| STA         | <u>^</u> |                | x              | ×           |           | ×                      | x                   | x                    | ł                    |                         | •   | •        | Λ   | Λ                         | 1.            |
| STOP        | x        | <u> </u>       | <u> </u>       | <u> </u>    |           | ·                      | <u> </u>            | <u> </u>             | +                    |                         |     | 0        |     |                           | -             |
|             | <u> </u> |                | +              | +           |           | x                      | x                   | x                    | ł                    |                         |     |          |     |                           | <u> </u>      |
| STX         |          |                | x              | ×           |           |                        |                     |                      |                      |                         | •   | •        |     |                           |               |
| SUB         |          | X              | <u> </u>       | X           |           | X                      | X                   | ×                    | +                    |                         | -   | 1        |     |                           |               |
| SWI<br>TAX  | ×        |                |                | I           |           | l                      |                     |                      | +                    |                         |     |          |     |                           |               |
|             | X        |                |                | +           |           | x                      | x                   |                      | +                    |                         | •   |          |     |                           |               |
| TST         | X        |                | x              |             |           | <u> </u>               | - ^                 |                      | +                    |                         | ÷   |          |     |                           |               |
| TXA         | X        |                |                | l           |           | ļ                      |                     | <b> </b>             | ŧ                    |                         |     |          |     |                           |               |
| WAIT        | X        |                |                | L           |           | I                      |                     | L                    | 1                    | l                       | •   | 10       | •   | L_                        | 1.            |

Condition Code Symbols

H Half Carry (From Bit 3)

I Interrupt Mask N Negative (Sign Bit) Z Zero C Carry/Borrow

- Λ Test and Set if True Cleared Otherwise
- Not Affected
- ? Load CC Register From Stack
- 0 Cleared
- 1 Set