

# **Advance Information**

## 8-BIT EPROM MICROCOMPUTER UNIT

The MC1468705G2 Microcomputer Unit (MCU) is an EPROM member of the MC146805 CMOS Family of Microcomputers. The user programmable EPROM allows program changes and lower volume applications in comparison to the factory mask programmable versions. The EPROM versions also reduce the development costs and turnaround time for prototype evaluation of the mask ROM versions. This 8-bit microcomputer contains on-chip oscillator, CPU, RAM, EPROM, selfprogramming bootstrap ROM, I/O, and TIMER.

In addition to power saving STOP and WAIT modes, 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 low-end to mid-range applications in the consumer, automotive, industrial, and communications markets where very low power consumption constitutes an important factor.

The following are the major features of the MC1468705G2 EPROM MCU.

## HARDWARE FEATURES

- Typical Full Speed Operating Power of 20 mW at 5 V
- Typical WAIT Mode Power of 5 mW
- Typical STOP Mode Power of 5 μW
- Fully Static Operation
- 112 Bytes of On-Chip RAM
- 2106 Bytes of UV Erasable, User Programmable ROM (EPROM)
- 32 Bidirectional I/O Lines
- High Current Drive
- Internal 8-Bit Timer with Software Programmable 7-Bit Prescaler
- External Timer Input
- External and Timer Interrupts
- Master Reset and Power-On Reset
- Single 3 to 5.5 V Supply
- On-Chip Oscillator with RC or Crystal Options Selected by EPROM Mask Option Register
- Plug-In Compatible with the MC146805G2
- Self-Programming Bootstrap Program in ROM Simplifies EPROM Programming

# SOFTWARE FEATURES

- Similar to the MC6800
- Efficient Use of Program Space
- Versatile Interrupt Handling
- True Bit Manipulation
- Addressing Modes with Indexed Addressing for Tables
- Efficient Instruction Set
- Memory Mapped I/O
- Two Power Saving Standby Modes; WAIT and STOP
- Fully Compatible with M146805 CMOS Family Microcomputers

This document contains information on a new product. Specifications and information herein are subject to change without notice.

# MC1468705G2

# CMOS

(HIGH-PERFORMANCE SILICON-GATE)

# 8-BIT EPROM MICROCOMPUTER



| PIN ASSIGNMENT    |    |                 |  |  |
|-------------------|----|-----------------|--|--|
| RESET C           |    | 40 <b>D</b> VDD |  |  |
|                   | .2 | 39 🗖 OSC1       |  |  |
| V <sub>PP</sub> C | 3  | 38 🗖 OSC2       |  |  |
| PA7 🕻             | 4  | 37 🗗 TIMER      |  |  |
| PA6 🕻             | 5  | 36 🗖 PD7        |  |  |
| PA5 🕻             | 6  | 35 <b>D</b> PD6 |  |  |
| PA4 🕻             | 7  | 34 🗗 PD5        |  |  |
| PA3 🕻             | 8  | 33 Þ PD4        |  |  |
| PA2               | 9  | 32 🏳 PD3        |  |  |
| PA1 C             | 10 | 31 🏳 PD2        |  |  |
| PA0 🖸             | 11 | 30 <b>D</b> PD1 |  |  |
| рво 🕻             | 12 | 29 <b>P</b> PD0 |  |  |
| PB1 🕻             | 13 | 28 <b>P</b> PC0 |  |  |
| РВ2 🕻             | 14 | 27 <b>р</b> РС1 |  |  |
| РВЗ 🕻             | 15 | 26 🗖 P.C2       |  |  |
| РВ4 🕻             | 16 | 25 <b>P</b> PC3 |  |  |
| РВ5 🕻             | 17 | 24 <b>D</b> PC4 |  |  |
| РВ6 🕻             | 18 | 23 <b>D</b> PC5 |  |  |
| РВ7 🕻             | 19 | 22 <b>P</b> PC6 |  |  |
| ∨ss <b>C</b>      | 20 | 21 <b>P</b> PC7 |  |  |
| •                 |    |                 |  |  |



FIGURE 1 - BLOCK DIAGRAM

# MAXIMUM RATINGS (Voltages Referenced to VSS)

| Ratings                                                                                                       | Symbol           | Value                                        | Unit     |
|---------------------------------------------------------------------------------------------------------------|------------------|----------------------------------------------|----------|
| Supply Voltage                                                                                                | VDD              | -0.3 to +5.5                                 | V        |
| Input Voltage                                                                                                 | Vin              | V <sub>SS</sub> -0.3 to V <sub>DD</sub> +0.3 | V        |
| EPROM Programming Voltage (VPP Pin)                                                                           | Vin              | -0.3 to -13.5                                | V        |
| Current Drain Per Pin<br>Excluding V <sub>DD</sub> , V <sub>SS</sub> , and V <sub>PP</sub><br>V <sub>PP</sub> | 1                | 10<br>30                                     | mA<br>mA |
| Operating Temperature Range                                                                                   | T_A              | 0 to 70                                      | °C       |
| Storage Temperature Range                                                                                     | T <sub>stg</sub> | - 55 to + 150                                | °C       |
| Current Drain Total (PD4-PD7 Only)                                                                            | ЮН               | 40                                           | mA       |

# THERMAL CHARACTERISTICS

| Characteristics    | Symbol | Value | Unit |
|--------------------|--------|-------|------|
| Thermal Resistance |        |       |      |
| Ceramic            | θ」Α    | 50    | °C/W |

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 Vin and Vout be constrained to the range V<sub>SS</sub>≤(V<sub>in</sub> or V<sub>out</sub>)≤V<sub>DD</sub>. Reliability of operation is enhanced if unused inputs except OSC2 and Vpp are connected to an appropriate logic voltage level (e.g., either VSS or VDD). Be sure that the EPROM window is shielded from light with an opaque cover at all times except when erasing.

| BOOTSTRAP PROGRAMMING OPERATION ELECTRICAL | . CHARACTERISTICS ( $V_{DD} = 5.25 \text{ Vdc}$ , $V_{SS} = 0 \text{ Vdc}$ , $T_A = 25^{\circ}C$ |
|--------------------------------------------|--------------------------------------------------------------------------------------------------|
|                                            | uploss otherwise noted)                                                                          |

|                                           | unless otherwise noted) |     |        |     |      |
|-------------------------------------------|-------------------------|-----|--------|-----|------|
| Characteristics                           | Symbol                  | Min | Тур    | Max | Unit |
| Programming Voltage (Vpp Pin) (Figure 20) | Vpp                     | -   | - 13.5 | -   | V    |
| Vpp Supply Current                        |                         |     |        |     |      |
| V <sub>PP</sub> = - 13.5 V                | IPP                     | -   | 30     | -   | mA   |
| Programming Oscillator Frequency          | foscp                   | -   | -      | 1.0 | MHz  |
| Bootstrap Programming Mode Voltage        |                         |     |        |     |      |
| (IRQ Pin) I <sub>in</sub> =100 µA Max     | VIRQP                   | -   | - 12.0 | -   | V    |
| TIMER Pin Programming Mode Voltage        | VTIMP                   | VDD |        | VDD | V    |

# DC ELECTRICAL CHARACTERISTICS ( $V_{DD}$ = 5.0 Vdc ± 10%, $V_{SS}$ = 0 Vdc, $V_{PP}$ = 0 Vdc, $T_{A}$ = 0°C to 70°C unless otherwise noted)

| Characteristic                                                                    | Symbol | Min                  | Max  | Unit |
|-----------------------------------------------------------------------------------|--------|----------------------|------|------|
| Output Voltage, ILoad ≤ 10.0 µA                                                   | VOL    | -                    | 0.1  | V    |
|                                                                                   | ∨он    | V <sub>DD</sub> -0.1 | -    |      |
| Output High Voltage                                                               |        |                      |      |      |
| $(I_{Load} = -100 \ \mu A) PB0-PB7, PC0-PC7$                                      |        |                      |      |      |
| $(I_{Load} = -2 \text{ mA}) \text{ PA0-PA7}, \text{ PD0-PD3}$                     | Vон    | 2.4                  | -    | V    |
| (I <sub>Load</sub> = -8 mA) PD4-PD7                                               |        |                      |      |      |
| Output Low Voltage                                                                |        |                      |      |      |
| (I <sub>Load</sub> =800 µA) PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7                    | VOL    |                      | 0.4  | V    |
| Input High Voltage                                                                |        |                      |      |      |
| PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7                                                |        | V <sub>DD</sub> -2.0 | VDD  |      |
| RESET, IRQ, TIMER, OSC1                                                           | VIH    | V <sub>DD</sub> -0.8 | VDD  | V    |
| Input Low Voltage All Inputs (except Vpp)                                         | VIL    | VSS                  | 0.8  | V    |
| Input Low Voltage Vpp (normal oper. mode)                                         | VIL    | VSS                  | VSS  | V    |
| Total Supply Current ( $C_L = 50$ pF on Ports, no dc Loads, $t_{CVC} = 1 \mu s$ ) |        |                      |      |      |
| RUN ( $V_{IL} = 0.2 \text{ V}, V_{IH} = V_{DD} - 0.2 \text{ V}$ )                 |        | -                    | 10   | mA   |
| WAIT (See Note 1)                                                                 | DD     | -                    | 5    | mA   |
| STOP (See Note 1)                                                                 |        | -                    | 250  | μΑ   |
| I/O Ports Input Leakage PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7                        | ηL     | -                    | ± 10 | μA   |
| Input Current RESET, IRQ, TIMER, OSC1                                             | lin    | -                    | ± 1  | μA   |
| Capacitance                                                                       |        |                      |      |      |
| Ports                                                                             | Cout   |                      | 12   | рF   |
| RESET, IRQ, TIMER, OSC1                                                           | Cin    |                      | 8    | рF   |

NOTES:

1. Test conditions for IDD are as follows:

All ports programmed as inputs

V<sub>IL</sub> = 0.2 V (PA0-PA7, PB0-PB7, PC0-PC7, PD0-PD7)

 $V_{IH}^{}=V_{DD}^{}-0.2$  V for RESET, IRQ, and 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 OSC2 capacitance)

2. Vpp is pin 3 on the MC1468705G2 and is connected to VSS in the normal operating mode.

#### TABLE 1 - CONTROL TIMING

(V\_DD=5.0 Vdc  $\pm$  10%, V\_SS=0 Vdc; T\_A=0 to 70°C)

| Characteristic                                                 | Symbol                            | Min  | Max | Unit             |
|----------------------------------------------------------------|-----------------------------------|------|-----|------------------|
| Crystal Oscillator Startup Time (See Figure 5)                 | toxov                             | -    | 100 | ms               |
| Stop Recovery Startup Time (Crystal Oscillator) (See Figure 6) | <b>t</b> ILCH                     |      | 100 | ms               |
| Timer Pulse Width (See Figure 4)                               | t <sub>TH</sub> , t <sub>TL</sub> | 500  | -   | t <sub>cyc</sub> |
| RESET Pulse Width (See Figure 5)                               | tRL                               | 1.5  | -   | t <sub>cyc</sub> |
| Timer Period (See Figure 4)                                    | <b>t</b> tltl                     | 1000 |     | ns               |
| Interrupt Pulse Width Low (See Figure 14)                      | ίLIΗ                              | 1.0  |     | t <sub>cyc</sub> |
| Interrupt Pulse Period (See Figure 14)                         | <b>TILIL</b>                      | *    | -   | t <sub>cyc</sub> |
| OSC1 Pulse Width (with External Clock)                         | tOH, tOL                          | 125  | -   | ns               |
| Cycle Time                                                     | t <sub>cyc</sub>                  | 1000 |     | ns               |
| Frequency of Operation                                         |                                   |      |     |                  |
| Crystal ( $\div$ 4 option)                                     | fosc                              | -    | 4.0 | MHz              |
| External Clock ( ÷ 4 option)                                   |                                   | dc   | 4.0 | MHz              |
| Crystal ( ÷ 2 option)                                          | fosc                              |      | 2.0 | MHz              |
| External Clock ( + 2 option)                                   |                                   | dc   | 2.0 | MHz              |

\*The minimum period tilli should not be less than the number of t<sub>cyc</sub> cycles it takes to execute the interrupt service routines plus 20 t<sub>cyc</sub> cycles.

## FIGURE 2 - EQUIVALENT TEST LOAD

| Port       | R <sub>1</sub> | R <sub>2</sub> |
|------------|----------------|----------------|
| B and C    | 24.3 kΩ        | 4.32 kΩ        |
| A, PD0-PD3 | 1.21 kΩ        | 3.1 kΩ         |
| PD4-PD7    | 300 <b>Ω</b>   | 1.64 kΩ        |











\*Internal timing signal and bus information not available externally. \*\*OSC1 line is not meant to represent frequency. It is only used to represent time.

3-1037

ω



### FIGURE 6 - STOP RECOVERY AND POWER-ON RESET

\*\* Represents the internal gating of the OSC1 input pin.

# FUNCTIONAL PIN DESCRIPTION

#### VDD and VSS

Power is supplied to the MCU using these two pins. VDD is power and VSS is ground.

# **IRQ** (MASKABLE INTERRUPT REQUEST)

IRQ is a programmable option which provides two different choices of interrupt triggering sensitivity. These options are: (1) negative edge-sensitive triggering only, or (2) both negative-edge sensitive and level-sensitive triggering. In the latter case, either type of input to the IRQ pin will produce the interrupt. The MCU completes the current instruction before it responds to the interrupt request. When the IRQ pin goes low for at least one t<sub>CVC</sub>, a logic one is latched internally to signify an interrupt has been requested. When the MCU completes its current instruction, the interrupt latch is tested. If the interrupt latch contains a logic one, and the interrupt mask bit (I bit) in the condition code register is clear, the MCU then begins the interrupt sequence.

If the option is selected to include level-sensitive triggering, then the IRQ input requires an external resistor to VDD for "wire-OR" operation. See INTERRUPTS for more detail. This pin also detects a negative voltage that is used to initiate the bootstrap mode program.

## RESET

The RESET input is not required for startup but can be used to reset the MCU internal state and provide an orderly software startup procedure. Refer to RESETS for a detailed description.

#### TIMER

The TIMER input may be used as an external clock for the on-chip timer. This pin is connected to VDD for the bootstrap mode (EPROM programming). Refer to TIMER for additional information about the timer circuitry.

## Vpp

The Vpp pin is used when programming the EPROM. By applying the negative programming voltage to this pin, one of the requirements is met for programming the EPROM. Refer to PROGRAMMING FIRMWARE and the PROGRAM-MING OPERATION ELECTRICAL CHARACTERISTICS table.

#### NOTE

In normal operation, this pin is connected directly to VSS.

## OSC1. OSC2

The MC1468705G2 can be configured to accept either a crystal input or an RC network to control the internal oscillator. Additionally, the internal clocks can be derived by either a divide-by-two or divide-by-four of the internal oscillator frequency (fosc). Both of these options are programmable via the mask option register (MOR) in the EPROM array. The programmable options provided via the MOR in the MC1468705G2 are mask options in the MC146805G2.

RC - If the RC oscillator option is selected, then a resistor is connected to the oscillator pins as shown in Figure 7(d). The relationship between R and fosc is shown in Figure 8.

CRYSTAL - The circuit shown in Figure 7(b) 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 fosc in Table 1 Control Timing. Using an external CMOS oscillator is recommended when crystals outside the specified ranges are to be used. The crystal and components should be mounted as close as possible to the input pins to minimize output distortion and startup stabilization time. Refer to Table 1 for VDD specifications.

|                      | 1 MHz | 4 MHz | Units |
|----------------------|-------|-------|-------|
| R <sub>S</sub> (Max) | 400   | 75    | Ω     |
| C <sub>0</sub> (Max) | 5     | 7     | pF    |
| C <sub>1</sub>       | 0.008 | 0.012 | μF    |
| COSC1                | 15-40 | 15-30 | рF    |
| C <sub>OSC2</sub>    | 15-30 | 15-25 | pF    |
| R <sub>P</sub> (Min) | 10    | 10    | MΩ    |
| 0                    | 30    | 40    | ĸ     |

# FIGURE 7- OSCILLATOR CONNECTIONS







(b) Crystal Oscillator Connections



(d) RC Oscillator Connection









**EXTERNAL CLOCK** — An external clock should be applied to the OSC1 input with the OSC2 input not connected, as shown in Figure 7(e). An external clock should be used with the crystal oscillator option and its pulse width should be the tOH, tOL specification. The tOXOV or tILCH specifications do not apply when using an external clock input.

#### PA0-PA7

These eight I/O lines comprise Port A. The state of any pin is software programmable. Refer to **PROGRAMMING** for a detailed description of I/O programming.

# P80-P87

These eight lines comprise Port B. The state of any pin is software programmable. Refer to **PROGRAMMING** for a detailed description of I/O programming.

#### PC0-PC7

These eight lines comprise Port C. The state of any pin is software programmable. Refer to **PROGRAMMING** for a detailed description of I/O programming.

# PD0-PD7

These eight lines comprise Port D. PD4-PD7 also are capable of driving LEDs directly. The state of any pin is software programmable. Refer to **PROGRAMMING** for a detailed description of I/O programming.

# PROGRAMMING

#### 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 one. A pin is configured as an input if its corresponding DDR bit is cleared to a logic zero. 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.

#### FIGURE 9 - TYPICAL PORT I/O CIRCUITRY



(b)

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

| R/₩* | DDR | I/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.          |

\*R/W is an internal signal.

#### EPROM PROGRAMMING

When programming the EPROM array within the MC146870502, ports are used in a special arrangement. See **PROGRAMMING FIRMWARE** and Figure 20 for a detailed description.

## MEMORY

As shown in Figure 10, the MCU is capable of addressing 8192 bytes of memory and I/O registers with its program counter. The MC1468705G2 MCU has implemented 2469 bytes of these locations. This consists of: 2106 bytes of user EPROM, 240 bytes of bootstrap ROM, 112 bytes of user RAM, an EPROM mask option register (MOR), eight bytes of I/O, and two timer registers. The user EPROM is located in two areas. The main EPROM area is in memory locations \$0080 to \$08AF. The second area is reserved for ten interrupt/reset vector bytes at memory locations \$1FF6 through \$1FFF. The MCU uses 10 of the lowest 16 memory locations for program control and I/O features such as data ports, the port DDRs, and the timer. The mask option register at memory location \$1FF5 completes the total. The 112 bytes of user RAM include up to 64 bytes for the stack. Except for the MOR, the memory mapping is similar to the MC146805G2; however, the MC1468705G2 has no self-check ROM because of the bootstrap ROM requirement.

The stack area is used during the processing of interrupt and subroutine calls to save the processor state. The contents of the CPU registers are pushed onto the stack in the order shown in Figure 12. Since the stack pointer decrements during pushes, the low order byte (PCL) of the program counter is stacked first; then the higher order five bits (PCH) are stacked. This ensures that the program counter is loaded correctly as the stack pointer increments when it pulls data from the stack. A subroutine call causes only the program counter (PCL, PCH) contents to be pushed onto the stack; the remaining CPU registers are not pushed.



#### FIGURE 10 - ADDRESS MAP

\* Reads of unused locations undefined.

# REGISTERS

The MC1468705G2 contains five registers, as shown in the programming model of Figure 11. The interrupt stacking order is shown in Figure 12.

#### ACCUMULATOR (A)

The accumulator is an 8-bit general purpose register used to hold operands, results of the 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 value 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 configured 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 machine state during interrupts. During external or power-on reset, and during a reset stack pointer (RSP) instruction, the stack pointer is set to its upper limit (\$007F]. Nested interrupt and/or subroutines may use up to 64 (decimal) locations, beyond which the stack pointer wraps around and points to

# FIGURE 11 - PROGRAMMING MODEL



FIGURE 12 - STACKING ORDER



NOTE: Since the Stack Pointer decrements during pushes, the PCL is stacked first, followed by PCH, etc. Pulling from the stack is in the reverse order.

its upper limit; thereby, losing the previously stored information. A subroutine call occupies two RAM bytes on the stack, while an interrupt uses five RAM 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 specified 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 and during an ADD or ADC instruction. The H bit is useful in binary coded decimal subroutines.

**INTERRUPT MASK BIT (I)** — When the I 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 I bit is set, the interrupt is latched and is processed after the I bit is next cleared.

**NEGATIVE (N)** — When set, this bit indicates that the result of the last arithmetic, logical, or data manipulation is negative (bit 7 in the result is a logic one).

 $\mbox{ZERO}~(\mbox{Z})$  — When set, this bit indicates that the result of the last arithmetic, logical, or data manipulation is zero.

CARRY/BORROW (C) -- Indicates that a carry or borrow out of the arithmetic logic unit (ALU) occurred during the last arithmetic operation. This bit is also affected during bit test and branch instructions, shifts, and rotates.

# RESETS

The MC1468705G2 has two reset modes: an active low external reset pin ( $\overline{\text{RESET}})$  and a power-on reset function; refer to Figure 5.

# RESET

The  $\overline{\text{RESET}}$  input pin is used to reset the MCU to provide an orderly software startup procedure. When using the external reset mode, the  $\overline{\text{RESET}}$  pin must stay low for a minimum of one  $t_{CVC}$ . The  $\overline{\text{RESET}}$  pin contains an internal Schmitt Trigger as part of its input to improve its noise immunity.

### **POWER-ON RESET**

The power-on reset occurs when a positive transition is detected on VDD. 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 that the oscillator becomes active. If the external RESET pin is low at the end of the 1920 t<sub>CVC</sub> the processor remains in the reset condition until RESET goes high.

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

 Timer control register interrupt request bit TCR7 is cleared to a logic zero to preclude premature timer interrupts.

- Timer control register interrupt mask bit TCR6 is set to a logic one to preclude timer interrupt processing.
- All data direction register bits are cleared to logic zeros to define all ports as input.
- Stack pointer is preset to its upper limit, \$007F.
- The internal address bus is forced to the reset vector (\$1FFE, \$1FFF).
- Condition code register interrupt mask bit (I) is set to a logic one to mask any external interrupts.
- STOP and WAIT latches are cleared to place MCU in normal operation.
- External interrupt latch is cleared to ensure no external interrupt is processed.
- MCU operation is set up per mask option register (MOR). External reset does not affect the MOR.

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

# BOOTSTRAP ROM

The bootstrap ROM contains a factory program which allows the MCU to present an address and fetch data from an external device and transfer it into the MC1468705G2 EPROM. The bootstrap program provides: timing of programming pulses, timing of Vpp input, and verification after programming. See **PROGRAMMING FIRMWARE**.

### MASK OPTION REGISTER (MOR)

The mask option register is an 8-bit user programmed (EPROM) register in which three of the bits are used. Bits in this register are used to select the type of system clock (crystal/RC oscillator), the divide-by-four/divide-by-two clock option (bus frequency), and the edge-sensitive or edge- and level-sensitive triggered interrupt recognition. The MOR is not available on the MC146805G2 ROM-based part.

#### INTERRUPTS

Systems often require that normal processing be interrupted so that some external event may be serviced. The MC1468705G2 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).

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

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

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

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. Refer to Figure 13 for the interrupt and instruction processing sequence.

Table 3 shows the execution priority of the RESET, IRQ, and timer interrupts, and the software interrupt, SWI. Two conditions are shown, one with the I bit set and the other with the I bit clear; however, in either case RESET has the highest priority of execution. If the I bit is set as per Table 3(a), the second highest priority is assigned to SWI. This is illustrated in Figure 13 which shows that the IRQ or Timer interrupts are not executed when the I bit is set and the next instruction (including SWI) is fetched. If the I bit is clear as

per Table 3(b), the priorities change in that the next instruction (including SWI) is not fetched until after the  $\overline{IRQ}$  and Timer interrupts have been recognized (and serviced). Also, when the I bit is clear, if both  $\overline{IRQ}$  and Timer interrupts are pending, the  $\overline{IRQ}$  interrupt is always serviced before the Timer interrupt.

# NOTE

The conditions for Table 3 assume that, except for RESET, the current instruction is completed, thus the MCU is at an instruction boundary.

FIGURE 13 - RESET AND INTERRUPT PROCESSING FLOWCHART



#### TABLE 3 — INTERRUPT INSTRUCTION EXECUTION PRIORITY AND VECTOR ADDRESS

(a) I Bit Set

| Interrupt/Instruction | Priority | Vector Address |
|-----------------------|----------|----------------|
| RESET                 | 1        | \$1FFE-\$1FFF  |
| SWI                   | 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 Clear

| Interrupt/Instruction | Priority | Vector Address |
|-----------------------|----------|----------------|
| RESET                 | 1        | \$1FFE-\$1FFF  |
| ĪRQ                   | 2        | \$1FFA-\$1FFB  |
| Timer                 | 3        | \$1FF8-\$1FF9  |
|                       |          | \$1FF6-\$1FF7* |
| SWI                   | 4        | \$1FFC-\$1FFD  |

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

#### TIMER INTERRUPT

If the timer interrupt mask bit (TCR6) is cleared, then each time the timer decrements to zero (transitions from \$01 to \$00 to set TCR7) an interrupt request is generated. The actual processor interrupt is generated only if the interrupt mask bit (in the condition code register) is 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.

The actual timer interrupt request can be delayed by controlling TCR6 (interrupt mask bit). If TCR6 is programmed to a logic one, no interrupt is generated even if TCR7 (interrupt request bit) is set. Then, TCR6 can be programmed (after a specific time) to a logic zero to generate the actual timerinterrupt request.

## EXTERNAL INTERRUPT

If the interrupt mask bit of the condition code register has been cleared and the external interrupt pin (IRQ) has gone low, then the external interrupt is recognized. The action of the external interrupt is identical to the timer interrupt with the exception that the interrupt request input at IRQ is latched internally and the service routine address is specified by the contents of \$1FFA and \$1FFB. Either a level-sensitive and edge-sensitive trigger, or an edge-sensitive only trigger are available as a mask option register (MOR) controlled programmable option. Figure 14 shows both a functional and mode timing diagram for the interrupt line. The timing diagram shows two different treatments of the interrupt line (IRQ) to the processor. The first method shows 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 pluse occurs, the next pulse should not occur until the MPU software has exited the routine (an RTI occurs). This time ( $t_{ILIL}$ ) is obtained by adding 20 instruction cycles ( $t_{CVC}$ ) to the total number of cycles it takes to complete the service routine including the RTI instruction; refer to Figure 14. The second configuration shows many interrupt lines "wire-ORed" to form the interrupts at the processor. Thus, if after servicing one interrupt the interrupt line remains low, then the next interrupt is recognized.

#### NOTE

The internal interrupt latch is cleared in the first part of the service routine; therefore, one (and only one) external interrupt pulse could be latched during  $t_{ILIL}$  and serviced as soon as the I bit is cleared.

# SOFTWARE INTERRUPT

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

# LOW-POWER MODES

#### STOP

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

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. The I bit in the condition code register is cleared to enable external interrupts. All other registers and memory remain unaltered. All input/output lines remain unchanged.

#### WAIT

The WAIT instruction places the MC1468705G2 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 disabled from all internal circuitry except for the timer; refer to Figure 16. 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 input/output lines remain in their previous 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 request is not cleared in the external interrupt interrupt is the routine, the normal timer interrupt (not the timer wait interrupt) is serviced since the MCU is no longer in the WAIT mode.

# FIGURE 14 - EXTERNAL INTERRUPT

## (a) Interrupt Functional Diagram



FIGURE 15 - STOP FUNCTION FLOWCHART

FIGURE 16 - WAIT FUNCTION FLOWCHART





# MODES OF OPERATION

The MC1468705G2 has two modes of operation. These modes are the normal (single-chip) mode and the bootstrap mode (firmware used to program the EPROM). These two modes are entered as described below.

## SINGLE-CHIP MODE

The normal operational mode of the part is the single-chip mode. The single-chip mode will be entered if the following conditions are satisfied: (1) the RESET line is brought low, (2) the IRQ pin is within its normal operational range (VSS-VDD), and (3) the VPP pin is connected to VSS. The next rising edge of the RESET pin then causes the part to enter the single-chip mode.

# BOOTSTRAP MODE

The bootstrap mode is entered if certain conditions are met on the TIMER, IRO, and RESET pins. A negative voltage (VIBOP) must be present on the IRQ pin. This value is latched internally on the rising edge of the external RESET pin. Also VDD should be applied to the TIMER pin. The high state of the TIMER pin is then latched internally on the rising edge of the RESET pin. Refer to Figure 17.

#### TIMER

The MCU timer contains an 8-bit software programmable counter (timer data register) with a 7-bit software selectable prescaler. Figure 18 contains a block diagram of the timer. The counter may be loaded 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, TCR) 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 begin servicing; refer to INTERRUPTS.





FIGURE 18 - TIMER BLOCK DIAGRAM



NOTES:

1. Prescaler and timer data register (8-bit counter) are clocked on the falling edge of the internal clock or external input. 2. The timer data register counts down continuously

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 become stable prior to the read portion of a cycle, and do not change during the read. The timer interrupt request bit (TCR7) remains set until cleared by the software. If the timer interrupt request bit (TCR7) is cleared before the timer interrupt is serviced, the interrupt is lost. TCR7 may also be used as a scanned status bit in a non-interrupt 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 zeros by the write operation into TCR when bit 3 of the written data equals a logic one. 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 and TCR5 timer control register bits. Refer to TIMER CONTROL REGISTER.

Figure 18 shows a block diagram of the timer subsystem. Power-on reset and the STOP instruction affect the state of the counter.

# TIMER INPUT MODE 1

If TCR4 and TCR5 are both programmed to a zero, 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.

#### TIMER INPUT MODE 2

With TCR4=1 and TCR5=0, the internal clock and the TIMER input pin are ANDed to form the timer input signal. This mode can be used to measure external pulse widths. The external timer input pulse simply turns on the internal clock through for the duration of the pulse. The resolution of the count in this mode is plus or minus one clock cycle; 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.

# TIMER CONTROL REGISTER (TCR) ~

.

| /    | 6    | 5    | 4    | 3    | 2    |      | 0    |        |
|------|------|------|------|------|------|------|------|--------|
| TCR7 | TCR6 | TCR5 | TCR4 | TCR3 | TCR2 | TCR1 | TCRO | \$0009 |

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

- 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 one it inhibits the timer interrupt to the processor.

- 1-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 (period = t<sub>CVC</sub>).

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 |                                     |
|---|------|------|-------------------------------------|
| 1 | 0    | 0    | Internal clock to timer             |
|   | 0    | 1    | AND of internal clock and TIMER pin |
|   |      |      | to timer                            |
|   | 1    | 0    | Inputs to timer disabled            |
|   | 1    | 1    | TIMER pin to timer                  |

TCR3 - Timer prescaler reset bit: writing a one to this bit resets the prescaler to zero. A read of this location always indicates a zero. (Unaffected by reset.)

TCR2, TCR1, TCR0 - Prescaler select bits: decoded to select one of eight outputs of the prescaler. (Unaffected by reset.)

|      | Pre  | scaler |        |
|------|------|--------|--------|
| TCR2 | TCR1 | TCRO   | 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  |

# OSCILLATOR AND INTERRUPT OPTIONS

The MC1468705G2 oscillator and interrupt options are implemented as an EPROM byte at address \$1FF5 and are EPROM programmable. Selection of these programmable options is discussed below.

# MASK OPTION REGISTER (MOR)



A discussion of the function of each bit is as follows.

B7,CLK – Determines the Clock Oscillator

- 0-Crystal Oscillator.
- 1-RC Oscillator.

**B6, DIV** – Determines Division of Clock Oscillator 0 – Divide-by-4 Oscillator Clock.

- 1-Divide-by-2 Oscillator Clock.
- **B4,INT** Determines type of Interrupt Trigger Input 0– Edge-Sensitive Triggered only.
  - 1-Edge-Sensitive or Level-Sensitive Triggered.

## NOTE

Bits 0, 1, 2, 3, and 5 in the MOR must be programmed to zero.

The EPROM in the erased state will read all zeros. While in the bootstrap mode, the MC1468705G2 will operate under crystal oscillator and divide-by-4 options regardless of how the MOR is actually programmed; however, the interrupt trigger input will remain as programmed in the MOR. When the MC1468705G2 is in the single-chip mode and completes a power-on reset, the MCU operation is set up per the mask option register (MOR). The state of the Vpp pin does not affect the MOR controlled options.

# ERASING THE EPROM

The MC1468705G2 EPROM can be erased by exposure to high-intensity ultraviolet (UV) light with a wavelength of 2537 angstroms. The recommended integrated dose (UV intensity a veposure time) is  $15 \text{ Ws/cm}^2$ . The lamps should be used without shortwave filters and the MC1468705G2 should be positioned about one inch from the UV tubes. Ultraviolet erasure clears all bits of the MC1468705G2 EPROM to the zero state. Data is then entered by programming ones into the desired bit locations.

#### CAUTION

Be sure that the EPROM window is shielded from light with an opaque cover at all times except when erasing. This protects both the EPROM and light-sensitive nodes.

## **PROGRAMMING FIRMWARE**

A bootstrap program in ROM allows the MC1468705G2 to program its own internal EPROM. The alternate vectoring used to implement the self-check in the MC1468705G2 is used to start execution of this program.

When the Vpp voltage is placed on pin 3 (provided pin 2 has  $V_{IRQP}$  applied and pin 37 has +5 V applied), the bootstrap program is executed and the MC1468705G2 pro-

grams itself. This ability to program itself is a function of the external hardware and the interaction between the internal hardware and the firmware. The amount of time for programming is determined by a value stored in the timer data register by the internal firmware. When the part is placed in the program and verify mode, the bootstrap vector will be fetched and the bootstrap firmware will start to execute.

Note that an MCM68764 (or MCM68766) UV EPROM must be programmed first with the exact duplicate of the information that is to be transferred to the MC1468705G2. Non-EPROM addresses are ignored by the on-chip ROM bootstrap. Since the MC1468705G2 and the MCM68764 (or MCM68766) EPROM are to be inserted and removed from the circuit, they should be mounted in sockets. Additionally, the precautions below should be observed (refer to Figures 19 and 20).

### NOTE

The advanced programming information provided below applies to MC1468705G2 EPROM MCUs which were manufactured using a mask set other than the MJ3 series. For programming information regarding the MJ3 series of mask sets, consult Motorola Engineering Bulletin EB-110.

Figure 19 illustrates the memory location of the MCM68764 EPROM which corresponds to the equivalent memory in the MC1468705G2. Note that the MCM68764 memory locations which correspond to RAM locations or unused EPROM or ROM locations, in the MC1468705G2, may be programmed as either \$00 or \$FF (don't care).

#### CAUTION

Be sure that S1 is open and S2 is closed when inserting the MC1468705G2 and MCM68764 EPROMs into their respective sockets. This ensures that power is not applied and RESET is held low while inserting the devices.

To program the MC1468705G2, open S3 (to select the programming and verify mode) and then close S1 (to apply the proper voltages for the VDD, TIMER, and IRQ pins). Next, open S2 (to remove reset and supply Vpp). When the reset cycle is complete, the internal ROM program initiates transfer of the external EPROM pattern one byte for each EPROM location. The MC1468705G2 bootstrap provides the address (A0-A12) and enable (TSC/E) signals to permit complete self-programming. At the start of the data transfer from the MCM68764 EPROM, the programming LED (DS2) is turned on and remains on throughout the programming sequence. After completion of the programming sequence, the programming LED turns off. Transfer of the entire MCM68764 EPROM content requires approximately 200 seconds. The internal timer data register is then cleared and the loop is repeated to verify that the programmed data is precisely the same as the incoming data from the MCM68764 EPROM; if so, the verified LED is turned on. If the verified LED does not turn on, the exact program has not been loaded from the MCM68764 to the MC1468705G2, indicating a possible defect. Close S2 and open S1 prior to removing any device from its socket.

#### CAUTION

Once the MC1468705G2 is programmed and connected for normal operation, be sure that Vpp (pin 3) is connected directly to  $V_{SS}$ .



# FIGURE 19 - MC1468705G2 MEMORY MAPPING ONTO MCM68764

FIGURE 20 - PROGRAMMING CONNECTIONS



MC1468705G2

0 = Switch closed 1 = Switch open

# 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. The first operand is either the accumulator or the index register. The second 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 4.

## **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-modifywrite sequence since it does not modify the value. Refer to Table 5.

#### **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 -127 and +128 to the current program counter. Refer to Table 6.

## **BIT MANIPULATION INSTRUCTIONS**

The MCU is capable of setting or clearing any bit which resides in the first 128 bytes of the memory space (where all port registers, port DDRs, timer, timer control, and on-chip RAM reside). Bit manipulation in the EPROM mapped area will not affect data in the EPROM. An additional feature allows the software to test and branch on the state of any bit within the first 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 automatically placed in the carry bit of the condition code register. Refer to Table 7.

#### CONTROL INSTRUCTIONS

These instructions are register reference instructions and are used to control processor operation during program execution. Refer to Table 8.

#### OPCODE MAP

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

# ALPHABETICAL LISTING

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

# ADDRESSING MODES

The MCU uses ten different addressing modes to provide the programmer with 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 scaling tables anywhere in the memory space. Short indexed accesses are single byte instructions, while the longest instructions (three bytes) permit accessing tables throughout memory. Short absolute (direct) and long absolute (extended) addressing are also included. One and two byte direct addressing instructions access all data bytes in most applications. Extended addressing permits jump instructions to reach all memory. Table 10 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 9.

The term "effective address" (EA) is used in describing the various addressing modes, and 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" the location or register referred to; e.g., (PC) indicates the contents of the location pointed to by the PC. An arrow indicates "is replaced by", and a colon indicates Computer/Microprocessor User's Manual.

# 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 \leftarrow PC + 2$ 

Address 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. When using the Motorola assembler, the user need not specify whether an instruction uses direct or extended addressing. The assembler automatically selects the most efficient addressing mode.

$$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. This mode is used to move a pointer through a table or to address a frequently referenced RAM or I/O location.

#### $EA = X; PC \leftarrow PC + 1$

Address Bus High  $\leftarrow 0$ ; Address Bus Low  $\leftarrow X$ 

| TABLE 4 — REGISTER/MEMORY I | INSTRUCTIONS |
|-----------------------------|--------------|
|-----------------------------|--------------|

|                                             |            |            | Addressing Modes |             |            |            |             |            |            |             |                     |            |                           |            |            |             |                     |            |             |
|---------------------------------------------|------------|------------|------------------|-------------|------------|------------|-------------|------------|------------|-------------|---------------------|------------|---------------------------|------------|------------|-------------|---------------------|------------|-------------|
|                                             |            | h          | mmediat          | e           | Direct     |            | Extended    |            |            | (           | Indexed<br>No Offse | t)         | Indexed<br>(8-Bit Offset) |            |            | (16         | Indexed<br>Bit Offs | iet)       |             |
| 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                           | <b>ŠTA</b> | -          | -                | -           | 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           | C9         | 3          | 4           | F9                  | 1          | 3                         | E9         | 2          | 4           | D9                  | 3          | 5           |
| Subtract Memory                             | SUB        | A0         | 2                | 2           | B0         | 2          | 3           | CO         | 3          | 4           | FO                  | 1          | 3                         | EO         | 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           | 88         | 2          | 3           | C8         | 3          | 4           | F8                  | 1          | 3                         | E8         | 2          | 4           | D8                  | 3          | 5           |
| Arithmetic Compare A 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) | віт        | <b>A</b> 5 | 2                | 2           | B5         | 2          | 3           | C5         | 3          | 4           | F5                  | 1          | 3                         | E5         | 2          | 4           | D5                  | 3          | 5           |
| Jump Unconditional                          | JMP        | -          |                  | -           | вс         | 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 5 - READ-MODIFY-WRITE INSTRUCTIONS

|                              |          |              |            |             |            |            |             | ,          | Addressi   | ng Mode:    | S                      |            |             |                           |            |             |
|------------------------------|----------|--------------|------------|-------------|------------|------------|-------------|------------|------------|-------------|------------------------|------------|-------------|---------------------------|------------|-------------|
| _                            |          | Inherent (A) |            |             | Ir         | herent (   | <b>X</b> )  |            | 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           |

|                                        | Relative | ative Addressing Mode |            |             |  |  |  |  |
|----------------------------------------|----------|-----------------------|------------|-------------|--|--|--|--|
| Function                               | Mnemonic | Op<br>Code            | #<br>Bytes | #<br>Cycles |  |  |  |  |
| Branch Aiways                          | 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      | BIH      | 2F                    | 2          | 3           |  |  |  |  |
| Branch to Subroutine                   | BSR      | AD                    | 2          | 6           |  |  |  |  |

# TABLE 6 - BRANCH INSTRUCTIONS

TABLE 7 - BIT MANIPULATION INSTRUCTIONS

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

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

|                  | Bit Ma          | nipulation     | Branch          |                | Re           | ad/Modify/    | Write              |       | Co           | ntroi          |                     |                | Registe        | er/Memory      |                |           |             |
|------------------|-----------------|----------------|-----------------|----------------|--------------|---------------|--------------------|-------|--------------|----------------|---------------------|----------------|----------------|----------------|----------------|-----------|-------------|
|                  | BTB             | BSC            | REL             | DIR            | INH          | INH           | IX1                | IX    | INH          | INH            | IMM                 | DIR            | EXT            | IX2            | IX1            | IX        |             |
| Hi               | 0000            | 0001           | 2<br>0010       | 3<br>0011      | 4<br>0100 _  | 5<br>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      | F<br>1111 | Hi Low      |
| 0000             | BRSET0<br>3 BTB | BSET0<br>2 BSC | BRA 3<br>2 REL  | NEG DIR        | NEG<br>1 INH | NEG<br>1 INH  | NEG 1X1            | NEG 1 | 8TI<br>1 INH |                | SUB<br>2 IMM        | SUB<br>2 DIR   | SUB<br>3 EXT   | SUB 3 1X2      | SUB 4          |           | 0000        |
| 1<br>0001        | BRCLR0<br>3 BTB |                | BRN<br>2 REL    |                |              |               |                    |       | RTS          |                | CMP 2<br>2 IMM      | 2 CMP 2 DIR    | CMP<br>3 EXT   | CMP 3 1X2      | CMP 2 1X1      |           | 1<br>0001   |
| 2<br>0010        | BRSET1<br>3 BTB | BSET1<br>2 BSC | BHI<br>2 REL    |                |              |               |                    |       |              |                | SBC 2<br>2 IMM      | SBC 3<br>2 DIR | SBC<br>3 EXT   | 3 SBC 3        | 2 SBC 1X1      | SBC 1     | 2<br>0010   |
| 3<br>3011        | BRCLR1<br>3 BTB | BCLR1<br>2 BSC | BLS<br>2 REL    | COM 2 DIR      |              |               | COM 6              | COM   | SWI          |                | 2<br>2 CPX<br>2 IMM | CPX 2 DIR      | CPX<br>3 EXT   | CPX 3 1X2      | CPX 4<br>2 1X1 |           | 3<br>0011   |
| <b>4</b><br>0100 | BRSET2<br>3 BTB | BSET2<br>2 BSC | BCC BCC BCC BCC | LSR 5<br>2 DTR |              |               | LSR                |       |              |                | AND 2<br>2 IMM      | AND 2 DIH      | AND<br>3 EXT   | AND 3          | AND 2 1X1      |           | 4<br>0100   |
| 5<br>0101        | BRCLR2<br>3 BTB |                | BCS 3           |                |              |               |                    |       |              |                | BIT 2<br>2 IMM      | BIT<br>2 DIR   | BIT<br>3 EXT   | BIT 5<br>3 IX2 | BIT 4<br>2 IX1 | BIT 3     | 5<br>0101   |
| 6<br>0110        | BRSET3<br>3 BTB | BSET3<br>2 BSC | BNE<br>2 REL    | ROR 5<br>2 DIR | RORA 3       |               | ROR 6              |       |              |                | LDA<br>2 IMM        | LDA<br>2 DIR   | LDA<br>3 EXT   | LDA 5          | LDA 2 1X1      | LDA 3     | 6<br>0110   |
| 7<br>0111        | BRCLR3<br>3 BTB | BCLR3<br>2 BSC | BEQ<br>2 REL    | ASR 2 DIR      |              |               | ASR 2 1X1          |       |              | TAX 2          |                     | STA 2 DIR      | STA<br>3 EXT   | STA 6          | STA STA        | STA 1     | 7<br>0111   |
| 8<br>1000        | BRSET4<br>3 BTB | BSET4<br>2 BSC | BHCC 3          | LSL 5<br>2 DIR | LSLA 3       | LSLX<br>1 INH | 6<br>LSL<br>2 الX1 |       |              | CLC 2<br>1 INH | EOR 2<br>2 IMM      | EOR 2 DIR      | EOR<br>3 EXT   | EOR 3 1X2      | EOR 2 1X1      |           | 8<br>1000   |
| 9<br>1001        | BRCLR4<br>3 BTB | BCLR4<br>2 BSC | BHCS<br>2 REL   | ROL<br>2 DIR   | ROLA 3       | ROLX 3        | 80L<br>2 1X1       |       |              | SEC SEC        | ADC 2<br>2 IMM      | ADC 2 DIR      | ADC<br>3 EXT   | ADC 3          | ADC 2 1X1      |           | 9<br>1001   |
| A<br>1010        | BRSET5<br>3 BTB | BSET5<br>2 BSC | BPL 3<br>2 REL  | DEC<br>2 DIR   |              | DECX 3        | DEC 2 1X1          | DEC 1 |              | CLI<br>1 INH   | 0RA<br>2 IMM        | 0RA<br>2 DIR   | ORA<br>3 EXT   | ORA 3 1X2      | ORA 2 1X1      |           | A<br>1010   |
| B<br>1011        | BRCLR5          | BCLR5          | BMI<br>2 REL    |                |              |               |                    |       |              | SEI            | ADD 2<br>2 IMM      | ADD<br>2 DIR   | ADD<br>3 EXT   | ADD 3 1X2      | ADD 2 1X1      |           | B<br>1011   |
| C<br>1100        | BRSET6<br>3 BTB | BSET6<br>2 BSC | BMC 2 REL       | INC DIR        | INCA 3       |               | INC 2 1X1          |       |              | RSP 2<br>1 INH |                     | JMP<br>2       | 3 JMP<br>3 EXT | JMP<br>3. 1X2  | JMP<br>2 IX1   | JMP 2     | C<br>1100   |
| D<br>1101        |                 | BCLR6<br>2 BSC | BMS 3           | TST 4<br>2 DIR | TSTA 3       | TSTX 3        | TST 5<br>2 IX1     | TST 4 |              | NOP 2<br>1 INH | BSR<br>2 REL        | JSR<br>2 DIR   | JSR<br>3 EXT   | JSR<br>3 1X2   | JSR<br>2 IX1   | JSR 5     | D '<br>1101 |
| E<br>1110        | BRSET7<br>3 BTB | BSET7          | BIL<br>2 REL    |                |              |               |                    |       | STOP         |                | LDX 2<br>2 IMM      | LDX<br>2 DIR   | LDX<br>3 EXT   | LDX 5          | LDX 4          |           | E<br>1110   |
| F<br>1111        |                 | BCLR7          | BIH<br>2 REL    | CLR DIR        |              |               |                    |       | WAIT         |                |                     | STX            | STX 5          | STX 6          | STX 5          | STX x     | F 1111      |

## TABLE 9 -- MC1468705G2 CMOS INSTRUCTION SET OPCODE MAP

#### Abbreviations for Address Modes

| <br>     |
|----------|
| Inherent |
| unnerent |

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

LEGEND



| Mnemonic         Inherent         Immediate         Direct         Extended         Relative         Indexed<br>(No Offset)         Indexed<br>(8 Bits)         Bit<br>Set/<br>(16 Bits)         Bit<br>Set/<br>Clear<br>Set/<br>Set/         Bit<br>Set/<br>Set/<br>Set/ |    | <u> </u> | T          | -   |                   |          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----------|------------|-----|-------------------|----------|
|                                                                                                                                                                                                                                                                           | н  | ۱        | N          | z   | : 0               | 2        |
| ADC X X X X X X X                                                                                                                                                                                                                                                         | Λ  | ٠        | Λ          | ۸   | . [7              |          |
| ADD X X X X X X                                                                                                                                                                                                                                                           | Λ  | ٠        | Λ          | Λ   | T                 |          |
| AND X X X X X X                                                                                                                                                                                                                                                           | ٠  | ٠        | Λ          | 1   |                   | <u> </u> |
| ASL X X X                                                                                                                                                                                                                                                                 | •  | •        | 1 A        | 1   | 14                | <u>+</u> |
| ASR X X X X                                                                                                                                                                                                                                                               | •  | •        | 1 A        |     |                   | 1        |
| BCC X                                                                                                                                                                                                                                                                     | •  | •        | •          | •   |                   |          |
| BCLH X                                                                                                                                                                                                                                                                    | •  |          | 1.         | -   |                   | _        |
|                                                                                                                                                                                                                                                                           |    | -        |            |     | +                 | -        |
|                                                                                                                                                                                                                                                                           | -  | -        |            |     | $\pm$             |          |
|                                                                                                                                                                                                                                                                           |    | -        |            |     |                   | -        |
|                                                                                                                                                                                                                                                                           |    |          | 1.         | 1.  |                   | -        |
|                                                                                                                                                                                                                                                                           |    |          | i          |     |                   | 5        |
|                                                                                                                                                                                                                                                                           |    |          |            |     |                   | 5        |
|                                                                                                                                                                                                                                                                           | •  | •        |            |     |                   | 5        |
|                                                                                                                                                                                                                                                                           | •  | ٠        | Ā          | Ā   |                   | 5        |
| BLO X                                                                                                                                                                                                                                                                     | ٠  | •        |            | •   |                   | ,        |
| BLŚ                                                                                                                                                                                                                                                                       | •  | ٠        |            |     |                   | 5        |
| BMC                                                                                                                                                                                                                                                                       | •  | ٠        | •          | •   |                   |          |
| BMI X                                                                                                                                                                                                                                                                     | ٠  | ٠        | •          | •   | •                 |          |
| BMS X                                                                                                                                                                                                                                                                     | •  | •        | ٠          | •   | •                 |          |
| BNE                                                                                                                                                                                                                                                                       | •  | ٠        | •          | •   |                   |          |
| BPL X                                                                                                                                                                                                                                                                     | •  | •        | •          | •   |                   |          |
| BRA X                                                                                                                                                                                                                                                                     | ٠  | ٠        | ۰          | •   | •                 |          |
| BRN X                                                                                                                                                                                                                                                                     | •  | •        | •          | •   | •                 | •        |
| BRCLR X                                                                                                                                                                                                                                                                   | •  |          | •          | •   | 1                 | 4        |
| BRSET                                                                                                                                                                                                                                                                     | •  | •        | •          | •   | 1                 | 1        |
| BSET X                                                                                                                                                                                                                                                                    | •  | •        |            |     |                   |          |
| BSH X                                                                                                                                                                                                                                                                     | •  | •        |            |     |                   | -        |
|                                                                                                                                                                                                                                                                           |    | -        | -          |     | +-                | 4        |
|                                                                                                                                                                                                                                                                           |    |          | -          |     | +                 | -        |
|                                                                                                                                                                                                                                                                           |    | -        | t.         | +   | $\pm$             | -        |
|                                                                                                                                                                                                                                                                           |    |          | 1 1        |     | +                 | ÷Н       |
|                                                                                                                                                                                                                                                                           | •  |          | 1 1        |     | $\pm i$           | ÷        |
|                                                                                                                                                                                                                                                                           |    | ÷        | T A        | 1   | ti                | ; - I    |
|                                                                                                                                                                                                                                                                           | •  | ۰        | Ā          | Λ   |                   | 5        |
|                                                                                                                                                                                                                                                                           | •  |          | Ā          | Ā   |                   | 5        |
| AME A A A A A A A A A A A A A A A A A A                                                                                                                                                                                                                                   | •  | •        | •          |     |                   | 5        |
| JSR X X X X X                                                                                                                                                                                                                                                             | •  | ٠        |            |     |                   | 5        |
|                                                                                                                                                                                                                                                                           | •  | ٠        | ٨          | Λ   |                   | 5        |
|                                                                                                                                                                                                                                                                           | ۲  | ٠        | Λ          | Λ   |                   |          |
|                                                                                                                                                                                                                                                                           | ٠  | •        | ۸          | Λ   |                   | 1        |
| LSR X X X                                                                                                                                                                                                                                                                 | •  | ۰        | 0          | A   | Ā                 | <u> </u> |
| NEG X X X X                                                                                                                                                                                                                                                               | •  | ۰        | Λ          | Λ   | X                 | <u>ا</u> |
|                                                                                                                                                                                                                                                                           | •  | •        | l.         | L.  | 1                 | 1        |
|                                                                                                                                                                                                                                                                           | •  | •        | 1 A        | 1 A | 1.                | 1        |
|                                                                                                                                                                                                                                                                           | -  |          | <u>†</u> ↑ | † V | 14                | 4        |
|                                                                                                                                                                                                                                                                           | -  | -        |            |     | +4                | -        |
|                                                                                                                                                                                                                                                                           | -, | 5        | ĻĻ         | Ļ   | +                 | 4        |
|                                                                                                                                                                                                                                                                           |    | -        | †÷         | ╞   | tá                | -        |
|                                                                                                                                                                                                                                                                           | -  | -        |            | +   | +                 | -        |
| SEC X A A A A A A A A A A A A A A A A A A                                                                                                                                                                                                                                 |    |          | †÷         | 1÷  | $\pm \frac{4}{1}$ | H        |
| SEL X                                                                                                                                                                                                                                                                     | -  | 1        | 1.         | 1.  |                   | -        |
| STA X X X X X X X                                                                                                                                                                                                                                                         | -  |          | 1          | 1   | +                 | 5        |
| STOP X 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1 2 1                                                                                                                                                                                                                              | -  | ō        | †÷         | 18  |                   | 1        |
| STX X X X X X X                                                                                                                                                                                                                                                           | •  | •        | Å          | tĂ  |                   | 5        |
| SUB X X X X X X X X X                                                                                                                                                                                                                                                     | •  | •        | 1 A        | t Ā | tā                | 1        |
| SWI X                                                                                                                                                                                                                                                                     | •  | 1        | Ť          | 1.  | Ť                 | 51       |
| TAX X X X                                                                                                                                                                                                                                                                 | •  | ۲        | •          | •   | 1                 | 5        |
|                                                                                                                                                                                                                                                                           | •  | ۰        | ٨          | ٨   |                   | 5        |
| TXA X AXT                                                                                                                                                                                                                                                                 | ٠  | ۰        | •          | •   |                   | 1        |
| WAIT X                                                                                                                                                                                                                                                                    | ٠  | 0        | •          | •   | 1                 | 1        |

# TABLE 10 - INSTRUCTION SET

Condition Code Symbols H Half Carry (From Bit 3) Interrupt Mask Negative (Sign Bit) T

Λ Test and Set if True, Cleared Otherwise •
?

Not Affected Load CC Register From Stack

Ν Z C Zero

Carry/Borrow

- 0 Cleared
- 1 Set

#### 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; therefore, the operand is located anywhere within the lowest 511 memory locations. For example, this mode of addressing is useful for selecting the mth 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 \leftarrow PC + 2$ Address Bus High  $\leftarrow K;$  Address Bus Low  $\leftarrow X + (PC + 1)$ 

Where:

K = The carry 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). As with direct and extended, the M6805 assembler determines the most efficient form of indexed offset; 8-or 16-bit. The contents of the index register are not changed.

> EA = X + [(PC + 1):(PC + 2))]; PC - PC + 3Address Bus High  $\leftarrow$  (PC + 1) + K; Address Bus Low  $\leftarrow$  X + (PC + 2)

#### Where:

K = The carry from the additon of X + (PC + 2)

#### 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) are 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. The Motorola assembler calculates the proper offset and checks to see if it is within the span of the branch.

 $EA = PC + 2 + (PC + 1); PC \leftarrow EA$  if branch taken; otherwise,  $EA = PC \leftarrow PC + 2$ 

## 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 the first three bits of the opcode. The bit set and clear instructions occupy two bytes, one for the opcode (including the bit number) and the other to address the byte which contains the bit of interest.

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

#### BIT TEST AND BRANCH

Bit test and branch is a combination of direct addressing, bit set/clear addressing, and relative addressing. The actual bit to be tested, within the byte, is specified within the low order nibble of the opcode. The address of the data byte to be tested is located via a direct address in the location 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 cleared 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.

 $\begin{array}{l} \mathsf{EA1} = (\mathsf{PC}+1) \\ \mathsf{Address} \; \mathsf{Bus} \; \mathsf{High} \longleftarrow (\mathsf{PC}+1) \\ \mathsf{EA2} = \mathsf{PC}+3 + (\mathsf{PC}+2); \; \mathsf{PC} \leftarrow \mathsf{EA2} \; \mathsf{if} \; \mathsf{branch} \; \mathsf{taken}; \\ & \mathsf{otherwise}, \; \mathsf{PC}-\mathsf{PC}+3 \end{array}$