

CPU12
Reference Manual

Motorola reserves the right to make changes without further notice to any products herein to improve reliability, function or design. Motorola does not assume any liability arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights nor the rights of others. Motorola products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Motorola was negligent regarding the design or manufacture of the part.

## TABLE OF CONTENTS

Paragraph Page
SECTION 1
INTRODUCTION
1.1 CPU12 Features ..... 1-1
1.2 Readership ..... 1-1
1.3 Symbols and Notation ..... 1-2
SECTION 2OVERVIEW
2.1 Programming Model ..... 2-1
2.2 Data Types ..... 2-5
2.3 Memory Organization ..... 2-5
2.4 Instruction Queue ..... 2-5
SECTION 3
ADDRESSING MODES
3.1 Mode Summary ..... 3-1
3.2 Effective Address ..... 3-2
3.3 Inherent Addressing Mode ..... 3-2
3.4 Immediate Addressing Mode ..... 3-2
3.5 Direct Addressing Mode ..... 3-3
3.6 Extended Addressing Mode ..... 3-3
3.7 Relative Addressing Mode ..... 3-4
3.8 Indexed Addressing Modes. ..... 3-5
3.9 Instructions Using Multiple Modes ..... 3-10
3.10 Addressing More than 64 Kbytes ..... 3-12
SECTION 4
INSTRUCTION QUEUE
4.1 Queue Description ..... 4-1
4.2 Data Movement in the Queue ..... 4-2
4.3 Changes in Execution Flow. ..... 4-2
SECTION 5
INSTRUCTION SET OVERVIEW
5.1 Instruction Set Description ..... 5-1
5.2 Load and Store Instructions ..... 5-1
5.3 Transfer and Exchange Instructions ..... 5-2
5.4 Move Instructions ..... 5-3
5.5 Addition and Subtraction Instructions ..... 5-3
5.6 Binary Coded Decimal Instructions ..... 5-4
5.7 Decrement and Increment Instructions ..... 5-4
5.8 Compare and Test Instructions ..... 5-5
5.9 Boolean Logic Instructions ..... 5-6
5.10 Clear, Complement, and Negate Instructions ..... 5-6

## TABLE OF CONTENTS

Paragraph Page
5.11 Multiplication and Division Instructions ..... 5-7
5.12 Bit Test and Manipulation Instructions ..... 5-7
5.13 Shift and Rotate Instructions ..... 5-8
5.14 Fuzzy Logic Instructions ..... 5-9
5.15 Maximum and Minimum Instructions ..... 5-11
5.16 Multiply and Accumulate Instruction. ..... 5-11
5.17 Table Interpolation Instructions ..... 5-12
5.18 Branch Instructions ..... 5-13
5.19 Loop Primitive Instructions ..... 5-16
5.20 Jump and Subroutine Instructions ..... 5-17
5.21 Interrupt Instructions ..... 5-18
5.22 Index Manipulation Instructions ..... 5-19
5.23 Stacking Instructions ..... 5-20
5.24 Pointer and Index Calculation Instructions ..... 5-20
5.25 Condition Code Instructions ..... 5-21
5.26 STOP and WAIT Instructions ..... 5-21
5.27 Background Mode and Null Operations ..... 5-22
SECTION 6
INSTRUCTION GLOSSARY
6.1 Glossary Information ..... 6-1
6.2 Condition Code Changes ..... 6-2
6.3 Object Code Notation ..... 6-2
6.4 Source Forms ..... 6-3
6.5 Cycle-by-Cycle Execution ..... 6-5
6.6 Glossary ..... 6-8
SECTION 7
EXCEPTION PROCESSING
7.1 Types of Exceptions ..... 7-1
7.2 Exception Priority ..... 7-2
7.3 Resets ..... 7-2
7.4 Interrupts ..... 7-3
7.5 Unimplemented Opcode Trap ..... 7-5
7.6 Software Interrupt Instruction ..... 7-6
7.7 Exception Processing Flow ..... 7-6
SECTION 8
DEVELOPMENT AND DEBUG SUPPORT
8.1 External Reconstruction of the Queue ..... 8-1
8.2 Instruction Queue Status Signals ..... 8-1
8.3 Implementing Queue Reconstruction ..... 8-3
8.4 Background Debug Mode ..... 8-6
8.5 Instruction Tagging ..... 8-13

## TABLE OF CONTENTS

Paragraph Page
8.6 Breakpoints ..... 8-14
SECTION 9
FUZZY LOGIC SUPPORT
9.1 Introduction ..... 9-1
9.2 Fuzzy Logic Basics ..... 9-1
9.3 Example Inference Kernel ..... 9-7
9.4 MEM Instruction Details ..... 9-9
9.5 REV, REVW Instruction Details ..... 9-13
9.6 WAV Instruction Details ..... 9-22
9.7 Custom Fuzzy Logic Programming ..... 9-26
SECTION 10
MEMORY EXPANSION
10.1 Expansion System Description ..... 10-1
10.2 CALL and Return from Call Instructions ..... 10-3
10.3 Address Lines for Expansion Memory ..... 10-4
10.4 Overlay Window Controls ..... 10-4
10.5 Using Chip-Select Circuits ..... 10-5
10.6 System Notes ..... 10-7
APPENDIX A
INSTRUCTION REFERENCE
A. 1 Instruction Set Summary ..... A-1
A. 2 Opcode Map ..... A-1
A. 3 Indexed Addressing Postbyte Encoding ..... A-1
A. 4 Transfer and Exchange Postbyte Encoding ..... A-1
A. 5 Loop Primitive Postbyte Encoding ..... A-1
APPENDIX B
M68HC11 TO M68HC12 UPGRADE PATH
B. 1 CPU12 Design Goals ..... B-1
B. 2 Source Code Compatibility ..... B-1
B. 3 Programmer's Model and Stacking ..... B-3
B. 4 True 16-Bit Architecture ..... B-3
B. 5 Improved Indexing ..... B-6
B. 6 Improved Performance ..... B-9
B. 7 Additional Functions ..... B-11
APPENDIX C
HIGH-LEVEL LANGUAGE SUPPORT
C. 1 Data Types ..... C-1
C. 2 Parameters and Variables ..... C-1
C. 3 Increment and Decrement Operators ..... C-3

## TABLE OF CONTENTS

Paragraph Page
C. 4 Higher Math Functions ..... C-3
C. 5 Conditional If Constructs ..... C-4
C. 6 Case and Switch Statements ..... C-4
C. 7 Pointers ..... C-4
C. 8 Function Calls ..... C-4
C. 9 Instruction Set Orthogonality ..... C-5
APPENDIX D
ASSEMBLY LISTING
INDEX
SUMMARY OF CHANGES

## LIST OF ILLUSTRATIONS

Figure Page
2-1 Programming Model ..... 2-1
6-1 Example Glossary Page ..... 6-1
7-2 Exception Processing Flow Diagram ..... 7-7
8-1 Queue Status Signal Timing ..... 8-2
8-2 BDM Host to Target Serial Bit Timing ..... 8-8
8-3 BDM Target to Host Serial Bit Timing (Logic 1) ..... 8-8
8-4 BDM Target to Host Serial Bit Timing (Logic 0) ..... 8-9
8-5 Tag Input Timing ..... 8-13
9-1 Block Diagram of a Fuzzy Logic System ..... 9-3
9-2 Fuzzification Using Membership Functions ..... 9-4
9-3 Fuzzy Inference Engine ..... 9-8
9-4 Defining a Normal Membership Function ..... 9-10
9-5 MEM Instruction Flow Diagram ..... 9-11
9-6 Abnormal Membership Function Case 1 ..... 9-12
9-7 Abnormal Membership Function Case 2 ..... 9-13
9-8 Abnormal Membership Function Case 3 ..... 9-13
9-9 REV Instruction Flow Diagram ..... 9-16
9-10 REVW Instruction Flow Diagram ..... 9-21
9-11 WAV and wavr Instruction Flow Diagram ..... 9-25
9-12 Endpoint Table Handling ..... 9-28

## LIST OF TABLES

Table Page
3-1 M68HC12 Addressing Mode Summary ..... 3-1
3-2 Summary of Indexed Operations ..... 3-6
3-3 PC Offsets for Move Instructions ..... 3-11
5-1 Load and Store Instructions ..... 5-2
5-2 Transfer and Exchange Instructions ..... 5-3
5-3 Move Instructions ..... 5-3
5-4 Addition and Subtraction Instructions ..... 5-4
5-5 BCD Instructions ..... 5-4
5-6 Decrement and Increment Instructions ..... 5-5
5-7 Compare and Test Instructions ..... 5-5
5-8 Boolean Logic Instructions ..... 5-6
5-9 Clear, Complement, and Negate Instructions ..... 5-6
5-10 Multiplication and Division Instructions ..... 5-7
5-11 Bit Test and Manipulation Instructions ..... 5-7
5-12 Shift and Rotate Instructions ..... 5-8
5-13 Fuzzy Logic Instructions ..... 5-10
5-14 Minimum and Maximum Instructions ..... 5-11
5-15 Multiply and Accumulate Instructions ..... 5-12
5-16 Table Interpolation Instructions ..... 5-12
5-17 Short Branch Instructions ..... 5-14
5-18 Long Branch Instructions ..... 5-15
5-19 Bit Condition Branch Instructions ..... 5-16
5-20 Loop Primitive Instructions ..... 5-16
5-21 Jump and Subroutine Instructions ..... 5-17
5-22 Interrupt Instructions ..... 5-18
5-23 Index Manipulation Instructions ..... 5-19
5-24 Stacking Instructions ..... 5-20
5-25 Pointer and Index Calculation Instructions ..... 5-21
5-26 Condition Codes Instructions ..... 5-21
5-27 STOP and WAIT Instructions ..... 5-22
5-28 Background Mode and Null Operation Instructions ..... 5-22
7-1 CPU12 Exception Vector Map ..... 7-1
7-2 Stacking Order on Entry to Interrupts ..... 7-5
8-1 IPIPE[1:0] Decoding ..... 8-2
8-2 BDM Commands Implemented in Hardware ..... 8-10
8-3 BDM Firmware Commands ..... 8-11
8-4 BDM Register Mapping ..... 8-11
8-5 Tag Pin Function ..... 8-13
10-1 Mapping Precedence ..... 10-2
A-1 Instruction Set Summary ..... A-2
A-2 CPU12 Opcode Map ..... A-20
A-3 Indexed Addressing Mode Summary ..... A-22
A-4 Indexed Addressing Mode Postbyte Encoding (xb) ..... A-23

## LIST OF TABLES

A-5 Transfer and Exchange Postbyte Encoding ..... A-24
A-6 Loop Primitive Postbyte Encoding (lb) ..... A-25
B-1 Translated M68HC11 Mnemonics ..... B-2
B-2 Instructions with Smaller Object Code ..... B-3
B-3 Comparison of Math Instruction Speeds ..... B-10
B-4 New M68HC12 Instructions ..... B-11

## SECTION 1 INTRODUCTION

This manual describes the features and operation of the CPU12 processing unit used in all M68HC12 microcontrollers.

### 1.1 CPU12 Features

The CPU12 is a high-speed, 16-bit processing unit that has a programming model identical to that of the industry standard M68HC11 CPU. The CPU12 instruction set is a proper superset of the M68HC11 instruction set, and M68HC11 source code is accepted by CPU12 assemblers with no changes.

The CPU12 has full 16-bit data paths and can perform arithmetic operations up to 20 bits wide for high-speed math execution.

Unlike many other 16-bit CPUs, the CPU12 allows instructions with odd byte counts, including many single-byte instructions. This allows much more efficient use of ROM space.

An instruction queue buffers program information so the CPU has immediate access to at least three bytes of machine code at the start of every instruction.

In addition to the addressing modes found in other Motorola MCUs, the CPU12 offers an extensive set of indexed addressing capabilities including:

- Using the stack pointer as an index register in all indexed operations
- Using the program counter as an index register in all but auto inc/dec mode
- Accumulator offsets allowed using A, B, or D accumulators
- Automatic pre- or post-increment or pre- or post-decrement (by -8 to +8)
- 5-bit, 9-bit, or 16-bit signed constant offsets
- 16-bit offset indexed-indirect and accumulator D offset indexed-indirect addressing


### 1.2 Readership

This manual is written for professionals and students in electronic design and software development. The primary goal is to provide information necessary to implement control systems using M68HC12 devices. Basic knowledge of electronics, microprocessors, and assembly language programming is required to use the manual effectively. Because the CPU12 has a great deal of commonality with the M68HC11 CPU, prior knowledge of M68HC11 devices is helpful, but is not essential. The CPU12 also includes features that are new and unique. In these cases, there is supplementary material in the text to explain the new technology.

### 1.3 Symbols and Notation

The following symbols and notation are used throughout the manual. More specialized usages that apply only to the instruction glossary are described at the beginning of that section.

### 1.3.1 Abbreviations for System Resources

A - Accumulator A
B - Accumulator B
D - Double accumulator D (A : B)
$X$ - Index register $X$
Y - Index register Y
SP — Stack pointer
PC - Program counter
CCR - Condition code register
S - STOP instruction control bit
X- Non-maskable interrupt control bit
H - Half-carry status bit
I - Maskable interrupt control bit
N - Negative status bit
Z - Zero status bit
V - Two's complement overflow status bit
C - Carry/Borrow status bit

### 1.3.2 Memory and Addressing

M - 8-bit memory location pointed to by the effective address of the instruction
$M: M+1-16$-bit memory location. Consists of the location pointed to by the effective address concatenated with the next higher memory location. The most significant byte is at location M .
$M \sim M+3-32$-bit memory location. Consists of the effective address of the $\mathrm{M}_{(\mathrm{Y})} \sim \mathrm{M}_{(\mathrm{Y}+3)} \quad$ instruction concatenated with the next three higher memory locations. The most significant byte is at location M or $\mathrm{M}_{(\mathrm{Y})}$.
$M_{(X)}$ - Memory locations pointed to by index register $X$
$M_{(S P)}$ - Memory locations pointed to by the stack pointer
$M_{(Y+3)}$ _ Memory locations pointed to by index register $Y$ plus 3, respectively.
PPAGE - Program overlay page (bank) number for extended memory (>64K).
Page - Program overlay page
$\mathrm{X}_{\mathrm{H}}$ - High-order byte
$X_{L}$ - Low-order byte
( ) - Content of register or memory location
\$ - Hexadecimal value
\% - Binary value

### 1.3.3 Operators

+     - Addition
-     - Subtraction
-     - Logical AND
+     - Logical OR (inclusive)
$\oplus$ - Logical exclusive OR
$\times$ — Multiplication
$\div$ - Division
$\bar{M}$ — Negation. One's complement (invert each bit of $M$ )
: - Concatenate
Example: A : B means: "The 16-bit value formed by concatenating 8-bit accumulator A with 8-bit accumulator B."
$A$ is in the high order position.
$\Rightarrow$ - Transfer
Example: $(A) \Rightarrow M$ means: "The content of accumulator $A$ is transferred to memory location M."
$\Leftrightarrow$ - Exchange
Example: $D \Leftrightarrow X$ means: "Exchange the contents of $D$ with those of X ."


### 1.3.4 Conventions

Logic level one is the voltage that corresponds to the True (1) state.
Logic level zero is the voltage that corresponds to the False (0) state.
Set refers specifically to establishing logic level one on a bit or bits.
Cleared refers specifically to establishing logic level zero on a bit or bits.
Asserted means that a signal is in active logic state. An active low signal changes from logic level one to logic level zero when asserted, and an active high signal changes from logic level zero to logic level one.
Negated means that an asserted signal changes logic state. An active low signal changes from logic level zero to logic level one when negated, and an active high signal changes from logic level one to logic level zero.
ADDR is the mnemonic for address bus.
DATA is the mnemonic for data bus.
LSB means least significant bit or bits; MSB, most significant bit or bits.
LSW means least significant word or words; MSW, most significant word or words.
A specific mnemonic within a range is referred to by mnemonic and number. A7 is bit 7 of accumulator A. A range of mnemonics is referred to by mnemonic and the numbers that define the range. DATA[15:8] form the high byte of the data bus.

## SECTION 2 OVERVIEW

This section describes the CPU12 programming model, register set, the data types used, and basic memory organization.

### 2.1 Programming Model

The CPU12 programming model, shown in Figure 2-1, is the same as that of the M68HC11 CPU. The CPU has two 8-bit general-purpose accumulators ( $A$ and $B$ ) that can be concatenated into a single 16-bit accumulator (D) for certain instructions. It also has two index registers ( X and Y ), a 16-bit stack pointer (SP), a 16-bit program counter (PC), and an 8-bit condition code register (CCR).


HC12 PROG MODEL
Figure 2-1 Programming Model

### 2.1.1 Accumulators

General-purpose 8-bit accumulators A and B are used to hold operands and results of operations. Some instructions treat the combination of these two 8 -bit accumulators (A : B) as a 16-bit double accumulator (D).

Most operations can use accumulator A or B interchangeably. However, there are a few exceptions. Add, subtract, and compare instructions involving both $A$ and $B$ (ABA, SBA, and CBA) only operate in one direction, so it is important to make certain the correct operand is in the correct accumulator. The decimal adjust accumulator A (DAA) instruction is used after binary-coded decimal (BCD) arithmetic operations. There is no equivalent instruction to adjust accumulator B.

### 2.1.2 Index Registers

16-bit index registers $X$ and $Y$ are used for indexed addressing. In the indexed addressing modes, the contents of an index register are added to 5 -bit, 9 -bit, or 16-bit constants or to the content of an accumulator to form the effective address of the instruction operand. The second index register is especially useful for moves and in cases where operands from two separate tables are used in a calculation.

### 2.1.3 Stack Pointer

The CPU12 supports an automatic program stack. The stack is used to save system context during subroutine calls and interrupts, and can also be used for temporary data storage. The stack can be located anywhere in the standard 64-Kbyte address space and can grow to any size up to the total amount of memory available in the system.

The stack pointer holds the 16-bit address of the last stack location used. Normally, the SP is initialized by one of the first instructions in an application program. The stack grows downward from the address pointed to by the SP. Each time a byte is pushed onto the stack, the stack pointer is automatically decremented, and each time a byte is pulled from the stack, the stack pointer is automatically incremented.

When a subroutine is called, the address of the instruction following the calling instruction is automatically calculated and pushed onto the stack. Normally, a return from subroutine (RTS) or a return from call (RTC) instruction is executed at the end of a subroutine. The return instruction loads the program counter with the previously stacked return address and execution continues at that address.

When an interrupt occurs, the current instruction finishes execution (REV, REVW, and WAV instructions can be interrupted, and resume execution once the interrupt has been serviced), the address of the next instruction is calculated and pushed onto the stack, all the CPU registers are pushed onto the stack, the program counter is loaded with the address pointed to by the interrupt vector, and execution continues at that address. The stacked registers are referred to as an interrupt stack frame. The CPU12 stack frame is the same as that of the M68HC11.

### 2.1.4 Program Counter

The program counter (PC) is a 16-bit register that holds the address of the next instruction to be executed. It is automatically incremented each time an instruction is fetched.

### 2.1.5 Condition Code Register

This register contains five status indicators, two interrupt masking bits, and a STOP instruction control bit. It is named for the five status indicators.

The status bits reflect the results of CPU operation as it executes instructions. The five flags are half carry (H), negative (N), zero (Z), overflow (V), and carry/borrow (C). The half-carry flag is used only for BCD arithmetic operations. The N, Z, V, and C status bits allow for branching based on the results of a previous operation.

In some architectures, only a few instructions affect condition codes, so that multiple instructions must be executed in order to load and test a variable. Since most CPU12 instructions automatically update condition codes, it is rarely necessary to execute an extra instruction for this purpose. The challenge in using the CPU12 lies in finding instructions that do not alter the condition codes. The most important of these instructions are pushes, pulls, transfers, and exchanges.

It is always a good idea to refer to an instruction set summary (see APPENDIX A INSTRUCTION REFERENCE) to check which condition codes are affected by a particular instruction.

The following paragraphs describe normal uses of the condition codes. There are other, more specialized uses. For instance, the C status bit is used to enable weighted fuzzy logic rule evaluation. Specialized usages are described in the relevant portions of this manual and in SECTION 6 INSTRUCTION GLOSSARY.

### 2.1.5.1 S Control Bit

Setting the $S$ bit disables the STOP instruction. Execution of a STOP instruction causes the on-chip oscillator to stop. This may be undesirable in some applications. If the CPU encounters a STOP instruction while the $S$ bit is set, it is treated like a no-operation (NOP) instruction, and continues to the next instruction.

### 2.1.5.2 X Mask Bit

The $\overline{X I R Q}$ input is an updated version of the $\overline{\text { NMI }}$ input found on earlier generations of MCUs. Non-maskable interrupts are typically used to deal with major system failures, such as loss of power. However, enabling non-maskable interrupts before a system is fully powered and initialized can lead to spurious interrupts. The X bit provides a mechanism for enabling non-maskable interrupts after a system is stable.

By default, the $X$ bit is set to one during reset. As long as the $X$ bit remains set, interrupt service requests made via the $\overline{X I R Q}$ pin are not recognized. An instruction must clear the $X$ bit to enable non-maskable interrupt service requests made via the $\overline{X I R Q}$ pin. Once the $X$ bit has been cleared to zero, software cannot reset it to one by writing to the CCR. The X bit is not affected by maskable interrupts.

When an $\overline{\mathrm{XIRQ}}$ interrupt occurs after non-maskable interrupts are enabled, both the $X$ bit and the I bit are automatically set to prevent other interrupts from being recognized during the interrupt service routine. The mask bits are set after the registers are stacked, but before the interrupt vector is fetched.

Normally, an RTI instruction at the end of the interrupt service routine restores register values that were present before the interrupt occurred. Since the CCR is stacked before the X bit is set, the RTI normally clears the X bit, and thus re-enables nonmaskable interrupts. While it is possible to manipulate the stacked value of $X$ so that $X$ is set after an RTI, there is no software method to re-set $X$ (and disable $\overline{\mathrm{NMI}}$ ) once $X$ has been cleared.

### 2.1.5.3 H Status Bit

The H bit indicates a carry from accumulator A bit 3 during an addition operation. The DAA instruction uses the value of the H bit to adjust a result in accumulator A to correct $B C D$ format. H is updated only by the ABA, ADD, and ADC instructions.

### 2.1.5.4 I Mask Bit

The I bit enables and disables maskable interrupt sources. By default, the I bit is set to one during reset. An instruction must clear the I bit to enable maskable interrupts. While the I bit is set, maskable interrupts can become pending and are remembered, but operation continues uninterrupted until the I bit is cleared.

When an interrupt occurs after interrupts are enabled, the I bit is automatically set to prevent other maskable interrupts during the interrupt service routine. The I bit is set after the registers are stacked, but before the interrupt vector is fetched.

Normally, an RTI instruction at the end of the interrupt service routine restores register values that were present before the interrupt occurred. Since the CCR is stacked before the I bit is set, the RTI normally clears the I bit, and thus re-enables interrupts. Interrupts can be re-enabled by clearing the I bit within the service routine, but implementing a nested interrupt management scheme requires great care, and seldom improves system performance.

### 2.1.5.5 N Status Bit

The N bit shows the state of the MSB of the result. N is most commonly used in two's complement arithmetic, where the MSB of a negative number is one and the MSB of a positive number is zero, but it has other uses. For instance, if the MSB of a register or memory location is used as a status flag, the user can test status by loading an accumulator.

### 2.1.5.6 Z Status Bit

The $Z$ bit is set when all the bits of the result are zeros. Compare instructions perform an internal implied subtraction, and the condition codes, including $Z$, reflect the results of that subtraction. The INX, DEX, INY, and DEY instructions affect the $Z$ bit and no other condition flags. These operations can only determine $=$ and $\neq$.

### 2.1.5.7 V Status Bit

The V bit is set when two's complement overflow occurs as a result of an operation.

### 2.1.5.8 C Status Bit

The C bit is set when a carry occurs during addition or a borrow occurs during subtraction. The C bit also acts as an error flag for multiply and divide operations. Shift and rotate instructions operate through the C bit to facilitate multiple-word shifts.

### 2.2 Data Types

The CPU12 uses the following types of data:

- Bits
- 5-bit signed integers
- 8-bit signed and unsigned integers
- 8-bit, 2-digit binary coded decimal numbers
- 9-bit signed integers
- 16-bit signed and unsigned integers
- 16-bit effective addresses
- 32-bit signed and unsigned integers

Negative integers are represented in two's complement form.
Five-bit and 9-bit signed integers are used only as offsets for indexed addressing modes.

Sixteen-bit effective addresses are formed during addressing mode computations.
Thirty-two-bit integer dividends are used by extended division instructions. Extended multiply and extended multiply-and-accumulate instructions produce 32-bit products.

### 2.3 Memory Organization

The standard CPU12 address space is 64 Kbytes. Some M68HC12 devices support a paged memory expansion scheme that increases the standard space by means of predefined windows in address space. The CPU12 has special instructions that support use of expanded memory. See SECTION 10 MEMORY EXPANSION for more information.

Eight-bit values can be stored at any odd or even byte address in available memory. Sixteen-bit values are stored in memory as two consecutive bytes; the high byte occupies the lowest address, but need not be aligned to an even boundary. Thirty-two-bit values are stored in memory as four consecutive bytes; the high byte occupies the lowest address, but need not be aligned to an even boundary.

All I/O and all on-chip peripherals are memory-mapped. No special instruction syntax is required to access these addresses. On-chip registers and memory are typically grouped in blocks which can be relocated within the standard 64-Kbyte address space. Refer to device documentation for specific information.

### 2.4 Instruction Queue

The CPU12 uses an instruction queue to buffer program information. The mechanism is called a queue rather than a pipeline because a typical pipelined CPU executes more than one instruction at the same time, while the CPU12 always finishes executing an instruction before beginning to execute another. Refer to SECTION 4 INSTRUCTION QUEUE for more information.

## SECTION 3 <br> ADDRESSING MODES

Addressing modes determine how the CPU accesses memory locations to be operated upon. This section discusses the various modes and how they are used.

### 3.1 Mode Summary

Addressing modes are an implicit part of CPU12 instructions. APPENDIX A INSTRUCTION REFERENCE shows the modes used by each instruction. All CPU12 addressing modes are shown in Table 3-1.

Table 3-1 M68HC12 Addressing Mode Summary

| Addressing Mode | Source Format | Abbreviation | Description |
| :---: | :---: | :---: | :---: |
| Inherent | INST <br> (no externally supplied operands) | INH | Operands (if any) are in CPU registers |
| Immediate | INST \#opr8i or INST \#opr16i | IMM | Operand is included in instruction stream 8 - or 16-bit size implied by context |
| Direct | INST opr8a | DIR | Operand is the lower 8-bits of an address in the range $\$ 0000-\$ 00 F F$ |
| Extended | INST opr16a | EXT | Operand is a 16-bit address |
| Relative | INST rel8 or INST rel16 | REL | An 8-bit or 16-bit relative offset from the current pc is supplied in the instruction |
| Indexed (5-bit offset) | INST oprx5,xysp | IDX | 5-bit signed constant offset from $x, y, s p$, or pc |
| Indexed (pre-decrement) | INST oprx3,-xys | IDX | Auto pre-decrement $x$, y , or sp by $1 \sim 8$ |
| Indexed (pre-increment) | INST oprx3,+xys | IDX | Auto pre-increment $\mathrm{x}, \mathrm{y}$, or sp by $1 \sim 8$ |
| Indexed (post-decrement) | INST oprx3,xys- | IDX | Auto post-decrement $\mathrm{x}, \mathrm{y}$, or sp by $1 \sim 8$ |
| Indexed (post-increment) | INST oprx3,xys+ | IDX | Auto post-increment $x$, y , or sp by $1 \sim 8$ |
| Indexed (accumulator offset) | INST abd,xysp | IDX | Indexed with 8-bit (A or B) or 16-bit (D) accumulator offset from $x, y, s p$, or $p c$ |
| Indexed (9-bit offset) | INST oprx9,xysp | IDX1 | 9-bit signed constant offset from $x, y, s p$, or $p c$ (lower 8-bits of offset in one extension byte) |
| Indexed (16-bit offset) | INST oprx16,xysp | IDX2 | 16-bit constant offset from $x, y, s p$, or pc (16-bit offset in two extension bytes) |
| Indexed-Indirect (16-bit offset) | INST [oprx16,xysp] | [IDX2] | Pointer to operand is found at... <br> 16-bit constant offset from $x, y, s p$, or pc (16-bit offset in two extension bytes) |
| Indexed-Indirect (D accumulator offset) | INST [D,xysp] | [D,IDX] | Pointer to operand is found at... $x, y, s p$, or $p c$ plus the value in $D$ |

The CPU12 uses all M68HC11 modes as well as new forms of indexed addressing. Differences between M68HC11 and M68HC12 indexed modes are described in 3.8 Indexed Addressing Modes. Instructions that use more than one mode are discussed in 3.9 Instructions Using Multiple Modes.

### 3.2 Effective Address

Each addressing mode except inherent mode generates a 16-bit effective address which is used during the memory reference portion of the instruction. Effective address computations do not require extra execution cycles.

### 3.3 Inherent Addressing Mode

Instructions that use this addressing mode either have no operands or all operands are in internal CPU registers. In either case, the CPU does not need to access any memory locations to complete the instruction.

Examples:

```
NOP ;this instruction has no operands
INX ;operand is a CPU register
```


### 3.4 Immediate Addressing Mode

Operands for immediate mode instructions are included in the instruction stream, and are fetched into the instruction queue one 16-bit word at a time during normal program fetch cycles. Since program data is read into the instruction queue several cycles before it is needed, when an immediate addressing mode operand is called for by an instruction, it is already present in the instruction queue.

The pound symbol (\#) is used to indicate an immediate addressing mode operand. One very common programming error is to accidentally omit the \# symbol. This causes the assembler to misinterpret the following expression as an address rather than explicitly provided data. For example LDAA \#\$55 means to load the immediate value \$55 into the A accumulator, while LDAA \$55 means to load the value from address \$0055 into the A accumulator. Without the \# symbol the instruction is erroneously interpreted as a direct addressing mode instruction.

Examples:

| LDAA | $\# \$ 55$ |
| :--- | :--- |
| LDX | $\# \$ 1234$ |
| LDY | $\# \$ 67$ |

These are common examples of 8 -bit and 16-bit immediate addressing mode. The size of the immediate operand is implied by the instruction context. In the third example, the instruction implies a 16-bit immediate value but only an 8-bit value is supplied. In this case the assembler will generate the 16-bit value $\$ 0067$ because the CPU expects a 16-bit value in the instruction stream.

In this example, extended addressing mode is used to access the operand FOO, immediate addressing mode is used to access the mask value $\$ 03$, and relative addressing mode is used to identify the destination address of a branch in case the branch-taken conditions are met. BRSET is listed as an extended mode instruction even though immediate and relative modes are also used.

### 3.5 Direct Addressing Mode

This addressing mode is sometimes called zero-page addressing because it is used to access operands in the address range $\$ 0000$ through $\$ 00 F F$. Since these addresses always begin with $\$ 00$, only the eight low-order bits of the address need to be included in the instruction, which saves program space and execution time. A system can be optimized by placing the most commonly accessed data in this area of memory. The eight low-order bits of the operand address are supplied with the instruction and the eight high-order bits of the address are assumed to be zero.

Examples:
LDAA $\$ 55$
This is a very basic example of direct addressing. The value $\$ 55$ is taken to be the low-order half of an address in the range $\$ 0000$ through $\$ 00 F F$. The high order half of the address is assumed to be zero. During execution of this instruction, the CPU combines the value $\$ 55$ from the instruction with the assumed value of $\$ 00$ to form the address $\$ 0055$, which is then used to access the data to be loaded into accumulator A .

LDX $\$ 20$
In this example, the value $\$ 20$ is combined with the assumed value of $\$ 00$ to form the address $\$ 0020$. Since the LDX instruction requires a 16 -bit value, a 16 -bit word of data is read from addresses $\$ 0020$ and $\$ 0021$. After execution of this instruction, the X index register will have the value from address $\$ 0020$ in its high-order half and the value from address $\$ 0021$ in its low-order half.

### 3.6 Extended Addressing Mode

In this addressing mode, the full 16-bit address of the memory location to be operated on is provided in the instruction. This addressing mode can be used to access any location in the 64 -Kbyte memory map.

Example:
LDAA \$F03B
This is a very basic example of extended addressing. The value from address \$F03B is loaded into the A accumulator.

### 3.7 Relative Addressing Mode

The relative addressing mode is used only by branch instructions. Short and long conditional branch instructions use relative addressing mode exclusively, but branching versions of bit manipulation instructions (BRSET and BRCLR) use multiple addressing modes, including relative mode. Refer to 3.9 Instructions Using Multiple Modes for more information.

Short branch instructions consist of an 8-bit opcode and a signed 8-bit offset contained in the byte that follows the opcode. Long branch instructions consist of an 8 -bit prebyte, an 8 -bit opcode and a signed 16 -bit offset contained in the two bytes that follow the opcode.

Each conditional branch instruction tests certain status bits in the condition code register. If the bits are in a specified state, the offset is added to the address of the next memory location after the offset to form an effective address, and execution continues at that address; if the bits are not in the specified state, execution continues with the instruction immediately following the branch instruction.

Bit-condition branches test whether bits in a memory byte are in a specific state. Various addressing modes can be used to access the memory location. An 8-bit mask operand is used to test the bits. If each bit in memory that corresponds to a one in the mask is either set (BRSET) or clear (BRCLR), an 8-bit offset is added to the address of the next memory location after the offset to form an effective address, and execution continues at that address; if all the bits in memory that correspond to a one in the mask are not in the specified state, execution continues with the instruction immediately following the branch instruction.

Both 8 -bit and 16 -bit offsets are signed two's complement numbers to support branching upward and downward in memory. The numeric range of short branch offset values is $\$ 80(-128)$ to $\$ 7 \mathrm{~F}$ (127). The numeric range of long branch offset values is $\$ 8000$ ( -32768 ) to \$7FFF (32767). If the offset is zero, the CPU executes the instruction immediately following the branch instruction, regardless of the test involved.

Since the offset is at the end of a branch instruction, using a negative offset value can cause the PC to point to the opcode and initiate a loop. For instance, a branch always (BRA) instruction consists of two bytes, so using an offset of \$FE sets up an infinite loop; the same is true of a long branch always (LBRA) instruction with an offset of \$FFFC.

An offset that points to the opcode can cause a bit-condition branch to repeat execution until the specified bit condition is satisfied. Since bit condition branches can consist of four, five, or six bytes depending on the addressing mode used to access the byte in memory, the offset value that sets up a loop can vary. For instance, using an offset of \$FC with a BRCLR that accesses memory using an 8 -bit indexed postbyte sets up a loop that executes until all the bits in the specified memory byte that correspond to ones in the mask byte are cleared.

### 3.8 Indexed Addressing Modes

The CPU12 uses redefined versions of M 68 HC 11 indexed modes that reduce execution time and eliminate code size penalties for using the $Y$ index register. In most cases, CPU12 code size for indexed operations is the same or is smaller than that for the M 68 HC 11 . Execution time is shorter in all cases. Execution time improvements are due to both a reduced number of cycles for all indexed instructions and to faster system clock speed.

The indexed addressing scheme uses a postbyte plus 0 , 1 , or 2 extension bytes after the instruction opcode. The postbyte and extensions do the following tasks:

1. Specify which index register is used.
2. Determine whether a value in an accumulator is used as an offset.
3. Enable automatic pre or post increment or decrement.
4. Specify size of increment or decrement.
5. Specify use of 5-, 9-, or 16 -bit signed offsets.

This approach eliminates the differences between $X$ and $Y$ register use while dramatically enhancing the indexed addressing capabilities.

Major advantages of the CPU12 indexed addressing scheme are:

- The stack pointer can be used as an index register in all indexed operations.
- The program counter can be used as an index register in all but autoincrement and autodecrement modes.
- A, B, or D accumulators can be used for accumulator offsets.
- Automatic pre- or post-increment or pre- or post-decrement by -8 to +8
- A choice of 5-, 9-, or 16 -bit signed constant offsets.
- Use of two new indexed-indirect modes.
- Indexed-indirect mode with 16-bit offset
- Indexed-indirect mode with accumulator D offset

Table 3-2 is a summary of indexed addressing mode capabilities and a description of postbyte encoding. The postbyte is noted as xb in instruction descriptions. Detailed descriptions of the indexed addressing mode variations follow the table.

All indexed addressing modes use a 16-bit CPU register and additional information to create an effective address. In most cases the effective address specifies the memory location affected by the operation. In some variations of indexed addressing, the effective address specifies the location of a value that points to the memory location affected by the operation.

Indexed addressing mode instructions use a postbyte to specify X, Y, SP, or PC as the base index register and to further classify the way the effective address is formed. A special group of instructions (LEAS, LEAX, and LEAY) cause this calculated effective address to be loaded into an index register for further calculations.

Table 3-2 Summary of Indexed Operations

| Postbyte Code (xb) | Source Code Syntax | $\begin{gathered} \text { Comments } \\ \mathrm{rr} ; 00=\mathrm{X}, 01=\mathrm{Y}, 10=\mathrm{SP}, 11=\mathrm{PC} \end{gathered}$ |
| :---: | :---: | :---: |
| rr0nnnnn | $\begin{aligned} & r \\ & n, r \\ & -n, r \end{aligned}$ | 5-bit constant offset $n=-16$ to +15 $r$ can specify $X, Y, S P$, or PC |
| 111rr0zs | $\begin{aligned} & n, r \\ & -n, r \end{aligned}$ | Constant offset (9- or 16-bit signed) <br> z- $\quad 0=9$-bit with sign in LSB of postbyte(s) $\quad-256<n<255$ <br> $1=16$-bit $0<n<65,535$ <br> if $z=s=1,16$-bit offset indexed-indirect (see below) <br> $r$ can specify $X, Y, S P$, or PC |
| 111rr011 | [ $\mathrm{n}, \mathrm{r}$ ] | 16-bit offset indexed-indirect rr can specify X, Y, SP, or PC $0<n<65,535$ |
| rr1pnnnn | $\begin{aligned} & \mathrm{n},-\mathrm{r} \\ & \mathrm{n}, \mathrm{r} \\ & \mathrm{n}, \mathrm{r}- \\ & \mathrm{n}, \mathrm{r} \end{aligned}$ | Auto pre-decrement/increment or Auto post-decrement/increment; $\mathrm{p}=$ pre-(0) or post-(1), $\mathrm{n}=-8$ to $-1,+1$ to +8 $r$ can specify $X, Y$, or SP (PC not a valid choice) $\begin{aligned} & +8=0111 \\ & \ldots \\ & +1=0000 \\ & -1=1111 \\ & \ldots \\ & -8=1000 \end{aligned}$ |
| 111rr1aa | $\begin{aligned} & A, r \\ & B, r \\ & D, r \end{aligned}$ | ```Accumulator offset (unsigned 8-bit or 16-bit) aa- \(00=A\) \(01=B\) \(10=\mathrm{D}\) (16-bit) 11 = see accumulator D offset indexed-indirect r can specify X, Y, SP, or PC``` |
| 111rr111 | [D, r] | Accumulator D offset indexed-indirect r can specify X, Y, SP, or PC |

### 3.8.1 5-Bit Constant Offset Indexed Addressing

This indexed addressing mode uses a 5-bit signed offset which is included in the instruction postbyte. This short offset is added to the base index register (X, Y, SP, or PC ) to form the effective address of the memory location that will be affected by the instruction. This gives a range of -16 through +15 from the value in the base index register. Although other indexed addressing modes allow 9- or 16-bit offsets, those modes also require additional extension bytes in the instruction for this extra information. The majority of indexed instructions in real programs use offsets that fit in the shortest 5-bit form of indexed addressing.

Examples:

| LDAA | $0, \mathrm{X}$ |
| :--- | :--- |
| STAB | $-8, Y$ |

For these examples, assume $X$ has a value of $\$ 1000$ and $Y$ has a value of $\$ 2000$ before execution. The 5-bit constant offset mode does not change the value in the index register, so X will still be $\$ 1000$ and Y will still be $\$ 2000$ after execution of these instructions. In the first example, A will be loaded with the value from address $\$ 1000$. In the second example, the value from the B accumulator will be stored at address \$1FF8 (\$2000-\$8).

### 3.8.2 9-Bit Constant Offset Indexed Addressing

This indexed addressing mode uses a 9-bit signed offset which is added to the base index register (X, Y, SP, or PC) to form the effective address of the memory location affected by the instruction. This gives a range of -256 through +255 from the value in the base index register. The most significant bit (sign bit) of the offset is included in the instruction postbyte and the remaining eight bits are provided as an extension byte after the instruction postbyte in the instruction flow.

Examples:

| LDAA | $\$ F F, X$ |
| :--- | :--- |
| LDAB | $-20, Y$ |

For these examples assume X is $\$ 1000$ and Y is $\$ 2000$ before execution of these instructions. (These instructions do not alter the index registers so they will still be $\$ 1000$ and $\$ 2000$ respectively after the instructions.) The first instruction will load A with the value from address $\$ 10 \mathrm{FF}$ and the second instruction will load $B$ with the value from address \$1FEC.

This variation of the indexed addressing mode in the CPU12 is similar to the M68HC11 indexed addressing mode, but is functionally enhanced. The M68HC11 CPU provides for unsigned 8 -bit constant offset indexing from $X$ or $Y$, and use of $Y$ requires an extra instruction byte and thus, an extra execution cycle. The 9-bit signed offset used in the CPU12 covers the same range of positive offsets as the M68HC11, and adds negative offset capability. The CPU12 can use X, Y, SP or PC as the base index register.

### 3.8.3 16-Bit Constant Offset Indexed Addressing

This indexed addressing mode uses a 16-bit offset which is added to the base index register (X, Y, SP, or PC) to form the effective address of the memory location affected by the instruction. This allows access to any address in the 64-Kbyte address space. Since the address bus and the offset are both 16 bits, it does not matter whether the offset value is considered to be a signed or an unsigned value (\$FFFF may be thought of as $+65,535$ or as -1 ). The 16 -bit offset is provided as two extension bytes after the instruction postbyte in the instruction flow.

### 3.8.4 16-Bit Constant Indirect Indexed Addressing

This indexed addressing mode adds a 16-bit instruction-supplied offset to the base index register to form the address of a memory location that contains a pointer to the memory location affected by the instruction. The instruction itself does not point to the address of the memory location to be acted upon, but rather to the location of a pointer to the address to be acted on. The square brackets distinguish this addressing mode from 16-bit constant offset indexing.

Example:

In this example, X holds the base address of a table of pointers. Assume that X has an initial value of $\$ 1000$, and that the value $\$ 2000$ is stored at addresses $\$ 100 \mathrm{~A}$ and \$100B. The instruction first adds the value 10 to the value in $X$ to form the address $\$ 100 \mathrm{~A}$. Next, an address pointer (\$2000) is fetched from memory at \$100A. Then, the value stored in location $\$ 2000$ is read and loaded into the $A$ accumulator.

### 3.8.5 Auto Pre/Post Decrement/Increment Indexed Addressing

This indexed addressing mode provides four ways to automatically change the value in a base index register as a part of instruction execution. The index register can be incremented or decremented by an integer value either before or after indexing takes place. The base index register may be X, Y, or SP (auto-modify modes would not make sense on PC).

Pre decrement and pre increment versions of the addressing mode adjust the value of the index register before accessing the memory location affected by the instruction the index register retains the changed value after the instruction executes. Post-decrement and post-increment versions of the addressing mode use the initial value in the index register to access the memory location affected by the instruction, then change the value of the index register.

The CPU12 allows the index register to be incremented or decremented by any integer value in the ranges -8 through -1 , or 1 through 8 . The value need not be related to the size of the operand for the current instruction. These instructions can be used to incorporate an index adjustment into an existing instruction rather than using an additional instruction and increasing execution time. This addressing mode is also used to perform operations on a series of data structures in memory.

When an LEAS, LEAX, or LEAY instruction is executed using this addressing mode, and the operation modifies the index register that is being loaded, the final value in the register is the value that would have been used to access a memory operand (premodification is seen in the result but postmodification is not).

Examples:

| STAA | $1,-S P$ | ; equivalent to PSHA |
| :--- | :--- | :--- |
| STX | $2,-S P$ | ; equivalent to PSHX |
| LDX | $2, S P+$ | ; equivalent to PULX |
| LDAA | $1, S P+$ | ;equivalent to PULA |

For a "last-used" type of stack like the CPU12 stack, these four examples are equivalent to common push and pull instructions. For a "next-available" stack like the M68HC11 stack, PSHA is equivalent to STAA $1, \mathrm{SP}$ - and PULA is equivalent to LDAA $1,+$ SP. However, in the M68HC11, 16-bit operations like PSHX and PULX require multiple instructions to decrement the SP by one, then store $X$, then decrement SP by one again.

In the STAA 1,-SP example, the stack pointer is pre-decremented by one and then A is stored to the address contained in the stack pointer. Similarly the LDX 2,SP+ first loads X from the address in the stack pointer, then post-increments SP by two.

Example:

$$
\text { MOVW } \quad 2, X+, 4,+Y
$$

This example demonstrates how to work with data structures larger than bytes and words. With this instruction in a program loop, it is possible to move words of data from a list having one word per entry into a second table that has four bytes per table element. In this example the source pointer is updated after the data is read from memory (post-increment) while the destination pointer is updated before it is used to access memory (pre-increment).

### 3.8.6 Accumulator Offset Indexed Addressing

In this indexed addressing mode, the effective address is the sum of the values in the base index register and an unsigned offset in one of the accumulators. The value in the index register itself is not changed. The index register can be $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC and the accumulator can be either of the 8 -bit accumulators ( $A$ or $B$ ) or the 16-bit $D$ accumulator.

Example:

$$
\text { LDAA } \quad B, X
$$

This instruction internally adds $B$ to $X$ to form the address from which $A$ will be loaded. $B$ and $X$ are not changed by this instruction. This example is similar to the following two-instruction combination in an M68HC11.

$$
\begin{aligned}
& \text { ABX } \\
& \text { LDAA } \quad 0, \mathrm{X}
\end{aligned}
$$

However, this two-instruction sequence alters the index register. If this sequence was part of a loop where B changed on each pass, the index register would have to be reloaded with the reference value on each loop pass. The use of LDAA $B, X$ is more efficient in the CPU12.

### 3.8.7 Accumulator D Indirect Indexed Addressing

This indexed addressing mode adds the value in the $D$ accumulator to the value in the base index register to form the address of a memory location that contains a pointer to the memory location affected by the instruction. The instruction operand does not point to the address of the memory location to be acted upon, but rather to the location of a pointer to the address to be acted upon. The square brackets distinguish this addressing mode from $D$ accumulator offset indexing.

Example:

| JMP | $[\mathrm{D}, \mathrm{PC}]$ |  |
| :--- | :--- | :--- |
| GO1 | DC.W | PLACE1 |
| GO2 | DC.W | PLACE2 |
| GO3 | DC.W | PLACE3 |

This example is a computed GOTO. The values beginning at GO1 are addresses of potential destinations of the jump instruction. At the time the JMP [D,PC] instruction is executed, PC points to the address GO1, and D holds one of the values $\$ 0000, \$ 0002$, or $\$ 0004$ (determined by the program some time before the JMP).

Assume that the value in D is $\$ 0002$. The JMP instruction adds the values in D and PC to form the address of GO2. Next the CPU reads the address PLACE2 from memory at GO2 and jumps to PLACE2. The locations of PLACE1 through PLACE3 were known at the time of program assembly but the destination of the JMP depends upon the value in D computed during program execution.

### 3.9 Instructions Using Multiple Modes

Several CPU12 instructions use more than one addressing mode in the course of execution.

### 3.9.1 Move Instructions

Move instructions use separate addressing modes to access the source and destination of a move. There are move variations for most combinations of immediate, extended, and indexed addressing modes.

The only combinations of addressing modes that are not allowed are those with an immediate mode destination (the operand of an immediate mode instruction is data, not an address). For indexed moves, the reference index register may be $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC.

Move instructions do not support indirect modes, or 9- or 16-bit offset modes requiring extra extension bytes. There are special considerations when using PC-relative addressing with move instructions.

PC-relative addressing uses the address of the location immediately following the last byte of object code for the current instruction as a reference point. The CPU12 normally corrects for queue offset and for instruction alignment so that queue operation is transparent to the user. However, move instructions pose three special problems:

1. Some moves use an indexed source and an indexed destination.
2. Some moves have object code that is too long to fit in the queue all at one time, so the PC value changes during execution.
3. All moves do not have the indexed postbyte as the last byte of object code.

These cases are not handled by automatic queue pointer maintenance, but it is still possible to use PC-relative indexing with move instructions by providing for PC offsets in source code.

Table 3-3 shows PC offsets from the location immediately following the current instruction by addressing mode.

Table 3-3 PC Offsets for Move Instructions

| MOVE Instruction | Addressing Modes | Offset Value |
| :---: | :---: | :---: |
| MOVB | IMM $\Rightarrow$ IDX | +1 |
|  | EXT $\Rightarrow$ IDX | +2 |
|  | IDX $\Rightarrow$ EXT | -2 |
|  | IDX $\Rightarrow$ IDX | - 1 for 1st Operand <br> +1 for 2nd Operand |
| MOVW | IMM $\Rightarrow$ IDX | +2 |
|  | EXT $\Rightarrow$ IDX | +2 |
|  | IDX $\Rightarrow$ EXT | -2 |
|  | IDX $\Rightarrow$ IDX | - 1 for 1st Operand <br> +1 for 2nd Operand |

Example:

```
1000 18 09 C2 20 00 MOVB $2000 2,PC
```

Moves a byte of data from $\$ 2000$ to $\$ 1009$
The expected location of the PC $=\$ 1005$. The offset $=+2$.
$(1005+2($ for $2, \mathrm{PC})+2($ for correction $)=1009)$
$\$ 18$ is the page pre-byte, 09 is the MOVB opcode for ext-idx, C2 is the indexed postbyte for 2,PC (without correction).

The Motorola MCUasm assembler produces corrected object code for PC-relative moves (1809 C0 2000 for the example shown). Note that, instead of assembling the 2,PC as C2, the correction has been applied to make it C0. Check whether an assembler makes the correction before using PC-relative moves.

### 3.9.2 Bit Manipulation Instructions

Bit manipulation instructions use either a combination of two or a combination of three addressing modes.

The BCLR and BSET instructions use an 8 -bit mask to determine which bits in a memory byte are to be changed. The mask must be supplied with the instruction as an immediate mode value. The memory location to be modified can be specified by means of direct, extended, or indexed addressing modes.

The BRCLR and BRSET instructions use an 8-bit mask to test the states of bits in a memory byte. The mask is supplied with the instruction as an immediate mode value. The memory location to be tested is specified by means of direct, extended, or indexed addressing modes. Relative addressing mode is used to determine the branch address. A signed 8 -bit offset must be supplied with the instruction.

### 3.10 Addressing More than 64 Kbytes

Some M68HC12 devices incorporate hardware that supports addressing a larger memory space than the standard 64 Kbytes. The expanded memory system uses fast on-chip logic to implement a transparent bank-switching scheme.

Increased code efficiency is the greatest advantage of using a switching scheme instead of a large linear address space. In systems with large linear address spaces, instructions require more bits of information to address a memory location, and CPU overhead is greater. Other advantages include the ability to change the size of system memory and the ability to use various types of external memory.

However, the add-on bank switching schemes used in other microcontrollers have known weaknesses. These include the cost of external glue logic, increased programming overhead to change banks, and the need to disable interrupts while banks are switched.

The M68HC12 system requires no external glue logic. Bank switching overhead is reduced by implementing control logic in the MCU. Interrupts do not need to be disabled during switching because switching tasks are incorporated in special instructions that greatly simplify program access to extended memory.

MCUs with expanded memory treat the 16 Kbytes of memory space from $\$ 8000$ to \$BFFF as a program memory window. Expanded-memory devices also have an 8-bit program page register (PPAGE), which allows up to 256 16-Kbyte program memory pages to be switched into and out of the program memory window. This provides for up to 4 Megabytes of paged program memory.

The CPU12 instruction set includes CALL and RTC (return from call) instructions, which greatly simplify the use of expanded memory space. These instructions also execute correctly on devices that do not have expanded-memory addressing capability, thus providing for portable code.

The CALL instruction is similar to the JSR instruction. When CALL is executed, the current value in PPAGE is pushed onto the stack with a return address, and a new in-struction-supplied value is written to PPAGE. This value selects the page the called subroutine resides upon, and can be considered to be part of the effective address. For all addressing mode variations except indexed indirect modes, the new page value is provided by an immediate operand in the instruction. For indexed indirect variations of CALL, a pointer specifies memory locations where the new page value and the address of the called subroutine are stored. Use of indirect addressing for both the page value and the address within the page frees the program from keeping track of explicit values for either address.

The RTC instruction restores the saved program page value and the return address from the stack. This causes execution to resume at the next instruction after the original CALL instruction.

Refer to SECTION 10 MEMORY EXPANSION for a detailed discussion of memory expansion.

## SECTION 4 <br> INSTRUCTION QUEUE

The CPU12 uses an instruction queue to increase execution speed. This section describes queue operation during normal program execution and changes in execution flow. These concepts augment the descriptions of instructions and cycle-by-cycle instruction execution in subsequent sections, but it is important to note that queue operation is automatic, and generally transparent to the user.

The material in this section is general. SECTION 6 INSTRUCTION GLOSSARY contains detailed information concerning cycle-by-cycle execution of each instruction. SECTION 8 DEVELOPMENT AND DEBUG SUPPORT contains detailed information about tracking queue operation and instruction execution.

### 4.1 Queue Description

The fetching mechanism in the CPU12 is best described as a queue rather than as a pipeline. Queue logic fetches program information and positions it for execution, but instructions are executed sequentially. A typical pipelined CPU can execute more than one instruction at the same time, but interactions between the prefetch and execution mechanisms can make tracking and debugging difficult. The CPU12 thus gains the advantages of independent fetches, yet maintains a straightforward relationship between bus and execution cycles.

There are two 16-bit queue stages and one 16-bit buffer. Program information is fetched in aligned 16-bit words. Unless buffering is required, program information is first queued into stage 1 , then advanced to stage 2 for execution.

At least two words of program information are available to the CPU when execution begins. The first byte of object code is in either the even or odd half of the word in stage 2 , and at least two more bytes of object code are in the queue.

Queue logic manages the position of program information so that the CPU itself does not deal with alignment. As it is executed, each instruction initiates at least enough program word fetches to replace its own object code in the queue.

The buffer is used when a program word arrives before the queue can advance. This occurs during execution of single-byte and odd-aligned instructions. For instance, the queue cannot advance after an aligned, single-byte instruction is executed, because the first byte of the next instruction is also in stage 2 . In these cases, information is latched into the buffer until the queue can advance.

Two external pins, IPIPE[1:0], provide time-multiplexed information about data movement in the queue and instruction execution. Decoding and use of these signals is discussed in SECTION 8 DEVELOPMENT AND DEBUG SUPPORT.

### 4.2 Data Movement in the Queue

All queue operations are combinations of four basic queue movement cycles. Descriptions of each of these cycles follows. Queue movement cycles are only one factor in instruction execution time, and should not be confused with bus cycles.

### 4.2.1 No Movement

There is no data movement in the instruction queue during the cycle. This occurs during execution of instructions that must perform a number of internal operations, such as division instructions.

### 4.2.2 Latch Data from Bus

All instructions initiate fetches to refill the queue as execution proceeds. However, a number of conditions, including instruction alignment and the length of previous instructions, affect when the queue advances. If the queue is not ready to advance when fetched information arrives, the information is latched into the buffer. Later, when the queue does advance, stage 1 is refilled from the buffer. If more than one latch cycle occurs before the queue advances, the buffer is filled on the first latch event and subsequent latch events are ignored until the queue advances.

### 4.2.3 Advance and Load from Data Bus

The content of queue stage 1 advances to stage 2 , and stage 1 is loaded with a word of program information from the data bus. The information was requested two bus cycles earlier but has only become available this cycle, due to access delay.

### 4.2.4 Advance and Load from Buffer

The content of queue stage 1 advances to stage 2 , and stage 1 is loaded with a word of program information from the buffer. The information in the buffer was latched from the data bus during a previous cycle because the queue was not ready to advance when it arrived.

### 4.3 Changes in Execution Flow

During normal instruction execution, queue operations proceed as a continuous sequence of queue movement cycles. However, situations arise which call for changes in flow. These changes are categorized as resets, interrupts, subroutine calls, conditional branches, and jumps. Generally speaking, resets and interrupts are considered to be related to events outside the current program context that require special processing, while subroutine calls, branches, and jumps are considered to be elements of program structure.

During design, great care is taken to assure that the mechanism that increases instruction throughput during normal program execution does not cause bottlenecks during changes of program flow, but internal queue operation is largely transparent to the user. The following information is provided to enhance subsequent descriptions of instruction execution.

### 4.3.1 Exceptions

Exceptions are events that require processing outside the normal flow of instruction execution. CPU12 exceptions include four types of resets, an unimplemented opcode trap, a software interrupt instruction, X-bit interrupts, and I-bit interrupts. All exceptions use the same microcode, but the CPU follows different execution paths for each type of exception.

CPU12 exception handling is designed to minimize the effect of queue operation on context switching. Thus, an exception vector fetch is the first part of exception processing, and fetches to refill the queue from the address pointed to by the vector are interleaved with the stacking operations that preserve context, so that program access time does not delay the switch. Refer to SECTION 7 EXCEPTION PROCESSING for detailed information.

### 4.3.2 Subroutines

The CPU12 can branch to (BSR), jump to (JSR), or CALL subroutines. BSR and JSR are used to access subroutines in the normal 64-Kbyte address space. The CALL instruction is intended for use in MCUs with expanded memory capability.

BSR uses relative addressing mode to generate the effective address of the subroutine, while JSR can use various other addressing modes. Both instructions calculate a return address, stack the address, then perform three program word fetches to refill the queue. The first two words fetched are queued during the second and third cycles of the sequence. The third fetch cycle is performed in anticipation of a queue advance, which may occur during the fourth cycle of the sequence. If the queue is not yet ready to advance at that time, the third word of program information is held in the buffer.

Subroutines in the normal 64-Kbyte address space are terminated with a return from subroutine (RTS) instruction. RTS unstacks the return address, then performs three program word fetches from that address to refill the queue.

CALL is similar to JSR. MCUs with expanded memory treat 16 Kbytes of addresses from $\$ 8000$ to $\$ B F F F$ as a memory window. An 8-bit PPAGE register switches memory pages into and out of the window. When CALL is executed, a return address is calculated, then it and the current PPAGE value are stacked, and a new instructionsupplied value is written to PPAGE. The subroutine address is calculated, then three program word fetches are made from that address.

The RTC instruction is used to terminate subroutines in expanded memory. RTC unstacks the PPAGE value and the return address, then performs three program word fetches from that address to refill the queue.

CALL and RTC execute correctly in the normal 64-Kbyte address space, thus providing for portable code. However, since extra execution cycles are required, routinely substituting CALL/RTC for JSR/RTS is not recommended.

### 4.3.3 Branches

Branch instructions cause execution flow to change when specific pre-conditions exist. The CPU12 instruction set includes short conditional branches, long conditional branches, and bit-condition branches. Types and conditions of branch instructions are described in 5.18 Branch Instructions. All branch instructions affect the queue similarly, but there are differences in overall cycle counts between the various types. Loop primitive instructions are a special type of branch instruction used to implement counter-based loops.

Branch instructions have two execution cases. Either the branch condition is satisfied, and a change of flow takes place, or the condition is not satisfied, and no change of flow occurs.

### 4.3.3.1 Short Branches

The "not-taken" case for short branches is simple. Since the instruction consists of a single word containing both an opcode and an 8-bit offset, the queue advances, another program word is fetched, and execution continues with the next instruction.

The "taken" case for short branches requires that the queue be refilled so that execution can continue at a new address. First, the effective address of the destination is calculated using the relative offset in the instruction. Then, the address is loaded into the program counter, and the CPU performs three program word fetches at the new address. The first two words fetched are loaded into the instruction queue during the second and third cycles of the sequence. The third fetch cycle is performed in anticipation of a queue advance, which may occur during the first cycle of the next instruction. If the queue is not yet ready to advance at that time, the third word of program information is held in the buffer.

### 4.3.3.2 Long Branches

The "not-taken" case for all long branches requires three cycles, while the "taken" case requires four cycles. This is due to differences in the amount of program information needed to fill the queue.

Long branch instructions begin with a $\$ 18$ prebyte which indicates that the opcode is on page 2 of the opcode map. The CPU12 treats the prebyte as a special one-byte instruction. If the prebyte is not aligned, the first cycle is used to perform a program word access; if the prebyte is aligned, the first cycle is used to perform a free cycle. The first cycle for the prebyte is executed whether or not the branch is taken.

The first cycle of the branch instruction is an optional cycle. Optional cycles make the effects of byte-sized and misaligned instructions consistent with those of aligned wordlength instructions. Optional cycles are always performed, but serve different purposes determined by instruction alignment. Program information is always fetched as aligned 16-bit words. When an instruction consists of an odd number of bytes, and the first byte is aligned with an even byte boundary, an optional cycle is used to make an additional program word access that maintains queue order. In all other cases, the optional cycle appears as a free cycle.

In the "not-taken" case, the queue must advance so that execution can continue with the next instruction. Two cycles are used to refill the queue. Alignment determines how the second of these cycles is used.

In the "taken" case, the effective address of the branch is calculated using the 16-bit relative offset contained in the second word of the instruction. This address is loaded into the program counter, then the CPU performs three program word fetches at the new address. The first two words fetched are loaded into the instruction queue during the second and third cycles of the sequence. The third fetch cycle is performed in anticipation of a queue advance, which may occur during the first cycle of the next instruction. If the queue is not yet ready to advance, the third word of program information is held in the buffer.

### 4.3.3.3 Bit Condition Branches

Bit-conditional branch instructions read a location in memory, and branch if the bits in that location are in a certain state. These instructions can use direct, extended, or indexed addressing modes. Indexed operations require varying amounts of information to determine the effective address, so instruction length varies according to the mode used, which in turn affects the amount of program information fetched. In order to shorten execution time, these branches perform one program word fetch in anticipation of the "taken" case. The data from this fetch is overwritten by subsequent fetches in the "not-taken" case.

### 4.3.3.4 Loop Primitives

The loop primitive instructions test a counter value in a register or accumulator, and branch to an address specified by a 9-bit relative offset contained in the instruction if a specified pre-condition is met. There are auto-increment and auto-decrement versions of the instructions. The test and increment/decrement operations are performed on internal CPU registers, and require no additional program information. In order to shorten execution time, these branches perform one program word fetch in anticipation of the "taken" case. The data from this fetch is overwritten by subsequent fetches in the "not-taken" case. The "taken" case performs two additional program word fetches at the new address. In the "not-taken" case, the queue must advance so that execution can continue with the next instruction. Two cycles are used to refill the queue.

### 4.3.4 Jumps

JMP is the simplest change of flow instruction. JMP can use extended or indexed addressing. Indexed operations require varying amounts of information to determine the effective address, so instruction length varies according to the mode used, which in turn affects the amount of program information fetched. All forms of JMP perform three program word fetches at the new address. The first two words fetched are loaded into the instruction queue during the second and third cycles of the sequence. The third fetch cycle is performed in anticipation of a queue advance, which may occur during the first cycle of the next instruction. If the queue is not yet ready to advance, the third word of program information is held in the buffer.

## SECTION 5 INSTRUCTION SET OVERVIEW

This section contains general information about the CPU12 instruction set. It is organized into instruction categories grouped by function.

### 5.1 Instruction Set Description

CPU12 instructions are a superset of the M68HC11 instruction set. Code written for an M68HC11 can be reassembled and run on a CPU12 with no changes. The CPU12 provides expanded functionality and increased code efficiency.

In the M68HC12 architecture, all memory and I/O are mapped in a common 64 -Kbyte address space (memory-mapped I/O). This allows the same set of instructions to be used to access memory, I/O, and control registers. General-purpose load, store, transfer, exchange, and move instructions facilitate movement of data to and from memory and peripherals.

The CPU12 has a full set of 8 -bit and 16 -bit mathematical instructions. There are instructions for signed and unsigned arithmetic, division and multiplication with 8-bit, 16bit, and some larger operands.

Special arithmetic and logic instructions aid stacking operations, indexing, BCD calculation, and condition code register manipulation. There are also dedicated instructions for multiply and accumulate operations, table interpolation, and specialized fuzzy logic operations that involve mathematical calculations.

Refer to SECTION 6 INSTRUCTION GLOSSARY for detailed information about individual instructions. APPENDIX A INSTRUCTION REFERENCE contains quick-reference material, including an opcode map and postbyte encoding for indexed addressing, transfer/exchange instructions, and loop primitive instructions.

### 5.2 Load and Store Instructions

Load instructions copy memory content into an accumulator or register. Memory content is not changed by the operation. Load instructions (but not LEA_ instructions) affect condition code bits so no separate test instructions are needed to check the loaded values for negative or zero conditions.

Store instructions copy the content of a CPU register to memory. Register/accumulator content is not changed by the operation. Store instructions automatically update the N and Z condition code bits, which can eliminate the need for a separate test instruction in some programs.

Table $5-1$ is a summary of load and store instructions.

Table 5-1 Load and Store Instructions

| Load Instructions |  |  |
| :---: | :---: | :---: |
| Mnemonic | Function | Operation |
| LDAA | Load $A$ | $(M) \Rightarrow A$ |
| LDAB | Load B | $(M) \Rightarrow B$ |
| LDD | Load D | $(M: M+1) \Rightarrow(A: B)$ |
| LDS | Load SP | $(M+M+1) \Rightarrow S P$ |
| LDX | Load Index Register $X$ | $(M: M+1) \Rightarrow X$ |
| LDY | Load Index Register $Y$ | $(M: M+1) \Rightarrow Y$ |
| LEAS | Load Effective Address into SP | Effective Address $\Rightarrow S P$ |
| LEAX | Load Effective Address into $X$ | Effective Address $\Rightarrow X$ |
| LEAY | Load Effective Address into $Y$ | Effective Address $\Rightarrow Y$ |
| Mnemonic | Store Instructions |  |
| STAA | Function | $(A) \Rightarrow M$ |
| STAB | Store $A$ | $(B) \Rightarrow M$ |
| STD | Store $B$ | $(A) \Rightarrow M,(B) \Rightarrow M+1$ |
| STS | Store $D$ | $(S P) \Rightarrow M: M+1$ |
| STX | Store SP | $(X) \Rightarrow M: M+1$ |
| STY | Store $X$ | $(Y) \Rightarrow M: M+1$ |

### 5.3 Transfer and Exchange Instructions

Transfer instructions copy the content of a register or accumulator into another register or accumulator. Source content is not changed by the operation. TFR is a universal transfer instruction, but other mnemonics are accepted for compatibility with the M68HC11. The TAB and TBA instructions affect the N, Z, and V condition code bits in the same way as M68HC11 instructions. The TFR instruction does not affect the condition code bits.

Exchange instructions exchange the contents of pairs of registers or accumulators.
The SEX instruction is a special case of the universal transfer instruction that is used to sign-extend 8-bit two's complement numbers so that they can be used in 16-bit operations. The 8 -bit number is copied from accumulator $A$, accumulator $B$, or the condition codes register to accumulator $D$, the X index register, the Y index register, or the stack pointer. All the bits in the upper byte of the 16-bit result are given the value of the MSB of the 8-bit number.

SECTION 6 INSTRUCTION GLOSSARY contains information concerning other transfers and exchanges between 8- and 16-bit registers.

Table 5-2 is a summary of transfer and exchange instructions.

Table 5-2 Transfer and Exchange Instructions

| Transfer Instructions |  |  |
| :---: | :---: | :---: |
| Mnemonic | Function | Operation |
| TAB | Transfer A to B | (A) $\Rightarrow$ B |
| TAP | Transfer A to CCR | $(\mathrm{A}) \Rightarrow \mathrm{CCR}$ |
| TBA | Transfer B to A | $(\mathrm{B}) \Rightarrow \mathrm{A}$ |
| TFR | Transfer Register to Register | $(\mathrm{A}, \mathrm{B}, \mathrm{CCR}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP) $\Rightarrow \mathrm{A}, \mathrm{B}, \mathrm{CCR}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP |
| TPA | Transfer CCR to A | $(\mathrm{CCR}) \Rightarrow A$ |
| TSX | Transfer SP to X | $(\mathrm{SP}) \Rightarrow \mathrm{X}$ |
| TSY | Transfer SP to Y | $(\mathrm{SP}) \Rightarrow \mathrm{Y}$ |
| TXS | Transfer X to SP | $(\mathrm{X}) \Rightarrow \mathrm{SP}$ |
| TYS | Transfer Y to SP | $(\mathrm{Y}) \Rightarrow \mathrm{SP}$ |
| Exchange Instructions |  |  |
| Mnemonic | Function | Operation |
| EXG | Exchange Register to Register | (A, B, CCR, D, X, Y, or SP) $\Leftrightarrow(\mathrm{A}, \mathrm{B}, \mathrm{CCR}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP) |
| XGDX | Exchange D with X | $(\mathrm{D}) \Leftrightarrow(\mathrm{X})$ |
| XGDY | Exchange D with Y | (D) $\Leftrightarrow(\mathrm{Y})$ |
| Sign Extension Instruction |  |  |
| Mnemonic | Function | Operation |
| SEX | Sign Extend 8-Bit Operand | $(\mathrm{A}, \mathrm{B}, \mathrm{CCR}) \Rightarrow \mathrm{X}, \mathrm{Y}$, or SP |

### 5.4 Move Instructions

These instructions move data bytes or words from a source $\left(M_{1}, M: M+1_{1}\right)$ to a destination ( $\mathrm{M}_{2}, \mathrm{M}: \mathrm{M}+1_{2}$ ) in memory. Six combinations of immediate, extended, and indexed addressing are allowed to specify source and destination addresses (IMM $\Rightarrow$ $\mathrm{EXT}, \mathrm{IMM} \Rightarrow \mathrm{IDX}, \mathrm{EXT} \Rightarrow \mathrm{EXT}, \mathrm{EXT} \Rightarrow \mathrm{IDX}, \mathrm{IDX} \Rightarrow \mathrm{EXT}, \mathrm{IDX} \Rightarrow \mathrm{IDX})$.

Table 5-3 shows byte and word move instructions.

Table 5-3 Move Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| MOVB | Move Byte (8-bit) | $\left(M_{1}\right) \Rightarrow M_{2}$ |
| MOVW | Move Word (16-bit) | $\left(M: M+1_{1}\right) \Rightarrow M: M+1_{2}$ |

### 5.5 Addition and Subtraction Instructions

Signed and unsigned 8- and 16-bit addition can be performed between registers or between registers and memory. Special instructions support index calculation. Instructions that add the CCR carry bit facilitate multiple precision computation.

Signed and unsigned 8- and 16-bit subtraction can be performed between registers or between registers and memory. Special instructions support index calculation. Instructions that subtract the CCR carry bit facilitate multiple precision computation. Refer to Table 5-4 for addition and subtraction instructions.

Table 5-4 Addition and Subtraction Instructions

| Addition Instructions |  |  |
| :---: | :---: | :---: |
| Mnemonic | Function | Operation |
| ABA | Add A to $B$ | $(A)+(B) \Rightarrow A$ |
| ABX | Add B to $X$ | $(B)+(X) \Rightarrow X$ |
| ABY | Add B to $Y$ | $(B)+(Y) \Rightarrow Y$ |
| ADCA | Add with Carry to $A$ | $(A)+(M)+C \Rightarrow A$ |
| ADCB | Add with Carry to $B$ | $(B)+(M)+C \Rightarrow B$ |
| ADDA | Add without Carry to $A$ | $(A)+(M) \Rightarrow A$ |
| ADDB | Add without Carry to $B$ | $(B)+(M) \Rightarrow B$ |
| ADDD | Add to $D$ | $(A: B)+(M) M+1) \Rightarrow A: B$ |
| Mnemonic | Subtraction Instructions |  |
| SBA | Function | $(A)-(B) \Rightarrow A$ |
| SBCA | Subtract B from A | $(A)-(M)-C \Rightarrow A$ |
| SBCB | Subtract with Borrow from $A$ | $(B)-(M)-C \Rightarrow B$ |
| SUBA | Subtract with Borrow from $B$ | $(A)-(M) \Rightarrow A$ |
| SUBB | Subtract Memory from $A$ | $(B)-(M) \Rightarrow B$ |
| SUBD | Subtract Memory from $B$ | $(D)-(M) M+1) \Rightarrow D$ |

### 5.6 Binary Coded Decimal Instructions

To add binary coded decimal operands, use addition instructions that set the half-carry bit in the CCR, then adjust the result with the DAA instruction. Table 5-5 is a summary of instructions that can be used to perform BCD operations.

Table 5-5 BCD Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| ABA | Add B to $A$ | $(A)+(B) \Rightarrow A$ |
| ADCA | Add with Carry to $A$ | $(A)+(M)+C \Rightarrow A$ |
| ADCB | Add with Carry to B | $(B)+(M)+C \Rightarrow B$ |
| ADDA | Add Memory to A | $(A)+(M) \Rightarrow A$ |
| ADDB | Add Memory to B | $(B)+(M) \Rightarrow B$ |
| DAA | Decimal Adjust A | $(A) 10$ |

### 5.7 Decrement and Increment Instructions

These instructions are optimized 8- and 16-bit addition and subtraction operations. They are generally used to implement counters. Because they do not affect the carry bit in the CCR, they are particularly well suited for loop counters in multiple-precision computation routines. Refer to 5.19 Loop Primitive Instructions for information concerning automatic counter branches. Table 5-6 is a summary of decrement and increment instructions.

Table 5-6 Decrement and Increment Instructions

| Decrement Instructions |  |  |
| :---: | :---: | :---: |
| Mnemonic | Function | Operation |
| DEC | Decrement Memory | $(\mathrm{M})-\$ 01 \Rightarrow \mathrm{M}$ |
| DECA | Decrement A | $(\mathrm{A})-\$ 01 \Rightarrow \mathrm{~A}$ |
| DECB | Decrement B | $(\mathrm{B})-\$ 01 \Rightarrow \mathrm{~B}$ |
| DES | Decrement SP | $(\mathrm{SP})-\$ 0001 \Rightarrow \mathrm{SP}$ |
| DEX | Decrement $X$ | $(\mathrm{X})-\$ 0001 \Rightarrow \mathrm{X}$ |
| DEY | Decrement $Y$ | $(\mathrm{Y})-\$ 0001 \Rightarrow \mathrm{Y}$ |
| Increment Instructions |  |  |
| Mnemonic | Function | $(\mathrm{M})+\$ 01 \Rightarrow \mathrm{M}$ |
| INC | Increment Memory | $(\mathrm{A})+\$ 01 \Rightarrow \mathrm{~A}$ |
| INCA | Increment A | $(\mathrm{B})+\$ 01 \Rightarrow \mathrm{~B}$ |
| INCB | Increment B | $(\mathrm{SP})+\$ 0001 \Rightarrow \mathrm{SP}$ |
| INS | Increment SP | $(\mathrm{X})+\$ 0001 \Rightarrow \mathrm{X}$ |
| INX | Increment $X$ | $(\mathrm{Y})+\$ 0001 \Rightarrow \mathrm{Y}$ |
| INY | Increment $Y$ |  |

### 5.8 Compare and Test Instructions

Compare and test instructions perform subtraction between a pair of registers or between a register and memory. The result is not stored, but condition codes are set by the operation. These instructions are generally used to establish conditions for branch instructions. In this architecture, most instructions update condition code bits automatically, so it is often unnecessary to include separate test or compare instructions. Table 5-7 is a summary of compare and test instructions.

Table 5-7 Compare and Test Instructions

| Compare Instructions |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Mnemonic | Function | Operation |  |  |
| CBA | Compare A to B | $(A)-(B)$ |  |  |
| CMPA | Compare A to Memory | $(A)-(M)$ |  |  |
| CMPB | Compare B to Memory | $(B)-(M)$ |  |  |
| CPD | Compare D to Memory (16-bit) | $(A: B)-(M: M+1)$ |  |  |
| CPS | Compare SP to Memory (16-bit) | $(S P)-(M: M+1)$ |  |  |
| CPX | Compare X to Memory (16-bit) | $(X)-(M: M+1)$ |  |  |
| CPY | Compare Y to Memory (16-bit) | $(Y)-(M: M+1)$ |  |  |
| Mnemonic | Test Instructions |  |  | Operation |
| TST | Function | $(M)-\$ 00$ |  |  |
| TSTA | Test Memory for Zero or Minus | $(A)-\$ 00$ |  |  |
| TSTB | Test A for Zero or Minus | $(B)-\$ 00$ |  |  |

### 5.9 Boolean Logic Instructions

These instructions perform a logic operation between an 8-bit accumulator or the CCR and a memory value. AND, OR, and exclusive OR functions are supported. Table 58 summarizes logic instructions.

Table 5-8 Boolean Logic Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| ANDA | AND A with Memory | $(A) \bullet(M) \Rightarrow A$ |
| ANDB | AND B with Memory | $(B) \bullet(M) \Rightarrow B$ |
| ANDCC | AND CCR with Memory (Clear CCR Bits) | $(C C R) \bullet(M) \Rightarrow C C R$ |
| EORA | Exclusive OR A with Memory | $(A) \oplus(M) \Rightarrow A$ |
| EORB | Exclusive OR B with Memory | $(B) \oplus(M) \Rightarrow B$ |
| ORAA | OR A with Memory | $(A)+(M) \Rightarrow A$ |
| ORAB | OR B with Memory | $(B)+(M) \Rightarrow B$ |
| ORCC | OR CCR with Memory (Set CCR Bits) | $(C C R)+(M) \Rightarrow C C R$ |

### 5.10 Clear, Complement, and Negate Instructions

Each of these instructions performs a specific binary operation on a value in an accumulator or in memory. Clear operations clear the value to zero, complement operations replace the value with its one's complement, and negate operations replace the value with its two's complement. Table 5-9 is a summary of clear, complement and negate instructions.

Table 5-9 Clear, Complement, and Negate Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| CLC | Clear C Bit in CCR | $0 \Rightarrow C$ |
| CLI | Clear I Bit in CCR | $0 \Rightarrow I$ |
| CLR | Clear Memory | $\$ 00 \Rightarrow M$ |
| CLRA | Clear A | $\$ 00 \Rightarrow A$ |
| CLRB | Clear B | $\$ 00 \Rightarrow B$ |
| CLV | Clear V bit in CCR | $0 \Rightarrow V$ |
| COM | One's Complement Memory | $\$ F F-(M) \Rightarrow M$ or $(\bar{M}) \Rightarrow M$ |
| COMA | One's Complement $A$ | $\$ F F-(A) \Rightarrow A$ or $(\bar{A}) \Rightarrow A$ |
| COMB | One's Complement $B$ | $\$ F F-(B) \Rightarrow B$ or $(\bar{B}) \Rightarrow B$ |
| NEG | Two's Complement Memory | $\$ 00-(M) \Rightarrow M$ or $(\bar{M})+1 \Rightarrow M$ |
| NEGA | Two's Complement $A$ | $\$ 00-(A) \Rightarrow A$ or $(\bar{A})+1 \Rightarrow A$ |
| NEGB | Two's Complement $B$ | $\$ 00-(B) \Rightarrow B$ or $(\bar{B})+1 \Rightarrow B$ |

### 5.11 Multiplication and Division Instructions

There are instructions for signed and unsigned 8- and 16-bit multiplication. Eight-bit multiplication operations have a 16-bit product. Sixteen-bit multiplication operations have 32-bit products.

Integer and fractional division instructions have 16-bit dividend, divisor, quotient, and remainder. Extended division instructions use a 32-bit dividend and a 16-bit divisor to produce a 16-bit quotient and a 16-bit remainder.

Table 5-10 is a summary of multiplication and division instructions.

Table 5-10 Multiplication and Division Instructions

| Multiplication Instructions |  |  |
| :---: | :---: | :---: |
| Mnemonic | Function | Operation |
| EMUL | 16 by 16 Multiply (Unsigned) | (D) $\times(\mathrm{Y}) \Rightarrow \mathrm{Y}: \mathrm{D}$ |
| EMULS | 16 by 16 Multiply (Signed) | $(\mathrm{D}) \times(\mathrm{Y}) \Rightarrow \mathrm{Y}: \mathrm{D}$ |
| MUL | 8 by 8 Multiply (Unsigned) | $(\mathrm{A}) \times(\mathrm{B}) \Rightarrow \mathrm{A}: \mathrm{B}$ |
| Division Instructions |  |  |
| Mnemonic | Function | Operation |
| EDIV | 32 by 16 Divide (Unsigned) | $\begin{gathered} \hline(\mathrm{Y}: \mathrm{D}) \div(\mathrm{X}) \\ \text { Quotient } \Rightarrow \mathrm{Y} \\ \text { Remainder } \Rightarrow \mathrm{D} \\ \hline \end{gathered}$ |
| EDIVS | 32 by 16 Divide (Signed) | $\begin{gathered} (\mathrm{Y}: \mathrm{D}) \div(\mathrm{X}) \\ \text { Quotient } \Rightarrow \mathrm{Y} \\ \text { Remainder } \Rightarrow \mathrm{D} \\ \hline \end{gathered}$ |
| FDIV | 16 by 16 Fractional Divide | $\begin{gathered} (D) \div(X) \Rightarrow X \\ \text { remainder } \Rightarrow D \end{gathered}$ |
| IDIV | 16 by 16 Integer Divide (Unsigned) | $\begin{gathered} (D) \div(X) \Rightarrow X \\ \text { remainder } \Rightarrow D \end{gathered}$ |
| IDIVS | 16 by 16 Integer Divide (Signed) | $\begin{gathered} (D) \div(X) \Rightarrow X \\ \text { remainder } \Rightarrow D \end{gathered}$ |

### 5.12 Bit Test and Manipulation Instructions

These operations use a mask value to test or change the value of individual bits in an accumulator or in memory. BITA and BITB provide a convenient means of testing bits without altering the value of either operand. Table 5-11 is a summary of bit test and manipulation instructions.

Table 5-11 Bit Test and Manipulation Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| BCLR | Clear Bits in Memory | $(M) \bullet(\overline{\mathrm{mm}}) \Rightarrow \mathrm{M}$ |
| BITA | Bit Test A | $(\mathrm{A}) \bullet(\mathrm{M})$ |
| BITB | Bit Test B | $(\mathrm{B}) \bullet(\mathrm{M})$ |
| BSET | Set Bits in Memory | $(\mathrm{M})+(\mathrm{mm}) \Rightarrow M$ |

### 5.13 Shift and Rotate Instructions

There are shifts and rotates for all accumulators and for memory bytes. All pass the shifted-out bit through the C status bit to facilitate multiple-byte operations. Because logical and arithmetic left shifts are identical, there are no separate logical left shift operations. LSL mnemonics are assembled as ASL operations. Table 5-12 shows shift and rotate instructions.

Table 5-12 Shift and Rotate Instructions

| Logical Shifts |  |  |
| :---: | :---: | :---: |
| Mnemonic | Function | Operation |
| $\begin{aligned} & \text { LSL } \\ & \text { LSLA } \\ & \text { LSLB } \end{aligned}$ | Logic Shift Left Memory Logic Shift Left A Logic Shift Left B |  |
| LSLD | Logic Shift Left D |  |
| $\begin{aligned} & \text { LSR } \\ & \text { LSRA } \\ & \text { LSRB } \end{aligned}$ | Logic Shift Right Memory Logic Shift Right A Logic Shift Right B |  |
| LSRD | Logic Shift Right D |  |
| Arithmetic Shifts |  |  |
| Mnemonic | Function | Operation |
| ASL ASLA ASLB | Arithmetic Shift Left Memory Arithmetic Shift Left A Arithmetic Shift Left B |  |
| ASLD | Arithmetic Shift Left D |  |
| ASR ASRA ASRB | Arithmetic Shift Right Memory Arithmetic Shift Right A Arithmetic Shift Right B |  |
| Rotates |  |  |
| Mnemonic | Function | Operation |
| ROL ROLA ROLB | Rotate Left Memory Through Carry Rotate Left A Through Carry Rotate Left B Through Carry |  |
| ROR RORA RORB | Rotate Right Memory Through Carry Rotate Right A Through Carry Rotate Right B Through Carry |  |

### 5.14 Fuzzy Logic Instructions

The CPU12 instruction set includes instructions that support efficient processing of fuzzy logic operations. The descriptions of fuzzy logic instructions that follow are functional overviews. Table 5-13 summarizes the fuzzy logic instructions. Refer to SECTION 9 FUZZY LOGIC SUPPORT for detailed discussion.

### 5.14.1 Fuzzy Logic Membership Instruction

The MEM instruction is used during the fuzzification process. During fuzzification, current system input values are compared against stored input membership functions to determine the degree to which each label of each system input is true. This is accomplished by finding the $y$ value for the current input on a trapezoidal membership function for each label of each system input. The MEM instruction performs this calculation for one label of one system input. To perform the complete fuzzification task for a system, several MEM instructions must be executed, usually in a program loop structure.

### 5.14.2 Fuzzy Logic Rule Evaluation Instructions

The REV and REVW instructions perform MIN-MAX rule evaluations that are central elements of a fuzzy logic inference program. Fuzzy input values are processed using a list of rules from the knowledge base to produce a list of fuzzy outputs. The REV instruction treats all rules as equally important. The REVW instruction allows each rule to have a separate weighting factor. The two rule evaluation instructions also differ in the way rules are encoded into the knowledge base. Because they require a number of cycles to execute, rule evaluation instructions can be interrupted. Once the interrupt has been serviced, instruction execution resumes at the point the interrupt occurred.

### 5.14.3 Fuzzy Logic Averaging Instruction

The WAV instruction provides a facility for weighted average calculations. In order to be usable, the fuzzy outputs produced by rule evaluation must be defuzzified to produce a single output value which represents the combined effect of all of the fuzzy outputs. Fuzzy outputs correspond to the labels of a system output and each is defined by a membership function in the knowledge base. The CPU12 typically uses singletons for output membership functions rather than the trapezoidal shapes used for inputs. As with inputs, the x-axis represents the range of possible values for a system output. Singleton membership functions consist of the x-axis position for a label of the system output. Fuzzy outputs correspond to the y-axis height of the corresponding output membership function. The WAV instruction calculates the numerator and denominator sums for a weighted average of the fuzzy outputs. Because WAV requires a number of cycles to execute, it can be interrupted. The wavr pseudo-instruction causes execution to resume at the point it was interrupted.

Table 5-13 Fuzzy Logic Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| MEM | Membership Function | $\begin{gathered} \mu(\text { grade }) \Rightarrow \mathrm{M}_{(\mathrm{Y})} \\ (\mathrm{X})+4 \Rightarrow \mathrm{X} ;(\mathrm{Y})+1 \Rightarrow \mathrm{Y} ; \mathrm{A} \text { unchanged } \\ \text { if }(\mathrm{A})<\mathrm{P} 1 \text { or }(\mathrm{A})>\mathrm{P} 2, \text { then } \mu=0, \text { else } \\ \mu=\mathrm{MIN}[((\mathrm{~A})-\mathrm{P} 1) \times \mathrm{S} 1,(\mathrm{P} 2-(\mathrm{A})) \times \mathrm{S} 2, \$ F F] \end{gathered}$ <br> where: <br> A = current crisp input value <br> $X$ points to a four byte data structure that describes a trapezoidal membership function as base intercept points and slopes (P1, P2, S1, S2) <br> $Y$ points at fuzzy input (RAM location) <br> See instruction details for special cases |
| REV | MIN-MAX Rule Evaluation | Find smallest rule input (MIN) <br> Store to rule outputs unless fuzzy output is larger (MAX) <br> Rules are unweighted <br> Each rule input is an 8-bit offset from a base address in $Y$ Each rule output is an 8-bit offset from a base address in Y \$FE separates rule inputs from rule outputs \$FF terminates the rule list <br> REV can be interrupted |
| REVW | MIN-MAX Rule Evaluation | Find smallest rule input (MIN) <br> Multiply by a rule weighting factor (optional) <br> Store to rule outputs unless fuzzy output is larger (MAX) <br> Each rule input is the 16-bit address of a fuzzy input Each rule output is the 16-bit address of a fuzzy output Address \$FFFE separates rule inputs from rule outputs \$FFFF terminates the rule list Weights are 8-bit values in a separate table <br> REVW can be interrupted |
| WAV | Calculates Numerator (Sum of Products) and Denominator (Sum of Weights) for Weighted Average Calculation <br> Results Are Placed in Correct Registers For EDIV immediately After WAV | $\begin{aligned} & \sum_{i=1}^{B} S_{i} F_{i} \Rightarrow Y: D \\ & \sum_{i=1}^{B} F_{i} \Rightarrow X \end{aligned}$ |
| wavr | Resumes Execution of Interrupted WAV Instruction | Recover immediate results from stack rather than initializing them to zero. |

### 5.15 Maximum and Minimum Instructions

These instructions are used to make comparisons between an accumulator and a memory location. These instructions can be used for linear programming operations, such as Simplex-method optimization or for fuzzification.

MAX and MIN instructions use accumulator A to perform 8-bit comparisons, while EMAX and EMIN instructions use accumulator D to perform 16-bit comparisons. The result (maximum or minimum value) can be stored in the accumulator (EMAXD, EMIND, MAXA, MINA) or the memory address (EMAXM, EMINM, MAXM, MINM).

Table 5-14 is a summary of minimum and maximum instructions.

Table 5-14 Minimum and Maximum Instructions

| Minimum Instructions |  |  |
| :---: | :---: | :---: |
| Mnemonic | Function | Operation |
| EMIND | MIN of Two Unsigned 16-Bit Values Result to Accumulator | $\operatorname{MIN}((\mathrm{D}),(\mathrm{M}: M+1)) \Rightarrow \mathrm{D}$ |
| EMINM | MIN of Two Unsigned 16-Bit Values Result to Memory | $\mathrm{MIN}((\mathrm{D}),(\mathrm{M}: \mathrm{M}+1)) \Rightarrow \mathrm{M}: \mathrm{M}+1$ |
| MINA | MIN of Two Unsigned 8-Bit Values <br> Result to Accumulator | $\mathrm{MIN}((\mathrm{A}),(\mathrm{M})) \Rightarrow \mathrm{A}$ |
| MINM | MIN of Two Unsigned 8-Bit Values Result to Memory | $\mathrm{MIN}((\mathrm{A}),(\mathrm{M})) \Rightarrow \mathrm{M}$ |
| Maximum Instructions |  |  |
| Mnemonic | Function | Operation |
| EMAXD | MAX of Two Unsigned 16-Bit Values Result to Accumulator | MAX ((D), $(\mathrm{M}: \mathrm{M}+1)) \Rightarrow \mathrm{D}$ |
| EMAXM | MAX of Two Unsigned 16-Bit Values Result to Memory | $\operatorname{MAX}((\mathrm{D}),(\mathrm{M}: \mathrm{M}+1)) \Rightarrow \mathrm{M}: \mathrm{M}+1$ |
| MAXA | MAX of Two Unsigned 8-Bit Values <br> Result to Accumulator | $\operatorname{MAX}((\mathrm{A}),(\mathrm{M})) \Rightarrow \mathrm{A}$ |
| MAXM | MAX of Two Unsigned 8-Bit Values Result to Memory | $\operatorname{MAX}((\mathrm{A}),(\mathrm{M})) \Rightarrow \mathrm{M}$ |

### 5.16 Multiply and Accumulate Instruction

The EMACS instruction multiplies two 16-bit operands stored in memory and accumulates the 32-bit result in a third memory location. EMACS can be used to implement simple digital filters and defuzzification routines that use 16-bit operands. The WAV instruction incorporates an 8- to 16-bit multiply and accumulate operation that obtains a numerator for the weighted average calculation. The EMACS instruction can automate this portion of the averaging operation when 16-bit operands are used. Table 515 shows the EMACS instruction.

Table 5-15 Multiply and Accumulate Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| EMACS | Multiply and Accumulate (Signed) <br> $16 \times 16$ Bit $\Rightarrow 32$ Bit | $\left(\left(\mathrm{M}_{(X)}: \mathrm{M}_{(\mathrm{X}+1)}\right) \times\left(\mathrm{M}_{(Y)}: \mathrm{M}_{(Y+1)}\right)\right)+(\mathrm{M} \sim \mathrm{M}+3) \Rightarrow \mathrm{M} \sim \mathrm{M}+3$ |

### 5.17 Table Interpolation Instructions

The TBL and ETBL instructions interpolate values from tables stored in memory. Any function that can be represented as a series of linear equations can be represented by a table of appropriate size. Interpolation can be used for many purposes, including tabular fuzzy logic membership functions. TBL uses 8 -bit table entries and returns an 8 bit result; ETBL uses 16 -bit table entries and returns a 16 -bit result. Use of indexed addressing mode provides great flexibility in structuring tables.

Consider each of the successive values stored in a table to be $y$-values for the endpoint of a line segment. The value in the $B$ accumulator before instruction execution begins represents change in $x$ from the beginning of the line segment to the lookup point divided by total change in $x$ from the beginning to the end of the line segment. B is treated as an 8-bit binary fraction with radix point left of the MSB, so each line segment is effectively divided into 256 smaller segments. During instruction execution, the change in y between the beginning and end of the segment (a signed byte for TBL or a signed word for ETBL) is multiplied by the content of the B accumulator to obtain an intermediate delta-y term. The result (stored in the A accumulator by TBL, and in the D accumulator by ETBL) is the $y$-value of the beginning point plus the signed intermediate delta-y value. Table $5-16$ shows the table interpolation instructions.

Table 5-16 Table Interpolation Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| ETBL | 16-Bit Table Lookup and Interpolate <br> (no indirect addressing modes allowed) | $(M: M+1)+[(B) \times((M+2: M+3)-(M: M+1))] \Rightarrow D$ <br> Initialize $B$, and index before $E T B L$. <br> <ea> points to the first table entry $(M: M+1)$ <br> $B$ is fractional part of lookup value |
|  | 8-Bit Table Lookup and Interpolate <br> (no indirect addressing modes allowed.) | $(M)+[(B) \times((M+1)-(M))] \Rightarrow A$ <br> $\quad$Initialize $B$, and index before TBL. <br> <ea> points to the first 8-bit table entry (M) <br> $B$ is fractional part of lookup value. |

### 5.18 Branch Instructions

Branch instructions cause sequence to change when specific conditions exist. The CPU12 uses three kinds of branch instructions. These are short branches, long branches, and bit-conditional branches.

Branch instructions can also be classified by the type of condition that must be satisfied in order for a branch to be taken. Some instructions belong to more than one classification.

Unary branch instructions always execute.
Simple branches are taken when a specific bit in the condition code register is in a specific state as a result of a previous operation.

Unsigned branches are taken when comparison or test of unsigned quantities results in a specific combination of condition code register bits.

Signed branches are taken when comparison or test of signed quantities results in a specific combination of condition code register bits.

### 5.18.1 Short Branch Instructions

Short branch instructions operate as follows. When a specified condition is met, a signed 8 -bit offset is added to the value in the program counter. Program execution continues at the new address.

The numeric range of short branch offset values is $\$ 80(-128)$ to $\$ 7 \mathrm{~F}(127)$ from the address of the next memory location after the offset value.

Table 5-17 is a summary of the short branch instructions.

### 5.18.2 Long Branch Instructions

Long branch instructions operate as follows. When a specified condition is met, a signed 16-bit offset is added to the value in the program counter. Program execution continues at the new address. Long branches are used when large displacements between decision-making steps are necessary.

The numeric range of long branch offset values is $\$ 8000(-32,768)$ to $\$ 7 F F F(32,767)$ from the address of the next memory location after the offset value. This permits branching from any location in the standard 64-Kbyte address map to any other location in the map.

Table 5-18 is a summary of the long branch instructions.

Table 5-17 Short Branch Instructions

| Unary Branches |  |  |  |
| :---: | :---: | :---: | :---: |
| Mnemonic | Function |  | Equation or Operation |
| BRA | Branch Always |  | 1 = 1 |
| BRN | Branch Never |  | $1=0$ |
| Simple Branches |  |  |  |
| Mnemonic | Function |  | Equation or Operation |
| BCC | Branch if Carry Clear |  | $\mathrm{C}=0$ |
| BCS | Branch if Carry Set |  | $\mathrm{C}=1$ |
| BEQ | Branch if Equal |  | $\mathrm{Z}=1$ |
| BMI | Branch if Minus |  | $\mathrm{N}=1$ |
| BNE | Branch if Not Equal |  | $\mathrm{Z}=0$ |
| BPL | Branch if Plus |  | $\mathrm{N}=0$ |
| BVC | Branch if Overflow Clear |  | $\mathrm{V}=0$ |
| BVS | Branch if Overflow Set |  | $\mathrm{V}=1$ |
| Unsigned Branches |  |  |  |
| Mnemonic | Function | Relation | Equation or Operation |
| BHI | Branch if Higher | $R>M$ | $\mathrm{C}+\mathrm{Z}=0$ |
| BHS | Branch if Higher or Same | $\mathrm{R} \geq \mathrm{M}$ | $\mathrm{C}=0$ |
| BLO | Branch if Lower | $R<M$ | $\mathrm{C}=1$ |
| BLS | Branch if Lower or Same | $R \leq M$ | $\mathrm{C}+\mathrm{Z}=1$ |
| Signed Branches |  |  |  |
| Mnemonic | Function | Relation | Equation or Operation |
| BGE | Branch if Greater Than or Equal | $R \geq M$ | $\mathrm{N} \oplus \mathrm{V}=0$ |
| BGT | Branch if Greater Than | $R>M$ | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ |
| BLE | Branch if Less Than or Equal | $R \leq M$ | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ |
| BLT | Branch if Less Than | $\mathrm{R}<\mathrm{M}$ | $\mathrm{N} \oplus \mathrm{V}=1$ |

Table 5-18 Long Branch Instructions

| Unary Branches |  |  |
| :---: | :---: | :---: |
| Mnemonic | Function | Equation or Operation |
| LBRA | Long Branch Always | 1 = 1 |
| LBRN | Long Branch Never | $1=0$ |
| Simple Branches |  |  |
| Mnemonic | Function | Equation or Operation |
| LBCC | Long Branch if Carry Clear | $\mathrm{C}=0$ |
| LBCS | Long Branch if Carry Set | $\mathrm{C}=1$ |
| LBEQ | Long Branch if Equal | $\mathrm{Z}=1$ |
| LBMI | Long Branch if Minus | $\mathrm{N}=1$ |
| LBNE | Long Branch if Not Equal | $\mathrm{Z}=0$ |
| LBPL | Long Branch if Plus | $\mathrm{N}=0$ |
| LBVC | Long Branch if Overflow Clear | $\mathrm{V}=0$ |
| LBVS | Long Branch if Overflow Set | $\mathrm{V}=1$ |
| Unsigned Branches |  |  |
| Mnemonic | Function | Equation or Operation |
| LBHI | Long Branch if Higher | $C+Z=0$ |
| LBHS | Long Branch if Higher or Same | C = 0 |
| LBLO | Long Branch if Lower | $\mathrm{Z}=1$ |
| LBLS | Long Branch if Lower or Same | $C+Z=1$ |
| Signed Branches |  |  |
| Mnemonic | Function | Equation or Operation |
| LBGE | Long Branch if Greater Than or Equal | $\mathrm{N} \oplus \mathrm{V}=0$ |
| LBGT | Long Branch if Greater Than | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ |
| LBLE | Long Branch if Less Than or Equal | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ |
| LBLT | Long Branch if Less Than | $\mathrm{N} \oplus \mathrm{V}=1$ |

### 5.18.3 Bit Condition Branch Instructions

These branches are taken when bits in a memory byte are in a specific state. A mask operand is used to test the location. If all bits in that location that correspond to ones in the mask are set (BRSET) or cleared (BRCLR), the branch is taken.

The numeric range of 8-bit offset values is $\$ 80(-128)$ to $\$ 7 \mathrm{~F}$ (127) from the address of the next memory location after the offset value. Table 5-19 is a summary of bit-condition branches.

Table 5-19 Bit Condition Branch Instructions

| Mnemonic | Function | Equation or Operation |
| :---: | :---: | :---: |
| BRCLR | Branch if Selected Bits Clear | $(\mathrm{M}) \bullet(\mathrm{mm})=0$ |
| BRSET | Branch if Selected Bits Set | $(\overline{\mathrm{M}}) \bullet(\mathrm{mm})=0$ |

### 5.19 Loop Primitive Instructions

The loop primitives can also be thought of as counter branches. The instructions test a counter value in a register or accumulator (A, B, D, X, Y, or SP) for zero or nonzero value as a branch condition. There are predecrement, preincrement and test-only versions of these instructions.

The numeric range of 8-bit offset values is $\$ 80(-128)$ to $\$ 7 \mathrm{~F}$ (127) from the address of the next memory location after the offset value. Table 5-20 is a summary of loop primitive branches.

Table 5-20 Loop Primitive Instructions

| Mnemonic | Function | Equation or Operation |
| :---: | :---: | :---: |
| DBEQ | Decrement counter and branch if $=0$ (counter = A, B, D, X, Y, or SP) | (counter) - $1 \Rightarrow$ counter <br> If (counter) $=0$, then branch else continue to next instruction |
| DBNE | Decrement counter and branch if $\neq 0$ (counter = A, B, D, X, Y, or SP) | (counter) - $1 \Rightarrow$ counter If (counter) not $=0$, then branch else continue to next instruction |
| IBEQ | Increment counter and branch if $=0$ (counter = A, B, D, X, Y, or SP) | (counter) $+1 \Rightarrow$ counter <br> If (counter) $=0$, then branch <br> else continue to next instruction |
| IBNE | Increment counter and branch if $\neq 0$ (counter = A, B, D, X, Y, or SP) | (counter) $+1 \Rightarrow$ counter <br> If (counter) not $=0$, then branch else continue to next instruction |
| TBEQ | Test counter and branch if $=0$ (counter = A, B, D, X, Y, or SP) | If (counter) $=0$, then branch else continue to next instruction |
| TBNE | Test counter and branch if $\neq 0$ (counter = A, B, D, X, Y, or SP) | If (counter) not $=0$, then branch else continue to next instruction |

### 5.20 Jump and Subroutine Instructions

Jump instructions cause immediate changes in sequence. The JMP instruction loads the PC with an address in the 64-Kbyte memory map, and program execution continues at that address. The address can be provided as an absolute 16-bit address or determined by various forms of indexed addressing.

Subroutine instructions optimize the process of transferring control to a code segment that performs a particular task. A short branch (BSR), a jump (JSR), or an expandedmemory call (CALL) can be used to initiate subroutines. There is no LBSR instruction, but a PC-relative JSR performs the same function. A return address is stacked, then execution begins at the subroutine address. Subroutines in the normal 64-Kbyte address space are terminated with an RTS instruction. RTS unstacks the return address so that execution resumes with the instruction after BSR or JSR.

The CALL instruction is intended for use with expanded memory. CALL stacks the value in the PPAGE register and the return address, then writes a new value to PPAGE to select the memory page where the subroutine resides. The page value is an immediate operand in all addressing modes except indexed indirect modes; in these modes, an operand points to locations in memory where the new page value and subroutine address are stored. The RTC instruction is used to terminate subroutines in expanded memory. RTC unstacks the PPAGE value and the return address so that execution resumes with the next instruction after CALL. For software compatibility, CALL and RTC execute correctly on devices that do not have expanded addressing capability. Table 5-21 summarizes the jump and subroutine instructions.

Table 5-21 Jump and Subroutine Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| BSR | Branch to Subroutine | $\begin{gathered} \mathrm{SP}-2 \Rightarrow \mathrm{SP} \\ \text { RTN }_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)} \\ \text { Subroutine address } \Rightarrow \mathrm{PC} \end{gathered}$ |
| CALL | Call Subroutine in Expanded Memory | $\begin{gathered} \mathrm{SP}-2 \Rightarrow \mathrm{SP} \\ \text { RTN }_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)} \\ \mathrm{SP}-1 \Rightarrow \mathrm{SP} \\ (\mathrm{PPAGE}) \Rightarrow \mathrm{M}_{(\mathrm{SP})} \\ \text { Page } \Rightarrow \text { PPAGE } \\ \text { Subroutine address } \Rightarrow \mathrm{PC} \end{gathered}$ |
| JMP | Jump | Subroutine Address $\Rightarrow P \mathrm{PC}$ |
| JSR | Jump to Subroutine | $\begin{gathered} S P-2 \Rightarrow S P \\ R_{H} N_{H}: R_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ \text { Subroutine address } \Rightarrow \mathrm{PC} \end{gathered}$ |
| RTC | Return from Call | $\begin{gathered} M_{(S P)}: M_{(S P+1)} \Rightarrow P C_{H}: P C_{L} \\ S P+2 \Rightarrow S P \end{gathered}$ |
| RTS | Return from Subroutine | $\begin{gathered} \mathrm{M}_{(\mathrm{SP})} \Rightarrow \mathrm{PPAGE} \\ \mathrm{SP}+1 \Rightarrow \mathrm{SP} \\ \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)} \Rightarrow \mathrm{PC}_{\mathrm{H}}: \mathrm{PC}_{\mathrm{L}} \\ \mathrm{SP}+2 \Rightarrow \mathrm{SP} \end{gathered}$ |

### 5.21 Interrupt Instructions

Interrupt instructions handle transfer of control to a routine that performs a critical task. Software interrupts are a type of exception. SECTION 7 EXCEPTION PROCESSING covers interrupt exception processing in detail.

The SWI instruction initiates synchronous exception processing. First, the return PC value is stacked. After CPU context is stacked, execution continues at the address pointed to by the SWI vector.

Execution of the SWI instruction causes an interrupt without an interrupt service request. SWI is not inhibited by global mask bits I and $X$ in the CCR, and execution of SWI sets the I mask bit. Once an SWI interrupt begins, maskable interrupts are inhibited until the I bit in the CCR is cleared. This typically occurs when an RTI instruction at the end of the SWI service routine restores context.

The CPU12 uses the software interrupt for unimplemented opcode trapping. There are opcodes in all 256 positions in the page 1 opcode map, but only 54 of the 256 positions on page 2 of the opcode map are used. If the CPU attempts to execute one of the unimplemented opcodes on page 2, an opcode trap interrupt occurs. Traps are essentially interrupts that share the \$FFF8:\$FFF9 interrupt vector.

The RTI instruction is used to terminate all exception handlers, including interrupt service routines. RTI first restores the CCR, B:A, X, Y, and the return address from the stack. If no other interrupt is pending, normal execution resumes with the instruction following the last instruction that executed prior to interrupt.

Table 5-22 is a summary of interrupt instructions.

Table 5-22 Interrupt Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| RTI | Return from Interrupt | $\left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow C C R ;(\mathrm{SP})+\$ 0001 \Rightarrow S P$ $\left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow B: A ;(\mathrm{SP})+\$ 0002 \Rightarrow \mathrm{SP}$ $\left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{X}_{\mathrm{H}}: \mathrm{X}_{\mathrm{L}} ;(\mathrm{SP})+\$ 0004 \Rightarrow \mathrm{SP}$ $\left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{PC}_{H}: \mathrm{PC}_{\mathrm{L}} ;(\mathrm{SP})+\$ 0002 \Rightarrow \mathrm{SP}$ $\left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{Y}_{H}: \mathrm{Y}_{\mathrm{L}} ;(\mathrm{SP})+\$ 0004 \Rightarrow \mathrm{SP}$ |
| SWI | Software Interrupt | $\begin{gathered} \hline S P-2 \Rightarrow S P ; R T N_{H}: R T N_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-2 \Rightarrow S P ; Y_{H}: Y_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-2 \Rightarrow S P ; X_{H}: X_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-2 \Rightarrow S P ; B: A \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-1 \Rightarrow S P ; C C R \Rightarrow M_{(S P)} \end{gathered}$ |
| TRAP | Software Interrupt | $\begin{gathered} \hline S P-2 \Rightarrow S P ; R T N_{H}: R T N_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-2 \Rightarrow S P ; Y_{H}: Y_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-2 \Rightarrow S P ; X_{H}: X_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-2 \Rightarrow S P ; B: A \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-1 \Rightarrow S P ; C C R \Rightarrow M_{(S P)} \end{gathered}$ |

### 5.22 Index Manipulation Instructions

These instructions perform 8- and 16-bit operations on the three index registers and accumulators, other registers, or memory, as shown in Table 5-23.

Table 5-23 Index Manipulation Instructions

| Addition Instructions |  |  |
| :---: | :---: | :---: |
| Mnemonic | Function | Operation |
| ABX | Add B to X | (B) $+(\mathrm{X}) \Rightarrow \mathrm{X}$ |
| ABY | Add B to Y | $(\mathrm{B})+(\mathrm{Y}) \Rightarrow \mathrm{Y}$ |
| Compare Instructions |  |  |
| Mnemonic | Function | Operation |
| CPS | Compare SP to Memory | (SP) - (M : M + 1) |
| CPX | Compare X to Memory | $(X)-(M: M+1)$ |
| CPY | Compare Y to Memory | $(Y)-(M: M+1)$ |
| Load Instructions |  |  |
| Mnemonic | Function | Operation |
| LDS | Load SP from Memory | $\mathrm{M}: \mathrm{M}+1 \Rightarrow \mathrm{SP}$ |
| LDX | Load X from Memory | $(\mathrm{M}: \mathrm{M}+1) \Rightarrow \mathrm{X}$ |
| LDY | Load Y from Memory | $(\mathrm{M}: \mathrm{M}+1) \Rightarrow \mathrm{Y}$ |
| LEAS | Load Effective Address into SP | Effective Address $\Rightarrow$ SP |
| LEAX | Load Effective Address into X | Effective Address $\Rightarrow \mathrm{X}$ |
| LEAY | Load Effective Address into Y | Effective Address $\Rightarrow \mathrm{Y}$ |
| Store Instructions |  |  |
| Mnemonic | Function | Operation |
| STS | Store SP in Memory | $(S P) \Rightarrow M: M+1$ |
| STX | Store X in Memory | $(X) \Rightarrow M: M+1$ |
| STY | Store Y in Memory | $(\mathrm{Y}) \Rightarrow \mathrm{M}: \mathrm{M}+1$ |
| Transfer Instructions |  |  |
| Mnemonic | Function | Operation |
| TFR | Transfer Register to Register | $(\mathrm{A}, \mathrm{B}, \mathrm{CCR}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP) $\Rightarrow \mathrm{A}, \mathrm{B}, \mathrm{CCR}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP |
| TSX | Transfer SP to X | $(\mathrm{SP}) \Rightarrow \mathrm{X}$ |
| TSY | Transfer SP to Y | $(\mathrm{SP}) \Rightarrow \mathrm{Y}$ |
| TXS | Transfer X to SP | $(\mathrm{X}) \Rightarrow \mathrm{SP}$ |
| TYS | Transfer Y to SP | $(\mathrm{Y}) \Rightarrow \mathrm{SP}$ |
| Exchange Instructions |  |  |
| Mnemonic | Function | Operation |
| EXG | Exchange Register to Register | (A, B, CCR, D, X, Y, or SP) $\Leftrightarrow(\mathrm{A}, \mathrm{B}, \mathrm{CCR}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP) |
| XGDX | EXchange D with X | $(\mathrm{D}) \Leftrightarrow(\mathrm{X})$ |
| XGDY | EXchange D with Y | (D) $\Leftrightarrow(\mathrm{Y})$ |

### 5.23 Stacking Instructions

There are two types of stacking instructions, as shown in Table 5-24. Stack pointer instructions use specialized forms of mathematical and data transfer instructions to perform stack pointer manipulation. Stack operation instructions save information on and retrieve information from the system stack.

Table 5-24 Stacking Instructions

| Stack Pointer Instructions |  |  |
| :---: | :---: | :---: |
| Mnemonic | Function | Operation |
| CPS | Compare SP to Memory | (SP) - (M : M + 1) |
| DES | Decrement SP | $(\mathrm{SP})-1 \Rightarrow \mathrm{SP}$ |
| INS | Increment SP | $(\mathrm{SP})+1 \Rightarrow \mathrm{SP}$ |
| LDS | Load SP | $(\mathrm{M}: \mathrm{M}+1) \Rightarrow \mathrm{SP}$ |
| LEAS | Load Effective Address into SP | Effective Address $\Rightarrow$ SP |
| STS | Store SP | $(S P) \Rightarrow M: M+1$ |
| TSX | Transfer SP to X | $(\mathrm{SP}) \Rightarrow \mathrm{X}$ |
| TSY | Transfer SP to Y | $(\mathrm{SP}) \Rightarrow \mathrm{Y}$ |
| TXS | Transfer X to SP | $(\mathrm{X}) \Rightarrow \mathrm{SP}$ |
| TYS | Transfer Y to SP | $(\mathrm{Y}) \Rightarrow \mathrm{SP}$ |
| Stack Operation Instructions |  |  |
| Mnemonic | Function | Operation |
| PSHA | Push A | $(\mathrm{SP})-1 \Rightarrow \mathrm{SP} ;(\mathrm{A}) \Rightarrow \mathrm{M}_{(S P)}$ |
| PSHB | Push B | $(S P)-1 \Rightarrow S P ;(B) \Rightarrow M_{(S P)}$ |
| PSHC | Push CCR | $(S P)-1 \Rightarrow S P ;(A) \Rightarrow M_{(S P)}$ |
| PSHD | Push D | $(S P)-2 \Rightarrow S P ;(A: B) \Rightarrow M_{(S P)}: M_{(S P+1)}$ |
| PSHX | Push X | $(S P)-2 \Rightarrow S P ;(X) \Rightarrow M_{(S P)}: M_{(S P+1)}$ |
| PSHY | Push Y | $(S P)-2 \Rightarrow S P ;(Y) \Rightarrow M_{(S P)}: M_{(S P+1)}$ |
| PULA | Pull A | $\left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow \mathrm{A} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP}$ |
| PULB | Pull B | $\left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow \mathrm{B} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP}$ |
| PULC | Pull CCR | $\left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow \mathrm{CCR} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP}$ |
| PULD | Pull D | $\left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{A}: \mathrm{B} ;(\mathrm{SP})+2 \Rightarrow \mathrm{SP}$ |
| PULX | Pull X | $\left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{X} ;(\mathrm{SP})+2 \Rightarrow \mathrm{SP}$ |
| PULY | Pull Y | $\left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{Y} ;(\mathrm{SP})+2 \Rightarrow \mathrm{SP}$ |

### 5.24 Pointer and Index Calculation Instructions

The load effective address instructions allow 5-, 8-, or 16-bit constants, or the contents of 8 -bit accumulators $A$ and $B$ or 16-bit accumulator $D$ to be added to the contents of the X and Y index registers, the SP, or the PC. Table 5-25 is a summary of pointer and index instructions.

Table 5-25 Pointer and Index Calculation Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| LEAS | Load Result of Indexed Addressing Mode <br> Effective Address Calculation <br> into Stack Pointer | $\mathrm{r} \pm$ Constant $\Rightarrow \mathrm{SP}$ or |
|  | LEAX | Load Result of Indexed Addressing Mode <br> Effective Address Calculation <br> into X Index Register |
|  | $\mathrm{r}=\mathrm{X}, \mathrm{Y}, \mathrm{SP}, \mathrm{or} \mathrm{PC}$ |  |

### 5.25 Condition Code Instructions

Condition code instructions are special forms of mathematical and data transfer instructions that can be used to change the condition code register. Table 5-26 shows instructions that can be used to manipulate the CCR.

Table 5-26 Condition Codes Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| ANDCC | Logical AND CCR with Memory | $(\mathrm{CCR}) \bullet(\mathrm{M}) \Rightarrow \mathrm{CCR}$ |
| CLC | Clear C Bit | $0 \Rightarrow C$ |
| CLI | Clear I Bit | $0 \Rightarrow 1$ |
| CLV | Clear V Bit | $0 \Rightarrow \mathrm{~V}$ |
| ORCC | Logical OR CCR with Memory | $(\mathrm{CCR})+(\mathrm{M}) \Rightarrow \mathrm{CCR}$ |
| PSHC | Push CCR onto Stack | $(S P)-1 \Rightarrow S P ;(C C R) \Rightarrow M_{(S P)}$ |
| PULC | Pull CCR from Stack | $\left(\mathrm{M}_{(\text {SP) }}\right) \Rightarrow \mathrm{CCR} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP}$ |
| SEC | Set C Bit | $1 \Rightarrow C$ |
| SEI | Set I Bit | $1 \Rightarrow 1$ |
| SEV | Set V Bit | $1 \Rightarrow \mathrm{~V}$ |
| TAP | Transfer A to CCR | $(\mathrm{A}) \Rightarrow \mathrm{CCR}$ |
| TPA | Transfer CCR to A | (CCR) $\Rightarrow$ A |

### 5.26 Stop and Wait Instructions

As shown in Table 5-27, there are two instructions that put the CPU12 in an inactive state that reduces power consumption.

The stop instruction (STOP) stacks a return address and the contents of CPU registers and accumulators, then halts all system clocks.

The wait instruction (WAI) stacks a return address and the contents of CPU registers and accumulators, then waits for an interrupt service request; however, system clock signals continue to run.

Both STOP and WAI require that either an interrupt or a reset exception occur before normal execution of instructions resumes. Although both instructions require the same number of clock cycles to resume normal program execution after an interrupt service request is made, restarting after a STOP requires extra time for the oscillator to reach operating speed.

Table 5-27 Stop and Wait Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| STOP | Stop | $\begin{gathered} \text { SP }-2 \Rightarrow S P ; R T N_{H}: R T N_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-2 \Rightarrow S P ; Y_{H}: Y_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-2 \Rightarrow S P ; X_{H}: X_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-2 \Rightarrow S P ; B: A \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-1 \Rightarrow S P ; C C R \Rightarrow M_{(S P)} \\ \text { STOP CPU Clocks } \end{gathered}$ |
| WAI | Wait for Interrupt | $\begin{gathered} S P-2 \Rightarrow S P ; R T N_{H}: R T N_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-2 \Rightarrow S P ; Y_{H}: Y_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-2 \Rightarrow S P ; X_{H}: X_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-2 \Rightarrow S P ; B: A \Rightarrow M_{(S P)}: M_{(S P+1)} \\ S P-1 \Rightarrow S P ; C C R \Rightarrow M_{(S P)} \end{gathered}$ |

### 5.27 Background Mode and Null Operations

Background debug mode is a special CPU12 operating mode that is used for system development and debugging. Executing BGND when BDM is enabled puts the CPU12 in this mode. For complete information refer to SECTION 8 DEVELOPMENT AND DEBUG SUPPORT.

Null operations are often used to replace other instructions during software debugging. Replacing conditional branch instructions with BRN, for instance, permits testing a de-cision-making routine without actually taking the branches.

Table 5-28 shows the BGND and NOP instructions.

Table 5-28 Background Mode and Null Operation Instructions

| Mnemonic | Function | Operation |
| :---: | :---: | :---: |
| BGND | Enter Background Debug Mode | If BDM enabled, enter BDM; <br> else, resume normal processing |
| BRN | Branch Never | Does not branch |
| LBRN | Long Branch Never | Does not branch |
| NOP | Null operation | - |

## SECTION 6 <br> INSTRUCTION GLOSSARY

This section is a comprehensive reference to the CPU12 instruction set.

### 6.1 Glossary Information

The glossary contains an entry for each assembler mnemonic, in alphabetic order. Figure 6-1 is a representation of a glossary page.


Figure 6-1 Example Glossary Page

Each entry contains symbolic and textual descriptions of operation, information concerning the effect of operation on status bits in the condition code register, and a table that describes assembler syntax, cycle count, and cycle-by-cycle execution of the instruction.

### 6.2 Condition Code Changes

The following special characters are used to describe the effects of instruction execution on the status bits in the condition codes register.

-     - Status bit not affected by operation.

0 - Status bit cleared by operation.
1 - Status bit set by operation.
$\Delta$ - Status bit affected by operation.
$\Downarrow$ - Status bit may be cleared or remain set, but is not set by operation.
$\Uparrow$ - Status bit may be set or remain cleared, but is not cleared by operation.
? - Status bit may be changed by operation but the final state is not defined.
! - Status bit used for a special purpose.

### 6.3 Object Code Notation

The digits 0 to 9 and the upper case letters $A$ to $F$ are used to express hexadecimal values. Pairs of lower case letters represent the 8-bit values as described below.
dd - 8-bit direct address $\$ 0000$ to $\$ 00 F F$. (High byte assumed to be $\$ 00$ ).
ee - High-order byte of a 16-bit constant offset for indexed addressing.
eb - Exchange/Transfer post-byte.
ff — Low-order eight bits of a 9-bit signed constant offset for indexed addressing, or low-order byte of a 16-bit constant offset for indexed addressing.
hh — High-order byte of a 16-bit extended address.
ii - 8-bit immediate data value.
jj — High-order byte of a 16-bit immediate data value.
kk - Low-order byte of a 16-bit immediate data value.
lb - Loop primitive (DBNE) post-byte.
II - Low-order byte of a 16-bit extended address.
mm - 8-bit immediate mask value for bit manipulation instructions. Set bits indicate bits to be affected.
pg — Program overlay page (bank) number used in CALL instruction.
qq - High-order byte of a 16-bit relative offset for long branches.
tn — Trap number \$30-\$39 or \$40-\$FF.
rr - Signed relative offset \$80 (-128) to \$7F (+127).
Offset relative to the byte following the relative offset byte, or low-order byte of a 16-bit relative offset for long branches.
xb - Indexed addressing post-byte.

### 6.4 Source Forms

The glossary pages provide only essential information about assembler source forms. Assemblers generally support a number of assembler directives, allow definition of program labels, and have special conventions for comments. For complete information about writing source files for a particular assembler, refer to the documentation provided by the assembler vendor.

Assemblers are typically very flexible about the use of spaces and tabs. Often, any number of spaces or tabs can be used where a single space is shown on the glossary pages. Spaces and tabs are also normally allowed before and after commas. When program labels are used, there must also be at least one tab or space before all instruction mnemonics. This required space is not apparent in the source forms.

Everything in the source forms columns, except expressions in italic characters, is literal information which must appear in the assembly source file exactly as shown. The initial 3 - to 5 -letter mnemonic is always a literal expression. All commas, pound signs (\#), parentheses, square brackets ( [ or ] ), plus signs (+), minus signs (-), and the register designation $D$ (as in [D,... ), are literal characters.

Groups of italic characters in the columns represent variable information to be supplied by the programmer. These groups can include any alphanumeric character or the underscore character, but cannot include a space or comma. For example, the groups xysp and oprx0_xysp are both valid, but the two groups oprx0 xysp are not valid because there is a space between them. Permitted syntax is described below.

The definition of a legal label or expression varies from assembler to assembler. Assemblers also vary in the way CPU registers are specified. Refer to assembler documentation for detailed information. Recommended register designators are $a, A, b, B$, ccr, CCR, d, D, x, X, y, Y, sp, SP, pc, and PC.

[^0]opr16a - Any label or expression that evaluates to a 16-bit value. The instruction treats this value as an address in the 64-Kbyte address space.
oprx0_xysp - This word breaks down into one of the following alternative forms that assemble to an 8 -bit indexed addressing postbyte code. These forms generate the same object code except for the value of the postbyte code, which is designated as xb in the object code columns of the glossary pages. As with the source forms, treat all commas, plus signs, and minus signs as literal syntax elements. The italicized words used in these forms are included in this key.
oprx5,xysp
oprx3,-xys
oprx3,+xys
oprx3,xys-
oprx3,xys+
abd,xysp
oprx3 - Any label or expression that evaluates to a value in the range +1 to +8 .
oprx5 - Any label or expression that evaluates to a 5 -bit value in the range -16 to +15 .
oprx9 - Any label or expression that evaluates to a 9-bit value in the range -256 to +255 .
oprx16 - Any label or expression that evaluates to a 16 -bit value. Since the CPU12 has a 16 -bit address bus, this can be either a signed or an unsigned value.
page - Any label or expression that evaluates to an 8-bit value. The CPU12 recognizes up to an 8 -bit page value for memory expansion but not all MCUs that include the CPU12 implement all of these bits. It is the programmer's responsibility to limit the page value to legal values for the intended MCU system. Some assemblers require a \# symbol before this value.
rel8 - Any label or expression that refers to an address that is within -256 to +255 locations from the next address after the last byte of object code for the current instruction. The assembler will calculate the 8 -bit signed offset and include it in the object code for this instruction.
rel9 - Any label or expression that refers to an address that is within -512 to +511 locations from the next address after the last byte of object code for the current instruction. The assembler will calculate the 9-bit signed offset and include it in the object code for this instruction. The sign bit for this 9 -bit value is encoded by the assembler as a bit in the looping postbyte (Ib) of one of the loop control instructions DBEQ, DBNE, IBEQ, IBNE, TBEQ, or TBNE. The remaining eight bits of the offset are included as an extra byte of object code.
rel16 - Any label or expression that refers to an address anywhere in the 64-Kbyte address space. The assembler will calculate the 16 -bit signed offset between this address and the next address after the last byte of object code for this instruction, and include it in the object code for this instruction.
trapnum - Any label or expression that evaluates to an 8-bit number in the range \$30-\$39 or \$40-\$FF. Used for TRAP instruction.
xys - Any one legal register designation for index registers X or Y or the SP.
xysp - Any one legal register designation for index registers X or Y , the SP, or the PC. The reference point for PC relative instructions is the next address after the last byte of object code for the current instruction.

### 6.5 Cycle-by-Cycle Execution

This information is found in the tables at the bottom of each instruction glossary page. Entries show how many bytes of information are accessed from different areas of memory during the course of instruction execution. With this information and knowledge of the type and speed of memory in the system, a user can determine the execution time for any instruction in any system.

A single letter code in the column represents a single CPU cycle. Upper case letters indicate 16-bit access cycles. There are cycle codes for each addressing mode variation of each instruction. Simply count code letters to determine the execution time of an instruction in a best-case system. An example of a best-case system is a singlechip 16-bit system with no 16-bit off-boundary data accesses to any locations other than on-chip RAM.

Many conditions can cause one or more instruction cycles to be stretched, but the CPU is not aware of the stretch delays because the clock to the CPU is temporarily stopped during these delays.

The following paragraphs explain the cycle code letters used and note conditions that can cause each type of cycle to be stretched.
f - Free cycle. This indicates a cycle where the CPU does not require use of the system buses. An f cycle is always one cycle of the system bus clock. These cycles can be used by a queue controller or the background debug system to perform single cycle accesses without disturbing the CPU.
g - Read 8-bit PPAGE register. These cycles are only used with the CALL instruction to read the current value of the PPAGE register, and are not visible on the external bus. Since the PPAGE register is an internal 8-bit register, these cycles are never stretched.
I - Read indirect pointer. Indexed indirect instructions use this 16-bit pointer from memory to address the operand for the instruction. These are always 16 -bit reads but they can be either aligned or misaligned. These cycles are extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. These cycles are also stretched if they correspond to misaligned access to a memory that is not designed for single-cycle misaligned access.
i - Read indirect PPAGE value. These cycles are only used with indexed indirect versions of the CALL instruction, where the 8 -bit value for the memory expansion page register of the CALL destination is fetched from an indirect memory location. These cycles are stretched only when controlled by a chip-select circuit that is programmed for slow memory.
n - Write 8-bit PPAGE register. These cycles are only used with the CALL and RTC instructions to write the destination value of the PPAGE register and are not visible on the external bus. Since the PPAGE register is an internal 8-bit register, these cycles are never stretched.

O - Optional cycle. Program information is always fetched as aligned 16-bit words. When an instruction consists of an odd number of bytes, and the first byte is misaligned, an O cycle is used to make an additional program word access (P) cycle that maintains queue order. In all other cases, the O cycle appears as a free (f) cycle. The $\$ 18$ prebyte for page two opcodes is treated as a special one-byte instruction. If the prebyte is misaligned, the O cycle is used as a program word access for the prebyte; if the prebyte is aligned, the O cycle appears as a free cycle. If the remainder of the instruction consists of an odd number of bytes, another O cycle is required some time before the instruction is completed. If the O cycle for the prebyte is treated as a P cycle, any subsequent O cycle in the same instruction is treated as an f cycle; if the O cycle for the prebyte is treated as an f cycle, any subsequent O cycle in the same instruction is treated as a P cycle. Optional cycles used for program word accesses can be extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the program is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. Optional cycles used as free cycles are never stretched.
P - Program word access. Program information is fetched as aligned 16-bit words. These cycles are extended to two bus cycles if the MCU is operating with an 8bit external data bus and the program is stored externally. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory.
$r-8$-bit data read. These cycles are stretched only when controlled by a chip-select circuit programmed for slow memory.
$R$ - 16-bit data read. These cycles are extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. These cycles are also stretched if they correspond to misaligned accesses to memory that is not designed for single-cycle misaligned access.
s - Stack 8-bit data. These cycles are stretched only when controlled by a chip-select circuit programmed for slow memory.
S - Stack 16-bit data. These cycles are extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the SP is pointing to external memory. There can be additional stretching if the address space is assigned to a chip-select circuit programmed for slow memory. These cycles are also stretched if they correspond to misaligned accesses to a memory that is not designed for single cycle misaligned access. The internal RAM is designed to allow single cycle misaligned word access.
w - 8-bit data write. These cycles are stretched only when controlled by a chip-select circuit programmed for slow memory.
W - 16-bit data write. These cycles are extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. These cycles are also stretched if they correspond to misaligned access to a memory that is not designed for single-cycle misaligned access.
u - Unstack 8-bit data. These cycles are stretched only when controlled by a chipselect circuit programmed for slow memory.

U - Unstack 16-bit data. These cycles are extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the SP is pointing to external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. These cycles are also stretched if they correspond to misaligned accesses to a memory that is not designed for single-cycle misaligned access. The internal RAM is designed to allow single-cycle misaligned word access.
V - Vector fetch. Vectors are always aligned 16-bit words. These cycles are extended to two bus cycles if the MCU is operating with an 8 -bit external data bus and the program is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory.
t - 8-bit conditional read. These cycles are either data read cycles or free cycles, depending upon the data and flow of the REVW instruction. These cycles are only stretched when controlled by a chip-select circuit programmed for slow memory.
T - 16-bit conditional read. These cycles are either data read cycles or free cycles, depending upon the data and flow of the REV or REVW instruction. These cycles are extended to two bus cycles if the MCU is operating with an 8-bit external data bus and the corresponding data is stored in external memory. There can be additional stretching when the address space is assigned to a chip-select circuit programmed for slow memory. These cycles are also stretched if they correspond to misaligned accesses to a memory that is not designed for singlecycle misaligned access.
$x-8$-bit conditional write. These cycles are either data write cycles or free cycles, depending upon the data and flow of the REV or REVW instruction. These cycles are only stretched when controlled by a chip-select circuit programmed for slow memory.

## Special Notation for Branch Taken/Not Taken Cases

PPP/P - Short branches require three cycles if taken, one cycle if not taken. Since the instruction consists of a single word containing both an opcode and an 8 -bit offset, the not-taken case is simple - the queue advances, another program word fetch is made, and execution continues with the next instruction. The taken case requires that the queue be refilled so that execution can continue at a new address. First, the effective address of the destination is determined, then the CPU performs three program word fetches from that address.
OPPP/OPO - Long branches require four cycles if taken, three cycles if not taken. Optional cycles are required because all long branches are page two opcodes, and thus include the $\$ 18$ prebyte. The CPU12 treats the prebyte as a special 1-byte instruction. If the prebyte is misaligned, the optional cycle is used to perform a program word access; if the prebyte is aligned, the optional cycle is used to perform a free cycle. As a result, both the taken and not-taken cases use one optional cycle for the prebyte. In the not-taken case, the queue must advance so that execution can continue with the next instruction, and another optional cycle is required to maintain the queue. The taken case requires that the queue be refilled so that execution can continue at a new address. First, the effective address of the destination is determined, then the CPU performs three program word fetches from that address.

### 6.6 Glossary

## Add Accumulator B To Accumulator A

Operation: $\quad(\mathrm{A})+(\mathrm{B}) \Rightarrow \mathrm{A}$
Description: Adds the content of accumulator $B$ to the content of accumulator $A$ and places the result in $A$. The content of $B$ is not changed. This instruction affects the H status bit so it is suitable for use in BCD arithmetic operations (see DAA instruction for additional information).

Condition Codes and Boolean Formulas:

$\mathrm{H}: \quad \mathrm{A} 3 \cdot \mathrm{~B} 3+\mathrm{B} 3 \cdot \overline{\mathrm{R} 3}+\overline{\mathrm{R} 3} \cdot \mathrm{~A} 3$
Set if there was a carry from bit 3; cleared otherwise.
N : Set if MSB of result is set; cleared otherwise.
Z : Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: ~ \mathrm{~A} 7 \cdot \mathrm{~B} 7 \bullet \overline{\mathrm{R} 7}+\overline{\mathrm{A} 7} \bullet \overline{\mathrm{~B} 7} \bullet \mathrm{R} 7$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
$C: \quad A 7 \bullet B 7+B 7 \bullet \overline{R 7}+\overline{R 7} \bullet A 7$
Set if there was a carry from the MSB of the result; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| ABA | INH | 1806 | 2 | 00 |

Operation: $\quad(B)+(X) \Rightarrow X$
Description: Adds the 8-bit unsigned content of accumulator $B$ to the content of index register X considering the possible carry out of the low-order byte of X ; places the result in $X$. The content of $B$ is not changed.

This mnemonic is implemented by the LEAX $B, X$ instruction. The LEAX instruction allows $A, B, D$, or a constant to be added to $X$. For compatibility with the M68HC11, the mnemonic ABX is translated into the LEAX $B, X$ instruction by the assembler.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| ABX translates to... <br> LEAX B, X | IDX | 1A E5 | 2 | $\mathrm{PP}^{1}$ |

Notes:

1. Due to internal CPU requirements, the program word fetch is performed twice to the same address during this instruction.

Operation: $\quad(B)+(Y) \Rightarrow Y$
Description: Adds the 8-bit unsigned content of accumulator $B$ to the content of index register Y considering the possible carry out of the low-order byte of Y ; places the result in Y . The content of B is not changed.

This mnemonic is implemented by the LEAY B,Y instruction. The LEAY instruction allows $A, B, D$, or a constant to be added to $Y$. For compatibility with the M 68 HC 11 , the mnemonic ABY is translated into the LEAY $B, Y$ instruction by the assembler.

Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| ABY translates to... <br> LEAY B,Y | IDX | 19 ED | 2 | $\mathrm{PP}^{1}$ |

Notes:

1. Due to internal CPU requirements, the program word fetch is performed twice to the same address during this instruction.

Operation: $\quad(A)+(M)+C \Rightarrow A$
Description: Adds the content of accumulator A to the content of memory location M , then adds the value of the $C$ bit and places the result in $A$. This instruction affects the H status bit, so it is suitable for use in BCD arithmetic operations (see DAA instruction for additional information).

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

H: X3 • M3 + M3 • $\overline{\mathrm{R} 3}+\overline{\mathrm{R} 3} \cdot \mathrm{X} 3$
Set if there was a carry from bit 3; cleared otherwise.
N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: X7•M7• $\overline{\mathrm{R7}}+\overline{\mathrm{X}} \bullet \overline{\mathrm{M} 7} \bullet \mathrm{R7}$
Set if two's complement overflow resulted from the operation; cleared otherwise.

C: $\quad \mathrm{X7} \cdot \mathrm{M} 7+\mathrm{M} 7 \bullet \overline{\mathrm{R7}}+\overline{\mathrm{R7}} \cdot \mathrm{X7}$
Set if there was a carry from the MSB of the result; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| ADCA \#Opr8i | IMM | 89 ii | 1 | P |
| ADCA opr8a | DIR | 99 dd | 3 | rfP |
| ADCA opr16a | EXT | B9 hh ll | 3 | rop |
| ADCA oprx0_xysp | IDX | A9 xb | 3 | rfP |
| ADCA oprx99xysp | IDX1 | A9 xb ff | 3 | rPO |
| ADCA oprx16,xysp | IDX2 | A9 xb ee ff | 4 | frPP |
| ADCA [D,xysp] | [D,IDX] | A9 xb | 6 | fIfrfP |
| ADCA [oprx16,xysp] | [IDX2] | A9 xb ee ff | 6 | fIPrfP |

Operation: $\quad(B)+(M)+C \Rightarrow B$
Description: Adds the content of accumulator $B$ to the content of memory location $M$, then adds the value of the C bit and places the result in B . This instruction affects the H status bit, so it is suitable for use in BCD arithmetic operations (see DAA instruction for additional information).

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

H: X3 • M3 + M3 • $\overline{\mathrm{R} 3}+\overline{\mathrm{R} 3} \cdot \mathrm{X} 3$
Set if there was a carry from bit 3; cleared otherwise.
N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: X7•M7• $\overline{\mathrm{R7}}+\overline{\mathrm{X7}} \bullet \overline{\mathrm{M} 7} \bullet \mathrm{R7}$
Set if two's complement overflow resulted from the operation; cleared otherwise.

C: $\quad$ X7 • M7 + M7• $\overline{\mathrm{R7}}+\overline{\mathrm{R7}} \cdot \mathrm{X7}$
Set if there was a carry from the MSB of the result; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| ADCB \#opr8i | IMM | C9 ii | 1 | P |
| ADCB opr8a | DIR | D9 dd | 3 | rfP |
| ADCB opr16a | EXT | F9 hh ll | 3 | rOP |
| ADCB oprx0_xysp | IDX | E9 xb | 3 | rfP |
| ADCB oprx9,xysp | IDX1 | E9 xb ff | 3 | rPo |
| ADCB oprx16,xysp | IDX2 | E9 xb ee ff | 4 | frPP |
| ADCB [D,xysp] | [D,IDX] | E9 xb | 6 | fIfrfP |
| ADCB [oprx16,xysp] | [IDX2] | E9 xb ee ff | 6 | fIPrfP |

Operation: $\quad(A)+(M) \Rightarrow A$
Description: Adds the content of memory location $M$ to accumulator $A$ and places the result in A . This instruction affects the H status bit, so it is suitable for use in BCD arithmetic operations (see DAA instruction for additional information).

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

H: X3 • M3 + M3 • $\overline{\mathrm{R} 3}+\overline{\mathrm{R} 3} \bullet \mathrm{X} 3$
Set if there was a carry from bit 3 ; cleared otherwise.
N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: X7•M7• $\overline{\mathrm{R7}}+\overline{\mathrm{X7}} \bullet \overline{\mathrm{M7}} \bullet \mathrm{R7}$
Set if two's complement overflow resulted from the operation; cleared otherwise.
C: $\quad$ X7 • M7 + M7• $\overline{R 7}+\overline{R 7} \bullet X 7$
Set if there was a carry from the MSB of the result; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| ADDA \#opr8i | IMM | 8B ii | 1 | P |
| ADDA opr8a | DIR | 9B dd | 3 | rfP |
| ADDA opr16a | EXT | BB hh 11 | 3 | rop |
| ADDA oprx0_xysp | IDX | AB xb | 3 | rfp |
| ADDA oprx9,xysp | IDX1 | AB xb ff | 3 | rPO |
| ADDA oprx16,xysp | IDX2 | AB xb ee ff | 4 | frpp |
| ADDA [D, $x$ ysp] | [D,IDX] | AB xb | 6 | fifrfp |
| ADDA [oprx16,xysp] | [IDX2] | AB xb ee ff | 6 | fiPrfp |

Operation: $\quad(B)+(M) \Rightarrow B$
Description: Adds the content of memory location M to accumulator B and places the result in B . This instruction affects the H status bit, so it is suitable for use in BCD arithmetic operations (see DAA instruction for additional information).

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

$\mathrm{H}: \quad \mathrm{X} 3 \cdot \mathrm{M} 3+\mathrm{M} 3 \cdot \overline{\mathrm{R} 3}+\overline{\mathrm{R} 3} \cdot \mathrm{X} 3$
Set if there was a carry from bit 3; cleared otherwise.
N : Set if MSB of result is set; cleared otherwise.
Z : Set if result is \$00; cleared otherwise.
$\mathrm{V}: \quad \mathrm{X} 7 \bullet \mathrm{M} 7 \bullet \overline{\mathrm{R} 7}+\overline{\mathrm{X} 7} \bullet \overline{\mathrm{M} 7} \bullet \mathrm{R} 7$
Set if two's complement overflow resulted from the operation; cleared otherwise.

C: $\quad \mathrm{X} 7 \bullet \mathrm{M} 7+\mathrm{M} 7 \bullet \overline{\mathrm{R} 7}+\overline{\mathrm{R7}} \bullet \mathrm{X} 7$
Set if there was a carry from the MSB of the result; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| ADDB \#opr8i | IMM | CB ii | 1 | P |
| ADDB opr8a | DIR | DB dd | 3 | rfP |
| ADDB opr16a | EXT | FB hh ll | 3 | roP |
| ADDB oprx0_xysp | IDX | EB xb | 3 | rfP |
| ADDB oprx9,xysp | IDX1 | EB xb ff | 3 | rPo |
| ADDB oprx16,xysp | IDX2 | EB xb ee ff | 4 | frPP |
| ADDB [D,xysp] | [D,IDX] | EB xb | 6 | fIfrfP |
| ADDB [oprx16,xysp] | [IDX2] | EB xb ee ff | 6 | fIPrfP |

Operation: $\quad(A: B)+(M: M+1) \Rightarrow A: B$
Description: Adds the content of memory location M concatenated with the content of memory location $\mathrm{M}+1$ to the content of double accumulator D and places the result in D. Accumulator A forms the high-order half of 16-bit double accumulator $D$; accumulator $B$ forms the low-order half.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: D15 • M15 • $\overline{\mathrm{R} 15}+\overline{\mathrm{D} 15} \cdot \overline{\mathrm{M} 15} \cdot \mathrm{R} 15$
Set if two's complement overflow resulted from the operation; cleared otherwise.
C: D15 • M15 + M15 • $\overline{\mathrm{R} 15}+\overline{\mathrm{R} 15} \cdot \mathrm{D} 15$
Set if there was a carry from the MSB of the result; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| ADDD \#opr16i | IMM | C3 jj kk | 2 | OP |
| ADDD opr8a | DIR | D3 dd | 3 | RfP |
| ADDD opr16a | EXT | F3 hh ll | 3 | ROP |
| ADDD oprx0 $x y s p ~$ | IDX | E3 xb | 3 | RfP |
| ADDD oprx9,xysp | IDX1 | E3 xb ff | 3 | RPO |
| ADDD oprx16,xysp | IDX2 | E3 xb ee ff | 4 | fRPP |
| ADDD [D,xysp] | [D,IDX] | E3 xb | 6 | fIfRfP |
| ADDD [oprx16,xysp] | [IDX2] | E3 xb ee ff | 6 | fIPRfP |

Operation: $\quad(A) \bullet(M) \Rightarrow A$
Description: Performs logical AND between the content of memory location $M$ and the content of accumulator A. The result is placed in A. After the operation is performed, each bit of $A$ is the logical AND of the corresponding bits of $M$ and of $A$ before the operation began.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| ANDA \#opr8i | IMM | 84 ii | 1 | P |
| ANDA opr8a | DIR | 94 dd | 3 | rfP |
| ANDA opr16a | EXT | B4 hh ll | 3 | rop |
| ANDA oprx0_xysp | IDX | A4 xb | 3 | rfP |
| ANDA oprx9,xysp | IDX1 | A4 xb ff | 3 | rPo |
| ANDA oprx16,xysp | IDX2 | A4 xb ee ff | 4 | frPP |
| ANDA [D,xysp] | [D,IDX] | A4 xb | 6 | fIfrfP |
| ANDA [oprx16,xysp] | [IDX2] | A4 xb ee ff | 6 | fIPrfP |

Operation: $\quad(B) \bullet(M) \Rightarrow B$
Description: Performs logical AND between the content of memory location M and the content of accumulator B. The result is placed in B. After the operation is performed, each bit of $B$ is the logical AND of the corresponding bits of $M$ and of $B$ before the operation began.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :--- | :--- |
| ANDB \#opr8i | IMM | C4 ii | 1 | P |
| ANDB opr8a | DIR | D4 dd | 3 | rfP |
| ANDB opr16a | EXT | F4 hh ll | 3 | rop |
| ANDB oprx0_xysp | IDX | E4 xb | 3 | rfP |
| ANDB oprx9, $x y s p ~$ | IDX1 | E4 xb ff | 3 | rPO |
| ANDB oprx16,xysp | IDX2 | E4 xb ee ff | 4 | frPP |
| ANDB [D,xysp] | [D,IDX] | E4 xb | 6 | fIfrfP |
| ANDB [oprx16,xysp] | [IDX2] | E4 xb ee ff | 6 | fIPrfP |

## $A D$ Logical AND CCR with Mask

Operation: $\quad(C C R) \bullet($ Mask $) \Rightarrow$ CCR
Description: Performs bitwise logical AND between the content of a mask operand and the content of the CCR. The result is placed in the CCR. After the operation is performed, each bit of the CCR is the result of a logical AND with the corresponding bits of the mask. To clear CCR bits, clear the corresponding mask bits. CCR bits that correspond to ones in the mask are not changed by the ANDCC operation.

If the I mask bit is cleared, there is a one cycle delay before the system allows interrupt requests. This prevents interrupts from occurring between instructions in the sequences CLI, WAI and CLI, SEI (CLI is equivalent to ANDCC \#\$EF).

Condition Codes and Boolean Formulas:

| s | X | I | N | z | v |  | c |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\downarrow$ | $\downarrow$ | $\downarrow$ | $\Downarrow$ | $\downarrow$ | $\downarrow$ |  | $\downarrow$ |

Condition code bits are cleared if the corresponding bit was zero before the operation or if the corresponding bit in the mask is zero.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :--- | :---: | :--- |
| ANDCC \#opr8i | IMM | 10 ii | 1 | P |

Arithmetic Shift Left Memory

## Operation:



Description: Shifts all bits of memory location M one bit position to the left. Bit 0 is loaded with a zero. The C status bit is loaded from the most significant bit of $M$.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}]+[\overline{\mathrm{N}} \cdot \mathrm{C}]$ (for N and C after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).

C: M7
Set if the MSB of M was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| ASL opr16a | EXT | 78 hh ll | 4 | rOPw |
| ASL oprx0_xysp | IDX | 68 xb | 3 | rPw |
| ASL oprx9,xysp | IDX1 | 68 xb ff | 4 | rPOw |
| ASL oprx16,xysp | IDX2 | 68 xb ee ff | 5 | frPPw |
| ASL [D,xysp] | [D,IDX] | 68 xb | 6 | fIfrPw |
| ASL [oprx16,xysp] | [IDX2] | 68 xb ee ff | 6 | fIPrPw |

## Operation:



Description: Shifts all bits of accumulator A one bit position to the left. Bit 0 is loaded with a zero. The $C$ status bit is loaded from the most significant bit of $A$.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad N \oplus C=[N \bullet \bar{C}]+[\bar{N} \bullet C]$ (for $N$ and $C$ after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: A7
Set if the MSB of A was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :---: |
| ASLA | INH | 48 | 1 | 0 |

## Operation:



Description: Shifts all bits of accumulator $B$ one bit position to the left. Bit 0 is loaded with a zero. The $C$ status bit is loaded from the most significant bit of $B$.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad N \oplus C=[N \bullet \bar{C}]+[\bar{N} \bullet C]$ (for $N$ and $C$ after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: B7
Set if the MSB of B was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :---: |
| ASLB | INH | 58 | 1 | 0 |

## ASLD

## Operation:



Description: Shifts all bits of double accumulator D one bit position to the left. Bit 0 is loaded with a zero. The C status bit is loaded from the most significant bit of $D$.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: $\quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}]+[\overline{\mathrm{N}} \bullet \mathrm{C}]$ (for N and C after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: D15
Set if the MSB of D was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| ASLD | INH | 59 | 1 | 0 |

## Operation:



Description: Shifts all bits of memory location M one place to the right. Bit 7 is held constant. Bit 0 is loaded into the C status bit. This operation effectively divides a two's complement value by two without changing its sign. The carry bit can be used to round the result.

## Condition Codes and Boolean Formulas:

| S | X | H | I | N | Z |  |  | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ |  |  | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}]+[\overline{\mathrm{N}} \cdot \mathrm{C}]$ (for N and C after the shift)
Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: MO
Set if the LSB of M was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| ASR opr16a | EXT | 77 hh ll | 4 | rOPw |
| ASR oprx0_xysp | IDX | 67 xb | 3 | rPw |
| ASR oprx9,xysp | IDX1 | 67 xb ff | 4 | rPOw |
| ASR oprx16,xysp | IDX2 | 67 xb ee ff | 5 | frPPw |
| ASR [D,xysp] | [D,IDX] | 67 xb | 6 | fIfrPw |
| ASR [oprx16,xysp] | [IDX2] | 67 xb ee ff | 6 | fIPrPw |

## Operation:



Description: Shifts all bits of accumulator A one place to the right. Bit 7 is held constant. Bit 0 is loaded into the C status bit. This operation effectively divides a two's complement value by two without changing its sign. The carry bit can be used to round the result.

## Condition Codes and Boolean Formulas:

| S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad N \oplus C=[N \bullet \bar{C}]+[\bar{N} \bullet C]$ (for $N$ and $C$ after the shift)
Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: AO
Set if the LSB of A was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| ASRA | INH | 47 | 1 | 0 |

## Operation:



Description: Shifts all bits of accumulator $B$ one place to the right. Bit 7 is held constant. Bit 0 is loaded into the C status bit. This operation effectively divides a two's complement value by two without changing its sign. The carry bit can be used to round the result.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |  |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad N \oplus C=[N \bullet \bar{C}]+[\bar{N} \bullet C]$ (for $N$ and $C$ after the shift)
Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: BO
Set if the LSB of B was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| ASRB | INH | 57 | 1 | 0 |

## Branch if Carry Cleared

(Same as BHS)
Operation: $\quad$ If $C=0$, then $(P C)+\$ 0002+\operatorname{Rel} \Rightarrow P C$
Simple branch
Description: Tests the C status bit and branches if $\mathrm{C}=0$.
See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :---: |
| BCC rel8 | REL | 24 rr | $3 / 1$ | $\mathrm{PPP}^{2} / \mathrm{P}^{1}$ |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $r<m$ | BLT | 2D | Signed |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $\mathrm{C}+\mathrm{Z}=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | C = 0 | $r<m$ | BLO/BCS | 25 | Unsigned |
| $r=m$ | BEQ | 27 | Z = 1 | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| r=0 | BEQ | 27 | $\mathrm{Z}=1$ | $\mathrm{r}=0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad(\mathrm{M}) \bullet(\overline{\text { Mask }}) \Rightarrow \mathrm{M}$
Description: Clears bits in location $M$. To clear a bit, set the corresponding bit in the mask byte. Bits in M that correspond to zeros in the mask byte are not changed. Mask bytes can be located at PC $+2, \mathrm{PC}+3$, or PC +4 , depending on addressing mode used.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode1 | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| BCLR opr8a, $m s k 8$ | DIR | 4 D dd mm | 4 | rPOw |
| BCLR opr16a, msk8 | EXT | 1D hh 11 mm | 4 | rPPw |
| BCLR oprx0_xysp, msk8 | IDX | 0D xb mm | 4 | rPOw |
| BCLR oprx9,xysp, msk8 | IDX1 | 0D xb ff mm | 4 | rPwP |
| BCLR oprx16,xysp, msk8 | IDX2 | 0D xb ee ff mm | 6 | frPwOP |

Notes:

1. Indirect forms of indexed addressing cannot be used with this instruction.

Operation: $\quad$ If $C=1$, then $(P C)+\$ 0002+\mathrm{Rel} \Rightarrow \mathrm{PC}$
Simple branch
Description: Tests the C status bit and branches if $\mathrm{C}=1$.
See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :---: |
| BCS rel8 | REL | 25 rr | $3 / 1$ | $\mathrm{PPP}^{2} / \mathrm{P}^{1}$ |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $r<m$ | BLT | 2D | Signed |
| $\mathrm{r}=\mathrm{m}$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $\mathrm{C}+\mathrm{Z}=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | C = 0 | $r<m$ | BLO/BCS | 25 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | BEQ | 27 | Z = 1 | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| $r<m$ | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| $\mathrm{r}=0$ | BEQ | 27 | Z = 1 | $r \neq 0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: If $Z=1$, then $(P C)+\$ 0002+\operatorname{ReI} \Rightarrow P C$
Simple branch
Description: Tests the $Z$ status bit and branches if $Z=1$.
See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :---: |
| BEQ rel8 | REL | 27 rr | $3 / 1$ | $\mathrm{PPP}^{2} / \mathrm{P}^{1}$ |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $r<m$ | BLT | 2D | Signed |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $\mathrm{C}+\mathrm{Z}=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | C = 0 | $r<m$ | BLO/BCS | 25 | Unsigned |
| $r=m$ | BEQ | 27 | Z = 1 | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| r=0 | BEQ | 27 | $\mathrm{Z}=1$ | $\mathrm{r}=0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad$ If $\mathrm{N} \oplus \mathrm{V}=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{Rel} \Rightarrow \mathrm{PC}$
For signed two's complement values
if (Accumulator) $\geq$ (Memory), then branch
Description: If BGE is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the signed two's complement number in the accumulator is greater than or equal to the signed two's complement number in memory.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| BGE rel8 | REL | 2C rr | $3 / 1$ | $\mathrm{PPP} / \mathrm{P}^{1}$ |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2 F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $r<m$ | BLT | 2D | Signed |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $C+Z=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | $\mathrm{C}=0$ | $r<m$ | BLO/BCS | 25 | Unsigned |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| $\mathrm{r}=0$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq 0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Description: BGND operates like a software interrupt, except that no registers are stacked. First, the current PC value is stored in internal CPU register TMP2. Next, the BDM ROM and background register block become active. The BDM ROM contains a substitute vector, mapped to the address of the software interrupt vector, which points to routines in the BDM ROM that control background operation. The substitute vector is fetched, and execution continues from the address that it points to. Finally, the CPU checks the location that TMP2 points to. If the value stored in that location is $\$ 00$ (the BGND opcode), TMP2 is incremented, so that the instruction that follows the BGND instruction is the first instruction executed when normal program execution resumes.

For all other types of BDM entry, the CPU performs the same sequence of operations as for a BGND instruction, but the value stored in TMP2 already points to the instruction that would have executed next had BDM not become active. If active BDM is triggered just as a BGND instruction is about to execute, the BDM firmware does increment TMP2, but the change does not affect resumption of normal execution.

While BDM is active, the CPU executes debugging commands received via a special single-wire serial interface. BDM is terminated by the execution of specific debugging commands. Upon exit from BDM, the background/boot ROM and registers are disabled, the instruction queue is refilled starting with the return address pointed to by TMP2, and normal processing resumes.

BDM is normally disabled to avoid accidental entry. While BDM is disabled, BGND executes as described, but the firmware causes execution to return to the user program. Refer to SECTION 8 DEVELOPMENT AND DEBUG SUPPORT for more information concerning BDM.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| BGND | INH | 00 | 5 | VfPPP |

Operation: $\quad$ If $Z+(N \oplus V)=0$, then $(P C)+\$ 0002+$ Rel $\Rightarrow P C$
For signed two's complement values
if (Accumulator) $>$ (Memory), then branch
Description: If BGT is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the signed two's complement number in the accumulator is greater than the signed two's complement number in memory.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| BGT rel8 | REL | 2 E rr | $3 / 1$ | $\mathrm{PPP} / \mathrm{P}^{1}$ |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $r<m$ | BLT | 2D | Signed |
| $\mathrm{r}=\mathrm{m}$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $\mathrm{C}+\mathrm{Z}=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | C = 0 | $r<m$ | BLO/BCS | 25 | Unsigned |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| r<m | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| $r=0$ | BEQ | 27 | Z = 1 | $r=0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad$ If $\mathrm{C}+\mathrm{Z}=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{Rel} \Rightarrow \mathrm{PC}$
For unsigned values, if (Accumulator) $>$ (Memory), then branch
Description: If BHI is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the unsigned binary number in the accumulator was greater than the unsigned binary number in memory. Generally not useful after INC/ DEC, LD/ST, TST/CLR/COM because these instructions do not affect the C status bit.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| BHI rel8 | REL | 22 rr | $3 / 1$ | $\mathrm{PPP} / \mathrm{P}^{1}$ |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2 F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $r<m$ | BLT | 2D | Signed |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $C+Z=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | C = 0 | $r<m$ | BLO/BCS | 25 | Unsigned |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| $r<m$ | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| $\mathrm{r}=0$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq 0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad$ If $C=0$, then $(P C)+\$ 0002+\mathrm{Rel} \Rightarrow \mathrm{PC}$
For unsigned values, if (Accumulator) $\geq$ (Memory), then branch
Description: If BHS is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the unsigned binary number in the accumulator was greater than the unsigned binary number in memory. Generally not useful after INC/ DEC, LD/ST, TST/CLR/COM because these instructions do not affect the C status bit.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| BHS rel8 | REL | 24 rr | $3 / 1$ | $\mathrm{PPP} / \mathrm{P}^{1}$ |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | BLT | 2D | Signed |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $C+Z=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | $\mathrm{C}=0$ | $r<m$ | BLO/BCS | 25 | Unsigned |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| $\mathrm{r}=0$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq 0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad(A) \bullet(M)$

Description: Performs bitwise logical AND on the content of accumulator A and the content of memory location M, and modifies the condition codes accordingly. Each bit of the result is the logical AND of the corresponding bits of the accumulator and the memory location. Neither the content of the accumulator nor the content of the memory location is affected.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| BITA \#opr8i | IMM | 85 ii | 1 | P |
| BITA opr8a | DIR | 95 dd | 3 | rfP |
| BITA opr16a | EXT | B5 hh ll | 3 | rop |
| BITA oprx0_xysp | IDX | A5 xb | 3 | rfP |
| BITA oprx99 $x y s p$ | IDX1 | A5 xb ff | 3 | rPO |
| BITA oprx16,xysp | IDX2 | A5 xb ee ff | 4 | frPP |
| BITA [D,xysp] | [D,IDX] | A5 xb | 6 | fIfrfP |
| BITA [oprx16,xysp] | [IDX2] | A5 xb ee ff | 6 | fIPrfP |

Operation: $\quad(B) \bullet(M)$

Description: Performs bitwise logical AND on the content of accumulator B and the content of memory location M, and modifies the condition codes accordingly. Each bit of the result is the logical AND of the corresponding bits of the accumulator and the memory location. Neither the content of the accumulator nor the content of the memory location is affected.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| BITB \#opr8i | IMM | C5 ii | 1 | P |
| BITB opr8a | DIR | D5 dd | 3 | rfP |
| BITB opr16a | EXT | F5 hh ll | 3 | rop |
| BITB oprx0_xysp | IDX | E5 xb | 3 | rfP |
| BITB oprx9,xysp | IDX1 | E5 xb ff | 3 | rPO |
| BITB oprx16,xysp | IDX2 | E5 xb ee ff | 4 | frpp |
| BITB [D, $x y s p] ~$ | [D,IDX] | E5 xb | 6 | fIfrfP |
| BITB [oprx16,xysp] | [IDX2] | E5 xb ee ff | 6 | fIPrfP |

Operation: $\quad$ If $Z+(N \oplus V)=1$, then $(P C)+\$ 0002+\operatorname{Rel} \Rightarrow P C$
For signed two's complement numbers
if (Accumulator) $\leq$ (Memory), then branch
Description: If BLE is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the two's complement number in the accumulator was less than or equal to the two's complement number in memory.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :--- | :---: | :--- |
| BLE rel8 | REL | 2 Frr | $3 / 1$ | $\mathrm{PPP} / \mathrm{P}^{1}$ |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $r<m$ | BLT | 2D | Signed |
| $\mathrm{r}=\mathrm{m}$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $\mathrm{C}+\mathrm{Z}=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | C = 0 | $r<m$ | BLO/BCS | 25 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| r<m | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2 A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| $\mathrm{r}=0$ | BEQ | 27 | $\mathrm{Z}=1$ | $\mathrm{r}=0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad$ If $C=1$, then $(P C)+\$ 0002+\mathrm{Rel} \Rightarrow \mathrm{PC}$
For unsigned values, if (Accumulator) < (Memory), then branch
Description: If BLO is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the unsigned binary number in the accumulator is less than the unsigned binary number in memory. Generally not useful after INC/DEC, LD/ST, TST/CLR/COM because these instructions do not affect the C status bit.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| BLO rel8 | REL | 25 rr | $3 / 1$ | $\mathrm{PPP} / \mathrm{P}^{1}$ |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | BLT | 2D | Signed |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $C+Z=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | $\mathrm{C}=0$ | $r<m$ | BLO/BCS | 25 | Unsigned |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| $\mathrm{r}=0$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq 0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad$ If $\mathrm{C}+\mathrm{Z}=1$, then $(\mathrm{PC})+\$ 0002+\mathrm{Rel} \Rightarrow \mathrm{PC}$
For unsigned values, if (Accumulator) $\leq$ (Memory), then branch
Description: If BLS is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the unsigned binary number in the accumulator is less than or equal to the unsigned binary number in memory. Generally not useful after INC/DEC, LD/ST, TST/CLR/COM because these instructions do not affect the C status bit.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :--- | :---: | :--- |
| BLS rel8 | REL | 23 rr | $3 / 1$ | PPP/P 1 |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $r<m$ | BLT | 2D | Signed |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $C+Z=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | $\mathrm{C}=0$ | $r<m$ | BLO/BCS | 25 | Unsigned |
| $r=m$ | BEQ | 27 | Z = 1 | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| $\mathrm{r}=0$ | BEQ | 27 | $\mathrm{Z}=1$ | $\mathrm{r}=0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad$ If $\mathrm{N} \oplus \mathrm{V}=1$, then $(\mathrm{PC})+\$ 0002+\operatorname{Rel} \Rightarrow \mathrm{PC}$
For signed two's complement numbers
if (Accumulator) < (Memory), then branch
Description: If BLT is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the two's complement number in the accumulator is less than the two's complement number in memory.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :---: |
| BLT rel8 | REL | 2D rr | $3 / 1$ | $\mathrm{PPP} / \mathrm{P}^{1}$ |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2 F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $r<m$ | BLT | 2D | Signed |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $C+Z=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | $\mathrm{C}=0$ | $r<m$ | BLO/BCS | 25 | Unsigned |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| $\mathrm{r}=0$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq 0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad$ If $N=1$, then $(P C)+\$ 0002+\operatorname{Rel} \Rightarrow P C$
Simple branch
Description: Tests the N status bit and branches if $\mathrm{N}=1$.
See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| BMI rel8 | REL | 2B rr | $3 / 1$ | PPP/P 1 |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | BLT | 2D | Signed |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $C+Z=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | C = 0 | $r<m$ | BLO/BCS | 25 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| r<m | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| $\mathrm{r}=0$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq 0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad$ If $Z=0$, then $(P C)+\$ 0002+\mathrm{Rel} \Rightarrow \mathrm{PC}$
Simple branch
Description: Tests the $Z$ status bit and branches if $Z=0$.
See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :---: |
| BNE rel8 | REL | 26 rr | $3 / 1$ | $\mathrm{PPP} / \mathrm{P}^{1}$ |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $r<m$ | BLT | 2D | Signed |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $\mathrm{C}+\mathrm{Z}=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | C = 0 | $r<m$ | BLO/BCS | 25 | Unsigned |
| $r=m$ | BEQ | 27 | Z = 1 | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| r=0 | BEQ | 27 | $\mathrm{Z}=1$ | $\mathrm{r}=0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad$ If $\mathrm{N}=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{Rel} \Rightarrow \mathrm{PC}$
Simple branch
Description: Tests the N status bit and branches if $\mathrm{N}=0$.
See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| BPL rel8 | REL | 2A rr | $3 / 1$ | PPP/P 1 |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $r \leq m$ | BLE | 2F | Signed |
| $r \geq m$ | BGE | 2 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $r<m$ | BLT | 2D | Signed |
| $r=m$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $\mathrm{C}+\mathrm{Z}=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | C = 0 | $r<m$ | BLO/BCS | 25 | Unsigned |
| $r=m$ | BEQ | 27 | Z = 1 | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| r<m | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| $\mathrm{r}=0$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq 0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad(\mathrm{PC})+\$ 0002+\mathrm{Rel} \Rightarrow \mathrm{PC}$
Description: Unconditional branch to an address calculated as shown in the expression. Rel is a relative offset stored as a two's complement number in the second byte of the branch instruction.

Execution time is longer when a conditional branch is taken than when it is not, because the instruction queue must be refilled before execution resumes at the new address. Since the BRA branch condition is always satisfied, the branch is always taken, and the instruction queue must always be refilled.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| BRA rel8 | REL | 20 rr | 3 | PPP |

## BRCLR

Operation: If $(M) \bullet($ Mask $)=0$, then branch
Description: Performs bitwise logical AND on memory location $M$ and the mask supplied with the instruction, then branches if and only if all bits with a value of one in the mask byte correspond to bits with a value of zero in the tested byte. Mask operands can be located at PC +1 , $\mathrm{PC}+2$, or PC +4 , depending on addressing mode. The branch offset is referenced to the next address after the relative offset (rr) which is the last byte of the instruction object code.

See 3.7 Relative Addressing Mode for details of branch execution.
Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode1 | Object Code | Cycles | Access <br> Detail |
| :--- | :---: | :---: | :---: | :--- |
| BRCLR opr8a, msk8, rel8 | DIR | 4 F dd mm rr | 4 | rPPP |
| BRCLR opr16a, msk8, rel8 | EXT | 1 F hh ll mm rr | 5 | rfPPP |
| BRCLR oprx0_xysp, msk8, rel8 | IDX | 0 F xb mm rr | 4 | rPPP |
| BRCLR oprx9,xysp, msk8, rel8 | IDX1 | 0 Fb ff mm rr | 6 | rffPPP |
| BRCLR oprx16,xysp, msk8, rel8 | IDX2 | FF xb ee ff mm <br> rr | 8 | frPffPPP |

Notes:

1. Indirect forms of indexed addressing cannot be used with this instruction.

Operation: $\quad(P C)+\$ 0002 \Rightarrow P C$
Description: Never branches. BRN is effectively a 2-byte NOP that requires one cycle to execute. BRN is included in the instruction set to provide a complement to the BRA instruction. The instruction is useful during program debug, to negate the effect of another branch instruction without disturbing the offset byte. A complement for BRA is also useful in compiler implementations.

Execution time is longer when a conditional branch is taken than when it is not, because the instruction queue must be refilled before execution resumes at the new address. Since the BRN branch condition is never satisfied, the branch is never taken, and only a single program fetch is needed to update the instruction queue.

See 3.7 Relative Addressing Mode for details of branch execution.
Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| BRN rel8 | REL | 21 rr | 1 | P |

Operation: If $(\overline{\mathrm{M}}) \bullet$ (Mask) $=0$, then branch
Description: Performs bitwise logical AND on the inverse of memory location $M$ and the mask supplied with the instruction, then branches if and only if all bits with a value of one in the mask byte correspond to bits with a value of one in the tested byte. Mask operands can be located at PC + 1, PC + 2 , or PC +4 , depending on addressing mode. The branch offset is referenced to the next address after the relative offset (rr) which is the last byte of the instruction object code.

See 3.7 Relative Addressing Mode for details of branch execution.
Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode1 | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| BRSET opr8a, msk8, rel8 BRSET opr16a, msk8, rel8 BRSET oprx0_xysp, msk8, rel8 BRSET oprx9,xysp, msk8, rel8 BRSET oprx16,xysp, msk8, rel8 | DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 | 4E dd mm rr <br> 1E hh ll mm rr <br> OE xb mm rr <br> OE xb ff mm rr <br> OE xb ee ff mm rr | $\begin{aligned} & 4 \\ & 5 \\ & 4 \\ & 6 \\ & 8 \end{aligned}$ | rPPP <br> rfPPP <br> rPPP <br> rffPPP <br> frPffPPP |

Notes:

1. Indirect forms of indexed addressing cannot be used with this instruction.

Operation: $\quad(M)+($ Mask $) \Rightarrow M$
Description: Sets bits in memory location M. To set a bit, set the corresponding bit in the mask byte. All other bits in M are unchanged. The mask byte can be located at $\mathrm{PC}+2, \mathrm{PC}+3$, or $\mathrm{PC}+4$, depending upon addressing mode.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode1 | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| BSET opr8a, msk8 | DIR | 4C dd mm | 4 | rPOw |
| BSET opr16a, msk8 | EXT | 1C hh 11 mm | 4 | rPPw |
| BSET oprx0_xysp, msk8 | IDX | 0C xb mm | 4 | rPOw |
| BSET oprx9,xysp, msk8 | IDX1 | 0C xb ff mm | 4 | rPwP |
| BSET oprx16,xysp, msk8 | IDX2 | 0C xb ee ff mm | 6 | frPwOP |

Notes:

1. Indirect forms of indexed addressing cannot be used with this instruction.

Operation: $\quad(S P)-\$ 0002 \Rightarrow S P$
RTN $_{H}: \operatorname{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{(S P)}: \mathrm{M}_{(S P+1)}$
(PC) $+\mathrm{Rel} \Rightarrow \mathrm{PC}$
Description: Sets up conditions to return to normal program flow, then transfers control to a subroutine. Uses the address of the instruction after the BSR as a return address.

Decrements the SP by two, to allow the two bytes of the return address to be stacked.

Stacks the return address (the SP points to the high order byte of the return address).
Branches to a location determined by the branch offset.
Subroutines are normally terminated with an RTS instruction, which restores the return address from the stack.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| BSR rel8 | REL | 07 rr | 4 | PPPS |

Operation: $\quad$ If $\mathrm{V}=0$, then $(\mathrm{PC})+\$ 0002+\mathrm{Rel} \Rightarrow \mathrm{PC}$
Simple branch
Description: Tests the V status bit and branches if $\mathrm{V}=0$.
BVC causes a branch when a previous operation on two's complement binary values does not cause an overflow. That is, when BVC follows a two's complement operation, a branch occurs when the result of the operation is valid.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| BVC rel8 | REL | 28 rr | $3 / 1$ | $\mathrm{PPP} / \mathrm{P}^{1}$ |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | BLE | 2 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | BGE | 2 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | BLT | 2 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | BEQ | 27 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | BNE | 26 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | BLE | 2 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | BGT | 2 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | BLT | 2 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | BGE | 2 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | BHI | 22 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | BLS | 23 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | $\mathrm{BHS} / \mathrm{BCC}$ | 24 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | BLO/BCS | 25 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | BEQ | 27 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | BNE | 26 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | BLS | 23 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | BHI | 22 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | BLO/BCS | 25 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2 B | $\mathrm{~N}=1$ | Plus | BPL | 2 A | Simple |
| Overflow | BVS | 29 | $\mathrm{~V}=1$ | No Overflow | BVC | 28 | Simple |
| $\mathrm{r}=0$ | BEQ | 27 | $\mathrm{Z=1}$ | $\mathrm{r} \neq 0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad$ If $\mathrm{V}=1$, then $(\mathrm{PC})+\$ 0002+\mathrm{ReI} \Rightarrow \mathrm{PC}$
Simple branch
Description: Tests the V status bit and branches if $\mathrm{V}=1$.
BVS causes a branch when a previous operation on two's complement binary values causes an overflow. That is, when BVS follows a two's complement operation, a branch occurs when the result of the operation is invalid.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| BVS rel8 | REL | 29 rr | $3 / 1$ | $\mathrm{PPP} / \mathrm{P}^{1}$ |

Notes:

1. PPP/P indicates this instruction takes three cycles to refill the instruction queue if the branch is taken and one program fetch cycle if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | BGT | 2E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | BLE | 2F | Signed |
| $r \geq m$ | BGE | 2C | $\mathrm{N} \oplus \mathrm{V}=0$ | $r<m$ | BLT | 2D | Signed |
| $\mathrm{r}=\mathrm{m}$ | BEQ | 27 | $\mathrm{Z}=1$ | $r \neq m$ | BNE | 26 | Signed |
| $r \leq m$ | BLE | 2F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $r>m$ | BGT | 2E | Signed |
| $r<m$ | BLT | 2D | $\mathrm{N} \oplus \mathrm{V}=1$ | $r \geq m$ | BGE | 2C | Signed |
| $r>m$ | BHI | 22 | $\mathrm{C}+\mathrm{Z}=0$ | $r \leq m$ | BLS | 23 | Unsigned |
| $r \geq m$ | BHS/BCC | 24 | $\mathrm{C}=0$ | $r<m$ | BLO/BCS | 25 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | BEQ | 27 | Z = 1 | $r \neq m$ | BNE | 26 | Unsigned |
| $r \leq m$ | BLS | 23 | $C+Z=1$ | $r>m$ | BHI | 22 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | BLO/BCS | 25 | $\mathrm{C}=1$ | $r \geq m$ | BHS/BCC | 24 | Unsigned |
| Carry | BCS | 25 | $\mathrm{C}=1$ | No Carry | BCC | 24 | Simple |
| Negative | BMI | 2B | $\mathrm{N}=1$ | Plus | BPL | 2A | Simple |
| Overflow | BVS | 29 | $\mathrm{V}=1$ | No Overflow | BVC | 28 | Simple |
| $\mathrm{r}=0$ | BEQ | 27 | $\mathrm{Z}=1$ | $\mathrm{r}=0$ | BNE | 26 | Simple |
| Always | BRA | 20 | - | Never | BRN | 21 | Unconditional |

Operation: $\quad(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP}$
RTN $\left._{H}: R_{\text {RTN }} \Rightarrow M_{(S P)}: M_{(S P}+1\right)$
(SP) - \$0001 $\Rightarrow$ SP
(PPAGE) $\Rightarrow M_{(S P)}$
page $\Rightarrow$ PPAGE
Subroutine Address $\Rightarrow P C$
Description: Sets up conditions to return to normal program flow, then transfers control to a subroutine in expanded memory. Uses the address of the instruction following the CALL as a return address. For code compatibility, CALL also executes correctly in devices that do not have expanded memory capability.

Decrements the SP by two, to allow the two bytes of the return address to be stacked.
Stacks the return address (the SP points to the high order byte of the return address).
Decrements the SP by one, to allow the current memory page value in the PPAGE register to be stacked.
Stacks the content of PPAGE.
Writes a new page value supplied by the instruction to PPAGE.
Transfers control to the subroutine.
In indexed-indirect modes, the subroutine address and the PPAGE value are fetched from memory in the order $M$ high byte, $M$ low byte, and new PPAGE value.

Expanded-memory subroutines must be terminated by an RTC instruction, which restores the return address and PPAGE value from the stack.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| CALL opr16a, page | EXT | 4 A hh ll pg | 8 | gnfSsPPP |
| CALL oprx0_xysp, page | IDX | 4B xb pg | 8 | gnfSsPPP |
| CALL oprx9,xysp, page | IDX1 | 4B xb ff pg | 8 | gnfSsPPP |
| CALL oprx16,xysp, page | IDX2 | 4B xb ee ff pg | 9 | fgnfSsPPP |
| CALL [D,xysp] | [D,IDX] | 4B xb | 10 | fIignSsPPP |
| CALL [oprx16,xysp] | [IDX2] | 4B xb ee ff | 10 | fIignSsPPP |

Operation: $\quad(A)-(B)$
Description: Compares the content of accumulator A to the content of accumulator B and sets the condition codes, which may then be used for arithmetic and logical conditional branches. The contents of the accumulators are not changed.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \quad \mathrm{A} \cdot \mathrm{B7} \cdot \overline{\mathrm{R7}}+\overline{\mathrm{A} 7} \bullet \mathrm{~B} 7 \bullet \mathrm{R} 7$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
$\mathrm{C}: \quad \overline{\mathrm{A} 7} \cdot \mathrm{~B} 7+\mathrm{B} 7 \bullet \mathrm{R} 7+\mathrm{R} 7+\overline{\mathrm{A} 7}$
Set if there was a borrow from the MSB of the result; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| CBA | INH | 1817 | 2 | 00 |

Clear Carry
Operation: $\quad 0 \Rightarrow \mathrm{C}$ bit
Description: Clears the C status bit. This instruction is assembled as ANDCC \#\$FE. The ANDCC instruction can be used to clear any combination of bits in the CCR in one operation.

CLC can be used to set up the C bit prior to a shift or rotate instruction involving the $C$ bit.

Condition Codes and Boolean Formulas:

| $\mathbf{L}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | $\mathbf{C}$ |  |  |  |  |  |
| - | - | - | - | - | - | 0 |

C: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| CLC translates to... <br> ANDCC \#\$FE | IMM | 10 FE | 1 | P |

Clear Interrupt Mask
Operation: $\quad 0 \Rightarrow 1$ bit
Description: Clears the I mask bit. This instruction is assembled as ANDCC \#\$EF. The ANDCC instruction can be used to clear any combination of bits in the CCR in one operation.

When the I bit is cleared, interrupts are enabled. There is a one cycle (bus clock) delay in the clearing mechanism for the I bit so that, if interrupts were previously disabled, the next instruction after a CLI will always be executed, even if there was an interrupt pending prior to execution of the CLI instruction.

## Condition Codes and Boolean Formulas:



I: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| CLI translates to... <br> ANDCC $\# \$ E F$ | IMM | 10 EF | 1 | P |

## Clear Memory

Operation: $\quad 0 \Rightarrow \mathrm{M}$
Description: All bits in memory location M are cleared to zero.
Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | 1 | 0 | 0 |

N: 0; Cleared.
Z: 1; Set.
V: 0; Cleared.
C: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| CLR opr16a | EXT | 79 hh ll | 3 | wOP |
| CLR oprx0_xysp | IDX | 69 xb | 2 | Pw |
| CLR oprx9,xysp | IDX1 | 69 xb ff | 3 | Pwo |
| CLR oprx16,xysp | IDX2 | 69 xb ee ff | 3 | PwP |
| CLR [D,xysp] | [D,IDX] | 69 xb | 5 | PIfPw |
| CLR [oprx16,xysp] | [IDX2] | 69 xb ee ff | 5 | PIPPw |

## Clear A

Operation: $\quad 0 \Rightarrow \mathrm{~A}$
Description: All bits in accumulator A are cleared to zero.
Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | 1 | 0 | 0 |

N: 0; Cleared.
Z: 1; Set.
V: 0; Cleared.
C: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| CLRA | INH | 87 | 1 | 0 |

## Clear B

Operation: $\quad 0 \Rightarrow B$
Description: All bits in accumulator B are cleared to zero.
Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | 1 | 0 | 0 |

N: 0; Cleared.
Z: 1; Set.
V: 0; Cleared.
C: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| CLRB | INH | C7 | 1 | 0 |

Operation: $\quad 0 \Rightarrow \mathrm{~V}$ bit
Description: Clears the V status bit. This instruction is assembled as ANDCC \#\$FD. The ANDCC instruction can be used to clear any combination of bits in the CCR in one operation.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | 0 | - |

V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| CLV translates to... <br> ANDCC \#\$FD | IMM | 10 FD | 1 | P |

## Operation: $\quad(\mathrm{A})-(\mathrm{M})$

Description: Compares the content of accumulator A to the content of memory location M and sets the condition codes, which may then be used for arithmetic and logical conditional branching. The contents of A and location M are not changed.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | $\mathbf{C}$

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \quad \mathrm{X} 7 \bullet \overline{\mathrm{M} 7} \bullet \overline{\mathrm{R7}}+\overline{\mathrm{X7}} \bullet \mathrm{M} 7 \bullet \mathrm{R} 7$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
$\mathrm{C}: \overline{\mathrm{X} 7} \cdot \mathrm{M} 7+\mathrm{M} 7 \bullet \mathrm{R} 7+\mathrm{R} 7+\overline{\mathrm{X} 7}$
Set if there was a borrow from the MSB of the result; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| CMPA \#opr8i | IMM | 81 ii | 1 | P |
| CMPA opr8a | DIR | 91 dd | 3 | rfP |
| CMPA opr16a | EXT | B1 hh ll | 3 | rOP |
| CMPA oprx0_xysp | IDX | A1 xb | 3 | rfP |
| CMPA oprx9,xysp | IDX1 | A1 xb ff | 3 | rPo |
| CMPA oprx16,xysp | IDX2 | A1 xb ee ff | 4 | frPP |
| CMPA [D, $x y s p]$ | [D,IDX] | A1 xb | 6 | fIfrfP |
| CMPA [oprx16, $x y s p] ~$ | $[I D X 2] ~$ | A1 xb ee ff | 6 | fIPrfP |

## Operation: $\quad(B)-(M)$

Description: Compares the content of accumulator B to the content of memory location M and sets the condition codes, which may then be used for arithmetic and logical conditional branching. The contents of $B$ and location M are not changed.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \quad \mathrm{X} 7 \bullet \overline{\mathrm{M} 7} \bullet \overline{\mathrm{R7}}+\overline{\mathrm{X7}} \bullet \mathrm{M} 7 \bullet \mathrm{R} 7$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
$\mathrm{C}: \overline{\mathrm{X} 7} \cdot \mathrm{M} 7+\mathrm{M} 7 \bullet \mathrm{R} 7+\mathrm{R} 7+\overline{\mathrm{X} 7}$
Set if there was a borrow from the MSB of the result; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| CMPB \#opr8i | IMM | C1 ii | 1 | P |
| CMPB opr8a | DIR | D1 dd | 3 | rfP |
| CMPB opr16a | EXT | F1 hh ll | 3 | rOP |
| CMPB oprx0_xysp | IDX | E1 xb | 3 | rfP |
| CMPB oprx9,xysp | IDX1 | E1 xb ff | 3 | rPo |
| CMPB oprx16,xysp | IDX2 | E1 xb ee ff | 4 | frPP |
| CMPB [D, $x y s p]$ | [D,IDX] | E1 xb | 6 | fIfrfP |
| CMPB [oprx16,xysp] | $[I D X 2] ~$ | E1 xb ee ff | 6 | fIPrfP |

Operation: $\quad(\overline{\mathrm{M}})=\$ \mathrm{FF}-(\mathrm{M}) \Rightarrow \mathrm{M}$
Description: Replaces the content of memory location M with its one's complement. Each bit of M is complemented. Immediately after a COM operation on unsigned values, only the BEQ, BNE, LBEQ, and LBNE branches can be expected to perform consistently. After operation on two's complement values, all signed branches are available.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | 1 |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
C: 1; Set (for M6800 compatibility).
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| COM opr16a | EXT | 71 hh ll | 4 | rOPw |
| COM oprx0_xysp | IDX | 61 xb | 3 | rPw |
| COM oprx9,xysp | IDX1 | 61 xb ff | 4 | rPOw |
| COM oprx16,xysp | IDX2 | 61 xb ee ff | 5 | frPPw |
| COM [D,xysp] | [D,IDX] | 61 xb | 6 | fIfrPw |
| COM [oprx16,xysp] | [IDX2] | 61 xb ee ff | 6 | fIPrPw |

Operation: $\quad(\overline{\mathrm{A}})=\$ \mathrm{FF}-(\mathrm{A}) \Rightarrow \mathrm{A}$
Description: Replaces the content of accumulator A with its one's complement. Each bit of A is complemented. Immediately after a COM operation on unsigned values, only the BEQ, BNE, LBEQ, and LBNE branches can be expected to perform consistently. After operation on two's complement values, all signed branches are available.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | 1 |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
C: 1; Set (for M6800 compatibility).
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| COMA | INH | 41 | 1 | 0 |

Operation: $\quad(\bar{B})=\$ F F-(B) \Rightarrow B$
Description: Replaces the content of accumulator B with its one's complement. Each bit of B is complemented. Immediately after a COM operation on unsigned values, only the BEQ, BNE, LBEQ, and LBNE branches can be expected to perform consistently. After operation on two's complement values, all signed branches are available.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | 1 |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
C: 1; Set (for M6800 compatibility).
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| COMB | INH | 51 | 1 | 0 |

Operation: $\quad(A: B)-(M: M+1)$
Description: Compares the content of double accumulator D with a 16-bit value at the address specified, and sets the condition codes accordingly. The compare is accomplished internally by a 16-bit subtract of $(M: M+1)$ from $D$ without modifying either $D$ or $(M: M+1)$.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: D15 • $\overline{\mathrm{M} 15} \cdot \overline{\mathrm{R} 15}+\mathrm{D} 15 \cdot \mathrm{M} 15 \cdot \mathrm{R} 15$
Set if two's complement overflow resulted from the operation; cleared otherwise.
$\mathrm{C}: \overline{\mathrm{D} 15} \cdot \mathrm{M} 15+\mathrm{M} 15 \cdot \mathrm{R} 15+\mathrm{R} 15+\overline{\mathrm{D} 15}$
Set if the absolute value of the content of memory is larger than the absolute value of the accumulator; cleared otherwise.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| CPD \#opr16i | IMM | 8C jj kk | 2 | OP |
| CPD opr8a | DIR | 9C dd | 3 | RfP |
| CPD opr16a | EXT | BC hh ll | 3 | ROP |
| CPD oprx0 xysp | IDX | AC xb | 3 | RfP |
| CPD oprx9, xysp | IDX1 | AC xb ff | 3 | RPO |
| CPD oprx16,xysp | IDX2 | AC xb ee ff | 4 | fRPP |
| CPD [D,xysp] | [D,IDX] | AC xb | 6 | fIfRfP |
| CPD [oprx16,xysp] | [IDX2] | AC xb ee ff | 6 | fIPRfP |

Operation: $\quad(S P)-(M: M+1)$
Description: Compares the content of the SP with a 16 -bit value at the address specified, and sets the condition codes accordingly. The compare is accomplished internally by doing a 16 -bit subtract of ( $M: M+1$ ) from the SP without modifying either the $S P$ or ( $M: M+1$ ).

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
$\mathrm{V}: \mathrm{S} 15 \cdot \mathrm{M} 15 \cdot \overline{\mathrm{R} 15}+\overline{\mathrm{S} 15} \cdot \overline{\mathrm{M} 15} \cdot \mathrm{R} 15$
Set if two's complement overflow resulted from the operation; cleared otherwise.
C: $\overline{\mathrm{S} 15} \cdot \mathrm{M} 15+\mathrm{M} 15 \cdot \mathrm{R} 15+\mathrm{R} 15+\overline{\mathrm{S} 15}$
Set if the absolute value of the content of memory is larger than the absolute value of the SP; cleared otherwise.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| CPS \#opr16i | IMM | 8F jj kk | 2 | OP |
| CPS opr8a | DIR | 9F dd | 3 | RfP |
| CPS opr16a | EXT | BF hh 11 | 3 | ROP |
| CPS oprx0_xysp | IDX | AF xb | 3 | RfP |
| CPS oprx9,xysp | IDX1 | AF xb ff | 3 | RPO |
| CPS oprx16,xysp | IDX2 | AF xb ee ff | 4 | fRPP |
| CPS [D, xysp] | [D,IDX] | AF xb | 6 | fIfRfP |
| CPS [oprx16,xysp] | [IDX2] | AF xb ee ff | 6 | fIPRfP |

Operation: $\quad(X)-(M: M+1)$
Description: Compares the content of index register $X$ with a 16-bit value at the address specified, and sets the condition codes accordingly. The compare is accomplished internally by a 16-bit subtract of (M:M+1) from index register $X$ without modifying either index register $X$ or $(M: M+1)$.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: X15 • $\overline{\mathrm{M} 15} \cdot \overline{\mathrm{R} 15}+\overline{\mathrm{X} 15} \cdot \mathrm{M} 15 \cdot \mathrm{R} 15$
Set if two's complement overflow resulted from the operation; cleared otherwise.
$\mathrm{C}: \overline{\mathrm{X} 15} \cdot \mathrm{M} 15+\mathrm{M} 15 \cdot \mathrm{R} 15+\mathrm{R} 15+\overline{\mathrm{X} 15}$
Set if the absolute value of the content of memory is larger than the absolute value of the index register; cleared otherwise.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| CPX \#opr16i | IMM | 8 jE jj kk | 2 | OP |
| CPX opr8a | DIR | 9 da dd | 3 | RfP |
| CPX opr16a | EXT | BE hh ll | 3 | ROP |
| CPX oprx0_xysp | IDX | AE xb | 3 | RfP |
| CPX oprx9,xysp | IDX1 | AE xb ff | 3 | RPO |
| CPX oprx16,xysp | IDX2 | AE xb ee ff | 4 | fRPP |
| CPX [D,xysp] | [D,IDX] | AE xb | 6 | fIfRfP |
| CPX [oprx16,xysp] | [IDX2] | AE xb ee ff | 6 | fIPRfP |

Operation: $\quad(\mathrm{Y})-(\mathrm{M}: \mathrm{M}+1)$
Description: Compares the content of index register Y to a 16 -bit value at the address specified, and sets the condition codes accordingly. The compare is accomplished internally by a 16 -bit subtract of ( $M: M+1$ ) from $Y$ without modifying either Y or $(\mathrm{M}: \mathrm{M}+1)$.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z : Set if result is $\$ 0000$; cleared otherwise.
V: Y15 • $\overline{\mathrm{M} 15} \cdot \overline{\mathrm{R} 15}+\overline{\mathrm{Y} 15} \cdot \mathrm{M} 15 \cdot \mathrm{R} 15$
Set if two's complement overflow resulted from the operation; cleared otherwise.
$\mathrm{C}: \overline{\mathrm{Y} 15} \cdot \mathrm{M} 15+\mathrm{M} 15 \cdot \mathrm{R} 15+\mathrm{R} 15+\overline{\mathrm{Y} 15}$
Set if the absolute value of the content of memory is larger than the absolute value of the index register; cleared otherwise.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| CPY \#opr16i | IMM | 8D jj kk | 2 | OP |
| CPY opr8a | DIR | $9 D$ dd | 3 | RfP |
| CPY opr16a | EXT | BD hh ll | 3 | ROP |
| CPY oprx0 $x y s p$ | IDX | AD xb | 3 | RfP |
| CPY oprx9,xysp | IDX1 | AD xb ff | 3 | RPO |
| CPY oprx16,xysp | IDX2 | AD xb ee ff | 4 | fRPP |
| CPY [D,xysp] | [D,IDX] | AD xb | 6 | fIfRfP |
| CPY [oprx16,xysp] | [IDX2] | AD xb ee ff | 6 | fIPRfP |

Description: DAA adjusts the content of accumulator $A$ and the state of the $C$ status bit to represent the correct binary-coded-decimal sum and the associated carry when a BCD calculation has been performed. In order to execute DAA, the content of accumulator $A$, the state of the $C$ status bit, and the state of the H status bit must all be the result of performing an $A B A$, ADD or ADC on BCD operands, with or without an initial carry.

The table below shows DAA operation for all legal combinations of input operands. Columns 1 through 4 represent the results of ABA, ADC, or ADD operations on BCD operands. The correction factor in column 5 is added to the accumulator to restore the result of an operation on two BCD operands to a valid BCD value, and to set or clear the C bit. All values are in hexadecimal.

| $\mathbf{1}$ | $\mathbf{2}$ | $\mathbf{3}$ | $\mathbf{4}$ | $\mathbf{5}$ | $\mathbf{6}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Initial <br> C Bit Value | Value of <br> A[7:4] | Initial <br> H Bit Value | Value of <br> A[3:0] | Correction <br> Factor | Corrected <br> C Bit Value |
| 0 | $0-9$ | 0 | $0-9$ | 00 | 0 |
| 0 | $0-8$ | 0 | A-F | 06 | 0 |
| 0 | $0-9$ | 1 | $0-3$ | 06 | 0 |
| 0 | A-F | 0 | $0-9$ | 60 | 1 |
| 0 | $9-F$ | 0 | A-F | 66 | 1 |
| 0 | A-F | 1 | $0-3$ | 66 | 1 |
| 1 | $0-2$ | 0 | $0-9$ | 60 | 1 |
| 1 | $0-2$ | 0 | A-F | 66 | 1 |
| 1 | $0-3$ | 1 | $0-3$ | 66 | 1 |

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $?$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: Undefined.
C: Represents BCD carry. See table above.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| DAA | INH | 1807 | 3 | $0 f 0$ |

## DBEQ

Operation: (Counter) $-1 \Rightarrow$ Counter
If (Counter) $=0$, then (PC) $+\$ 0003+$ Rel $\Rightarrow \mathrm{PC}$,
Description: Subtract one from the specified counter register A, B, D, X, Y, or SP. If the counter register has reached zero, execute a branch to the specified relative destination. The DBEQ instruction is encoded into three bytes of machine code including the 9 -bit relative offset ( -256 to +255 locations from the start of the next instruction).

IBEQ and TBEQ instructions are similar to DBEQ except that the counter is incremented or tested rather than being decremented. Bits 7 and 6 of the instruction postbyte are used to determine which operation is to be performed.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code ${ }^{1}$ | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| DBEQ abdxys, rel9 | REL | 04 lb rr | $3 / 3$ | PPP |

Notes:

1. Encoding for 1 lb is summarized in the following table. Bit 3 is not used (don't care), bit 5 selects branch on zero (DBEQ - 0 ) or not zero (DBNE -1) versions, and bit 4 is the sign bit of the 9 -bit relative offset. Bits 7 and 6 would be 0:0 for DBEQ.

| Count <br> Register | Bits 2:0 | Source Form | Object Code <br> (if offset is positive) | Object Code <br> (if offset is negative) |  |  |
| :---: | :---: | :--- | :--- | :--- | :--- | :--- |
| A | 000 | DBEQ A, rel9 | 04 | 00 | rr | 04 |

Operation: (Counter) $-1 \Rightarrow$ Counter
If (Counter) not $=0$, then (PC) $+\$ 0003+$ Rel $\Rightarrow \mathrm{PC}$,
Description: Subtract one from the specified counter register A, B, D, X, Y, or SP. If the counter register has not been decremented to zero, execute a branch to the specified relative destination. The DBNE instruction is encoded into three bytes of machine code including a 9 -bit relative offset ( -256 to +255 locations from the start of the next instruction).

IBNE and TBNE instructions are similar to DBNE except that the counter is incremented or tested rather than being decremented. Bits 7 and 6 of the instruction postbyte are used to determine which operation is to be performed.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code1 | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| DBNE abdxys, rel9 | REL | 04 lb rr | $3 / 3$ | PPP |

Notes:

1. Encoding for 1 lb is summarized in the following table. Bit 3 is not used (don't care), bit 5 selects branch on zero (DBEQ - 0 ) or not zero (DBNE -1) versions, and bit 4 is the sign bit of the 9 -bit relative offset. Bits 7 and 6 would be 0:0 for DBNE.

| Count <br> Register | Bits 2:0 | Source Form | Object Code <br> (if offset is positive) | Object Code <br> (if offset is negative) |  |  |
| :---: | :---: | :--- | :--- | :--- | :--- | :--- |
| A | 000 | DBNE A, rel9 | 04 | 20 | rr | 04 |

Operation: $\quad(\mathrm{M})-\$ 01 \Rightarrow \mathrm{M}$
Description: Subtract one from the content of memory location M.
The $\mathrm{N}, \mathrm{Z}$ and V status bits are set or cleared according to the results of the operation. The $C$ status bit is not affected by the operation, thus allowing the DEC instruction to be used as a loop counter in multiple-precision computations.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | - |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V : Set if there was a two's complement overflow as a result of the operation; cleared otherwise. Two's complement overflow occurs if and only if (M) was $\$ 80$ before the operation.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| DEC opr16a | EXT | 73 hh ll | 4 | rOPw |
| DEC oprx0_xysp | IDX | 63 xb | 3 | rPw |
| DEC oprx9,xysp | IDX1 | 63 xb ff | 4 | rPOw |
| DEC oprx16,xysp | IDX2 | 63 xb ee ff | 5 | frPPw |
| DEC [D,xysp] | [D,IDX] | 63 xb | 6 | fIfrPw |
| DEC [oprx16,xysp] | [IDX2] | 63 xb ee ff | 6 | fIPrPw |

## Decrement A

Operation: $\quad(A)-\$ 01 \Rightarrow A$
Description: Subtract one from the content of accumulator $A$.
The $\mathrm{N}, \mathrm{Z}$ and V status bits are set or cleared according to the results of the operation. The C status bit is not affected by the operation, thus allowing the DEC instruction to be used as a loop counter in multiple-precision computations.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ |  | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\mathbf{D}$ | $\mathbf{C}$ |  |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: Set if there was a two's complement overflow as a result of the operation; cleared otherwise. Two's complement overflow occurs if and only if (A) was $\$ 80$ before the operation.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| DECA | INH | 43 | 1 | 0 |

## Decrement B

Operation: $\quad(B)-\$ 01 \Rightarrow B$
Description: Subtract one from the content of accumulator B.
The $\mathrm{N}, \mathrm{Z}$ and V status bits are set or cleared according to the results of the operation. The C status bit is not affected by the operation, thus allowing the DEC instruction to be used as a loop counter in multiple-precision computations.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ |  | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\mathbf{D}$ | $\mathbf{C}$ |  |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: Set if there was a two's complement overflow as a result of the operation; cleared otherwise. Two's complement overflow occurs if and only if (B) was $\$ 80$ before the operation.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :---: |
| DECB | INH | 53 | 1 | 0 |

Operation: $\quad(S P)-\$ 0001 \Rightarrow S P$
Description: Subtract one from the SP. This instruction assembles to LEAS -1,SP. The LEAS instruction does not affect condition codes as DEX or DEY instructions do.

Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| DES translates to... <br> LEAS $-1, S P$ | IDX | 1 B 9 F | 2 | $\mathrm{PP}^{1}$ |

Notes:

1. Due to internal CPU requirements, the program word fetch is performed twice to the same address during this instruction.

Operation: $\quad(X)-\$ 0001 \Rightarrow X$
Description: Subtract one from index register $X$. LEAX $-1, X$ can produce the same result, but LEAX does not affect the $Z$ bit. Although the LEAX instruction is more flexible, DEX requires only one byte of object code.

Only the $Z$ bit is set or cleared according to the result of this operation.
Condition Codes and Boolean Formulas:


Z: Set if result is $\$ 0000$; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| DEX | INH | 09 | 1 | 0 |

Operation: $\quad(\mathrm{Y})-\$ 0001 \Rightarrow \mathrm{Y}$
Description: Subtract one from index register Y. LEAY $-1, Y$ can produce the same result, but LEAY does not affect the $Z$ bit. Although the LEAY instruction is more flexible, DEY requires only one byte of object code.

Only the Z bit is set or cleared according to the result of this operation.
Condition Codes and Boolean Formulas:


Z: Set if result is $\$ 0000$; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| DEY | INH | 03 | 1 | 0 |

Operation: $\quad(Y: D) \div(X) \Rightarrow Y$; Remainder $\Rightarrow D$
Description: Divides a 32 -bit unsigned dividend by a 16 -bit divisor, producing a 16 -bit unsigned quotient and an unsigned 16 -bit remainder. All operands and results are located in CPU registers. If an attempt to divide by zero is made, the contents of double accumulator D and index register Y do not change, but the states of the N and Z bits in the CCR are undefined.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise. Undefined after overflow or division by zero.
Z: Set if result is \$0000; cleared otherwise. Undefined after overflow or division by zero.
V: Set if the result was > \$FFFF; cleared otherwise. Undefined after division by zero.
C: Set if divisor was \$0000; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| EDIV | INH | 11 | 11 | $f f f f f f f f f f 0$ |

Operation: $\quad(Y: D) \div(X) \Rightarrow Y ;$ Remainder $\Rightarrow D$
Description: Divides a signed 32 -bit dividend by a 16 -bit signed divisor, producing a signed 16 -bit quotient and a signed 16 -bit remainder. All operands and results are located in CPU registers. If an attempt to divide by zero is made, the C status bit is set and the contents of double accumulator D and index register Y do not change, but the states of the N and Z bits in the CCR are undefined.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise. Undefined after overflow or division by zero.
Z: Set if result is $\$ 0000$; cleared otherwise. Undefined after overflow or division by zero.
V: Set if the result was $>\$ 7 F F F$ or $<\$ 8000$; cleared otherwise. Undefined after division by zero.
C: Set if divisor was $\$ 0000$; cleared otherwise. (Indicates division by zero.)
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| EDIVS | INH | 1814 | 12 | Offffffffff0 |

Operation: $\quad\left(\mathrm{M}_{(\mathrm{X})}: \mathrm{M}_{(\mathrm{X}+1)}\right) \times\left(\mathrm{M}_{(\mathrm{Y})}: \mathrm{M}_{(\mathrm{Y}+1)}\right)+(\mathrm{M} \sim \mathrm{M}+3) \Rightarrow \mathrm{M} \sim \mathrm{M}+3$
Description: A 16 -bit value is multiplied by a 16 -bit value to produce a 32 -bit intermediate result. This 32 -bit intermediate result is then added to the content of a 32-bit accumulator in memory. EMACS is a signed integer operation. All operands and results are located in memory. When the EMACS instruction is executed, the first source operand is fetched from an address pointed to by X , and the second source operand is fetched from an address pointed to by index register Y . Before the instruction is executed, the X and Y index registers must contain values that point to the most significant bytes of the source operands. The most significant byte of the 32 -bit result is specified by an extended address supplied with the instruction.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00000000$; cleared otherwise.
V: M31 • I31 • $\overline{\mathrm{R} 31}+\overline{\mathrm{M} 31} \cdot \overline{\mathrm{I} 1} \cdot \mathrm{R} 31$
Set if result > \$7FFFFFFF (+ overflow) or < \$80000000 (- underflow). Indicates two's complement overflow.
C: $\mathrm{M} 15 \cdot \mathrm{I} 15+\mathrm{I} 15 \cdot \overline{\mathrm{R} 15}+\overline{\mathrm{R} 15} \cdot \mathrm{M} 15$
Set if there was a carry from bit 15 of the result; cleared otherwise. Indicates a carry from low word to high word of the result occurred.

Addressing Modes, Machine Code, and Execution Times:

| Source Form1 | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| EMACS opr16a | Special | 1812 hh ll | 13 | ORROfffRRfWWP |

Notes:

1. opr16a is an extended address specification. Both X and Y point to source operands.

Operation: $\quad \operatorname{MAX}((D),(M: M+1)) \Rightarrow D$
Description: Subtracts an unsigned 16-bit value in memory from an unsigned 16-bit value in double accumulator $D$ to determine which is larger, and leaves the larger of the two values in $D$. The $Z$ status bit is set when the result of the subtraction is zero (the values are equal), and the C status bit is set when the subtraction requires a borrow (the value in memory is larger than the value in the accumulator). When $C=1$, the value in $D$ has been replaced by the value in memory.

The unsigned value in memory is accessed by means of indexed addressing modes, which allow a great deal of flexibility in specifying the address of the operand. Auto increment/decrement variations of indexed addressing facilitate finding the largest value in a list of values.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: D15• $\overline{\mathrm{M} 15} \cdot \overline{\mathrm{R} 15}+\overline{\mathrm{D} 15} \cdot \mathrm{M} 15 \cdot \mathrm{R} 15$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
C: $\overline{\mathrm{D} 15} \cdot \mathrm{M} 15+\mathrm{M} 15 \cdot \mathrm{R} 15+\mathrm{R} 15 \cdot \overline{\mathrm{D} 15}$
Set if the value of the content of memory is larger than the value of the accumulator; cleared otherwise.
Condition codes reflect internal subtraction ( $R=D-M: M+1$ ).

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| EMAXD oprx0_xysp | IDX | 18 1A xb | 4 | ORfP |
| EMAXD oprx9,xysp | IDX1 | $18 \mathrm{1A} \mathrm{xb} \mathrm{ff}$ | 4 | ORPO |
| EMAXD oprx16,xysp | IDX2 | 18 1A xb ee ff | 5 | OfRPP |
| EMAXD [D, xysp] | [D,IDX] | 18 1A xb | 7 | OfIfRfP |
| EMAXD [oprx16,xysp] | [IDX2] | 181 Alb ee ff | 7 | OfIPRfP |

Operation: $\quad \operatorname{MAX}((D),(M: M+1)) \Rightarrow M: M+1$
Description: Subtracts an unsigned 16-bit value in memory from an unsigned 16-bit value in double accumulator D to determine which is larger, and leaves the larger of the two values in the memory location. The Z status bit is set when the result of the subtraction is zero (the values are equal), and the $C$ status bit is set when the subtraction requires a borrow (the value in memory is larger than the value in the accumulator). When $C=0$, the value in $D$ has replaced the value in memory.

The unsigned value in memory is accessed by means of indexed addressing modes, which allow a great deal of flexibility in specifying the address of the operand.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: D15 • $\overline{\mathrm{M} 15} \cdot \overline{\mathrm{R} 15}+\overline{\mathrm{D} 15} \cdot \mathrm{M} 15 \cdot \mathrm{R} 15$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
C: $\overline{\mathrm{D} 15} \cdot \mathrm{M} 15+\mathrm{M} 15 \cdot \mathrm{R} 15+\mathrm{R} 15 \cdot \overline{\mathrm{D} 15}$
Set if the value of the content of memory is larger than the value of the accumulator; cleared otherwise.
Condition codes reflect internal subtraction ( $R=D-M: M+1$ ).
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| EMAXM oprx0_xysp | IDX | 181 E xb | 4 | ORPW |
| EMAXM oprx9,xysp | IDX1 | 18 le xb ff | 5 | ORPWO |
| EMAXM oprx16,xysp | IDX2 | 181 Exb ee ff | 6 | OfRPWP |
| EMAXM [D,xysp] | [D,IDX] | 181 Exb | 7 | OfIfRPW |
| EMAXM [oprx16,xysp] | [IDX2] | 181 Exb ee ff | 7 | OfIPRPW |

Operation: $\quad \operatorname{MIN}((\mathrm{D}),(\mathrm{M}: \mathrm{M}+1)) \Rightarrow \mathrm{D}$
Description: Subtracts an unsigned 16-bit value in memory from an unsigned 16-bit value in double accumulator D to determine which is larger, and leaves the smaller of the two values in $D$. The $Z$ status bit is set when the result of the subtraction is zero (the values are equal), and the C status bit is set when the subtraction requires a borrow (the value in memory is larger than the value in the accumulator). When $C=0$, the value in $D$ has been replaced by the value in memory.

The unsigned value in memory is accessed by means of indexed addressing modes, which allow a great deal of flexibility in specifying the address of the operand. Auto increment/decrement variations of indexed addressing facilitate finding the largest value in a list of values.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: D15 • $\overline{\mathrm{M} 15} \cdot \overline{\mathrm{R} 15}+\overline{\mathrm{D} 15} \cdot \mathrm{M} 15 \cdot \mathrm{R} 15$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
C: $\overline{\mathrm{D} 15} \cdot \mathrm{M} 15+\mathrm{M} 15 \cdot \mathrm{R} 15+\mathrm{R} 15 \cdot \overline{\mathrm{D} 15}$
Set if the value of the content of memory is larger than the value of the accumulator; cleared otherwise.
Condition codes reflect internal subtraction ( $R=D-M: M+1$ ).
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| EMIND oprx0_xysp | IDX | 18 1B xb | 4 | ORfP |
| EMIND oprx9,xysp | IDX1 | 18 lB xb ff | 4 | ORPO |
| EMIND oprx16,xysp | IDX2 | 181 Brb ee ff | 5 | OfRPP |
| EMIND [D,xysp] | [D,IDX] | 181 Brb | 7 | OfIfRfP |
| EMIND [oprx16,xysp] | [IDX2] | 181 Brb ee ff | 7 | OfIPRfP |

Operation: $\quad \operatorname{MIN}((D),(M: M+1)) \Rightarrow M: M+1$
Description: Subtracts an unsigned 16-bit value in memory from an unsigned 16-bit value in double accumulator D to determine which is larger, and leaves the smaller of the two values in the memory location. The $Z$ status bit is set when the result of the subtraction is zero (the values are equal), and the $C$ status bit is set when the subtraction requires a borrow (the value in memory is larger than the value in the accumulator). When $C=1$, the value in $D$ has replaced the value in memory.

The unsigned value in memory is accessed by means of indexed addressing modes, which allow a great deal of flexibility in specifying the address of the operand.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

$\mathrm{N}: ~ S e t$ if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: D15 • $\overline{\mathrm{M} 15} \cdot \overline{\mathrm{R} 15}+\overline{\mathrm{D} 15} \cdot \mathrm{M} 15 \cdot \mathrm{R} 15$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
C: $\overline{\mathrm{D} 15} \cdot \mathrm{M} 15+\mathrm{M} 15 \cdot \mathrm{R} 15+\mathrm{R} 15 \cdot \overline{\mathrm{D} 15}$
Set if the value of the content of memory is larger than the value of the accumulator; cleared otherwise.

Condition codes reflect internal subtraction ( $R=D-M: M+1$ ).
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| EMINM oprx0_xysp | IDX | 181 F xb | 4 | ORPW |
| EMINM oprx9,xysp | IDX1 | 181 Fb ff | 5 | ORPWO |
| EMINM oprx16,xysp | IDX2 | 181 F xb ee ff | 6 | OfRPWP |
| EMINM [D,xysp] | [D,IDX] | 181 F xb | 7 | OfIfRPW |
| EMINM [oprx16,xysp] | [IDX2] | 181 Fb ee ff | 7 | OfIPRPW |

Operation: $\quad(\mathrm{D}) \times(\mathrm{Y}) \Rightarrow \mathrm{Y}: \mathrm{D}$
Description: An unsigned 16-bit value is multiplied by an unsigned 16-bit value to produce an unsigned 32-bit result. The first source operand must be loaded into 16-bit double accumulator $D$ and the second source operand must be loaded into index register Y before executing the instruction. When the instruction is executed, the value in D is multiplied by the value in Y . The upper 16-bits of the 32-bit result are stored in Y and the low-order 16 -bits of the result are stored in D.

The $C$ status bit can be used to round the high-order 16 bits of the result.

## Condition Codes and Boolean Formulas:



N : Set if the MSB of the result is set; cleared otherwise.
Z: Set if result is $\$ 00000000$; cleared otherwise.
C: Set if bit 15 of the result is set; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| EMUL | INH | 13 | 3 | $f f 0$ |

Operation: $\quad(\mathrm{D}) \times(\mathrm{Y}) \Rightarrow \mathrm{Y}: \mathrm{D}$
Description: A signed 16-bit value is multiplied by a signed 16-bit value to produce a signed 32-bit result. The first source operand must be loaded into 16-bit double accumulator $D$ and the second source operand must be loaded into index register Y before executing the instruction. When the instruction is executed, D is multiplied by the value Y . The 16 high-order bits of the 32-bit result are stored in Y and the 16 low-order bits of the result are stored in D.

The $C$ status bit can be used to round the high-order 16 bits of the result.

## Condition Codes and Boolean Formulas:



N : Set if the MSB of the result is set; cleared otherwise.
Z: Set if result is $\$ 00000000$; cleared otherwise.
C: Set if bit 15 of the result is set; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| EMULS | INH | 1813 | 3 | $0 £ 0$ |

## Exclusive-OR A

Operation: $\quad(A) \oplus(M) \Rightarrow A$
Description: Performs the logical exclusive OR between the content of accumulator A and the content of memory location M . The result is placed in A . Each bit of $A$ after the operation is the logical exclusive OR of the corresponding bits of M and A before the operation.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| EORA \#opr8i | IMM | 88 ii | 1 | P |
| EORA opr8a | DIR | 98 dd | 3 | rfP |
| EORA opr16a | EXT | B8 hh ll | 3 | rop |
| EORA oprx0_xysp | IDX | A8 xb | 3 | rfP |
| EORA oprx9,xysp | IDX1 | A8 xb ff | 3 | rPO |
| EORA oprx16,xysp | IDX2 | A8 xb ee ff | 4 | frPP |
| EORA [D,xysp] | [D,IDX] | A8 xb | 6 | fIfrfP |
| EORA [oprx16,xysp] | $[I D X 2] ~$ | A8 xb ee ff | 6 | fIPrfP |

## Exclusive-OR B

Operation: $\quad(B) \oplus(M) \Rightarrow B$
Description: Performs the logical exclusive OR between the content of accumulator B and the content of memory location M. The result is placed in A. Each bit of A after the operation is the logical exclusive OR of the corresponding bits of M and B before the operation.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| EORB \#opr8i | IMM | C8 ii | 1 | P |
| EORB opr8a | DIR | D8 dd | 3 | rfP |
| EORB opr16a | EXT | F8 hh ll | 3 | rOP |
| EORB oprx0_xysp | IDX | E8 xb | 3 | rfP |
| EORB oprx9,xysp | IDX1 | E8 xb ff | 3 | rPO |
| EORB oprx16,xysp | IDX2 | E8 xb ee ff | 4 | frPP |
| EORB [D,xysp] | [D,IDX] | E8 xb | 6 | fIfrfP |
| EORB [oprx16,xysp] | $[I D X 2] ~$ | E8 xb ee ff | 6 | fIPrfP |

Operation: $\quad(M: M+1)+[(B) \times((M+2: M+3)-(M: M+1))] \Rightarrow D$
Description: ETBL linearly interpolates one of 256 result values that fall between each pair of data entries in a lookup table stored in memory. Data points in the table represent the endpoints of equally-spaced line segments. Table entries and the interpolated result are 16 -bit values. The result is stored in the D accumulator.

Before executing ETBL, set up an index register so that it points to the starting point (X1) of a line segment when the instruction is executed. X 1 is the table entry closest to, but less than or equal to, the desired lookup value. The next table entry after X 1 is $\mathrm{X} 2 . \mathrm{XL}$ is the distance in X between X 1 and X 2 . Load accumulator B with a binary fraction (radix point to left of MSB) representing the ratio (XL-X1) $\div(\mathrm{X} 2-\mathrm{X} 1)$.

The 16-bit unrounded result is calculated using the following expression:

$$
\mathrm{D}=\mathrm{Y} 1+[(\mathrm{B}) \times(\mathrm{Y} 2-\mathrm{Y} 1)]
$$

Where
(B) $=(\mathrm{XL}-\mathrm{X} 1) \div(\mathrm{X} 2-\mathrm{X} 1)$

$$
\begin{aligned}
& \text { Y1 }=16 \text {-bit data entry pointed to by <effective address> } \\
& \text { Y2 }=16 \text {-bit data entry pointed to by <effective address> }+2
\end{aligned}
$$

The intermediate value $[(\mathrm{B}) \times(\mathrm{Y} 2-\mathrm{Y} 1)]$ produces a 24 -bit result with the radix point between bits 7 and 8 . Any indexed addressing mode, except indirect modes or 9 -bit and 16 -bit offset modes, can be used to identify the first data point (X1, Y1). The second data point is the next table entry.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | - | $?$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
C: Undefined.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| ETBL oprxO_xysp | IDX | 183 F xb | 10 | ORRfffffff |

## Exchange Register Contents

Operation: See table
Description: Exchanges the contents of registers specified in the instruction as shown below. Note that the order in which exchanges between 8 -bit and 16 -bit registers are specified affects the high byte of the 16-bit registers differently. Exchanges of D with A or B are ambiguous. Cases involving TMP2 and TMP3 are reserved for Motorola use, so some assemblers may not permit their use, but it is possible to generate these cases by using DC.B or DC.W assembler directives.

## Condition Codes and Boolean Formulas:



None affected, unless the CCR is the destination register. Condition codes take on the value of the corresponding source bits, except that the X mask bit cannot change from zero to one. Software can leave the X bit set, leave it cleared, or change it from one to zero, but it can only be set by a reset or by recognition of an XIRQ interrupt.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code1 | Cycles | Access Detail |
| :---: | :---: | :--- | :---: | :---: |
| EXG $a b c d x y s, a b c d x y s$ | INH | B7 eb | 1 | P |

Notes:

1. Legal coding for eb is summarized in the following table. Columns represent the high-order source digit. Rows represent the low-order destination digit (bit 3 is a don't-care). Values are in hexadecimal.

|  | 8 | 9 | A | B | C | D | E | F |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $A \Leftrightarrow A$ | $B \Leftrightarrow A$ | $C C R \Leftrightarrow A$ | $\begin{gathered} \mathrm{TMP} 3_{\mathrm{L}} \Rightarrow \mathrm{~A} \\ \$ 00: \mathrm{A} \Rightarrow \mathrm{TMP3} \end{gathered}$ | $\begin{aligned} & B \Rightarrow A \\ & A \Rightarrow B \end{aligned}$ | $\begin{gathered} X_{L} \Rightarrow A \\ \$ 00: A \Rightarrow X \end{gathered}$ | $\begin{gathered} Y_{L} \Rightarrow A \\ \$ 00: A \Rightarrow Y \end{gathered}$ | $\begin{aligned} S P_{\mathrm{L}} & \Rightarrow \mathrm{~A} \\ \$ 00: \mathrm{A} & \Rightarrow \mathrm{SP} \end{aligned}$ |
| 1 | $A \Leftrightarrow B$ | $B \Leftrightarrow B$ | $C C R \Leftrightarrow B$ | $\begin{gathered} \mathrm{TMP} 3_{\mathrm{L}} \Rightarrow \mathrm{~B} \\ \$ F F: B \Rightarrow \mathrm{TMP3} \end{gathered}$ | $\begin{gathered} B \Rightarrow B \\ \$ F F \Rightarrow A \end{gathered}$ | $\begin{gathered} X_{L} \Rightarrow B \\ \$ F F: B \Rightarrow X \end{gathered}$ | $\begin{gathered} Y_{L} \Rightarrow B \\ \$ F F: B \Rightarrow Y \end{gathered}$ | $\begin{aligned} \mathrm{SP} \mathrm{~L}_{\mathrm{L}} & \Rightarrow \mathrm{~B} \\ \$ \mathrm{FF}: \mathrm{B} & \Rightarrow \mathrm{SP} \end{aligned}$ |
| 2 | A $\Leftrightarrow$ CCR | $B \Leftrightarrow C C R$ | CCR $\Leftrightarrow$ CCR | $\begin{array}{c\|} \mathrm{TMP3}_{\mathrm{L}} \Rightarrow \mathrm{CCR} \\ \text { \$FF:CR } \Rightarrow \mathrm{TMP3} \end{array}$ | $\begin{gathered} \mathrm{B} \Rightarrow \mathrm{CCR} \\ \$ F F: C C R \Rightarrow D \end{gathered}$ | $\begin{gathered} \mathrm{X}_{\mathrm{L}} \Rightarrow \mathrm{CCR} \\ \text { \$FF:CCR } \Rightarrow \mathrm{X} \end{gathered}$ | $\begin{gathered} Y_{L} \Rightarrow C C R \\ \$ F F: C C R \Rightarrow Y \end{gathered}$ | $\begin{gathered} \mathrm{SP} \mathrm{~L}_{\mathrm{L}} \Rightarrow \mathrm{CCR} \\ \$ \mathrm{FF}: \mathrm{CCR} \Rightarrow \mathrm{SP} \end{gathered}$ |
| 3 | $\begin{gathered} \$ 00: \mathrm{A} \Rightarrow \mathrm{TMP2} \\ \mathrm{TMP} 2_{\mathrm{L}} \Rightarrow \mathrm{~A} \end{gathered}$ | $\begin{gathered} \$ 00: B \Rightarrow \mathrm{TMP2} \\ \mathrm{TMP2} 2 \Rightarrow \mathrm{~B} \end{gathered}$ | $\begin{gathered} \$ 00: C C R \Rightarrow \text { TMP2 } \\ \text { TMP2L } \Rightarrow \text { CCR } \end{gathered}$ | TMP3 $\Leftrightarrow$ TMP2 | $\mathrm{D} \Leftrightarrow \mathrm{TMP2}$ | $\mathrm{X} \Leftrightarrow$ TMP2 | $Y \Leftrightarrow T M P 2$ | SP $\Leftrightarrow$ TMP2 |
| 4 | \$00:A $\Rightarrow$ D | \$00:B $\Rightarrow$ D | $\begin{gathered} \$ 00: C C R \Rightarrow D \\ B \Rightarrow C C R \end{gathered}$ | TMP3 $\Leftrightarrow$ D | $\mathrm{D} \Leftrightarrow \mathrm{D}$ | $\mathrm{X} \Leftrightarrow \mathrm{D}$ | $Y \Leftrightarrow D$ | $\mathrm{SP} \Leftrightarrow \mathrm{D}$ |
| 5 | $\begin{gathered} \$ 00: A \Rightarrow X \\ X_{L} \Rightarrow A \end{gathered}$ | $\begin{gathered} \$ 00: B \Rightarrow X \\ X_{L} \Rightarrow B \end{gathered}$ | $\begin{gathered} \$ 00: C C R \Rightarrow X \\ X_{L} \Rightarrow C C R \end{gathered}$ | TMP3 $\Leftrightarrow$ X | $D \Leftrightarrow X$ | $\mathrm{X} \Leftrightarrow \mathrm{X}$ | $Y \Leftrightarrow X$ | SP $\Leftrightarrow \mathrm{X}$ |
| 6 | $\begin{gathered} \$ 00: A \Rightarrow Y \\ Y_{L} \Rightarrow A \end{gathered}$ | $\begin{gathered} \$ 00: B \Rightarrow Y \\ Y_{L} \Rightarrow B \end{gathered}$ | $\begin{gathered} \$ 00: C C R \Rightarrow Y \\ Y_{L} \Rightarrow C C R \end{gathered}$ | TMP3 $\Leftrightarrow \mathrm{Y}$ | $D \Leftrightarrow Y$ | $X \Leftrightarrow Y$ | $Y \Leftrightarrow Y$ | SP $\Leftrightarrow \mathrm{Y}$ |
| 7 | $\begin{gathered} \$ 00: \mathrm{A} \Rightarrow \mathrm{SP} \\ \mathrm{SP} \mathrm{~L} \end{gathered}$ | $\begin{gathered} \$ 00: \mathrm{B} \Rightarrow \mathrm{SP} \\ \mathrm{SP}=\mathrm{B} \end{gathered}$ | $\begin{gathered} \$ 00: C C R \Rightarrow S P \\ S P_{L} \Rightarrow C C R \end{gathered}$ | TMP3 $\Leftrightarrow$ SP | $\mathrm{D} \Leftrightarrow \mathrm{SP}$ | $\mathrm{X} \Leftrightarrow \mathrm{SP}$ | $Y \Leftrightarrow S P$ | SP $\Leftrightarrow$ SP |

Operation: $\quad(D) \div(X) \Rightarrow X$; Remainder $\Rightarrow D$
Description: Divides an unsigned 16-bit numerator in double accumulator $D$ by an unsigned 16-bit denominator in index register $X$, producing an unsigned 16 -bit quotient in $X$, and an unsigned 16-bit remainder in $D$. If both the numerator and the denominator are assumed to have radix points in the same positions, the radix point of the quotient is to the left of bit 15 . The numerator must be less than the denominator. In the case of overflow (denominator is less than or equal to the numerator) or division by zero, the quotient is set to \$FFFF, and the remainder is indeterminate.

FDIV is equivalent to multiplying the numerator by 216 and then performing $32 \times 16$-bit integer division. The result is interpreted as a binaryweighted fraction, which resulted from the division of a 16-bit integer by a larger 16 -bit integer. A result of $\$ 0001$ corresponds to 0.000015 , and $\$$ FFFF corresponds to 0.9998 . The remainder of an IDIV instruction can be resolved into a binary-weighted fraction by an FDIV instruction. The remainder of an FDIV instruction can be resolved into the next 16 bits of binary-weighted fraction by another FDIV instruction.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ |

Z: Set if quotient is $\$ 0000$; cleared otherwise.
$V$ : 1 if $X \leq D$
Set if the denominator was less than or equal to the numerator; cleared otherwise.
$\mathrm{C}: \overline{\mathrm{X} 15} \cdot \overline{\mathrm{X} 14} \cdot \overline{\mathrm{X} 13} \cdot \overline{\mathrm{X} 12} \cdot \ldots \cdot \overline{\mathrm{X} 3} \cdot \overline{\mathrm{X} 2} \cdot \overline{\mathrm{X} 1} \cdot \overline{\mathrm{X} 0}$
Set if denominator was $\$ 0000$; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| FDIV | INH | 1811 | 12 | Offffffffffo |

Operation: $\quad($ Counter $)+1 \Rightarrow$ Counter
If (Counter) $=0$, then $(\mathrm{PC})+\$ 0003+$ Rel $\Rightarrow \mathrm{PC}$,
Description: Add one to the specified counter register A, B, D, X, Y, or SP. If the counter register has reached zero, branch to the specified relative destination. The IBEQ instruction is encoded into three bytes of machine code including a 9 -bit relative offset ( -256 to +255 locations from the start of the next instruction).

DBEQ and TBEQ instructions are similar to IBEQ except that the counter is decremented or tested rather than being incremented. Bits 7 and 6 of the instruction postbyte are used to determine which operation is to be performed.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code ${ }^{1}$ | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| IBEQ abdXys, rel9 | REL | 041 br | $3 / 3$ | PPP |

Notes:

1. Encoding for 1 lb is summarized in the following table. Bit 3 is not used (don't care), bit 5 selects branch on zero (IBEQ - 0) or not zero (IBNE -1) versions, and bit 0 is the sign bit of the 9 -bit relative offset. Bits 7 and 6 should be 1:0 for IBEQ.

| Count Register | Bits 2:0 | Source Form | Object Code <br> (if offset is positive) | Object Code (if offset is negative) |
| :---: | :---: | :---: | :---: | :---: |
| A | 000 | IBEQ A, rel9 | 0480 rr | 0490 rr |
| B | 001 | IBEQ B, rel9 | 0481 rr | 0491 rr |
| D | 100 | IBEQ D, rel9 | 0484 rr | 0494 rr |
| X | 101 | IBEQ X, rel9 | 0485 rr | 0495 rr |
| Y | 110 | IBEQ Y, rel9 | 0486 rr | 0496 rr |
| SP | 111 | IBEQ SP, rel9 | 0487 rr | 0497 rr |

Operation: $\quad$ (Counter) $+1 \Rightarrow$ Counter
If (Counter) not $=0$, then (PC) $+\$ 0003+\mathrm{Rel} \Rightarrow \mathrm{PC}$
Description: Add one to the specified counter register A, B, D, X, Y, or SP. If the counter register has not been incremented to zero, branch to the specified relative destination. The IBNE instruction is encoded into three bytes of machine code including a 9 -bit relative offset ( -256 to +255 locations from the start of the next instruction).

DBNE and TBNE instructions are similar to IBNE except that the counter is decremented or tested rather than being incremented. Bits 7 and 6 of the instruction postbyte are used to determine which operation is to be performed.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code1 | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| IBNE abdxys, rel9 | REL | 04 lb rr | $3 / 3$ | PPP |

Notes:

1. Encoding for 1 lb is summarized in the following table. Bit 3 is not used (don't care), bit 5 selects branch on zero (IBEQ -0 ) or not zero (IBNE -1) versions, and bit 0 is the sign bit of the 9 -bit relative offset. Bits 7 and 6 should be 1:0 for IBNE.

| Count <br> Register | Bits 2:0 | Source Form | Object Code <br> (if offset is positive) | Object Code (if offset is negative) |
| :---: | :---: | :---: | :---: | :---: |
| A | 000 | IBNE A, rel9 | 04 A0 rr | 04 BO rr |
| B | 001 | IBNE B, rel9 | 04 Al rr | $04 \mathrm{B1} \mathrm{rr}$ |
| D | 100 | IBNE D, rel9 | 04 A4 rr | 04 B4 rr |
| X | 101 | IBNE X, rel9 | 04 A5 rr | $04 \mathrm{B5}$ rr |
| Y | 110 | IBNE Y, rel9 | 04 A6 rr | 04 B6 rr |
| SP | 111 | IBNE SP, rel9 | 04 A7 rr | $04 \mathrm{B7} \mathrm{rr}$ |

Operation: $\quad(D) \div(X) \Rightarrow X$; Remainder $\Rightarrow D$
Description: Divides an unsigned 16-bit dividend in double accumulator $D$ by an unsigned 16-bit divisor in index register X, producing an unsigned 16-bit quotient in $X$, and an unsigned 16-bit remainder in D . If both the divisor and the dividend are assumed to have radix points in the same positions, the radix point of the quotient is to the right of bit zero. In the case of division by zero, the quotient is set to \$FFFF, and the remainder is indeterminate.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | $\Delta$ | 0 | $\Delta$ |

Z: Set if quotient is $\$ 0000$; cleared otherwise.
V: 0; Cleared.
C: $\overline{\mathrm{X} 15} \cdot \overline{\mathrm{X} 14} \cdot \overline{\mathrm{X} 13} \cdot \overline{\mathrm{X} 12} \cdot \ldots \cdot \overline{\mathrm{X} 3} \cdot \overline{\mathrm{X} 2} \cdot \overline{\mathrm{X} 1} \cdot \overline{\mathrm{X} 0}$
Set if denominator was $\$ 0000$; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| IDIV | INH | 1810 | 12 | Offffffffff0 |

Operation: $\quad(D) \div(X) \Rightarrow X$; Remainder $\Rightarrow D$
Description: Performs signed integer division of a signed 16-bit numerator in double accumulator D by a signed 16-bit denominator in index register X, producing a signed 16 -bit quotient in $X$, and a signed 16 -bit remainder in $D$. If division by zero is attempted, the values in $D$ and $X$ are not changed, but the values of the $\mathrm{N}, \mathrm{Z}$, and V status bits are undefined.

Other than division by zero, which is not legal and causes the $C$ status bit to be set, the only overflow case is:

$$
\frac{\$ 8000}{\$ F F F F}=\frac{-32,768}{-1}=+32,768
$$

But the highest positive value that can be represented in a 16-bit two's complement number is 32,767 (\$7FFFF).

## Condition Codes and Boolean Formulas:

| S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise. Undefined after overflow or division by zero.
Z: Set if quotient is $\$ 0000$; cleared otherwise. Undefined after overflow or division by zero.
V: Set if the result was $>\$ 7 F F F$ or $<\$ 8000$; cleared otherwise. Undefined after division by zero.
C: $\overline{\mathrm{X} 15} \cdot \overline{\mathrm{X} 14} \cdot \overline{\mathrm{X} 13} \cdot \overline{\mathrm{X} 12} \cdot \ldots \cdot \overline{\mathrm{X} 3} \cdot \overline{\mathrm{X} 2} \cdot \overline{\mathrm{X} 1} \cdot \overline{\mathrm{X0}}$
Set if denominator was $\$ 0000$; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| IDIVS | INH | 1815 | 12 | Offffffffffo |

Operation: $\quad(M)+\$ 01 \Rightarrow M$
Description: Add one to the content of memory location M.
The $\mathrm{N}, \mathrm{Z}$ and V status bits are set or cleared according to the results of the operation. The C status bit is not affected by the operation, thus allowing the INC instruction to be used as a loop counter in multiple-precision computations.

When operating on unsigned values, only BEQ, BNE, LBEQ, and LBNE branches can be expected to perform consistently. When operating on two's complement values, all signed branches are available.

## Condition Codes and Boolean Formulas:



N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is \$00; cleared otherwise.
V : Set if there is a two's complement overflow as a result of the operation; cleared otherwise. Two's complement overflow occurs if and only if $(\mathrm{M})$ was \$7F before the operation.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| INC opr16a | EXT | 72 hh ll | 4 | rOPw |
| INC oprx0_xysp | IDX | 62 xb | 3 | rPw |
| INC oprx9,xysp | IDX1 | 62 xb ff | 4 | rPOw |
| INC oprx16,xysp | IDX2 | 62 xb ee ff | 5 | frPPw |
| INC [D,xysp] | [D,IDX] | 62 xb | 6 | fIfrPw |
| INC [oprx16,xysp] | [IDX2] | 62 xb ee ff | 6 | fIPrPw |

Operation: $\quad(A)+\$ 01 \Rightarrow A$
Description: Add one to the content of accumulator A.
The $\mathrm{N}, \mathrm{Z}$ and V status bits are set or cleared according to the results of the operation. The C status bit is not affected by the operation, thus allowing the INC instruction to be used as a loop counter in multiple-precision computations.

When operating on unsigned values, only BEQ, BNE, LBEQ, and LBNE branches can be expected to perform consistently. When operating on two's complement values, all signed branches are available.

## Condition Codes and Boolean Formulas:



N : Set if MSB of result is set; cleared otherwise.
$Z$ : Set if result is $\$ 00$; cleared otherwise.
V : Set if there is a two's complement overflow as a result of the operation; cleared otherwise. Two's complement overflow occurs if and only if $(A)$ was \$7F before the operation.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| INCA | INH | 42 | 1 | 0 |

Operation: $\quad(B)+\$ 01 \Rightarrow B$
Description: Add one to the content of accumulator B.
The N, Z and V status bits are set or cleared according to the results of the operation. The C status bit is not affected by the operation, thus allowing the INC instruction to be used as a loop counter in multiple-precision computations.

When operating on unsigned values, only BEQ, BNE, LBEQ, and LBNE branches can be expected to perform consistently. When operating on two's complement values, all signed branches are available.

## Condition Codes and Boolean Formulas:



N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V : Set if there is a two's complement overflow as a result of the operation; cleared otherwise. Two's complement overflow occurs if and only if (B) was \$7F before the operation.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| INCB | INH | 52 | 1 | 0 |

Operation: $\quad(S P)+\$ 0001 \Rightarrow S P$
Description: Add one to the SP. This instruction is assembled to LEAS 1,SP. The LEAS instruction does not affect condition codes as an INX or INY instruction would.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| INS translates to... <br> LEAS 1,SP | IDX | 1 B 81 | 2 | $\mathrm{PP}^{1}$ |

Notes:

1. Due to internal CPU requirements, the program word fetch is performed twice to the same address during this instruction.

Operation: $\quad(X)+\$ 0001 \Rightarrow X$
Description: Add one to index register X. LEAX $1, X$ can produce the same result but LEAX does not affect the $Z$ status bit. Although the LEAX instruction is more flexible, INX requires only one byte of object code.

INX operation affects only the $Z$ status bit.

## Condition Codes and Boolean Formulas:



Z: Set if result is $\$ 0000$; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| INX | INH | 08 | 1 | 0 |

Operation: $\quad(\mathrm{Y})+\$ 0001 \Rightarrow \mathrm{Y}$
Description: Add one to index register Y. LEAY 1,Y can produce the same result but LEAY does not affect the $Z$ status bit. Although the LEAY instruction is more flexible, INY requires only one byte of object code.

INY operation affects only the $Z$ status bit.

## Condition Codes and Boolean Formulas:



Z: Set if result is $\$ 0000$; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| INY | INH | 02 | 1 | 0 |

Operation: $\quad$ Effective Address $\Rightarrow \mathrm{PC}$
Description: Jumps to the instruction stored at the effective address. The effective address is obtained according to the rules for extended or indexed addressing.

Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| JMP opr16a | EXT | 06 hh ll | 3 | PPP |
| JMP oprx0_xysp | IDX | 05 xb | 3 | PPP |
| JMP oprx9,xysp | IDX1 | 05 xb ff | 3 | PPP |
| JMP oprx16,xysp | IDX2 | 05 xb ee ff | 4 | fPPP |
| JMP [D,xysp] | [D,IDX] | 05 xb | 6 | fIfPPP |
| JMP [oprx16,xysp] | [IDX2] | 05 xb ee ff | 6 | fIfPPP |

## Jump to Subroutine

Operation: $\quad(S P)-\$ 0002 \Rightarrow S P$
RTN $_{H}:$ RTN $_{L} \Rightarrow M_{(S P)}: M_{(S P+1)}$
Subroutine Address $\Rightarrow$ PC
Description: Sets up conditions to return to normal program flow, then transfers control to a subroutine. Uses the address of the instruction following the JSR as a return address.

Decrements the SP by two, to allow the two bytes of the return address to be stacked.

Stacks the return address (the SP points to the high order byte of the return address).
Calculates an effective address according to the rules for extended, direct or indexed addressing.
Jumps to the location determined by the effective address.
Subroutines are normally terminated with an RTS instruction, which restores the return address from the stack.

## Condition Codes and Boolean Formulas:

| $\mathbf{L}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - |

None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| JSR opr8a | DIR | 17 dd | 4 | PPPS |
| JSR opr16a | EXT | $16 \mathrm{hh} l \mathrm{l}$ | 4 | PPPS |
| JSR oprx0_xysp | IDX | 15 xb | 4 | PPPS |
| JSR oprx9,xysp | IDX1 | 15 xb ff | 4 | PPPS |
| JSR oprx16,xysp | IDX2 | 15 xb ee ff | 5 | fPPPS |
| JSR [D,xysp] | [D,IDX] | 15 xb | 7 | fIfPPPS |
| JSR [oprx16,xysp] | [IDX2] | 15 xb ee ff | 7 | fIfPPPS |

Operation: $\quad$ If $C=0$, then $(P C)+\$ 0004+\operatorname{Rel} \Rightarrow P C$
Simple branch
Description: Tests the C status bit and branches if $\mathrm{C}=0$.
See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LBCC rel16 | REL | 1824 qq rr | $4 / 3$ | OPPP/OPO 1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $r=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r}=0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad$ If $C=1$, then $(P C)+\$ 0004+\mathrm{ReI} \Rightarrow \mathrm{PC}$
Simple branch
Description: Tests the C status bit and branches if $\mathrm{C}=1$.
See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LBCS rel16 | REL | 1825 qq rr | $4 / 3$ | OPPP/OPO 1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $\mathrm{r}=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r} \neq 0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad$ If $Z=1,(P C)+\$ 0004+\operatorname{Rel} \Rightarrow P C$
Simple branch
Description: $\quad$ Tests the $Z$ status bit and branches if $Z=1$.
See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LBEQ rel16 | REL | 1827 qq rr | $4 / 3$ | OPPP/OPO ${ }^{1}$ |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r}=\mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $r=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r}=0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad$ If $\mathrm{N} \oplus \mathrm{V}=0,(\mathrm{PC})+\$ 0004+\mathrm{Rel} \Rightarrow \mathrm{PC}$
For signed two's complement numbers, if (Accumulator) $\geq$ Memory), then branch

Description: If LBGE is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the two's complement number in the accumulator was greater than or equal to the two's complement number in memory.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LBGE rel16 | REL | 18 2C qq rr | $4 / 3$ | OPPP/OPO 1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $\mathrm{r}=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r} \neq 0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad$ If $Z+(N \oplus V)=0$, then $(P C)+\$ 0004+$ Rel $\Rightarrow P C$
For signed two's complement numbers, If (Accumulator) $>$ (Memory), then branch

Description: If LBGT is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the two's complement number in the accumulator was greater than the two's complement number in memory.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LBGT rel16 | REL | 182 E qq rr | $4 / 3$ | OPPP/OPO 1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $\mathrm{r}=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r} \neq 0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad$ If $C+Z=0$, then $(P C)+\$ 0004+\mathrm{Rel} \Rightarrow \mathrm{PC}$
For unsigned binary numbers, if (Accumulator) > (Memory), then branch
Description: If LBHI is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the unsigned binary number in the accumulator was greater than the unsigned binary number in memory. This instruction is generally not useful after INC/DEC, LD/ST, TST/CLR/COM because these instructions do not affect the C status bit.

See 3.7 Relative Addressing Mode for details of branch execution.
Condition Codes and Boolean Formulas:


None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| LBHI rel16 | REL | 1822 qq rr | $4 / 3$ | OPPP/OPO1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $r=0$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq 0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad$ If $C=0$, then $(P C)+\$ 0004+\mathrm{Rel} \Rightarrow \mathrm{PC}$
For unsigned binary numbers, if (Accumulator) $\geq$ (Memory), then branch
Description: If LBHS is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the unsigned binary number in the accumulator was greater than or equal to the unsigned binary number in memory. This instruction is generally not useful after INC/DEC, LD/ST, TST/CLR/COM because these instructions do not affect the C status bit.

See 3.7 Relative Addressing Mode for details of branch execution.
Condition Codes and Boolean Formulas:


None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LBHS rel16 | REL | 1824 qq rr | $4 / 3$ | OPPP/OPO 1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $\mathrm{r}=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r}=0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad$ If $Z+(N \oplus V)=1$, then $(P C)+\$ 0004+\operatorname{Rel} \Rightarrow \mathrm{PC}$
For signed two's complement numbers, if (Accumulator) $\leq$ (Memory), then branch

Description: If LBLE is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the two's complement number in the accumulator was less than or equal to the two's complement number in memory.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LBLE rel16 | REL | 182 F qq rr | $4 / 3$ | OPPP/OPO 1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $\mathrm{r}=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r} \neq 0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad$ If $C=1$, then $(P C)+\$ 0004+\mathrm{Rel} \Rightarrow \mathrm{PC}$
For unsigned binary numbers, if (Accumulator) < (Memory), then branch
Description: If LBLO is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the unsigned binary number in the accumulator was less than the unsigned binary number in memory. This instruction is generally not useful after INC/DEC, LD/ST, TST/CLR/COM because these instructions do not affect the C status bit.

See 3.7 Relative Addressing Mode for details of branch execution.
Condition Codes and Boolean Formulas:


None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LBLO rel16 | REL | 1825 qq rr | $4 / 3$ | OPPP/OPO 1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $\mathrm{r}=0$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq 0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad$ If $C+Z=1$, then $(P C)+\$ 0004+\mathrm{Rel} \Rightarrow \mathrm{PC}$
For unsigned binary numbers, if (Accumulator) $\leq$ (Memory), then branch
Description: If LBLS is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the unsigned binary number in the accumulator was less than or equal to the unsigned binary number in memory. This instruction is generally not useful after INC/DEC, LD/ST, TST/CLR/COM because these instructions do not affect the C status bit.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LBLS rel16 | REL | 1823 qq rr | $4 / 3$ | OPPP/OPO 1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $\mathrm{r}=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r} \neq 0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad$ If $\mathrm{N} \oplus \mathrm{V}=1,(\mathrm{PC})+\$ 0004+\mathrm{Rel} \Rightarrow \mathrm{PC}$
For signed two's complement numbers, if (Accumulator) < (Memory), then branch

Description: If LBLT is executed immediately after execution of CBA, CMPA, CMPB, CMPD, CPX, CPY, SBA, SUBA, SUBB, or SUBD, a branch occurs if and only if the two's complement number in the accumulator was less than the two's complement number in memory.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| LBLT rel16 | REL | 182 D qq rr | $4 / 3$ | OPPP/OPO 1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $\mathrm{r}=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r} \neq 0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad$ If $N=1$, then $(P C)+\$ 0004+\mathrm{ReI} \Rightarrow \mathrm{PC}$
Simple branch
Description: Tests the N status bit and branches if $\mathrm{N}=1$.
See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| LBMI rel16 | REL | 18 2B qq rr | $4 / 3$ | OPPP/OPO 1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $\mathrm{r}=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r} \neq 0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

## LBNE

Operation: If $Z=0$, then $(P C)+\$ 0004+\operatorname{Rel} \Rightarrow P C$
Simple branch
Description: Tests the $Z$ status bit and branches if $Z=0$.
See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LBNE rel16 | REL | 1826 qq rr | $4 / 3$ | OPPP/OPO 1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $\mathrm{r}=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r} \neq 0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad$ If $N=0$, then $(P C)+\$ 0004+\operatorname{Rel} \Rightarrow P C$
Simple branch
Description: Tests the N status bit and branches if $\mathrm{N}=0$.
See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LBPL rel16 | REL | 18 2A qq rr | $4 / 3$ | OPPP/OPO1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $\mathrm{r}=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r} \neq 0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad(\mathrm{PC})+\$ 0004+\mathrm{Rel} \Rightarrow \mathrm{PC}$
Description: Unconditional branch to an address calculated as shown in the expression. Rel is a relative offset stored as a two's complement number in the second and third bytes of machine code corresponding to the long branch instruction.

Execution time is longer when a conditional branch is taken than when it is not, because the instruction queue must be refilled before execution resumes at the new address. Since the LBRA branch condition is always satisfied, the branch is always taken, and the instruction queue must always be refilled, so execution time is always the larger value.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| LBRA rel16 | REL | 1820 qq rr | 4 | OPPP |

Operation: $\quad(P C)+\$ 0004 \Rightarrow \mathrm{PC}$
Description: Never branches. LBRN is effectively a 4-byte NOP that requires three cycles to execute. LBRN is included in the instruction set to provide a complement to the LBRA instruction. The instruction is useful during program debug, to negate the effect of another branch instruction without disturbing the offset byte. A complement for LBRA is also useful in compiler implementations.

Execution time is longer when a conditional branch is taken than when it is not, because the instruction queue must be refilled before execution resumes at the new address. Since the LBRN branch condition is never satisfied, the branch is never taken, and the queue does not need to be refilled, so execution time is always the smaller value.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| LBRN rel16 | REL | 1821 qq rr | 3 | OPO |

Operation: $\quad$ If $V=0$, then $(P C)+\$ 0004+$ Rel $\Rightarrow P C$
Simple branch
Description: Tests the V status bit and branches if $\mathrm{V}=0$.
LBVC causes a branch when a previous operation on two's complement binary values does not cause an overflow. That is, when LBVC follows a two's complement operation, a branch occurs when the result of the operation is valid.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LBVC rel16 | REL | 1828 qq rr | $4 / 3$ | OPPP/OPO1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $r=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r}=0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad$ If $\mathrm{V}=1$, then $(\mathrm{PC})+\$ 0004+\mathrm{Rel} \Rightarrow \mathrm{PC}$
Simple branch
Description: Tests the V status bit and branches if $\mathrm{V}=1$.
LBVS causes a branch when a previous operation on two's complement binary values causes an overflow. That is, when LBVS follows a two's complement operation, a branch occurs when the result of the operation is invalid.

See 3.7 Relative Addressing Mode for details of branch execution.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LBVS rel16 | REL | 1829 qq rr | $4 / 3$ | OPPP/OPO 1 |

Notes:

1. OPPP/OPO indicates this instruction takes four cycles to refill the instruction queue if the branch is taken and three cycles if the branch is not taken.

| Branch |  |  |  | Complementary Branch |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Test | Mnemonic | Opcode | Boolean | Test | Mnemonic | Opcode | Comment |
| $r>m$ | LBGT | 182 E | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | Signed |
| $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | $\mathrm{N} \oplus \mathrm{V}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | Signed |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Signed |
| $\mathrm{r} \leq \mathrm{m}$ | LBLE | 182 F | $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | $\mathrm{r}>\mathrm{m}$ | LBGT | 182 E | Signed |
| $\mathrm{r}<\mathrm{m}$ | LBLT | 182 D | $\mathrm{N} \oplus \mathrm{V}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBGE | 182 C | Signed |
| $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | $\mathrm{C}+\mathrm{Z}=0$ | $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | Unsigned |
| $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | $\mathrm{C}=0$ | $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | Unsigned |
| $\mathrm{r}=\mathrm{m}$ | LBEQ | 1827 | $\mathrm{Z}=1$ | $\mathrm{r} \neq \mathrm{m}$ | LBNE | 1826 | Unsigned |
| $\mathrm{r} \leq \mathrm{m}$ | LBLS | 1823 | $\mathrm{C}+\mathrm{Z}=1$ | $\mathrm{r}>\mathrm{m}$ | LBHI | 1822 | Unsigned |
| $\mathrm{r}<\mathrm{m}$ | LBLO/LBCS | 1825 | $\mathrm{C}=1$ | $\mathrm{r} \geq \mathrm{m}$ | LBHS/LBCC | 1824 | Unsigned |
| Carry | LBCS | 1825 | $\mathrm{C}=1$ | No Carry | LBCC | 1824 | Simple |
| Negative | LBMI | 182 B | $\mathrm{~N}=1$ | Plus | LBPL | 182 A | Simple |
| Overflow | LBVS | 1829 | $\mathrm{~V}=1$ | No Overflow | LBVC | 1828 | Simple |
| $\mathrm{r}=0$ | LBEQ | 1827 | $\mathrm{Z=1}$ | $\mathrm{r}=0$ | LBNE | 1826 | Simple |
| Always | LBRA | 1820 | - | Never | LBRN | 1821 | Unconditional |

Operation: $\quad(M) \Rightarrow A$
Description: Loads the content of memory location M into accumulator A. The condition codes are set according to the data.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| LDAA \#opr8i | IMM | 86 ii | 1 | P |
| LDAA opr8a | DIR | 96 dd | 3 | rfP |
| LDAA opr16a | EXT | B6 hh ll | 3 | rop |
| LDAA oprx0_xysp | IDX | A6 xb | 3 | rfP |
| LDAA oprx9,xysp | IDX1 | A6 xb ff | 3 | rPo |
| LDAA oprx16,xysp | IDX2 | A6 xb ee ff | 4 | frPP |
| LDAA [D,xysp] | [D,IDX] | A6 xb | 6 | fIfrfP |
| LDAA [oprx16,xysp] | [IDX2] | A6 xb ee ff | 6 | fIPrfP |

Operation: $\quad(M) \Rightarrow B$
Description: Loads the content of memory location M into accumulator B. The condition codes are set according to the data.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is \$00; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LDAB \#opr8i | IMM | C6 ii | 1 | P |
| LDAB opr8a | DIR | D6 dd | 3 | rfP |
| LDAB opr16a | EXT | F6 hh 11 | 3 | rop |
| LDAB oprx0_xysp | IDX | E6 xb | 3 | rfP |
| LDAB oprx9,xysp | IDX1 | E6 xb ff | 3 | rPo |
| LDAB oprx16,xysp | IDX2 | E6 xb ee ff | 4 | frPP |
| LDAB [D, xysp] | [D,IDX] | E6 xb | 6 | fIfrfP |
| LDAB [oprx16,xysp] | [IDX2] | E6 xb ee ff | 6 | fIPrfP |

Operation: $\quad(M: M+1) \Rightarrow A: B$
Description: Loads the contents of memory locations $M$ and $M+1$ into double accumulator D . The condition codes are set according to the data. The information from M is loaded into accumulator A , and the information from $\mathrm{M}+1$ is loaded into accumulator B .

Condition Codes and Boolean Formulas:

| S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :--- | :--- |
| LDD \#opr16i | IMM | CC jj kk | 2 | OP |
| LDD opr8a | DIR | DC dd | 3 | RfP |
| LDD opr16a | EXT | FC hh ll | 3 | ROP |
| LDD oprx0_xysp | IDX | EC xb | 3 | RfP |
| LDD oprx9,xysp | IDX1 | EC xb ff | 3 | RPO |
| LDD oprx16,xysp | IDX2 | EC xb ee ff | 4 | fRPP |
| LDD [D,xysp] | [D,IDX] | EC xb | 6 | fIfRfP |
| LDD [oprx16,xysp] | $[I D X 2] ~$ | EC xb ee ff | 6 | fIPRfP |

## Load Stack Pointer

Operation: $\quad(\mathrm{M}: \mathrm{M}+1) \Rightarrow \mathrm{SP}$
Description: Loads the most significant byte of the SP with the content of memory location M , and loads the least significant byte of the SP with the content of the next byte of memory at $\mathrm{M}+1$.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :--- | :--- |
| LDS \#opr16i | IMM | CF jj kk | 2 | OP |
| LDS opr8a | DIR | DF dd | 3 | RfP |
| LDS opr16a | EXT | FF hh ll | 3 | ROP |
| LDS oprx0_xysp | IDX | EF xb | 3 | RfP |
| LDS oprx9,xysp | IDX1 | EF xb ff | 3 | RPo |
| LDS oprx16,xysp | IDX2 | EF xb ee ff | 4 | fRPP |
| LDS [D, $x y s p] ~$ | [D,IDX] | EF xb | 6 | fIfRfP |
| LDS [oprx16,xysp] | $[I D X 2]$ | EF xb ee ff | 6 | fIPRfP |

Operation: $\quad(M: M+1) \Rightarrow X$
Description: Loads the most significant byte of index register $X$ with the content of memory location $M$, and loads the least significant byte of $X$ with the content of the next byte of memory at $\mathrm{M}+1$.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :--- | :--- |
| LDX \#opr16i | IMM | CE jj kk | 2 | OP |
| LDX opr8a | DIR | DE dd | 3 | RfP |
| LDX opr16a | EXT | FE hh ll | 3 | ROP |
| LDX oprx0_xysp | IDX | EE xb | 3 | RfP |
| LDX oprx9,xysp | IDX1 | EE xb ff | 3 | RPo |
| LDX oprx16,xysp | IDX2 | EE xb ee ff | 4 | fRPP |
| LDX [D, $x y s p] ~$ | $[D, I D X]$ | EE xb | 6 | fIfRfP |
| LDX[oprx16,xysp] | $[I D X 2]$ | EE xb ee ff | 6 | fIPRfP |

Operation: $\quad(M: M+1) \Rightarrow Y$
Description: Loads the most significant byte of index register $Y$ with the content of memory location $M$, and loads the least significant byte of $Y$ with the content of the next memory location at $\mathrm{M}+1$.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :--- | :--- |
| LDY \#opr16i | IMM | CD jj kk | 2 | OP |
| LDY opr8a | DIR | DD dd | 3 | RfP |
| LDY opr16a | EXT | FD hh ll | 3 | ROP |
| LDY oprx0_xysp | IDX | ED xb | 3 | RfP |
| LDY oprx9,xysp | IDX1 | ED xb ff | 3 | RPO |
| LDY oprx16,xysp | IDX2 | ED xb ee ff | 4 | fRPP |
| LDY [D,xysp] | [D,IDX] | ED xb | 6 | fIfRfP |
| LDY [oprx16,xysp] | $[I D X 2] ~$ | ED xb ee ff | 6 | fIPRfP |

Operation: $\quad$ Effective Address $\Rightarrow \mathrm{SP}$
Description: Loads the stack pointer with an effective address specified by the program. The effective address can be any indexed addressing mode operand address except an indirect address. Indexed addressing mode operand addresses are formed by adding an optional constant supplied by the program or an accumulator value to the current value in $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC. See 3.8 Indexed Addressing Modes for more details.

LEAS does not alter condition code bits. This allows stack modification without disturbing CCR bits changed by recent arithmetic operations.

Operation is a bit more complex when LEAS is used with auto-increment or aut-odecrement operand specifications and the SP is the referenced index register. The index register is loaded with what would have gone out to the address bus in the case of a load index instruction. In the case of a pre-increment or pre-decrement, the modification is made before the index register is loaded. In the case of a post-increment or post-decrement, modification would have taken effect after the address went out on the address bus, so post-modification does not affect the content of the index register.

Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| LEAS oprx0_xysp | IDX | 1B xb | 2 | $\mathrm{PP}^{1}$ |
| LEAS oprx9,xysp | IDX1 | 1B xb ff | 2 | PO |
| LEAS oprx16, $x y s p ~$ | IDX2 | 1B xb ee ff | 2 | PP |

Notes:

1. Due to internal CPU requirements, the program word fetch is performed twice to the same address during this instruction.

Operation: $\quad$ Effective Address $\Rightarrow \mathrm{X}$
Description: Loads index register $X$ with an effective address specified by the program. The effective address can be any indexed addressing mode operand address except an indirect address. Indexed addressing mode operand addresses are formed by adding an optional constant supplied by the program or an accumulator value to the current value in $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC. See 3.8 Indexed Addressing Modes for more details.

Operation is a bit more complex when LEAX is used with auto-increment or auto-decrement operand specifications and index register $X$ is the referenced index register. The index register is loaded with what would have gone out to the address bus in the case of a load indexed instruction. In the case of a pre-increment or pre-decrement, the modification is made before the index register is loaded. In the case of a post-increment or post-decrement, modification would have taken effect after the address went out on the address bus, so post-modification does not affect the content of the index register.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| LEAX oprx0_xysp | IDX | 1A xb | 2 | $\mathrm{PP}^{1}$ |
| LEAX oprx9,xysp | IDX1 | 1A xb ff | 2 | Po |
| LEAX oprx16, $x y s p ~$ | IDX2 | 1A xb ee ff | 2 | PP |

Notes:

1. Due to internal CPU requirements, the program word fetch is performed twice to the same address during this instruction.

Operation: $\quad$ Effective Address $\Rightarrow \mathrm{Y}$
Description: Loads index register Y with an effective address specified by the program. The effective address can be any indexed addressing mode operand address except an indirect address. Indexed addressing mode operand addresses are formed by adding an optional constant supplied by the program or an accumulator value to the current value in $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC. See 3.8 Indexed Addressing Modes for more details.

Operation is a bit more complex when LEAY is used with auto-increment or auto-decrement operand specifications and index register $Y$ is the referenced index register. The index register is loaded with what would have gone out to the address bus in the case of a load indexed instruction. In the case of a pre-increment or pre-decrement, the modification is made before the index register is loaded. In the case of a post-increment or post-decrement, modification would have taken effect after the address went out on the address bus, so post-modification does not affect the content of the index register.

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| LEAY oprx0_xysp | IDX | 19 xb | 2 | $\mathrm{PP}^{1}$ |
| LEAY oprx9,xysp | IDX1 | 19 xb ff | 2 | PO |
| LEAY oprx16,xysp | IDX2 | 19 xb ee ff | 2 | PP |

Notes:

1. Due to internal CPU requirements, the program word fetch is performed twice to the same address during this instruction.

## Operation:



Description: Shifts all bits of the memory location M one place to the left. Bit 0 is loaded with zero. The C status bit is loaded from the most significant bit of M .

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}]+[\overline{\mathrm{N}} \bullet \mathrm{C}]$ (for N and C after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: M7
Set if the LSB of $M$ was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| LSL opr16a | EXT | 78 hh ll | 4 | roPw |
| LSL oprx0 $x y s p$ | IDX | 68 xb | 3 | rPw |
| LSL oprx9,xysp | IDX1 | 68 xb ff | 4 | rPOw |
| LSL oprx16,xysp | IDX2 | 68 xb ee ff | 5 | frPPw |
| LSL [D, $x y s p]$ | [D,IDX] | 68 xb | 6 | fIfrPw |
| LSL $[o p r x 16, x y s p]$ | [IDX2] | 68 xb ee ff | 6 | fIPrPw |

## Operation:



Description: Shifts all bits of accumulator A one place to the left. Bit 0 is loaded with zero. The $C$ status bit is loaded from the most significant bit of $A$.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}]+[\overline{\mathrm{N}} \bullet \mathrm{C}]$ (for N and C after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: A7
Set if the LSB of A was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :---: |
| LSLA | INH | 48 | 1 | 0 |

## Operation:



Description: Shifts all bits of accumulator B one place to the left. Bit 0 is loaded with zero. The $C$ status bit is loaded from the most significant bit of $B$.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}]+[\overline{\mathrm{N}} \bullet \mathrm{C}]$ (for N and C after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: B7
Set if the LSB of B was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| LSLB | INH | 58 | 1 | 0 |

## LSLD

## Logical Shift Left Double

(Same as ASLD)

## Operation:



Description: Shifts all bits of double accumulator D one place to the left. Bit 0 is loaded with zero. The C status bit is loaded from the most significant bit of accumulator A .

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: $\quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}]+[\overline{\mathrm{N}} \cdot \mathrm{C}]$ (for N and C after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: D15
Set if the MSB of D was set before the shift; cleared otherwise.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| LSLD | INH | 59 | 1 | 0 |

## Operation:



Description: Shifts all bits of memory location M one place to the right. Bit 7 is loaded with zero. The C status bit is loaded from the least significant bit of M .

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | $\Delta$ | $\Delta$ | $\Delta$ |

$\mathrm{N}: ~ 0 ;$ Cleared.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad N \oplus C=[N \cdot \bar{C}]+[\bar{N} \cdot C]$ (for $N$ and $C$ after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: MO
Set if the LSB of M was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| LSR opr16a | EXT | 74 hh ll | 4 | rOPw |
| LSR oprx0_xysp | IDX | 64 xb | 3 | rPw |
| LSR oprx9,xysp | IDX1 | 64 xb ff | 4 | rPOw |
| LSR oprx16,xysp | IDX2 | 64 xb ee ff | 5 | frPPw |
| LSR [D,xysp] | [D,IDX] | 64 xb | 6 | fIfrPw |
| LSR [oprx16,xysp] | [IDX2] | 64 xb ee ff | 6 | fIPrPw |

## Operation:



Description: Shifts all bits of accumulator $A$ one place to the right. Bit 7 is loaded with zero. The C status bit is loaded from the least significant bit of A .

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ |  | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

N: 0; Cleared.
Z : Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}]+[\overline{\mathrm{N}} \bullet \mathrm{C}]$ (for N and C after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of $N$ and C after the shift).

C: AO
Set if the LSB of A was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| LSRA | INH | 44 | 1 | 0 |

## Logical Shift Right B

## Operation:



Description: Shifts all bits of accumulator B one place to the right. Bit 7 is loaded with zero. The C status bit is loaded from the least significant bit of $B$.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | 0 | $\Delta$ | $\Delta$ | $\Delta$ |

N: 0; Cleared.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad N \oplus C=[N \cdot \bar{C}]+[\bar{N} \cdot C]$ (for $N$ and $C$ after the shift)
Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of $N$ and $C$ after the shift).

C: B0
Set if the LSB of B was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :--- | :---: | :---: |
| LSRB | INH | 54 | 1 | 0 |

## LSRD

## Operation:



Description: Shifts all bits of double accumulator D one place to the right. D15 (MSB of $A$ ) is loaded with zero. The C status bit is loaded from D0 (LSB of B).

Condition Codes and Boolean Formulas:

$\mathrm{N}: ~ 0 ;$ Cleared.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: DO
Set if, after the shift operation, C is set; cleared otherwise.
C: D0
Set if the LSB of D was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| LSRD | INH | 49 | 1 | 0 |

Operation: $\quad \operatorname{MAX}((A),(M)) \Rightarrow A$
Description: Subtracts an unsigned 8-bit value in memory from an unsigned 8-bit value in accumulator A to determine which is larger, and leaves the larger of the two values in $A$. The $Z$ status bit is set when the result of the subtraction is zero (the values are equal), and the $C$ status bit is set when the subtraction requires a borrow (the value in memory is larger than the value in the accumulator). When $\mathrm{C}=1$, the value in A has been replaced by the value in memory.

The unsigned value in memory is accessed by means of indexed addressing modes, which allow a great deal of flexibility in specifying the address of the operand. Auto increment/decrement variations of indexed addressing facilitate finding the largest value in a list of values.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad \mathrm{X} 7 \bullet \overline{\mathrm{M} 7} \bullet \overline{\mathrm{R7}}+\overline{\mathrm{X7}} \bullet \mathrm{M} 7 \bullet \mathrm{R7}$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
C: $\overline{X 7} \cdot M 7+M 7 \bullet R 7+R 7 \bullet \overline{X 7}$
Set if the value of the content of memory is larger than the value of the accumulator; cleared otherwise.
Condition codes reflect internal subtraction ( $R=A-M$ ).
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| MAXA oprx0_xysp | IDX | 1818 xb | 4 | OrfP |
| MAXA oprx9,xysp | IDX1 | 1818 xb ff | 4 | OrPO |
| MAXA oprx16,xysp | IDX2 | 1818 xb ee ff | 5 | OfrPP |
| MAXA [D,xysp] | [D,IDX] | 1818 xb | 7 | OfIfrfP |
| MAXA [oprx16,xysp] | [IDX2] | 1818 xb ee ff | 7 | OfIPrfP |

Operation: $\quad \operatorname{MAX}((A),(M)) \Rightarrow M$
Description: Subtracts an unsigned 8-bit value in memory from an unsigned 8-bit value in accumulator A to determine which is larger, and leaves the larger of the two values in the memory location. The Z status bit is set when the result of the subtraction is zero (the values are equal), and the C status bit is set when the subtraction requires a borrow (the value in memory is larger than the value in the accumulator). When $\mathrm{C}=0$, the value in accumulator A has replaced the value in memory.

The unsigned value in memory is accessed by means of indexed addressing modes, which allow a great deal of flexibility in specifying the address of the operand.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z : Set if result is $\$ 00$; cleared otherwise.
V : $\quad \mathrm{X} 7 \bullet \overline{\mathrm{M} 7} \bullet \overline{\mathrm{R} 7}+\overline{\mathrm{X} 7} \bullet \mathrm{M} 7 \bullet \mathrm{R} 7$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
$\mathrm{C}: \overline{\mathrm{X} 7} \cdot \mathrm{M} 7+\mathrm{M} 7 \bullet R 7+\mathrm{R} 7 \cdot \overline{\mathrm{X}}$
Set if the value of the content of memory is larger than the value of the accumulator; cleared otherwise.

Condition codes reflect internal subtraction $(R=A-M)$.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| MAXM oprx0_xysp | IDX | 18 1C xb | 4 | OrPw |
| MAXM oprx9,xysp | IDX1 | 18 1C xb ff | 5 | OrPwo |
| MAXM oprx16,xysp | IDX2 | 18 1C xb ee ff | 6 | OfrPwP |
| MAXM [D,xysp] | [D,IDX] | 18 1C xb | 7 | OfIfrPw |
| MAXM [oprx16,xysp] | [IDX2] | 18 1C xb ee ff | 7 | OfIPrPw |

Operation: $\quad$ Grade of Membership $\Rightarrow M_{(Y)}$
$(\mathrm{Y})+\$ 0001 \Rightarrow \mathrm{Y}$
$(X)+\$ 0004 \Rightarrow X$
Description: Accumulator A and index registers X and Y must be set up as follows before executing MEM.

A must hold the current crisp value of a system input variable.
X must point to a 4-byte data structure that describes the trapezoidal membership function for a label of the system input.
Y must point to the fuzzy input (RAM location) where the resulting grade of membership is to be stored.
The 4-byte membership function data structure consists of Point_1, Point_2, Slope_1, and Slope_2, in that order.

Point_ 1 is the X -axis starting point for the leading side of the trapezoid, and Slope_1 is the slope of the leading side of the trapezoid.
Point 2 is the X -axis position of the rightmost point of the trapezoid, and Slope_2 is the slope of the trailing side of the trapezoid. The trailing side slopes up and left from Point_2.
A Slope_1 or Slope_2 value of $\$ 00$ indicates a special case where the membership function either starts with a grade of \$FF at input = Point_1, or ends with a grade of \$FF at input = Point_2 (infinite slope).

When MEM is executed, X points at Point_1 and Slope_2 is at $\mathrm{X}+3$. After execution, the content of $A$ is unchanged. $X$ has been incremented by four to point to the next set of membership function points and slopes. The fuzzy input (RAM location) to which $Y$ pointed contains the grade of membership that was calculated by MEM, and Y has been incremented by one so it points to the next fuzzy input.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $?$ | - | $?$ | $?$ | $?$ | $?$ |

H, N, Z, V, and C may be altered by this instruction.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| MEM | Special | 01 | 5 | RRfOw |

Operation: $\quad \operatorname{MIN}((A),(M)) \Rightarrow A$
Description: Subtracts an unsigned 8-bit value in memory from an unsigned 8-bit value in accumulator A to determine which is larger, and leaves the smaller of the two values in accumulator $A$. The $Z$ status bit is set when the result of the subtraction is zero (the values are equal), and the C status bit is set when the subtraction requires a borrow (the value in memory is larger than the value in the accumulator). When $C=0$, the value in accumulator A has been replaced by the value in memory.

The unsigned value in memory is accessed by means of indexed addressing modes, which allow a great deal of flexibility in specifying the address of the operand. Auto increment/decrement variations of indexed addressing facilitate finding the largest value in a list of values.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \quad \mathrm{X7} \bullet \overline{\mathrm{M} 7} \bullet \overline{\mathrm{R7}}+\overline{\mathrm{X} 7} \bullet \mathrm{M} 7 \bullet \mathrm{R7}$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
C: $\overline{X 7} \bullet M 7+M 7 \bullet R 7+R 7 \bullet \overline{X 7}$
Set if the value of the content of memory is larger than the value of the accumulator; cleared otherwise.
Condition codes reflect internal subtraction ( $R=A-M$ ).
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| MINA oprx0_xysp | IDX | 1819 xb | 4 | OrfP |
| MINA oprx9,xysp | IDX1 | 1819 xb ff | 4 | OrPO |
| MINA oprx16,xysp | IDX2 | 1819 xb ee ff | 5 | OfrPP |
| MINA [D, $x y s p]$ | [D,IDX] | 1819 xb | 7 | OfIfrfP |
| MINA [oprx16,xysp] | [IDX2] | 1819 xb ee ff | 7 | OfIPrfP |

Operation: $\quad \operatorname{MIN}((A),(M)) \Rightarrow \mathrm{M}$
Description: Subtracts an unsigned 8-bit value in memory from an unsigned 8-bit value in accumulator $A$ to determine which is larger, and leaves the smaller of the two values in the memory location. The $Z$ status bit is set when the result of the subtraction is zero (the values are equal), and the $C$ status bit is set when the subtraction requires a borrow (the value in memory is larger than the value in the accumulator). When $C=1$, the value in accumulator A has replaced the value in memory.

The unsigned value in memory is accessed by means of indexed addressing modes, which allow a great deal of flexibility in specifying the address of the operand.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: X7•M7• $\overline{\mathrm{R7}}+\overline{\mathrm{X7}} \bullet \mathrm{M} 7 \bullet \mathrm{R7}$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
C: $\overline{\mathrm{X7}} \bullet \mathrm{M} 7+\mathrm{M} 7 \bullet \mathrm{R} 7+\mathrm{R} 7 \bullet \overline{\mathrm{X7}}$
Set if the value of the content of memory is larger than the value of the accumulator; cleared otherwise.
Condition codes reflect internal subtraction ( $R=A-M$ ).
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| MINM oprx0_xysp | IDX | 18 1D xb | 4 | OrPw |
| MINM oprx9,xysp | IDX1 | 181 db ff | 5 | OrPwo |
| MINM oprx16,xysp | IDX2 | 18 1D xb ee ff | 6 | OfrPwP |
| MINM [D,xysp] | [D,IDX] | 181 db | 7 | OfIfrPw |
| MINM [oprx16,xysp] | [IDX2] | 18 1D xb ee ff | 7 | OfIPrPw |

## Move a Byte of Data

 from One Memory Location to AnotherOperation: $\quad\left(M_{1}\right) \Rightarrow M_{2}$
Description: Moves the content of one memory location to another memory location. The content of the source memory location is not changed.

Move instructions use separate addressing modes to access the source and destination of a move. The following combinations of addressing modes are supported: IMM-EXT, IMM-IDX, EXT-EXT, EXT-IDX, IDXEXT, and IDX-IDX. IDX operands allow indexed addressing mode specifications that fit in a single postbyte; including 5-bit constant, accumulator offsets, and auto increment/decrement modes. Nine-bit and 16-bit constant offsets would require additional extension bytes and are not allowed. Indexed indirect modes (for example [D,r]) are also not allowed.

There are special considerations when using PC-relative addressing with move instructions. These are discussed in 3.9 Instructions Using Multiple Modes.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form1 | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| MOVB \#opr8, opr16a | IMM-EXT | 18 0B ii hh ll | 4 | OPwP |
| MOVB \#opr8i, oprx0_xysp | IMM-IDX | 18 08 xb ii | 4 | OPwO |
| MOVB opr16a, opr16a | EXT-EXT | 18 oc hh ll hh ll | 6 | OrPwPo |
| MOVB opr16a, oprx0_xysp | EXT-IDX | 18 09 xb hh ll | 5 | OPrPw |
| MOVB oprx0_xysp, opr16a | IDX-EXT | 18 0D xb hh ll | 5 | OrPwP |
| MOVB oprx0_xysp,oprx0_xysp | IDX-IDX | 18 0A xb xb | 5 | OrPwO |

Notes:

1. The first operand in the source code statement specifies the source for the move.

Operation: $\quad(M: M+11) \Rightarrow M: M+12$
Description: Moves the content of one location in memory to another location in memory. The content of the source memory location is not changed.

Move instructions use separate addressing modes to access the source and destination of a move. The following combinations of addressing modes are supported: IMM-EXT, IMM-IDX, EXT-EXT, EXT-IDX, IDXEXT, and IDX-IDX. IDX operands allow indexed addressing mode specifications that fit in a single postbyte; including 5-bit constant, accumulator offsets, and auto increment/decrement modes. Nine-bit and 16-bit constant offsets would require additional extension bytes and are not allowed. Indexed indirect modes (for example [D,r]) are also not allowed.

There are special considerations when using PC-relative addressing with move instructions. These are discussed in 3.9 Instructions Using Multiple Modes.

Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form ${ }^{1}$ | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| MOVW \#opr16i, opr16a | IMM-EXT | 1803 jj kk hh ll | 5 | OPWPO |
| MOVW \#opr16i, oprx0_xysp | IMM-IDX | 1800 xb jj kk | 4 | OPPW |
| MOVW opr16a, opr16a | EXT-EXT | 1804 hh ll hh 11 | 6 | ORPWPO |
| MOVW opr16a, oprx0_xysp | EXT-IDX | 1801 xb hh 11 | 5 | OPRPW |
| MOVW oprx0_xysp, opr16a | IDX-EXT | 1805 xb hh ll | 5 | ORPWP |
| MOVW oprx0_xysp, oprx0_xysp | IDX-IDX | 1802 xb xb | 5 | ORPWO |

Notes:

1. The first operand in the source code statement specifies the source for the move.

Operation: $\quad(A) \times(B) \Rightarrow A: B$
Description: Multiplies the 8-bit unsigned binary value in accumulator A by the 8 -bit unsigned binary value in accumulator $B$, and places the 16 -bit unsigned result in double accumulator D . The carry flag allows rounding the most significant byte of the result through the sequence: MUL, ADCA \#0.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | $\Delta$ |

C: R7
Set if bit 7 of the result ( B bit 7 ) is set; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| MUL | INH | 12 | 3 | ffO |

Operation: $\quad 0-(M)=(\bar{M})+1 \Rightarrow M$
Description: Replaces the content of memory location M with its two's complement (the value $\$ 80$ is left unchanged).

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \mathrm{R} 7 \cdot \overline{\mathrm{R} 6} \cdot \overline{\mathrm{R} 5} \cdot \overline{\mathrm{R} 4} \cdot \overline{\mathrm{R} 3} \cdot \overline{\mathrm{R} 2} \cdot \overline{\mathrm{R} 1} \cdot \overline{\mathrm{R} 0}$
Set if there is a two's complement overflow from the implied subtraction from zero; cleared otherwise. Two's complement overflow occurs if and only if $(M)=\$ 80$
$\mathrm{C}: ~ \mathrm{R} 7+\mathrm{R} 6+\mathrm{R} 5+\mathrm{R} 4+\mathrm{R} 3+\mathrm{R} 2+\mathrm{R} 1+\mathrm{R} 0$
Set if there is a borrow in the implied subtraction from zero; cleared otherwise. Set in all cases except when $(M)=\$ 00$.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| NEG opr16a | EXT | 70 hh ll | 4 | rOPw |
| NEG oprx0 $x y s p$ | IDX | 60 xb | 3 | rPw |
| NEG oprx9,xysp | IDX1 | 60 xb ff | 4 | rPOw |
| NEG oprx16,xysp | IDX2 | 60 xb ee ff | 5 | frPPw |
| NEG [D, $x y s p]$ | [D,IDX] | 60 xb | 6 | fIfrPw |
| NEG [oprx16,xysp] | [IDX2] | 60 xb ee ff | 6 | fIPrPw |

Operation: $\quad 0-(A)=(\bar{A})+1 \Rightarrow A$
Description: Replaces the content of accumulator A with its two's complement (the value $\$ 80$ is left unchanged).

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \quad \mathrm{R} 7 \cdot \overline{\mathrm{R} 6} \cdot \overline{\mathrm{R} 5} \cdot \overline{\mathrm{R} 4} \cdot \overline{\mathrm{R} 3} \cdot \overline{\mathrm{R} 2} \cdot \overline{\mathrm{R} 1} \cdot \overline{\mathrm{R} 0}$
Set if there is a two's complement overflow from the implied subtraction from zero; cleared otherwise. Two's complement overflow occurs if and only if $(A)=\$ 80$.
$\mathrm{C}: ~ \mathrm{R} 7+\mathrm{R} 6+\mathrm{R} 5+\mathrm{R} 4+\mathrm{R} 3+\mathrm{R} 2+\mathrm{R} 1+\mathrm{R} 0$ Set if there is a borrow in the implied subtraction from zero; cleared otherwise. Set in all cases except when $(A)=\$ 00$.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| NEGA | INH | 40 | 1 | 0 |

Operation: $\quad 0-(B)=(\bar{B})+1 \Rightarrow B$
Description: Replaces the content of accumulator B with its two's complement (the value $\$ 80$ is left unchanged).

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \mathrm{R} 7 \cdot \overline{\mathrm{R} 6} \cdot \overline{\mathrm{R} 5} \cdot \overline{\mathrm{R} 4} \cdot \overline{\mathrm{R} 3} \cdot \overline{\mathrm{R} 2} \cdot \overline{\mathrm{R} 1} \cdot \overline{\mathrm{R} 0}$
Set if there is a two's complement overflow from the implied subtraction from zero; cleared otherwise. Two's complement overflow occurs if and only if $(B)=\$ 80$.

C: $\quad R 7+R 6+R 5+R 4+R 3+R 2+R 1+R 0$
Set if there is a borrow in the implied subtraction from zero; cleared otherwise. Set in all cases except when $(B)=\$ 00$.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| NEGB | INH | 50 | 1 | 0 |

Null Operation

Operation: No operation
Description: This single-byte instruction increments the PC and does nothing else. No other CPU registers are affected. NOP is typically used to produce a time delay, although some software disciplines discourage CPU fre-quency-based time delays. During debug, NOP instructions are sometimes used to temporarily replace other machine code instructions, thus disabling the replaced instruction(s).

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| NOP | INH | A7 | 1 | 0 |

Operation: $\quad(A)+(M) \Rightarrow A$
Description: Performs bitwise logical inclusive OR between the content of accumulator A and the content of memory location M and places the result in A . Each bit of $A$ after the operation is the logical inclusive OR of the corresponding bits of M and of A before the operation.

Condition Codes and Boolean Formulas:

|  | $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| ORAA \#opr8i | IMM | 8A ii | 1 | P |
| ORAA opr8a | DIR | 9A dd | 3 | rff |
| ORAA opr16a | EXT | BA hh 11 | 3 | rop |
| ORAA oprx0_xysp | IDX | AA xb | 3 | rfP |
| ORAA oprx9,xysp | IDX1 | AA xb ff | 3 | rPo |
| ORAA oprx16,xysp | IDX2 | AA xb ee ff | 4 | frPP |
| ORAA [D, xysp] | [D,IDX] | AA xb | 6 | fIfrfP |
| ORAA [oprx16,xysp] | [IDX2] | AA xb ee ff | 6 | fIPrfP |

## Inclusive OR B

Operation: $\quad(B)+(M) \Rightarrow B$
Description: Performs bitwise logical inclusive OR between the content of accumulator B and the content of memory location M . The result is placed in B . Each bit of $B$ after the operation is the logical inclusive OR of the corresponding bits of M and of B before the operation.

Condition Codes and Boolean Formulas:

|  | $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| ORAB \#opr8i | IMM | CA ii | 1 | P |
| ORAB opr8a | DIR | DA dd | 3 | rfP |
| ORAB opr16a | EXT | FA hh ll | 3 | rOP |
| ORAB oprx0_xysp | IDX | EA xb | 3 | rfP |
| ORAB oprx9,xysp | IDX1 | EA xb ff | 3 | rPO |
| ORAB oprx16,xysp | IDX2 | EA xb ee ff | 4 | frPP |
| ORAB [D,xysp] | OD,IDX] | EA xb | 6 | fIfrfP |
| ORAB [oprx16,xysp] | $[I D X 2] ~$ | EA xb ee ff | 6 | fIPrfP |

Operation: $\quad(C C R)+(M) \Rightarrow C C R$
Description: Performs bitwise logical inclusive OR between the content of memory location M and the content of the CCR, and places the result in the CCR. Each bit of the CCR after the operation is the logical OR of the corresponding bits of M and of CCR before the operation. To set one or more bits, set the corresponding bit of the mask equal to one. Bits corresponding to zeros in the mask are not changed by the ORCC operation.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
|  | - | $\Uparrow$ | $\Uparrow$ | $\Uparrow$ | $\Uparrow$ | $\Uparrow$ | $\Uparrow$ |

Condition code bits are set if the corresponding bit was one before the operation or if the corresponding bit in the instruction-provided mask is one. The X interrupt mask cannot be set by any software instruction.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| ORCC \#opr8i | IMM | 14 ii | 1 | P |

Operation: $\quad(S P)-\$ 0001 \Rightarrow S P$

$$
(A) \Rightarrow M_{(S P)}
$$

Description: Stacks the content of accumulator A. The stack pointer is decremented by one. The content of $A$ is then stacked at the address the SP points to.

Push instructions are commonly used to save the contents of one or more CPU registers at the start of a subroutine. Complementary pull instructions can be used to restore the saved CPU registers just before returning from the subroutine.

Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| PSHA | INH | 36 | 2 | Os |

Push B onto Stack

Operation: $\quad(S P)-\$ 0001 \Rightarrow S P$
(B) $\Rightarrow M_{(S P)}$

Description: Stacks the content of accumulator B. The stack pointer is decremented by one. The content of $B$ is then stacked at the address the SP points to.

Push instructions are commonly used to save the contents of one or more CPU registers at the start of a subroutine. Complementary pull instructions can be used to restore the saved CPU registers just before returning from the subroutine.

Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| PSHB | INH | 37 | 2 | Os |

Operation: $\quad(S P)-\$ 0001 \Rightarrow S P$
(CCR) $\Rightarrow \mathrm{M}_{(\mathrm{SP})}$
Description: Stacks the content of the condition codes register. The stack pointer is decremented by one. The content of the CCR is then stacked at the address to which the SP points.

Push instructions are commonly used to save the contents of one or more CPU registers at the start of a subroutine. Complementary pull instructions can be used to restore the saved CPU registers just before returning from the subroutine.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| PSHC | INH | 39 | 2 | Os |

Operation: $\quad(S P)-\$ 0002 \Rightarrow S P$

$$
(A: B) \Rightarrow M_{(S P)}: M_{(S P+1)}
$$

Description: Stacks the content of double accumulator D. The stack pointer is decremented by two, then the contents of accumulators A and B are stacked at the location to which the SP points.

After PSHD executes, the SP points to the stacked value of accumulator A. This stacking order is the opposite of the order in which A and B are stacked when an interrupt is recognized. The interrupt stacking order is backward-compatible with the M6800, which had no 16-bit accumulator.

Push instructions are commonly used to save the contents of one or more CPU registers at the start of a subroutine. Complementary pull instructions can be used to restore the saved CPU registers just before returning from the subroutine.

Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| PSHD | INH | 3B | 2 | OS |

Operation: $\quad(S P)-\$ 0002 \Rightarrow S P$
$\left(X_{H}: X_{L}\right) \Rightarrow M_{(S P)}: M_{(S P+1)}$
Description: Stacks the content of index register X . The stack pointer is decremented by two. The content of $X$ is then stacked at the address to which the SP points. After PSHX executes, the SP points to the stacked value of the high-order half of $X$.

Push instructions are commonly used to save the contents of one or more CPU registers at the start of a subroutine. Complementary pull instructions can be used to restore the saved CPU registers just before returning from the subroutine.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | - |

None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| PSHX | INH | 34 | 2 | $0 S$ |

Operation: $\quad(S P)-\$ 0002 \Rightarrow S P$
$\left(Y_{H}: Y_{L}\right) \Rightarrow M_{(S P)}: M_{(S P+1)}$
Description: Stacks the content of index register Y . The stack pointer is decremented by two. The content of $Y$ is then stacked at the address to which the SP points. After PSHY executes, the SP points to the stacked value of the high-order half of Y .

Push instructions are commonly used to save the contents of one or more CPU registers at the start of a subroutine. Complementary pull instructions can be used to restore the saved CPU registers just before returning from the subroutine.

Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| PSHY | INH | 35 | 2 | $0 S$ |

Operation: $\quad\left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow \mathrm{A}$
$(S P)+\$ 0001 \Rightarrow S P$
Description: Accumulator A is loaded from the address indicated by the stack pointer. The SP is then incremented by one.

Pull instructions are commonly used at the end of a subroutine, to restore the contents of CPU registers that were pushed onto the stack before subroutine execution.

Condition Codes and Boolean Formulas:

| s | x | H | 1 | N | z | v | c |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | - |

None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| PULA | INH | 32 | 3 | uf0 |

Pull B from Stack

Operation: $\quad\left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow \mathrm{B}$
$(S P)+\$ 0001 \Rightarrow S P$
Description: Accumulator $B$ is loaded from the address indicated by the stack pointer. The SP is then incremented by one.

Pull instructions are commonly used at the end of a subroutine, to restore the contents of CPU registers that were pushed onto the stack before subroutine execution.

Condition Codes and Boolean Formulas:

| s | X | H | 1 | N | Z | z V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - |  | - | - |  |  |  |  |

None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| PULB | INH | 33 | 3 | ufO |

Operation: $\quad\left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow \mathrm{CCR}$
$(S P)+\$ 0001 \Rightarrow S P$
Description: The condition code register is loaded from the address indicated by the stack pointer. The SP is then incremented by one.

Pull instructions are commonly used at the end of a subroutine, to restore the contents of CPU registers that were pushed onto the stack before subroutine execution.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\Delta$ | $\Downarrow$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Condition codes take on the value pulled from the stack, except that the $X$ mask bit cannot change from zero to one. Software can leave the $X$ bit set, leave it cleared, or change it from one to zero, but it can only be set by a reset or by recognition of an $\overline{\mathrm{XIRQ}}$ interrupt.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| PULC | INH | 38 | 3 | ufO |

## Pull Double Accumulator from Stack

Operation: $\left.\quad\left(M_{(S P)}: M_{(S P}+1\right)\right) \Rightarrow A: B$ $(S P)+\$ 0002 \Rightarrow S P$

Description: Double accumulator $D$ is loaded from the address indicated by the stack pointer. The SP is then incremented by two.

The order in which $A$ and $B$ are pulled from the stack is the opposite of the order in which $A$ and $B$ are pulled when an RTI instruction is executed. The interrupt stacking order for A and B is backward-compatible with the M6800, which had no 16-bit accumulator.

Pull instructions are commonly used at the end of a subroutine, to restore the contents of CPU registers that were pushed onto the stack before subroutine execution.

Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| PULD | INH | 3A | 3 | UfO |

Operation: $\left.\quad\left(M_{(S P)}: M_{(S P}+1\right)\right) \Rightarrow X_{H}: X_{L}$
$(S P)+\$ 0002 \Rightarrow S P$
Description: Index register X is loaded from the address indicated by the stack pointer. The SP is then incremented by two.

Pull instructions are commonly used at the end of a subroutine, to restore the contents of CPU registers that were pushed onto the stack before subroutine execution.

Condition Codes and Boolean Formulas:

| $\mathbf{S} \mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - |

None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| PULX | INH | 30 | 3 | UfO |

Operation: $\left.\quad\left(M_{(S P)}: M_{(S P}+1\right)\right) \Rightarrow Y_{H}: Y_{L}$ $(S P)+\$ 0002 \Rightarrow S P$

Description: Index register Y is loaded from the address indicated by the stack pointer. The SP is then incremented by two.

Pull instructions are commonly used at the end of a subroutine, to restore the contents of CPU registers that were pushed onto the stack before subroutine execution.

Condition Codes and Boolean Formulas:

| $\mathbf{S} \mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - |

None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| PULY | INH | 31 | 3 | UfO |

## Operation: $\quad$ MIN - MAX Rule Evaluation

Description: Performs an unweighted evaluation of a list of rules, using fuzzy input values to produce fuzzy outputs. REV can be interrupted, so it does not adversely affect interrupt latency.

The REV instruction uses an 8 -bit offset from a base address stored in index register Y to determine the address of each fuzzy input and fuzzy output. For REV to execute correctly, each rule in the knowledge base must consist of a table of 8-bit antecedent offsets followed by a table of 8 -bit consequent offsets. The value $\$$ FE marks boundaries between antecedents and consequents, and between successive rules. The value \$FF marks the end of the rule list. REV can evaluate any number of rules with any number of inputs and outputs.
Beginning with the address pointed to by the first rule antecedent, REV evaluates each successive fuzzy input value until it encounters an \$FE separator. Operation is similar to that of a MINA instruction. The smallest input value is the truth value of the rule. Then, beginning with the address pointed to by the first rule consequent, the truth value is compared to each successive fuzzy output value until another $\$$ FE separator is encountered; if the truth value is greater than the current output value, it is written to the output. Operation is similar to that of a MAXM instruction. Rules are processed until an \$FF terminator is encountered.

Before executing REV, perform the following set up operations.
X must point to the first 8-bit element in the rule list.
Y must point to the base address for fuzzy inputs and fuzzy outputs.
A must contain the value $\$$ FF, and the CCR $V$ bit must $=0$ (LDAA \#\$FF places the correct value in A and clears V ).
Clear fuzzy outputs to zeros.
Index register X points to the element in the rule list that is being evaluated. X is automatically updated so that execution can resume correctly if the instruction is interrupted. When execution is complete, $X$ points to the next address after the \$FF separator at the end of the rule list.

Index register $Y$ points to the base address for the fuzzy inputs and fuzzy outputs. The value in Y does not change during execution.

Accumulator A holds intermediate results. During antecedent processing, a MIN function compares each fuzzy input to the value stored in A, and writes the smaller of the two to A. When all antecedents have been evaluated, A contains the smallest input value. This is the truth value used during consequent processing. Accumulator A must be initialized to \$FF for the MIN function to evaluate the inputs of the first rule correctly. For subsequent rules, the value \$FF is written to $A$ when an \$FE marker is encountered. At the end of execution, accumulator $A$ holds the truth value for the last rule.

The V status bit signals whether antecedents (0) or consequents (1) are being processed. V must be initialized to zero in order for processing to begin with the antecedents of the first rule. Once execution begins, the value of V is automatically changed as $\$ F E$ separators are encountered. At the end of execution, $V$ should equal one, because the last element before the \$FF end marker should be a rule consequent. If V is equal to zero at the end of execution, the rule list is incorrect.

Fuzzy outputs must be cleared to $\$ 00$ before processing begins in order for the MAX algorithm used during consequent processing to work correctly. Residual output values would cause incorrect comparison.

Refer to SECTION 9 FUZZY LOGIC SUPPORT for details.

## Condition Codes and Boolean Formulas:

| S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | ? | - | ? | ? | $\Delta$ | ? |

V: 1; Normally set, unless rule structure is erroneous.
$\mathrm{H}, \mathrm{N}, \mathrm{Z}$ and C may be altered by this instruction.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| REV <br> (add if interrupted) | Special | 183 A | see note ${ }^{-1}$ | Orf (ttx)O <br> ff + Orf |

Notes:

1. The 3-cycle loop in parentheses is executed once for each element in the rule list. When an interrupt occurs, there is a 2-cycle exit sequence, a 4-cycle re-entry sequence, then execution resumes with a prefetch of the last antecedent or consequent being processed at the time of the interrupt.

Operation: $\quad$ MIN - MAX Rule Evaluation with Optional Rule Weighting
Description: REVW performs either weighted or unweighted evaluation of a list of rules, using fuzzy inputs to produce fuzzy outputs. REVW can be interrupted, so it does not adversely affect interrupt latency.
For REVW to execute correctly, each rule in the knowledge base must consist of a table of 16-bit antecedent pointers followed by a table of 16bit consequent pointers. The value \$FFFE marks boundaries between antecedents and consequents, and between successive rules. The value \$FFFF marks the end of the rule list. REVW can evaluate any number of rules with any number of inputs and outputs.
Setting the $C$ status bit enables weighted evaluation. To use weighted evaluation, a table of 8-bit weighting factors, one per rule, must be stored in memory. Index register Y points to the weighting factors.

Beginning with the address pointed to by the first rule antecedent, REVW evaluates each successive fuzzy input value until it encounters an \$FFFE separator. Operation is similar to that of a MINA instruction. The smallest input value is the truth value of the rule. Next, if weighted evaluation is enabled, a computation is performed, and the truth value is modified. Then, beginning with the address pointed to by the first rule consequent, the truth value is compared to each successive fuzzy output value until another \$FFFE separator is encountered; if the truth value is greater than the current output value, it is written to the output. Operation is similar to that of a MAXM instruction. Rules are processed until an \$FFFF terminator is encountered.

Perform these set up operations before execution.
X must point to the first 16-bit element in the rule list.
A must contain the value \$FF, and the CCR V bit must $=0$
(LDAA \#\$FF places the correct value in A and clears V ).
Clear fuzzy outputs to zeros.
Set or clear the CCR C bit. When weighted evaluation is enabled, Y must point to the first item in a table of 8-bit weighting factors.

Index register $X$ points to the element in the rule list that is being evaluated. X is automatically updated so that execution can resume correctly if the instruction is interrupted. When execution is complete, $X$ points to the address after the \$FFFF separator at the end of the rule list.

Index register Y points to the weighting factor being used. Y is automatically updated so that execution can resume correctly if the instruction is interrupted. When execution is complete, Y points to the last weighting factor used. When weighting is not used $(\mathrm{C}=0), \mathrm{Y}$ is not changed.

Accumulator A holds intermediate results. During antecedent processing, a MIN function compares each fuzzy input to the value stored in A, and writes the smaller of the two to A. When all antecedents have been evaluated, A contains the smallest input value. For unweighted evaluation, this is the truth value used during consequent processing. For weighted evaluation, the value in $A$ is multiplied by the quantity (Rule Weight +1 ) and the upper eight bits of the result replace the content of A. Accumulator A must be initialized to \$FF for the MIN function to evaluate the inputs of the first rule correctly. For subsequent rules, the value $\$ F F$ is written to A when an \$FFFE marker is encountered. At the end of execution, accumulator $A$ holds the truth value for the last rule.

The V status bit signals whether antecedents (0) or consequents (1) are being processed. V must be initialized to zero in order for processing to begin with the antecedents of the first rule. Once execution begins, the value of V is automatically changed as \$FFFE separators are encountered. At the end of execution, V should equal one, because the last element before the \$FF end marker should be a rule consequent. If V is equal to zero at the end of execution, the rule list is incorrect.

Fuzzy outputs must be cleared to $\$ 00$ before processing begins in order for the MAX algorithm used during consequent processing to work correctly. Residual output values would cause incorrect comparison.

Refer to SECTION 9 FUZZY LOGIC SUPPORT for details.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $?$ | - | $?$ | $?$ | $\Delta$ | $!$ |

V: 1; Normally set, unless rule structure is erroneous.
C : Selects weighted (1) or unweighted (0) rule evaluation.
$\mathrm{H}, \mathrm{N}, \mathrm{Z}$ and C may be altered by this instruction.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| REVW <br> (add 2 at end of ins if wts) <br> (add if interrupted) | Special | 183 B | See note ${ }^{-1}$ | ORf $(t \mathrm{Tx}) \mathrm{O}$ <br> $(r f f R f)$ <br> fff + ORft |

Notes:

1. The 3-cycle loop in parentheses expands to five cycles for separators when weighting is enabled. The loop is executed once for each element in the rule list. When an interrupt occurs, there is a 2 -cycle exit sequence, a 4cycle re-entry sequence, then execution resumes with a prefetch of the last antecedent or consequent being processed at the time of the interrupt.

## Operation:



Description: Shifts all bits of memory location M one place to the left. Bit 0 is loaded from the C status bit. The C bit is loaded from the most significant bit of M. Rotate operations include the carry bit to allow extension of shift and rotate operations to multiple bytes. For example, to shift a 24 -bit value one bit to the left, the sequence ASL LOW, ROL MID, ROL HIGH could be used where LOW, MID and HIGH refer to the low-order, middle and high-order bytes of the 24-bit value, respectively.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z : Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \mathrm{C}]+[\overline{\mathrm{N}} \bullet \mathrm{C}]$ (for N and C after the shift)
Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: M7
Set if the MSB of M was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| ROL opr16a | EXT | $75 \mathrm{hh} l \mathrm{l}$ | 4 | rOPw |
| ROL oprx0_xysp | IDX | 65 xb | 3 | rPw |
| ROL oprx9,xysp | IDX1 | 65 xb ff | 4 | rPOw |
| ROL oprx16,xysp | IDX2 | 65 xb ee ff | 5 | frPPw |
| ROL [D,xysp] | [D,IDX] | 65 xb | 6 | fIfrPw |
| ROL [oprx16,xysp] | [IDX2] | 65 xb ee ff | 6 | fIPrPw |

## Operation:



Description: Shifts all bits of accumulator $A$ one place to the left. Bit 0 is loaded from the C status bit. The C bit is loaded from the most significant bit of A . Rotate operations include the carry bit to allow extension of shift and rotate operations to multiple bytes. For example, to shift a 24 -bit value one bit to the left, the sequence ASL LOW, ROL MID, ROL HIGH could be used where LOW, MID and HIGH refer to the low-order, middle and high-order bytes of the 24 -bit value, respectively.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z : Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \mathrm{C}]+[\overline{\mathrm{N}} \bullet \mathrm{C}]$ (for N and C after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: A7
Set if the MSB of A was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| ROLA | INH | 45 | 1 | 0 |

## Rotate Left B

## Operation:



Description: Shifts all bits of accumulator B one place to the left. Bit 0 is loaded from the C status bit. The C bit is loaded from the most significant bit of B . Rotate operations include the carry bit to allow extension of shift and rotate operations to multiple bytes. For example, to shift a 24 -bit value one bit to the left, the sequence ASL LOW, ROL MID, ROL HIGH could be used where LOW, MID and HIGH refer to the low-order, middle and high-order bytes of the 24-bit value, respectively.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}]+[\overline{\mathrm{N}} \bullet \mathrm{C}]$ (for N and C after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: B7
Set if the MSB of B was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| ROLB | INH | 55 | 1 | 0 |

## Operation:



Description: Shifts all bits of memory location $M$ one place to the right. Bit 7 is loaded from the C status bit. The C bit is loaded from the least significant bit of M. Rotate operations include the carry bit to allow extension of shift and rotate operations to multiple bytes. For example, to shift a 24 -bit value one bit to the right, the sequence LSR HIGH, ROR MID, ROR LOW could be used where LOW, MID and HIGH refer to the low-order, middle, and high-order bytes of the 24-bit value, respectively.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z : Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \mathrm{C}]+[\overline{\mathrm{N}} \bullet \mathrm{C}]$ (for N and C after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: M0
Set if the LSB of $M$ was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| ROR opr16a | EXT | $76 \mathrm{hh} l \mathrm{l}$ | 4 | rOPw |
| ROR oprx0_xysp | IDX | 66 xb | 3 | rPw |
| ROR oprx9,xysp | IDX1 | 66 xb ff | 4 | rPOw |
| ROR oprx16,xysp | IDX2 | 66 xb ee ff | 5 | frPPw |
| ROR [D,xysp] | [D,IDX] | 66 xb | 6 | fIfrPw |
| ROR [oprx16,xysp] | [IDX2] | 66 xb ee ff | 6 | fIPrPw |

## Operation:



Description: Shifts all bits of accumulator A one place to the right. Bit 7 is loaded from the $C$ status bit. The $C$ bit is loaded from the least significant bit of $A$. Rotate operations include the carry bit to allow extension of shift and rotate operations to multiple bytes. For example, to shift a 24 -bit value one bit to the right, the sequence LSR HIGH, ROR MID, ROR LOW could be used where LOW, MID and HIGH refer to the low-order, middle, and high-order bytes of the 24-bit value, respectively.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}]+[\overline{\mathrm{N}} \bullet \mathrm{C}]$ (for N and C after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: AO
Set if the LSB of A was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| RORA | INH | 46 | 1 | 0 |

## Operation:



Description: Shifts all bits of accumulator B one place to the right. Bit 7 is loaded from the $C$ status bit. The $C$ bit is loaded from the least significant bit of $B$. Rotate operations include the carry bit to allow extension of shift and rotate operations to multiple bytes. For example, to shift a 24-bit value one bit to the right, the sequence LSR HIGH, ROR MID, ROR LOW could be used where LOW, MID and HIGH refer to the low-order, middle and high-order bytes of the 24-bit value, respectively.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad \mathrm{N} \oplus \mathrm{C}=[\mathrm{N} \bullet \overline{\mathrm{C}}]+[\overline{\mathrm{N}} \bullet \mathrm{C}]$ (for N and C after the shift) Set if ( N is set and C is cleared) or ( N is cleared and C is set); cleared otherwise (for values of N and C after the shift).
C: BO
Set if the LSB of B was set before the shift; cleared otherwise.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :--- | :---: | :---: |
| RORB | INH | 56 | 1 | 0 |

Operation: $\quad\left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow$ PPAGE
(SP) $+\$ 0001 \Rightarrow$ SP
$\left.\left(M_{(S P)}: M_{(S P}+1\right)\right) \Rightarrow P C_{H}: P C_{L}$
(SP) $+\$ 0002 \Rightarrow$ SP
Description: Terminates subroutines in expanded memory invoked by the CALL instruction. Returns execution flow from the subroutine to the calling program. The program overlay page (PPAGE) register and the return address are restored from the stack; program execution continues at the restored address. For code compatibility purposes, CALL and RTC also execute correctly in M68HC12 devices that do not have expanded memory capability.

## Condition Codes and Boolean Formulas:

| s | x | H | 1 | N | z | v | c |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | - |

None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| RTC | INH | OA | 6 | uUnPPP |

Operation: $\quad\left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow \mathrm{CCR} ;(\mathrm{SP})+\$ 0001 \Rightarrow \mathrm{SP}$
$\left(M_{(S P)}: M_{(S P}+1\right) \Rightarrow B: A ;(S P)+\$ 0002 \Rightarrow S P$
$\left(M_{(S P)}: M_{(S P+1)}\right) \Rightarrow X_{H}: X_{L} ;(S P)+\$ 0004 \Rightarrow S P$ $\left(M_{(S P)}: M_{(S P+1)} \Rightarrow \mathrm{PC}_{H}: \mathrm{PC}_{\mathrm{L}} ;(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP}\right.$ $\left(M_{(S P)}: M_{(S P+1)}\right) \Rightarrow Y_{H}: Y_{L} ;(S P)+\$ 0004 \Rightarrow S P$

Description: Restores system context after interrupt service processing is completed. The condition codes, accumulators B and A, index register X, the PC, and index register Y are restored to a state pulled from the stack. The X mask bit may be cleared as a result of an RTI instruction, but cannot be set if it was cleared prior to execution of the RTI instruction.

If another interrupt is pending when RTI has finished restoring registers from the stack, the SP is adjusted to preserve stack content, and the new vector is fetched. This operation is functionally identical to the same operation in the M 68 HC 11 , where registers actually are re-stacked, but is faster.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ |  | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\Delta$ | $\Downarrow$ | $\mathbf{C}$ |  |  |  |  |  |
|  | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |  |

Condition codes take on the value pulled from the stack, except that the X mask bit cannot change from zero to one. Software can leave the $X$ bit set, leave it cleared, or change it from one to zero, but it can only be set by a reset or by recognition of an XIRQ interrupt.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| RTI |  |  |  |  |
| (with interrupt pending) | INH | 0 B | 8 | uUUUUPPP |
| uUUUUVfPPP |  |  |  |  |

Operation: $\left.\quad\left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}}+1\right)\right) \Rightarrow \mathrm{PC}_{\mathrm{H}}: \mathrm{PC}_{\mathrm{L}} ;(\mathrm{SP})+\$ 0002 \Rightarrow \mathrm{SP}$
Description: Restores context at the end of a subroutine. Loads the program counter with a 16 -bit value pulled from the stack and increments the stack pointer by two. Program execution continues at the address restored from the stack.

Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| RTS | INH | $3 D$ | 5 | UfPPP |

## Subtract Accumulators

Operation: $\quad(A)-(B) \Rightarrow A$
Description: Subtracts the content of accumulator B from the content of accumulator $A$ and places the result in $A$. The content of $B$ is not affected. For subtraction instructions, the C status bit represents a borrow.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \quad \mathrm{A} 7 \cdot \overline{\mathrm{~B} 7} \bullet \overline{\mathrm{R7}}+\overline{\mathrm{A} 7} \bullet \mathrm{B7} \bullet \mathrm{R7}$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
$\mathrm{C}: \quad \overline{\mathrm{A}} \cdot \mathrm{B} 7+\mathrm{B} 7 \bullet \mathrm{R} 7+\mathrm{R} 7 \bullet \overline{\mathrm{~A} 7}$
Set if the absolute value of $B$ is larger than the absolute value of $A$; cleared otherwise.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| SBA | INH | 1816 | 2 | 00 |

# SBCA 

Operation: $\quad(A)-(M)-C \Rightarrow A$
Description: Subtracts the content of memory location M and the value of the C status bit from the content of accumulator A . The result is placed in A . For subtraction instructions, the C status bit represents a borrow.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z : Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \quad \mathrm{X} 7 \bullet \overline{\mathrm{M} 7} \bullet \overline{\mathrm{R} 7}+\overline{\mathrm{X} 7} \bullet \mathrm{M} 7 \bullet \mathrm{R} 7$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
C: $\overline{\mathrm{X} 7} \bullet \mathrm{M} 7+\mathrm{M} 7 \bullet R 7+R 7 \bullet \overline{\mathrm{X} 7}$
Set if the absolute value of the content of memory plus previous carry is larger than the absolute value of the accumulator; cleared otherwise.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| SBCA \#opr8i | IMM | 82 ii | 1 | P |
| SBCA opr8a | DIR | 92 dd | 3 | rfP |
| SBCA opr16a | EXT | B2 hh ll | 3 | rOP |
| SBCA oprx0_xysp | IDX | A2 xb | 3 | rfP |
| SBCA oprx9,xysp | IDX1 | A2 xb ff | 3 | rPO |
| SBCA oprx16,xysp | IDX2 | A2 xb ee ff | 4 | frPP |
| SBCA [D,xysp] | [D,IDX] | A2 xb | 6 | fIfrfP |
| SBCA [oprx16,xysp] | $[I D X 2] ~$ | A2 xb ee ff | 6 | fIPrfP |

# SBCB 

Operation: $\quad(B)-(M)-C \Rightarrow B$
Description: Subtracts the content of memory location $M$ and the value of the $C$ status bit from the content of accumulator B . The result is placed in B . For subtraction instructions, the C status bit represents a borrow.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: $\quad \mathrm{X} 7 \cdot \overline{\mathrm{M} 7} \cdot \overline{\mathrm{R7}}+\overline{\mathrm{X7}} \bullet \mathrm{M} 7 \bullet \mathrm{R7}$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
C: $\overline{\mathrm{X7}} \bullet \mathrm{M} 7+\mathrm{M} 7 \bullet R 7+R 7 \bullet \overline{\mathrm{X7}}$
Set if the absolute value of the content of memory plus previous carry is larger than the absolute value of the accumulator; cleared otherwise.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| SBCB \#opr8i | IMM | C2 ii | 1 | P |
| SBCB opr8a | DIR | D2 dd | 3 | rfP |
| SBCB opr16a | EXT | F2 hh ll | 3 | rOP |
| SBCB oprx0_xysp | IDX | E2 xb | 3 | rfP |
| SBCB oprx9,xysp | IDX1 | E2 xb ff | 3 | rPo |
| SBCB oprx16,xysp | IDX2 | E2 xb ee ff | 4 | frPP |
| SBCB [D,xysp] | [D,IDX] | E2 xb | 6 | fIfrfP |
| SBCB [oprx16,xysp] | $[I D X 2] ~$ | E2 xb ee ff | 6 | fIPrfP |

Operation: $\quad 1 \Rightarrow C$ bit
Description: Sets the $C$ status bit. This instruction is assembled as ORCC \#\$01. The ORCC instruction can be used to set any combination of bits in the CCR in one operation.

SEC can be used to set up the C bit prior to a shift or rotate instruction involving the $C$ bit.

## Condition Codes and Boolean Formulas:

| s | x | H | 1 | N | z | v | c |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | 1 |

C: 1; Set.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| SEC translates to... <br> ORCC \#\$01 | IMM | 1401 | 1 | P |

Operation: $1 \Rightarrow \mid$ bit
Description: Sets the I mask bit. This instruction is assembled as ORCC \#\$10. The ORCC instruction can be used to set any combination of bits in the CCR in one operation. When the I bit is set, all maskable interrupts are inhibited, and the CPU will recognize only non-maskable interrupt sources or an SWI.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

I: 1; Set.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| SEI translates to... <br> ORCC \#\$10 | IMM | 1410 | 1 | P |

Operation: $\quad 1 \Rightarrow \mathrm{~V}$ bit
Description: Sets the $V$ status bit. This instruction is assembled as ORCC \#\$02. The ORCC instruction can be used to set any combination of bits in the CCR in one operation.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | 1 | - |

V: 1;Set.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| SEV translates to... <br> ORCC \#\$02 | IMM | 1402 | 1 | P |

Operation: If r 1 bit $7=0$, then $\$ 00:(r 1) \Rightarrow \mathrm{r} 2$
If r 1 bit $7=1$, then $\$ \mathrm{FF}:(\mathrm{r} 1) \Rightarrow \mathrm{r} 2$
Description: This instruction is an alternate mnemonic for the TFR $\mathrm{r} 1, \mathrm{r} 2$ instruction, where r 1 is an 8 -bit register and r 2 is a 16 -bit register. The result in r 2 is the 16 -bit sign extended representation of the original two's complement number in $r 1$. The content of $r 1$ is unchanged in all cases except that of SEX A,D (D is A : B).

## Condition Codes and Boolean Formulas:



None affected.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code1 | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| SEX $a b c, d x y s$ | INH | B7 eb | 1 | P |

Notes:

1. Legal coding for eb is summarized in the following table. Columns represent the high-order digit, and rows represent the low-order digit in hexadecimal (MSB is a don't-care).

|  | 0 | 1 | 2 |
| :---: | :---: | :---: | :---: |
| 3 | sex:A $\Rightarrow$ TMP2 | sex:B $\Rightarrow$ TMP2 | sex:CCR $\Rightarrow$ TMP2 |
| 4 | $\begin{aligned} & \text { sex:A } \Rightarrow D \\ & \text { SEX A,D } \end{aligned}$ | $\begin{aligned} & \text { sex: } B \Rightarrow D \\ & \text { SEX B,D } \end{aligned}$ | $\begin{aligned} & \text { sex:CCR } \Rightarrow D \\ & \text { SEX CCR,D } \end{aligned}$ |
| 5 | $\begin{aligned} & \text { sex:A } \Rightarrow X \\ & \text { SEX } A, X \end{aligned}$ | $\begin{aligned} & \text { sex }: B \Rightarrow X \\ & \text { SEX } B, X \end{aligned}$ | $\begin{aligned} & \text { sex:CCR } \Rightarrow X \\ & \text { SEX CCR,X } \end{aligned}$ |
| 6 | $\begin{gathered} \text { sex:A } \Rightarrow Y \\ \text { SEX A, } Y \end{gathered}$ | $\begin{aligned} & \text { sex: } B \Rightarrow Y \\ & \text { SEX } B, Y \end{aligned}$ | $\begin{gathered} \text { sex:CCR } \Rightarrow Y \\ \text { SEX CCR,Y } \end{gathered}$ |
| 7 | $\begin{aligned} & \text { sex:A } \Rightarrow \text { SP } \\ & \text { SEX A,SP } \end{aligned}$ | $\begin{gathered} \text { sex: } B \Rightarrow S P \\ \text { SEX B,SP } \end{gathered}$ | $\begin{aligned} & \text { sex:CCR } \Rightarrow \text { SP } \\ & \text { SEX CCR,SP } \end{aligned}$ |

Operation: $\quad(A) \Rightarrow M$
Description: Stores the content of accumulator $A$ in memory location $M$. The content of $A$ is unchanged.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| STAA opr8a | DIR | 5A dd | 2 | Pw |
| STAA opr16a | EXT | 7 A hh ll | 3 | wOP |
| STAA oprx0_xysp | IDX | 6A xb | 2 | Pw |
| STAA oprx9,xysp | IDX1 | 6A xb ff | 3 | PwO |
| STAA oprx16,xysp | IDX2 | 6A xb ee ff | 3 | PwP |
| STAA [D,xysp] | [D,IDX] | 6A xb | 5 | PIfPw |
| STAA [oprx16,xysp] | $[I D X 2] ~$ | 6A xb ee ff | 5 | PIPPw |

Operation: $\quad(B) \Rightarrow M$
Description: Stores the content of accumulator B in memory location M. The content of $B$ is unchanged.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.

## Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| STAB opr8a | DIR | 5B dd | 2 | Pw |
| STAB opr16a | EXT | 7B hh ll | 3 | wOP |
| STAB oprx0_xysp | IDX | 6B xb | 2 | Pw |
| STAB oprx9,xysp | IDX1 | 6B xb ff | 3 | PwO |
| STAB oprx16,xysp | IDX2 | 6B xb ee ff | 3 | PwP |
| STAB [D,xysp] | [D,IDX] | 6B xb | 5 | PIfPw |
| STAB [oprx16,xysp] | $[I D X 2]$ | 6B xb ee ff | 5 | PIPPw |

Operation: $\quad(A: B) \Rightarrow M: M+1$
Description: Stores the content of double accumulator D in memory location M : M + 1. The content of $D$ is unchanged.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ |  | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathbf{S}$ | $\mathbf{C}$ |  |  |  |  |  |  |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is \$0000; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| STD opr8a | DIR | 5 c dd | 2 | PW |
| STD opr16a | EXT | 7 Chh 11 | 3 | Wop |
| STD oprxO_xysp | IDX | 6 C xb | 2 | PW |
| STD oprx9,xysp | IDX1 | 6 Cxb ff | 3 | Pwo |
| STD oprx16,xysp | IDX2 | 6 Clb ee ff | 3 | PWP |
| STD [D,xysp] | [D,IDX] | 6 Cxb | 5 | PIfPW |
| STD [oprx16,xysp] | [IDX2] | 6 Cbb ee ff | 5 | PIPPW |

Operation: $\quad(S P)-\$ 0002 \Rightarrow S P ;$ RTN $\left._{H}: R_{L N} \Rightarrow\left(M_{(S P)}: M_{(S P}+1\right)\right)$
$\left.(S P)-\$ 0002 \Rightarrow S P ; Y_{H}: Y_{L} \Rightarrow\left(M_{(S P)}: M_{(S P}+1\right)\right)$
$(S P)-\$ 0002 \Rightarrow S P ; X_{H}: X_{L} \Rightarrow\left(M_{(S P)}: M_{(S P+1)}\right)$
$\left.(S P)-\$ 0002 \Rightarrow S P ; B: A \Rightarrow\left(M_{(S P)}: M_{(S P}+1\right)\right)$
(SP) $-\$ 0001 \Rightarrow$ SP; CCR $\Rightarrow\left(\mathrm{M}_{(\mathrm{SP})}\right)$
Stop All Clocks
Description: When the $S$ control bit is set, STOP is disabled and operates like a twocycle NOP instruction. When the S bit is cleared, STOP stacks CPU context, stops all system clocks, and puts the device in standby mode.

Standby operation minimizes system power consumption. The contents of registers and the states of I/O pins remain unchanged.

Asserting the $\overline{R E S E T}, \overline{\text { XIRQ, or }} \overline{\mathrm{IRQ}}$ signals ends standby mode. Stacking on entry to STOP allows the CPU to recover quickly when an interrupt is used, provided a stable clock is applied to the device. If the system uses a clock reference crystal that also stops during low-power mode, crystal start-up delay lengthens recovery time.

If $\overline{\mathrm{XIRQ}}$ is asserted while the X mask bit $=0$ ( $\overline{\mathrm{XIRQ}}$ interrupts enabled), execution resumes with a vector fetch for the $\overline{X I R Q}$ interrupt. If the $X$ mask bit $=1(\overline{\mathrm{XIRQ}}$ interrupts disabled $)$, a two-cycle recovery sequence including an O cycle is used to adjust the instruction queue, and execution continues with the next instruction after STOP.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| STOP (entering STOP) | INH | 18 3E | 9 | $00 S S S f S s f$ |
| (exiting STOP) |  |  | 5 | VfPPP |
| (continue) |  |  | 2 | fO |
| (if STOP disabled) |  |  | 2 | 00 |

Operation: $\quad\left(S P_{\mathrm{H}}: S P_{\mathrm{L}}\right) \Rightarrow \mathrm{M}: \mathrm{M}+1$
Description: Stores the content of the stack pointer in memory. The most significant byte of the SP is stored at the specified address, and the least significant byte of the SP is stored at the next higher byte address (the specified address plus one).

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| STS opr8a | DIR | 5 F dd | 2 | PW |
| STS opr16a | EXT | 7 F hh ll | 3 | WOP |
| STS oprx0_xysp | IDX | 6 F xb | 2 | PW |
| STS oprx9,xysp | IDX1 | 6 F xb ff | 3 | PWo |
| STS oprx16,xysp | IDX2 | 6 F xb ee ff | 3 | PWP |
| STS [D,xysp] | [D,IDX] | 6 F xb | 5 | PIfPW |
| STS [oprx16,xysp] | [IDX2] | 6 F xb ee ff | 5 | PIPPW |

Operation: $\quad\left(X_{H}: X_{L}\right) \Rightarrow M: M+1$
Description: Stores the content of index register X in memory. The most significant byte of X is stored at the specified address, and the least significant byte of X is stored at the next higher byte address (the specified address plus one).

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| STX opr8a | DIR | 5 E dd | 2 | PW |
| STX opr16a | EXT | 7 E hh ll | 3 | WOP |
| STX oprx0_xysp | IDX | 6 E xb | 2 | PW |
| STX oprx9,xysp | IDX1 | 6 E xb ff | 3 | PWo |
| STX oprx16,xysp | IDX2 | 6 E xb ee ff | 3 | PWP |
| STX [D, $x y s p]$ | [D,IDX] | 6 E xb | 5 | PIfPW |
| STX[oprx16,xysp] | $[I D X 2]$ | 6 E xb ee ff | 5 | PIPPW |

Operation: $\quad\left(Y_{H}: Y_{L}\right) \Rightarrow M: M+1$
Description: Stores the content of index register Y in memory. The most significant byte of Y is stored at the specified address, and the least significant byte of Y is stored at the next higher byte address (the specified address plus one).

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| STY opr8a | DIR | 5D dd | 2 | PW |
| STY opr16a | EXT | 7D hh 11 | 3 | WOP |
| STY oprx0_xysp | IDX | 6D xb | 2 | PW |
| STY oprx9,xysp | IDX1 | 6D xb ff | 3 | PWo |
| STY oprx16,xysp | IDX2 | 6D xb ee ff | 3 | PWP |
| STY [D,xysp] | [D,IDX] | 6D xb | 5 | PIfPW |
| STY [oprx16,xysp] | $[I D X 2]$ | 6D xb ee ff | 5 | PIPPW |

Operation: $\quad(A)-(M) \Rightarrow A$
Description: Subtracts the content of memory location M from the content of accumulator A , and places the result in A . For subtraction instructions, the C status bit represents a borrow.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
$Z$ : Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \quad \mathrm{X} 7 \bullet \overline{\mathrm{M} 7} \bullet \overline{\mathrm{R} 7}+\overline{\mathrm{X} 7} \bullet \mathrm{M} 7 \bullet \mathrm{R} 7$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
C: $\overline{\mathrm{X} 7} \bullet \mathrm{M} 7+\mathrm{M} 7 \bullet R 7+R 7 \cdot \overline{\mathrm{X} 7}$
Set if the value of the content of memory is larger than the value of the accumulator; cleared otherwise.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| SUBA \#opr8i | IMM | 80 ii | 1 | P |
| SUBA opr8a | DIR | 90 dd | 3 | rfP |
| SUBA opr16a | EXT | B0 hh ll | 3 | roP |
| SUBA oprx0_xysp | IDX | A0 xb | 3 | rfP |
| SUBA oprx9,xysp | IDX1 | A0 xb ff | 3 | rPO |
| SUBA oprx16,xysp | IDX2 | A0 xb ee ff | 4 | frPP |
| SUBA [D,xysp] | $1 \mathrm{D,IDX]}$ | A0 xb | 6 | fIfrfP |
| SUBA [oprx16,xysp] | $[I D X 2] ~$ | A0 xb ee ff | 6 | fIPrfP |

Operation: $\quad(B)-(M) \Rightarrow B$
Description: Subtracts the content of memory location M from the content of accumulator B and places the result in B. For subtraction instructions, the C status bit represents a borrow.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
$\mathrm{V}: \quad \mathrm{X} 7 \bullet \overline{\mathrm{M} 7} \bullet \overline{\mathrm{R7}}+\overline{\mathrm{X}} \cdot \mathrm{M} 7 \bullet \mathrm{R} 7$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
C: $\overline{X 7} \cdot M 7+M 7 \bullet R 7+R 7 \bullet \overline{X 7}$
Set if the value of the content of memory is larger than the value of the accumulator; cleared otherwise.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| SUBB \#opr8i | IMM | C0 ii | 1 | P |
| SUBB opr8a | DIR | D0 dd | 3 | rfP |
| SUBB orr16a | EXT | F0 hh ll | 3 | roP |
| SUBB oprx0 $x y s p$ | IDX | E0 xb | 3 | rfP |
| SUBB oprx9,xysp | IDX1 | E0 xb ff | 3 | rPO |
| SUBB oprx16,xysp | IDX2 | E0 xb ee ff | 4 | frPP |
| SUBB [D,xysp] | [D,IDX] | E0 xb | 6 | fIfrfP |
| SUBB [oprx16,xysp] | [IDX2] | E0 xb ee ff | 6 | fIPrfP |

Operation: $\quad(A: B)-(M: M+1) \Rightarrow A: B$
Description: Subtracts the content of memory location $M$ : $M+1$ from the content of double accumulator D and places the result in D. For subtraction instructions, the C status bit represents a borrow.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

N : Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 0000$; cleared otherwise.
V: D15 • $\overline{\mathrm{M} 15} \cdot \overline{\mathrm{R} 15}+\overline{\mathrm{D} 15} \cdot \mathrm{M} 15 \cdot \mathrm{R} 15$
Set if a two's complement overflow resulted from the operation; cleared otherwise.
C: $\overline{\mathrm{D} 15} \cdot \mathrm{M} 15+\mathrm{M} 15 \cdot \mathrm{R} 15+\mathrm{R} 15 \cdot \overline{\mathrm{D} 15}$
Set if the value of the content of memory is larger than the value of the accumulator; cleared otherwise.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| SUBD \#opr16i | IMM | 83 jj kk | 2 | OP |
| SUBD opr8a | DIR | 93 dd | 3 | RfP |
| SUBD opr16a | EXT | B3 hh ll | 3 | ROP |
| SUBD oprx0_xysp | IDX | A3 xb | 3 | RfP |
| SUBD oprx99 $x y s s p ~$ | IDX1 | A3 xb ff | 3 | RPO |
| SUBD oprx16,xysp | IDX2 | A3 xb ee ff | 4 | fRPP |
| SUBD [D,xysp] | [D,IDX] | A3 xb | 6 | fIfRfP |
| SUBD [oprx16,xysp] | [IDX2] | A3 xb ee ff | 6 | fIPRfP |

Operation: $\left.\quad(S P)-\$ 0002 \Rightarrow S P ; R_{H}: R T N_{L} \Rightarrow\left(M_{(S P)}: M_{(S P}+1\right)\right)$
$(S P)-\$ 0002 \Rightarrow S P ; Y_{H}: Y_{L} \Rightarrow\left(M_{(S P)}: M_{(S P+1)}\right)$
$(S P)-\$ 0002 \Rightarrow S P ; X_{H}: X_{L} \Rightarrow\left(M_{(S P)}: M_{(S P+1)}\right)$
$\left.(S P)-\$ 0002 \Rightarrow S P ; B: A \Rightarrow\left(M_{(S P)}: M_{(S P}+1\right)\right)$
(SP) $-\$ 0001 \Rightarrow \mathrm{SP} ; \mathrm{CCR} \Rightarrow\left(\mathrm{M}_{(\mathrm{SP})}\right)$
$1 \Rightarrow 1$
(SWI Vector) $\Rightarrow \mathrm{PC}$
Description: Causes an interrupt without an external interrupt service request. Uses the address of the next instruction after SWI as a return address. Stacks the return address, index registers $Y$ and $X$, accumulators $B$ and $A$, and the CCR, decrementing the SP before each item is stacked. The I mask bit is then set, the PC is loaded with the SWI vector, and instruction execution resumes at that location. SWI is not affected by the I mask bit. Refer to SECTION 7 EXCEPTION PROCESSING for more information.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |

I: 1; Set.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| SWI | INH | 3 F | 9 | VSPSSPSsP 1 |

Notes:

1. The CPU also uses the SWI processing sequence for hardware interrupts and unimplemented opcode traps. A variation of the sequence (VfPPP) is used for resets.

## TAB

## Transfer from Accumulator A to Accumulator B

Operation: $\quad(A) \Rightarrow B$
Description: Moves the content of accumulator $A$ to accumulator $B$. The former content of $B$ is lost; the content of $A$ is not affected. Unlike the general transfer instruction TFR A,B which does not affect condition codes, the TAB instruction affects the $N, Z$, and $V$ status bits for compatibility with M68HC11.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| TAB | INH | 18 0E | 2 | 00 |

## TAP

Operation: $\quad(A) \Rightarrow C C R$
Description: Transfers the logic states of bits [7:0] of accumulator A to the corresponding bit positions of the CCR. The content of A remains unchanged. The $X$ mask bit can be cleared as a result of a TAP, but cannot be set if it was cleared prior to execution of the TAP. If the I bit is cleared, there is a one cycle delay before the system allows interrupt requests. This prevents interrupts from occurring between instructions in the sequences CLI, WAI and CLI, SEI.

This instruction is accomplished with the TFR A,CCR instruction. For compatibility with the M68HC11, the mnemonic TAP is translated by the assembler.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\Delta$ | $\Downarrow$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Condition codes take on the value of the corresponding bit of accumulator A , except that the X mask bit cannot change from zero to one. Software can leave the $X$ bit set, leave it cleared, or change it from one to zero, but it can only be set by a reset or by recognition of an XIRQ interrupt.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| TAP translates to... <br> TFR A,CCR | INH | B7 02 | 1 | P |

## Transfer from Accumulator B to Accumulator A

Operation: $\quad(B) \Rightarrow A$
Description: Moves the content of accumulator $B$ to accumulator A. The former content of $A$ is lost; the content of $B$ is not affected. Unlike the general transfer instruction TFR B,A, which does not affect condition codes, the TBA instruction affects $\mathrm{N}, \mathrm{Z}$, and V for compatibility with M68HC11.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| TBA | INH | 180 F | 2 | 00 |

Operation: If (Counter) $=0$, then (PC) $+\$ 0003+$ Rel $\Rightarrow \mathrm{PC}$
Description: Tests the specified counter register A, B, D, X, Y, or SP. If the counter register is zero, branches to the specified relative destination. TBEQ is encoded into three bytes of machine code including a 9-bit relative offset ( -256 to +255 locations from the start of the next instruction).

DBEQ and IBEQ instructions are similar to TBEQ, except that the counter is decremented or incremented rather than simply being tested. Bits 7 and 6 of the instruction postbyte are used to determine which operation is to be performed.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code ${ }^{1}$ | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| TBEQ abdxys,re/9 | REL | 04 lb rr | $3 / 3$ | PPP |

Notes:

1. Encoding for 1 lb is summarized in the following table. Bit 3 is not used (don't care), bit 5 selects branch on zero (TBEQ - 0 ) or not zero (TBNE -1) versions, and bit 4 is the sign bit of the 9 -bit relative offset. Bits 7 and 6 should be $0: 1$ for TBEQ.

| Count Register | Bits 2:0 | Source Form | Object Code (if offset is positive) | Object Code (if offset is negative) |
| :---: | :---: | :---: | :---: | :---: |
| A | 000 | TBEQ A, rel9 | 0440 rr | 0450 rr |
| B | 001 | TBEQ B, rel9 | 0441 rr | 0451 rr |
| D | 100 | TBEQ D, rel9 | 0444 rr | 0454 rr |
| X | 101 | TBEQ X, rel9 | 0445 rr | 0455 rr |
| Y | 110 | TBEQ Y, rel9 | 0446 rr | 0456 rr |
| SP | 111 | TBEQ SP, rel9 | 0447 rr | 0457 rr |

Operation: $\quad(M)+[(B) \times((M+1)-(M))] \Rightarrow A$
Description: Linearly interpolates one of 256 result values that fall between each pair of data entries in a lookup table stored in memory. Data points in the table represent the endpoints of equally spaced line segments. Table entries and the interpolated result are 8-bit values. The result is stored in accumulator $A$.

Before executing TBL, set up an index register so that it will point to the starting point (X1) of a line segment when the instruction is executed. X1 is the table entry closest to, but less than or equal to, the desired lookup value. The next table entry after X 1 is X 2 . XL is the X position of the desired lookup point. Load accumulator $B$ with a binary fraction (radix point to left of $M S B$ ), representing the ratio $(X L-X 1) \div(X 2-X 1)$.

The 8-bit unrounded result is calculated using the following expression:

$$
A=Y 1+[(B) \times(Y 2-Y 1)]
$$

Where

$$
(B)=(X L-X 1) \div(X 2-X 1)
$$

Y1 = 8-bit data entry pointed to by <effective address>
$\mathrm{Y} 2=8$-bit data entry pointed to by <effective address>+1
The intermediate value $[(B) \times(Y 2-Y 1)]$ produces a 16-bit result with the radix point between bits 7 and 8 . The result in $A$ is the upper 8 -bits (integer part) of this intermediate 16 -bit value, plus the 8 -bit value Y 1 .

Any indexed addressing mode referenced to $\mathrm{X}, \mathrm{Y}, \mathrm{SP}$, or PC, except indirect modes or 9-bit and 16-bit offset modes, can be used to identify the first data point ( $\mathrm{X} 1, \mathrm{Y} 1$ ). The second data point is the next table entry.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | - | $?$ |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
C: Undefined.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| TBL oprx0_xysp | IDX | $183 \mathrm{D} \times \mathrm{b}$ | 8 | OrrffffP |

Operation: If (Counter) $\neq 0$, then $(\mathrm{PC})+\$ 0003+\mathrm{ReI} \Rightarrow \mathrm{PC}$,
Description: Tests the specified counter register A, B, D, X, Y, or SP. If the counter register is not zero, branches to the specified relative destination. TBNE is encoded into three bytes of machine code including a 9 -bit relative offset ( -256 to +255 locations from the start of the next instruction).

DBNE and IBNE instructions are similar to TBNE, except that the counter is decremented or incremented rather than simply being tested. Bits 7 and 6 of the instruction postbyte are used to determine which operation is to be performed.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code ${ }^{1}$ | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| TBNE abdxys,rel9 | REL | 04 lb rr | $3 / 3$ | PPP |

Notes:

1. Encoding for 1 lb is summarized in the following table. Bit 3 is not used (don't care), bit 5 selects branch on zero (TBEQ - 0 ) or not zero (TBNE -1) versions, and bit 4 is the sign bit of the 9 -bit relative offset. Bits 7 and 6 should be 0:1 for TBNE.

| Count Register | Bits 2:0 | Source Form | Object Code (if offset is positive) | Object Code (if offset is negative) |
| :---: | :---: | :---: | :---: | :---: |
| A | 000 | TBNE A, rel9 | 0460 rr | 0470 rr |
| B | 001 | TBNE B, rel9 | 0461 rr | 0471 rr |
| D | 100 | TBNE D, rel9 | 0464 rr | 0474 rr |
| X | 101 | TBNE X, rel9 | 0465 rr | 0475 rr |
| Y | 110 | TBNE Y, rel9 | 0466 rr | 0476 rr |
| SP | 111 | TBNE SP, rel9 | 0467 rr | 0477 rr |

## Operation: See table.

Description: Transfers the content of a source register to a destination register specified in the instruction. The order in which transfers between 8 -bit and 16bit registers are specified affects the high byte of the 16 -bit registers differently. Cases involving TMP2 and TMP3 are reserved for Motorola use, so some assemblers may not permit their use. It is possible to generate these cases by using DC.B or DC.W assembler directives.

## Condition Codes and Boolean Formulas:


or

| $\Delta$ | $\Downarrow$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |

None affected, unless the CCR is the destination register. Condition codes take on the value of the corresponding source bits, except that the X mask bit cannot change from zero to one. Software can leave the $X$ bit set, leave it cleared, or change it from one to zero, but it can only be set by a reset or by recognition of an XIRQ interrupt.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code1 | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :--- |
| TFR $a b c d x y s, a b c d x y s$ | INH | B7 eb | 1 | P |

Notes:

1. Legal coding for eb is summarized in the following table. Columns represent the high-order digit, and rows represent the low-order digit in hexadecimal (MSB is a don't-care).

|  | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | $A \Rightarrow A$ | $B \Rightarrow A$ | CCR $\Rightarrow \mathrm{A}$ | TMP3 ${ }_{L} \Rightarrow \mathrm{~A}$ | $B \Rightarrow A$ | $\mathrm{X}_{\mathrm{L}} \Rightarrow \mathrm{A}$ | $Y_{L} \Rightarrow A$ | $\mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{A}$ |
| 1 | $A \Rightarrow B$ | $B \Rightarrow B$ | $C C R \Rightarrow B$ | TMP3 ${ }_{L} \Rightarrow$ B | $B \Rightarrow B$ | $\mathrm{X}_{\mathrm{L}} \Rightarrow \mathrm{B}$ | $Y_{L} \Rightarrow B$ | $S P_{L} \Rightarrow B$ |
| 2 | $A \Rightarrow C C R$ | $B \Rightarrow C C R$ | CCR $\Rightarrow$ CCR | TMP3 ${ }_{\text {L }} \Rightarrow$ CCR | $B \Rightarrow C C R$ | $X_{L} \Rightarrow C C R$ | $Y_{L} \Rightarrow C C R$ | $S P_{L} \Rightarrow C C R$ |
| 3 | sex:A $\Rightarrow$ TMP2 | sex:B $\Rightarrow$ TMP2 | sex:CCR $\Rightarrow$ TMP2 | TMP3 $\Rightarrow$ TMP2 | D $\Rightarrow$ TMP2 | $\mathrm{X} \Rightarrow$ TMP2 | $Y \Rightarrow$ TMP2 | SP $\Rightarrow$ TMP2 |
| 4 | $\begin{aligned} & \text { sex:A } \Rightarrow D \\ & \text { SEX A,D } \end{aligned}$ | $\begin{gathered} \text { sex: } B \Rightarrow D \\ \text { SEX } B, D \end{gathered}$ | $\begin{aligned} & \text { sex:CCR } \Rightarrow D \\ & \text { SEX CCR,D } \end{aligned}$ | TMP3 $\Rightarrow$ D | $\mathrm{D} \Rightarrow \mathrm{D}$ | $\mathrm{X} \Rightarrow \mathrm{D}$ | $\mathrm{Y} \Rightarrow \mathrm{D}$ | $\mathrm{SP} \Rightarrow \mathrm{D}$ |
| 5 | $\begin{aligned} & \text { sex: } A \Rightarrow X \\ & \text { SEX A,X } \end{aligned}$ | $\begin{aligned} & \text { sex: } B \Rightarrow X \\ & \text { SEX } B, X \end{aligned}$ | $\begin{aligned} & \hline \text { sex:CCR } \Rightarrow X \\ & \text { SEX CCR,X } \end{aligned}$ | TMP3 $\Rightarrow$ X | $\mathrm{D} \Rightarrow \mathrm{X}$ | $\mathrm{X} \Rightarrow \mathrm{X}$ | $Y \Rightarrow X$ | SP $\Rightarrow$ X |
| 6 | $\begin{aligned} & \text { sex:A } \Rightarrow Y \\ & \text { SEX A,Y } \end{aligned}$ | $\begin{aligned} & \text { sex:B } \Rightarrow Y \\ & \text { SEX } B, Y \end{aligned}$ | $\begin{gathered} \text { sex:CCR } \Rightarrow Y \\ \text { SEX CCR, } Y \end{gathered}$ | TMP3 $\Rightarrow$ Y | $D \Rightarrow Y$ | $X \Rightarrow Y$ | $Y \Rightarrow Y$ | $\mathrm{SP} \Rightarrow \mathrm{Y}$ |
| 7 | $\begin{gathered} \text { sex:A } \Rightarrow \text { SP } \\ \text { SEX A,SP } \end{gathered}$ | $\begin{gathered} \text { sex: } B \Rightarrow S P \\ \text { SEX B,SP } \end{gathered}$ | $\begin{gathered} \text { sex:CCR } \Rightarrow \text { SP } \\ \text { SEX CCR,SP } \end{gathered}$ | TMP3 $\Rightarrow$ SP | $\mathrm{D} \Rightarrow \mathrm{SP}$ | $\mathrm{X} \Rightarrow \mathrm{SP}$ | $\mathrm{Y} \Rightarrow \mathrm{SP}$ | $\mathrm{SP} \Rightarrow \mathrm{SP}$ |

## TPA

## Transfer from Condition Code Register to Accumulator A

## TPA

Operation: $\quad(C C R) \Rightarrow A$
Description: Transfers the content of the condition code register to corresponding bit positions of accumulator A. The CCR remains unchanged.

This mnemonic is implemented by the TFR CCR,A instruction. For compatibility with the M68HC11, the mnemonic TPA is translated into the TFR CCR,A instruction by the assembler.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ |  | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | - | - | - | - |

None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| TPA translates to... <br> TFR CCR,A | INH | B7 20 | 1 | P |

Operation: $\left.\quad(\mathrm{SP})-\$ 0002 \Rightarrow \mathrm{SP} ; \mathrm{RTN}_{\mathrm{H}}: \operatorname{RTN}_{\mathrm{L}} \Rightarrow\left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}}+1\right)\right)$
(SP) $\left.-\$ 0002 \Rightarrow S P ; Y_{H}: Y_{L} \Rightarrow\left(M_{(S P)}: M_{(S P}+1\right)\right)$
$(S P)-\$ 0002 \Rightarrow S P ; X_{H}: X_{L} \Rightarrow\left(M_{(S P)}: M_{(S P+1)}\right)$
(SP) $\left.-\$ 0002 \Rightarrow S P ; B: A \Rightarrow\left(M_{(S P)}: M_{(S P}+1\right)\right)$
(SP) $-\$ 0001 \Rightarrow$ SP; CCR $\Rightarrow\left(\mathrm{M}_{(\mathrm{SP})}\right)$
$1 \Rightarrow I$
(Trap Vector) $\Rightarrow$ PC
Description: Traps unimplemented opcodes. There are opcodes in all 256 positions in the page 1 opcode map, but only 54 of the 256 positions on page 2 of the opcode map are used. If the CPU attempts to execute one of the unimplemented opcodes on page 2, an opcode trap interrupt occurs. Unimplemented opcode traps are essentially interrupts that share the \$FFF8:\$FFF9 interrupt vector.

TRAP uses the next address after the unimplemented opcode as a return address. It stacks the return address, index registers Y and X , accumulators B and A, and the CCR, automatically decrementing the SP before each item is stacked. The I mask bit is then set, the PC is loaded with the trap vector, and instruction execution resumes at that location. This instruction is not maskable by the I bit. Refer to SECTION 7 EXCEPTION PROCESSING for more information.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | 1 | - | - | - | - |

I: 1; Set.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| TRAP trapnum | INH | $\$ 18 \mathrm{tn}^{1}$ | 11 | OfVSPSSPSSP |

Notes:

1. The value tn represents an unimplemented page 2 opcode in either of the two ranges $\$ 30$ to $\$ 39$ or $\$ 40$ to $\$ F F$.

Operation: $\quad(\mathrm{M})-\$ 00$
Description: Subtracts $\$ 00$ from the content of memory location M and sets the condition codes accordingly.

The subtraction is accomplished internally without modifying M .
The TST instruction provides limited information when testing unsigned values. Since no unsigned value is less than zero, BLO and BLS have no utility following TST. While BHI can be used after TST, it performs the same function as BNE, which is preferred. After testing signed values, all signed branches are available.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | - | - | $\Delta$ | $\Delta$ | 0 | 0 |

N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
C: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| TST opr16a | EXT | F7 hh ll | 3 | rOP |
| TST oprx0_xysp | IDX | E7 xb | 3 | rfP |
| TST oprx9,xysp | IDX1 | E7 xb ff | 3 | rPo |
| TST oprx16,xysp | IDX2 | E7 xb ee ff | 4 | frPP |
| TST [D,xysp] | [D,IDX] | E7 xb | 6 | fIfrfP |
| TST [oprx16,xysp] | $[I D X 2] ~$ | E7 xb ee ff | 6 | fIPrfP |

Operation: $\quad(A)-\$ 00$
Description: Subtracts $\$ 00$ from the content of accumulator $A$ and sets the condition codes accordingly.

The subtraction is accomplished internally without modifying A.
The TSTA instruction provides limited information when testing unsigned values. Since no unsigned value is less than zero, BLO and BLS have no utility following TSTA. While BHI can be used after TST, it performs the same function as BNE, which is preferred. After testing signed values, all signed branches are available.

## Condition Codes and Boolean Formulas:



N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
C: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| TSTA | INH | 97 | 1 | 0 |

Operation: $\quad(B)-\$ 00$
Description: Subtracts \$00 from the content of accumulator B and sets the condition codes accordingly.

The subtraction is accomplished internally without modifying $B$.
The TSTB instruction provides limited information when testing unsigned values. Since no unsigned value is less than zero, BLO and BLS have no utility following TSTB. While BHI can be used after TST, it performs the same function as BNE, which is preferred. After testing signed values, all signed branches are available.

## Condition Codes and Boolean Formulas:



N: Set if MSB of result is set; cleared otherwise.
Z: Set if result is $\$ 00$; cleared otherwise.
V: 0; Cleared.
C: 0; Cleared.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :---: | :---: | :---: |
| TSTB | INH | D7 | 1 | 0 |

## Transfer from Stack Pointer to Index Register X

Operation: $\quad(\mathrm{SP}) \Rightarrow X$
Description: This is an alternate mnemonic to transfer the stack pointer value to index register X. The content of the SP remains unchanged. After a TSX instruction, X points at the last value that was stored on the stack.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| TSX translates to... <br> TFR SP,X | INH | B7 75 | 1 | P |

## Transfer from Stack Pointer to Index Register Y

Operation: $\quad(S P) \Rightarrow Y$
Description: This is an alternate mnemonic to transfer the stack pointer value to index register Y. The content of the SP remains unchanged. After a TSY instruction, Y points at the last value that was stored on the stack.

Condition Codes and Boolean Formulas:


None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :---: |
| TSY translates to... <br> TFR SP,Y | INH | B7 76 | 1 | P |

## TXS

## Transfer from Index Register X to Stack Pointer

Operation: $\quad(\mathrm{X}) \Rightarrow \mathrm{SP}$
Description: This is an alternate mnemonic to transfer index register X value to the stack pointer. The content of X is unchanged.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :---: | :---: | :--- | :---: | :--- |
| TXS translates to... <br> TFR X,SP | INH | B7 57 | 1 | P |

Transfer from Index Register $\mathbf{Y}$ to Stack Pointer

Operation: $\quad(\mathrm{Y}) \Rightarrow \mathrm{SP}$
Description: This is an alternate mnemonic to transfer index register $Y$ value to the stack pointer. The content of Y is unchanged.

Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| - | - | - | - | - | - | - | - |

None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :--- | :---: | :--- |
| TYS translates to... <br> TFR Y,SP | INH | B7 67 | 1 | P |

Operation: $\left.\quad(S P)-\$ 0002 \Rightarrow S P ; R_{H}: R T N_{L} \Rightarrow\left(M_{(S P)}: M_{(S P}+1\right)\right)$
$\left.(S P)-\$ 0002 \Rightarrow S P ; Y_{H}: Y_{L} \Rightarrow\left(M_{(S P)}: M_{(S P}+1\right)\right)$
$(S P)-\$ 0002 \Rightarrow S P ; X_{H}: X_{L} \Rightarrow\left(M_{(S P)}: M_{(S P+1)}\right)$
$\left.(S P)-\$ 0002 \Rightarrow S P ; B: A \Rightarrow\left(M_{(S P)}: M_{(S P}+1\right)\right)$
(SP) $-\$ 0001 \Rightarrow \mathrm{SP} ; \mathrm{CCR} \Rightarrow\left(\mathrm{M}_{(\mathrm{SP})}\right)$
Stop CPU Clocks
Description: Puts the CPU into a wait state. Uses the address of the instruction following WAI as a return address. Stacks the return address, index registers Y and X , accumulators B and A , and the CCR, decrementing the SP before each item is stacked.

The CPU then enters a wait state for an integer number of bus clock cycles. During the wait state, CPU clocks are stopped, but other MCU clocks can continue to run. The CPU leaves the wait state when it senses an interrupt that has not been masked.

Upon leaving the wait state, the CPU sets the appropriate interrupt mask bit(s), fetches the vector corresponding to the interrupt sensed, and instruction execution continues at the location the vector points to.

## Condition Codes and Boolean Formulas:



Although the WAI instruction itself does not alter the condition codes, the interrupt that causes the CPU to resume processing also causes the I mask bit (and the $X$ mask bit, if the interrupt was $\overline{X I R Q}$ ) to be set as the interrupt vector is fetched.

Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :--- |
| WAI (before interrupt) | INH | 3 E | 8 | $0.2 S S f S s f$ |
| (when interrupt comes) |  |  | 5 | VfPPP |

Operation: Do until $B=0$, leave $S O P$ in $Y: D, S O W$ in $X$
Partial Product $=(\mathrm{M}$ pointed to by X$) \times(\mathrm{M}$ pointed to by Y$)$ Sum-of-Products (24-bit SOP) = Previous SOP + Partial Product Sum-of-Weights (16-bit SOW) = Previous SOW + (M pointed to by Y )
$(\mathrm{X})+\$ 0001 \Rightarrow \mathrm{X} ;(\mathrm{Y})+\$ 0001 \Rightarrow \mathrm{Y}$
(B) $-\$ 01 \Rightarrow B$

Description: Performs weighted average calculations on values stored in memory. Uses indexed $(\mathrm{X})$ addressing mode to reference one source operand list, and indexed $(\mathrm{Y})$ addressing mode to reference a second source operand list. Accumulator $B$ is used as a counter to control the number of elements to be included in the weighted average.

For each pair of data points, a 24 -bit sum of products (SOP) and a 16bit sum of weights (SOW) is accumulated in temporary registers. When $B$ reaches zero (no more data pairs), the SOP is placed in Y:D. The SOW is placed in $X$. To arrive at the final weighted average, divide the content of $\mathrm{Y}: \mathrm{D}$ by X by executing an EDIV after the WAV.

This instruction can be interrupted. If an interrupt occurs during WAV execution, the intermediate results (six bytes) are stacked in the order $\mathrm{SOW}_{[15: 0]}, \mathrm{SOP}_{[15: 0]}, \$ 00: \mathrm{SOP}_{\text {[23:16] }}$ before the interrupt is processed. The wavr pseudo-instruction is used to resume execution after an interrupt. The mechanism is re-entrant. New WAV instructions can be started and interrupted while a previous WAV instruction is interrupted.

This instruction is often used in fuzzy logic rule evaluation. Refer to SECTION 9 FUZZY LOGIC SUPPORT for more information.

## Condition Codes and Boolean Formulas:

| $\mathbf{S}$ | $\mathbf{X}$ | $\mathbf{H}$ | $\mathbf{I}$ | $\mathbf{N}$ | $\mathbf{Z}$ | $\mathbf{V}$ | $\mathbf{C}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| - | - | $?$ | - | $?$ | 1 | $?$ | $?$ |

Z: 1; Set.
$\mathrm{H}, \mathrm{N}, \mathrm{V}$ and C may be altered by this instruction.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| WAV <br> (add if interrupted) | Special | 183 C | See note ${ }^{-1}$ | Off $(f r r f f f f f) 0$ <br> SSSUUUrr |

Notes:

1. The 8-cycle sequence in parentheses represents the loop for one iteration of SOP and SOW accumulation.

## Exchange Double Accumulator

 and Index Register XOperation: $\quad(\mathrm{D}) \Leftrightarrow(\mathrm{X})$
Description: Exchanges the content of double accumulator $D$ and the content of index register X. For compatibility with the M68HC11, the XGDX instruction is translated into an EXG D,X instruction by the assembler.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| :--- | :---: | :---: | :---: | :---: |
| XGDX translates to... <br> EXG D,X | INH | B7 C5 | 1 | P |

## Exchange Double Accumulator and Index Register Y

[^1]Description: Exchanges the content of double accumulator $D$ and the content of index register Y. For compatibility with the M68HC11, the XGDY instruction is translated into an EXG D, Y instruction by the assembler.

## Condition Codes and Boolean Formulas:



None affected.
Addressing Modes, Machine Code, and Execution Times:

| Source Form | Address Mode | Object Code | Cycles | Access Detail |
| ---: | :---: | :--- | :---: | :--- |
| XGDY translates to... <br> EXG D,Y | INH | B7 C6 | 1 | P |

## SECTION 7 <br> EXCEPTION PROCESSING

Exceptions are events that require processing outside the normal flow of instruction execution. This section describes exceptions and the way each is handled.

### 7.1 Types of Exceptions

CPU12 exceptions include resets, an unimplemented opcode trap, a software interrupt instruction, X-bit interrupts, and I-bit interrupts. Each exception has an associated 16bit vector, which points to the memory location where the routine that handles the exception is located. As shown in Table 7-1, vectors are stored in the upper 128 bytes of the standard $64-K b y t e$ address map.

Table 7-1 CPU12 Exception Vector Map

| Vector Address | Source |
| :---: | :---: |
| \$FFFE-\$FFFF | System Reset |
| \$FFFC-\$FFFD | Clock Monitor Reset |
| \$FFFA-\$FFFB | COP Reset |
| \$FFF8-\$FFF9 | Unimplemented Opcode Trap |
| \$FFF6-\$FFF7 | Software Interrupt Instruction (SWI) |
| \$FFF4-\$FFF5 | XIRQ Signal |
| \$FFF2-\$FFF3 | $\overline{\text { IRQ Signal }}$ |
| \$FFC0-\$FFF1 | Device-Specific Interrupt Sources |

The six highest vector addresses are used for resets and unmaskable interrupt sources. The remaining vectors are used for maskable interrupts. All vectors must be programmed to point to the address of the appropriate service routine.

The CPU12 can handle up to 64 exception vectors, but the number actually used varies from device to device, and some vectors are reserved for Motorola use. Refer to device documentation for more information.

Exceptions can be classified by the effect of the $X$ and I interrupt mask bits on recognition of a pending request.

Resets, the unimplemented opcode trap, and the SWI instruction are not affected by the $X$ and I mask bits.

Interrupt service requests from the $\overline{X I R Q}$ pin are inhibited when $X=1$, but are not affected by the I bit.

All other interrupts are inhibited when $\mathrm{I}=1$.

### 7.2 Exception Priority

A hardware priority hierarchy determines which reset or interrupt is serviced first when simultaneous requests are made. Six sources are not maskable. The remaining sources are maskable, and the device integration module typically can change the relative priorities of maskable interrupts. Refer to 7.4 Interrupts for more detail concerning interrupt priority and servicing.

The priorities of the unmaskable sources are:

1. RESET pin
2. Clock monitor reset
3. COP watchdog reset
4. $\overline{\mathrm{XIRQ}}$ signal
5. Unimplemented opcode trap
6. Software interrupt instruction (SWI)

An external reset has the highest exception-processing priority, followed by clock monitor reset, and then the on-chip watchdog reset.

The $\overline{X I R Q}$ interrupt is pseudo-non-maskable. After reset, the $X$ bit in the CCR is set, which inhibits all interrupt service requests from the XIRQ pin until the $X$ bit is cleared. The $X$ bit can be cleared by a program instruction, but program instructions cannot reset $X$ from zero to one. Once the $X$ bit is cleared, interrupt service requests made via the XIRQ pin become non-maskable.

The unimplemented page 2 opcode trap (TRAP) and the software interrupt instruction (SWI) are special cases. In one sense, these two exceptions have very low priority, because any enabled interrupt source that is pending prior to the time exception processing begins will take precedence. However, once the CPU begins processing a TRAP or SWI, neither can be interrupted. Also, since these are mutually exclusive instructions, they have no relative priority.

All remaining interrupts are subject to masking via the I bit in the CCR. Most M68HC12 MCUs have an external $\overline{\mathrm{IRQ}}$ pin, which is assigned the highest I-bit interrupt priority, and an internal periodic real-time interrupt generator, which has the next highest priority. The other maskable sources have default priorities that follow the address order of the interrupt vectors - the higher the address, the higher the priority of the interrupt. Other maskable interrupts are associated with on-chip peripherals such as timers or serial ports. Typically, logic in the device integration module can give one I-masked source priority over other I-masked sources. Refer to the documentation for the specific M68HC12 derivative for more information.

### 7.3 Resets

M68HC12 devices perform resets with a combination of hardware and software. Integration module circuitry determines the type of reset that has occurred, performs basic system configuration, then passes control to the CPU12. The CPU fetches a vector determined by the type of reset that has occurred, jumps to the address pointed to by the vector, and begins to execute code at that address.

There are four possible sources of reset. Power-on reset (POR) and external reset share the same reset vector. The computer operating properly (COP) reset and the clock monitor reset each have a vector.

### 7.3.1 Power-On Reset

The M68HC12 device integration module incorporates circuitry to detect a positive transition in the $\mathrm{V}_{\mathrm{DD}}$ supply and initialize the device during cold starts, generally by asserting the reset signal internally. The signal is typically released after a delay that allows the device clock generator to stabilize.

### 7.3.2 External Reset

The MCU distinguishes between internal and external resets by sensing how quickly the signal on the RESET pin rises to logic level one after it has been asserted. When the MCU senses any of the four reset conditions, internal circuitry drives the RESET signal low for 16 clock cycles, then releases. Eight clock cycles later, the MCU samples the state of the signal applied to the RESET pin. If the signal is still low, an external reset has occurred. If the signal is high, reset has been initiated internally by either the COP system or the clock monitor.

### 7.3.3 COP Reset

The MCU includes a computer operating properly (COP) system to help protect against software failures. When the COP is enabled, software must write a particular code sequence to a specific address in order to keep a watchdog timer from timing out. If software fails to execute the sequence properly, a reset occurs.

### 7.3.4 Clock Monitor Reset

The clock monitor circuit uses an internal RC circuit to determine whether clock frequency is above a predetermined limit. If clock frequency falls below the limit when the clock monitor is enabled, a reset occurs.

### 7.4 Interrupts

Each M68HC12 device can recognize a number of interrupt sources. Each source has a vector in the vector table. The XIRQ signal, the unimplemented opcode trap, and the SWI instruction are non-maskable, and have a fixed priority. The remaining interrupt sources can be masked by the I bit. In most M68HC12 devices, the external interrupt request pin is assigned the highest maskable interrupt priority, and the internal periodic real-time interrupt generator has the next highest priority. Other maskable interrupts are associated with on-chip peripherals such as timers or serial ports. These maskable sources have default priorities that follow the address order of the interrupt vectors. The higher the vector address, the higher the priority of the interrupt. Typically, a device integration module incorporates logic that can give one maskable source priority over other maskable sources.

### 7.4.1 Non-Maskable Interrupt Request ( $\overline{\mathrm{XIRQ}}$ )

The $\overline{X I R Q}$ input is an updated version of the $\overline{\text { NMI }}$ input of earlier MCUs. The XIRQ function is disabled during system reset and upon entering the interrupt service routine for an XIRQ interrupt.

During reset, both the I bit and the $X$ bit in the CCR are set. This disables maskable interrupts and interrupt service requests made by asserting the XIRQ signal. After minimum system initialization, software can clear the $X$ bit using an instruction such as ANDCC $\# \$ B F$. Software cannot reset the $X$ bit from zero to one once it has been cleared, and interrupt requests made via the XIRQ pin become non-maskable. When a non-maskable interrupt is recognized, both the $X$ and I bits are set after context is saved. The $X$ bit is not affected by maskable interrupts. Execution of an RTI at the end of the interrupt service routine normally restores the $X$ and I bits to the pre-interrupt request state.

### 7.4.2 Maskable Interrupts

Maskable interrupt sources include on-chip peripheral systems and external interrupt service requests. Interrupts from these sources are recognized when the global interrupt mask bit (I) in the CCR is cleared. The default state of the I bit out of reset is one, but it can be written at any time.

The integration module manages maskable interrupt priorities. Typically, an on-chip interrupt source is subject to masking by associated bits in control registers in addition to global masking by the I bit in the CCR. Sources generally must be enabled by writing one or more bits in associated control registers. There may be other interrupt-related control bits and flags, and there may be specific register read-write sequences associated with interrupt service. Refer to individual on-chip peripheral descriptions for details.

### 7.4.3 Interrupt Recognition

Once enabled, an interrupt request can be recognized at any time after the I mask bit is cleared. When an interrupt service request is recognized, the CPU responds at the completion of the instruction being executed. Interrupt latency varies according to the number of cycles required to complete the current instruction. Because the REV, REVW and WAV instructions can take many cycles to complete, they are designed so that they can be interrupted. Instruction execution resumes when interrupt execution is complete. When the CPU begins to service an interrupt, the instruction queue is refilled, a return address is calculated, and then the return address and the contents of the CPU registers are stacked as shown in Table 7-2.

After the CCR is stacked, the I bit (and the $X$ bit, if an $\overline{X I R Q}$ interrupt service request caused the interrupt) is set to prevent other interrupts from disrupting the interrupt service routine. Execution continues at the address pointed to by the vector for the high-est-priority interrupt that was pending at the beginning of the interrupt sequence. At the end of the interrupt service routine, an RTI instruction restores context from the stacked registers, and normal program execution resumes.

Table 7-2 Stacking Order on Entry to Interrupts

| Memory Location | CPU Registers |
| :---: | :---: |
| SP | $\mathrm{RTN}_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}}$ |
| $\mathrm{SP}+2$ | $\mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}}$ |
| $\mathrm{SP}+4$ | $\mathrm{X}_{\mathrm{H}}: \mathrm{X}_{\mathrm{L}}$ |
| $\mathrm{SP}+6$ | $\mathrm{~B}: \mathrm{A}$ |
| $\mathrm{SP}+8$ | CCR |

### 7.4.4 External Interrupts

External interrupt service requests are made by asserting an active-low signal connected to the IRQ pin. Typically, control bits in the device integration module affect how the signal is detected and recognized.

The I bit serves as the $\overline{\mathrm{RQ}}$ interrupt enable flag. When an $\overline{\mathrm{RQ}}$ interrupt is recognized, the I bit is set to inhibit interrupts during the interrupt service routine. Before other maskable interrupt requests can be recognized, the I bit must be cleared. This is generally done by an RTI instruction at the end of the service routine.

### 7.4.5 Return from Interrupt Instruction (RTI)

RTI is used to terminate interrupt service routines. RTI is an 8 -cycle instruction when no other interrupt is pending, and a 10 -cycle instruction when another interrupt is pending. In either case, the first five cycles are used to restore (pull) the CCR, B:A, X, Y , and the return address from the stack. If no other interrupt is pending at this point, three program words are fetched to refill the instruction queue from the area of the return address and processing proceeds from there.

If another interrupt is pending after registers are restored, a new vector is fetched, and the stack pointer is adjusted to point at the CCR value that was just recovered (SP = SP -9). This makes it appear that the registers have been stacked again. After the SP is adjusted, three program words are fetched to refill the instruction queue, starting at the address the vector points to. Processing then continues with execution of the instruction that is now at the head of the queue.

### 7.5 Unimplemented Opcode Trap

The CPU12 has opcodes in all 256 positions in the page 1 opcode map, but only 54 of the 256 positions on page 2 of the opcode map are used. If the CPU attempts to execute one of the 202 unused opcodes on page 2, an unimplemented opcode trap occurs. The 202 unimplemented opcodes are essentially interrupts that share a common interrupt vector, \$FFF8:\$FFF9.

The CPU12 uses the next address after an unimplemented page 2 opcode as a return address. This differs from the M68HC11 illegal opcode interrupt, which uses the address of an illegal opcode as the return address. In the CPU12, the stacked return address can be used to calculate the address of the unimplemented opcode for softwarecontrolled traps.

### 7.6 Software Interrupt Instruction

Execution of the SWI instruction causes an interrupt without an interrupt service request. SWI is not inhibited by the global mask bits in the CCR, and execution of SWI sets the I mask bit. Once an SWI interrupt begins, maskable interrupts are inhibited until the I bit in the CCR is cleared. This typically occurs when an RTI instruction at the end of the SWI service routine restores context.

### 7.7 Exception Processing Flow

The first cycle in the exception processing flow for all CPU12 exceptions is the same, regardless of the source of the exception. Between the first and second cycles of execution, the CPU chooses one of three alternative paths. The first path is for resets, the second path is for pending $X$ or $I$ interrupts, and the third path is used for software interrupts (SWI) and trapping unimplemented opcodes. The last two paths are virtually identical, differing only in the details of calculating the return address. Refer to Figure 7-2 for the following discussion.

### 7.7.1 Vector Fetch

The first cycle of all exception processing, regardless of the cause, is a vector fetch. The vector points to the address where exception processing will continue. Exception vectors are stored in a table located at the top of the memory map (\$FFC0-\$FFFF). The CPU cannot use the fetched vector until the third cycle of the exception processing sequence.

During the vector fetch cycle, the CPU issues a signal that tells the integration module to drive the vector address of the highest priority, pending exception onto the system address bus (the CPU does not provide this address).

After the vector fetch, the CPU selects one of the three alternate execution paths, depending upon the cause of the exception.

### 7.7.2 Reset Exception Processing

If reset caused the exception, processing continues to cycle 2.0. This cycle sets the $X$ and I bits in the CCR. The stack pointer is also decremented by two, but this is an artifact of shared code used for interrupt processing; the SP is not intended to have any specific value after a reset. Cycles 3.0 through 5.0 are program word fetches that refill the instruction queue. Fetches start at the address pointed to by the reset vector. When the fetches are completed, exception processing ends, and the CPU starts executing the instruction at the head of the instruction queue.


Figure 7-2 Exception Processing Flow Diagram

### 7.7.3 Interrupt and Unimplemented Opcode Trap Exception Processing

If an exception was not caused by a reset, a return address is calculated.
Cycles 2.1and 2.2 are both $S$ cycles (a 16-bit word), but the cycles are not identical because the CPU12 performs different return address calculations for each type of exception.

When an X- or I-related interrupt causes the exception, the return address points to the next instruction that would have been executed had processing not been interrupted.

When an exception is caused by an SWI opcode or by an unimplemented opcode (see 7.5 Unimplemented Opcode Trap), the return address points to the next address after the opcode.

Once calculated, the return address is pushed onto the stack.
Cycles 3.1 through 9.1 are identical to cycles 3.2 through 9.2 for the rest of the sequence, except for X mask bit manipulation performed in cycle 8.1.

Cycle 3.1/3.2 is the first of three program word fetches that refill the instruction queue.
Cycle 4.1/4.2 pushes $Y$ onto the stack.
Cycle 5.1/5.2 pushes $X$ onto the stack.
Cycle 6.1/6.2 is the second of three program word fetches that refill the instruction queue. During this cycle, the contents of the $A$ and $B$ accumulators are concatenated into a 16-bit word in the order B:A. This makes register order in the stack frame the same as that of the M68HC11, M6801, and the M6800.

Cycle 7.1/7.2 pushes the 16-bit word containing B:A onto the stack.
Cycle 8.1/8.2 pushes the 8-bit CCR onto the stack, then updates the mask bits.
When an XIRQ interrupt causes an exception, both $X$ and I are set, which inhibits further interrupts during exception processing.

When any other interrupt causes an exception, the I bit is set, but the X bit is not changed.

Cycle 9.1/9.2 is the third of three program word fetches that refill the instruction queue. It is the last cycle of exception processing. After this cycle the CPU starts executing the first cycle of the instruction at the head of the instruction queue.

## SECTION 8 DEVELOPMENT AND DEBUG SUPPORT

This section is an explanation of CPU-related aspects of the background debugging system. Topics include the instruction queue status signals, instruction tagging, and the single-wire background debug interface.

### 8.1 External Reconstruction of the Queue

The CPU12 uses an instruction queue to buffer program information and increase instruction throughput. The queue consists of two 16 -bit stages, plus a 16 -bit holding latch. Program information is always fetched in aligned 16 -bit words. At least three bytes of program information are available to the CPU when instruction execution begins. The holding latch is used when a word of program information arrives before the queue can advance.

Because of the queue, program information is fetched a few cycles before it is used by the CPU. Internally, the MCU only needs to buffer the fetched data. But, in order to monitor cycle-by-cycle CPU activity, it is necessary to externally reconstruct what is happening in the instruction queue.

Two external pins, IPIPE[1:0], provide time-multiplexed information about data movement in the queue and instruction execution. To complete the picture for system debugging, it is also necessary to include program information and associated addresses in the reconstructed queue.

The instruction queue and cycle-by-cycle activity can be reconstructed in real time or from trace history captured by a logic analyzer. However, neither scheme can be used to stop the CPU12 at a specific instruction. By the time an operation is visible outside the MCU, the instruction has already begun execution. A separate instruction tagging mechanism is provided for this purpose. A tag follows the information in the queue as the queue is advanced. During debugging, the CPU enters active background debug mode when a tagged instruction reaches the head of the queue, rather than executing the tagged instruction. For more information about tagging, refer to 8.5 Instruction Tagging.

### 8.2 Instruction Queue Status Signals

The IPIPE[1:0] signals carry time-multiplexed information about data movement and instruction execution during normal CPU operation. The signals are available on two multifunctional device pins. During reset, the pins are used as mode-select input signals MODA and MODB. After reset, information on the pins does not become valid until an instruction reaches queue stage 2.

To reconstruct the queue, the information carried by the status signals must be captured externally. In general, data movement and execution start information are considered to be distinct 2-bit values, with the low-order bit on IPIPE0 and the high-order bit on IPIPE1. Data movement information is available on rising edges of the E clock; execution start information is available on falling edges of the E clock, as shown in Figure 8-1. Data movement information refers to data on the bus at the previous falling edge of $E$. Execution information refers to the bus cycle from the current falling edge to the next falling edge of E . Table 8-1 summarizes the information encoded on the IPIPE[1:0] pins.


Figure 8-1 Queue Status Signal Timing

Table 8-1 IPIPE[1:0] Decoding

| Data Movement <br> (capture at E rise) | Mnemonic | Meaning |
| :---: | :---: | :---: |
| $0: 0$ | - | No movement |
| $0: 1$ | LAT | Latch data from bus |
| $1: 0$ | ALD | Advance queue and load from bus |
| $1: 1$ | ALL | Mdvance queue and load from latch |
| Execution Start <br> (capture at E fall) | Mnemonic |  |
| $0: 0$ | - | No start |
| $0: 1$ | INT | Start interrupt sequence |
| $1: 0$ | SEV | Start even instruction |
| $1: 1$ | SOD | Start odd instruction |

### 8.2.1 Zero Encoding (0:0)

The 0:0 state at the rising edge of $E$ indicates that there was no data movement in the instruction queue during the previous cycle; the 0:0 state at the falling edge of $E$ indicates continuation of an instruction or interrupt sequence.

### 8.2.2 LAT — Latch Data from Bus Encoding (0:1)

Fetched program information has arrived, but the queue is not ready to advance. The information is latched into the buffer. Later, when the queue does advance, stage 1 is refilled from the buffer, or from the data bus if the buffer is empty. In some instruction sequences, there can be several latch cycles before the queue advances. In these cases, the buffer is filled on the first latch event and additional latch requests are ignored.

### 8.2.3 ALD - Advance and Load from Data Bus Encoding (1:0)

The two-stage instruction queue is advanced by one word and stage 1 is refilled with a word of program information from the data bus. The CPU requested the information two bus cycles earlier but, due to access delays, the information was not available until the E cycle immediately prior to the ALD.

### 8.2.4 ALL - Advance and Load from Latch Encoding (1:1)

The two-stage instruction queue is advanced by one word and stage 1 is refilled with a word of program information from the buffer. The information was latched from the data bus at the falling edge of a previous E cycle because the instruction queue was not ready to advance when it arrived.

### 8.2.5 INT — Interrupt Sequence Encoding (0:1)

The E cycle starting at this E fall is the first cycle of an interrupt sequence. Normally this cycle is a read of the interrupt vector. However, in systems that have interrupt vectors in external memory and an 8-bit data bus, this cycle reads only the upper byte of the 16-bit interrupt vector.

### 8.2.6 SEV - Start Instruction on Even Address Encoding (1:0)

The E cycle starting at this E fall is the first cycle of the instruction in the even (high order) half of the word at the head of the instruction queue. The queue treats the $\$ 18$ prebyte for instructions on page 2 of the opcode map as a special 1-byte, 1-cycle instruction, except that interrupts are not recognized at the boundary between the prebyte and the rest of the instruction.

### 8.2.7 SOD — Start Instruction on Odd Address Encoding (1:1)

The E cycle starting at this E fall is the first cycle of the instruction in the odd (low order) half of the word at the head of the instruction queue. The queue treats the $\$ 18$ prebyte for instructions on page 2 of the opcode map as a special 1-byte, 1-cycle instruction, except that interrupts are not recognized at the boundary between the prebyte and the rest of the instruction.

### 8.3 Implementing Queue Reconstruction

The raw signals required for queue reconstruction are the address bus (ADDR), the data bus (DATA), the read/write strobe (R/W), the system clock (E), and the queue status signals (IPIPE[1:0]). An E clock cycle begins after an E fall. Addresses, R/信 state, and data movement status must be captured at the E rise in the middle of the cycle. Data and execution start status must be captured at the $E$ fall at the end of the cycle. These captures can then be organized into records with one record per E clock cycle.

Implementation details depend upon the type of device and the mode of operation. For instance, the data bus can be eight bits or 16 bits wide, and non-multiplexed or multiplexed. In all cases, the externally reconstructed queue must use 16-bit words. Demultiplexing and assembly of 8-bit data into 16-bit words is done before program information enters the real queue, so it must also be done for the external reconstruction. An example:

Systems with an 8-bit data bus and a program stored in external memory require two cycles for each program word fetch. MCU bus control logic freezes the CPU clocks long enough to do two 8-bit accesses rather than a single 16-bit access, so the CPU sees only 16-bit words of program information. To recover the 16-bit program words externally, latch the data bus state at the falling edge of $E$ when ADDR0 $=0$, and gate the outputs of the latch onto DATA[15:8] when a LAT or ALD cycle occurs. Since the 8-bit data bus is connected to DATA[7:0], the 16-bit word on the data lines corresponds to the ALD or LAT status indication at the E rise after the second 8 -bit fetch, which is always to an odd address. IPIPE[1:0] status signals indicate 0:0 at the beginning ( E fall) and middle ( E rise) of the first 8 -bit fetch.

Some M68HC12 devices have address lines to support memory expansion beyond the standard 64-Kbyte address space. When memory expansion is used, expanded addresses must also be captured and maintained.

### 8.3.1 Queue Status Registers

Queue reconstruction requires the following registers, which can be implemented as software variables when previously captured trace data is used, or as hardware latches in real time.

### 8.3.1.1 in_add, in_dat Registers

These registers contain the address and data from the previous external bus cycle. Depending upon how records are read and processed from the raw capture information, it may be possible to simply read this information from the raw capture data file when needed.

### 8.3.1.2 fetch_add, fetch_dat Registers

These registers buffer address and data for information that was fetched before the queue was ready to advance.

### 8.3.1.3 st1_add, st1_dat Registers

These registers contain address and data for the first stage of the reconstructed instruction queue.

### 8.3.1.4 st2_add, st2_dat Registers

These registers contain address and data for the final stage of the reconstructed instruction queue. When the IPIPE[1:0] signals indicate that an instruction is starting to execute, the address and opcode can be found in these registers.

### 8.3.2 Reconstruction Algorithm

This section describes in detail how to use IPIPE[1:0] signals and status storage registers to perform queue reconstruction. An "is_full" flag is used to indicate when the fetch_add and fetch_dat buffer registers contain information. The use of the flag is explained more fully in subsequent paragraphs.

Typically, the first few cycles of raw capture data are not useful because it takes several cycles before an instruction propagates to the head of the queue. During these first raw cycles, the only meaningful information available are data movement signals. Information on the external address and data buses during this setup time reflects the actions of instructions that were fetched before data collection started.

In the special case of a reset, there is a five cycle sequence (VfPPP) during which the reset vector is fetched and the instruction queue is filled, before execution of the first instruction begins. Due to the timing of the switchover of the IPIPE[1:0] pins from their alternate function as mode select inputs, the status information on these two pins may be erroneous during the first cycle or two after the release of reset. This is not a problem because the status is correct in time for queue reconstruction logic to correctly replicate the queue.

Before starting to reconstruct the queue, clear the is_full flag to indicate that there is no meaningful information in the fetch_add and fetch_dat buffers. Further movement of information in the instruction queue is based on the decoded status on the IPIPE[1:0] signals at the rising edges of $E$.

### 8.3.2.1 LAT Decoding

On a latch cycle, check the is_full flag. If and only if is_full $=0$, transfer the address and data from the previous bus cycle (in_add and in_dat) into the fetch_add and fetch_dat registers respectively. Then, set the is_full flag. The usual reason for a latch request instead of an advance request is that the previous instruction ended with a single aligned byte of program information in the last stage of the instruction queue. Since the odd half of this word still holds the opcode for the next instruction, the queue cannot advance on this cycle. However, the cycle to fetch the next word of program information has already started and the data is on its way.

### 8.3.2.2 ALD Decoding

On an advance-and-load-from-data-bus cycle, the information in the instruction queue must advance by one stage. Whatever was in stage 2 of the queue is simply thrown away. The previous contents of stage 1 are moved to stage 2, and the address and data from the previous cycle (in_add and in_dat) are transferred into stage 1 of the instruction queue. Finally, clear the is_full flag to indicate the buffer latch is ready for new data. Usually, there would be no useful information in the fetch buffer when an ALD cycle was encountered, but in the case of a change-of-flow, any data that was there needs to be flushed out (by clearing the is_full flag).

### 8.3.2.3 ALL Decoding

On an advance-and-load-from-latch cycle, the information in the instruction queue must advance by one stage. Whatever was in stage 2 of the queue is simply thrown away. The previous contents of stage 1 are moved to stage 2 , and the contents of the fetch buffer latch are transferred into stage 1 of the instruction queue. One or more cycles preceding the ALL cycle will have been a LAT cycle. After updating the instruction queue, clear the is_full flag to indicate the fetch buffer is ready for new information.

### 8.4 Background Debug Mode

M68HC12 MCUs include a resident debugging system. This system is implemented with on-chip hardware rather than external software, and provides a full set of debugging options. The debugging system is less intrusive than systems used on other microcontrollers, because the control logic resides in the on-chip integration module, rather than in the CPU. Some activities, such as reading and writing memory locations, can be performed while the CPU is executing normal code with no effect on real-time system activity.

The integration module generally uses CPU dead cycles to execute debugging commands while the CPU is operating normally, but can steal cycles from the CPU when necessary. Other commands are firmware based, and require that the CPU be in active background debug mode (BDM) for execution. While BDM is active, the CPU executes a monitor program located in a small on-chip ROM.

Debugging control logic communicates with external devices serially, via the BKGD pin. This single-wire approach helps to minimize the number of pins needed for development support.

Background debug does not operate in STOP mode.

### 8.4.1 Enabling BDM

The debugger must be enabled before it can be activated. Enabling has two phases. First, the BDM ROM must be enabled by writing the ENBDM bit in the BDM status register, using a debugging command sent via the single wire interface. Once the ROM is enabled, it remains available until the next system reset, or until ENBDM is cleared by another debugging command. Second, BDM must be activated to map the ROM and BDM control registers to addresses \$FF00 to \$FFFF and put the MCU in background mode.

After the firmware is enabled, BDM can be activated by the hardware BACKGROUND command, by breakpoints tagged via the LIM breakpoint logic or the BDM tagging mechanism, and by the BGND instruction. An attempt to activate BDM before firmware has been enabled causes the MCU to resume normal instruction execution after a brief delay.

BDM becomes active at the next instruction boundary following execution of the BDM BACKGROUND command. Breakpoints can be configured to activate BDM before a tagged instruction is executed.

While BDM is active, BDM control registers are mapped to addresses \$FF00 to \$FF06. These registers are only accessible through BDM firmware or BDM hardware commands. 8.4.4 BDM Registers describes the registers.

Some M68HC12 on-chip peripherals have a BDM control bit, which determines whether the peripheral function is available during BDM. If no bit is shown, the peripheral is active in BDM.

### 8.4.2 BDM Serial Interface

The BDM serial interface uses a clocking scheme in which the external host generates a falling edge on the BKGD pin to indicate the start of each bit time. This falling edge must be sent for every bit, whether data is transmitted or received.

BKGD is an open drain pin that can be driven either by the MCU or by an external host. Data is transferred MSB first, at 16 E-clock cycles per bit. The interface times out if 512 E -clock cycles occur between falling edges from the host. The hardware clears the command register when a time-out occurs.

The BKGD pin is used to send and receive data. The following diagrams show timing for each of these cases. Interface timing is synchronous to MCU clocks, but the external host is asynchronous to the target MCU. The internal clock signal is shown for reference in counting cycles.

Figure $8 \mathbf{- 2}$ shows an external host transmitting a data bit to the BKGD pin of a target M 68 HC 12 MCU . The host is asynchronous to the target, so there is a 0 - to 1 -cycle delay from the host-generated falling edge to the time when the target perceives the bit. Ten target E-cycles later, the target senses the bit level on the BKGD pin. The host can drive high during host-to-target transmission to speed up rising edges, because the target does not drive the pin during this time.


Figure 8-2 BDM Host to Target Serial Bit Timing

Figure 8-3 shows an external host receiving a logic one from the target MCU. Since the host is asynchronous to the target, there is a 0 - or 1 -cycle delay from the host-generated falling edge on BKGD until the target perceives the bit. The host holds the signal low long enough for the target to recognize it (a minimum of two target E-clock cycles), but must release the low drive before the target begins to drive the active-high speed-up pulse seven cycles after the start of the bit time. The host should sample the bit level about ten cycles after the start of bit time.


Figure 8-3 BDM Target to Host Serial Bit Timing (Logic 1)

Figure 8-4 shows the host receiving a logic zero from the target. Since the host is asynchronous to the target, there is a 0-or 1-cycle delay from the host-generated falling edge on BKGD until the target perceives the bit. The host initiates the bit time, but the target finishes it. To make certain the host receives a logic zero, the target drives the BKGD pin low for 13 E-clock cycles, then briefly drives the signal high to speed up the rising edge. The host samples the bit level about ten cycles after starting the bit time.


CPU12 BDM THOTIM
Figure 8-4 BDM Target to Host Serial Bit Timing (Logic 0)

### 8.4.3 BDM Commands

All BDM opcodes are eight bits long, and can be followed by an address or data, as indicated by the instruction.

Commands implemented in BDM control hardware are listed in Table 8-2. These commands, except for BACKGROUND, do not require the CPU to be in BDM mode for execution. The control logic uses CPU dead cycles to execute these instructions. If a dead cycle cannot be found within 128 cycles, the control logic steals cycles from the CPU.

Table 8-2 BDM Commands Implemented in Hardware

| Command | Opcode (Hex) | Data | Description |
| :---: | :---: | :---: | :---: |
| BACKGROUND | 90 | None | Enter background mode (if firmware enabled). |
| READ_BD_BYTE | E4 | 16-bit address 16-bit data out | Read from memory with BDM in map (may steal cycles if external access) data for odd address on low byte, data for even address on high byte. |
| STATUS1 | E4 | $\begin{gathered} \text { FF01, } \\ 00000000 \text { (out) } \end{gathered}$ | READ_BD_BYTE \$FF01. Running user code (BGND instruction is not allowed). |
|  |  | $\begin{gathered} \text { FF01, } \\ 10000000 \text { (out) } \end{gathered}$ | READ_BD_BYTE \$FF01. BGND instruction is allowed. |
|  |  | $\begin{gathered} \text { FF01, } \\ 11000000 \text { (out) } \end{gathered}$ | READ_BD_BYTE \$FF01. Background mode active (waiting for single wire serial command). |
| READ_BD_WORD | EC | 16-bit address 16-bit data out | Read from memory with BDM in map (may steal cycles if external access) must be aligned access. |
| READ_BYTE | E0 | 16-bit address 16-bit data out | Read from memory with BDM out of map (may steal cycles if external access) data for odd address on low byte, data for even address on high byte. |
| READ_WORD | E8 | 16-bit address 16-bit data out | Read from memory with BDM out of map (may steal cycles if external access) must be aligned access. |
| WRITE_BD_BYTE | C4 | 16-bit address 16-bit data in | Write to memory with BDM in map (may steal cycles if external access) data for odd address on low byte, data for even address on high byte. |
| ENABLE_FIRMWARE2 | C4 | $\begin{gathered} \text { FF01, } \\ 1 \mathrm{xxx} \times \mathrm{xxx}(\mathrm{in}) \end{gathered}$ | Write byte \$FF01, set the ENBDM bit. This allows execution of commands which are implemented in firmware. Typically, read STATUS, OR in the MSB, write the result back to STATUS. |
| WRITE_BD_WORD | CC | 16-bit address 16-bit data in | Write to memory with BDM in map (may steal cycles if external access) must be aligned access. |
| WRITE_BYTE | C0 | 16-bit address 16-bit data in | Write to memory with BDM out of map (may steal cycles if external access) data for odd address on low byte, data for even address on high byte. |
| WRITE_WORD | C8 | 16-bit address 16-bit data in | Write to memory with BDM out of map (may steal cycles if external access) must be aligned access. |

## NOTES:

1. STATUS command is a specific case of the READ_BD_BYTE command.
2. ENABLE_FIRMWARE is a specific case of the WRITE_BD_BYTE command.

The CPU must be in background mode to execute commands that are implemented in the BDM ROM. The CPU executes code from the ROM to perform the requested operation. These commands are shown in Table 8-3.

The host controller must wait 150 cycles for a non-intrusive BDM command to execute before another command can be sent. This delay includes 128 cycles for the maximum delay for a dead cycle.

BDM logic retains control of the internal buses until a read or write is completed. If an operation can be completed in a single cycle, it does not intrude on normal CPU operation. However, if an operation requires multiple cycles, CPU clocks are frozen until the operation is complete.

Table 8-3 BDM Firmware Commands

| Command | Opcode (Hex) | Data | Description |
| :---: | :---: | :---: | :--- |
| GO | 08 | none | Resume normal processing |
| TRACE1 | 10 | none | Execute one user instruction then return to BDM |
| TAGGO | 18 | none | Enable tagging then resume normal processing |
| WRITE_NEXT | 42 | 16 -bit data in | X = X + 2; Write next word @ 0,X |
| WRITE_PC | 43 | 16 -bit data in | Write program counter |
| WRITE_D | 44 | 16 -bit data in | Write D accumulator |
| WRITE_X | 45 | 16 -bit data in | Write X index register |
| WRITE_Y | 46 | 16 -bit data in | Write Y index register |
| WRITE_SP | 47 | 16 -bit data in | Write stack pointer |
| READ_NEXT | 62 | 16 -bit data out | X = X + 2; Read next word @ 0,X |
| READ_PC | 63 | 16 -bit data out | Read program counter |
| READ_D | 64 | 16-bit data out | Read D accumulator |
| READ_X | 65 | 16-bit data out | Read X index register |
| READ_Y | 66 | 16 -bit data out | Read Y index register |
| READ_SP | 67 | 16 -bit data out | Read stack pointer |

### 8.4.4 BDM Registers

Seven BDM registers are mapped into the standard 64-Kbyte address space when BDM is active. Mapping is shown in Table 8-4.

Table 8-4 BDM Register Mapping

| Address | Register |
| :---: | :---: |
| \$FF00 | BDM instruction register |
| \$FF01 | BDM status register |
| \$FF02-\$FF03 | BDM shift register |
| \$FF04-\$FF05 | BDM address register |
| \$FF06 | BDM CCR register |

The content of the instruction register is determined by the type of background instruction being executed. The status register indicates BDM operating conditions. The shift register contains data being received or transmitted via the serial interface. The address register is temporary storage for BDM commands. The CCR register preserves the content of the CPU12 CCR while BDM is active.

The only register of interest to users is the status register. The other BDM registers are used only by the BDM firmware to execute commands. The registers can be accessed by means of the hardware READ_BD and WRITE_BD commands, but must not be written during BDM operation.

### 8.4.4.1 BDM Status Register

STATUS - BDM Status Register
\$FF01

|  | BIT 7 | 6 | 5 | 4 | 3 | 2 | 1 | BIT 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | ENBDM | BDMACT | ENTAG | SDV | TRACE | 0 | 0 | 0 |
| RESET: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| SP. | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

S. CHIP \&

PERIPH.:

## ENBDM - Enable BDM ROM

Shows whether the BDM ROM is enabled. Cleared by reset.
$0=$ BDM ROM not enabled
$1=$ BDM ROM enabled, but not in memory map unless BDM is active
BDMACT - BDM Active Flag
Shows whether the BDM ROM is in the memory map. Cleared by reset.
$0=$ ROM not in map
$1=\mathrm{ROM}$ in map (MCU is in active BDM)
ENTAG - Instruction Tagging Enable
Shows whether instruction tagging is enabled. Set by the TAGGO instruction and cleared when BDM is entered. Cleared by reset.

## NOTE

Execute a TAGGO command to enable instruction tagging. Do not write ENTAG directly.
$0=$ Tagging not enabled, or BDM active
1 = Tagging active
SDV — Shifter Data Valid
Shows that valid data is in the serial interface shift register.

## NOTE

SDV is used by firmware-based instructions. Do not attempt to write SDV directly.
$0=$ No valid data
1 = Valid Data
TRACE - Trace Flag
Shows when tracing is enabled.

## NOTE

Execute a TRACE1 command to enable instruction tagging. Do not attempt to write TRACE directly.
$0=$ Tracing not enabled
1 = Tracing active

### 8.5 Instruction Tagging

The instruction queue and cycle-by-cycle CPU activity can be reconstructed in real time, or from trace history that was captured by a logic analyzer. However, the reconstructed queue cannot be used to stop the CPU at a specific instruction, because execution has already begun by the time an operation is visible outside the MCU. A separate instruction tagging mechanism is provided for this purpose.

Executing the BDM TAGGO command configures two MCU pins for tagging. The TAGLO signal shares a pin with the $\overline{\text { LSTRB }}$ signal, and the TAGHI signal shares a pin with the BKGD pin. Tagging information is latched on the falling edge of ECLK, as shown in Figure 8-5.


Figure 8-5 Tag Input Timing

Table 8-5 shows the functions of the two tagging pins. The pins operate independently; the state of one pin does not affect the function of the other. The presence of logic level zero on either pin at the fall of ECLK performs the indicated function. Tagging is allowed in all modes. Tagging is disabled when BDM becomes active.

Table 8-5 Tag Pin Function

| $\overline{\text { TAGHI }}$ | $\overline{\text { TAGLO }}$ | Tag |
| :---: | :---: | :---: |
| 1 | 1 | No Tag |
| 1 | 0 | Low Byte |
| 0 | 1 | High Byte |
| 0 | 0 | Both Bytes |

In M68HC12 derivatives that have hardware breakpoint capability, the breakpoint control logic and BDM control logic use the same internal signals for instruction tagging. The CPU12 does not differentiate between the two kinds of tags.

The tag follows program information as it advances through the queue. When a tagged instruction reaches the head of the queue, the CPU enters active background debug mode rather than executing the instruction.

### 8.6 Breakpoints

Breakpoints halt instruction execution at particular places in a program. To assure transparent operation, breakpoint control logic is implemented outside the CPU, and particular models of MCU can have different breakpoint capabilities. Refer to the appropriate device manual for detailed information. Generally, breakpoint logic can be configured to halt execution before an instruction executes, or to halt execution on the next instruction boundary following the breakpoint.

### 8.6.1 Breakpoint Type

There are three basic types of breakpoints:

1. Address-only breakpoints that cause the CPU to execute an SWI. These breakpoints can be set only on addresses. When the breakpoint logic encounters the breakpoint tag, the CPU12 executes an SWI instruction.
2. Address-only breakpoints that cause the MCU to enter BDM. These breakpoints can be set only on addresses. When the breakpoint logic encounters the breakpoint tag, BDM is activated.
3. Address/data breakpoints that cause the MCU to enter BDM. These breakpoints can be set on an address, or on an address and data. When the breakpoint logic encounters the breakpoint tag, BDM is activated.

### 8.6.2 Breakpoint Operation

Breakpoints use two mechanisms to halt execution:

1. The tag mechanism marks a particular program fetch with a high (even) or low (odd) byte indicator. The tagged byte moves through the instruction queue until a start cycle occurs, then the breakpoint is taken. Breakpoint logic can be configured to force BDM, or to initiate an SWI when the tag is encountered.
2. The force BDM mechanism causes the MCU to enter active BDM at the next instruction start cycle.
CPU12 instructions are used to implement both breakpoint mechanisms. When an SWI tag is encountered, the CPU performs the same sequence of operations as for an SWI. When BDM is forced, the CPU executes a BGND instruction. However, because these operations are not part of the normal flow of instruction execution, the control program must keep track of the actual breakpoint address.

Both SWI and BGND store a return PC value (SWI on the stack and BGND in the CPU12 TMP2 register), but this value is automatically incremented to point to the next instruction after SWI or BGND. In order to resume execution where a breakpoint occurred, the control program must preserve the breakpoint address rather than use the incremented PC value.

The breakpoint logic generally uses match registers to determine when a break is taken. Registers can be used to match the high and low bytes of addresses for single and dual breakpoints, to match data for single breakpoints, or to do both functions. Use of the registers is generally determined by control bit settings.

## SECTION 9 FUZZY LOGIC SUPPORT

The CPU12 has the first microcontroller instruction set to specifically address the needs of fuzzy logic. This section describes the use of fuzzy logic in control systems, discusses the CPU12 fuzzy logic instructions, and provides examples of fuzzy logic programs.

### 9.1 Introduction

The CPU12 includes four instructions that perform specific fuzzy logic tasks. In addition, several other instructions are especially useful in fuzzy logic programs. The overall C-friendliness of the instruction set also aids development of efficient fuzzy logic programs.

This section explains the basic fuzzy logic algorithm for which the four fuzzy logic instructions are intended. Each of the fuzzy logic instructions are then explained in detail. Finally, other custom fuzzy logic algorithms are discussed, with emphasis on use of other CPU12 instructions.

The four fuzzy logic instructions are MEM, which evaluates trapezoidal membership functions; REV and REVW, which perform unweighted or weighted MIN-MAX rule evaluation; and WAV, which performs weighted average defuzzification on singleton output membership functions.

Other instructions that are useful for custom fuzzy logic programs include MINA, EMIND, MAXM, EMAXM, TBL, ETBL, and EMACS. For higher resolution fuzzy programs, the fast extended precision math instructions in the CPU12 are also beneficial. Flexible indexed addressing modes help simplify access to fuzzy logic data structures stored as lists or tabular data structures in memory.

The actual logic additions required to implement fuzzy logic support in the CPU12 are quite small, so there is no appreciable increase in cost for the typical user. A fuzzy inference kernel for the CPU12 requires one-fifth as much code space, and executes fifteen times faster than a comparable kernel implemented on a typical midrange microcontroller. By incorporating fuzzy logic support into a high-volume, general-purpose microcontroller product family, Motorola has made fuzzy logic available for a huge base of applications.

### 9.2 Fuzzy Logic Basics

This is an overview of basic fuzzy logic concepts. It can serve as a general introduction to the subject, but that is not the main purpose. There are a number of fuzzy logic programming strategies. This discussion concentrates on the methods implemented in the CPU12 fuzzy logic instructions. The primary goal is to provide a background for a detailed explanation of the CPU12 fuzzy logic instructions.

In general, fuzzy logic provides for set definitions that have fuzzy boundaries rather than the crisp boundaries of Aristotelian logic. These sets can overlap so that, for a specific input value, one or more sets associated with linguistic labels may be true to a degree at the same time. As the input varies from the range of one set into the range of an adjacent set, the first set becomes progressively less true while the second set becomes progressively more true.

Fuzzy logic has membership functions which emulate human concepts like "temperature is warm"; that is, conditions are perceived to have gradual boundaries. This concept seems to be a key element of the human ability to solve certain types of complex problems that have eluded traditional control methods.

Fuzzy sets provide a means of using linguistic expressions like "temperature is warm" in rules which can then be evaluated with a high degree of numerical precision and repeatability. This directly contradicts the common misperception that fuzzy logic produces approximate results - a specific set of input conditions always produces the same result, just as a conventional control system does.

A microcontroller-based fuzzy logic control system has two parts. The first part is a fuzzy inference kernel which is executed periodically to determine system outputs based on current system inputs. The second part of the system is a knowledge base which contains membership functions and rules. Figure 9-1 is a block diagram of this kind of fuzzy logic system.

The knowledge base can be developed by an application expert without any microcontroller programming experience. Membership functions are simply expressions of the expert's understanding of the linguistic terms that describe the system to be controlled. Rules are ordinary language statements that describe the actions a human expert would take to solve the application problem.

Rules and membership functions can be reduced to relatively simple data structures (the knowledge base) stored in nonvolatile memory. A fuzzy inference kernel can be written by a programmer who does not know how the application system works. The only thing the programmer needs to do with knowledge base information is store it in the memory locations used by the kernel.

One execution pass through the fuzzy inference kernel generates system output signals in response to current input conditions. The kernel is executed as often as needed to maintain control. If the kernel is executed more often than needed, processor bandwidth and power are wasted; delaying too long between passes can cause the system to get too far out of control. Choosing a periodic rate for a fuzzy control system is the same as it would be for a conventional control system.


Figure 9-1 Block Diagram of a Fuzzy Logic System

### 9.2.1 Fuzzification (MEM)

During the fuzzification step, the current system input values are compared against stored input membership functions to determine the degree to which each label of each system input is true. This is accomplished by finding the y-value for the current input value on a trapezoidal membership function for each label of each system input. The MEM instruction in the CPU12 performs this calculation for one label of one system input. To perform the complete fuzzification task for a system, several MEM instructions must be executed, usually in a program loop structure.

Figure 9-2 shows a system of three input membership functions, one for each label of the system input. The x-axis of all three membership functions represents the range of possible values of the system input. The vertical line through all three membership functions represents a specific system input value. The y-axis represents degree of truth and varies from completely false (\$00 or $0 \%$ ) to completely true (\$FF or $100 \%$ ). The $y$-value where the vertical line intersects each of the membership functions, is the degree to which the current input value matches the associated label for this system input. For example, the expression "temperature is warm" is $25 \%$ true (\$40). The value $\$ 40$ is stored to a RAM location, and is called a fuzzy input (in this case, the fuzzy input for "temperature is warm"). There is a RAM location for each fuzzy input (for each label of each system input).


Figure 9-2 Fuzzification Using Membership Functions

When the fuzzification step begins, the current value of the system input is in an accumulator of the CPU12, one index register points to the first membership function definition in the knowledge base, and a second index register points to the first fuzzy input in RAM. As each fuzzy input is calculated by executing a MEM instruction, the result is stored to the fuzzy input and both pointers are updated automatically to point to the locations associated with the next fuzzy input. The MEM instruction takes care of everything except counting the number of labels per system input and loading the current value of any subsequent system inputs.

The end result of the fuzzification step is a table of fuzzy inputs representing current system conditions.

### 9.2.2 Rule Evaluation (REV and REVW)

Rule evaluation is the central element of a fuzzy logic inference program. This step processes a list of rules from the knowledge base using current fuzzy input values from RAM to produce a list of fuzzy outputs in RAM. These fuzzy outputs can be thought of as raw suggestions for what the system output should be in response to the current input conditions. Before the results can be applied, the fuzzy outputs must be further processed, or defuzzified, to produce a single output value that represents the combined effect of all of the fuzzy outputs.

The CPU12 offers two variations of rule evaluation instructions. The REV instruction provides for unweighted rules (all rules are considered to be equally important). The REVW instruction is similar but allows each rule to have a separate weighting factor which is stored in a separate parallel data structure in the knowledge base. In addition to the weights, the two rule evaluation instructions also differ in the way rules are encoded into the knowledge base.

An understanding of the structure and syntax of rules is needed to understand how a microcontroller performs the rule evaluation task. The following is an example of a typical rule.

If temperature is warm and pressure is high then heat is (should be) off.
At first glance, it seems that encoding this rule in a compact form understandable to the microcontroller would be difficult, but it is actually simple to reduce the rule to a small list of memory pointers. The left portion of the rule is a statement of input conditions and the right portion of the rule is a statement of output actions.

The left portion of a rule is made up of one or more (in this case two) antecedents connected by a fuzzy and operator. Each antecedent expression consists of the name of a system input, followed by is, followed by a label name. The label must be defined by a membership function in the knowledge base. Each antecedent expression corresponds to one of the fuzzy inputs in RAM. Since and is the only operator allowed to connect antecedent expressions, there is no need to include these in the encoded rule. The antecedents can be encoded as a simple list of pointers to (or addresses of) the fuzzy inputs to which they refer.

The right portion of a rule is made up of one or more (in this case one) consequents. Each consequent expression consists of the name of a system output, followed by is, followed by a label name. Each consequent expression corresponds to a specific fuzzy output in RAM. Consequents for a rule can be encoded as a simple list of pointers to (or addresses of) the fuzzy outputs to which they refer.

The complete rules are stored in the knowledge base as a list of pointers or addresses of fuzzy inputs and fuzzy outputs. In order for the rule evaluation logic to work, there must be some means of knowing which pointers refer to fuzzy inputs, and which refer to fuzzy outputs. There also must be a way to know when the last rule in the system has been reached.

One method of organization is to have a fixed number of rules with a specific number of antecedents and consequents. A second method, employed in Motorola Freeware M 68 HC 11 kernels, is to mark the end of the rule list with a reserved value, and use a bit in the pointers to distinguish antecedents from consequents. A third method of organization, used in the CPU12, is to mark the end of the rule list with a reserved value, and separate antecedents and consequents with another reserved value. This permits any number of rules, and allows each rule to have any number of antecedents and consequents, subject to the limits imposed by availability of system memory.

Each rule is evaluated sequentially, but the rules as a group are treated as if they were all evaluated simultaneously. Two mathematical operations take place during rule evaluation. The fuzzy and operator corresponds to the mathematical minimum operation and the fuzzy or operation corresponds to the mathematical maximum operation. The fuzzy and is used to connect antecedents within a rule. The fuzzy or is implied between successive rules. Before evaluating any rules, all fuzzy outputs are set to zero (meaning not true at all). As each rule is evaluated, the smallest (minimum) antecedent is taken to be the overall truth of the rule. This rule truth value is applied to each consequent of the rule (by storing this value to the corresponding fuzzy output) unless the fuzzy output is already larger (maximum). If two rules affect the same fuzzy output, the rule that is most true governs the value in the fuzzy output because the rules are connected by an implied fuzzy or.

In the case of rule weighting, the truth value for a rule is determined as usual by finding the smallest rule antecedent. Before applying this truth value to the consequents for the rule, the value is multiplied by a fraction from zero (rule disabled) to one (rule fully enabled). The resulting modified truth value is then applied to the fuzzy outputs.

The end result of the rule evaluation step is a table of suggested or "raw" fuzzy outputs in RAM. These values were obtained by plugging current conditions (fuzzy input values) into the system rules in the knowledge base. The raw results cannot be supplied directly to the system outputs because they may be ambiguous. For instance, one raw output can indicate that the system output should be medium with a degree of truth of $50 \%$ while, at the same time, another indicates that the system output should be low with a degree of truth of $25 \%$. The defuzzification step resolves these ambiguities.

### 9.2.3 Defuzzification (WAV)

The final step in the fuzzy logic program combines the raw fuzzy outputs into a composite system output. Unlike the trapezoidal shapes used for inputs, the CPU12 typically uses singletons for output membership functions. As with the inputs, the x-axis represents the range of possible values for a system output. Singleton membership functions consist of the x-axis position for a label of the system output. Fuzzy outputs correspond to the $y$-axis height of the corresponding output membership function.

The WAV instruction calculates the numerator and denominator sums for weighted average of the fuzzy outputs according to the formula:

$$
\text { System Output }=\frac{\sum_{i=1}^{n} S_{i} F_{i}}{\sum_{i=1}^{n} F_{i}}
$$

Where n is the number of labels of a system output, $\mathrm{S}_{\mathrm{i}}$ are the singleton positions from the knowledge base, and $F_{i}$ are fuzzy outputs from RAM. For a common fuzzy logic program on the CPU12, n is eight or less (though this instruction can handle any value to 255 ) and $\mathrm{S}_{\mathrm{i}}$ and $\mathrm{F}_{\mathrm{i}}$ are 8 -bit values. The final divide is performed with a separate EDIV instruction placed immediately after the WAV instruction.

Before executing WAV, an accumulator must be loaded with the number of iterations (n), one index register must be pointed at the list of singleton positions in the knowledge base, and a second index register must be pointed at the list of fuzzy outputs in RAM. If the system has more than one system output, the WAV instruction is executed once for each system output.

### 9.3 Example Inference Kernel

Figure 9-3 is a complete fuzzy inference kernel written in CPU12 assembly language. Numbers in square brackets are cycle counts. The kernel uses two system inputs with seven labels each and one system output with seven labels. The program assembles to 57 bytes. It executes in about $54 \mu \mathrm{~s}$ at an 8 MHz bus rate. The basic structure can easily be extended to a general-purpose system with a larger number of inputs and outputs.

Lines 1 to 3 set up pointers and load the system input value into the $A$ accumulator.
Line 4 sets the loop count for the loop in lines 5 and 6.
Lines 5 and 6 make up the fuzzification loop for seven labels of one system input. The MEM instruction finds the $y$-value on a trapezoidal membership function for the current input value, for one label of the current input, and then stores the result to the corresponding fuzzy input. Pointers in $X$ and $Y$ are automatically updated by four and one so they point at the next membership function and fuzzy input respectively.

Line 7 loads the current value of the next system input. Pointers in X and Y already point to the right places as a result of the automatic update function of the MEM instruction in line 5.

Line 8 reloads a loop count.
Lines 9 and 10 form a loop to fuzzify the seven labels of the second system input. When the program drops to line 11, the Y index register is pointing at the next location after the last fuzzy input, which is the first fuzzy output in this system.

| * |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 01 | [2] | FUZZIFY | LDX | \# INPUT_MFS | ; Point at MF definitions |
| 02 | [2] |  | LDY | \#FUZ_INS | ; Point at fuzzy input table |
| 03 | [3] |  | LDAA | CURRENT_INS | ; Get first input value |
| 04 | [1] |  | LDAB | \# 7 | ; 7 labels per input |
| 05 | [5] | GRAD_LOOP | MEM |  | ; Evaluate one MF |
| 06 | [3] |  | DBNE | B, GRAD_LOOP | ;For 7 labels of 1 input |
| 07 | [3] |  | LDAA | CURRENT_INS+1 | ; Get second input value |
| 08 | [1] |  | LDAB | \# 7 | ; 7 labels per input |
| 09 | [5] | GRAD_LOOP1 | MEM |  | ; Evaluate one MF |
| 10 | [3] |  | DBNE | B, GRAD_LOOP1 | ;For 7 labels of 1 input |
| 11 | [1] |  | LDAB | \#7 | ; Loop count |
| 12 | [2] | RULE_EVAL | CLR | 1, Y+ | ; Clr a fuzzy out \& inc ptr |
| 13 | [3] |  | DBNE | b, RULE_EVAL | ; Loop to clr all fuzzy outs |
| 14 | [2] |  | LDX | \#RULE_START | ; Point at first rule element |
| 15 | [2] |  | LDY | \#FUZ_INS | ; Point at fuzzy ins and outs |
| 16 | [1] |  | LDAA | \# \$FF | ; Init A (and clears V-bit) |
| 17 | [3n+4] |  | REV |  | ; Process rule list |
| 18 | [2] | DEFUZ | LDY | \#FUZ_OUT | ; Point at fuzzy outputs |
| 19 | [1] |  | LDX | \#SGLTN_POS | ; Point at singleton positions |
| 20 | [1] |  | LDAB | \# 7 | ; 7 fuzzy outs per COG output |
| 21 | [8b+9] |  | WAV |  | ; Calculate sums for wtd av |
| 22 | [11] |  | EDIV |  | ; Final divide for wtd av |
|  | [1] |  | TFR | Y D | ; Move result to A:B |
|  | [3] |  | STAB | COG_OUT | ; Store system output |
|  | ***** | End |  |  |  |

Figure 9-3 Fuzzy Inference Engine
Line 11 sets the loop count to clear seven fuzzy outputs.
Lines 12 and 13 form a loop to clear all fuzzy outputs before rule evaluation starts.
Line 14 initializes the X index register to point at the first element in the rule list for the REV instruction.

Line 15 initializes the Y index register to point at the fuzzy inputs and outputs in the system. The rule list (for REV) consists of 8 -bit offsets from this base address to particular fuzzy inputs or fuzzy outputs. The special value \$FE is interpreted by REV as a marker between rule antecedents and consequents.

Line 16 initializes the A accumulator to the highest 8 -bit value in preparation for finding the smallest fuzzy input referenced by a rule antecedent. The LDAA \#\$FF instruction also clears the $V$-bit in the CPU12's condition code register so the REV instruction knows it is processing antecedents. During rule list processing, the V bit is toggled each time an $\$ F E$ is detected in the list. The $V$ bit indicates whether REV is processing antecedents or consequents.

Line 17 is the REV instruction, a self-contained loop to process successive elements in the rule list until an \$FF character is found. For a system of 17 rules with two antecedents and one consequent each, the REV instruction takes 259 cycles, but it is interruptible so it does not cause a long interrupt latency.

Lines 18 through 20 set up pointers and an iteration count for the WAV instruction.
Line 21 is the beginning of defuzzification. The WAV instruction calculates a sum-ofproducts and a sum-of-weights.

Line 22 completes defuzzification. The EDIV instruction performs a 32-bit by 16-bit divide on the intermediate results from WAV to get the weighted average.

Line 23 moves the EDIV result into the double accumulator.
Line 24 stores the low 8-bits of the defuzzification result.
This example inference program shows how easy it is to incorporate fuzzy logic into general applications using the CPU12. Code space and execution time are no longer serious factors in the decision to use fuzzy logic. The next section begins a much more detailed look at the fuzzy logic instructions of the CPU12.

### 9.4 MEM Instruction Details

This section provides a more detailed explanation of the membership function evaluation instruction (MEM), including details about abnormal special cases for improperly defined membership functions.

### 9.4.1 Membership Function Definitions

Figure 9-4 shows how a normal membership function is specified in the CPU12. Typically a software tool is used to input membership functions graphically, and the tool generates data structures for the target processor and software kernel. Alternatively, points and slopes for the membership functions can be determined and stored in memory with define-constant assembler directives.

An internal CPU algorithm calculates the y-value where the current input intersects a membership function. This algorithm assumes the membership function obeys some common-sense rules. If the membership function definition is improper, the results may be unusual. 9.4.2 Abnormal Membership Function Definitions discusses these cases. The following rules apply to normal membership functions.

- $\$ 00 \leq$ point $1<\$ F F$
- $\$ 00<$ point2 $\leq \$ F F$
- point1 < point2
- The sloping sides of the trapezoid meet at or above \$FF

Each system input such as temperature has several labels such as cold, cool, normal, warm, and hot. Each label of each system input must have a membership function to describe its meaning in an unambiguous numerical way. Typically, there are three to seven labels per system input, but there is no practical restriction on this number as far as the fuzzification step is concerned.


Figure 9-4 Defining a Normal Membership Function

### 9.4.2 Abnormal Membership Function Definitions

In the CPU12, it is possible (and proper) to define "crisp" membership functions. A crisp membership function has one or both sides vertical (infinite slope). Since the slope value $\$ 00$ is not used otherwise, it is assigned to mean infinite slope to the MEM instruction in the CPU12.

Although a good fuzzy development tool will not allow the user to specify an improper membership function, it is possible to have program errors or memory errors which result in erroneous abnormal membership functions. Although these abnormal shapes do not correspond to any working systems, understanding how the CPU12 treats these cases can be helpful for debugging.

A close examination of the MEM instruction algorithm will show how such membership functions are evaluated. Figure 9-5 is a complete flow diagram for the execution of a MEM instruction. Each rectangular box represents one CPU bus cycle. The number in the upper left corner corresponds to the cycle number and the letter corresponds to the cycle type (refer to SECTION 6 INSTRUCTION GLOSSARY for details). The upper portion of the box includes information about bus activity during this cycle (if any). The lower portion of the box, which is separated by a dashed line, includes information about internal CPU processes. It is common for several internal functions to take place during a single CPU cycle (for example, in cycle 2, two 8 -bit subtractions take place and a flag is set based on the results).


Figure 9-5 MEM Instruction Flow Diagram
Consider 4a: If $(($ Slope_2 $=0)$ or $($ Grade_2 $>$ \$FF) $)$ and (flag_d12n $=0)$ ).
The flag_d12n is zero as long as the input value (in accumulator A) is within the trapezoid. Everywhere outside the trapezoid, one or the other delta term will be negative, and the flag will equal one. Slope_2 equals zero indicates the right side of the trapezoid has infinite slope, so the resulting grade should be \$FF everywhere in the trapezoid, including at point_2, as far as this side is concerned. The term grade_2 greater than \$FF means the value is far enough into the trapezoid that the right sloping side of the trapezoid has crossed above the \$FF cutoff level and the resulting grade should be $\$$ FF as far as the right sloping side is concerned. 4a decides if the value is left of the right sloping side (Grade = \$FF), or on the sloping portion of the right side of the trapezoid (Grade = Grade_2). 4b could still override this tentative value in grade.

In 4b, slope_1 is zero if the left side of the trapezoid has infinite slope (vertical). If so, the result (grade) should be \$FF at and to the right of point_1 everywhere within the trapezoid as far as the left side is concerned. The grade_1 greater than \$FF term corresponds to the input being to the right of where the left sloping side passes the \$FF cutoff level. If either of these conditions is true, the result (grade) is left at the value it got from 4a. The "else" condition in 4b corresponds to the input falling on the sloping portion of the left side of the trapezoid (or possibly outside the trapezoid), so the result is grade equal grade_1. If the input was outside the trapezoid, flag_d12n would be one and grade_1 and grade_2 would have been forced to $\$ 00$ in cycle 3 . The else condition of 4 b would set the result to $\$ 00$.

The following special cases represent abnormal membership function definitions. The explanations describe how the specific algorithm in the CPU12 resolves these unusual cases. The results are not all intuitively obvious, but rather fall out from the specific algorithm. Remember, these cases should not occur in a normal system.

### 9.4.2.1 Abnormal Membership Function Case 1

This membership function is abnormal because the sloping sides cross below the \$FF cutoff level. The flag_d12n signal forces the membership function to evaluate to $\$ 00$ everywhere except from point_1 to point_2. Within this interval, the tentative values for grade_1 and grade_2 calculated in cycle 3 fall on the crossed sloping sides. In step $4 a$, grade gets set to the grade_2 value, but in $4 b$ this is overridden by the grade_1 value, which ends up as the result of the MEM instruction. One way to say this is that the result follows the left sloping side until the input passes point_2, where the result goes to $\$ 00$.

Memory Definition: $\$ 60, \$ 80, \$ 04, \$ 04$; Point_1, Point_2, Slope_1, Slope_2

Graphical Representation:


How Interpreted:


ABN MEM 1
Figure 9-6 Abnormal Membership Function Case 1

If point_1 was to the right of point_2, flag_d12n would force the result to be $\$ 00$ for all input values. In fact, flag_d12n always limits the region of interest to the space greater than or equal to point_1 and less than or equal to point_2.

### 9.4.2.2 Abnormal Membership Function Case 2

Like the previous example, the membership function in case 2 is abnormal because the sloping sides cross below the \$FF cutoff level, but the left sloping side reaches the $\$ F F$ cutoff level before the input gets to point_2. In this case, the result follows the left sloping side until it reaches the \$FF cutoff level. At this point, the (grade_1 > \$FF) term of $4 b$ kicks in, making the expression true so grade equals grade (no overwrite). The result from here to point_2 becomes controlled by the "else" part of 4 a (grade = grade_2), and the result follows the right sloping side.

Memory Definition: \$60, \$C0, \$04, \$04; Point_1, Point_2, Slope_1, Slope_2

Graphical Representation


How Interpreted


ABN MEM 2
Figure 9-7 Abnormal Membership Function Case 2

### 9.4.2.3 Abnormal Membership Function Case 3

The membership function in case 3 is abnormal because the sloping sides cross below the \$FF cutoff level, and the left sloping side has infinite slope. In this case, 4a is not true, so grade equals grade_2. 4 b is true because slope_1 is zero, so 4 b does not overwrite grade.

Memory Definition: \$60, \$80, \$00, \$04; Point_1, Point_2, Slope_1, Slope_2

Graphical Representation


How Interpreted


ABN MEM 3
Figure 9-8 Abnormal Membership Function Case 3

### 9.5 REV, REVW Instruction Details

This section provides a more detailed explanation of the rule evaluation instructions (REV and REVW). The data structures used to specify rules are somewhat different for the weighted versus unweighted versions of the instruction. One uses 8-bit offsets in the encoded rules, while the other uses full 16-bit addresses. This affects the size of the rule data structure and execution time.

### 9.5.1 Unweighted Rule Evaluation (REV)

This instruction implements basic min-max rule evaluation. CPU registers are used for pointers and intermediate calculation results.

Since the REV instruction is essentially a list-processing instruction, execution time is dependent on the number of elements in the rule list. The REV instruction is interruptible (typically within three bus cycles), so it does not adversely affect worst case interrupt latency. Since all intermediate results and instruction status are held in stacked CPU registers, the interrupt service code can even include independent REV and REVW instructions.

### 9.5.1.1 Set Up Prior to Executing REV

Some CPU registers and memory locations need to be set up prior to executing the REV instruction. X and Y index registers are used as index pointers to the rule list and the fuzzy inputs and outputs. The A accumulator is used for intermediate calculation results and needs to be set to \$FF initially. The V condition code bit is used as an instruction status indicator to show whether antecedents or consequents are being processed. Initially, the V bit is cleared to zero to indicate antecedents are being processed. The fuzzy outputs (working RAM locations) need to be cleared to $\$ 00$. If these values are not initialized before executing the REV instruction, results will be erroneous.

The X index register is set to the address of the first element in the rule list (in the knowledge base). The REV instruction automatically updates this pointer so that the instruction can resume correctly if it is interrupted. After the REV instruction finishes, $X$ will point at the next address past the \$FF separator character that marks the end of the rule list.

The Y index register is set to the base address for the fuzzy inputs and outputs (in working RAM). Each rule antecedent is an unsigned 8-bit offset from this base address to the referenced fuzzy input. Each rule consequent is an unsigned 8-bit offset from this base address to the referenced fuzzy output. The Y index register remains constant throughout execution of the REV instruction.

The 8-bit A accumulator is used to hold intermediate calculation results during execution of the REV instruction. During antecedent processing, A starts out at \$FF and is replaced by any smaller fuzzy input that is referenced by a rule antecedent (MIN). During consequent processing, A holds the truth value for the rule. This truth value is stored to any fuzzy output that is referenced by a rule consequent, unless that fuzzy output is already larger (MAX).

Before starting to execute REV, A must be set to \$FF (the largest 8-bit value) because rule evaluation always starts with processing of the antecedents of the first rule. For subsequent rules in the list, $A$ is automatically set to \$FF when the instruction detects the \$FE marker character between the last consequent of the previous rule, and the first antecedent of a new rule.

The instruction LDAA \#\$FF clears the $V$ bit at the same time it initializes $A$ to \$FF. This satisfies the REV setup requirement to clear the V bit as well as the requirement to initialize A to \$FF. Once the REV instruction starts, the value in the V bit is automatically maintained as \$FE separator characters are detected.

The final requirement to clear all fuzzy outputs to $\$ 00$ is part of the MAX algorithm. Each time a rule consequent references a fuzzy output, that fuzzy output is compared to the truth value for the current rule. If the current truth value is larger, it is written over the previous value in the fuzzy output. After all rules have been evaluated, the fuzzy output contains the truth value for the most-true rule that referenced that fuzzy output.

After REV finishes, A will hold the truth value for the last rule in the rule list. The V condition code bit should be one because the last element before the \$FF end marker should have been a rule consequent. If V is zero after executing REV, it indicates the rule list was structured incorrectly.

### 9.5.1.2 Interrupt Details

The REV instruction includes a three-cycle processing loop for each byte in the rule list (including antecedents, consequents, and special separator characters). Within this loop, a check is performed to see if any qualified interrupt request is pending. If an interrupt is detected, the current CPU registers are stacked and the interrupt is honored. When the interrupt service routine finishes, an RTI instruction causes the CPU to recover its previous context from the stack, and the REV instruction is resumed as if it had not been interrupted.

The stacked value of the program counter (PC), in case of an interrupted REV instruction, points to the REV instruction rather than the instruction that follows. This causes the CPU to try to execute a new REV instruction upon return from the interrupt. Since the CPU registers (including the V bit in the condition codes register) indicate the current status of the interrupted REV instruction, this effectively causes the rule evaluation operation to resume from where it left off.

### 9.5.1.3 Cycle-by-Cycle Details for REV

The central element of the REV instruction is a three-cycle loop that is executed once for each byte in the rule list. There is a small amount of housekeeping activity to get this loop started as REV begins, and a small sequence to end the instruction. If an interrupt comes, there is a special small sequence to save CPU status on the stack before honoring the requested interrupt.

Figure 9-9 is a REV instruction flow diagram. Each rectangular box represents one CPU clock cycle. Decision blocks and connecting arrows are considered to take no time at all. The letters in the small rectangles in the upper left corner of each bold box correspond to execution cycle codes (refer to SECTION 6 INSTRUCTION GLOSSARY for details). Lower case letters indicate a cycle where 8-bit or no data is transferred. Upper case letters indicate cycles where 16-bit or no data is transferred.


Figure 9-9 REV Instruction Flow Diagram

When a value is read from memory, it cannot be used by the CPU until the second cycle after the read takes place. This is due to access and propagation delays.

Since there is more than one flow path through the REV instruction, cycle numbers have a decimal place. This decimal place indicates which of several possible paths is being used. The CPU normally moves forward by one digit at a time within the same flow (flow number is indicated after the decimal point in the cycle number). There are two exceptions possible to this orderly sequence through an instruction. The first is a branch back to an earlier cycle number to form a loop as in 6.0 to 4.0. The second type of sequence change is from one flow to a parallel flow within the same instruction such as 4.0 to 5.2 , which occurs if the REV instruction senses an interrupt. In this second type of sequence branch, the whole number advances by one and the flow number changes to a new value (the digit after the decimal point).

In cycle 1.0, the CPU12 does an optional program word access to replace the $\$ 18$ prebyte of the REV instruction. Notice that cycle 7.0 is also an O type cycle. One or the other of these will be a program word fetch, while the other will be a free cycle where the CPU does not access the bus. Although the $\$ 18$ page prebyte is a required part of the REV instruction, it is treated by the CPU12 as a somewhat separate single cycle instruction.

Rule evaluation begins at cycle 2.0 with a byte read of the first element in the rule list. Usually this would be the first antecedent of the first rule, but the REV instruction can be interrupted, so this could be a read of any byte in the rule list. The X index register is incremented so it points to the next element in the rule list. Cycle 3.0 is needed to satisfy the required delay between a read and when data is valid to the CPU. Some internal CPU housekeeping activity takes place during this cycle, but there is no bus activity. By cycle 4.0, the rule element that was read in cycle 2.0 is available to the CPU.

Cycle 4.0 is the first cycle of the main three cycle rule evaluation loop. Depending upon whether rule antecedents or consequents are being processed, the loop will consist of cycles $4.0,5.0,6.0$, or the sequence $4.0,5.0,6.1$. This loop is executed once for every byte in the rule list, including the \$FE separators and the \$FF end-of-rules marker.


#### Abstract

At each cycle 4.0, a fuzzy input or fuzzy output is read, except during the loop passes associated with the \$FE and \$FF marker bytes, where no bus access takes place during cycle 4.0. The read access uses the Y index register as the base address and the previously read rule byte $\left(R_{X}\right)$ as an unsigned offset from Y . The fuzzy input or output value read here will be used during the next cycle 6.0 or 6.1. Besides being used as the offset from $Y$ for this read, the previously read $R_{X}$ is checked to see if it is a separator character (\$FE). If $R_{x}$ was $\$ F E$ and the V-bit was one, this indicates a switch from processing consequents of one rule to starting to process antecedents of the next rule. At this transition, the A accumulator is initialized to \$FF to prepare for the min operation to find the smallest fuzzy input. Also, if Rx is \$FE, the V-bit is toggled to indicate the change from antecedents to consequents, or consequents to antecedents.

During cycle 5.0, a new rule byte is read unless this is the last loop pass, and $R_{x}$ is \$FF (marking the end of the rule list). This new rule byte will not be used until cycle 4.0 of the next pass through the loop.


Between cycle 5.0 and 6.x, the V-bit is used to decide which of two paths to take. If V is zero, antecedents are being processed and the CPU progresses to cycle 6.0. If V is one, consequents are being processed and the CPU goes to cycle 6.1.

During cycle 6.0, the current value in the A accumulator is compared to the fuzzy input that was read in the previous cycle 4.0, and the lower value is placed in the A accumulator (min operation). If $R x$ is $\$ F E$, this is the transition between rule antecedents and rule consequents, and this min operation is skipped (although the cycle is still used). No bus access takes place during cycle 6.0 but cycle 6.x is considered an $x$ type cycle because it could be a byte write (cycle 6.1), or a free cycle (cycle 6.0 or 6.1 with $R x=\$ F E$ or $\$ F F)$.

If an interrupt arrives while the REV instruction is executing, REV can break between cycles 4.0 and 5.0 in an orderly fashion so that the rule evaluation operation can resume after the interrupt has been serviced. Cycles 5.2 and 6.2 are needed to adjust the PC and $X$ index register so the REV operation can recover after the interrupt. PC is adjusted backward in cycle 5.2 so it points to the currently running REV instruction. After the interrupt, rule evaluation will resume, but the values that were stored on the stack for index registers, accumulator A, and CCR will cause the operation to pick up where it left off. In cycle 6.2, the X index register is adjusted backward by one because the last rule byte needs to be re-fetched when the REV instruction resumes.

After cycle 6.2, the REV instruction is finished, and execution would continue to the normal interrupt processing flow.

### 9.5.2 Weighted Rule Evaluation (REVW)

This instruction implements a weighted variation of min-max rule evaluation. The weighting factors are stored in a table with one 8-bit entry per rule. The weight is used to multiply the truth value of the rule (minimum of all antecedents) by a value from zero to one to get the weighted result. This weighted result is then applied to the consequents, just as it would be for unweighted rule evaluation.

Since the REVW instruction is essentially a list-processing instruction, execution time is dependent on the number of rules and the number of elements in the rule list. The REVW instruction is interruptible (typically within three to five bus cycles), so it does not adversely affect worst case interrupt latency. Since all intermediate results and instruction status are held in stacked CPU registers, the interrupt service code can even include independent REV and REVW instructions.

The rule structure is different for REVW than for REV. For REVW, the rule list is made up of 16-bit elements rather than 8-bit elements. Each antecedent is represented by the full 16-bit address of the corresponding fuzzy input. Each rule consequent is represented by the full address of the corresponding fuzzy output.

The markers separating antecedents from consequents are the reserved 16-bit value $\$ F F F E$, and the end of the last rule is marked by the reserved 16 -bit value \$FFFF. Since \$FFFE and \$FFFF correspond to the addresses of the reset vector, there would never be a fuzzy input or output at either of these locations.

### 9.5.2.1 Set Up Prior to Executing REVW

Some CPU registers and memory locations need to be set up prior to executing the REVW instruction. X and Y index registers are used as index pointers to the rule list and the list of rule weights. The A accumulator is used for intermediate calculation results and needs to be set to \$FF initially. The V condition code bit is used as an instruction status indicator that shows whether antecedents or consequents are being processed. Initially the V bit is cleared to zero to indicate antecedents are being processed. The C condition code bit is used to indicate whether rule weights are to be used (1) or not (0). The fuzzy outputs (working RAM locations) need to be cleared to $\$ 00$. If these values are not initialized before executing the REVW instruction, results will be erroneous.

The X index register is set to the address of the first element in the rule list (in the knowledge base). The REVW instruction automatically updates this pointer so that the instruction can resume correctly if it is interrupted. After the REVW instruction finishes, X will point at the next address past the \$FFFF separator word that marks the end of the rule list.

The Y index register is set to the starting address of the list of rule weights. Each rule weight is an 8 -bit value. The weighted result is the truncated upper eight bits of the 16bit result, which is derived by multiplying the minimum rule antecedent value (\$00$\$ F F$ ) by the weight plus one ( $\$ 001-\$ 100$ ). This method of weighting rules allows an 8bit weighting factor to represent a value between zero and one inclusive.

The 8-bit A accumulator is used to hold intermediate calculation results during execution of the REVW instruction. During antecedent processing, A starts out at \$FF and is replaced by any smaller fuzzy input that is referenced by a rule antecedent. If rule weights are enabled by the $C$ condition code bit equal one, the rule truth value is multiplied by the rule weight just before consequent processing starts. During consequent processing, A holds the truth value (possibly weighted) for the rule. This truth value is stored to any fuzzy output that is referenced by a rule consequent, unless that fuzzy output is already larger (MAX).

Before starting to execute REVW, A must be set to \$FF (the largest 8-bit value) because rule evaluation always starts with processing of the antecedents of the first rule. For subsequent rules in the list, A is automatically set to \$FF when the instruction detects the \$FFFE marker word between the last consequent of the previous rule, and the first antecedent of a new rule.

Both the C and V condition code bits must be set up prior to starting a REVW instruction. Once the REVW instruction starts, the $C$ bit remains constant and the value in the V bit is automatically maintained as \$FFFE separator words are detected.

The final requirement to clear all fuzzy outputs to $\$ 00$ is part of the MAX algorithm. Each time a rule consequent references a fuzzy output, that fuzzy output is compared to the truth value (weighted) for the current rule. If the current truth value is larger, it is written over the previous value in the fuzzy output. After all rules have been evaluated, the fuzzy output contains the truth value for the most-true rule that referenced that fuzzy output.

After REVW finishes, A will hold the truth value (weighted) for the last rule in the rule list. The V condition code bit should be one because the last element before the \$FFFF end marker should have been a rule consequent. If V is zero after executing REVW, it indicates the rule list was structured incorrectly.

### 9.5.2.2 Interrupt Details

The REVW instruction includes a three-cycle processing loop for each word in the rule list (this loop expands to five cycles between antecedents and consequents to allow time for the multiplication with the rule weight). Within this loop, a check is performed to see if any qualified interrupt request is pending. If an interrupt is detected, the current CPU registers are stacked and the interrupt is honored. When the interrupt service routine finishes, an RTI instruction causes the CPU to recover its previous context from the stack, and the REVW instruction is resumed as if it had not been interrupted.

The stacked value of the program counter (PC), in case of an interrupted REVW instruction, points to the REVW instruction rather than the instruction that follows. This causes the CPU to try to execute a new REVW instruction upon return from the interrupt. Since the CPU registers (including the C bit and V bit in the condition codes register) indicate the current status of the interrupted REVW instruction, this effectively causes the rule evaluation operation to resume from where it left off.

### 9.5.2.3 Cycle-by-Cycle Details for REVW

The central element of the REVW instruction is a three-cycle loop that is executed once for each word in the rule list. For the special case pass (where the \$FFFE separator word is read between the rule antecedents and the rule consequents, and weights enabled by the C bit equal one), this loop takes five cycles. There is a small amount of housekeeping activity to get this loop started as REVW begins and a small sequence to end the instruction. If an interrupt comes, there is a special small sequence to save CPU status on the stack before the interrupt is serviced.

Figure $9-10$ is a detailed flow diagram for the REVW instruction. Each rectangular box represents one CPU clock cycle. Decision blocks and connecting arrows are considered to take no time at all. The letters in the small rectangles in the upper left corner of each bold box correspond to the execution cycle codes (refer to SECTION 6 INSTRUCTION GLOSSARY for details). Lower case letters indicate a cycle where 8-bit or no data is transferred. Upper case letters indicate cycles where 16-bit data could be transferred.


Figure 9-10 REVW Instruction Flow Diagram

In cycle 2.0, the first element of the rule list (a 16-bit address) is read from memory. Due to propagation delays, this value cannot be used for calculations until two cycles later (cycle 4.0). The $X$ index register, which is used to access information from the rule list, is incremented by two to point at the next element of the rule list.

The operations performed in cycle 4.0 depend on the value of the word read from the rule list. \$FFFE is a special token that indicates a transition from antecedents to consequents, or from consequents to antecedents of a new rule. The V bit can be used to decide which transition is taking place, and V is toggled each time the \$FFFE token is detected. If V was zero, a change from antecedents to consequents is taking place, and it is time to apply weighting (provided it is enabled by the $C$ bit equal one). The address in TMP2 (derived from Y ) is used to read the weight byte from memory. In this case, there is no bus access in cycle 5.0, but the index into the rule list is updated to point to the next rule element.

The old value of $X\left(X_{0}\right)$ is temporarily held on internal nodes, so it can be used to access a rule word in cycle 7.2. The read of the rule word is timed to start two cycles before it will be used in cycle 4.0 of the next loop pass. The actual multiply takes place in cycles 6.2 through 8.2. The 8-bit weight from memory is incremented (possibly overflowing to $\$ 100$ ) before the multiply, and the upper eight bits of the 16-bit internal result is used as the weighted result. By using weight+1, the result can range from 0.0 times A to 1.0 times A. After 8.2, flow continues to the next loop pass at cycle 4.0.

At cycle 4.0, if $R_{x}$ is \$FFFE and $V$ was one, a change from consequents to antecedents of a new rule is taking place, so accumulator A must be reinitialized to \$FF. During processing of rule antecedents, $A$ is updated with the smaller of $A$, or the current fuzzy input (cycle 6.0). Cycle 5.0 is usually used to read the next rule word and update the pointer in $X$. This read is skipped if the current $R_{X}$ is $\$ F F F F$ (end of rules mark). If this is a weight multiply pass, the read is delayed until cycle 7.2. During processing of consequents, cycle 6.1 is used to optionally update a fuzzy output if the value in accumulator $A$ is larger.

After all rules have been processed, cycle 7.0 is used to update the PC to point at the next instruction. If weights were enabled, Y is updated to point at the location that immediately follows the last rule weight.

### 9.6 WAV Instruction Details

The WAV instruction performs weighted average calculations used in defuzzification. The pseudo-instruction wavr is used to resume an interrupted weighted average operation. WAV calculates the numerator and denominator sums using:

$$
\text { System Output }=\frac{\sum_{i=1}^{n} S_{i} F_{i}}{\sum_{i=1}^{n} F_{i}}
$$

Where n is the number of labels of a system output, $\mathrm{S}_{\mathrm{i}}$ are the singleton positions from the knowledge base, and $F_{i}$ are fuzzy outputs from RAM. $S_{i}$ and $F_{i}$ are 8-bit values. The 8-bit B accumulator holds the iteration count n. Internal temporary registers hold intermediate sums, 24 bits for the numerator and 16 bits for the denominator. This makes this instruction suitable for $n$ values up to 255 although eight is a more typical value. The final long division is performed with a separate EDIV instruction immediately after the WAV instruction. The WAV instruction returns the numerator and denominator sums in the correct registers for the EDIV. (EDIV performs the unsigned division $Y=Y: D / X$; remainder in $D)$.

Execution time for this instruction depends on the number of iterations (labels for the system output). WAV is interruptible so that worst case interrupt latency is not affected by the execution time for the complete weighted average operation. WAV includes initialization for the 24-bit and 16-bit partial sums so the first entry into WAV looks different than a resume from interrupt operation. The CPU12 handles this difficulty with a pseudo-instruction (wavr), which is specifically intended to resume an interrupted weighted average calculation. Refer to 9.6.3 Cycle-by-Cycle Details for WAV and wavr for more detail.

### 9.6.1 Setup Prior to Executing WAV

Before executing the WAV instruction, index registers $X$ and $Y$ and accumulator $B$ must be set up. Index register $X$ is a pointer to the $S_{i}$ singleton list. $X$ must have the address of the first singleton value in the knowledge base. Index register Y is a pointer to the fuzzy outputs $\mathrm{F}_{\mathrm{i}}$. Y must have the address of the first fuzzy output for this system output. $B$ is the iteration count $n$. The $B$ accumulator must be set to the number of labels for this system output.

### 9.6.2 WAV Interrupt Details

The WAV instruction includes an 8-cycle processing loop for each label of the system output. Within this loop, the CPU checks whether a qualified interrupt request is pending. If an interrupt is detected, the current values of the internal temporary registers for the 24-bit and 16-bit sums are stacked, the CPU registers are stacked, and the interrupt is serviced.

A special processing sequence is executed when an interrupt is detected during a weighted average calculation. This exit sequence adjusts the PC so that it points to the second byte of the WAV object code (\$3C), before the PC is stacked. Upon return from the interrupt, the \$3C value is interpreted as a wavr pseudo-instruction. The wavr pseudo-instruction causes the CPU to execute a special WAV resumption sequence. The wavr recovery sequence adjusts the PC so that it looks like it did during execution of the original WAV instruction, then jumps back into the WAV processing loop. If another interrupt occurs before the weighted average calculation finishes, the PC is adjusted again as it was for the first interrupt. WAV can be interrupted any number of times, and additional WAV instructions can be executed while a WAV instruction is interrupted.

### 9.6.3 Cycle-by-Cycle Details for WAV and wavr

The WAV instruction is unusual in that the logic flow has two separate entry points. The first entry point is the normal start of a WAV instruction. The second entry point is used to resume the weighted average operation after a WAV instruction has been interrupted. This recovery operation is called the wavr pseudo-instruction.

Figure $9-11$ is a flow diagram of the WAV instruction including the wavr pseudo-instruction. Each rectangular box in this figure represents one CPU clock cycle. Decision blocks and connecting arrows are considered to take no time at all. The letters in the small rectangles in the upper left corner of the boxes correspond to execution cycle codes (refer to SECTION 6 INSTRUCTION GLOSSARY for details). Lower case letters indicate a cycle where 8-bit or no data is transferred. Upper case letters indicate cycles where 16-bit data could be transferred.

In terms of cycle-by-cycle bus activity, the $\$ 18$ page select prebyte is treated as a special 1-byte instruction. In cycle 1.0 of the WAV instruction, one word of program information will be fetched into the instruction queue if the $\$ 18$ is located at an odd address. If the $\$ 18$ is at an even address, the instruction queue cannot advance so there is no bus access in this cycle.

There is no bus access in cycles 2.0 or 3.0. In cycle 3.0, three internal 16-bit temporary registers are cleared in preparation for summation operations. The WAV instruction maintains a 32-bit sum-of-products in TMP3: TMP2 and a 16-bit sum-of-weights in TMP1. By keeping these sums inside the CPU, bus accesses are reduced and the WAV operation is optimized for high speed.

Cycles 4.0 through 11.0 form the eight cycle main loop for WAV. The value in the 8-bit $B$ accumulator is used to count the number of loop iterations. B is decremented at the top of the loop in cycle 4.0, and the test for zero is located at the bottom of the loop after cycle 11.0. Cycle 5.0 and 6.0 are used to fetch the 8 -bit operands for one iteration of the loop. X and Y index registers are used to access these operands. The index registers are incremented as the operands are fetched. Cycle 7.0 is used to accumulate the current fuzzy output into TMP1. Cycles 8.0 through 10.0 are used to perform the eight by eight multiply of $\mathrm{F}_{\mathrm{i}}$ times $\mathrm{S}_{\mathrm{i}}$. The multiply result is accumulated into TMP3 : TMP2 during cycles 10.0 and 11.0. Even though the sum-of-products will not exceed 24 bits, the sum is maintained in the 32-bit combined TMP3: TMP2 register because it is easier to use existing 16-bit operations than it would be to create a new smaller operation to handle the high order bits of this sum.

Since the weighted average operation could be quite long, it is made to be interruptible. The usual longest latency path is from very early in cycle 7.0, through cycle 11.0, to the top of the loop to cycle 4.0, through cycle 6.0 to the interrupt check. There is also a three cycle ( 7.1 through 9.1) exit sequence making this latency path a total of 12 cycles. There is an even longer path, but it is much less likely to occur. If an interrupt comes near the beginning of cycle 2.1, when a weighted average operation is being resumed after a previous interrupt, the latency path is 2.1 through 6.1 plus 7.0 through 11.0 plus 4.0 through 6.0 plus the exit 7.1 through 9.1. This is a worst-case total of 17 cycles.


Figure 9-11 WAV and wavr Instruction Flow Diagram

If the WAV instruction is interrupted, the internal temporary registers TMP3, TMP2, and TMP1 need to be stored on the stack so the operation can be resumed. Since the WAV instruction included initialization in cycle 2.0, the recovery path after an interrupt needs to be different. The wavr pseudo-instruction has the same opcode as WAV, but it is on the first page of the opcode map so there is no page prebyte $(\$ 18)$ like there is for WAV. When WAV is interrupted, the PC is adjusted to point at the second byte of the WAV object code, so that it will be interpreted as the wavr pseudo-instruction on return from the interrupt, rather than the WAV instruction. During the recovery sequence, the PC is readjusted in case another interrupt comes before the weighted average operation finishes.

The resume sequence includes recovery of the temporary registers from the stack (2.1 through 4.1), and reads to get the operands for the current iteration. The normal WAV flow is then rejoined at cycle 7.0.

Upon normal completion of the instruction (cycle 12.0), the PC is adjusted so it points to the next instruction. The results are transferred from the TMP registers into CPU registers in such a way that the EDIV instruction can be used to divide the sum-ofproducts by the sum-of-weights. TMP3 : TMP2 is transferred into $Y: D$ and TMP1 is transferred into X .

### 9.7 Custom Fuzzy Logic Programming

The basic fuzzy logic inference techniques described above are suitable for a broad range of applications, but some systems may require customization. The built-in fuzzy instructions use 8-bit resolution and some systems may require finer resolution. The rule evaluation instructions only support variations of MIN-MAX rule evaluation and other methods have been discussed in fuzzy logic literature. The weighted average of singletons is not the only defuzzification technique. The CPU12 has several instructions and addressing modes that can be helpful when in developing custom fuzzy logic systems.

### 9.7.1 Fuzzification Variations

The MEM instruction supports trapezoidal membership functions and several other varieties, including membership functions with vertical sides (infinite slope sides). Triangular membership functions are a subset of trapezoidal functions. Some practitioners refer to $s$-, $z$-, and $\pi$-shaped membership functions. These refer to a trapezoid butted against the right end of the x-axis, a trapezoid butted against the left end of the x-axis, and a trapezoidal membership function that isn't butted against either end of the xaxis, respectively. Many other membership function shapes are possible, if memory space and processing bandwidth are sufficient.

Tabular membership functions offer complete flexibility in shape and very fast evaluation time. However, tables take a very large amount of memory space (as many as 256 bytes per label of one system input). The excessive size to specify tabular membership functions makes them impractical for most microcontroller-based fuzzy systems. The CPU12 instruction set includes two instructions (TBL and ETBL) for lookup and interpolation of compressed tables.

The TBL instruction uses 8-bit table entries (y-values) and returns an 8-bit result. The ETBL instruction uses 16-bit table entries (y-values) and returns a 16-bit result. A flexible indexed addressing mode is used to identify the effective address of the data point at the beginning of the line segment, and the data value for the end point of the line segment is the next consecutive memory location (byte for TBL and word for ETBL). In both cases, the B accumulator represents the ratio of (the x-distance from the beginning of the line segment to the lookup point) to (the x-distance from the beginning of the line segment to the end of the line segment). $B$ is treated as an 8-bit binary fraction with radix point left of the MSB, so each line segment can effectively be divided into 256 pieces. During execution of the TBL or ETBL instruction, the difference between the end point $y$-value and the beginning point $y$-value (a signed byte-TBL or word-ETBL) is multiplied by the $B$ accumulator to get an intermediate delta-y term. The result is the $y$-value of the beginning point, plus this signed intermediate delta-y value.

Because indexed addressing mode is used to identify the starting point of the line segment of interest, there is a great deal of flexibility in constructing tables. A common method is to break the $x$-axis range into 256 equal width segments and store the $y$ value for each of the resulting 257 endpoints. The 16-bit D accumulator is then used as the $x$ input to the table. The upper eight bits $(A)$ is used as a coarse lookup to find the line segment of interest, and the lower eight bits $(B)$ is used to interpolate within this line segment.

In the program sequence...

| LDX | \#TBL_START |
| :--- | :--- |
| LDD | DATA_IN |
| TBL | A, X |

The notation $A, X$ causes the TBL instruction to use the $A^{\text {th }}$ line segment in the table. The low-order half of $D(B)$ is used by TBL to calculate the exact data value from this line segment. This type of table uses only 257 entries to approximate a table with 16 bits of resolution. This type of table has the disadvantage of equal width line segments, which means just as many points are needed to describe a flat portion of the desired function as are needed for the most active portions.

Another type of table stores $x$ :y coordinate pairs for the endpoints of each linear segment. This type of table may reduce the table storage space compared to the previous fixed-width segments because flat areas of the functions can be specified with a single pair of endpoints. This type of table is a little harder to use with the CPU12 TBL and ETBL instructions because the table instructions expect $y$-values for segment endpoints to be in consecutive memory locations.

Consider a table made up of an arbitrary number of $x$ :y coordinate pairs, where all values are eight bits. The table is entered with the x-coordinate of the desired point to lookup in the A accumulator. When the table is exited, the corresponding y-value is in the A accumulator. Figure $\mathbf{9 - 1 2}$ shows one way to work with this type of table.


Figure 9-12 Endpoint Table Handling

The basic idea is to find the segment of interest, temporarily build a one-segment table of the correct format on the stack, then use TBL with stack relative indexed addressing to interpolate. The most difficult part of the routine is calculating the proportional distance from the beginning of the segment to the lookup point versus the width of the segment ((XL-XB)/(XE-XB)). With this type of table, this calculation must be done at run time. In the previous type of table, this proportional term is an inherent part (the lowest order bits) of the data input to the table.

Some fuzzy theorists have suggested membership functions should be shaped like normal distribution curves or other mathematical functions. This may be correct, but the processing requirements to solve for an intercept on such a function would be unacceptable for most microcontroller-based fuzzy systems. Such a function could be encoded into a table of one of the previously described types.

For many common systems, the thing that is most important about membership function shape is that there is a gradual transition from non-membership to membership as the system input value approaches the central range of the membership function. Let us examine the human problem of stopping a car at an intersection. We might use rules like "If intersection is close and speed is fast, apply brakes." The meaning (reflected in membership function shape and position) of the labels "close" and "fast" will be different for a teenager than they are for a grandmother, but both can accomplish the goal of stopping. It makes intuitive sense that the exact shape of a membership function is much less important than the fact that it has gradual boundaries.

### 9.7.2 Rule Evaluation Variations

The REV and REVW instructions expect fuzzy input and fuzzy output values to be 8bit values. In a custom fuzzy inference program, higher resolution may be desirable (although this is not a common requirement). The CPU12 includes variations of minimum and maximum operations that work with the fuzzy MIN-MAX inference algorithm. The problem with the fuzzy inference algorithm is that the min and max operations need to store their results differently, so the min and max instructions must work differently or more than one variation of these instructions is needed.

The CPU12 has min and max instructions for 8- or 16-bit operands, where one operand is in an accumulator and the other is a referenced memory location. There are separate variations that replace the accumulator or the memory location with the result. While processing rule antecedents in a fuzzy inference program, a reference value must be compared to each of the referenced fuzzy inputs, and the smallest input must end up in an accumulator. The instruction...

$$
\text { EMIND } 2, X+\quad \text { process one rule antecedent }
$$

automates the central operations needed to process rule antecedents. The E stands for extended, so this instruction compares 16-bit operands. The D at the end of the mnemonic stands for the $D$ accumulator, which is both the first operand for the comparison and the destination of the result. The $2, \mathrm{X}+$ is an indexed addressing specification that says $X$ points to the second operand for the comparison.

When processing rule consequents, the operand in the accumulator must remain constant (in case there is more than one consequent in the rule), and the result of the comparison must replace the referenced fuzzy output in RAM. To do this, use the instruction...

EMAXM 2,X+ ;process one rule consequent
The $M$ at the end of the mnemonic indicates that the result will replace the referenced memory operand. Again, indexed addressing is used. These two instructions would form the working part of a 16-bit resolution fuzzy inference routine.

There are many other methods of performing inference, but none of these are as widely used as the min-max method. Since the CPU12 is a general-purpose microcontroller, the programmer has complete freedom to program any algorithm desired. A custom programmed algorithm would typically take more code space and execution time than a routine that used the built-in REV or REVW instructions.

### 9.7.3 Defuzzification Variations

There are two main areas where other CPU12 instructions can help with custom defuzzification routines. The first case is working with operands that are more than eight bits. The second case involves using an entirely different approach than weighted average of singletons.

The primary part of the WAV instruction is a multiply and accumulate operation to get the numerator for the weighted average calculation. When working with operands as large as 16 bits, the EMACS instruction could at least be used to automate the multiply and accumulate function. The CPU12 has extended math capabilities, including the EMACS instruction which uses 16-bit input operands and accumulates the sum to a 32 -bit memory location and 32-bit by 16 -bit divide instructions.

One benefit of the WAV instruction is that both a sum of products and a sum of weights are maintained, while the fuzzy output operand is only accessed from memory once. Since memory access time is such a significant part of execution time, this provides a speed advantage compared to conventional instructions.

The weighted average of singletons is the most commonly used technique in microcontrollers because it is computationally less difficult than most other methods. The simplest method is called max defuzzification, which simply uses the largest fuzzy output as the system result. However, this approach does not take into account any other fuzzy outputs, even when they are almost as true as the chosen max output. Max defuzzification is not a good general choice because it only works for a subset of fuzzy logic applications.

The CPU12 is well suited for more computationally challenging algorithms than weighted average. A 32 -bit by 16 -bit divide instruction takes eleven or twelve $8-\mathrm{MHz}$ cycles for unsigned or signed variations. A 16-bit by 16-bit multiply with a 32-bit result takes only three $8-\mathrm{MHz}$ cycles. The EMACS instruction uses 16 -bit operands and accumulates the result in a 32-bit memory location, taking only twelve $8-\mathrm{MHz}$ cycles per iteration, including accessing all operands from memory and storing the result to memory.

## SECTION 10 <br> MEMORY EXPANSION

This section discusses expansion memory principles that apply to the entire M68HC12 family. Some family devices do not have memory expansion capabilities, and the size of the expanded memory can also vary. Please refer to the documentation for a derivative to determine details of implementation.

### 10.1 Expansion System Description

Certain members of the M68HC12 family incorporate hardware that supports addressing a larger memory space than the standard 64 Kbytes. The expanded memory system uses fast on-chip logic to implement a transparent paged memory or bankswitching scheme.
Increased code efficiency is the greatest advantage of using bank switching instead of implementing a large linear address space. In systems with large linear address spaces, instructions require more bits of information to address a memory location, and CPU overhead is greater. Other advantages of bank switching include the ability to change the size of system memory, and the ability to use various types of external memory.

However, the add-on bank switching schemes used in other microcontrollers have known weaknesses. These include the cost of external glue logic, increased programming overhead to change banks, and the need to disable interrupts while banks are switched.

The M68HC12 system requires no external glue logic. Bank switching overhead is reduced by implementing control logic in the MCU. Interrupts do not need to be disabled during switching because switching tasks are incorporated in special instructions that greatly simplify program access to extended memory. Operation of the bank-switching logic is transparent to the CPU.

The CPU12 has a linear 64-Kbyte address space. All MCU system resources, including control registers for on-chip peripherals and on-chip memory arrays, are mapped into this space. In a typical M68HC12 derivative, the resources have default addresses out of reset, but can be re-mapped to other addresses by means of control registers in the on-chip integration module.
Memory expansion control logic is outside the CPU. A block of circuitry in the MCU integration module manages overlays that occupy pre-defined locations in the 64Kbyte space addressed by the CPU. These overlays can be thought of as windows through which the CPU accesses information in the expanded memory space.
There are three overlay windows. The program window expands program memory, the data window is used for independent data expansion, and the extra window expands access to special types of memory such as EEPROM. The program window always occupies the 16-Kbyte space from $\$ 8000$ to \$BFFF. Data and extra windows can vary in size and location.

Each window has an associated page select register that selects external memory pages to be accessed via the window. Only one page at a time can occupy a window; the value in the register must be changed to access a different page of memory. With 8 -bit registers, there can be up to 256 expansion pages per window, each page the same size as the window.

For data and extra windows, page switching is accomplished by means of normal read and write instructions. This is the traditional method of managing a bank-switching system. The CPU12 CALL and RTC instructions automatically manipulate the program page select (PPAGE) register for the program window.

In M68HC12 expanded memory systems, control registers, vector spaces, and a portion of on-chip memory are located in unpaged portions of the 64-Kbyte address space. The stack and I/O addresses should also be placed in unpaged memory to make them accessible from any overlay page.

The initial portions of exception handlers must be located in unpaged memory because the 16 -bit exception vectors cannot point to addresses in paged memory. However, service routines can call other routines in paged memory. The upper 16-Kbyte block of memory space (\$C000-\$FFFF) is unpaged. It is recommended that all reset and interrupt vectors point to locations in this area.

Although internal MCU resources, such as control registers and on-chip memory, have default addresses out of reset, each can typically be relocated by changing the default values in control registers. Normally, I/O addresses, control registers, vector spaces, overlay windows, and on-chip memory are not mapped so that their respective address ranges overlap. However, there is an access priority order that prevents access conflicts should such overlaps occur. Table 10-1 shows the mapping precedence. Resources with higher precedence block access to those with a lower precedence. The windows have lowest priority - registers, exception vectors, and on-chip memory are always visible to a program regardless of the values in the page select registers.

Table 10-1 Mapping Precedence

| Precedence | Resource |
| :---: | :---: |
| 1 | Registers |
| 2 | Exception Vectors/BDM ROM |
| 3 | RAM |
| 4 | EEPROM |
| 5 | Flash |
| 6 | Expansion Windows |

When background debugging is enabled and active, the CPU executes code located in a small on-chip ROM mapped to addresses \$FF20 to \$FFFF, and BDM control registers are accessible at addresses \$FF00 to \$FF06. The BDM ROM replaces the regular system vectors while BDM is active, but BDM resources are not in the memory map during normal execution of application programs.

### 10.2 CALL and Return from Call Instructions

The CALL is similar to a JSR instruction, but the subroutine that is called can be located anywhere in the normal 64-Kbyte address space, or on any page of program expansion memory. When CALL is executed, a return address is calculated, then it and the current program page register value are stacked, and a new instruction-supplied value is written to PPAGE. The PPAGE value controls which of the 256 possible pages is visible through the 16-Kbyte window in the 64-Kbyte memory map. Execution continues at the address of the called subroutine.

The actual sequence of operations that occur during execution of CALL is:

- The CPU reads the old PPAGE value into an internal temporary register, and writes the new instruction-supplied PPAGE value to PPAGE. This switches the destination page into the program overlay window.
- The CPU calculates the address of the next instruction after the CALL instruction (the return address), and pushes this 16-bit value onto the stack.
- The old 8 -bit PPAGE value is pushed onto the stack.
- The effective address of the subroutine is calculated, the queue is refilled, and execution begins at the new address.

This sequence of operations is an uninterruptable CPU instruction. There is no need to inhibit interrupts during CALL execution. In addition, a CALL can be performed from any address in memory to any other address. This is a big improvement over other bank-switching schemes, where the page switch operation can only be performed by a program outside the overlay window.

For all practical purposes, the PPAGE value supplied by the instruction can be considered to be part of the effective address. For all addressing mode variations except indexed indirect modes, the new page value is provided by an immediate operand in the instruction. For indexed indirect variations of CALL, a pointer specifies memory locations where the new page value and the address of the called subroutine are stored. Use of indirect addressing for both the new page value and the address within the page allows use run-time calculated values rather than immediate values that must be known at the time of assembly.

The RTC instruction is used to terminate subroutines invoked by a CALL instruction. RTC unstacks the PPAGE value and the return address, the queue is refilled, and execution resumes with the next instruction after the corresponding CALL.

The actual sequence of operations that occur during execution of RTC is:

- The return value of the 8-bit PPAGE register is pulled from the stack.
- The 16-bit return address is pulled from the stack and loaded into the PC.
- The return PPAGE value is written to the PPAGE register.
- The queue is refilled, and execution begins at the new address.

Since the return operation is implemented as a single uninterruptable CPU instruction, the RTC can be executed from anywhere in memory, including from a different page of extended memory in the overlay window.

In an MCU where there is no memory expansion, the CALL and RTC instructions still perform the same sequence of operations, but there is no PPAGE register or address translation logic. The value the CPU reads when the PPAGE register is accessed is indeterminate but doesn't matter, because the value is not involved in addressing memory in the unpaged 64-Kbyte memory map. When the CPU writes to the non-existent PPAGE register, nothing happens.

The CALL and RTC instructions behave like JSR and RTS, except they have slightly longer execution times. Since extra execution cycles are required, routinely substituting CALL/RTC for JSR/RTS is not recommended. JSR and RTS can be used to access subroutines that are located on the same memory page. However, if a subroutine can be called from other pages, it must be terminated with an RTC. In this case, since RTC unstacks the PPAGE value as well as the return address, all accesses to the subroutine, even those made from the same page, must use CALL instructions.

### 10.3 Address Lines for Expansion Memory

All M68HC12 family members have at least 16 address lines, ADDR[15:0]. Devices with memory expansion capability can have as many as six additional high-order external address lines, ADDR[21:16]. Each of these additional address lines is typically associated with a control bit that allows address expansion to be selectively enabled. When expansion is enabled, internal address translation circuitry multiplexes data from the page select registers onto the high order address lines when there is an access to an address in a corresponding expansion window.

Assume that a device has six expansion address lines and an 8-bit PPAGE register. The lines and the program expansion window have been enabled. The address $\$ 9000$ is within the 16 -Kbyte program overlay window. When there is an access to this address, the value in the PPAGE register is multiplexed onto external address lines ADDR[21:14]. The 14 low-order address lines select a location within the program overlay page. Up to 256 16-Kbyte pages (4 Mbytes) of memory can be accessed through the window. When there is an access to a location that is not within any enabled overlay window, ADDR[21:16] are driven to logic level one.

The address translation logic can produce the same address on the external address lines for two different internal addresses. For example, the 22-bit address \$3FFFFF could result from an internal access to \$FFFF in the 64-Kbyte memory map, or to the last location (\$BFFF) within page 255 (PPAGE = \$FF) of the program overlay window. Considering only the 22 external address lines, the last physical page of the program overlay appears to occupy the same address space as the unpaged 16-Kbyte block from \$C000 to \$FFFF of the 64-Kbyte memory map. Using MCU chip-select circuits to enable external memory can resolve these ambiguities.

### 10.4 Overlay Window Controls

There is a page select register associated with each overlay window. PPAGE holds the page select for the program overlay, DPAGE holds the page select for the data overlay, and EPAGE holds the page select for the extra page. The CPU12 manipulates the PPAGE register directly, so it will always be eight bits or less in devices that
support program memory expansion. The DPAGE and EPAGE registers are not controlled by dedicated CPU12 instructions. These registers can be larger or smaller than eight bits in various M68HC12 derivatives.

Typically, each of the overlay windows also has an associated control bit to enable memory expansion through the appropriate window. Memory expansion is generally disabled out of reset, so control bits must be written to enable the address translation logic.

### 10.5 Using Chip-Select Circuits

M68HC12 chip-select circuits can be used to preclude ambiguities in memory-mapping due to the operation of internal address translation logic. If built-in chip selects are not used, take care to use only overlay pages which produce unique addresses on the external address lines.

M68HC12 derivatives typically have two or more chip-select circuits. Chip-select function is conceptually simple. Whenever an access to a pre-defined range of addresses is made, internal MCU circuitry detects an address match and asserts a control signal that can be used to enable external devices. Chip-select circuits typically incorporate a number of options that make it possible to use more than one range of addresses for matches as well as to enable various types and configurations of external devices.

Chip-select circuits used in conjunction with the memory-expansion scheme must be able to match all accesses made to addresses within the appropriate program overlay window. In the case of the program expansion window, the range of addresses occupies the 16 -Kbyte space from $\$ 8000$ to $\$$ BFFF. For data and extra expansion windows, the range of addresses varies from device to device. The following paragraphs discuss a typical implementation of memory expansion chip-select functions in the system integration module. Implementation will vary from device to device within the M68HC12 family. Please refer to the appropriate device manual for details.

### 10.5.1 Program Memory Expansion Chip-Select Controls

There are two program memory expansion chip-select circuits, CSP0 and CSP1. The associated control register contains eight control bits that provide for a number of system configurations.

### 10.5.1.1 CSP1E Control Bit

Enables (1) or disables (0) the CSP1 chip select. The default is disabled.

### 10.5.1.2 CSPOE Control Bit

Enables (1) or disables (0) the CSP0 chip select. The default is enabled. This allows CSP0 to be used to select an external memory that includes the reset vector and startup initialization programs.

### 10.5.1.3 CSP1FL Control Bit

Configures CSP1 to occupy all of the 64-Kbyte memory map that is not used by a high-er-priority resource. If CSP1FL $=0, C S P 1$ is mapped to the area from $\$ 8000$ to $\$ F F F F$. CSP1 has the lowest access priority except for external memory space that is not associated with any chip select.

### 10.5.1.4 CSPA21 Control Bit

Logic one causes CSP0 and CSP1 to be controlled by the ADDR21 signal. CSP1 is active when ADDR21 $=0$, and CSP0 is active when ADDR21 $=1$. When CSPA21 is one, the CSP1FL bit is ignored and both CSP0 and CSP1 are active in the region \$8000-\$FFFF. When CSPA21 is zero, CSP0 and CSP1 operate independently from the value of the ADDR21 signal.

### 10.5.1.5 STRPOA:STRPOB Control Field

These two bits program an extra delay into accesses to the CSP0 area of memory. The choices are $0,1,2$, or 3 E-cycles in addition to the normal one cycle for unstretched accesses. This allows use of slow external memory without slowing down the entire system.

### 10.5.1.6 STRP1A:STRP1B Control Field

These two bits program an extra delay into accesses to the CSP1 area of memory. The choices are 0, 1, 2, or 3 E-cycles in addition to the normal one cycle for unstretched accesses. This allows use of slow external memory without slowing down the entire system.

When enabled, CSP0 is active for the memory space from $\$ 8000$ through \$FFFF. This includes the program overlay space (\$8000-\$BFFF) and the unpaged 16-Kbyte block from \$C000 through \$FFFF. This configuration can be used if there is a single program memory device (up to four Mbytes) in the system.

If CSP1 is also enabled and the CSPA21 bit is set, CSP1 can be used to select the first 128 16-Kbyte pages (two Mbytes) in the program overlay expansion memory space while CSPO selects the higher numbered program expansion pages and the unpaged block from \$C000 through \$FFFF. Recall that the external memory device cannot distinguish between an access to the \$C000 to \$FFFF space and an access to $\$ 8000-\$ B F F F$ in the 255 th page (PPAGE $=\$ F F$ ) of the program overlay window.

### 10.5.2 Data Expansion Chip Select Controls

The data chip select (CSD) has four associated control bits.

### 10.5.2.1 CSDE Control Bit

Enables (1) or disables (0) the CSD chip select. The default is disabled.

### 10.5.2.2 CSDHF Control Bit

Configures CSD to occupy the lower half of the 64-Kbyte memory map (for areas that are not used by a higher priority resource). If CSDHF is zero, CSD occupies the range of addresses used by the data expansion window.

### 10.5.2.3 STRDA:STRDB Control Field

These two bits program an extra delay into accesses to the CSD area of memory. The choices are $0,1,2$, or 3 additional E -cycles in addition to the normal one cycle for unstretched accesses. This allows use of slow external memory without slowing down the entire system.

### 10.5.3 Extra Expansion Chip Select Controls

The extra chip select (CSE) has four associated control bits.

### 10.5.3.1 CSEE Control Bit

Enables (1) or disables (0) the CSE chip select. The default is disabled.

### 10.5.3.2 CSEEP Control Bit

Logic one configures CSE to be active for the EPAGE area. A logic zero causes CSE to be active for the CS3 area of the internal register space, which can typically be remapped to any 2-Kbyte boundary.

### 10.5.3.3 STREA:STREB Control Field

These two bits program an extra delay into accesses to the CSE area of memory. The choices are 0, 1, 2, or 3 E-cycles in addition to the normal one cycle for unstretched accesses. This allows use of slow external memory without slowing down the entire system.

To use CSE with the extra overlay window, it must be enabled (CSEE = 1) and configured to follow the extra page (CSEEP = 1).

### 10.6 System Notes

The expansion overlay windows are specialized for specific application uses, but there are no restrictions on the use of these memory spaces. Motorola MCUs have a mem-ory-mapped architecture in which all memory resources are treated equally. Although it is possible to execute programs in paged external memory in the data and extra overlay areas, it is less convenient than using the program overlay area.

The CALL and RTC instructions automate the program page switching functions in an uninterruptable instruction. For the data and extra overlay windows, the user must take care not to let interrupts corrupt the page switching sequence or change the active page while executing out of another page in the same overlay area.

Internal MCU chip-select circuits have access to all 16 internal CPU address lines and the overlay window select lines. This allows all 256 expansion pages in an overlay window to be distinguished from unpaged memory locations with 22-bit addresses that are the same as addresses in overlay pages.

## APPENDIX A INSTRUCTION REFERENCE

## A. 1 Instruction Set Summary

Table A-1 is a quick reference to the CPU12 instruction set. The table shows source form, describes the operation performed, lists the addressing modes used, gives machine encoding in hexadecimal form, and describes the effect of execution on the condition code bits.

## A. 2 Opcode Map

Table A-2 displays the mnemonic, opcode, addressing mode, and cycle count for each instruction. The first table represents those opcodes with no prebyte. The second page of the table represents those opcodes with a prebyte value of $\$ 18$. Notice the first hexadecimal digit of the opcode (shown in the upper left corner of each cell) corresponds to column location, while the second hexadecimal digit of the opcode corresponds to row location.

## A. 3 Indexed Addressing Postbyte Encoding

Table A-5 shows postbyte encoding for indexed addressing modes. The mnemonic for the indexed addressing mode postbyte is xb . This is also the notation used in instruction glossary entries. Table A-3 presents the same information in two-digit hexadecimal format. The first digit of the postbyte is represented by the value of the columns in the table. The second digit of the postbyte is represented by the value of the row.

## A. 4 Transfer and Exchange Postbyte Encoding

Table A-4 shows postbyte encoding for transfer and exchange instructions. The mnemonic for the transfer and exchange postbyte is eb. This is also the notation used in instruction glossary entries. The first digit of the instruction postbyte is related to the columns of the table. The second digit of the postbyte is related to the rows. The body of the table shows actions caused by the postbyte.

## A. 5 Loop Primitive Postbyte Encoding

Table A-6 shows postbyte encoding for loop primitive instructions. The mnemonic for the loop primitive postbyte is lb . This is also the notation used in instruction glossary entries. The loop primitive instructions are DBEQ, DBNE, IBEQ, IBNE, TBEQ, and TBNE. The first digit of the instruction postbyte corresponds to the columns of the table. The second digit of the postbyte corresponds to the rows. The body of the table shows actions caused by the postbyte.

Table A-1 Instruction Set Summary

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ABA | $(\mathrm{A})+(\mathrm{B}) \Rightarrow \mathrm{A}$ <br> Add Accumulators $A$ and $B$ | INH | 1806 | 2 | - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ABX | $(B)+(X) \Rightarrow X$ <br> Translates to LEAX B,X | IDX | 1A E5 | 2 | - | - | - | - | - | - | - | - |
| ABY | $(\mathrm{B})+(\mathrm{Y}) \Rightarrow \mathrm{Y}$ <br> Translates to LEAY B,Y | IDX | 19 ED | 2 | - | - | - | - | - | - | - | - |
| ADCA opr | $(\mathrm{A})+(\mathrm{M})+\mathrm{C} \Rightarrow \mathrm{~A}$ <br> Add with Carry to A | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 89 ii <br> 99 dd <br> B9 hh II <br> A9 xb <br> A9 xb ff <br> A9 xb ee ff <br> A9 xb <br> A9 xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ADCB opr | $(B)+(M)+C \Rightarrow B$ <br> Add with Carry to B | $\begin{gathered} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \hline \end{gathered}$ | C9 ii <br> D9 dd <br> F9 hh II <br> E9 xb <br> E9 xb ff <br> E9 xb ee ff <br> E9 xb <br> E9 xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ADDA opr | $(\mathrm{A})+(\mathrm{M}) \Rightarrow \mathrm{A}$ <br> Add without Carry to A | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 8B ii <br> 9B dd <br> BB hh II <br> AB xb <br> $A B \times b$ ff <br> $A B \times b$ eeff <br> $A B \times b$ <br> $A B \times b$ ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & \hline \end{aligned}$ | - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ADDB opr | $(B)+(M) \Rightarrow B$ <br> Add without Carry to B | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | CB ii <br> DB dd <br> FB hh II <br> EB xb <br> EB xb ff <br> EB xb ee ff <br> EB xb <br> EB xb eeff | $\begin{aligned} & \hline 1 \\ & \hline 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & \hline \end{aligned}$ | - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ADDD opr | $(A: B)+(M: M+1) \Rightarrow A: B$ <br> Add 16-Bit to D (A:B) | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | C3 jj kk <br> D3 dd <br> F3 hh II <br> E3 xb <br> E3 xb ff <br> E3 xb ee ff <br> E3 xb <br> E3 xb ee ff | $\begin{aligned} & \hline 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ANDA opr | $(A) \cdot(M) \Rightarrow A$ <br> Logical And A with Memory | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 84 ii <br> 94 dd <br> B4 hh II <br> A4 xb <br> A4 xb ff <br> A4 xb ee ff <br> A4 xb <br> A4 xb ee ff | $\begin{aligned} & 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| ANDB opr | $(\mathrm{B}) \bullet(\mathrm{M}) \Rightarrow \mathrm{B}$ <br> Logical And B with Memory | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | C4 ii <br> D4 dd <br> F4 hh II <br> E4 xb <br> E4 xb ff <br> E4 xb ee ff <br> E4 xb <br> E4 xb ee ff | $\begin{aligned} & 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - |  | $\Delta$ | $\Delta$ | 0 | - |
| ANDCC opr | $(\mathrm{CCR}) \cdot(\mathrm{M}) \Rightarrow \mathrm{CCR}$ <br> Logical And CCR with Memory | IMM | 10 ii | 1 | $\Downarrow$ | $\Downarrow$ | $\Downarrow$ | $\Downarrow$ | $\Downarrow$ | $\Downarrow$ | $\Downarrow$ | $\Downarrow$ |
| ASL opr <br> ASLA <br> ASLB | Arithmetic Shift Left <br> Arithmetic Shift Left Accumulator A Arithmetic Shift Left Accumulator B | $\begin{gathered} \hline \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \text { INH } \\ \text { INH } \end{gathered}$ | 78 hh II 68 xb 68 xb ff 68 xb ee ff 68 xb 68 xb ee ff 48 58 | $\begin{aligned} & \hline 4 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 6 \\ & 1 \\ & 1 \end{aligned}$ | - | - | - |  | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ASLD | Arithmetic Shift Left Double | INH | 59 | 1 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ASR opr <br> ASRA ASRB | Arithmetic Shift Right <br> Arithmetic Shift Right Accumulator A Arithmetic Shift Right Accumulator B | $\begin{gathered} \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \text { INH } \\ \text { INH } \end{gathered}$ | 77 hh II <br> 67 xb <br> 67 xb ff <br> 67 xb ee ff <br> 67 xb <br> 67 xb ee ff <br> 47 <br> 57 | $\begin{aligned} & \hline 4 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 6 \\ & 1 \\ & 1 \end{aligned}$ | - | - | - |  | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| BCC rel | Branch if Carry Clear (if $\mathrm{C}=0$ ) | REL | 24 rr | 3/1 | - | - | - | - | - | - | - | - |
| BCLR opr, msk | $\begin{aligned} & (\mathrm{M}) \bullet(\overline{\mathrm{mm}}) \Rightarrow M \\ & \text { Clear Bit(s) in Memory } \end{aligned}$ | $\begin{aligned} & \hline \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \end{aligned}$ | 4D dd mm 1D hh II mm OD xb mm OD xb ff mm OD xb ee ff mm | $\begin{aligned} & 4 \\ & 4 \\ & 4 \\ & 4 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| BCS rel | Branch if Carry Set (if C = 1) | REL | 25 rr | 3/1 | - | - | - | - | - | - | - | - |
| BEQ rel | Branch if Equal (if $\mathrm{Z}=1$ ) | REL | 27 rr | 3/1 | - | - | - | - | - | - | - | - |
| BGE rel | Branch if Greater Than or Equal (if $\mathrm{N} \oplus \mathrm{V}=0$ ) (signed) | REL | 2C rr | 3/1 | - | - | - | - | - | - | - | - |
| BGND | Place CPU in Background Mode see Background Mode section. | INH | 00 | 5 | - | - | - | - | - | - | - | - |
| BGT rel | Branch if Greater Than (if $Z+(N \oplus V)=0$ ) (signed) | REL | 2E rr | 3/1 | - | - | - | - | - | - | - | - |
| BHI rel | Branch if Higher (if $C+Z=0$ ) (unsigned) | REL | 22 rr | 3/1 | - | - | - | - | - | - | - | - |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BHS rel | Branch if Higher or Same (if $\mathrm{C}=0$ ) (unsigned) same function as BCC | REL | 24 rr | 3/1 | - | - | - | - | - | - | - | - |
| BITA opr | (A) • (M) Logical And A with Memory | $\begin{gathered} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ {[D, \text { IDX] }} \\ {[\text { IDX2] }} \end{gathered}$ | 85 ii <br> 95 dd <br> B5 hh II <br> A5 xb <br> A5 xb ff <br> A5 xb ee ff <br> A5 xb <br> A5 xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| BITB opr | (B) • (M) Logical And B with Memory | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | C5 ii <br> D5 dd <br> F5 hh II <br> E5 xb <br> E5 xb ff <br> E5 xb ee ff <br> E5 xb <br> E5 xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - |  | - | $\Delta$ | $\Delta$ | 0 | - |
| BLE rel | Branch if Less Than or Equal (if $Z+(N \oplus V)=1$ ) (signed) | REL | 2F rr | 3/1 | - | - | - | - | - | - | - | - |
| BLO rel | Branch if Lower (if $\mathrm{C}=1$ ) (unsigned) same function as BCS | REL | 25 rr | 3/1 | - | - | - | - | - | - | - | - |
| BLS rel | Branch if Lower or Same (if $C+Z=1$ ) (unsigned) | REL | 23 rr | 3/1 | - | - | - | - | - | - | - | - |
| BLT rel | Branch if Less Than (if $\mathrm{N} \oplus \mathrm{V}=1$ ) (signed) | REL | 2D rr | 3/1 | - | - | - | - | - | - | - | - |
| BMI rel | Branch if Minus (if $\mathrm{N}=1$ ) | REL | 2B rr | 3/1 | - | - | - | - | - | - | - | - |
| BNE rel | Branch if Not Equal (if $\mathrm{Z}=0$ ) | REL | 26 rr | 3/1 | - | - | - | - | - | - | - | - |
| BPL rel | Branch if Plus (if $\mathrm{N}=0$ ) | REL | 2 Arr | 3/1 | - | - | - | - | - | - | - | - |
| BRA rel | Branch Always (if $1=1$ ) | REL | 20 rr | 3 | - | - | - | - | - | - | - | - |
| BRCLR opr, msk, rel | Branch if $(\mathrm{M}) \bullet(\mathrm{mm})=0$ (if All Selected Bit(s) Clear) | $\begin{aligned} & \hline \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \end{aligned}$ | 4F dd mm rr 1F hh II mm rr OF xb mm rr 0 F xb ff mm rr OF xb ee ff mm rr | $\begin{aligned} & \hline 4 \\ & 5 \\ & 4 \\ & 6 \\ & 8 \end{aligned}$ | - | - | - | - | - | - | - | - |
| BRN rel | Branch Never (if $1=0$ ) | REL | 21 rr | 1 | - | - | - | - | - | - | - | - |
| BRSET opr, msk, rel | Branch if $(\overline{\mathrm{M}}) \cdot(\mathrm{mm})=0$ (if All Selected Bit(s) Set) | $\begin{aligned} & \hline \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \end{aligned}$ | 4E dd mm rr 1E hh II mm rr OE xb mm rr OE xb ff mm rr OE xb ee ff mm rr | $\begin{aligned} & \hline 4 \\ & 5 \\ & 4 \\ & 6 \\ & 8 \end{aligned}$ | - | - | - | - | - | - | - | - |
| BSET opr, msk | $(\mathrm{M})+(\mathrm{mm}) \Rightarrow \mathrm{M}$ <br> Set Bit(s) in Memory | $\begin{aligned} & \hline \text { DIR } \\ & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \hline \end{aligned}$ | 4C dd mm 1C hh II mm OC xb mm OC xb ff mm OC xb ee ff mm | $\begin{aligned} & \hline 4 \\ & 4 \\ & 4 \\ & 4 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| BSR rel | $\begin{aligned} & (\mathrm{SP})-2 \Rightarrow \mathrm{SP} ; \\ & \text { RTN }_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{(\mathrm{SP}): M_{(S P+1)}} \\ & \text { Subroutine address } \Rightarrow \mathrm{PC} \\ & \text { Branch to Subroutine } \end{aligned}$ | REL | 07 rr | 4 | - | - | - | - | - | - | - | - |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BVC rel | Branch if Overflow Bit Clear (if $\mathrm{V}=0$ ) | REL | 28 rr | 3/1 | - | - | - | - | - | - | - | - |
| BVS rel | Branch if Overflow Bit Set (if V = 1) | REL | 29 rr | 3/1 | - | - | - | - | - | - | - | - |
| CALL opr, page | $\begin{aligned} & \text { (SP) - } 2 \Rightarrow \text { SP; } \\ & \text { RTN }_{H}: \text { RTN }_{L} \Rightarrow M_{(S P):} M_{(S P+1)} \\ & (\mathrm{SP})-1 \Rightarrow \text { SP; } \\ & (\mathrm{PPG}) \Rightarrow \mathrm{M}_{(S P) ;} ; \\ & \text { pg } \Rightarrow \text { PPAGE register; } \\ & \text { Program address } \Rightarrow \mathrm{PC} \end{aligned}$ <br> Call subroutine in extended memory (Program may be located on another expansion memory page.) | $\begin{aligned} & \hline \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \end{aligned}$ | 4A hh II pg 4B xb pg 4B xb ff pg $4 B \times b$ ee ff $p g$ | $\begin{aligned} & \hline 8 \\ & 8 \\ & 8 \\ & 9 \end{aligned}$ | - | - | - | - | - | - | - | - |
| CALL [D,r] CALL [opr,r] | Indirect modes get program address and new pg value based on pointer. $r=\mathrm{X}, \mathrm{Y}, \mathrm{SP}, \text { or } \mathrm{PC}$ | $\begin{gathered} \hline[\mathrm{D}, \mathrm{IDX}] \\ {[\mathrm{IDX} 2]} \end{gathered}$ | $\begin{aligned} & 4 \mathrm{~B} \times \mathrm{b} \\ & 4 \mathrm{~B} \times \mathrm{b} \text { ee ff } \end{aligned}$ | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | - | - |  | - | - | - | - | - |
| CBA | $(\mathrm{A})-(\mathrm{B})$ <br> Compare 8-Bit Accumulators | INH | 1817 | 2 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CLC | $0 \Rightarrow C$ <br> Translates to ANDCC \#\$FE | IMM | 10 FE | 1 | - | - | - | - | - | - | - | 0 |
| CLI | $\begin{array}{\|l\|} \hline 0 \Rightarrow \mathrm{I} \\ \text { Translates to ANDCC \#\$EF } \\ \text { (enables I-bit interrupts) } \\ \hline \end{array}$ | IMM | 10 EF | 1 | - | - | - | 0 | - | - | - | - |
| CLR opr <br> CLRA <br> CLRB | $0 \Rightarrow \mathrm{M}$ Clear Memory Location <br>   <br>   <br> $0 \Rightarrow \mathrm{~A}$ Clear Accumulator A <br> $0 \Rightarrow \mathrm{~B}$ Clear Accumulator B | $\begin{gathered} \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \text { INH } \\ \text { INH } \end{gathered}$ | 79 hh II 69 xb 69 xb ff 69 xb ee ff 69 xb 69 xb ee ff 87 C 7 | $\begin{aligned} & \hline 3 \\ & 2 \\ & 3 \\ & 3 \\ & 5 \\ & 5 \\ & 1 \\ & 1 \end{aligned}$ | - | - | - | - | 0 | 1 | 0 | 0 |
| CLV | $\begin{array}{\|l} \hline 0 \Rightarrow \mathrm{~V} \\ \text { Translates to ANDCC \#\$FD } \end{array}$ | IMM | 10 FD | 1 | - | - | - | - | - | - | 0 | - |
| CMPA opr | (A) - (M) <br> Compare Accumulator A with Memory | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 81 ii <br> 91 dd <br> B1 hh II <br> A1 xb <br> A1 xb ff <br> A1 xb ee ff <br> A1 xb <br> A1 xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CMPB opr | $\text { (B) }-(\mathrm{M})$ <br> Compare Accumulator B with Memory | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | C1 ii <br> D1 dd <br> F1 hh II <br> E1 xb <br> E1 xb ff <br> E1 xb ee ff <br> E1 xb <br> E1 xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| COM opr | $(\bar{M}) \Rightarrow M$ equivalent to $\$ F F-(M) \Rightarrow M$ 1's Complement Memory Location <br> $(\overline{\mathrm{A}}) \Rightarrow \mathrm{A} \quad$ Complement Accumulator A <br> $(\bar{B}) \Rightarrow B \quad$ Complement Accumulator $B$ | EXT IDX IDX1 IDX2 [D,IDX] [IDX2] INH INH | 71 hh II 61 xb 61 xb ff 61 xb ee ff 61 xb 61 xb ee ff 41 51 | $\begin{aligned} & \hline 4 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 6 \\ & 1 \\ & 1 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | 1 |
| CPD opr | $(A: B)-(M: M+1)$ <br> Compare D to Memory (16-Bit) | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 8C jj kk <br> 9C dd <br> BC hh II <br> AC xb <br> $A C x b$ ff <br> $A C x b$ ee ff <br> AC xb <br> $A C$ xb ee ff | $\begin{aligned} & \hline 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CPS opr | $(\mathrm{SP})-(\mathrm{M}: \mathrm{M}+1)$ <br> Compare SP to Memory (16-Bit) | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 8F jj kk <br> 9F dd <br> BF hh II <br> AF xb <br> AF xb ff <br> AF xb ee ff <br> AF xb <br> AF xb ee ff | $\begin{aligned} & \hline 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CPX opr | $\begin{aligned} & (\mathrm{X})-(\mathrm{M}: \mathrm{M}+1) \\ & \text { Compare } \mathrm{X} \text { to Memory (16-Bit) } \end{aligned}$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 8E jj kk 9E dd BE hh II AE xb AE xb ff AE xb ee ff AE xb AE xb ee ff | $\begin{aligned} & \hline 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CPY opr | $\begin{aligned} & (\mathrm{Y})-(\mathrm{M}: \mathrm{M}+1) \\ & \text { Compare } \mathrm{Y} \text { to Memory (16-Bit) } \end{aligned}$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 8D jj kk <br> 9D dd <br> BD hh II <br> AD xb <br> AD xb ff <br> $A D$ xb ee ff <br> AD xb <br> AD xb ee ff | $\begin{aligned} & 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| DAA | Adjust Sum to BCD Decimal Adjust Accumulator A | INH | 1807 | 3 | - | - | - | - | $\Delta$ | $\Delta$ | ? | $\Delta$ |
| DBEQ cntr, rel | $\begin{aligned} & \text { (cntr) }-1 \Rightarrow \text { cntr } \\ & \text { if (cntr) }=0 \text {, then Branch } \\ & \text { else Continue to next instruction } \\ & \\ & \text { Decrement Counter and Branch if = } 0 \\ & (\text { cntr }=A, B, D, X, Y, \text { or SP) } \end{aligned}$ | $\begin{aligned} & \text { REL } \\ & \text { (9-bit) } \end{aligned}$ | 04 lb rr | 3 | - | - | - | - | - | - | - | - |
| DBNE cntr, rel | (cntr) $-1 \Rightarrow \mathrm{cntr}$ If (cntr) not $=0$, then Branch; else Continue to next instruction <br> Decrement Counter and Branch if $\neq 0$ (cntr = A, B, D, X, Y, or SP) | $\begin{gathered} \text { REL } \\ \text { (9-bit) } \end{gathered}$ | 04 lb rr | 3 | - | - | - | - | - | - | - | - |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{\|c} \hline \text { DEC opr } \\ \\ \\ \\ \text { DECA } \\ \text { DECB } \end{array}$ | $(M)-\$ 01 \Rightarrow M$ <br> Decrement Memory Location <br> (A) $-\$ 01 \Rightarrow A$ <br> Decrement A <br> (B) $-\$ 01 \Rightarrow B$ <br> Decrement B | $\begin{gathered} \hline \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \text { INH } \\ \text { INH } \\ \hline \end{gathered}$ | 73 hh II 63 xb 63 xb ff 63 xb ee ff 63 xb 63 xb ee ff 43 53 | $\begin{aligned} & \hline 4 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 6 \\ & 1 \\ & 1 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | - |
| DES | $(\mathrm{SP})-\$ 0001 \Rightarrow \mathrm{SP}$ <br> Translates to LEAS -1,SP | IDX | 1B 9F | 2 | - | - | - | - | - | - | - | - |
| DEX | $(X)-\$ 0001 \Rightarrow X$ <br> Decrement Index Register $X$ | INH | 09 | 1 | - | - | - | - | - | $\Delta$ | - | - |
| DEY | (Y) - \$0001 $\Rightarrow \mathrm{Y}$ <br> Decrement Index Register $Y$ | INH | 03 | 1 | - | - | - | - | - | $\Delta$ | - | - |
| EDIV | $\begin{aligned} & (Y: D) \div(X) \Rightarrow Y \text { Remainder } \Rightarrow D \\ & 32 \times 16 \text { Bit } \Rightarrow 16 \text { Bit Divide (unsigned) } \end{aligned}$ | INH | 11 | 11 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EDIVS | $\begin{aligned} & (Y: D) \div(X) \Rightarrow Y \text { Remainder } \Rightarrow D \\ & 32 \times 16 \text { Bit } \Rightarrow 16 \text { Bit Divide (signed) } \end{aligned}$ | INH | 1814 | 12 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMACS sum | $\begin{aligned} & \left(\mathrm{M}_{(\mathrm{X})}: \mathrm{M}_{(\mathrm{X}+1)}\right) \times\left(\mathrm{M}_{(\mathrm{Y})}: \mathrm{M}_{(\mathrm{Y}+1)}\right)+(\mathrm{M} \sim \mathrm{M}+3) \Rightarrow \\ & \mathrm{M} \sim \mathrm{M}+3 \\ & 16 \times 16 \text { Bit } \Rightarrow 32 \text { Bit } \\ & 16 \times 1 \\ & \text { Multiply and Accumulate (signed) } \\ & \hline \end{aligned}$ | Special | 1812 hh II | 13 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMAXD opr | $\operatorname{MAX}((\mathrm{D}),(\mathrm{M}: M+1)) \Rightarrow \mathrm{D}$ <br> MAX of 2 Unsigned 16-Bit Values <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}$ and C status bits reflect result of internal compare ((D) - (M:M+1)) | $\begin{gathered} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ {[\mathrm{D}, \text { IDX] }]} \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | 181 A xb 181 A xb ff $181 \mathrm{~A} x \mathrm{~b}$ ee ff 181 A xb $181 \mathrm{~A} x \mathrm{xb}$ ee ff | $\begin{aligned} & 4 \\ & 4 \\ & 4 \\ & 5 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMAXM opr | $\operatorname{MAX}((\mathrm{D}),(\mathrm{M}: \mathrm{M}+1)) \Rightarrow \mathrm{M}: \mathrm{M}+1$ MAX of 2 Unsigned 16-Bit Values <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}$ and C status bits reflect result of internal compare ((D) - (M:M+1)) | $\begin{gathered} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | 181 Exb 181 Eb ff 181 Eb ee ff 181 Ebb 181 Exb ee ff | $\begin{aligned} & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMIND opr | $\operatorname{MIN}((\mathrm{D}),(\mathrm{M}: \mathrm{M}+1)) \Rightarrow \mathrm{D}$ <br> MIN of 2 Unsigned 16-Bit Values <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}$ and C status bits reflect result of internal compare ((D) - (M:M+1)) | $\begin{gathered} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | $181 B \times b$ $181 B \times b$ ff $181 B \times b$ ee ff $181 B \times b$ $181 B \times b$ ee ff | $\begin{aligned} & 4 \\ & 4 \\ & 4 \\ & 5 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMINM opr | $\operatorname{MIN}((\mathrm{D}),(\mathrm{M}: \mathrm{M}+1)) \Rightarrow \mathrm{M}: \mathrm{M}+1$ <br> MIN of 2 Unsigned 16-Bit Values <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}$ and C status bits reflect result of internal compare ((D) - (M:M+1)) | $\begin{gathered} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | $\begin{aligned} & 181 \mathrm{~F} x \mathrm{x} \\ & 181 \mathrm{Fb} \mathrm{ff} \\ & 181 \mathrm{~F} \text { xbee ff } \\ & 181 \mathrm{Fb} \\ & 181 \mathrm{~F} \mathrm{xb} \text { ee ff } \end{aligned}$ | $\begin{aligned} & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMUL | $\begin{aligned} & (\mathrm{D}) \times(\mathrm{Y}) \Rightarrow \mathrm{Y}: \mathrm{D} \\ & 16 \times 16 \text { Bit Multiply (unsigned) } \\ & \hline \end{aligned}$ | INH | 13 | 3 | - | - | - | - | $\Delta$ | $\Delta$ | - | $\Delta$ |
| EMULS | $\begin{aligned} & \hline(\mathrm{D}) \times(\mathrm{Y}) \Rightarrow \mathrm{Y}: \mathrm{D} \\ & 16 \times 16 \text { Bit Multiply (signed) } \end{aligned}$ | INH | 1813 | 3 | - | - | - | - | $\Delta$ | $\Delta$ | - | $\Delta$ |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EORA opr | $(A) \oplus(M) \Rightarrow A$ <br> Exclusive-OR A with Memory | $\begin{gathered} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | 88 ii <br> 98 dd <br> B8 hh II <br> A8 xb <br> A8 xb ff <br> A8 xb ee ff <br> A8 xb <br> A8 xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| EORB opr | $(B) \oplus(M) \Rightarrow B$ <br> Exclusive-OR B with Memory | IMM <br> DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | C8 ii <br> D8 dd <br> F8 hh II <br> E8 xb <br> E8 xb ff <br> E8 xb ee ff <br> E8 xb <br> E8 xb ee ff | $\begin{aligned} & 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| ETBL opr | $(\mathrm{M}: \mathrm{M}+1)+[(\mathrm{B}) \times((\mathrm{M}+2: \mathrm{M}+3)-(\mathrm{M}: M+1))] \Rightarrow \mathrm{D}$ <br> 16-Bit Table Lookup and Interpolate <br> Initialize B, and index before ETBL. <ea> points at first table entry ( $\mathrm{M}: \mathrm{M}+1$ ) and $B$ is fractional part of lookup value <br> (no indirect addr. modes allowed) | IDX | 18 3F xb | 10 | - | - | - | - | $\Delta$ | $\Delta$ | - | ? |
| EXG r1, r2 | ( r 1 ) $\Leftrightarrow$ ( r 2 ) (if r 1 and r 2 same size) or $\$ 00:(\mathrm{r} 1) \Rightarrow \mathrm{r} 2$ (if $\mathrm{r} 1=8$-bit; $\mathrm{r} 2=16$-bit) or $\left(\mathrm{r} 1_{\text {low }}\right) \Leftrightarrow(\mathrm{r} 2)$ (if $\mathrm{r} 1=16$-bit; $\mathrm{r} 2=8$-bit) <br> r1 and r2 may be <br> A, B, CCR, D, X, Y, or SP | INH | B7 eb | 1 | - | - | - | - | - | - | - | - |
| FDIV | $\begin{aligned} & (\mathrm{D}) \div(\mathrm{X}) \Rightarrow \mathrm{X} ; \mathrm{r} \Rightarrow \mathrm{D} \\ & 16 \times 16 \text { Bit Fractional Divide } \end{aligned}$ | INH | 1811 | 12 | - | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ |
| IBEQ cntr, rel | $\text { (cntr) }+1 \Rightarrow \mathrm{cntr}$ <br> If (cntr) $=0$, then Branch else Continue to next instruction <br> Increment Counter and Branch if $=0$ (cntr = A, B, D, X, Y, or SP) | $\begin{gathered} \text { REL } \\ \text { (9-bit) } \end{gathered}$ | 04 lb rr | 3 | - | - | - | - | - | - | - | - |
| IBNE cntr, rel | (cntr) $+1 \Rightarrow \mathrm{cntr}$ if (cntr) not $=0$, then Branch; else Continue to next instruction <br> Increment Counter and Branch if $\neq 0$ (cntr = A, B, D, X, Y, or SP) | $\begin{gathered} \text { REL } \\ (9 \text {-bit) } \end{gathered}$ | 04 lb rr | 3 | - | - | - | - | - | - | - | - |
| IDIV | $\begin{aligned} & \text { (D) } \div(X) \Rightarrow X ; r \Rightarrow D \\ & 16 \times 16 \text { Bit Integer Divide (unsigned) } \end{aligned}$ | INH | 1810 | 12 | - | - | - | - | - | $\Delta$ | 0 | $\Delta$ |
| IDIVS | $\begin{aligned} & \hline(\mathrm{D}) \div(\mathrm{X}) \Rightarrow \mathrm{X} ; \mathrm{r} \Rightarrow \mathrm{D} \\ & 16 \times 16 \text { Bit Integer Divide (signed) } \\ & \hline \end{aligned}$ | INH | 1815 | 12 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | $\sim^{*}$ | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| INC opr <br> INCA <br> INCB | $\begin{aligned} & (\mathrm{M})+\$ 01 \Rightarrow \mathrm{M} \\ & \text { Increment Memory Byte } \\ & \\ & \\ & \\ & \text { (A) }+\$ 01 \Rightarrow \mathrm{~A} \\ & \text { (B) }+\$ 01 \Rightarrow \mathrm{~B} \\ & \hline \end{aligned} \quad \text { Increment Acc. A }$ | $\begin{gathered} \hline \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \text { INH } \\ \text { INH } \\ \hline \end{gathered}$ | 72 hh Il 62 xb 62 xb ff 62 xb ee ff 62 xb 62 xb ee ff 42 52 | $\begin{aligned} & \hline 4 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 6 \\ & 6 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | - |
| INS | $(S P)+\$ 0001 \Rightarrow S P$ <br> Translates to LEAS 1,SP | IDX | 1B 81 | 2 | - | - | - | - | - | - | - | - |
| INX | $\begin{aligned} & (X)+\$ 0001 \Rightarrow X \\ & \text { Increment Index Register } X \end{aligned}$ | INH | 08 | 1 | - | - | - | - | - | $\Delta$ | - | - |
| INY | $(Y)+\$ 0001 \Rightarrow Y$ <br> Increment Index Register Y | INH | 02 | 1 | - | - | - | - | - | $\Delta$ | - | - |
| JMP opr | Subroutine address $\Rightarrow \mathrm{PC}$ Jump | $\begin{gathered} \hline \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \end{gathered}$ | 06 hh II 05 xb 05 xb ff 05 xb ee ff 05 xb 05 xb ee ff | $\begin{aligned} & \hline 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | - | - | - | - |
| JSR opr | $\begin{aligned} & \text { (SP) }-2 \Rightarrow \mathrm{SP} ; \\ & \text { RTN }_{\mathrm{H}}: \text { RTN } \\ & \text { Subroutine address } \Rightarrow \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)} ; \\ & \\ & \text { Jump to Subroutine } \end{aligned}$ | DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] <br> REL | 17 dd 16 hh II 15 xb 15 xb ff 15 xb ee ff 15 xb 15 xb ee ff | $\begin{aligned} & 4 \\ & 4 \\ & 4 \\ & 4 \\ & 4 \\ & 5 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | - | - | - | - |
| LBCC rel | Long Branch if Carry Clear (if $\mathrm{C}=0$ ) | REL | 1824 qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBCS rel | Long Branch if Carry Set (if C=1) | REL | 1825 qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBEQ rel | Long Branch if Equal (if $\mathrm{Z}=1$ ) | REL | 1827 qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBGE rel | Long Branch Greater Than or Equal (if $\mathrm{N} \oplus \mathrm{V}=0$ ) (signed) | REL | 18 2C qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBGT rel | Long Branch if Greater Than (if $Z+(N \oplus V)=0$ ) (signed) | REL | 18 2E qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBHI rel | Long Branch if Higher (if $C+Z=0$ ) (unsigned) | REL | 1822 qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBHS rel | Long Branch if Higher or Same (if $\mathrm{C}=0$ ) (unsigned) <br> same function as LBCC | REL | 1824 qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBLE rel | Long Branch if Less Than or Equal (if $Z+(N \oplus V)=1$ ) (signed) | REL | 182 Fqq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBLO rel | Long Branch if Lower (if $C=1$ ) (unsigned) same function as LBCS | REL | 1825 qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBLS rel | Long Branch if Lower or Same (if $C+Z=1$ ) (unsigned) | REL | 1823 qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBLT rel | Long Branch if Less Than (if $\mathrm{N} \oplus \mathrm{V}=1$ ) (signed) | REL | 18 2D qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBMI rel | Long Branch if Minus (if $\mathrm{N}=1$ ) | REL | 18 2B qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBNE rel | Long Branch if Not Equal (if $\mathrm{Z}=0$ ) | REL | 1826 qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBPL rel | Long Branch if Plus (if $\mathrm{N}=0$ ) | REL | 18 2A qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBRA rel | Long Branch Always (if $1=1$ ) | REL | 1820 qq rr | 4 | - | - | - | - | - | - | - | - |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LBRN $r e l$ | Long Branch Never (if $1=0$ ) | REL | 1821 qq rr | 3 | - | - | - | - | - | - | - | - |
| LBVC rel | Long Branch if Overflow Bit Clear (if $\mathrm{V}=0$ ) | REL | 1828 qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBVS rel | Long Branch if Overflow Bit Set (if V = 1) | REL | 1829 qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LDAA opr | $(M) \Rightarrow A$ <br> Load Accumulator A | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 86 ii <br> 96 dd <br> B6 hh II <br> A6 xb <br> A6 xb ff <br> A6 xb ee ff <br> A6 xb <br> A6 xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| LDAB opr | $(\mathrm{M}) \Rightarrow \mathrm{B}$ <br> Load Accumulator B | $\begin{gathered} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | C6 ii <br> D6 dd <br> F6 hh II <br> E6 xb <br> E6 xb ff <br> E6 xb ee ff <br> E6 xb <br> E6 xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| LDD opr | $(M: M+1) \Rightarrow A: B$ <br> Load Double Accumulator D (A:B) | $\begin{gathered} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \end{gathered}$ | CC jj kk <br> DC dd <br> FC hh II <br> EC xb <br> EC xb ff <br> EC xb ee ff <br> EC xb <br> EC xb ee ff | $\begin{aligned} & \hline 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| LDS opr | $\begin{aligned} & (\mathrm{M}: \mathrm{M}+1) \Rightarrow \mathrm{SP} \\ & \text { Load Stack Pointer } \end{aligned}$ | IMM <br> DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | CF jj kk <br> DF dd <br> FF hh II <br> EF xb <br> EF xb ff <br> EF xb ee ff <br> EF xb <br> EF xb ee ff | $\begin{aligned} & \hline 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| LDX opr | $\begin{aligned} & (\mathrm{M}: \mathrm{M}+1) \Rightarrow \mathrm{X} \\ & \text { Load Index Register } \mathrm{X} \end{aligned}$ | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | CE jj kk <br> DE dd <br> FE hh II <br> EE xb <br> EE xb ff <br> EE xb ee ff <br> EE xb <br> EE xb ee ff | $\begin{aligned} & \hline 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| LDY opr | $(\mathrm{M}: \mathrm{M}+1) \Rightarrow \mathrm{Y}$ <br> Load Index Register Y | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | CD jj kk <br> DD dd <br> FD hh II <br> ED xb <br> ED xb ff <br> ED xb ee ff <br> ED xb <br> ED xb ee ff | $\begin{aligned} & \hline 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| LEAS opr | Effective Address $\Rightarrow$ SP <br> Load Effective Address into SP | $\begin{aligned} & \hline \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \hline \end{aligned}$ | $\begin{aligned} & 1 \mathrm{~B} \times \mathrm{b} \\ & 1 \mathrm{~B} \times \mathrm{ff} \\ & 1 \mathrm{~B} \times \mathrm{b} \text { ee ff } \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & \hline \end{aligned}$ | - | - | - | - | - | - | - | - |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LEAX opr | Effective Address $\Rightarrow X$ Load Effective Address into $X$ | $\begin{aligned} & \hline \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \end{aligned}$ | $\begin{aligned} & 1 \mathrm{~A} \times \mathrm{b} \\ & 1 \mathrm{~A} \times \mathrm{bff} \\ & 1 \mathrm{~A} \times \mathrm{b} \text { ee ff } \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | - | - | - | - | - | - | - | - |
| LEAY opr | Effective Address $\Rightarrow \mathrm{Y}$ <br> Load Effective Address into $Y$ | $\begin{aligned} & \hline \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \end{aligned}$ | $\begin{aligned} & 19 \mathrm{xb} \\ & 19 \mathrm{xb} \mathrm{ff} \\ & 19 \mathrm{xb} \text { ee ff } \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | - | - | - | - | - | - | - | - |
| $\begin{array}{\|l\|} \hline \text { LSL opr } \\ \\ \\ \\ \hline \end{array}$ | Logical Shift Left same function as ASL <br> Logical Shift Accumulator A to Left Logical Shift Accumulator B to Left | EXT IDX IDX1 IDX2 [D,IDX] [IDX2] INH INH | 78 hh II 68 xb 68 xb ff 68 xb ee ff 68 xb 68 xb ee ff 48 58 | $\begin{aligned} & \hline 4 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 6 \\ & 1 \\ & 1 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| LSLD | Logical Shift Left D Accumulator same function as ASLD | INH | 59 | 1 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| $\begin{array}{\|l\|} \hline \text { LSR opr } \\ \\ \\ \\ \\ \text { LSRA } \\ \text { LSRB } \end{array}$ | Logical Shift Accumulator A to Right Logical Shift Accumulator B to Right | EXT IDX IDX1 IDX2 [D,IDX] [IDX2] INH INH | 74 hh II 64 xb $64 \mathrm{xb} f \mathrm{ff}$ 64 xb ee ff 64 xb 64 xb ee ff 44 54 | $\begin{aligned} & 4 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 6 \\ & 1 \\ & 1 \end{aligned}$ | - | - | - | - | 0 | $\Delta$ | $\Delta$ | $\Delta$ |
| LSRD | Logical Shift Right D Accumulator | INH | 49 | 1 | - | - | - | - | 0 | $\Delta$ | $\Delta$ | $\Delta$ |
| MAXA | $\operatorname{MAX}((A),(M)) \Rightarrow A$ <br> MAX of 2 Unsigned 8-Bit Values <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}$ and C status bits reflect result of internal compare ((A) - (M)). | IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | 1818 xb 1818 xb ff 1818 xb ee ff 1818 xb 1818 xb ee ff | $\begin{aligned} & \hline 4 \\ & 4 \\ & 5 \\ & 7 \\ & 7 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| MAXM | $\operatorname{MAX}((A),(M)) \Rightarrow M$ <br> MAX of 2 Unsigned 8-Bit Values <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}$ and C status bits reflect result of internal compare ((A) - (M)). | $\begin{gathered} \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \hline \end{gathered}$ | $181 \mathrm{C} x \mathrm{~b}$ 181 Cb ff 181 Cb ee ff $181 \mathrm{C} x \mathrm{~b}$ 181 Cb ee ff | $\begin{aligned} & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| MEM | $\mu$ (grade) $\Rightarrow \mathrm{M}_{(\mathrm{Y})}$; <br> $(X)+4 \Rightarrow X ;(Y)+1 \Rightarrow Y ; A$ unchanged $\begin{aligned} & \text { if }(A)<\text { P1 or }(A)>\text { P2 then } \mu=0 \text {, else } \\ & \mu=\operatorname{MIN}[((A)-P 1) \times S 1,(P 2-(A)) \times \text { S2, \$FF] } \end{aligned}$ <br> where: <br> A = current crisp input value; <br> X points at 4-byte data structure that describes a trapezoidal membership function (P1, P2, S1, S2); <br> Y points at fuzzy input (RAM location). <br> See instruction details for special cases. | Special | 01 | 5 | - | - | ? | - | ? | ? | ? | $?$ |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MINA | $\operatorname{MIN}((A),(M)) \Rightarrow A$ <br> MIN of Two Unsigned 8-Bit Values <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}$ and C status bits reflect result of internal compare ((A) - (M)). | $\begin{gathered} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \hline \end{gathered}$ | 1819 xb 1819 xb ff 1819 xb ee ff 1819 xb 1819 xb ee ff | $\begin{aligned} & 4 \\ & 4 \\ & 4 \\ & 5 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| MINM | $\operatorname{MIN}((\mathrm{A}),(\mathrm{M})) \Rightarrow \mathrm{M}$ <br> MIN of Two Unsigned 8-Bit Values <br> $\mathrm{N}, \mathrm{Z}, \mathrm{V}$ and C status bits reflect result of internal compare ((A) - (M)). | $\begin{gathered} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | 181 D xb 181 xb ff 181 db ee ff 181 db 181 db ee ff | $\begin{aligned} & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| MOVB opr1, opr2 | $\left(M_{1}\right) \Rightarrow M_{2}$ <br> Memory to Memory Byte-Move (8-Bit) | $\begin{aligned} & \text { IMM-EXT } \\ & \text { IMM-IDX } \\ & \text { EXT-EXT } \\ & \text { EXT-IDX } \\ & \text { IDX-EXT } \\ & \text { ID-IDX } \end{aligned}$ | 180 Bii hh II 1808 xb ii 180 Chh II hh II 1809 xb hh II 180 xb hh II 180 Ab xb | $\begin{aligned} & \hline 4 \\ & 4 \\ & 6 \\ & 5 \\ & 5 \\ & 5 \end{aligned}$ | - | - | - | - | - | - | - | - |
| MOVW opr1, opr2 | $\left(\mathrm{M}: \mathrm{M}+1_{1}\right) \Rightarrow \mathrm{M}: \mathrm{M}+1_{2}$ <br> Memory to Memory Word-Move (16-Bit) | $\begin{aligned} & \text { IMM-EXT } \\ & \text { IMM-IDX } \\ & \text { EXT-EXT } \\ & \text { EXT-IDX } \\ & \text { IDX-EXT } \\ & \text { IDX-IDX } \end{aligned}$ | 1803 jj kk hh II 1800 xb jj kk 1804 hh II hh II 1801 xb hh II 1805 xb hh II 1802 xb xb | $\begin{aligned} & 5 \\ & 4 \\ & 6 \\ & 5 \\ & 5 \\ & 5 \end{aligned}$ | - | - | - | - | - | - | - | - |
| MUL | $(A) \times(B) \Rightarrow A: B$ <br> $8 \times 8$ Unsigned Multiply | INH | 12 | 3 | - | - | - | - | - | - | - | $\Delta$ |
| NEG opr <br> NEGA <br> NEGB | $0-(\mathrm{M}) \Rightarrow \mathrm{M} \text { or }(\overline{\mathrm{M}})+1 \Rightarrow \mathrm{M}$ <br> Two's Complement Negate $0-(A) \Rightarrow A \text { equivalent to }(\bar{A})+1 \Rightarrow B$ <br> Negate Accumulator A $0-(B) \Rightarrow B$ equivalent to $(\bar{B})+1 \Rightarrow B$ Negate Accumulator B | $\begin{gathered} \hline \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \text { INH } \\ \\ \text { INH } \end{gathered}$ | 70 hh II 60 xb 60 xb ff 60 xb ee ff 60 xb 60 xb ee ff 40 50 | $\begin{aligned} & 4 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 6 \\ & 1 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| NOP | No Operation | INH | A7 | 1 | - | - | - | - | - | - | - | - |
| ORAA opr | $(A)+(M) \Rightarrow A$ <br> Logical OR A with Memory | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 8 A ii <br> 9A dd <br> BA hh II <br> AA xb <br> $A A x b$ ff <br> $A A x b$ ee $f f$ <br> AA xb <br> $A A$ xb ee ff | $\begin{aligned} & 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| ORAB opr | $(B)+(M) \Rightarrow B$ <br> Logical OR B with Memory | $\begin{gathered} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | CA ii <br> DA dd <br> FA hh II <br> EA xb <br> EA xb ff <br> EA xb ee ff <br> EA xb <br> EA xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| ORCC opr | $\begin{array}{\|l\|} \hline(C C R)+M \Rightarrow C C R \\ \text { Logical OR CCR with Memory } \\ \hline \end{array}$ | IMM | 14 ii | 1 | $\Uparrow$ | - | $\Uparrow$ | $\Uparrow$ | $\Uparrow$ | $\Uparrow$ | $\Uparrow$ | $\Uparrow$ |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | $\begin{aligned} & \text { Machine } \\ & \text { Coding (hex) } \end{aligned}$ | ~* | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| PSHA | $(S P)-1 \Rightarrow S P ;(A) \Rightarrow M_{(S P)}$ <br> Push Accumulator A onto Stack | INH | 36 | 2 | - | - | - | - | - | - | - | - |
| PSHB | $(S P)-1 \Rightarrow S P ;(B) \Rightarrow M_{(S P)}$ <br> Push Accumulator B onto Stack | INH | 37 | 2 | - | - | - | - | - | - | - | - |
| PSHC | $(S P)-1 \Rightarrow S P ;(C C R) \Rightarrow M_{(S P)}$ <br> Push CCR onto Stack | INH | 39 | 2 | - | - | - | - | - | - | - | - |
| PSHD | $(S P)-2 \Rightarrow S P ;(A: B) \Rightarrow M_{(S P)}: M_{(S P+1)}$ <br> Push D Accumulator onto Stack | INH | 3B | 2 | - | - | - | - | - | - | - | - |
| PSHX | $(S P)-2 \Rightarrow S P ;\left(X_{H}: X_{L}\right) \Rightarrow M_{(S P)}: M_{(S P+1)}$ <br> Push Index Register $X$ onto Stack | INH | 34 | 2 | - | - | - | - | - | - | - | - |
| PSHY | $(S P)-2 \Rightarrow S P ;\left(Y_{H}: Y_{L}\right) \Rightarrow M_{(S P)}: M_{(S P+1)}$ <br> Push Index Register Y onto Stack | INH | 35 | 2 | - | - | - | - | - | - | - | - |
| PULA | $\begin{aligned} & \left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow \mathrm{A} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP} \\ & \text { Pull Accumulator A from Stack } \end{aligned}$ | INH | 32 | 3 | - | - | - | - | - | - | - | - |
| PULB | $\left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow \mathrm{B} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP}$ <br> Pull Accumulator B from Stack | INH | 33 | 3 | - | - | - | - | - | - | - | - |
| PULC | $\left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow \mathrm{CCR} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP}$ <br> Pull CCR from Stack | INH | 38 | 3 | $\Delta$ | $\Downarrow$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| PULD | $\left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{A}: \mathrm{B} ;(\mathrm{SP})+2 \Rightarrow \mathrm{SP}$ <br> Pull D from Stack | INH | 3A | 3 | - | - | - | - | - | - | - | - |
| PULX | $\left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{X}_{\mathrm{H}}: \mathrm{X}_{\mathrm{L}} ;(\mathrm{SP})+2 \Rightarrow \mathrm{SP}$ <br> Pull Index Register $X$ from Stack | INH | 30 | 3 | - | - | - | - | - | - | - | - |
| PULY | $\left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}} ;(\mathrm{SP})+2 \Rightarrow \mathrm{SP}$ <br> Pull Index Register Y from Stack | INH | 31 | 3 | - | - | - | - | - | - | - | - |
| REV | MIN-MAX rule evaluation <br> Find smallest rule input (MIN). <br> Store to rule outputs unless fuzzy output is already larger (MAX). <br> For rule weights see REVW. <br> Each rule input is an 8-bit offset from the base address in Y. Each rule output is an 8bit offset from the base address in Y. \$FE separates rule inputs from rule outputs. \$FF terminates the rule list. <br> REV may be interrupted. | Special | 18 3A | $\begin{aligned} & \hline 3^{* *} \\ & \text { per } \\ & \text { rule } \\ & \text { byte } \end{aligned}$ | - | - | - | - | - | - | $\Delta$ | - |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| REVW | MIN-MAX rule evaluation <br> Find smallest rule input (MIN), <br> Store to rule outputs unless fuzzy output is already larger (MAX). <br> Rule weights supported, optional. <br> Each rule input is the 16 -bit address of a fuzzy input. Each rule output is the 16 -bit address of a fuzzy output. The value \$FFFE separates rule inputs from rule outputs. \$FFFF terminates the rule list. <br> REVW may be interrupted. | Special | 18 3B | $3^{* *}$ per rule byte; 5 per wt. | - | - | ? | - | ? | ? | $\Delta$ | ! |
| ROL opr <br> ROLA <br> ROLB | Rotate Memory Left through Carry <br> Rotate A Left through Carry <br> Rotate B Left through Carry | EXT IDX IDX1 IDX2 [D,IDX] [IDX2] INH INH | 75 hh II 65 xb 65 xb ff 65 xb ee ff 65 xb 65 xb ee ff 45 55 | $\begin{aligned} & \hline 4 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 6 \\ & 1 \\ & 1 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ROR opr <br> RORA <br> RORB | Rotate Memory Right through Carry <br> Rotate A Right through Carry Rotate B Right through Carry | EXT IDX IDX1 IDX2 [D,IDX] [IDX2] INH INH | 76 hh II 66 xb 66 xb ff 66 xb ee ff 66 xb 66 xb ee ff 46 t 56 | $\begin{aligned} & 4 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 6 \\ & 1 \\ & 1 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| RTC | $\begin{aligned} & \left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow \mathrm{PPAGE} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP} ; \\ & \left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{PC}_{H}: \mathrm{PC}_{\mathrm{L}} ; \\ & (\mathrm{SP})+2 \Rightarrow \mathrm{SP} \end{aligned}$ <br> Return from Call | INH | OA | 6 | - | - | - | - | - | - | - | - |
| RTI | $\begin{aligned} & \left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow \mathrm{CCR} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP} \\ & \left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{B}: A ;(\mathrm{SP})+2 \Rightarrow \mathrm{SP} \\ & \left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{X}_{H}: \mathrm{X}_{\mathrm{L}} ;(\mathrm{SP})+4 \Rightarrow \mathrm{SP} \\ & \left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{PC}_{H}: P C_{L} ;(\mathrm{SP})-2 \Rightarrow \mathrm{SP} \\ & \left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{Y}_{H}: \mathrm{Y}_{\mathrm{L}} ; \\ & (\mathrm{SP})+4 \Rightarrow \mathrm{SP} \end{aligned}$ <br> Return from Interrupt | INH | OB | 8 | $\Delta$ | $\Downarrow$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| RTS | $\begin{aligned} & \left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{PC}_{\mathrm{H}}: \mathrm{PC}_{\mathrm{L}} ; \\ & (\mathrm{SP})+2 \Rightarrow \mathrm{SP} \end{aligned}$ <br> Return from Subroutine | INH | 3D | 5 | - | - | - | - | - | - | - | - |
| SBA | $(A)-(B) \Rightarrow A$ <br> Subtract B from A | INH | 1816 | 2 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SBCA opr | $(A)-(M)-C \Rightarrow A$ <br> Subtract with Borrow from A | $\begin{gathered} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | 82 ii <br> 92 dd <br> B2 hh II <br> A2 xb <br> A2 xb ff <br> A2 xb ee ff <br> A2 xb <br> A2 xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SBCB opr | $(B)-(M)-C \Rightarrow B$ <br> Subtract with Borrow from B | $\begin{gathered} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | C2 ii <br> D2 dd <br> F2 hh II <br> E2 xb <br> E2 xb ff <br> E2 xb ee ff <br> E2 xb <br> E2 xb ee ff | $\begin{aligned} & \hline 1 \\ & \hline 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SEC | $\begin{aligned} & 1 \Rightarrow \mathrm{C} \\ & \text { Translates to ORCC \#\$01 } \end{aligned}$ | IMM | 1401 | 1 | - | - | - | - | - | - | - | 1 |
| SEI | $1 \Rightarrow \mathrm{I}$; (inhibit I interrupts) Translates to ORCC \#\$10 | IMM | 1410 | 1 | - | - | - | 1 | - | - | - | - |
| SEV | $\begin{aligned} & 1 \Rightarrow \mathrm{~V} \\ & \text { Translates to ORCC \#\$02 } \end{aligned}$ | IMM | 1402 | 1 | - | - | - | - | - | - | 1 | - |
| SEX r1, r2 | $\$ 00:(\mathrm{r} 1) \Rightarrow \mathrm{r} 2$ if r 1 , bit 7 is 0 or \$FF:(r1) $\Rightarrow \mathrm{r} 2$ if r 1 , bit 7 is 1 <br> Sign Extend 8-bit r1 to 16-bit r2 r1 may be $A, B$, or CCR r2 may be $\mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP <br> Alternate mnemonic for TFR r1, r2 | INH | B7 eb | 1 | - | - | - | - | - | - | - | - |
| STAA opr | $(A) \Rightarrow M$ <br> Store Accumulator A to Memory | DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 5A dd <br> 7A hh II <br> 6A xb <br> $6 \mathrm{~A} x \mathrm{ff}$ <br> 6A xb ee ff <br> 6A xb <br> $6 A$ xb ee ff | $\begin{aligned} & 2 \\ & 3 \\ & 2 \\ & 3 \\ & 3 \\ & 5 \\ & 5 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| STAB opr | $(B) \Rightarrow M$ <br> Store Accumulator B to Memory | DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 5B dd $7 B \mathrm{hh} \mathrm{II}$ $6 B \times b$ $6 B \times b ~ f f$ $6 B \times b$ ee ff $6 B \times b$ $6 B \times b$ ee ff | $\begin{aligned} & 2 \\ & 3 \\ & 2 \\ & 3 \\ & 3 \\ & 5 \\ & 5 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| STD opr | $(A) \Rightarrow M,(B) \Rightarrow M+1$ <br> Store Double Accumulator | DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 5C dd 7C hh II 6C xb 6 C xb ff 6C xb ee ff 6C xb 6 C xb ee ff | $\begin{aligned} & \hline 2 \\ & 3 \\ & 2 \\ & 3 \\ & 3 \\ & 5 \\ & 5 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| STOP | $\begin{aligned} & (S P)-2 \Rightarrow S P ; \\ & R_{T N}: R T N_{L} \Rightarrow M_{(S P)}: M_{(S P+1)} ; \\ & (S P)-2 \Rightarrow S P ;\left(Y_{H}: Y_{L}\right) \Rightarrow M_{(S P)}: M_{(S P+1)} ; \\ & (S P)-2 \Rightarrow S P ;\left(X_{H}: X_{L}\right) \Rightarrow M_{(S P)}: M_{(S P+1)} ; \\ & (S P)-2 \Rightarrow S P ;(B: A) \Rightarrow M_{(S P}: M_{(S P+1)} ; \\ & (S P)-1 \Rightarrow S P ;(C C R) \Rightarrow M_{(S P)} ; \end{aligned}$ <br> STOP All Clocks <br> If $S$ control bit $=1$, the STOP instruction is disabled and acts like a two-cycle NOP. <br> Registers stacked to allow quicker recovery by interrupt. | INH | 18 3E | $\begin{gathered} 9^{* *} \\ +5 \\ \text { or } \\ +2^{* *} \end{gathered}$ | - | - | - | - | - | - | - | - |
| STS opr | $\left(\mathrm{SP}_{\mathrm{H}}: \mathrm{SP}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}: \mathrm{M}+1$ <br> Store Stack Pointer | $\begin{gathered} \hline \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \end{gathered}$ | 5F dd <br> 7F hh II <br> 6F xb <br> 6F xb ff <br> 6F xb ee ff <br> 6F xb <br> 6F xb ee ff | $\begin{aligned} & 2 \\ & 3 \\ & 2 \\ & 3 \\ & 3 \\ & 3 \\ & 5 \\ & 5 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| STX opr | $\left(X_{H}: X_{L}\right) \Rightarrow M: M+1$ <br> Store Index Register X | DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 5E dd <br> 7E hh II <br> 6E xb <br> 6E xb ff <br> 6E xb ee ff <br> 6E xb <br> 6E xb ee ff | $\begin{aligned} & \hline 2 \\ & 3 \\ & 2 \\ & 3 \\ & 3 \\ & 3 \\ & 5 \\ & 5 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| STY opr | $\left(Y_{H}: Y_{L}\right) \Rightarrow M: M+1$ <br> Store Index Register $Y$ | DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | 5D dd <br> 7D hh II <br> 6D xb <br> 6D xb ff <br> 6D xb ee ff <br> 6D xb <br> 6D xb ee ff | $\begin{aligned} & \hline 2 \\ & 3 \\ & 2 \\ & 3 \\ & 3 \\ & 5 \\ & 5 \\ & 5 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| SUBA opr | $(\mathrm{A})-(\mathrm{M}) \Rightarrow \mathrm{A}$ <br> Subtract Memory from Accumulator A | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 80 ii <br> 90 dd <br> B0 hh II <br> A0 xb <br> A0 xb ff <br> A0 xb ee ff <br> A0 xb <br> A0 xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SUBB opr | $(\mathrm{B})-(\mathrm{M}) \Rightarrow \mathrm{B}$ <br> Subtract Memory from Accumulator B | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | C0 ii <br> D0 dd <br> FO hh II <br> E0 xb <br> E0 xb ff <br> E0 xb ee ff <br> E0 xb <br> E0 xb eeff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SUBD opr | $\text { (D) }-(M: M+1) \Rightarrow D$ <br> Subtract Memory from D (A:B) | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 83 jj kk <br> 93 dd <br> B3 hh II <br> A3 xb <br> A3 xb ff <br> A3 xb ee ff <br> A3 xb <br> A3 xb ee ff | $\begin{aligned} & \hline 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SWI | $\begin{aligned} & (\mathrm{SP})-2 \Rightarrow \mathrm{SP} ; \\ & \mathrm{RTN}_{\mathrm{H}}: \mathrm{RTN}_{\mathrm{L}} \Rightarrow \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)} ; \\ & (\mathrm{SP})-2 \Rightarrow \mathrm{SP} ;\left(\mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)} ; \\ & (\mathrm{SP})-2 \Rightarrow \mathrm{SP} ;\left(\mathrm{X}_{\mathrm{H}}: \mathrm{X}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)} ; \\ & (\mathrm{SP})-2 \Rightarrow \mathrm{SP} ;(\mathrm{B}: A) \Rightarrow \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)} ; \\ & (\mathrm{SP})-1 \Rightarrow \mathrm{SP} ;(\mathrm{CCR}) \Rightarrow \mathrm{M}_{(\mathrm{SP})} \\ & 1 \Rightarrow \mathrm{I} ;(\mathrm{SWI} \text { Vector) } \Rightarrow \mathrm{PC} \end{aligned}$ <br> Software Interrupt | INH | 3 F | 9 | - | - | - | 1 | - | - | - | - |
| TAB | (A) $\Rightarrow B$ <br> Transfer A to B | INH | 18 0E | 2 | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| TAP | $(A) \Rightarrow C C R$ <br> Translates to TFR A , CCR | INH | B7 02 | 1 | $\Delta$ | $\Downarrow$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| TBA | $\begin{aligned} & \text { (B) } \Rightarrow A \\ & \text { Transfer B to } A \end{aligned}$ | INH | 180 F | 2 | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| TBEQ cntr, rel | If (cntr) $=0$, then Branch; else Continue to next instruction <br> Test Counter and Branch if Zero (cntr = A, B, D, X, Y, or SP) | $\begin{gathered} \hline \text { REL } \\ \text { (9-bit) } \end{gathered}$ | 04 lb rr | 3 | - | - | - | - | - | - | - | - |
| TBL opr | $(M)+[(B) \times((M+1)-(M))] \Rightarrow A$ <br> 8-Bit Table Lookup and Interpolate <br> Initialize B, and index before TBL. <ea> points at first 8-bit table entry (M) and $B$ is fractional part of lookup value. <br> (no indirect addressing modes allowed.) | IDX | 18 3D xb | 8 | - | - | - | - | $\Delta$ | $\Delta$ | - | $?$ |
| TBNE cntr, rel | If (cntr) not $=0$, then Branch; else Continue to next instruction <br> Test Counter and Branch if Not Zero ( cntr = A, B, D, X, Y, or SP) | $\begin{gathered} \hline \text { REL } \\ \text { (9-bit) } \end{gathered}$ | 04 lb rr | 3 | - | - | - | - | - | - | - | - |
| TFR r1, r2 | $\begin{aligned} & (r 1) \Rightarrow r 2 \text { or } \\ & \$ 00:(r 1) \Rightarrow r 2 \text { or } \\ & (r 1[7: 0]) \Rightarrow r 2 \end{aligned}$ <br> Transfer Register to Register r1 and r2 may be A, B, CCR, D, X, Y, or SP | INH | B7 eb | 1 | - or $\Delta$ |  | $\Delta$ | $\Delta$ | $\Delta$ | $-$ | $-$ | - |
| TPA | $\begin{array}{\|l} (\mathrm{CCR}) \Rightarrow \mathrm{A} \\ \text { Translates to TFR CCR }, \mathrm{A} \end{array}$ | INH | B7 20 | 1 | - | - | - | - | - | - | - | - |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| TRAP | (SP) $-2 \Rightarrow S P$; <br> $\operatorname{RTN}_{\mathrm{H}}:$ RTN $_{\mathrm{L}} \Rightarrow \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}$; <br> $(S P)-2 \Rightarrow S P ;\left(Y_{H}: Y_{L}\right) \Rightarrow M_{(S P)}: M_{(S P+1)}$; <br> $(\mathrm{SP})-2 \Rightarrow \mathrm{SP} ;\left(\mathrm{X}_{\mathrm{H}}: \mathrm{X}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)} ;$ <br> $(S P)-2 \Rightarrow S P ;(B: A) \Rightarrow M_{(S P)}: M_{(S P+1)}$; <br> (SP) $-1 \Rightarrow S P ;(C C R) \Rightarrow M_{(S P)}$ <br> $1 \Rightarrow \mathrm{I}$; (TRAP Vector) $\Rightarrow \mathrm{PC}$ <br> Unimplemented opcode trap | INH | $\begin{aligned} & 18 \mathrm{tn} \\ & \mathrm{tn}=\$ 30-\$ 39 \\ & \quad \text { or } \\ & \quad \$ 40-\$ F F \end{aligned}$ | 10 | - | - | - | 1 | - | - | - | - |
| $\begin{array}{\|c\|} \hline \text { TST opr } \\ \\ \\ \\ \\ \hline \text { TSTA } \\ \text { TSTB } \\ \hline \end{array}$ | $(\mathrm{M})-0$ <br> Test Memory for Zero or Minus <br> (A) -0 <br> Test A for Zero or Minus <br> (B) -0 <br> Test B for Zero or Minus | EXT IDX IDX1 IDX2 [D,IDX] [IDX2] INH INH | F7 hh II <br> E7 xb <br> E7 xb ff <br> E7 xb ee ff <br> E7 xb <br> E7 xb ee ff <br> 97 <br> D7 | $\begin{aligned} & \hline 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & 1 \\ & 1 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | 0 |
| TSX | $(S P) \Rightarrow X$ <br> Translates to TFR SP, X | INH | B7 75 | 1 | - | - | - | - | - | - | - | - |
| TSY | $(S P) \Rightarrow Y$ <br> Translates to TFR SP,Y | INH | B7 76 | 1 | - | - | - | - | - | - | - | - |
| TXS | $(X) \Rightarrow S P$ <br> Translates to TFR X,SP | INH | B7 57 | 1 | - | - | - | - | - | - | - | - |
| TYS | $(\mathrm{Y}) \Rightarrow \mathrm{SP}$ <br> Translates to TFR Y,SP | INH | B7 67 | 1 | - | - | - | - | - | - | - | - |
| WAI | $\begin{aligned} & (\mathrm{SP})-2 \Rightarrow \mathrm{SP} ; \\ & \mathrm{RN}_{\mathrm{H}}: R T N_{\mathrm{L}} \Rightarrow \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)} ; \\ & (\mathrm{SP})-2 \Rightarrow \mathrm{SP} ;\left(\mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)} ; \\ & (\mathrm{SP})-2 \Rightarrow \mathrm{SP} ;\left(\mathrm{X}_{\mathrm{H}}: \mathrm{X}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)} ; \\ & (\mathrm{SP})-2 \Rightarrow \mathrm{SP} ;(\mathrm{B}: \mathrm{A}) \Rightarrow \mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)} ; \\ & (\mathrm{SP})-1 \Rightarrow \mathrm{SP} ;(\mathrm{CCR}) \Rightarrow \mathrm{M}_{(\mathrm{SP})} ; \end{aligned}$ <br> WAIT for interrupt | INH | 3E | $\begin{gathered} \hline 8^{* *} \\ \text { (in) } \\ + \\ 5 \\ \text { (int) } \end{gathered}$ | or <br> or | 1 | - | 1 1 | ${ }_{-}^{-}$ | - | - - - | - - - |
| WAV | $\begin{aligned} & \sum_{i=1}^{B} S_{i} F_{i} \Rightarrow Y: D \\ & \sum_{i=1}^{B} F_{i} \Rightarrow X \end{aligned}$ <br> Calculate Sum of Products and Sum of Weights for Weighted Average Calculation <br> Initialize B, X, and Y before WAV. B specifies number of elements. $X$ points at first element in $\mathrm{S}_{\mathrm{i}}$ list. Y points at first element in $\mathrm{F}_{\mathrm{i}}$ list. <br> All $\mathrm{S}_{\mathrm{i}}$ and $\mathrm{F}_{\mathrm{i}}$ elements are 8-bits. <br> If interrupted, six extra bytes of stack used for intermediate values | Special | 183 C | $\begin{gathered} 8^{* *} \\ \text { per } \\ \text { lable } \end{gathered}$ | - | - | ? | - | ? | $\Delta$ | ? | ? |

Table A-1 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~* | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| wavr | see WAV | Special | 3C | ** | - | - | ? | - | ? | $\Delta$ | ? | $?$ |
| pseudoinstruction | Resume executing an interrupted WAV instruction (recover intermediate results from stack rather than initializing them to zero) |  |  |  |  |  |  |  |  |  |  |  |
| XGDX | $(\mathrm{D}) \Leftrightarrow(\mathrm{X})$ <br> Translates to EXG D, X | INH | B7 C5 | 1 | - | - | - | - | - | - | - | - |
| XGDY | $(\mathrm{D}) \Leftrightarrow(\mathrm{Y})$ <br> Translates to EXG D, Y | INH | B7 C6 | 1 | - | - | - | - | - | - | - | - |

NOTES:
*Each cycle ( $\sim$ ) is typically 125 ns for an $8-\mathrm{MHz}$ bus ( $16-\mathrm{MHz}$ oscillator).
${ }^{* *}$ Refer to detailed instruction descriptions for additional information.

## Key to Table A-2



Addressing mode abbreviations:
DI — Direct
EX — Extended
ID - Indexed
IH — Inherent
IM - Immediate
RL — Relative
SP - Special
Cycle counts are for single-chip mode with 16-bit internal buses. Stack location (internal or external), external bus width, and operand alignment can affect actual execution time.

Table A-2 CPU12 Opcode Map (Sheet 1 of 2)

| $\begin{gathered} 00{ }^{*} 5 \\ \text { BGND } \end{gathered}$ | $\begin{array}{\|l\|} \hline 10 \\ \text { ANDCC } \end{array}$ | $\mathrm{BRA}^{20}$ | ${ }^{30} \text { PULX }^{3}$ | $\begin{gathered} 40 \\ \text { NEGA } \end{gathered}$ | ${ }^{50}{ }^{\text {NEGB }}{ }^{1}$ | $\begin{gathered} 60{ }^{3-6} \\ \text { NEG } \end{gathered}$ | $\begin{gathered} 70 \\ \\ \\ N E G \end{gathered}$ | $80{ }^{1}{ }^{1}$ | $90{ }^{9}{ }^{3}$ | $\begin{gathered} \hline \text { A0 }{ }^{3-6} \\ \text { SUBA } \end{gathered}$ | $\begin{gathered} \text { BOBA }^{3} \end{gathered}$ | $\begin{aligned} & \text { CO } \\ & \text { SUBB } \end{aligned}$ | $\text { SUBB }^{3}$ | SUBB | SUBB |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IH | IM | RL | IH | IH | IH | ID 2-4 | EX | IM 2 | DI 2 | ID 2-4 | EX | IM | DI | ID 2-4 | EX |
| ${ }^{01}{ }^{51}{ }^{5}$ | ${ }^{11} \text { EDIV }^{11}$ | ${ }^{21} \text { BRN }^{1}$ | ${ }^{31} \text { PULY }^{3}$ | $\stackrel{41}{\text { COMA }}$ | 51 | ${ }^{61} \mathrm{COM}^{3-6}$ | 4 |  | ${ }^{91} \mathrm{CMPA}^{3}$ | A1 ${ }^{3-6}$ CMPA | B1 ${ }^{\text {CMPA }}$ |  | ${\mathrm{D} 1{ }^{\text {CMPB }}{ }^{3}}$ | E1 ${ }^{3-6}$ CMPB | CMPB |
| IH | IH | RL | IH | IH | IH | ID 2-4 | EX | IM 2 | DI | ID 2-4 | EX | IM | DI | D | EX |
| ${ }^{02}{ }_{\text {INY }}{ }^{1}$ | ${ }^{12} \mathrm{MUL}^{3}$ | $\begin{gathered} 223 / 1 \\ \mathrm{BHI} \end{gathered}$ | ${ }^{32} \text { PULA }^{3}$ | ${ }^{42}{ }^{1}{ }^{1}$ | ${ }^{52}{ }^{1}$ | $\begin{gathered} 62 \quad{ }^{63-6} \end{gathered}$ | $\begin{array}{\|l\|} \hline 72 \\ \\ \\ \hline \end{array}$ | $82{ }^{1}{ }^{1}$ | ${ }^{92}$ SBCA ${ }^{3}$ | $\begin{array}{\|c\|} \hline \text { A2 }{ }^{3-6} \\ \text { SBCA } \end{array}$ | $\mathrm{BBCA}^{3}$ | $\begin{gathered} \hline \mathrm{C} 2 \\ \mathrm{SBCB} \end{gathered}$ | $\begin{array}{\|l\|} \hline \text { D2 } \\ \text { SBCB } \end{array}$ | $\begin{gathered} \mathrm{E}^{3} \quad 3-6 \\ \mathrm{SBCB} \end{gathered}$ | $\mathrm{F}^{\mathrm{SBCB}}$ |
| IH | IH | RL | IH | IH | IH | ID 2-4 | EX 3 | IM | DI | ID | EX | IM | DI | ID | EX |
| $03{ }^{2}{ }^{1}$ | ${ }^{13} \text { EMUL }^{3}$ | $\begin{array}{\|cc} 23 \quad 3 / 1 \\ B L S \end{array}$ | $\text { PULB }^{33}$ | $43{ }^{1}{ }^{1}$ | ${ }^{53}{ }^{\text {DECB }}{ }^{1}$ | $\begin{gathered} 63{ }^{3-6} \\ \hline \end{gathered}$ | $73 \quad 4$ | ${ }^{83} \text { SUBD }^{2}$ | $\mathrm{SUBD}^{33}$ | $\begin{aligned} & \text { A3 }{ }^{3-6} \\ & \text { SUBD } \end{aligned}$ | $\text { BUBD }^{3}$ | $\begin{array}{cr} \hline \mathrm{C} 3 & 2 \\ \mathrm{ADDDD}^{2} \end{array}$ | $\begin{array}{\|l\|} \hline \text { D3 } \\ \hline \end{array}{ }^{3}$ | $\begin{array}{cr} \hline \text { E3 } & 3-6 \\ \text { ADDD } \end{array}$ | ${ }^{\text {F3 }}{ }^{3}{ }^{3}$ |
| IH | IH | RL 2 | IH | IH | IH | ID | EX | IM | DI | ID 2-4 | EX | IM 3 | DI | ID 2-4 | EX |
| $04 \text { loop }^{\ddagger}$ | $\begin{array}{\|c\|} \hline 14 \\ \text { ORCC }^{1} \end{array}$ | $\begin{gathered} 24 \quad 3 / 1 \\ B C C \end{gathered}$ | $34{ }^{34}{ }^{2}$ | $44{ }^{4}{ }^{1}$ | ${ }^{54}{ }^{\text {LSRB }}{ }^{1}$ | ${ }^{4} \text { LSR }^{3-}$ | $4^{4}{ }^{4}$ | $\begin{gathered} 84 \\ \text { ANDA } \end{gathered}$ | $94{ }^{94}{ }^{3}$ | $\begin{array}{cc} \hline \text { A4 } \\ \text { AND } \end{array}$ | $\begin{aligned} & \text { B4 }{ }^{3}{ }^{3} \end{aligned}$ | C4 ANDB | $\mathrm{D}^{\mathrm{ANDB}}{ }^{3}$ | $\begin{array}{cr} \hline \mathrm{E} 4 & 3-6 \\ \text { ANDB } \end{array}$ | $\begin{array}{ll} -4 \\ \text { ANDB } \end{array}$ |
| RL 3 | IM | RL 2 | IH | IH | IH | ID 2-4 | EX 3 | IM 2 | DI 2 | ID 2-4 | EX | IM 2 | DI | ID 2-4 | EX |
| $$ | $\begin{gathered} 15 \quad \begin{array}{c} 4-7 \\ \text { JSR } \end{array} \\ \hline \end{gathered}$ | $\begin{array}{\|cc} 25 \\ B C S \end{array}$ | $\begin{gathered} 35 \\ { }^{3}{ }^{2} \end{gathered}$ | ${ }^{45} \text { ROLA }^{1}$ | ${ }^{55} \text { ROLB }^{1}$ | $\begin{gathered} 65 \mathrm{ROL}^{3-6} \end{gathered}$ | $\begin{array}{\|c\|} \hline 75 \\ \mathrm{ROL} \\ \hline \end{array}$ | $85 \text { BITA }{ }^{1}$ | $95{ }^{9}{ }^{3}$ | $\begin{array}{cc} \hline \text { A5 }{ }^{3-6} \\ \text { BITA } \end{array}$ | $\begin{aligned} & \text { B5 } \\ & \text { BITA } \end{aligned}$ | $\begin{gathered} \text { C5 } \\ \text { BITB } \end{gathered}$ | $\begin{array}{\|cc\|} \hline \text { D5 } \\ \text { BITB } \end{array}$ | $\begin{array}{cc} \hline \text { E5 } & 3-6 \\ \text { BITB } \end{array}$ | $\begin{aligned} & \text { F5 } \\ & \text { BITB } \end{aligned}$ |
| ID 2-4 | ID 2-4 | RL 2 | IH | IH | IH | ID 2-4 | EX | IM 2 | DI 2 | ID 2-4 | EX | IM | DI 2 | ID 2-4 | EX |
| $06{ }^{3}{ }^{3}$ | $\begin{array}{\|cc\|} \hline 16 \underset{\text { JSR }}{ }{ }^{4} \\ \hline \end{array}$ | $\begin{gathered} 36 \quad 3 / 1 \\ \text { BNE } \end{gathered}$ | ${ }^{36}{ }^{36}{ }^{2}$ | $\begin{gathered} 46 \\ \text { RORA }^{1} \end{gathered}$ | ${ }^{56}{ }^{\text {RORB }}{ }^{1}$ | $\begin{gathered} 66{ }^{3-6} \\ \text { ROR } \end{gathered}$ | $\begin{array}{\|c\|} \hline 76 \text { ROR }^{4} \end{array}$ | ${ }^{86} \operatorname{LDAA}^{1}$ | ${ }^{96} \text { LDAA }^{3}$ | $\begin{gathered} \text { A6 }{ }^{3-6} \\ \text { LDAA } \end{gathered}$ | $\begin{aligned} & \text { B6 } \\ & \text { LDAA } \end{aligned}{ }^{3}$ | ${ }^{\mathrm{C} 6}{ }^{1}$ | $\mathrm{LDAB}^{3}$ | $\begin{array}{cc} \text { E6 } & 3-6 \\ \text { LDAB } \end{array}$ | ${ }^{\text {LD }}{ }^{2}{ }^{3}$ |
| EX | EX 3 | RL | IH | IH | IH | ID 2-4 | EX | IM | DI 2 | ID 2-4 | EX | IM | DI 2 | ID 2-4 | EX |
| $\begin{array}{\|c\|} \hline 07 \\ B_{B S R} \end{array}$ | ${ }^{17}{ }_{\text {JSR }}{ }^{4}$ | $\begin{array}{\|c} \hline 27 \\ \text { BEQ } \end{array}$ |  | $47{ }^{1}{ }^{1}$ | ${ }^{57}{ }^{1}{ }^{1}$ | $\mathrm{SR}^{3}$ | $\begin{gathered} 47 \\ \text { ASR }^{4} \end{gathered}$ | ${ }^{87}{ }^{\text {CLRA }}{ }^{1}$ | ${ }^{97}{ }^{\text {TSTA }}{ }^{1}$ | ${ }^{\text {A7 }}{ }^{\text {NOP }}{ }^{1}$ | $\begin{array}{\|c\|c\|} \text { B7 } \\ \text { TFR/EXG } \end{array}$ | $\begin{gathered} \mathrm{C}^{\mathrm{CLRB}}{ }^{1} \end{gathered}$ |  | $\begin{array}{cc} \text { E7 } \\ \text { TST } \end{array}$ | ${ }^{7} 7$ |
| RL 2 | DI 2 | RL 2 | IH | IH | IH | ID 2-4 | EX 3 | IH | IH | IH | IH | IH | IH | ID 2-4 | EX |
| ${ }^{08} \text { INX }{ }^{1}$ | $\begin{aligned} & 18 \\ & \text { page } 2 \end{aligned}$ | $\begin{gathered} 28 \quad 3 / 1 \\ B V C^{3} \end{gathered}$ | ${ }^{38} \text { PULC }^{3}$ | $48{ }^{4}{ }^{1}$ | ${ }^{58} \text { ASLB }^{1}$ | $68 \text { ASL }$ | $78 \text { ASL }$ | $88{ }^{88}{ }^{1}$ | ${ }^{98}$ EORA $^{3}$ | $\begin{gathered} \text { A8 }{ }^{3-6} \\ \text { EORA } \end{gathered}$ | B8 EORA ${ }^{3}$ | C8 ${ }^{\text {EORB }}{ }^{1}$ | $\mathrm{D8}^{\text {EORB }}{ }^{3}$ | $\begin{array}{cc} \hline \text { E8 } & 3-6 \\ \text { EORB } \end{array}$ | $\begin{gathered} \mathrm{FORB}^{3} \end{gathered}$ |
| IH |  | RL | IH | IH | IH | ID 2-4 | EX | IM 2 | DI 2 | ID 2-4 | EX | IM 2 | DI | ID 2-4 | EX |
| $09{ }^{0}{ }^{1}$ | ${ }^{19} \text { LEAY }^{2}$ | $\begin{gathered} 29 \mathrm{~S}^{3 / 1} \\ \mathrm{BVS}^{2} \end{gathered}$ | 39 PSHC ${ }^{2}$ | $49{ }^{4}{ }^{1}$ | ${ }^{59}$ ASLD ${ }^{1}$ | $\begin{gathered} 69 \text { CLR } \end{gathered}$ | 79 | 89 ADCA ${ }^{1}$ | ${ }^{99}{ }^{\text {ADCA }}{ }^{3}$ | $\begin{array}{cc} \hline \text { A9 }{ }^{3-6} \\ \text { ADCA } \end{array}$ | $\mathrm{B9}_{\text {ADCA }}{ }^{3}$ | $\mathrm{Ca}_{\text {ADCB }}{ }^{1}$ | $\mathrm{D9}_{\text {ADCB }}{ }^{3}$ | $\begin{array}{cc} \hline \text { E9 } & 3-6 \\ \text { ADCB } \end{array}$ | $\begin{aligned} & \mathrm{F9}{ }^{\mathrm{ADCB}}{ }^{3} \end{aligned}$ |
| IH | ID 2-4 | RL 2 | IH | IH | IH | ID 2-4 | EX 3 | IM | DI 2 | ID | EX | IM | DI | ID 2-4 | EX |
| $\begin{gathered} 0 \mathrm{~A} \\ \text { RTC } \end{gathered}$ | $\operatorname{LEAX}^{2}$ | $\begin{gathered} 2 \mathrm{~A} \quad 3 / 1 \\ \mathrm{BPL} \end{gathered}$ | ${ }^{3 \mathrm{AA}} \mathrm{PULD}^{3}$ | $\mathrm{CALL}^{48}$ | $\text { STAA }^{2}$ | $\begin{gathered} 6 A{ }^{2-4} \\ \text { STAA } \end{gathered}$ | $\begin{aligned} & \text { 7A } \\ & \text { ST } \end{aligned}$ | $\text { ORAA }^{1}$ | $\mathrm{ORAA}^{3}$ | $\begin{gathered} \hline \text { AA } 3-6 \\ \text { ORAA } \end{gathered}$ | $\mathrm{BA}^{\mathrm{ORAA}}{ }^{3}$ | CA ORAB | $\begin{gathered} \hline \text { DA }{ }^{3} \\ \text { ORAB } \end{gathered}$ | $\begin{array}{cc} \hline \text { EA } 3-6 \\ \text { ORAB } \end{array}$ | $\text { ORAB }{ }^{3}$ |
| IH | ID 2-4 | RL 2 | IH | EX | DI | ID 2-4 | EX | IM 2 | DI 2 | ID 2-4 | EX | IM 2 | DI | ID 2-4 | EX |
| $\begin{gathered} 0 B_{R T I} \end{gathered} 8$ | $\operatorname{LEAS}^{2}$ | BMI | ${ }^{3 B}{ }^{2}$ | $\begin{gathered} \text { 4B }{ }^{8-10} \\ \text { CALL } \end{gathered}$ | $\mathrm{SB}^{2}{ }^{2}$ | $\begin{gathered} \text { 6B }{ }^{2-4} \\ \text { STAB } \end{gathered}$ | $\begin{aligned} & \text { 7B } \\ & \text { STAB } \end{aligned}$ | $\begin{gathered} \text { 8B }{ }^{1} \end{gathered}$ | ${ }^{9 \mathrm{ADDA}}{ }^{3}$ | $\begin{array}{cc} \hline \text { AB } & 3-6 \\ \text { ADDA } \end{array}$ | $\begin{aligned} & \text { BB }{ }^{3}{ }^{3} \end{aligned}$ | $\begin{gathered} \text { CB } \\ \\ \end{gathered}$ | $\begin{gathered} \hline \mathrm{DB} \quad 3 \\ \mathrm{ADDB}^{3} \end{gathered}$ | $\begin{array}{cc} \hline \mathrm{EB} & 3-6 \\ \mathrm{ADDB} \end{array}$ | ADDB |
| IH | ID 2-4 | RL | IH | ID 2-5 | DI 2 | ID 2-4 | EX | IM 2 | DI 2 | ID 2-4 | EX | IM 2 | DI 2 | ID 2-4 | EX |
| $\begin{array}{\|cr\|} \hline 0 \mathrm{Cr} & 4-6 \\ \text { BSET } \end{array}$ | ${ }^{1 C}{ }^{\text {BSET }}{ }^{4}$ | $\begin{gathered} 2 \mathrm{C}{ }^{3 /} \\ \mathrm{BGE} \end{gathered}$ | $\begin{gathered} \hline 3 C \quad{ }^{*}+9 \\ \text { wavr } \end{gathered}$ | 4C BSET ${ }^{4}$ | ${ }^{5} \mathrm{STD}{ }^{2}$ | $\mathrm{CC}^{\text {STD }}{ }^{2-5}$ | 7C | ${ }_{8 C P D}{ }^{2}$ | ${ }_{\text {9CPD }}{ }^{3}$ | $\mathrm{AC}^{\text {CPD }}{ }^{3-6}$ | CPD | $\mathrm{CCDD}^{2}$ | $\mathrm{DC} \mathrm{LDD}^{3}$ | $\begin{gathered} \text { EC } \\ \text { LDD } \end{gathered}$ | CDD |
| ID 3-5 | EX | RL 2 | SP | DI 3 | DI 2 | ID | EX | IM 3 | DI 2 | ID 2-4 | EX 3 | IM | DI 2 | ID 2-4 | EX |
| $\begin{array}{\|c\|} \hline \text { OD } \\ \text { BCLR } \end{array}$ | 1D ${ }^{\text {BCLR }}{ }^{4}$ | $\begin{gathered} 2 \mathrm{D}{ }^{3 / 1} \\ \mathrm{BLT}^{2} \end{gathered}$ | $\begin{gathered} \text { 3D } \\ \text { RTS } \end{gathered}$ | ${ }_{\text {4DCLR }}{ }^{4}$ | ${ }^{5 D} \mathrm{STY}^{2}$ | $\begin{gathered} \text { 6D } \text { STY }^{2-5} \end{gathered}$ | 7D STY | ${ }^{8 \mathrm{D}} \mathrm{CPY}{ }^{2}$ | $\mathrm{CPY}^{3}$ | $\begin{gathered} \text { AD }{ }^{3-6} \\ \hline \text { PY } \end{gathered}$ | ${ }^{\text {BD }} \mathrm{CPY}{ }^{3}$ | CDDY ${ }^{2}$ | LD LDY $^{3}$ | $\begin{aligned} & \text { ED }{ }^{3-6} \end{aligned}$ | LDY |
| ID 3-5 | EX | RL 2 | IH 1 | DI 3 | DI 2 | ID 2-4 | EX | IM 3 | DI | ID 2-4 | EX | IM | DI 2 | ID 2-4 | EX |
| $\begin{array}{\|lr\|} \hline \text { OE } & 4-8 \\ \text { BRSET } \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline \text { 1E } \\ \hline \\ \text { BRSET } \\ \hline \end{array}$ | $\begin{gathered} \hline 2 \mathrm{E} \quad 3 / 1 \\ \mathrm{BGT} \end{gathered}$ | ${ }^{3 E_{W A I}}{ }^{*} 8$ | $\begin{array}{lr} \hline 4 \mathrm{E} & 4 \\ \text { BRSET } \end{array}$ | ${ }_{5 T X}{ }^{2}$ | ${ }^{6 E} \mathrm{STX}^{2-5}$ | STX | ${ }_{8 E P X^{2}}$ | ${ }^{9 E} \mathrm{CPX}^{3}$ | $\mathrm{AE}^{\mathrm{AE}} \mathrm{CP}^{3-6}$ | $\mathrm{BEPX}^{3}$ | $\mathrm{CESX}^{2}$ | $\mathrm{DE}_{\text {LDX }}{ }^{3}$ | $\mathrm{EE}^{\mathrm{E}} \mathrm{SX}^{3-6}$ | EDX |
| ID 4-6 | EX 5 | RL 2 | IH 1 | DI | DI 2 | ID 2-4 | EX 3 | IM 3 | DI | ID 2-4 | EX 3 | IM 3 | DI 2 | ID 2-4 | EX |
| $\begin{array}{\|lr\|} \hline 0 F & 4-8 \\ \text { BRCLR } \end{array}$ | 1F ${ }^{\text {BRCLR }}$ | $\begin{array}{cr} \hline 2 \mathrm{~F} & 3 / 1 \\ \text { BLE } \end{array}$ | ${ }^{3 F_{\text {SWI }} 9}$ | 4Fr ${ }_{\text {BRCLR }}$ | $\mathrm{5F}_{\text {STS }}{ }^{2}$ | ${ }^{6 F} \mathrm{STS}^{2-5}$ | ${ }^{7 F}$ STS | ${ }^{8 \mathrm{~F}} \mathrm{CPS}{ }^{2}$ | ${ }^{9 F} \mathrm{CPS}^{3}$ | ${ }^{\text {AF }}{ }^{\text {CPS }}$ | $\mathrm{BF}^{\mathrm{CPS}}{ }^{3}$ | CF LDS ${ }^{2}$ | DF LDS ${ }^{3}$ | $\begin{array}{cc} \hline \text { EF } & 3-6 \\ L D S \end{array}$ | FF LDS |
| ID | EX 5 | RL 2 | IH 1 | DI | DI | D | EX | IM | DI | ID 2-4 | EX | IM | DI | ID 2-4 | EX |

Table A-2 CPU12 Opcode Map (Sheet 2 of 2)

| MOVW | $\text { IDIV }^{12}$ | ${ }^{20} \text { LBRA }^{4}$ | TRAP | $\begin{aligned} & 0 \\ & \text { TRAP } \end{aligned}$ | ${ }^{50} \mathrm{TRAP}^{10}$ | $\begin{aligned} & 60{ }^{10}{ }^{10} 8 \mathrm{c} \end{aligned}$ | TRAP | $\begin{aligned} & 80{ }^{10}{ }^{10} \end{aligned}$ | $\begin{aligned} & 90{ }^{10} \\ & \operatorname{TRAP} \end{aligned}$ | $\begin{aligned} & \text { A0 }{ }^{10} \end{aligned}$ | $\begin{aligned} & \text { B0 }{ }^{10} \end{aligned}$ | $\begin{aligned} & \text { C0 }{ }^{10} \end{aligned}$ | $\begin{aligned} & \text { DO }{ }^{10} \end{aligned}$ | $\begin{aligned} & \text { E0 }{ }^{10} \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { F0 }{ }^{1( } \end{aligned}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IM-ID | IH | RL | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH 2 | H 2 |
| $\begin{array}{\|l\|} \hline 01 \\ \text { MOVW } \end{array}$ | $11 \text { Falv } 12$ | ${ }^{21}{ }^{\text {LBRN }}{ }^{3}$ | $31 \quad 10$ | $41 \quad 10$ | $\begin{array}{\|ll\|} \hline 51 & 10 \\ \hline \end{array}$ | $\begin{gathered} 61 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{array}{\|c\|} \hline 710 \\ \text { TRAP } \end{array}$ | $81 \quad 10$ | $\begin{array}{\|c\|} \hline 91 \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { A1 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|ll\|} \hline \text { B1 } & 10 \end{array}$ | $\begin{array}{\|l\|} \hline \text { C1 } 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \hline \text { D1 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|c\|} \hline \text { E1 } 10 \\ \text { TRAP } \end{array}$ | $\begin{array}{lr} \hline \text { F1 } \quad 10 \\ \text { TRAP } \end{array}$ |
| EX-ID | IH | RL | IH | IH | IH | IH | H | IH | IH | IH | IH | IH | IH | IH | H |
| $\begin{array}{\|l\|} \hline 02 \\ \text { MOVW } \end{array}$ | $\begin{array}{lr} \hline 12 & 13 \\ \text { EMACS } \end{array}$ | $\begin{array}{\|cc\|} \hline 22 & 4 / 3 \\ \text { LBHI } \end{array}$ | $32 \quad 10$ | $\begin{gathered} 42 \\ \text { TRAP }^{10} \end{gathered}$ | $\begin{array}{\|l\|} \hline 52 \quad 10 \\ \hline \end{array}$ | $\begin{aligned} & 62{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|l\|} \hline 72 \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{gathered} 82 \\ \text { TRAP }^{10} \end{gathered}$ | $\begin{array}{\|cc\|} \hline 92 \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { A2 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{gathered} \mathrm{B}^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{array}{\|l\|} \hline \text { C2 } 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { D2 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { E2 }{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { F2 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ |
| ID-ID | SP | RL | IH | IH | IH | IH | IH | IH | IH | IH | H | IH | IH | IH 2 | H |
| $\begin{array}{lr} \hline 03 & 5 \\ \text { MOVW } \end{array}$ | $\begin{array}{lr} \hline 13 & 3 \\ \text { EMULS } \end{array}$ | $\begin{array}{\|cc\|} \hline 23 & 4 / 3 \\ \text { LBLS } \end{array}$ | $\begin{gathered} \hline 33 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} 43 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{array}{\|c\|} \hline 53 \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & 63{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{gathered} 73 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} 83 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{array}{\|c\|} \hline 93 \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{gathered} \text { A3 }{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & \text { B3 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|c\|} \hline \text { C3 } 10 \\ \text { TRAP } \end{array}$ | $\begin{array}{\|l\|} \hline \text { D3 }{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{array}{\|cc\|} \hline \text { E3 } 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \hline \text { F3 } \quad 10 \\ & \text { TRAP } \end{aligned}$ |
| IM-EX | IH | RL | IH | IH 2 | IH 2 | IH | IH | IH | IH | IH | IH | IH | IH | IH | H |
| $\begin{array}{\|l\|} \hline 04 \\ \text { MOVW } \end{array}$ | $\begin{array}{cc} 14 & 12 \\ \text { EDIVS } \end{array}$ | $\begin{array}{\|cc\|} \hline 24 & 4 / 3 \\ \text { LBCC } \end{array}$ | $\begin{gathered} \hline 34 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & 44{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & 54 \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & 64{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|c\|} \hline 74 \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{gathered} 84{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & 94 \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|c} \hline \text { A4 }{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{array}{\|c\|} \hline \text { B4 } 10 \\ \text { TRAP } \end{array}$ | $\begin{array}{\|l\|} \hline \text { C4 } 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { D4 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|cc\|} \hline \text { E4 }{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{array}{ll} \hline \text { F4 } \quad 10 \\ \text { TRAP } \end{array}$ |
| EX-EX 6 | IH | RL | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | H |
|  | $\begin{aligned} & 15 \quad 12 \\ & \text { IDIVS } \end{aligned}$ | $\begin{array}{\|cc\|} \hline 25 & 4 / 3 \\ \text { LBCS } \end{array}$ | $\begin{gathered} 35 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & 45 \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|c\|} \hline 55 \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & 65 \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|ll\|} \hline 75 & 10 \\ \hline \end{array}$ | $\begin{gathered} 85{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} 95 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & \text { A5 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { B5 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{ll} \hline \text { C5 } 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \hline \text { D5 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { E5 }{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { F5 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ |
| ID-EX | IH | RL | IH | IH 2 | IH | IH | IH | IH | IH 2 | IH | IH | IH | IH | IH | IH |
| ${ }^{06} \mathrm{ABA}^{2}$ | ${ }^{16} \mathrm{SBA}^{2}$ | $\begin{array}{\|cc\|} \hline 26 \quad 4 / 3 \\ \text { LBNE } \end{array}$ | $\begin{gathered} \hline 36 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & 46{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|c\|} \hline 56 \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & 66{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|l\|} \hline 76 \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{gathered} 86 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{array}{\|c\|} \hline 96 \quad{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { A6 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|l\|l\|} \hline \text { B6 }{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{array}{\|l\|} \hline \text { C6 }{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \hline \text { D6 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { E6 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { F6 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ |
| IH 2 | IH | RL 4 | IH | IH 2 | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH 2 | IH 2 |
| $07{ }^{07}{ }^{3}$ | ${ }^{17} \mathrm{CBA}^{2}$ | $\begin{array}{\|cc} \hline 27 & 4 / 3 \\ \text { LBEQ } \end{array}$ | $\begin{gathered} \hline 37 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} 47{ }^{47}{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{array}{\|cc} \hline 57 \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{gathered} 67{ }^{67}{ }^{10} \end{gathered}$ | $\begin{array}{\|c} \hline 77 \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{array}{ll} 87 \\ \\ \text { TRAP } \end{array}$ | $\begin{array}{\|c} 97 \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { A7 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { B7 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|c\|} \hline \text { C7 }{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { D7 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { E7 }{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { F7 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ |
| IH | IH 2 | RL 4 | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH |
| $\begin{array}{\|ll\|} \hline 08 & 4 \\ \text { MOVB } \end{array}$ | $\begin{aligned} & 18 \quad 4-7 \\ & \text { MAXA } \end{aligned}$ | $\begin{array}{\|cc\|} \hline 28 & 4 / 3 \\ \text { LBVC } \end{array}$ | $\begin{aligned} & 38 \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & 48 \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|cc} \hline 58 \quad{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{aligned} & 68{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|cc\|} \hline 78 \quad{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{aligned} & 88 \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{ll} \hline 98 \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{array}{ll} \hline \text { A8 } \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{array}{ll} \hline \text { B8 } \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{array}{\|l\|} \hline \text { C8 } 10 \\ \text { TRAP } \end{array}$ | $\begin{array}{cc} \hline \text { D8 } \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { E8 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & 10 \\ & \text { TRAP } \end{aligned}$ |
| IM-ID | ID 3-5 | RL | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH |
| $\begin{array}{\|l\|} \hline 09 \\ \mathrm{MOVB}^{5} \end{array}$ | $\begin{gathered} 19{ }^{4-1} \\ \text { MINA } \end{gathered}$ | $\begin{array}{\|cc\|} \hline 29 & 4 / 3 \\ \text { LBVS } \end{array}$ | P | $\begin{aligned} & 49 \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|c\|} \hline 59 \quad{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{aligned} & 10 \\ & A P \end{aligned}$ | $\begin{gathered} \hline 79 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} 89{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} 99 \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & \text { A9 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{ll} \hline \text { B9 } & 10 \\ \text { TRAP } \end{array}$ | $\begin{array}{\|l\|} \hline \text { C9 } \\ \text { TRAP } \end{array}$ | $\begin{array}{cc} \hline \text { D9 }{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { E9 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { F9 }{ }^{10} \\ & \text { TRAP } \end{aligned}$ |
| EX-ID | ID 3-5 | RL | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH | IH |
| $\begin{array}{\|c\|} \hline \text { OA } \\ \mathrm{MOVB}^{5} \end{array}$ | $1 \mathrm{~A} \quad 4$ EMAXD | $\begin{array}{cc} \hline 2 \mathrm{~A} \quad 4 / 3 \\ \text { LBPL } \end{array}$ | $\begin{gathered} { }^{*} 3 \mathrm{An} \\ \text { REV } \end{gathered}$ | $\begin{aligned} & \text { 4A }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|c\|} \hline \text { 5A }{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { 6A }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{gathered} \text { 7A } 10 \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} 8 \mathrm{~A} \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & 9 \mathrm{~A} \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \hline \text { AA }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \hline \text { BA }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \hline \text { CA }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { DA }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { EA }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { FA }{ }^{10} \\ & \text { TRAP } \end{aligned}$ |
| ID-ID | ID 3-5 | RL | SP | IH | IH | IH | IH | IH 2 | IH 2 | IH | IH | IH | IH | IH | IH |
| $\begin{array}{\|l\|} \hline \text { OB } \\ \text { MOVB } \end{array}$ | $\begin{aligned} & \hline \text { 1B } 4-7 \\ & \text { EMIND } \end{aligned}$ | $\begin{array}{\|cc\|} \hline \text { 2B } \quad 4 / 3 \\ \text { LBMI } \end{array}$ | $\begin{gathered} 3 B{ }^{*} 3 n \\ \text { REVW } \end{gathered}$ | $\begin{aligned} & \text { 4B }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{gathered} \hline \text { 5B }{ }^{10}{ }^{10} \\ \hline \end{gathered}$ | $\begin{aligned} & \text { 6B }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{gathered} \hline 7 \mathrm{~B} \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & 8 \mathrm{~B} \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & 9 \mathrm{~B} \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \hline \text { AB } \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \hline \text { BB }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { CB }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \hline{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { BB }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { FB } \quad 10 \\ & \text { TRAP } \end{aligned}$ |
| IM-EX 5 | ID 3-5 | RL 4 | SP | $1 \mathrm{H} \quad 2$ | IH | IH | IH | IH 2 | IH | IH | IH 2 | IH 2 | IH 2 | IH | IH |
| $\begin{array}{\|ll\|} \hline 0 \mathrm{C} & 6 \\ \mathrm{MOVB}^{2} \end{array}$ | 1C MAXM | $\begin{array}{\|cc\|} \hline \text { 2C } 4 / 3 \\ \text { LBGE } \end{array}$ | $\begin{gathered} 3 C^{*} 8 \\ \text { WAV } \end{gathered}$ | $\begin{aligned} & \text { 4C }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{cc} \hline 5 \mathrm{C} \quad 10 \\ \text { TRAP } \end{array}$ | ${ }^{10}$ | $\begin{array}{cc} \hline 7 C \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & 8 \mathrm{CB}{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & 9 \mathrm{CB}{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { C }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { BC }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { CC }{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{array}{cc} \hline \text { DC } \quad 10 \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { EC }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { FC }{ }^{10} \\ & \text { TRAP } \end{aligned}$ |
| EX-EX 6 | ID 3-5 | RL | SP | IH 2 | IH | IH | IH | IH 2 | IH | IH | IH 2 | IH 2 | IH 2 | IH 2 | IH |
| $\begin{array}{\|ll\|} \hline \text { OD } & 5 \\ \mathrm{MOVB}^{2} \end{array}$ | $\begin{array}{cc} \hline 1 \mathrm{D} \quad 4-7 \\ \text { MINM } \end{array}$ | 2D ${ }_{\text {LBLT }}$ | 3D ${ }^{\text {TBL }}$ | $\begin{gathered} \text { 4D }{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} \hline \text { 5D }{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} \hline \text { 6D }{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} \text { 7D }{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & \hline 8 \mathrm{D} \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{gathered} 9 \mathrm{D} \quad 10 \\ \mathrm{TRAP} \end{gathered}$ | $\begin{aligned} & \hline \text { AD } 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { BD }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { CD }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{gathered} \hline \text { DD }{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & \text { ED } 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { FD }{ }^{10} \\ & \text { TRAP } \end{aligned}$ |
| ID-EX 5 | ID 3-5 | RL | ID 3 | IH 2 | IH 2 | IH 2 | IH | $1 \mathrm{H} \quad 2$ | IH 2 | IH 2 | IH 2 | IH | IH 2 | IH | IH |
| ${ }^{0 E_{T A B}}{ }^{2}$ | $\begin{array}{\|rr} \hline 1 \mathrm{E} & 4-7 \\ \text { EMAXM } \end{array}$ | $\begin{gathered} \hline \text { 2E } 4 / 3 \\ \text { LBGT } \end{gathered}$ | $\begin{gathered} \mathrm{3E}^{*} 9+5 \\ \text { STOP } \end{gathered}$ | $\begin{aligned} & 4 \mathrm{E} \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { 5E }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { 6E }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{gathered} \text { 7E }{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & 8 \mathrm{E} \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & 9 \mathrm{E} \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \hline \text { AE } \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \text { BE }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{gathered} \hline \text { CE } \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} \hline \text { DE } \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & ={ }^{-E}{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & ={ }^{-10} \\ & \text { TRAP } \end{aligned}$ |
| $1 \mathrm{H} \quad 2$ | ID 3-5 | RL | IH 2 | IH 2 | IH 2 | IH 2 | IH | IH 2 | IH | IH | IH 2 | IH 2 | IH | IH | IH |
| ${ }^{0 F_{B A}}{ }^{2}$ | $\begin{array}{lr} 1 F & 4-7 \\ \text { EMINM } \end{array}$ | $\begin{gathered} \hline 2 \mathrm{~F} \quad 4 / 3 \\ \text { LBLE } \end{gathered}$ | $\begin{array}{cr} 3 F & 10 \\ E T B L \end{array}$ | $\begin{aligned} & \text { 4F }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{gathered} \hline \text { 5F }{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} 6 \mathrm{~F} \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{gathered} \hline 7 \mathrm{~F} \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & 8 \mathrm{~F} \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & 9 \mathrm{~F} \quad 10 \\ & \text { TRAP } \end{aligned}$ | $\begin{gathered} \text { AF }{ }^{10} \\ \text { TRAP } \end{gathered}$ | $\begin{aligned} & \text { BF }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{gathered} \hline \text { CF } \quad 10 \\ \text { TRAP } \end{gathered}$ | $\begin{array}{cr} \hline \text { DF }{ }^{10} \\ \text { TRAP } \end{array}$ | $\begin{aligned} & \text { EF }{ }^{10} \\ & \text { TRAP } \end{aligned}$ | $\begin{aligned} & \hline \text { FF } \quad 10 \\ & \text { TRAP } \end{aligned}$ |
| IH 2 | ID 3-5 | RL | D | IH 2 | IH 2 | IH 2 | IH 2 | IH 2 | IH 2 | IH 2 | IH 2 | IH 2 | IH 2 | IH | IH 2 |

* Refer to instruction glossary for more information.
$\ddagger$ The opcode $\$ 04$ corresponds to one of the loop primitive instructions DBEQ, DBNE, IBEQ, IBNE, TBEQ, or TBNE.

Table A-3 Indexed Addressing Mode Postbyte Encoding (xb)

| 00 0, X 5b const | $10$ $-16, X$ <br> 5b const | $\begin{array}{\|ll} \hline 20 & \\ \text { pre-inc } \\ \hline \end{array}$ | $301, \mathrm{X}+$ post-inc | $\begin{array}{cc} 40 \\ 5 \mathrm{O} \text { const } \end{array}$ | $\begin{aligned} & 50-16, Y \\ & 5 b \text { const } \end{aligned}$ | $\begin{array}{ll} 60 & \\ 1,+Y \\ \text { pre-inc } \end{array}$ | $\begin{array}{lr} 70 \\ & 1, Y_{+} \\ \text {post-inc } \end{array}$ | $\begin{array}{ll} 80 \\ 0, S P \\ 5 b & \text { const } \end{array}$ | $\begin{aligned} & 90 \\ & \quad-16, \mathrm{SP} \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & \mathrm{A} 0 \\ & 1,+\mathrm{SP} \\ & \text { pre-inc } \end{aligned}$ | $\begin{aligned} & \mathrm{B0} \\ & \text { 1,SP+ } \\ & \text { post-inc } \end{aligned}$ | $\begin{aligned} & \mathrm{CO} \\ & 0, \mathrm{PC} \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | D0 $-16, P C$ <br> 5b const | $\begin{array}{\|l\|} \hline \text { E0 } \\ \text { n, } X \\ 9 b \text { const } \end{array}$ | $\begin{array}{\|l\|} \hline \text { F0 } \\ \text { n,SP } \\ 9 b \text { const } \\ \hline \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{ll} \hline 01 & \\ & 1, X \\ \hline \end{array}$ $5 \mathrm{~b} \text { const }$ | $11$ <br> -15, X 5b const | $\underbrace{21}_{2,+\mathrm{X}}$ pre-inc | 31 <br> 2, X+ post-inc | $\left\lvert\, \begin{array}{cc} 41 & 1, Y \\ 5 b & \text { const } \end{array}\right.$ | $\begin{array}{ll} 51-15, Y \\ 5 h \end{array}$ | $\int_{\text {nro-in }}^{61}$ | $\begin{array}{\|r} 71 \\ 2, Y_{+} \\ \text {post-inc } \end{array}$ | $\begin{array}{ll} 81 \\ & 1, \mathrm{SP} \\ 5 \mathrm{~b} \text { const } \end{array}$ | $\begin{array}{\|l\|} \hline 91 \\ 5 \mathrm{~b} \text { const } \end{array}$ | $\begin{aligned} & \text { A1 } \\ & \text { 2,+SP } \\ & \text { pre-inc } \end{aligned}$ | $\begin{aligned} & \mathrm{B} 1 \\ & \text { 2,SP+ } \\ & \text { post-inc } \end{aligned}$ | C1 <br> 1,PC <br> 5b const | D1 $-15, P C$ <br> 5b const | E1 $\begin{array}{ll}\text { En, } \\ \text { 9b } & \\ \text { nonst }\end{array}$ | $\begin{array}{\|l\|} \hline \mathrm{F} 1 \\ \text {-n, } \mathrm{SP} \\ 9 \mathrm{~b} \text { const } \end{array}$ |
| $02$ | 12 <br> -14, X $5 b$ const | $\begin{array}{\|c} 22 \\ 3,+\mathrm{X} \\ \text { pre-inc } \end{array}$ | 32 <br> $3, X_{+}$ post-inc | $\begin{array}{lr} 42 & 2, Y \\ 5 b & \text { const } \end{array}$ | $\begin{array}{lr} 52 & -14, Y \\ 5 b \text { const } \end{array}$ | $\begin{array}{\|c\|} \hline 62 \\ 3,+Y \\ \text { pre-inc } \end{array}$ | $\begin{aligned} & 72 \\ & 3, Y_{+} \\ & \text {post-inc } \end{aligned}$ | $\begin{aligned} & 82 \\ & 2, \mathrm{SP} \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{array}{\|l\|} \hline 92 \\ -14, \mathrm{SP} \\ 5 \mathrm{~b} \text { const } \end{array}$ | $\begin{array}{\|l\|} \hline \text { A2 } \\ 3,+ \text { SP } \\ \text { pre-inc } \end{array}$ | $\begin{aligned} & \mathrm{B} 2 \\ & 3, \mathrm{SP}+ \\ & \text { post-inc } \end{aligned}$ | \|C2 2,PC <br> 5b const | D2 $-14, \mathrm{PC}$ <br> 5b const | $\begin{array}{\|l\|} \hline E 2 n, X \\ 16 b \text { const } \\ \hline \end{array}$ | $\begin{array}{\|l} \hline \text { F2 } n, S P \\ 16 \mathrm{~b} \text { const } \end{array}$ |
| 03 <br> 3, X <br> 5b const | 13 <br> $-13, \mathrm{X}$ <br> $5 b$ const | ${ }^{23} \quad 4,+X$ pre-inc | $33 \begin{array}{r}4, X_{+} \\ \text {post-inc }\end{array}$ | $\left\lvert\, \begin{array}{cc} 43 & 3, Y \\ 5 b & \text { const } \end{array}\right.$ | $\begin{aligned} & 53-13, Y \\ & 5 b \text { const } \end{aligned}$ | $6_{4,+Y}$ pre-inc | $\begin{array}{\|c} 734, Y_{+} \\ \text {post-inc } \end{array}$ | $\begin{aligned} & 83 \text { 3,SP } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{array}{\|c\|} \hline 93 \\ -13, \mathrm{SP} \\ 5 \mathrm{~b} \text { const } \end{array}$ | $\begin{aligned} & \text { A3 } \\ & \text { 4,+SP } \\ & \text { pre-inc } \end{aligned}$ | $\begin{aligned} & \text { B3 } \\ & \text { 4,SP+ } \\ & \text { post-inc } \end{aligned}$ | C3 <br> 3,PC <br> 5b const | D3 $-13, P C$ <br> 5b const | $\mathrm{E}^{[\mathrm{n}, \mathrm{X}]}$ | $\text { F3 }[n, S P]$ $16 \mathrm{~b} \text { indr }$ |
| 04 <br> $4, X$ <br> $5 b$ const | 14 <br> $-12, X$ 5b const | $24{ }_{5,+} \mathrm{X}$ pre-inc | $\begin{aligned} & 34 \\ & \text { 5, X+ } \\ & \text { post-inc } \end{aligned}$ | $\left\lvert\, \begin{array}{cc} 44 & 4, Y \\ 5 b & \text { const } \end{array}\right.$ | $\begin{aligned} & 54-12, Y \\ & 5 b \text { const } \end{aligned}$ | $\begin{aligned} & 64 \\ & \text { pre-+Y } \\ & \text { pre- } \end{aligned}$ |  | $\int_{4 \mathrm{4,SP}}^{84} \begin{aligned} & \text { const } \end{aligned}$ | $\begin{aligned} & 94 \\ & \quad-12, \mathrm{SP} \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { A4 } \\ \begin{array}{c} 5,+ \text { SP } \\ \text { pre-inc } \end{array} \\ \hline \end{array}$ | $\begin{aligned} & \text { B4 } \\ & \text { 5,SP+ } \\ & \text { post-inc } \end{aligned}$ | C4 <br> 4,PC <br> $5 b$ const | D4 $-12, \mathrm{PC}$ 5b const |  | F4 A,SP A offset |
| $\left.\right\|_{5, x}$ 5b const | $15$ <br> -11, X 5b const | $\int_{6,+X}$ pre-inc | $\left.\right\|^{35} \begin{aligned} & 6, X_{+} \\ & \text {post-inc } \end{aligned}$ | $\left\lvert\, \begin{array}{cc} 45 & 5, Y \\ 5 b \text { const } \end{array}\right.$ | $\begin{aligned} & 55-11, Y \\ & 5 b \text { const } \end{aligned}$ | ${ }_{\text {nro,+ }}^{65}$ |  | $\begin{aligned} & 85 \text { 5,SP } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{array}{\|l\|} \hline 95 \\ 5 \mathrm{~b} \text { const } \end{array}$ | $\begin{aligned} & \text { A5 } \\ & \begin{array}{l} 6,+ \text { SP } \\ \text { pre-inc } \end{array} \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { B5 } \\ & \begin{array}{l} 6, S P+ \\ \text { post-inc } \end{array} \end{aligned}$ | C5 5,PC 5b const | D5 <br> -11,PC <br> 5b const | E5  <br>  B,X <br> B offset  | $\begin{aligned} & \text { F5 } \\ & \begin{array}{l} \text { B,SP } \\ \text { B offset } \end{array} \end{aligned}$ |
| 06 <br> 6, X 5b const | $16$ -10,X <br> 5b const | ${ }^{26} \quad 7,+X$ pre-inc | $\begin{array}{ll} 36 \\ & 7, X+ \\ \text { nost-inc } \end{array}$ | $\begin{array}{\|cc} 46 \\ \text { 6,Y } \\ 5 b \text { const } \end{array}$ | $\left\lvert\, \begin{aligned} & 56-10, Y \\ & 5 b \text { const } \end{aligned}\right.$ | $\begin{array}{ll} 66 \\ 7,+Y \end{array}$ |  | $\begin{aligned} & 86 \\ & \text { 6b const } \\ & \text { 5b } \end{aligned}$ | $\begin{aligned} & 96 \\ & \quad-10, \mathrm{SP} \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & \text { A6 } \\ & \text { 7,+SP } \\ & \text { pre-inc } \end{aligned}$ | $\begin{aligned} & \mathrm{B6} \\ & \text { 7,SP+ } \\ & \text { post-inc } \end{aligned}$ | $\begin{aligned} & \text { C6 } \begin{array}{l} 6, \mathrm{PC} \\ 5 \mathrm{~b} \text { const } \end{array} \end{aligned}$ | D6 $-10, P C$ <br> 5b const | $\begin{array}{\|l\|l\|} \hline \text { E6 } \\ & \text { D,X } \\ \text { D offset } \end{array}$ | $\begin{array}{\|l\|} \hline \text { F6 } \\ \begin{array}{l} \text { D,SP } \\ \text { D offset } \end{array} \end{array}$ |
| $\begin{array}{\|cc\|} \hline 07 & \\ 5, X \\ 5, x \end{array}$ 5b const | $\begin{array}{\|cc} 17 & \\ 5 \mathrm{c} \\ \hline \text { const } \end{array}$ | ${ }^{27}{ }_{8,+\mathrm{X}}$ | $\begin{array}{\|r} 37 \\ 8, X_{+} \\ \text {post-inc } \end{array}$ | $\left\lvert\, \begin{aligned} & 47 \\ & \text { 7, } Y \text { const } \end{aligned}\right.$ | $\begin{cases}57 & \\ 5 b & -9, Y \\ 5 \text { const }\end{cases}$ | $\begin{aligned} & 67 \\ & \begin{array}{l} 8,+\mathrm{Y} \\ \text { pre-inc } \end{array} \\ & \hline \end{aligned}$ |  | $\begin{array}{ll} 87, \mathrm{SP} \\ 5 b & \\ 5 \mathrm{~b} \text { const } \end{array}$ | $\begin{aligned} & 97 \\ & \text {-9,SP } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { A7 } \\ \text { 8,+SP } \\ \text { pre-inc } \end{array}$ | $\begin{aligned} & \text { B7 } \\ & \text { 8,SP+ } \\ & \text { post-inc } \end{aligned}$ | $\begin{aligned} & \text { C7 }{ }_{7, \mathrm{PC}} \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & \mathrm{D7} 7 \\ & \text {-9, PC } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{array}{\|l\|l\|} \hline \mathrm{E} 7 \\ {[\mathrm{D}, \mathrm{X}]} \\ \mathrm{D} \text { indirect } \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline \text { F7 } \\ {[\mathrm{D}, \mathrm{SP}]} \\ \mathrm{D} \text { indirect } \\ \hline \end{array}$ |
| $08$ <br> 8, X 5b const | 18 <br> $-8, \mathrm{X}$ <br> 5b const | $\begin{array}{\|rr\|} \hline 28 & \\ 8,-\mathrm{X} \\ \text { pre-dec } \end{array}$ | 38 <br> 8,X-post-dec | $\left\lvert\, \begin{array}{cc} 48 & 8, Y \\ 5 b & \text { const } \end{array}\right.$ | $\left\lvert\, \begin{array}{ll} 58 & \\ 5 b & -8, Y \\ 5 \text { const } \end{array}\right.$ | $\begin{array}{\|c\|} \hline 68,-Y \\ \text { pre-dec } \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline 78 \\ 8, Y- \\ \text { post-dec } \end{array}$ | $\begin{aligned} & 88 \\ & 8 \mathrm{~B} \text { 8, SP } \\ & 5 \mathrm{const} \end{aligned}$ | $\begin{aligned} & 98-8, \mathrm{SP} \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & \text { A8 } \\ & \begin{array}{l} 8,- \text { SP } \\ \text { pre-dec } \end{array} \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { B8 } \\ \text { 8,SP- } \\ \text { post-dec } \end{array}$ | $\begin{aligned} & \mathrm{C} 8 \\ & 8, \mathrm{PC} \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & \text { D8 } \\ & \text {-8, PC } \\ & \text { b const } \end{aligned}$ | $\begin{aligned} & \text { E8 } \\ & \text { n, } Y \\ & 9 b \text { const } \end{aligned}$ |  |
| 09 <br> 9,X <br> 5b const | $19$ | ${ }^{29} \quad 7,-x$ pre-dec | $39 \text { 7,X- }$ post-dec | $\begin{array}{cc} 49 \\ 9, Y \\ 5 b \text { const } \end{array}$ | $\left\lvert\, \begin{array}{ll} 59 & \\ 5 b & -7, Y \\ 5 \text { const } \end{array}\right.$ | $\begin{aligned} & 69 \begin{array}{l} 7,-Y \end{array} \\ & \text { nre-der } \end{aligned}$ | $79$ <br> 7,Y-post-dec | $\begin{aligned} & 89 \\ & \text { 9,SP } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & 99-7, \mathrm{SP} \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & \text { A9 } \\ & \text { 7,-SP } \\ & \text { pre-dec } \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { B9 } \\ \text { 7,SP- } \\ \text { post-dec } \end{array}$ | C9 <br> 9,PC <br> 5b const | D9 $-7, \mathrm{PC}$ 5b const | $\begin{array}{\|ll} \text { E9 } & \\ \text {-n, } \\ 9 b \text { const } \end{array}$ | $\begin{aligned} & \text { F9 } \\ & \text {-n, PC } \\ & 9 \mathrm{~b} \text { const } \end{aligned}$ |
| $\begin{array}{ll} 0 \mathrm{~A} \\ & 10, \mathrm{X} \\ 5 \mathrm{~b} \end{array}$ | $1 \mathrm{~A} \underset{\substack{-6, \mathrm{X} \\ 5 \\ \text { nonst }}}{ }$ |  | 3 3A $\begin{gathered}6, X- \\ \text { post-dec }\end{gathered}$ | 4A <br> $10, Y$ <br> 5 b const | $\left\{\begin{array}{l} 5 \mathrm{~A} \\ \text {-6,Y } \\ 5 \mathrm{~b} \text { const } \end{array}\right.$ | $\left\lvert\, \begin{array}{r} 6 \mathrm{~A} \\ \text { pre-- }-\mathrm{Y} \end{array}\right.$ | 7A $6, Y-$ post-dec | $\begin{aligned} & 8 \mathrm{~A} \\ & \text { 10,SP } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & 9 \mathrm{~A} \\ & \text {-6,SP } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & \text { AA } \\ & \text { 6,-SP } \\ & \text { pre-dec } \end{aligned}$ | $\begin{aligned} & \text { BA } \\ & \text { 6,SP- } \\ & \text { post-dec } \end{aligned}$ | CA 10,PC 5b const | DA $-6, P C$ 5b const | $\begin{array}{\|l\|} \hline E A \\ n, Y \\ 16 \mathrm{~b} \text { const } \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline \text { FA } \\ \text { n, PC } \\ 16 \mathrm{~b} \text { const } \end{array}$ |
| OB <br> 11,X 5b const |  | ${ }_{5,-\mathrm{X}}^{2 \mathrm{X}^{2}}$ pre-dec | $\begin{array}{\|c\|} \hline \text { 3B } \\ 5, \mathrm{X}- \\ \text { post-dec } \end{array}$ | $\left\{\begin{array}{l} 4 \mathrm{~B} \\ \text { 11,Y } \\ 5 \mathrm{~b} \text { const } \end{array}\right.$ | $\begin{array}{\|c\|} \hline 5 B \\ 5 \mathrm{~b}, \mathrm{Y} \\ 5 \mathrm{const} \end{array}$ | ${ }_{5,-Y}$ pre-dec | ```7B \[ 5, Y- \] post-dec``` | $\begin{aligned} & 8 \mathrm{~B} \\ & \begin{array}{l} 11, \mathrm{SP} \\ 5 \mathrm{~b} \text { const } \end{array} \end{aligned}$ | $\begin{array}{\|c} \hline 9 \mathrm{~B} \\ \hline-5, \mathrm{SP} \\ 5 \mathrm{~b} \text { const } \end{array}$ | $\begin{aligned} & \mathrm{AB} \\ & \begin{array}{c} 5,-\mathrm{SP} \\ \text { pre-dec } \end{array} \end{aligned}$ | $\begin{array}{\|c\|} \hline \mathrm{BB} \\ 5, \mathrm{SP}- \\ \text { post-dec } \end{array}$ | CB <br> 11,PC <br> 5b const | $\begin{array}{\|l\|} \hline \text { DB } \\ -5, \mathrm{PC} \\ 5 \mathrm{~b} \text { const } \end{array}$ | $\begin{aligned} & \mathrm{EB}{ }_{[\mathrm{n}, \mathrm{Y}]} \\ & 16 \mathrm{~b} \text { indr } \end{aligned}$ | $\begin{aligned} & \hline \text { FB } \\ & \text { [n, PC] } \\ & 16 \mathrm{~b} \text { indr } \end{aligned}$ |
| OC <br> 12,X <br> 5b const | 1C <br> $-4, \mathrm{X}$ 5b const | ${ }^{2 C_{4,-X}}$ pre-dec | $\begin{array}{\|c\|} \hline 3 \mathrm{C} \\ \text { 4,X- } \\ \text { post-dec } \end{array}$ | $\left\{\begin{array}{l} 4 C_{12, Y} \\ 5 b \text { const } \end{array}\right.$ | $\begin{aligned} & 5 \mathrm{C} \\ & \text { 5b const } \end{aligned}$ | $\begin{aligned} & 6 \mathrm{C} \\ & \text { 4,-Y } \\ & \text { pre-dec } \end{aligned}$ | $7 C_{4, Y-}$ post-dec | $\begin{aligned} & 8 \mathrm{C} \\ & \text { 12,SP } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & 9 \mathrm{C} \\ & \text {-4,SP } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & \text { AC } \\ & \text { 4,--SP } \\ & \text { pre-dec } \end{aligned}$ | $\begin{aligned} & \hline \mathrm{BC} \\ & \text { 4,SP- } \\ & \text { post-dec } \end{aligned}$ | $\begin{aligned} & \hline C \mathrm{CC} \\ & 5 \mathrm{l}, \mathrm{PC} \\ & 5 \mathrm{const} \end{aligned}$ | $\begin{aligned} & \text { DC } \\ & 5 \mathrm{-4,PC} \\ & 5 \text { const } \end{aligned}$ |  | $\begin{aligned} & \text { FC } \\ & \text { A,PC } \\ & \text { A offset } \end{aligned}$ |
| $\left\lvert\, \begin{array}{lr} \text { OD } & \\ \text { 13, } \\ 5 \mathrm{~b} \text { const } \end{array}\right.$ 5b const | 1D $-3, X$ 5b const | $\begin{aligned} & \text { 2D } \begin{array}{r} 3,-\mathrm{X} \\ \text { pre-dec } \end{array} \end{aligned}$ | $\begin{array}{\|l\|} \hline 3 \mathrm{D} \\ \begin{array}{r} 3, \mathrm{X}- \\ \text { post-dec } \end{array} \end{array}$ | $\begin{aligned} & 4 \mathrm{D} \\ & \text { 13,Y } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & 5 \mathrm{D} \\ & \text {-3,Y } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ |  |  | $\begin{aligned} & 8 \mathrm{D} \\ & 13, \mathrm{SP} \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & 9 \mathrm{D} \\ & 5 \mathrm{~B}, \mathrm{SP} \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { AD } \\ 3,--S P \\ \text { pre-dec } \end{array}$ | $\begin{array}{\|l\|} \hline \text { BD } \\ 3, S P- \\ \text { post-dec } \end{array}$ | CD <br> 13, PC <br> 5b const | $\begin{aligned} & \text { DD } \\ & 5 \mathrm{~b} \text {-3, PC } \\ & \text { 5 } \end{aligned}$ |  |  |
| $\mathrm{OE}_{14, \mathrm{X}}$ 5b const | $\left\lvert\, \begin{aligned} & 1 \mathrm{E} \\ & -2, \mathrm{X} \\ & 5 \mathrm{~b} \text { const } \end{aligned}\right.$ | $\begin{aligned} & \text { 2E } \left.\begin{array}{l} 2,-X \\ \text { pre-d } \end{array} \right\rvert\, \end{aligned}$ | $\begin{array}{\|l\|} \hline 3 E_{2, \mathrm{X}} \\ \text { post-dec } \end{array}$ | $\begin{aligned} & 4 \mathrm{E} \\ & \text { 14,Y } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & 5 \mathrm{E} \\ & \text { }-2, Y \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ |  |  | $\begin{gathered} 8 \mathrm{E} \\ \text { 14,SP } \\ 5 \mathrm{~b} \text { const } \end{gathered}$ | $\begin{gathered} 9 \mathrm{E} \\ \text {-2,SP } \\ 5 \mathrm{~b} \text { const } \end{gathered}$ | $\begin{aligned} & \mathrm{AE} \\ & 2,-\mathrm{SP} \\ & \text { pre-dec } \end{aligned}$ | $\begin{aligned} & \text { BE } \\ & \text { 2,SP- } \\ & \text { post-dec } \end{aligned}$ |  | $\begin{aligned} & \text { DE } \\ & 5 \mathrm{-2,PC} \\ & 5 \text { const } \end{aligned}$ | $\begin{array}{\|l\|} \hline \text { EE } \\ \text { D,Y } \\ \text { D offset } \end{array}$ | $\begin{array}{\|l\|} \hline \text { FE } \\ \text { D,PC } \\ \text { D offset } \end{array}$ |
| $\begin{array}{\|l\|} \hline 0 F \\ \text { 15,x } \\ 5 b \text { const } \end{array}$ | $\begin{array}{\|c\|} \hline 1 F \\ 5 b \text { const } \end{array}$ | $\mathrm{LF}_{\text {nre-d,- }}$ | $\begin{aligned} & \text { 3F } \\ & \text { post-dec } \end{aligned}$ | $\begin{aligned} & 4 \mathrm{~F} \\ & \text { 15,Y } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ |  | $\left\lvert\, \begin{array}{ll} 6 \mathrm{~F} & \\ \text { 1,-Y } \\ \text { pre-dec } \end{array}\right.$ |  | $\begin{aligned} & 8 F_{15, S P} \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & 9 \mathrm{~F} \\ & -1, \mathrm{SP} \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{array}{\|l\|} \hline \mathrm{AF} \\ \text { 1,-SP } \\ \text { pre-dec } \end{array}$ | $\begin{aligned} & \text { BF } \\ & \text { 1,SP- } \\ & \text { post-dec } \end{aligned}$ | $\begin{aligned} & \hline \text { CF } \\ & \text { 15,PC } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | $\begin{aligned} & \text { DF } \\ & \text {-1,PC } \\ & 5 \mathrm{~b} \text { const } \end{aligned}$ | EF <br> [D, Y] <br> D indirect | $\begin{array}{\|l} \hline \text { FF } \\ \text { [D,PC] } \\ \mathrm{D} \text { indirect } \\ \hline \end{array}$ |

Table A-4 Transfer and Exchange Postbyte Encoding

| TRANSFERS |  |  |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\Downarrow$  <br> LS MS $\Rightarrow$ | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
| 0 | $A \Rightarrow A$ | $B \Rightarrow A$ | $C C R \Rightarrow A$ | TMP3 ${ }_{L} \Rightarrow \mathrm{~A}$ | $B \Rightarrow A$ | $\mathrm{X}_{\mathrm{L}} \Rightarrow \mathrm{A}$ | $\mathrm{Y}_{\mathrm{L}} \Rightarrow \mathrm{A}$ | $\mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{A}$ |
| 1 | $A \Rightarrow B$ | $B \Rightarrow B$ | $\mathrm{CCR} \Rightarrow \mathrm{B}$ | TMP3 ${ }_{L} \Rightarrow$ B | $B \Rightarrow B$ | $\mathrm{X}_{\mathrm{L}} \Rightarrow \mathrm{B}$ | $Y_{L} \Rightarrow B$ | $\mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{B}$ |
| 2 | A $\Rightarrow$ CCR | $B \Rightarrow C C R$ | $\mathrm{CCR} \Rightarrow \mathrm{CCR}$ | $\mathrm{TMP3}_{\mathrm{L}} \Rightarrow \mathrm{CCR}$ | $B \Rightarrow C C R$ | $\mathrm{X}_{\mathrm{L}} \Rightarrow \mathrm{CCR}$ | $Y_{L} \Rightarrow C C R$ | $\mathrm{SP}_{\mathrm{L}} \Rightarrow \mathrm{CCR}$ |
| 3 | sex:A $\Rightarrow$ TMP2 | sex: $B \Rightarrow$ TMP2 | sex:CCR $\Rightarrow$ TMP2 | TMP3 $\Rightarrow$ TMP2 | $\mathrm{D} \Rightarrow \mathrm{TMP2}$ | X $\Rightarrow$ TMP2 | $Y \Rightarrow$ TMP2 | $\mathrm{SP} \Rightarrow \mathrm{TMP} 2$ |
| 4 | $\begin{aligned} & \text { sex:A } \Rightarrow D \\ & \text { SEX } A, D \end{aligned}$ | $\begin{aligned} & \text { sex }: B \Rightarrow D \\ & \text { SEX } B, D \end{aligned}$ | $\begin{aligned} & \text { sex:CCR } \Rightarrow D \\ & \text { SEX CCR,D } \end{aligned}$ | TMP3 $\Rightarrow$ D | $\mathrm{D} \Rightarrow \mathrm{D}$ | X $\Rightarrow$ D | $\mathrm{Y} \Rightarrow \mathrm{D}$ | $\mathrm{SP} \Rightarrow \mathrm{D}$ |
| 5 | $\begin{aligned} & \text { sex:A } \Rightarrow X \\ & \text { SEX A,X } \end{aligned}$ | $\begin{aligned} & \text { sex }: B \Rightarrow X \\ & \text { SEX } B, X \end{aligned}$ | $\begin{aligned} & \text { sex:CCR } \Rightarrow X \\ & \text { SEX CCR,X } \end{aligned}$ | TMP3 $\Rightarrow$ X | D $\Rightarrow$ X | X $\Rightarrow$ X | $\mathrm{Y} \Rightarrow \mathrm{X}$ | $S P \Rightarrow X$ |
| 6 | $\begin{aligned} & \text { sex:A } \Rightarrow Y \\ & \text { SEX } A, Y \end{aligned}$ | $\begin{gathered} \text { sex: } B \Rightarrow Y \\ \text { SEX } B, Y \end{gathered}$ | $\begin{aligned} & \text { sex:CCR } \Rightarrow Y \\ & \text { SEX CCR, } Y \end{aligned}$ | TMP3 $\Rightarrow$ Y | $D \Rightarrow Y$ | $X \Rightarrow Y$ | $Y \Rightarrow Y$ | $S P \Rightarrow Y$ |
| 7 | $\begin{gathered} \text { sex:A } \Rightarrow \text { SP } \\ \text { SEX A,SP } \end{gathered}$ | $\begin{gathered} \text { sex: } B \Rightarrow \text { SP } \\ \text { SEX B,SP } \end{gathered}$ | $\begin{gathered} \text { sex:CCR } \Rightarrow \text { SP } \\ \text { SEX CCR,SP } \end{gathered}$ | TMP3 $\Rightarrow$ SP | $D \Rightarrow S P$ | $\mathrm{X} \Rightarrow \mathrm{SP}$ | $\mathrm{Y} \Rightarrow \mathrm{SP}$ | $\mathrm{SP} \Rightarrow \mathrm{SP}$ |
| EXCHANGES |  |  |  |  |  |  |  |  |
| $\Downarrow$  <br> LS MS $\Rightarrow$ | 8 | 9 | A | B | C | D | E | F |
| 0 | $A \Leftrightarrow A$ | $B \Leftrightarrow A$ | $\mathrm{CCR} \Leftrightarrow \mathrm{A}$ | $\begin{gathered} \mathrm{TMP} 3_{\mathrm{L}} \Rightarrow \mathrm{~A} \\ \$ 00: \mathrm{A} \Rightarrow \mathrm{TMP3} \end{gathered}$ | $\begin{aligned} & B \Rightarrow A \\ & A \Rightarrow B \end{aligned}$ | $\begin{gathered} X_{L} \Rightarrow A \\ \$ 00: A \Rightarrow X \end{gathered}$ | $\begin{gathered} Y_{L} \Rightarrow A \\ \$ 00: A \Rightarrow Y \end{gathered}$ | $\begin{gathered} S P_{\mathrm{L}} \Rightarrow \mathrm{~A} \\ \$ 00: A \Rightarrow S P \end{gathered}$ |
| 1 | $A \Leftrightarrow B$ | $B \Leftrightarrow B$ | CCR $\Leftrightarrow \mathrm{B}$ | $\begin{gathered} \mathrm{TMP3}_{\mathrm{L}} \Rightarrow \mathrm{~B} \\ \$ \mathrm{FF}: \mathrm{B} \Rightarrow \mathrm{TMP3} \end{gathered}$ | $\begin{gathered} B \Rightarrow B \\ \$ F F \Rightarrow A \end{gathered}$ | $\begin{gathered} X_{L} \Rightarrow B \\ \$ F F: B \Rightarrow X \end{gathered}$ | $\begin{gathered} Y_{L} \Rightarrow B \\ \$ F F: B \Rightarrow Y \end{gathered}$ | $\begin{aligned} S P_{\mathrm{L}} & \Rightarrow \mathrm{~B} \\ \$ \mathrm{FF}: B & \Rightarrow \mathrm{SP} \end{aligned}$ |
| 2 | A $\Leftrightarrow$ CCR | $\mathrm{B} \Leftrightarrow \mathrm{CCR}$ | CCR $\Leftrightarrow$ CCR | $\begin{gathered} \mathrm{TMP3}_{\mathrm{L}} \Rightarrow \mathrm{CCR} \\ \$ F F: C C R \Rightarrow \text { TMP3 } \end{gathered}$ | $\begin{gathered} \mathrm{B} \Rightarrow \mathrm{CCR} \\ \$ F \mathrm{~F}: C C R \Rightarrow \mathrm{D} \end{gathered}$ | $\begin{gathered} \mathrm{X}_{\mathrm{L}} \Rightarrow \mathrm{CCR} \\ \text { \$FF:CCR } \Rightarrow \mathrm{X} \end{gathered}$ | $\begin{gathered} \mathrm{Y}_{\mathrm{L}} \Rightarrow \mathrm{CCR} \\ \$ F F: C C R \Rightarrow \mathrm{Y} \end{gathered}$ | $\begin{gathered} S P_{\mathrm{L}} \Rightarrow \mathrm{CCR} \\ \$ \mathrm{FF}: \mathrm{CCR} \Rightarrow \mathrm{SP} \end{gathered}$ |
| 3 | $\begin{gathered} \$ 00: \mathrm{A} \Rightarrow \mathrm{TMP2} \\ \mathrm{TMP2} \mathrm{~L}_{\mathrm{L}} \Rightarrow \mathrm{~A} \end{gathered}$ | $\begin{gathered} \$ 00: \mathrm{B} \Rightarrow \mathrm{TMP2} \\ \mathrm{TMP2}_{\mathrm{L}} \Rightarrow \mathrm{~B} \end{gathered}$ | $\begin{gathered} \$ 00: C C R \Rightarrow \text { TMP2 } \\ \text { TMP2 }_{L} \Rightarrow C C R \end{gathered}$ | TMP3 $\Leftrightarrow$ TMP2 | $\mathrm{D} \Leftrightarrow \mathrm{TMP2}$ | X $\Leftrightarrow$ TMP2 | $Y \Leftrightarrow T M P 2$ | SP $\Leftrightarrow$ TMP2 |
| 4 | \$00:A $\Rightarrow$ D | \$00: $\mathrm{B} \Rightarrow \mathrm{D}$ | $\begin{gathered} \$ 00: C C R \Rightarrow D \\ B \Rightarrow C C R \end{gathered}$ | TMP3 $\Leftrightarrow$ D | $\mathrm{D} \Leftrightarrow \mathrm{D}$ | $X \Leftrightarrow D$ | $Y \Leftrightarrow D$ | $\mathrm{SP} \Leftrightarrow \mathrm{D}$ |
| 5 | $\begin{gathered} \$ 00: A \Rightarrow X \\ X_{L} \Rightarrow A \end{gathered}$ | $\begin{gathered} \$ 00: B \Rightarrow X \\ X_{L} \Rightarrow B \end{gathered}$ | $\begin{gathered} \$ 00: C C R \Rightarrow X \\ X_{L} \Rightarrow C C R \end{gathered}$ | TMP3 $\Leftrightarrow$ X | $D \Leftrightarrow X$ | $X \Leftrightarrow X$ | $Y \Leftrightarrow X$ | SP $\Leftrightarrow \mathrm{X}$ |
| 6 | $\begin{gathered} \$ 00: A \Rightarrow Y \\ Y_{L} \Rightarrow A \end{gathered}$ | $\begin{gathered} \$ 00: B \Rightarrow Y \\ Y_{L} \Rightarrow B \end{gathered}$ | $\begin{gathered} \$ 00: C C R \Rightarrow Y \\ Y_{L} \Rightarrow C C R \end{gathered}$ | TMP3 $\Leftrightarrow \mathrm{Y}$ | $D \Leftrightarrow Y$ | $X \Leftrightarrow Y$ | $Y \Leftrightarrow Y$ | $S P \Leftrightarrow Y$ |
| 7 | $\begin{gathered} \$ 00: A \Rightarrow S P \\ S P_{L} \Rightarrow A \end{gathered}$ | $\begin{gathered} \$ 00: B \Rightarrow S P \\ S P_{L} \Rightarrow B \end{gathered}$ | $\begin{gathered} \$ 00: C C R \Rightarrow S P \\ S P_{L} \Rightarrow \mathrm{CCR} \end{gathered}$ | TMP3 $\Leftrightarrow$ SP | $\mathrm{D} \Leftrightarrow \mathrm{SP}$ | $X \Leftrightarrow S P$ | $Y \Leftrightarrow S P$ | $\mathrm{SP} \Leftrightarrow \mathrm{SP}$ |

## Key to Table A-3



Table A-5 Indexed Addressing Mode Summary

| Postbyte Code (xb) | Operand Syntax | Comments |
| :---: | :---: | :---: |
| rrOnnnnn | $\left\lvert\, \begin{aligned} & , r \\ & n, r \\ & -n, r \end{aligned}\right.$ | 5-bit constant offset $n=-16 \text { to }+15$ <br> rr can specify X, Y, SP, or PC |
| 111rrOzs | $\begin{aligned} & \mathrm{n}, \mathrm{r} \\ & -\mathrm{n}, \mathrm{r} \end{aligned}$ | Constant offset (9- or 16-bit signed) <br> z- $\quad 0=9$-bit with sign in LSB of postbyte (s) $1 \text { = 16-bit }$ <br> if $z=s=1,16$-bit offset indexed-indirect (see below) rr can specify X, Y, SP, or PC |
| $111 \mathrm{rr011}$ | [n,r] | 16-bit offset indexed-indirect rr can specify X, Y, SP, or PC |
| rr1pnnnn | $\begin{aligned} & \mathrm{n},-\mathrm{r} \\ & \mathrm{n},+\mathrm{r} \\ & \mathrm{n}, \mathrm{r}- \\ & \mathrm{n}, \mathrm{r}+ \end{aligned}$ | Auto pre-decrement /increment or Auto post-decrement/increment; $\mathrm{p}=$ pre-( 0 ) or post-( 1 ), $\mathrm{n}=-8$ to $-1,+1$ to +8 rr can specify $\mathrm{X}, \mathrm{Y}$, or SP (PC not a valid choice) |
| 111rr1aa | $\begin{aligned} & \mathrm{A}, \mathrm{r} \\ & \mathrm{~B}, \mathrm{r} \\ & \mathrm{D}, \mathrm{r} \end{aligned}$ | Accumulator offset (unsigned 8-bit or 16-bit) $\begin{aligned} & \text { aa }-00=A \\ & 01=B \\ & 10=\text { D (16-bit) } \\ & 11=\text { see accumulator D offset indexed-indirect } \\ & \text { rr can specify X, Y, SP, or PC } \end{aligned}$ |
| 111rr111 | [D,r] | Accumulator D offset indexed-indirect rr can specify X, Y, SP, or PC |

Table A-6 Loop Primitive Postbyte Encoding (Ib)

| ${ }^{00}{ }^{\text {DBEQ }}{ }^{\text {A }}$ <br> (+) | ${ }^{10}{ }_{\text {DBEQ }}{ }^{\text {A }}$ $(-)$ | ${ }^{20}{ }^{\text {DBNE }}{ }^{\text {A }}$ <br> (+) | 30 A DBNE (-) | ${ }^{40}{ }_{\text {TBEQ }}{ }^{\mathrm{A}}$ $(+)$ | ${ }^{50}{ }_{\text {TBEQ }}{ }^{\text {A }}$ $(-)$ | $\begin{gathered} \overline{60}{ }^{\text {TBNE }} \end{gathered}$ $(+)$ | $\begin{gathered} 70{ }^{7}{ }^{\text {TBNE }} \end{gathered}$ $(-)$ | ${ }^{80}{ }^{\text {IBEQ }}$ $(+)$ | $\underset{(-)}{90}{ }^{\text {IBEQ }}$ | $\mathrm{ADNE}^{\mathrm{A}}$ $(+)$ | $\underset{{ }_{\text {IBNE }}{ }^{\mathrm{A}}}{ }$ $(-)$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{aligned} & 01 \\ & D_{B E Q} \end{aligned}$ <br> (+) | $\begin{array}{\|c} \hline 11 \\ \text { DBEQ }^{\mathrm{B}} \end{array}$ $(-)$ | ${ }^{21}{ }^{\text {DBNE }}$ <br> (+) | ${ }^{31}{ }^{\text {DBNE }}{ }^{\text {B }}$ <br> (-) | ${ }^{41}$ TBEQ $^{B}$ <br> (+) | ${ }^{51} \text { TBEQ }^{B}$ <br> (-) | ${ }^{61}$ TBNE $^{B}$ <br> (+) | ${ }^{71}{ }^{7 B N E}{ }^{B}$ <br> (-) | ${ }^{81} \mathrm{IBEQ}$ <br> (+) | ${ }^{91}{ }^{18} \mathrm{~B}$ <br> (-) | ${ }^{\text {A1 }}{ }^{\text {IBNE }}{ }^{\text {B }}$ <br> (+) | ${ }^{\mathrm{B} 1} \mathrm{IBNE}^{\mathrm{B}}$ <br> (-) |
| 02 | 12 | 22 | 32 | 42 | 52 | 62 | 72 | 82 | 92 | A2 | B2 |
| 03 | 13 | 23 | 33 | 43 | 53 | 63 | 73 | 83 | 93 | A3 | B3 |
| 04 DBEQ <br> (+) | $\begin{gathered} 14 \\ D^{D}{ }^{D} \end{gathered}$ <br> (-) | $\begin{array}{\|c} \hline 24 \text { D } \\ { }^{24} \text { DBNE } \end{array}$ <br> (+) | $\begin{array}{\|c} \hline 34 \text { D } \\ \text { DBNE } \end{array}$ <br> (-) | $\begin{array}{\|c\|} \hline 44 \\ \hline \text { TBEQ } \end{array}$ <br> (+) | $\begin{array}{\|c} 54 \\ \text { TBEQ } \\ \hline \end{array}$ <br> (-) | ${ }^{64 \text { DBNE }}$ <br> (+) | $\begin{array}{\|c} \hline 74 \mathrm{D} \\ \hline \text { TBNE } \end{array}$ $(-)$ | ${ }^{84}{ }_{\text {IBEQ }}$ <br> (+) | ${ }^{94}{ }^{\text {IBEQ }}$ | (+) | $\mathrm{BA}_{\mathrm{IBNE}}^{\mathrm{D}}$ <br> (-) |
| ${ }^{05}{ }^{\text {DBEQ }} \times$ <br> (+) | ${ }^{15}{ }_{D B E Q}$ <br> (-) | ${ }_{\text {DBNE }} \mathrm{X}$ <br> (+) | ${ }^{35} \mathrm{DBNE} \times$ <br> (-) | ${ }_{\text {TBEQ }} \mathrm{X}$ <br> (+) | ${ }_{\text {TBEQ }}{ }^{\mathrm{S5}}$ <br> (-) | ${ }_{\text {TBNE }} \mathrm{X}$ <br> (+) | ${ }^{75} \mathrm{TBNE}$ | ${ }^{85}{ }_{\text {IBEQ }} \mathrm{X}$ <br> (+) | ${ }^{95} \mathrm{IBEQ}$ <br> (-) | $\mathrm{A}_{\mathrm{IBNE}} \mathrm{X}$ <br> (+) | ${ }_{\text {IBNE }}^{\text {B5 }} \mathrm{X}$ <br> (-) |
| ${ }^{06}{ }^{06}{ }^{Y}$ <br> (+) | $\begin{gathered} 16 \mathrm{Y} \\ \mathrm{DBEQ}^{\prime} \end{gathered}$ <br> (-) | ${ }^{26}{ }^{26}{ }^{Y}$ <br> (+) | ${ }^{36}{ }^{\text {DBNE }}{ }^{Y}$ <br> (-) | ${ }^{46} \mathrm{TBEQ}^{Y}$ <br> (+) | ${ }^{56}$ TBEQ $^{Y}$ <br> (-) | ${ }^{66}{ }^{\text {TBNE }}{ }^{Y}$ <br> (+) | $\begin{gathered} 76 \\ \hline{ }^{7 B N E} \end{gathered}$ $(-)$ | ${ }^{86} \mathrm{IBEQ}$ <br> (+) | $\begin{gathered} 96 \\ \text { IBEQ } \end{gathered}$ <br> (-) | ${ }^{\text {A6 }}$ IBNE ${ }^{Y}$ <br> (+) | ${ }_{\text {B6NE }}{ }^{\text {B }}$ <br> (-) |
| $\begin{array}{\|cc} \hline 07 & \mathrm{SP} \\ \mathrm{DBEQ} \end{array}$ <br> (+) | $\begin{gathered} 17 \text { SP } \\ \text { DBEQ } \end{gathered}$ $(-)$ | 27 SP <br> (+) | 37 SP <br> (-) | 47 SP TBEQ <br> (+) | $57 \quad$ SP TBEQ <br> (-) | 67 SP TBNE <br> (+) | $77 \quad$ SP TBNE (-) | $\begin{gathered} 87 \\ \hline \text { IBEQ } \\ (+) \end{gathered}$ | $\begin{gathered} 97 \\ \hline \text { IBEQ } \\ (-) \end{gathered}$ | A7 SP <br> IBNE <br> (+) | B7 SP IBNE <br> (-) |



## APPENDIX B M68HC11 TO M68HC12 UPGRADE PATH

This appendix discusses similarities and differences between the CPU12 and the M68HC11 CPU. In general, the CPU12 is a proper superset of the M68HC11. Significant changes have been made to improve the efficiency and capabilities of the CPU without giving up compatibility and familiarity for the large community of M68HC11 programmers.

## B. 1 CPU12 Design Goals

The primary goals of the CPU12 design were:

- ABSOLUTE source code compatibility with the M68HC11
- Same programming model
- Same stacking operations
- Upgrade to 16-bit architecture
- Eliminate extra byte/extra cycle penalty for using index register Y
- Improve performance
- Improve compatibility with high level languages


## B. 2 Source Code Compatibility

Every M68HC11 instruction mnemonic and source code statement can be assembled directly with a CPU12 assembler with no modifications.
The CPU12 supports all M68HC11 addressing modes and includes several new variations of indexed addressing mode. CPU12 instructions affect condition code bits in the same way as M 68 HC 11 instructions.
CPU12 object code is similar to but not identical to M68HC11 object code. Some primary objectives, such as the elimination of the penalty for using Y , could not be achieved without object code differences. While the object code has been changed, the majority of the opcodes are identical to those of the M6800, which was developed more than 20 years earlier.
The CPU12 assembler automatically translates a few M68HC11 instruction mnemonics into functionally equivalent CPU12 instructions. For example, the CPU12 does not have an increment stack pointer (INS) instruction, so the INS mnemonic is translated to LEAS 1,S. The CPU12 does provide single-byte DEX, DEY, INX, and INY instructions because the LEAX and LEAY instructions do not affect the condition codes, while the M 68 HC 11 instructions update the $Z$ bit according to the result of the decrement or increment.
Table B-1 shows M68HC11 instruction mnemonics that are automatically translated into equivalent CPU12 instructions. This translation is performed by the assembler so there is no need to modify an old M68HC11 program in order to assemble it for the CPU12. In fact, the M68HC11 mnemonics can be used in new CPU12 programs.

Table B-1 Translated M68HC11 Mnemonics

| M68HC11 <br> Mnemonic | Equivalent CPU12 Instruction | Comments |
| :---: | :---: | :---: |
| $\begin{aligned} & \text { ABX } \\ & \text { ABY } \end{aligned}$ | LEAX B,X LEAY B,Y | Since CPU12 has accumulator offset indexing, ABX and ABY are rarely used in new CPU12 programs. ABX was one byte on M68HC11 but ABY was two bytes. The LEA substitutes are two bytes. |
| $\begin{aligned} & \hline \text { CLC } \\ & \text { CLI } \\ & \text { CLV } \\ & \text { SEC } \\ & \text { SEI } \\ & \text { SEV } \end{aligned}$ | ANDCC \#\$FE ANDCC \#\$EF ANDCC \#\$FD ORCC \#\$01 ORCC \#\$10 ORCC \#\$02 | ANDCC and ORCC now allow more control over the CCR, including the ability to set or clear multiple bits in a single instruction. These instructions took one byte each on M68HC11 while the ANDCC and ORCC equivalents take two bytes each. |
| $\begin{aligned} & \text { DES } \\ & \text { INS } \end{aligned}$ | LEAS -1,S LEAS 1,S | Unlike DEX and INX, DES and INS did not affect CCR bits in the M68HC11, so the LEAS equivalents in CPU12 duplicate the function of DES and INS. These instructions were one byte on M68HC11 and two bytes on CPU12. |
| $\begin{gathered} \hline \text { TAP } \\ \text { TPA } \\ \text { TSX } \\ \text { TSY } \\ \text { TXS } \\ \text { TYS } \\ \text { XGDX } \\ \text { XGDY } \end{gathered}$ | TFR A,CCR TFR CCR,A TFR S, X TFR S, Y TFR X, S TFR Y, S EXG D,X EXG D,Y | The M68HC11 had a small collection of specific transfer and exchange instructions. CPU12 expanded this to allow transfer or exchange between any two CPU registers. For all but TSY and TYS (which take two bytes on either CPU), the CPU12 transfer/exchange costs one extra byte compared to the M 68 HC 11 . The substitute instructions execute in one cycle rather than two. |

All of the translations produce the same amount of or slightly more object code than the original M 68 HC 11 instructions. However, there are offsetting savings in other instructions. Y-indexed instructions in particular assemble into one byte less object code than the same M68HC11 instruction.

The CPU12 has a two-page opcode map, rather than the four-page M68HC11 map. This is largely due to redesign of the indexed addressing modes. Most of pages 2, 3, and 4 of the M 68 HC 11 opcode map are required because Y -indexed instructions use different opcodes than X-indexed instructions. Approximately two-thirds of the M68HC11 page 1 opcodes are unchanged in CPU12, and some M68HC11 opcodes have been moved to page 1 of the CPU12 opcode map. Object code for each of the moved instructions is one byte smaller than object code for the equivalent M68HC11 instruction. Table B-2 shows instructions that assemble to one byte less object code on the CPU12.

Instruction set changes offset each other to a certain extent. Programming style also affects the rate at which instructions appear. As a test, the BUFFALO monitor, an 8Kbyte M68HC11 assembly code program, was reassembled for the CPU12. The resulting object code is six bytes smaller than the M68HC11 code. It is fair to conclude that M68HC11 code can be reassembled with very little change in size.

Table B-2 Instructions with Smaller Object Code

| Instruction | Comments |
| :---: | :---: |
| $\begin{aligned} & \hline \text { DEY } \\ & \text { INY } \end{aligned}$ | Page 2 opcodes in M68HC11 but page 1 in CPU12. |
| INST n, Y | For values of $n$ less than 16 (the majority of cases). Were on page 2, now are on page 1. Applies to BSET, BCLR, BRSET, BRCLR, NEG, COM, LSR, ROR, ASR, ASL, ROL, DEC, INC, TST, JMP, CLR, SUB, CMP, SBC, SUBD, ADDD, AND, BIT, LDA, STA, EOR, ADC, ORA, ADD, JSR, LDS, and STS. If $X$ is the index reference and the offset is greater than 15 (much less frequent than offsets of 0,1 , and 2), the CPU12 instruction assembles to one byte more of object code than the equivalent M 68 HC 11 instruction. |
| $\begin{aligned} & \hline \text { PSHY } \\ & \text { PULY } \end{aligned}$ | Were on page 2, now are on page 1. |
| $\begin{aligned} & \hline \text { LDY } \\ & \text { STY } \\ & \text { CPY } \end{aligned}$ | Were on page 2, now are on page 1. |
| CPY n, Y <br> LDY n, Y <br> STY n, Y | For values of n less than 16 (the majority of cases). Were on page 3, now are on page 1. |
| CPD | Was on page 2, 3, or 4, now on page 1. In the case of indexed with offset greater than 15, CPU12 and M68HC11 object code are the same size. |

The relative size of code for M68HC11 vs. code for CPU12 has also been tested by rewriting several smaller programs from scratch. In these cases, the CPU12 code is typically about $30 \%$ smaller. These savings are mostly due to improved indexed addressing.

It seems useful to mention the results of size comparisons done on C programs. A C program compiled for the CPU12 is about $30 \%$ smaller than the same program compiled for the M 68 HC 11 . The savings are largely due to better indexing.

## B. 3 Programmer's Model and Stacking

The CPU12 programming model and stacking order are identical to those of the M68HC11.

## B. 4 True 16-Bit Architecture

The M68HC11 is a direct descendant of the M6800, one of the first microprocessors, which was introduced in 1974. The M6800 was strictly an 8 -bit machine, with 8 -bit data buses and 8-bit instructions. As Motorola devices evolved from the M6800 to the M68HC11, a number of 16 -bit instructions were added, but the data buses remained eight bits wide, so these instructions were performed as sequences of 8 -bit operations. The CPU12 is a true 16-bit implementation, but it retains the ability to work with the mostly 8 -bit M68HC11 instruction set. The larger ALU of the CPU12 (it can perform some 20 -bit operations) is used to calculate 16 -bit pointers and to speed up math operations.

## B.4.1 Bus Structures

The CPU12 is a 16 -bit processor with 16 -bit data paths. Typical M68HC12 devices have internal and external 16-bit data paths, but some derivatives incorporate operating modes that allow for an 8-bit data bus, so that a system can be built with low-cost 8-bit program memory. M68HC12 MCUs include an on-chip integration module that manages the external bus interface. When the CPU makes a 16-bit access to a resource that is served by an 8-bit bus, the integration module performs two 8-bit accesses, freezes the CPU clocks for part of the sequence, and assembles the data into a 16-bit word. As far as the CPU is concerned, there is no difference between this access and a 16-bit access to an internal resource via the 16-bit data bus. This is similar to the way an M68HC11 can stretch clock cycles to accommodate slow peripherals.

## B.4.2 Instruction Queue

The CPU12 has a two-word instruction queue and a 16-bit holding buffer, which sometimes acts as a third word for queueing program information. All program information is fetched from memory as aligned 16-bit words, even though there is no requirement for instructions to begin or end on even word boundaries. There is no penalty for misaligned instructions. If a program begins on an odd boundary (if the reset vector is an odd address), program information is fetched to fill the instruction queue, beginning with the aligned word at the next address below the misaligned reset vector. The instruction queue logic starts execution with the opcode in the low order half of this word.

The instruction queue causes three bytes of program information (starting with the instruction opcode) to be directly available to the CPU at the beginning of every instruction. As it executes, each instruction performs enough additional program fetches to refill the space it took up in the queue. Alignment information is maintained by the logic in the instruction queue. The CPU provides signals that tell the queue logic when to advance a word of program information, and when to toggle the alignment status.

The CPU is not aware of instruction alignment. The queue logic includes a multiplexer that sorts out the information in the queue to present the opcode and the next two bytes of information as CPU inputs. The multiplexer determines whether the opcode is in the even or odd half of the word at the head of the queue. Alignment status is also available to the ALU for address calculations. The execution sequence for all instructions is independent of the alignment of the instruction.

The only situation where alignment can affect the number of cycles an instruction takes occurs in devices that have a narrow (8-bit) external data bus, and is related to optional program fetch cycles (O type cycles). O cycles are always performed, but serve different purposes determined by instruction size and alignment.

Each instruction includes one program fetch cycle for every two bytes of object code. Instructions with an odd number of bytes can use an O cycle to fetch an extra word of object code. If the queue is aligned at the start of an instruction with an odd byte count, the last byte of object code shares a queue word with the opcode of the next instruction. Since this word holds part of the next instruction, the queue cannot ad-
vance after the odd byte executes, or the first byte of the next instruction would be lost. In this case, the O cycle appears as a free cycle since the queue is not ready to accept the next word of program information. If this same instruction had been misaligned, the queue would be ready to advance and the O cycle would be used to perform a program word fetch.

In a single-chip system or in a system with the program in 16-bit memory, both the free cycle and the program fetch cycle take one bus cycle. In a system with the program in an external 8-bit memory, the O cycle takes one bus cycle when it appears as a free cycle, but it takes two bus cycles when used to perform a program fetch. In this case, the on-chip integration module freezes the CPU clocks long enough to perform the cycle as two smaller accesses. The CPU handles only 16 -bit data, and is not aware that the 16 -bit program access is split into two 8 -bit accesses.

In order to allow development systems to track events in the CPU12 instruction queue, two status signals (IPIPE[1:0]) provide information about data movement in the queue and about the start of instruction execution. A development system can use this information along with address and data information to externally reconstruct the queue. This representation of the queue can also track both the data and address buses.

## B.4.3 Stack Function

Both the M68HC11 and the CPU12 stack nine bytes for interrupts. Since this is an odd number of bytes, there is no practical way to assure that the stack will stay aligned. To assure that instructions take a fixed number of cycles regardless of stack alignment, the internal RAM in M68HC12 MCUs is designed to allow single cycle 16bit accesses to misaligned addresses. As long as the stack is located in this special RAM, stacking and unstacking operations take the same amount of execution time, regardless of stack alignment. If the stack is located in an external 16-bit RAM, a PSHX instruction can take two or three cycles depending upon the alignment of the stack. This extra access time is transparent to the CPU because the integration module freezes the CPU clocks while it performs the extra 8 -bit bus cycle required for a misaligned stack operation.

The CPU12 has a "last-used" stack rather than a "next-available" stack like the M68HC11 CPU. That is, the stack pointer points to the last 16-bit stack address used, rather than to the address of the next available stack location. This generally has very little effect, because it is very unusual to access stacked information using absolute addressing. The change allows a 16 -bit word of data to be removed from the stack without changing the value of the SP twice.

To illustrate, consider the operation of a PULX instruction. With the next-available M68HC11 stack, if the SP = \$01F0 when execution begins, the sequence of operations is: $S P=S P+1$; load $X$ from $\$ 01 F 1: 01 F 2 ; S P=S P+1$; and the $S P$ ends up at $\$ 01 F 2$. With the last-used CPU12 stack, if the $\mathrm{SP}=\$ 01 \mathrm{FO}$ when execution begins, the sequence is: load X from \$01F0:01F1; SP = SP + 2; and the SP again ends up at \$01F2. The second sequence requires one less stack pointer adjustment.

The stack pointer change also affects operation of the TSX and TXS instructions. In the M68HC11, TSX increments the SP by one during the transfer. This adjustment causes the X index to point to the last stack location used. The TXS instruction operates similarly, except that it decrements the SP by one during the transfer. CPU12 TSX and TXS instructions are ordinary transfers - the CPU12 stack requires no adjustment.

For ordinary use of the stack, such as pushes, pulls, and even manipulations involving TSX and TXS, there are no differences in the way the M68HC11 and the CPU12 stacks look to a programmer. However, the stack change can affect a program algorithm in two subtle ways.

The LDS \#\$xxxx instruction is normally used to initialize the stack pointer at the start of a program. In the M68HC11, the address specified in the LDS instruction is the first stack location used. In the CPU12, however, the first stack location used is one address lower than the address specified in the LDS instruction. Since the stack builds downward, M68HC11 programs reassembled for the CPU12 operate normally, but the program stack is one physical address lower in memory.

In very uncommon situations, such as test programs used to verify CPU operation, a program could initialize the SP, stack data, and then read the stack via an extended mode read (it is normally improper to read stack data from an absolute extended address). To make an M68HC11 source program that contains such a sequence work on the CPU12, change either the initial LDS \#\$xxxx, or the absolute extended address used to read the stack.

## B. 5 Improved Indexing

The CPU12 has significantly improved indexed addressing capability, yet retains compatibility with the M68HC11. The one cycle and one byte cost of doing Y-related indexing in the M68HC11 has been eliminated. In addition, high level language requirements, including stack relative indexing and the ability to perform pointer arithmetic directly in the index registers, have been accommodated.

The M68HC11 has one variation of indexed addressing that works from X or Y as the reference pointer. For X indexed addressing, an 8-bit unsigned offset in the instruction is added to the index pointer to arrive at the address of the operand for the instruction. A load accumulator instruction assembles into two bytes of object code, the opcode and a 1-byte offset. Using $Y$ as the reference, the same instruction assembles into three bytes (a page prebyte, the opcode, and a one-byte offset.) Analysis of M 68 HC 11 source code indicates that the offset is most frequently zero and very seldom greater than four.

The CPU12 indexed addressing scheme uses a postbyte plus 0 , 1 , or 2 extension bytes after the instruction opcode. These bytes specify which index register is used, determine whether an accumulator is used as the offset, implement automatic pre/ post increment/decrement of indices, and allow a choice of 5-, 9-, or 16-bit signed offsets. This approach eliminates the differences between $X$ and $Y$ register use and dramatically enhances indexed addressing capabilities.

Major improvements that result from this new approach are:

- Stack pointer can be used as an index register in all indexed operations
- Program counter can be used as index register in all but auto inc/dec modes
- Accumulator offsets allowed using A, B, or D accumulators
- Automatic pre- or post-, increment or decrement (by -8 to +8)
- 5-bit, 9-bit, or 16-bit signed constant offsets
- 16-bit offset indexed-indirect and accumulator D offset indexed-indirect

The change completely eliminates pages three and four of the M68HC11 opcode map and eliminates almost all instructions from page two of the opcode map. For offsets of +0 to +15 from the $X$ index register, the object code is the same size as it was for the M 68 HC 11 . For offsets of +0 to +15 from the Y index register, the object code is one byte smaller than it was for the M68HC11.

Table A-5 summarizes M68HC12 indexed addressing mode capabilities. Table A-3 shows how the postbyte is encoded.

## B.5.1 Constant Offset Indexing

The CPU12 offers three variations of constant offset indexing in order to optimize the efficiency of object code generation.

The most common constant offset is zero. Offsets of $1,2, \ldots 4$ are used fairly often, but with less frequency than zero.

The 5-bit constant offset variation covers the most frequent indexing requirements by including the offset in the postbyte. This reduces a load accumulator indexed instruction to two bytes of object code, and matches the object code size of the smallest M68HC11 indexed instructions, which can only use $X$ as the index register. The CPU12 can use $X, Y$, SP, or PC as the index reference with no additional object code size cost.

The signed 9-bit constant offset indexing mode covers the same positive range as the M68HC11 8-bit unsigned offset. The size was increased to nine bits with the sign bit (ninth bit) included in the postbyte, and the remaining 8-bits of the offset in a single extension byte.

The 16-bit constant offset indexing mode allows indexed access to the entire normal $64-K b y t e$ address space. Since the address consists of 16 bits, the 16-bit offset can be regarded as a signed $(-32,768$ to +32767 ) or unsigned ( 0 to 65,535 ) value. In 16bit constant offset mode, the offset is supplied in two extension bytes after the opcode and postbyte.

## B.5.2 Auto-Increment Indexing

The CPU12 provides greatly enhanced auto increment and decrement modes of indexed addressing. In the CPU12, the index modification may be specified for before the index is used (pre-), or after the index is used (post-), and the index can be incremented or decremented by any amount from one to eight, independent of the size of the operand that was accessed. X, Y, and SP can be used as the index reference, but this mode does not allow PC to be the index reference (this would interfere with proper program execution).

This addressing mode can be used to implement a software stack structure, or to manipulate data structures in lists or tables, rather than manipulating bytes or words of data. Anywhere an M68HC11 program has an increment or decrement index register operation near an indexed mode instruction, the increment or decrement operation can be combined with the indexed instruction with no cost in object code size, as shown in the following code comparison.

| 18 A6 00 | LDAA 0,Y | A6 71 | LDAA 2,Y+ |
| :--- | :--- | :--- | :--- |
| 1808 | INY |  |  |
| 1808 | INY |  |  |

The M68HC11 object code requires seven bytes, while the CPU12 requires only two bytes to accomplish the same functions. Three bytes of M68HC11 code were due to the page prebyte for each Y-related instruction (\$18). CPU12 post-increment indexing capability allowed the two INY instructions to be absorbed into the LDAA indexed instruction. The replacement code is not identical to the original three instruction sequence because the $Z$ condition code bit is affected by the M68HC11 INY instructions, while the $Z$ bit in the CPU12 would be determined by the value loaded into $A$.

## B.5.3 Accumulator Offset Indexing

This indexed addressing variation allows the programmer to use either an 8-bit accumulator ( $A$ or $B$ ), or the 16 -bit $D$ accumulator as the offset for indexed addressing. This allows for a program-generated offset, which is more difficult to achieve in the M68HC11. The following code compares the M68HC11 and CPU12 operations.

| C6 05 |  | LDAB | \# \$5 | [2] | C6 05 |  | LDAB | \# \$5 | [1] |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CE 1000 | LOOP | LDX | \# \$1000 | [3] | CE 1000 |  | LDX | \#\$1000 | [2] |
| 3A |  | ABX |  | [3] | A6 E5 | LOOP | LDAA | B, X | [3] |
| A6 00 |  | LDAA | 0, X | [4] | 0431 FB |  | DBNE | B, LOOP | [3] |
| 5A |  | DECB |  | [2] |  |  |  |  |  |
| 26 F 7 |  | BNE | LOOP | [3] |  |  |  |  |  |

The CPU12 object code is only one byte smaller, but the LDX \# instruction is outside the loop. It is not necessary to reload the base address in the index register on each pass through the loop because the LDAA B, $X$ instruction does not alter the index register. This reduces the loop execution time from 15 cycles to six cycles. This reduction, combined with the $8-\mathrm{MHz}$ bus speed of the M68HC12 family, can have significant effects.

## B.5.4 Indirect Indexing

The CPU12 allows some forms of indexed indirect addressing where the instruction points to a location in memory where the address of the operand is stored. This is an extra level of indirection compared to ordinary indexed addressing. The two forms of indexed indirect addressing are 16-bit constant offset indexed indirect and D accumulator indexed indirect. The reference index register can be X, Y, SP, or PC as in other CPU12 indexed addressing modes. PC-relative indirect addressing is one of the more common uses of indexed indirect addressing. The indirect variations of indexed addressing help in the implementation of pointers. D accumulator indexed indirect addressing can be used to implement a runtime computed GOTO function. Indirect addressing is also useful in high level language compilers. For instance, PC-relative indirect indexing can be used to efficiently implement some C case statements.

## B. 6 Improved Performance

The CPU12 improves on M68HC11 performance in several ways. M68HC12 devices are designed using sub-micron design rules, and fabricated using advanced semiconductor processing, the same methods used to manufacture the M68HC16 and M68300 families of modular microcontrollers. M68HC12 devices have a base bus speed of eight MHz , and are designed to operate over a wide range of supply voltages. The 16-bit wide architecture also increases performance. Beyond these obvious improvements, the CPU12 uses a reduced number of cycles for many of its instructions, and a 20-bit ALU makes certain CPU12 math operations much faster.

## B.6.1 Reduced Cycle Counts

No M68HC11 instruction takes less than two cycles, but the CPU12 has more than 50 opcodes that take only one cycle. Some of the reduction comes from the instruction queue, which assures that several program bytes are available at the start of each instruction. Other cycle reductions occur because the CPU12 can fetch 16 bits of information at a time, rather than eight bits at a time.

## B.6.2 Fast Math

The CPU12 has some of the fastest math ever designed into a Motorola general-purpose MCU. Much of the speed is due to a 20-bit ALU that can perform two smaller operations simultaneously. The ALU can also perform two operations in a single bus cycle in certain cases. Table B-3 compares the speed of CPU12 and M68HC11 math instructions. The CPU12 requires fewer cycles to perform an operation, and the cycle time is half that of the M68HC11.

Table B-3 Comparison of Math Instruction Speeds

| Instruction Mnemonic | Math Operation | $\begin{gathered} \text { M68HC11 } \\ 1 \text { Cycle }=250 \\ \text { ns } \end{gathered}$ | M68HC11 w/Coprocessor <br> 1 Cycle = 250 ns | CPU12 <br> 1 Cycle = 125 ns |
| :---: | :---: | :---: | :---: | :---: |
| MUL | $\begin{gathered} 8 \times 8=16 \\ \text { (signed) } \end{gathered}$ | 10 cycles | - | 3 cycles |
| EMUL | $\begin{gathered} 16 \times 16=32 \\ \text { (unsigned) } \end{gathered}$ | - | 20 cycles | 3 cycles |
| EMULS | $16 \times 16=32$ <br> (signed) | - | 20 cycles | 3 cycles |
| IDIV | $\begin{gathered} 16 \div 16=16 \\ \text { (unsigned) } \end{gathered}$ | 41 cycles | - | 12 cycles |
| FDIV | $\begin{gathered} 16 \div 16=16 \\ \text { (fractional) } \end{gathered}$ | 41 cycles | - | 12 cycles |
| EDIV | $\begin{gathered} 32 \div 16=16 \\ \text { (unsigned) } \end{gathered}$ | - | 33 cycles | 11 cycles |
| EDIVS | $\begin{gathered} 32 \div 16=16 \\ \text { (signed) } \end{gathered}$ | - | 37 cycles | 12 cycles |
| IDIVS | $\begin{gathered} 16 \div 16=16 \\ \text { (signed) } \end{gathered}$ | - | - | 12 cycles |
| EMACS | $\begin{aligned} & 32 \times(16 \times 16) \Rightarrow 32 \\ & \text { (signed MAC) } \end{aligned}$ | - | 20 cycles | 12 cycles |

The IDIVS instruction is included specifically for C compilers, where word-sized operands are divided to produce a word-sized result (unlike the $32 \div 16=16$ EDIV). The EMUL and EMULS instructions place the result in registers so a C compiler can choose to use only 16 bits of the 32 -bit result.

## B.6.3 Code Size Reduction

CPU12 assembly language programs written from scratch tend to be $30 \%$ smaller than equivalent programs written for the M68HC11. This figure has been independently qualified by Motorola programmers and an independent $C$ compiler vendor. The major contributors to the reduction appear to be improved indexed addressing and the universal transfer/exchange instruction.

In some specialized areas, the reduction is much greater. A fuzzy logic inference kernel requires about 250 bytes in the M 68 HC 11 , and the same program for the CPU12 requires about 50 bytes. The CPU12 fuzzy logic instructions replace whole subroutines in the M68HC11 version. Table lookup instructions also greatly reduce code space.

Other CPU12 code space reductions are more subtle. Memory to memory moves are one example. The CPU12 move instruction requires almost as many bytes as an equivalent sequence of M68HC11 instructions, but the move operations themselves do not require the use of an accumulator. This means that the accumulator often need not be saved and restored, which saves instructions.

Arithmetic on index pointers is another example. The M68HC11 usually requires that the content of the index register be moved into accumulator D, where calculations are performed, then back to the index register before indexing can take place. In the CPU12, the LEAS, LEAX, and LEAY instructions perform arithmetic operations directly on the index pointers. The pre-/post-increment/decrement variations of indexed addressing also allow index modification to be incorporated into an existing indexed instruction rather than performing the index modification as a separate operation.

Transfer and exchange operations often allow register contents to be temporarily saved in another register rather than having to save the contents in memory. Some CPU12 instructions such as MIN and MAX combine the actions of several M68HC11 instructions into a single operation.

## B. 7 Additional Functions

The CPU12 incorporates a number of new instructions that provide added functionality and code efficiency. Among other capabilities, these new instructions allow efficient processing for fuzzy logic applications and support subroutine processing in extended memory beyond the standard 64-Kbyte address map for M68HC12 devices incorporating this feature. Table B-4 is a summary of these new instructions. Subsequent paragraphs discuss significant enhancements.

Table B-4 New M68HC12 Instructions

| Mnemonic | Addressing Modes | Brief Functional Description |
| :---: | :---: | :--- |
| ANDCC | Immediate | AND CCR with Mask (replaces CLC, CLI, and CLV) |
| BCLR | Extended | Bit(s) Clear (added extended mode) |
| BGND | Inherent | Enter Background Debug Mode, if enabled |
| BRCLR | Extended | Branch if Bit(s) Clear (added extended mode) |
| BRSET | Extended | Branch if Bit(s) Set (added extended mode) |
| BSET | Extended | Bit(s) Set (added extended mode) |
| CALL | Extended, Indexed | Similar to JSR Except also Stacks PPAGE Value <br> With RTC instruction, allows easy access to >64-Kbyte space |
| CPS | Immediate, Direct, <br> Extended, and Indexed | Compare Stack Pointer |
| DBNE | Relative | Decrement and Branch if Equal to Zero (Looping Primitive) |
| DBEQ | Relative | Decrement and Branch if Not Equal to Zero (Looping Primitive) |
| EDIV | Inherent | Extended Divide Y:D/X = Y(Q) and D(R) (Unsigned) |
| EDIVS | Inherent | Extended Divide Y:D/X = Y(Q) and D(R) (Signed) |
| EMACS | Special | Multiply and Accumulate 16 $\times 16 \Rightarrow 32$ (Signed) |
| EMAXD | Indexed | Maximum of Two Unsigned 16-Bit Values |
| EMAXM | Indexed | Maximum of Two Unsigned 16-Bit Values |
| EMIND | Indexed | Minimum of Two Unsigned 16-Bit Values |
| EMINM | Indexed | Minimum of Two Unsigned 16-Bit Values |
| EMUL | Special | Extended Multiply $16 \times 16 \Rightarrow 32 ;$ M(idx) * D $\Rightarrow$ Y:D |
| EMULS | Special | Extended Multiply $16 \times 16 \Rightarrow 32$ (signed); M(idx) * D $\Rightarrow$ Y:D |
| ETBL | Special | Table Lookup and Interpolate (16-bit entries) |
| EXG | Inherent | Exchange Register Contents |
| IBEQ | Relative | Increment and Branch if Equal to Zero (Looping Primitive) |
| IBNE | Relative | Increment and Branch if Not Equal to Zero (Looping Primitive) |
| IDIVS | Inherent | Signed Integer Divide D/X $\Rightarrow$ X(Q) and D(R) (Signed) |

Table B-4 New M68HC12 Instructions (Continued)

| Mnemonic | Addressing Modes | Brief Functional Description |
| :---: | :---: | :---: |
| LBCC | Relative | Long Branch if Carry Clear (Same as LBHS) |
| LBCS | Relative | Long Branch if Carry Set (Same as LBLO) |
| LBEQ | Relative | Long Branch if Equal ( $\mathrm{Z}=1$ ) |
| LBGE | Relative | Long Branch if Greater than or Equal to Zero |
| LBGT | Relative | Long Branch if Greater than Zero |
| LBHI | Relative | Long Branch if Higher |
| LBHS | Relative | Long Branch if Higher or Same (Same as LBCC) |
| LBLE | Relative | Long Branch if Less than or Equal to Zero |
| LBLO | Relative | Long Branch if Lower (Same as LBCS) |
| LBLS | Relative | Long Branch if Lower or Same |
| LBLT | Relative | Long Branch if Less than Zero |
| LBMI | Relative | Long Branch if Minus |
| LBNE | Relative | Long Branch if Not Equal to Zero |
| LBPL | Relative | Long Branch if Plus |
| LBRA | Relative | Long Branch Always |
| LBRN | Relative | Long Branch Never |
| LBVC | Relative | Long Branch if Overflow Clear |
| LBVS | Relative | Long Branch if Overflow Set |
| LEAS | Indexed | Load Stack Pointer with Effective Address |
| LEAX | Indexed | Load X Index Register with Effective Address |
| LEAY | Indexed | Load Y Index Register with Effective Address |
| MAXA | Indexed | Maximum of Two Unsigned 8-Bit Values |
| MAXM | Indexed | Maximum of Two Unsigned 8-Bit Values |
| MEM | Special | Determine Grade of Fuzzy Membership |
| MINA | Indexed | Minimum of Two Unsigned 8-Bit Values |
| MINM | Indexed | Minimum of Two Unsigned 8-Bit Values |
| MOVB(W) | Combinations of Immediate, Extended, and Indexed | Move Data from One Memory Location to Another |
| ORCC | Immediate | OR CCR with Mask (replaces SEC, SEI, and SEV) |
| PSHC | Inherent | Push CCR onto Stack |
| PSHD | Inherent | Push Double Accumulator onto Stack |
| PULC | Inherent | Pull CCR Contents from Stack |
| PULD | Inherent | Pull Double Accumulator from Stack |
| REV | Special | Fuzzy Logic Rule Evaluation |
| REVW | Special | Fuzzy Logic Rule Evaluation with Weights |
| RTC | Inherent | Restore Program Page and Return Address from Stack Used with CALL Instruction, Allows Easy Access to >64-Kbyte Space |
| SEX | Inherent | Sign Extend 8-bit Register into 16-bit Register |
| TBEQ | Relative | Test and Branch if Equal to Zero (Looping Primitive) |
| TBL | Inherent | Table Lookup and Interpolate (8-bit Entries) |
| TBNE | Relative | Test Register and Branch if Not Equal to Zero (Looping Primitive) |
| TFR | Inherent | Transfer Register Contents to Another Register |
| WAV | Special | Weighted Average (Fuzzy Logic Support) |

## B.7.1 Memory-to-Memory Moves

The CPU12 has both 8- and 16-bit variations of memory-to-memory move instructions. The source address can be specified with immediate, extended, or indexed addressing modes. The destination address can be specified by extended or indexed addressing mode. The indexed addressing mode for move instructions is limited to modes that require no extension bytes (9- and 16-bit constant offsets are not allowed), and indirect indexing is not allowed for moves. This leaves a 5-bit signed constant offset, accumulator offsets, and the automatic increment/decrement modes. The following simple loop is a block move routine capable of moving up to 256 words of information from one memory area to another.

```
LOOP MOVW 2,X+ , 2,Y+ ;move a word and update pointers
    DBNE B,LOOP ;repeat B times
```

The move immediate to extended is a convenient way to initialize a register without using an accumulator or affecting condition codes.

## B.7.2 Universal Transfer and Exchange

The M68HC11 has only eight transfer instructions and two exchange instructions. The CPU12 has a universal transfer/exchange instruction that can be used to transfer or exchange data between any two CPU registers. The operation is obvious when the two registers are the same size, but some of the other combinations provide very useful results. For example when an 8 -bit register is transferred to a 16-bit register, a sign-extend operation is performed. Other combinations can be used to perform a zero-extend operation.

These instructions are used often in CPU12 assembly language programs. Transfers can be used to make extra copies of data in another register, and exchanges can be used to temporarily save data during a call to a routine that expects data in a specific register. This is sometimes faster and produces more compact object code than saving data to memory with pushes or stores.

## B.7.3 Loop Construct

The CPU12 instruction set includes a new family of six loop primitive instructions. These instructions decrement, increment, or test a loop count in a CPU register and then branch based on a zero or non-zero test result. The CPU registers that can be used for the loop count are A, B, D, X, Y, or SP. The branch range is a 9-bit signed value $(-512$ to +511$)$ which gives these instructions twice the range of a short branch instruction.

## B.7.4 Long Branches

All of the branch instructions from the M 68 HC 11 are also available with 16-bit offsets which allows them to reach any location in the 64-Kbyte address space.

## B.7.5 Minimum and Maximum Instructions

Control programs often need to restrict data values within upper and lower limits. The CPU12 facilitates this function with 8 - and 16-bit versions of MIN and MAX instructions. Each of these instructions has a version that stores the result in either the accumulator or in memory.

For example, in a fuzzy logic inference program, rule evaluation consists of a series of MIN and MAX operations. The min operation is used to determine the smallest rule input (the running result is held in an accumulator), and the max operation is used to store the largest rule truth value (in an accumulator) or the previous fuzzy output value (in a RAM location), to the fuzzy output in RAM. The following code demonstrates how MIN and MAX instructions can be used to evaluate a rule with four inputs and two outputs.

| LDY | \#OUT1 | ; Point at first output |
| :---: | :---: | :---: |
| LDX | \# IN1 | ;Point at first input value |
| LDAA | \# \$FF | ; start with largest 8-bit number in A |
| MINA | 1, X + | ; $\mathrm{A}=\mathrm{MIN}(\mathrm{A}, \mathrm{IN} 1)$ |
| MINA | 1, X + | ; $\mathrm{A}=\mathrm{MIN}(\mathrm{A}, \mathrm{IN} 2)$ |
| MINA | 1, X+ | ; $\mathrm{A}=\mathrm{MIN}(\mathrm{A}, \mathrm{IN} 3)$ |
| MINA | 1, X + | ; $\mathrm{A}=\mathrm{MIN}(\mathrm{A}, \mathrm{IN} 4)$ so A holds smallest input |
| MAXM | 1, Y+ | ; OUT1=MAX(A,OUT1) and A is unchanged |
| MAXM | 1, Y + | ; OUT1=MAX(A,OUT2) A still has min input |

Before this sequence is executed, the fuzzy outputs must be cleared to zeros (not shown). M68HC11 MIN or MAX operations are performed by executing a compare followed by a conditional branch around a load or store operation.
These instructions can also be used to limit a data value prior to using it as an input to a table lookup or other routine. Suppose a table is valid for input values between $\$ 20$ and \$7F. An arbitrary input value can be tested against these limits and be replaced by the largest legal value if it is too big, or the smallest legal value if too small using the following two CPU12 instructions.

```
HILIMIT FCB $7F ;comparison value needs to be in mem
LOWLIMIT FCB $20 ; so it can be referenced via indexed
    MINA HILIMIT,PCR ; A=MIN(A,$7F)
    MAXA LOWLIMIT,PCR;A=MAX(A,$20)
    ;A now within the legal range $20 to $7F
```

The ",PCR" notation is also new for the CPU12. This notation indicates the programmer wants an appropriate offset from the PC reference to the memory location (HILIMIT or LOWLIMIT in this example), and then to assemble this instruction into a PC-relative indexed MIN or MAX instruction.

## B.7.6 Fuzzy Logic Support

The CPU12 includes four instructions (MEM, REV, REVW, and WAV) specifically designed to support fuzzy logic programs. These instructions have a very small impact on the size of the CPU, and even less impact on the cost of a complete MCU. At the same time these instructions dramatically reduce the object code size and execution time for a fuzzy logic inference program. A kernel written for the M68HC11 required about 250 bytes and executed in about 750 milliseconds. The CPU12 kernel uses about 50 bytes and executes in about 50 microseconds.

## B.7.7 Table Lookup and Interpolation

The CPU12 instruction set includes two instructions (TBL and ETBL) for lookup and interpolation of compressed tables. Consecutive table values are assumed to be the $x$ coordinates of the endpoints of a line segment. The TBL instruction uses 8-bit table entries (y-values) and returns an 8-bit result. The ETBL instruction uses 16-bit table entries ( $y$-values) and returns a 16-bit result.

An indexed addressing mode is used to identify the effective address of the data point at the beginning of the line segment, and the data value for the end point of the line segment is the next consecutive memory location (byte for TBL and word for ETBL). In both cases, the B accumulator represents the ratio of (the x-distance from the beginning of the line segment to the lookup point) to (the x-distance from the beginning of the line segment to the end of the line segment). B is treated as an 8-bit binary fraction with radix point left of the MSB, so each line segment is effectively divided into 256 pieces. During execution of the TBL or ETBL instruction, the difference between the end point $y$-value and the beginning point $y$-value (a signed byte for TBL or a signed word for ETBL) is multiplied by the $B$ accumulator to get an intermediate delta-y term. The result is the $y$-value of the beginning point, plus this signed intermediate delta-y value.

## B.7.8 Extended Bit Manipulation

The M68HC11 CPU only allows direct or indexed addressing. This typically causes the programmer to dedicate an index register to point at some memory area such as the on-chip registers. The CPU12 allows all bit manipulation instructions to work with direct, extended or indexed addressing modes.

## B.7.9 Push and Pull D and CCR

The CPU12 includes instructions to push and pull the D accumulator and the CCR. It is interesting to note that the order in which 8-bit accumulators $A$ and $B$ are stacked for interrupts is the opposite of what would be expected for the upper and lower bytes of the 16 -bit D accumulator. The order used originated in the M6800, an 8-bit microprocessor developed long before anyone thought 16-bit single-chip devices would be made. The interrupt stacking order for accumulators $A$ and $B$ is retained for code compatibility.

## B.7.10 Compare SP

This instruction was added to the CPU12 instruction set to improve orthogonality and high-level language support. One of the most important requirements for C high-level language support is the ability to do arithmetic on the stack pointer for such things as allocating local variable space on the stack. The LEAS -5,SP instruction is an example of how the compiler could easily allocate five bytes on the stack for local variables. LDX 5,SP+ loads $X$ with the value on the bottom of the stack and deallocates five bytes from the stack in a single operation that takes only two bytes of object code.

## B.7.11 Support for Memory Expansion

Bank switching is a common method of expanding memory beyond the 64-Kbyte limit of a CPU with a 64-Kbyte address space, but there are some known difficulties associated with bank switching. One problem is that interrupts cannot take place during the bank switching operation. This increases worst case interrupt latency and requires extra programming space and execution time.

Some M68HC12 variants include a built-in bank switching scheme that eliminates many of the problems associated with external switching logic. The CPU12 includes CALL and return from call (RTC) instructions that manage the interface to the bankswitching system. These instructions are analogous to the JSR and RTS instructions, except that the bank page number is saved and restored automatically during execution. Since the page change operation is part of an uninterruptable instruction, many of the difficulties associated with bank switching are eliminated. On M68HC12 derivatives with expanded memory capability, bank numbers are specified by on-chip control registers. Since the addresses of these control registers may not be the same in all M68HC12 derivatives, the CPU12 has a dedicated control line to the on-chip integration module that indicates when a memory-expansion register is being read or written. This allows the CPU to access the PPAGE register without knowing the register address.

The indexed indirect versions of the CALL instruction access the address of the called routine and the destination page value indirectly. For other addressing mode variations of the CALL instruction, the destination page value is provided as immediate data in the instruction object code. CALL and RTC execute correctly in the normal $64-K b y t e ~ a d d r e s s ~ s p a c e, ~ t h u s ~ p r o v i d i n g ~ f o r ~ p o r t a b l e ~ c o d e . ~$

## APPENDIX C HIGH-LEVEL LANGUAGE SUPPORT

Many programmers are turning to high-level languages such as $C$ as an alternative to coding in native assembly languages. High-level language (HLL) programming can improve productivity and produce code that is more easily maintained than assembly language programs. The most serious drawback to the use of HLL in MCUs has been the relatively large size of programs written in HLL. Larger program ROM size requirements translate into increased system costs.

Motorola solicited the cooperation of third-party software developers to assure that the CPU12 instruction set would meet the needs of a more efficient generation of compilers. Several features of the CPU12 were specifically designed to improve the efficiency of compiled HLL, and thus minimize cost.

This appendix identifies CPU12 instructions and addressing modes that provide improved support for high-level language. C language examples are provided to demonstrate how these features support efficient HLL structures and concepts. Since the CPU12 instruction set is a superset of the M68HC11 instruction set, some of the discussions use the M68HC11 as a basis for comparison.

## C. 1 Data Types

The CPU12 supports the bit-sized data type with bit manipulation instructions which are available in extended, direct, and indexed variations. The char data type is a simple 8-bit value that is commonly used to specify variables in a small microcontroller system because it requires less memory space than a 16-bit integer (provided the variable has a range small enough to fit into eight bits). The 16-bit CPU12 can easily handle 16-bit integer types and the available set of conditional branches (including long branches) allow branching based on signed or unsigned arithmetic results. Some of the higher math functions allow for division and multiplication involving 32-bit values, although it is somewhat less common to use such long values in a microcontroller system.

The CPU12 has special sign extension instructions to allow easy type-casting from smaller data types to larger ones, such as from char to integer. This sign extension is automatically performed when an 8-bit value is transferred to a 16-bit register.

## C. 2 Parameters and Variables

High-level languages make extensive use of the stack, both to pass variables and for temporary and local storage. It follows that there should be easy ways to push and pull all CPU registers, stack pointer based indexing should be allowed, and that direct arithmetic manipulation of the stack pointer value should be allowed. The CPU12 instruction set provided for all of these needs with improved indexed addressing, the addition of an LEAS instruction, and the addition of push and pull instructions for the D accumulator and the CCR.

## C.2.1 Register Pushes and Pulls

The M68HC11 has push and pull instructions for $A, B, X$, and $Y$, but requires separate 8 -bit pushes and pulls of accumulators $A$ and $B$ to stack or unstack the 16-bit $D$ accumulator (the concatenated combination of $A: B$ ). The PSHD and PULD instructions allow directly stacking the $D$ accumulator in the expected 16-bit order.

Adding PSHC and PULC improved orthogonality by completing the set of stacking instructions so that any of the CPU registers can be pushed or pulled. These instructions are also useful for preserving the CCR value during a function call subroutine.

## C.2.2 Allocating and Deallocating Stack Space

The LEAS instruction can be used to allocate or deallocate space on the stack for temporary variables:

```
LEAS -10,S ;Allocate space for 5 16-bit integers
LEAS 10,S ;Deallocate space for 5 16-bit ints
```

The (de)allocation can even be combined with a register push or pull as in the following example:
LDX 8,S+ ;Load return value and deallocate

X is loaded with the 16-bit integer value at the top of the stack, and the stack pointer is adjusted up by eight to deallocate space for eight bytes worth of temporary storage. Post-increment indexed addressing is used in this example, but all four combinations of pre/post increment/decrement are available (offsets from -8 to +8 inclusive, from X , Y, or SP). This form of indexing can often be used to get an index (or stack pointer) adjustment for free during an indexed operation (the instruction requires no more code space or cycles than a zero-offset indexed instruction).

## C.2.3 Frame Pointer

In the C language, it is common to have a frame pointer in addition to the CPU stack pointer. The frame is an area of memory within the system stack which is used for parameters and local storage of variables used within a function subroutine. The following is a description of how a frame pointer can be set up and used.

First, parameters (typically values in CPU registers) are pushed onto the system stack prior to using a JSR or CALL to get to the function subroutine. At the beginning of the called subroutine, the frame pointer of the calling program is pushed onto the stack. Typically, an index register, such as X, is used as the frame pointer, so a PSHX instruction would save the frame pointer from the calling program.

Next, the called subroutine establishes a new frame pointer by executing a TFR S,X. Space is allocated for local variables by executing an LEAS $-n, S$, where $n$ is the number of bytes needed for local variables.

Notice that parameters are at positive offsets from the frame pointer while locals are at negative offsets. In the M68HC11, the indexed addressing mode uses only positive offsets, so the frame pointer always points to the lowest address of any parameter or local. After the function subroutine finishes, calculations are required to restore the stack pointer to the mid-frame position between the locals and the parameters before returning to the calling program. The CPU12 only requires execution of TFR X,S to deallocate the local storage and return.

The concept of a frame pointer is supported in the CPU12 through a combination of improved indexed addressing, universal transfer/exchange, and the LEA instruction. These instructions work together to achieve more efficient handling of frame pointers. It is important to consider the complete instruction set as a complex system with subtle interrelationships rather than simply examining individual instructions when trying to improve an instruction set. Adding or removing a single instruction can have unexpected consequences.

## C. 3 Increment and Decrement Operators

In C, the notation ++i or $\mathrm{i}--$ is often used to form loop counters. Within limited constraints, the CPU12 loop primitives can be used to speed up the loop count and branch function.

The CPU12 includes a set of six basic loop control instructions which decrement, increment, or test a loop count register, and then branch if it is either equal to zero or not equal to zero. The loop count register can be A, B, D, X, Y, or SP. A or B could be used if the loop count fits in an 8 -bit char variable; the other choices are all 16-bit registers. The relative offset for the loop branch is a 9-bit signed value, so these instructions can be used with loops as long as 256 bytes.

In some cases, the pre- or post-increment operation can be combined with an indexed instruction to eliminate the cost of the increment operation. This is typically done by post-compile optimization because the indexed instruction that could absorb the increment/decrement operation may not be apparent at compile time.

## C. 4 Higher Math Functions

In the CPU12, subtle characteristics of higher math operations such as IDIVS and EMUL are arranged so a compiler can handle inputs and outputs more efficiently.

The most apparent case is the IDIVS instruction, which divides two 16-bit signed numbers to produce a 16 -bit result. While the same function can be accomplished with the EDIVS instruction (a 32 by 16 divide), doing so is much less efficient because extra steps are required to prepare inputs to the EDIVS, and because EDIVS uses the Y index register. EDIVS uses a 32 -bit signed numerator and the C compiler would typically want to use a 16 -bit value (the size of an integer data type). The 16 -bit C value would need to be sign-extended into the upper 16-bits of the 32-bit EDIVS numerator before the divide operation.

Operand size is also a potential problem in the extended multiply operations but the difficulty can be minimized by putting the results in CPU registers. Having higher precision math instructions is not necessarily a requirement for supporting high-level language because these functions can be performed as library functions. However, if an application requires these functions, the code is much more efficient if the MCU can use native instructions instead of relatively large, slow routines.

## C. 5 Conditional If Constructs

In the CPU12 instruction set, most arithmetic and data manipulation instructions automatically update the condition code register, unlike other architectures that only change condition codes during a few specific compare instructions. The CPU12 includes branch instructions that perform conditional branching based on the state of the indicators in the condition codes register. Short branches use a single byte relative offset that allows branching to a destination within about $\pm 128$ locations from the branch. Long branches use a 16 -bit relative offset that allows conditional branching to any location in the 64 -Kbyte map.

## C. 6 Case and Switch Statements

Case and switch statements (and computed GOTOs) can use PC-relative indirect addressing to determine which path to take. Depending upon the situation, cases can use either the constant offset variation or the accumulator D offset variation of indirect indexed addressing.

## C. 7 Pointers

The CPU12 supports pointers by allowing direct arithmetic operations on the 16 -bit index registers (LEAS, LEAX, and LEAY instructions) and by allowing indexed indirect addressing modes.

## C. 8 Function Calls

Bank switching is a fairly common way of adapting a CPU with a 16 -bit address bus to accommodate more than 64 -Kbytes of program memory space. One of the most significant drawbacks of this technique has been the requirement to mask (disable) interrupts while the bank page value was being changed. Another problem is that the physical location of the bank page register can change from one MCU derivative to another (or even due to a change to mapping controls by a user program). In these situations, an operating system program has to keep track of the physical location of the page register. The CPU12 addresses both of these problems with the uninterruptible CALL and return from call (RTC) instructions.

The CALL instruction is similar to a JSR instruction, except that the programmer supplies a destination page value as part of the instruction. When CALL executes, the old page value is saved on the stack and the new page value is written to the bank page register. Since the CALL instruction is uninterruptible, this eliminates the need to separately mask off interrupts during the context switch.

The CPU12 has dedicated signal lines that allow the CPU to access the bank page register without having to use an address in the normal 64-Kbyte address space. This eliminates the need for the program to know where the page register is physically located.

The RTC instruction is similar to the RTS instruction, except that RTC uses the byte of information that was saved on the stack by the corresponding CALL instruction to restore the bank page register to its old value. Although a CALL/RTC pair can be used to access any function subroutine regardless of the location of the called routine (on the current bank page or a different page), it is most efficient to access some subroutines with JSR/RTS instructions when the called subroutine is on the current page or in an area of memory that is always visible in the 64-Kbyte map regardless of the bank page selection.

Push and pull instructions can be used to stack some or all the CPU registers during a function call. The CPU12 can push and pull any of the CPU registers A, B, CCR, D, X, Y, or SP.

## C. 9 Instruction Set Orthogonality

One very helpful aspect of the CPU12 instruction set, orthogonality, is difficult to quantify in terms of direct benefit to an HLL compiler. Orthogonality refers to the regularity of the instruction set. A completely orthogonal instruction set would allow any instruction to operate in any addressing mode, would have identical code sizes and execution times for similar operations on different registers, and would include both signed and unsigned versions of all mathematical instructions. Greater regularity of the instruction makes it possible to implement compilers more efficiently, because operation is more consistent, and fewer special cases must be handled.

# APPENDIX D <br> ASSEMBLY LISTING 

## D. 1 Assembler Test File

The following assembler test file illustrates all possible variations of the M68HC12 instruction set and can be used as a quick reference for instruction syntax. Instructions are in alphabetical order and include redundancy.

| * | 68HC12 assembly listing <br> * |  | d11b a9 2f | adca | 1, -x |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | d11d a9 6f | adca | 1,-y |
| 0072 | immed | equ $\quad \$ 72$ | d11f a9 a8 | adca | 8,-sp |
| 0055 | dir | equ $\$ 55$ | d121 a9 28 | adca | 8,-x |
| 1234 | ext | equ $\quad \$ 1234$ | d123 a9 68 | adca | 8,-y |
| 0037 | ind | equ \$37 | d125 a9 9f | adca | -1, sp |
| 000e | small | equ \$e | d127 a9 1f | adca | -1, x |
| 00 cc | mask | equ \%11001100 | d129 a9 5f | adca | -1, y |
|  |  |  | d12b a9 90 | adca | -16, sp |
|  |  | * | d12d a9 10 | adca | -16,x |
|  |  | * | d12f a9 50 | adca | -16,y |
| d000 | ORG | \$D000 | d131 a9 f1 ef | adca | -17, sp |
|  |  |  | d134 a9 e1 ef | adca | -17,x |
|  |  |  | d137 a9 e9 ef | adca | -17, y |
|  |  |  | d13a a9 d2 | adca | -small, pc |
|  |  |  | d13c a9 92 | adca | -small, sp |
| d000 0002 | dw | 2 | d13e a9 12 | adca | -small, x |
| d002 02 | db | 2 | d140 a9 52 | adca | -small,y |
| d003 0002 | dc.w | 2 | d142 a9 c0 | adca | 0, pc |
| d005 02 | dc.b | 2 | d144 a9 80 | adca | $0, \mathrm{sp}$ |
| d006 02 | fcb | 2 | d146 a9 00 | adca | 0,x |
| d007 08 ae | fdb | 2222 | d148 a9 40 | adca | 0, y |
| d009 | ds | 34 | d14a a9 b0 | adca | 1, sp+ |
| d02b | ds.b | 34 | d14c a9 30 | adca | 1,x+ |
| d04d | ds.w | 34 | d14e a9 e2 0188 | adca | ext, x |
| d091 | rmb | 34 | d152 a9 e2 8944 | adca | ext, x |
| d0b3 | rmw | 34 | d156 a9 e2 3333 | adca | ext, x |
|  |  |  | d15a a9 e2 4444 | adca | ext, x |
|  |  |  | d15e a9 e2 0188 | adca | ext, x |
|  |  |  | d162 a9 70 | adca | 1, $\mathrm{y}+$ |
|  |  |  | d164 a9 81 | adca | 1, sp |
| d0f7 1806 | aba |  | d166 a9 01 | adca | 1, x |
| d0f9 1a e5 | abx |  | d168 a9 41 | adca | 1, Y |
| d0fb 19 ed | aby |  | d16a a9 bf | adca | 1,sp- |
| d0fd 8972 | adca | \#immed | d16c a9 3f | adca | 1, $\mathrm{x}^{-}$ |
| d0ff 8972 | adca | \#immed | d16e a9 7f | adca | 1, $\mathrm{y}^{-}$ |
| d101 8972 | adca | \#immed | d170 a9 f8 7d | adca | 125, pc |
| d103 8972 | adca | \#immed | d173 a9 f0 7d | adca | 125, sp |
| d105 8972 | adca | \#immed | d176 a9 e0 7d | adca | 125, x |
| d107 a9 a0 | adca | $1,+\mathrm{sp}$ | d179 a9 e8 7d | adca | 125, y |
| d109 a9 20 | adca | $1,+\mathrm{x}$ | d17c a9 8f | adca | 15, sp |
| d10b a9 60 | adca | 1, +y | d17e a9 0f | adca | 15, x |
| d10d a9 a7 | adca | 8, +sp | d180 a9 4f | adca | 15, y |
| d10f a9 67 | adca | $8,+y$ | d182 a9 f0 10 | adca | 16,sp |
| d111 a9 c0 | adca | , pc | d185 a9 e0 10 | adca | 16, x |
| d113 a9 80 | adca | , sp | d188 a9 e8 10 | adca | 16, y |
| d115 a9 00 | adca | , x | d18b a9 b7 | adca | 8,sp+ |
| d117 a9 40 | adca | , Y | d18d a9 37 | adca | 8, x+ |
| d119 a9 af | adca | 1,-sp | d18f a9 77 | adca | 8, $\mathrm{Y}^{+}$ |




| d45f e1 40 | cmpb | , Y | d4f6 e1 f0 37 | cmpb | ind, sp |
| :---: | :---: | :---: | :---: | :---: | :---: |
| d461 e1 af | cmpb | 1,-sp | d4f9 e1 e0 37 | cmpb | ind, x |
| d463 e1 2f | cmpb | 1,-x | d4fc e1 e8 37 | cmpb | ind, y |
| d465 e1 6f | cmpb | 1,-y | d4ff el ce | cmpb | small, pc |
| d467 e1 a8 | cmpb | 8,-sp | d501 e1 8e | cmpb | small, sp |
| d469 e1 28 | cmpb | 8,-x | d503 e1 0e | cmpb | small, x |
| d46b e1 68 | cmpb | 8,-y | d505 e1 4e | cmpb | small,y |
| d46d e1 9f | cmpb | -1, sp | d507 61 a0 | com | 1, +sp |
| d46f e1 1f | cmpb | -1, x | d509 61 20 | com | 1, +x |
| d471 e1 5f | cmpb | -1, y | d50b 6160 | com | 1, +y |
| d473 e1 90 | cmpb | -16, sp | d50d 61 a7 | com | 8, +sp |
| d475 e1 10 | cmpb | -16,x | d50f 6127 | com | $8,+x$ |
| d477 e1 50 | cmpb | -16,y | d511 6167 | com | 8, +y |
| d479 e1 f1 ef | cmpb | -17, sp | d513 61 c0 | com | , pc |
| d47c e1 e1 ef | cmpb | -17, x | d515 6180 | com | , sp |
| d47f e1 e9 ef | cmpb | -17, y | d517 6100 | com | , x |
| d482 e1 d2 | cmpb | -small, pc | d519 61 40 | com | , Y |
| d484 e1 92 | cmpb | -small, sp | d51b 61 af | com | 1,-sp |
| d486 e1 12 | cmpb | -small, x | d51d 612 f | com | 1,-x |
| d488 e1 52 | cmpb | -small, y | d51f 61 6f | com | 1,-y |
| d48a e1 c0 | cmpb | 0, pc | d521 61 a8 | com | 8,-sp |
| d48c e1 80 | cmpb | 0,sp | d523 6128 | com | 8,-x |
| d48e e1 00 | cmpb | 0, x | d525 6168 | com | 8,-y |
| d490 e1 40 | cmpb | 0,y | d527 61 9f | com | -1, sp |
| d492 e1 b0 | cmpb | 1, sp+ | d529 61 1f | com | -1, x |
| d494 e1 30 | cmpb | 1, x+ | d52b 615 f | com | -1, y |
| d496 e1 70 | cmpb | 1, $\mathrm{y}^{+}$ | d52d 6190 | com | -16,sp |
| d498 e1 81 | cmpb | 1, sp | d52f 6110 | com | -16,x |
| d49a e1 01 | cmpb | 1, x | d531 6150 | com | -16, y |
| d49c e1 41 | cmpb | 1, y | d533 61 f1 ef | com | -17, sp |
| d49e e1 bf | cmpb | 1, sp- | d536 61 e1 ef | com | -17, x |
| d4a0 e1 3f | cmpb | 1, $\mathrm{x}-$ | d539 61 e9 ef | com | -17,y |
| d4a2 e1 7f | cmpb | 1, $\mathrm{y}-$ | d53c 61 d2 | com | -small, pc |
| d4a4 e1 f8 7d | cmpb | 125, pc | d53e 6192 | com | -small, sp |
| d4a7 e1 f0 7d | cmpb | 125, sp | d540 61 12 | com | -small, x |
| d4aa e1 e0 7d | cmpb | 125, x | d542 6152 | com | -small, y |
| d4ad e1 e8 7d | cmpb | 125, y | d544 61 c0 | com | 0, pc |
| d4b0 e1 8f | cmpb | 15, sp | d546 61 80 | com | $0, \mathrm{sp}$ |
| d4b2 e1 0f | cmpb | 15, x | d548 6100 | com | 0, x |
| d4b4 e1 4f | cmpb | 15, y | d54a 6140 | com | 0, y |
| d4b6 e1 f0 10 | cmpb | 16, sp | d54c 61 b0 | com | 1, sp+ |
| d4b9 e1 e0 10 | cmpb | 16, x | d54e 6130 | com | 1, x+ |
| d4bc el e8 10 | cmpb | 16, y | d550 6170 | com | 1, $\mathrm{y}^{+}$ |
| d4bf e1 b7 | cmpb | 8,sp+ | d552 6181 | com | 1, sp |
| d4c1 e1 37 | cmpb | 8, x+ | d554 6101 | com | 1, x |
| d4c3 e1 77 | cmpb | 8, y+ | d556 61 41 | com | 1, y |
| d4c5 e1 b8 | cmpb | 8,sp- | d558 61 bf | com | 1, sp- |
| d4c7 e1 38 | cmpb | 8, x- | d55a 613 f | com | 1, $\mathrm{x}^{-}$ |
| d4c9 e1 78 | cmpb | 8, y- | d55c 617 f | com | 1, $\mathrm{y}-$ |
| d4cb e1 f4 | cmpb | a,sp | d55e 61 f8 7d | com | 125, pc |
| d4cd e1 e4 | cmpb | a, x | d561 61 f0 7d | com | 125, sp |
| d4cf e1 ec | cmpb | a, y | d564 61 e0 7d | com | 125, x |
| d4d1 e1 f5 | cmpb | b, sp | d567 61 e8 7d | com | 125, y |
| d4d3 e1 e5 | cmpb | b , x | d56a 618 f | com | 15, sp |
| d4d5 e1 ed | cmpb | b, y | d56c $610 \mathrm{f}^{\text {f }}$ | com | 15, x |
| d4d7 e1 f6 | cmpb | d,sp | d56e 614 f | com | 15, y |
| d4d9 e1 e6 | cmpb | d, x | d570 61 f0 10 | com | 16, sp |
| d4db e1 ee | cmpb | d, y | d573 61 e0 10 | com | 16, x |
| d4dd d1 55 | cmpb | dir | d576 61 e8 10 | com | 16, y |
| d4df d1 55 | cmpb | dir | d579 61 b7 | com | 8,sp+ |
| d4e1 f1 0188 | cmpb | ext | d57b 6137 | com | 8, x+ |
| d4e4 f1 0188 | cmpb | ext | d57d 6177 | com | 8, y+ |
| d4e7 e1 f2 0188 | cmpb | ext,sp | d57f 61 b8 | com | 8, sp- |
| d4eb e1 e2 0188 | cmpb | ext, x | d581 6138 | com | 8, x- |
| d4ef e1 ea 0188 | cmpb | ext, y | d583 6178 | com | 8, y- |
| d4f3 e1 f8 37 | cmpb | ind, pc | d585 61 f 4 | com | a,sp |


| d587 61 e4 | com | a, x | d61b ac 3f | cpd | 1, $\mathrm{x}^{-}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| d589 61 ec | com | a, y | d61d ac 7 f | cpd | 1, $\mathrm{Y}^{-}$ |
| d58b 61 f5 | com | b, sp | d61f ac f8 7d | cpd | 125, pc |
| d58d 61 e5 | com | b , x | d622 ac f0 7d | cpd | 125, sp |
| d58f 61 ed | com | b, y | d625 ac e0 7d | cpd | 125, x |
| d591 61 f6 | com | d, sp | d628 ac e8 7d | cpd | 125, y |
| d593 61 e6 | com | d, x | d62b ac 8f | cpd | 15, sp |
| d595 61 ee | com | d, y | d62d ac 0f | cpd | 15, x |
| d597 710055 | com | dir | d62f ac 4f | cpd | 15, y |
| d59a 710188 | com | ext | d631 ac f0 10 | cpd | 16, sp |
| d59d 710188 | com | ext | d634 ac e0 10 | cpd | 16, x |
| d5a0 61 f2 0188 | com | ext,sp | d637 ac e8 10 | cpd | 16, y |
| d5a4 61 e2 0188 | com | ext, x | d63a ac b7 | cpd | 8,sp+ |
| d5a8 61 ea 0188 | com | ext,y | d63c ac 37 | cpd | 8, x+ |
| d5ac 61 f8 37 | com | ind, pc | d63e ac 77 | cpd | 8, $\mathrm{y}^{+}$ |
| d5af 61 f0 37 | com | ind, sp | d640 ac b8 | cpd | 8,sp- |
| d5b2 61 e0 37 | com | ind, $x$ | d642 ac 38 | cpd | 8, x- |
| d5b5 61 e8 37 | com | ind, y | d644 ac 78 | cpd | 8, $\mathrm{y}^{-}$ |
| d5b8 61 ce | com | small, pc | d646 ac f4 | cpd | a,sp |
| d5ba 618 e | com | small,sp | d648 ac e4 | cpd | a, x |
| d5bc 610 l | com | small, x | d64a ac ec | cpd | a, y |
| d5be 614 e | com | small,y | d64c ac f5 | cpd | b, sp |
| d5c0 41 | coma |  | d64e ac e5 | cpd | b, x |
| d5c1 51 | comb |  | d650 ac ed | cpd | b, y |
| d5c2 8c 0072 | cpd | \#immed | d652 ac f6 | cpd | d, sp |
| d5c5 8c 0072 | cpd | \#immed | d654 ac e6 | cpd | d, x |
| d5c8 ac a0 | cpd | 1, +sp | d656 ac ee | cpd | d, y |
| d5ca ac 20 | cpd | 1, +x | d658 9c 55 | cpd | dir |
| d5cc ac 60 | cpd | 1, +y | d65a 9c 55 | cpd | dir |
| d5ce ac a7 | cpd | 8, +sp | d65c bc 0188 | cpd | ext |
| d5d0 ac 27 | cpd | 8, +x | d65f bc 0188 | cpd | ext |
| d5d2 ac 67 | cpd | 8, +y | d662 ac f2 0188 | cpd | ext,sp |
| d5d4 ac c0 | cpd | , pc | d666 ac e2 0188 | cpd | ext,x |
| d5d6 ac 80 | cpd | , sp | d66a ac ea 0188 | cpd | ext,y |
| d5d8 ac 00 | cpd | , x | d66e ac f8 37 | cpd | ind, pc |
| d5da ac 40 | cpd | , Y | d671 ac f0 37 | cpd | ind, sp |
| d5dc ac af | cpd | 1,-sp | d674 ac e0 37 | cpd | ind, x |
| d5de ac 2f | cpd | 1,-x | d677 ac e8 37 | cpd | ind, y |
| d5e0 ac 6f | cpd | 1,-y | d67a ac ce | cpd | small, pc |
| d5e2 ac a8 | cpd | 8,-sp | d67c ac 8e | cpd | small,sp |
| d5e4 ac 28 | cpd | 8,-x | d67e ac 0e | cpd | small, x |
| d5e6 ac 68 | cpd | 8,-y | d680 ac $4 e$ | cpd | small,y |
| d5e8 ac 9f | cpd | -1, sp | d682 8f 0072 | cps | \#immed |
| d5ea ac 1f | cpd | -1, x | d685 af a0 | cps | 1, +sp |
| d5ec ac 5f | cpd | -1, y | d687 af 20 | cps | $1,+x$ |
| d5ee ac 90 | cpd | -16, sp | d689 af 60 | cps | 1, + y |
| d5f0 ac 10 | cpd | -16, x | d68b af a7 | cps | 8, +sp |
| d5f2 ac 50 | cpd | -16,y | d68d af 27 | cps | 8, +x |
| d5f4 ac fl ef | cpd | -17, sp | d68f af 67 | cps | 8, +y |
| d5f7 ac e1 ef | cpd | -17,x | d691 af c0 | cps | , pc |
| d5fa ac e9 ef | cpd | -17, y | d693 af 80 | cps | , sp |
| d5fd ac d2 | cpd | -small, pc | d695 af 00 | cps | , x |
| d5ff ac 92 | cpd | -small, sp | d697 af 40 | cps | , Y |
| d601 ac 12 | cpd | -small, x | d699 af af | cps | 1,-sp |
| d603 ac 52 | cpd | -small, y | d69b af 2f | cps | 1,-x |
| d605 ac c0 | cpd | 0, pc | d69d af 6f | cps | 1,-y |
| d607 ac 80 | cpd | $0, \mathrm{sp}$ | d69f af a8 | cps | 8,-sp |
| d609 ac 00 | cpd | 0 , x | d6a1 af 28 | cps | 8,-x |
| d60b ac 40 | cpd | 0, y | d6a3 af 68 | cps | 8,-y |
| d60d ac b0 | cpd | 1,sp+ | d6a5 af 9f | cps | -1, sp |
| d60f ac 30 | cpd | 1, x+ | d6a7 af 1f | cps | -1, x |
| d611 ac 70 | cpd | 1, $\mathrm{Y}^{+}$ | d6a9 af 5f | cps | -1, y |
| d613 ac 81 | cpd | 1, sp | d6ab af 90 | cps | -16,sp |
| d615 ac 01 | cpd | 1,x | d6ad af 10 | cps | -16, x |
| d617 ac 41 | cpd | 1, Y | d6af af 50 | cps | -16,y |
| d619 ac bf | cpd | 1,sp- | d6b1 af f1 ef | cps | -17, sp |


| d6b4 a | af e1 ef | cps | -17, x |
| :---: | :---: | :---: | :---: |
| d6b7 a | af e9 ef | cps | -17, y |
| d6ba a | af d2 | cps | -small, po |
| d6bc a | af 92 | cps | -small,sp |
| d6be a | af 12 | cps | -small,x |
| d6c0 a | af 52 | cps | -small, y |
| d6c2 a | af co | cps | 0, pc |
| d6c4 a | af 80 | cps | 0,sp |
| d6c6 a | af 00 | cps | 0,x |
| d6c8 a | af 40 | cps | 0, y |
| d6ca a | af bo | cps | 1, sp+ |
| d6cc a | af 30 | cps | 1,x+ |
| d6ce a | af 70 | cps | 1, $\mathrm{Y}^{+}$ |
| d6d0 a | af 81 | cps | 1, sp |
| d6d2 a | af 01 | cps | 1, x |
| d6d4 a | af 41 | cps | 1, y |
| d6d6 a | af bf | cps | 1,sp- |
| d6d8 a | af 3f | cps | 1, $\mathrm{x}-$ |
| d6da a | af 7f | cps | 1, $\mathrm{y}^{-}$ |
| d6dc a | af f8 7d | cps | 125, pc |
| d6df a | af f0 7d | cps | 125, sp |
| d6e2 a | af e0 7d | cps | 125, x |
| d6e5 a | af e8 7d | cps | 125, y |
| d6e8 a | af 8f | cps | 15, sp |
| d6ea a | af 0f | cps | 15, x |
| d6ec a | af 4f | cps | 15, y |
| d6ee a | af f0 10 | cps | 16, sp |
| d6f1 a | af e0 10 | cps | 16, x |
| d6£4 a | af e8 10 | cps | 16, y |
| d6f7 a | af b7 | cps | 8,sp+ |
| d6f9 a | af 37 | cps | 8, x+ |
| d6fb a | af 77 | cps | 8, y+ |
| d6fd a | af b8 | cps | 8,sp- |
| d6ff a | af 38 | cps | 8, x- |
| d701 a | af 78 | cps | 8, $\mathrm{y}^{-}$ |
| d703 a | af f 4 | cps | a,sp |
| d705 a | af e4 | cps | a, x |
| d707 a | af ec | cps | a, y |
| d709 a | af $f 5$ | cps | b, sp |
| d70b a | af e5 | cps | $\mathrm{b}, \mathrm{x}$ |
| d70d a | af ed | cps | b, y |
| d70f a | af $f 6$ | cps | d, sp |
| d711 a | af e6 | cps | d, x |
| d713 a | af ee | cps | d, y |
| d715 9 | 9f 55 | cps | dir |
| d717 9 | 9f 55 | cps | dir |
| d 719 b | bf 0188 | cps | ext |
| d71c b | bf 0188 | cps | ext |
| d71f a | af f2 0188 | cps | ext,sp |
| d723 a | af e2 0188 | cps | ext, x |
| d727 a | af ea 0188 | cps | ext,y |
| d72b a | af $\mathrm{f8} 37$ | cps | ind, pc |
| d72e a | af f0 37 | cps | ind, sp |
| d731 a | af e0 37 | cps | ind, x |
| d734 a | af e8 37 | cps | ind, y |
| d737 a | af ce | cps | small, pc |
| d739 a | af 8 e | cps | small,sp |
| d73b a | af 0 e | cps | small, x |
| d73d a | af 4 e | cps | small, y |
| d73f 8 | 8 e 0072 | cpx | \#immed |
| d742 8 | 8 e 0072 | cpx | \#immed |
| d745 a | ae a0 | cpx | 1, +sp |
| d747 a | ae 20 | cpx | $1,+x$ |
| d749 a | ae 60 | cpx | 1, +y |
| d74b a | ae a7 | cpx | 8, +sp |
| d74d a | ae 27 | cpx | $8,+x$ |


| d74f ae 67 | cpx | 8, +y |
| :---: | :---: | :---: |
| d751 ae c0 | cpx | , pc |
| d753 ae 80 | cpx | , sp |
| d755 ae 00 | cpx | , x |
| d757 ae 40 | cpx | , Y |
| d759 ae af | cpx | 1,-sp |
| d75b ae 2 f | cpx | 1,-x |
| d75d ae 6f | cpx | 1,-y |
| d75f ae a8 | cpx | 8,-sp |
| d761 ae 28 | cpx | 8,-x |
| d763 ae 68 | cpx | 8,-y |
| d765 ae 9f | cpx | -1, sp |
| d767 ae 1f | cpx | -1, x |
| d769 ae 5f | cpx | -1, y |
| d76b ae 90 | cpx | -16,sp |
| d76d ae 10 | cpx | -16, x |
| d76f ae 50 | cpx | -16,y |
| d771 ae f1 ef | cpx | -17, sp |
| d774 ae e1 ef | cpx | -17, x |
| d777 ae e9 ef | cpx | -17, y |
| d77a ae d2 | cpx | -small, pc |
| d77c ae 92 | cpx | -small,sp |
| d77e ae 12 | cpx | -small, x |
| d780 ae 52 | cpx | -small, y |
| d782 ae c0 | cpx | 0, pc |
| d784 ae 80 | cpx | 0,sp |
| d786 ae 00 | cpx | 0, x |
| d788 ae 40 | cpx | 0, y |
| d78a ae b0 | cpx | 1, sp+ |
| d78c ae 30 | cpx | 1, x+ |
| d78e ae 70 | cpx | 1, $\mathrm{y}^{+}$ |
| d790 ae 81 | cpx | 1, sp |
| d792 ae 01 | cpx | 1, x |
| d794 ae 41 | cpx | 1, y |
| d796 ae bf | cpx | 1,sp- |
| d798 ae 3f | cpx | 1, $\mathrm{x}-$ |
| d79a ae 7f | cpx | 1, $\mathrm{Y}^{-}$ |
| d79c ae f8 7d | cpx | 125, pc |
| d79f ae f0 7d | cpx | 125, sp |
| d7a2 ae e0 7d | cpx | 125, x |
| d7a5 ae e8 7d | cpx | 125, y |
| d7a8 ae 8f | cpx | 15, sp |
| d7aa ae 0f | cpx | 15, x |
| d7ac ae 4f | cpx | 15, y |
| d7ae ae f0 10 | cpx | 16, sp |
| d7b1 ae e0 10 | cpx | 16, x |
| d7b4 ae e8 10 | cpx | 16,y |
| d7b7 ae b7 | cpx | 8, sp+ |
| d7b9 ae 37 | cpx | 8, x+ |
| d7bb ae 77 | cpx | 8, y+ |
| d7bd ae b8 | cpx | 8,sp- |
| d7bf ae 38 | cpx | 8, x- |
| d7c1 ae 78 | cpx | 8, $\mathrm{Y}^{-}$ |
| d7c3 ae f4 | cpx | a,sp |
| d7c5 ae e4 | cpx | a, x |
| d7c7 ae ec | cpx | a, y |
| d7c9 ae f5 | cpx | b, sp |
| d7cb ae e5 | cpx | b, x |
| d7cd ae ed | cpx | b, y |
| d7cf ae f6 | cpx | d, sp |
| d7d1 ae e6 | cpx | d, x |
| d7d3 ae ee | cpx | d, y |
| d7d5 9e 55 | cpx | dir |
| d7d7 9e 55 | cpx | dir |
| d7d9 be 0188 | cpx | ext |
| d7dc be 0188 | cpx | ext |


| d7df ae f2 0188 | cpx | ext,sp | d879 ad 37 | cpy | 8, x+ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| d7e3 ae e2 0188 | cpx | ext, x | d87b ad 77 | cpy | 8, y+ |
| d7e7 ae ea 0188 | cpx | ext,y | d87d ad b8 | cpy | 8,sp- |
| d7eb ae f8 37 | cpx | ind, pc | d87f ad 38 | cpy | 8, x- |
| d7ee ae f0 37 | cpx | ind, sp | d881 ad 78 | cpy | 8, $\mathrm{y}^{-}$ |
| d7f1 ae e0 37 | cpx | ind, $x$ | d883 ad f4 | cpy | a,sp |
| d7f 4 ae e8 37 | cpx | ind, y | d885 ad e4 | cpy | a, x |
| d7f7 ae ce | cpx | small, pc | d887 ad ec | cpy | a, y |
| d7f9 ae 8e | cpx | small,sp | d889 ad f5 | cpy | b, sp |
| $d 7 \mathrm{fb}$ ae 0 e | cpx | small, x | d88b ad e5 | cpy | b , x |
| d7fd ae 4 e | cpx | small, Y | d88d ad ed | cpy | b, y |
| d7ff 8d 0072 | cpy | \#immed | d88f ad f6 | cpy | d, sp |
| d802 8d 0072 | cpy | \#immed | d891 ad e6 | cpy | d, x |
| d805 ad a0 | cpy | 1, +sp | d893 ad ee | cpy | d, y |
| d807 ad 20 | cpy | 1, +x | d895 9d 55 | cpy | dir |
| d809 ad 60 | cpy | 1, +y | d897 9d 55 | cpy | dir |
| d80b ad a7 | cpy | 8, +sp | d899 bd 0188 | cpy | ext |
| d80d ad 27 | cpy | $8,+x$ | d89c bd 0188 | cpy | ext |
| d80f ad 67 | cpy | 8, +y | d89f ad f2 0188 | cpy | ext,sp |
| d811 ad c0 | cpy | , pc | d8a3 ad e2 0188 | cpy | ext,x |
| d813 ad 80 | cpy | , sp | d8a7 ad ea 0188 | cpy | ext,y |
| d815 ad 00 | cpy | , x | d8ab ad f8 37 | cpy | ind, pc |
| d817 ad 40 | cpy | , y | d8ae ad f0 37 | cpy | ind, sp |
| d819 ad af | cpy | 1,-sp | d8b1 ad e0 37 | cpy | ind, x |
| d81b ad 2f | cpy | 1,-x | d8b4 ad e8 37 | cpy | ind, y |
| d81d ad 6f | cpy | 1,-y | d8b7 ad ce | cpy | small, pc |
| d81f ad a8 | cpy | 8,-sp | d8b9 ad 8e | cpy | small,sp |
| d821 ad 28 | cpy | 8,-x | d8bb ad 0 e | cpy | small, x |
| d823 ad 68 | cpy | 8,-y | d8bd ad 4e | cpy | small, y |
| d825 ad 9f | cpy | -1, sp | d8bf 1807 | daa |  |
| d827 ad 1f | cpy | -1, x | d8c1 0430 fd | dbne | a * |
| d829 ad 5f | cpy | -1, y | d8c4 0431 fd | dbne | b * |
| d82b ad 90 | cpy | -16, sp | d8c7 0435 fd | dbne | x * |
| d82d ad 10 | cpy | -16, x | d8ca 0436 fd | dbne | y * |
| d82f ad 50 | cpy | -16,y | d8cd 63 a0 | dec | 1, +sp |
| d831 ad f1 ef | cpy | -17, sp | d8cf 6320 | dec | 1, +x |
| d834 ad e1 ef | cpy | -17, x | d8d1 6360 | dec | 1, +y |
| d837 ad e9 ef | cpy | -17, y | d8d3 63 a7 | dec | 8, +sp |
| d83a ad d2 | cpy | -small, pc | d8d5 6327 | dec | 8, +x |
| d83c ad 92 | cpy | -small,sp | d8d7 6367 | dec | 8, +y |
| d83e ad 12 | cpy | -small,x | d8d9 63 c0 | dec | , pc |
| d840 ad 52 | cpy | -small, y | d8db 6380 | dec | , sp |
| d842 ad c0 | cpy | 0, pc | d8dd 6300 | dec | , x |
| d844 ad 80 | cpy | 0, sp | d8df 6340 | dec | , Y |
| d846 ad 00 | cpy | 0 , x | d8e1 63 af | dec | 1,-sp |
| d848 ad 40 | cpy | 0, y | d8e3 632 f | dec | 1,-x |
| d84a ad b0 | cpy | 1, sp+ | d8e5 63 6f | dec | 1,-y |
| d84c ad 30 | cpy | 1, x+ | d8e7 63 a8 | dec | 8,-sp |
| d84e ad 70 | cpy | 1, $\mathrm{Y}^{+}$ | d8e9 6328 | dec | 8,-x |
| d850 ad 81 | cpy | 1, sp | d8eb 6368 | dec | 8,-y |
| d852 ad 01 | cpy | 1, x | d8ed 63 9f | dec | -1, sp |
| d854 ad 41 | cpy | 1, y | d8ef 631 f | dec | -1, x |
| d856 ad bf | cpy | 1, sp- | d8f1 635 f | dec | -1, y |
| d858 ad 3f | cpy | 1, $\mathrm{x}-$ | d8f3 6390 | dec | -16, sp |
| d85a ad 7f | cpy | 1, $\mathrm{y}^{-}$ | d8f5 6310 | dec | -16, x |
| d85c ad f8 7d | cpy | 125, pc | d8f7 6350 | dec | -16,y |
| d85f ad f0 7d | cpy | 125, sp | d8f9 63 f1 ef | dec | -17, sp |
| d862 ad e0 7d | cpy | 125, x | d8fc 63 e1 ef | dec | -17,x |
| d865 ad e8 7d | cpy | 125, y | d8ff 63 e9 ef | dec | -17, y |
| d868 ad 8f | cpy | 15, sp | d902 63 d2 | dec | -small, pc |
| d86a ad 0 f | cpy | 15, x | d904 6392 | dec | -small, sp |
| d86c ad 4f | cpy | 15, y | d906 6312 | dec | -small, x |
| d86e ad f0 10 | cpy | 16, sp | d908 6352 | dec | -small,y |
| d871 ad e0 10 | cpy | 16, x | d90a 63 c0 | dec | 0, pc |
| d874 ad e8 10 | cpy | 16, y | d90c 6380 | dec | 0, sp |
| d877 ad b7 | cpy | 8, sp+ | d90e 6300 | dec | $0, \mathrm{x}$ |


| d910 6 | 6340 | dec | 0, y |
| :---: | :---: | :---: | :---: |
| d912 6 | 63 b0 | dec | 1, sp+ |
| d914 6 | 6330 | dec | 1, x+ |
| d916 6 | 6370 | dec | 1, $\mathrm{y}+$ |
| d918 6 | 6381 | dec | 1, sp |
| d91a 6 | 6301 | dec | 1, x |
| d91c 6 | 6341 | dec | 1, y |
| d91e 6 | 63 bf | dec | 1,sp- |
| d920 6 | 63 3f | dec | 1, $\mathrm{x}-$ |
| d922 6 | 637 f | dec | 1, $\mathrm{Y}^{-}$ |
| d924 6 | $63 \mathrm{f8} 7 \mathrm{~d}$ | dec | 125, pc |
| d927 6 | $63 \mathrm{f0} 7 \mathrm{~d}$ | dec | 125, sp |
| d92a 6 | 63 e0 7d | dec | 125, x |
| d92d 6 | 63 e8 7d | dec | 125, y |
| d930 6 | 63 8f | dec | 15, sp |
| d932 6 | 63 0f | dec | 15, x |
| d934 6 | 63 4f | dec | 15, y |
| d936 6 | $63 \mathrm{f0} 10$ | dec | 16, sp |
| d939 6 | 63 e0 10 | dec | 16, x |
| d93c 6 | 63 e8 10 | dec | 16, y |
| d93f 6 | 63 b7 | dec | 8,sp+ |
| d941 6 | $63 \quad 37$ | dec | 8, x+ |
| d943 6 | 6377 | dec | 8, y+ |
| d945 6 | 63 b8 | dec | 8,sp- |
| d947 6 | 6338 | dec | 8, x- |
| d949 6 | 6378 | dec | 8, y- |
| d94b 6 | 63 f 4 | dec | a,sp |
| d94d 6 | 63 e4 | dec | a, x |
| d94f 6 | 63 ec | dec | a, y |
| d951 6 | 63 f5 | dec | b, sp |
| d953 6 | 63 e5 | dec | b , x |
| d955 6 | 63 ed | dec | b, y |
| d957 6 | 63 f6 | dec | d,sp |
| d959 6 | 63 e6 | dec | d, x |
| d95b 6 | 63 ee | dec | d, y |
| d95d 7 | 730055 | dec | dir |
| d960 7 | 730188 | dec | ext |
| d963 7 | 730188 | dec | ext |
| d966 6 | 63 f2 0188 | dec | ext,sp |
| d96a 6 | 63 e2 0188 | dec | ext, x |
| d96e 6 | 63 ea 0188 | dec | ext,y |
| d972 6 | 63 f8 37 | dec | ind, pc |
| d975 6 | 63 f0 37 | dec | ind, sp |
| d978 6 | 63 e0 37 | dec | ind, x |
| d97b 6 | 63 e8 37 | dec | ind, y |
| d97e 6 | 63 ce | dec | small, pc |
| d980 6 | 63 8e | dec | small, sp |
| d982 6 | 63 0e | dec | small, x |
| d984 6 | 63 4e | dec | small, y |
| d986 4 | 43 | deca |  |
| d987 5 | 53 | decb |  |
| d988 1 | 1b 9f | des |  |
| d98a 0 | 09 | dex |  |
| d98b 0 |  | dey |  |
| d98c 1 |  | ediv |  |
| d98d 1 | 1814 | edivs |  |
| d98f 1 | $\begin{array}{llll}18 & 12 & 00 & 55\end{array}$ | emacs | dir |
| d993 1 | $\begin{array}{lllll}18 & 12 & 01 & 88\end{array}$ | emacs | ext |
| d997 1 | 1812000 e | emacs | small |
| d99b 1 | 18 1a a0 | emaxd | 1, +sp |
| d99e 1 | 18 1a 20 | emaxd | 1, +x |
| d9a1 1 | 18 1a 60 | emaxd | 1, +y |
| d9a4 1 | 18 1a a7 | emaxd | 8, +sp |
| d9a7 1 | 18 1a 27 | emaxd | 8, +x |
| d9aa 1 | 18 1a 67 | emaxd | 8, +y |
| d9ad 1 | 18 1a c0 | emaxd | , pc |



| da89 1 | 18 1a e8 37 | emaxd | ind, y |
| :---: | :---: | :---: | :---: |
| da8d 1 | 18 1a ce | emaxd | small, pc |
| da90 1 | 18 1a 8e | emaxd | small,sp |
| da93 1 | 18 1a 0e | emaxd | small, x |
| da96 1 | 18 1a 4e | emaxd | small, y |
| da99 1 | 18 1e a0 | emaxm | $1,+\mathrm{sp}$ |
| da9c 1 | 18 1e 20 | emaxm | 1, +x |
| da9f 1 | 18 1e 60 | emaxm | 1, +y |
| daa2 1 | 18 1e a7 | emaxm | 8, +sp |
| daa5 1 | 18 1e 27 | emaxm | $8,+x$ |
| daa8 1 | 18 1e 67 | emaxm | 8, +y |
| daab 1 | 18 1e c0 | emaxm | , pc |
| daae 1 | 18 1e 80 | emaxm | , sp |
| dab1 1 | 18 le 00 | emaxm | , x |
| dab4 1 | 18 1e 40 | emaxm | , Y |
| dab7 1 | 18 le af | emaxm | 1,-sp |
| daba 1 | 18 1e 2f | emaxm | 1,-x |
| dabd 1 | 18 1e 6f | emaxm | 1,-y |
| dac0 1 | 18 1e a8 | emaxm | 8,-sp |
| dac3 1 | 18 1e 28 | emaxm | 8,-x |
| dac6 1 | 181 e 68 | emaxm | 8,-y |
| dac9 1 | 18 1e 9f | emaxm | -1, sp |
| dacc 1 | 18 1e 1f | emaxm | -1, x |
| dacf 1 | 18 1e 5f | emaxm | -1, y |
| dad2 1 | 18 1e 90 | emaxm | -16,sp |
| dad5 1 | 18 1e 10 | emaxm | -16, x |
| dad8 1 | 18 1e 50 | emaxm | -16, y |
| dadb 1 | 18 le f1 ef | emaxm | -17, sp |
| dadf 1 | 18 1e e1 ef | emaxm | -17, x |
| dae3 1 | 18 1e e9 ef | emaxm | -17, y |
| dae7 1 | 18 1e d2 | emaxm | -small, pc |
| daea 1 | 18 1e 92 | emaxm | -small,sp |
| daed 1 | 18 1e 12 | emaxm | -small, x |
| daf0 1 | 18 le 52 | emaxm | -small, y |
| daf3 1 | 18 1e c0 | emaxm | $0, \mathrm{pc}$ |
| daf6 1 | 18 1e 80 | emaxm | $0, \mathrm{sp}$ |
| daf9 1 | 18 1e 00 | emaxm | 0 , x |
| dafc 1 | 18 1e 40 | emaxm | 0, y |
| daff 1 | 18 1e b0 | emaxm | 1, sp+ |
| db02 1 | 18 1e 30 | emaxm | 1, x+ |
| db05 1 | 18 1e 70 | emaxm | 1, $\mathrm{y}+$ |
| db08 1 | 18 1e 81 | emaxm | 1,sp |
| db0b 1 | 18 1e 01 | emaxm | 1, x |
| $\mathrm{db0e} 1$ | 18 1e 41 | emaxm | 1, y |
| db11 1 | 18 1e bf | emaxm | 1,sp- |
| db14 1 | 18 1e 3f | emaxm | 1, $\mathrm{x}-$ |
| db17 1 | 18 1e 7f | emaxm | 1, $\mathrm{Y}^{-}$ |
| db1a 1 | 18 1e f8 7d | emaxm | 125, pc |
| db1e 1 | 18 1e f0 7d | emaxm | 125, sp |
| db22 1 | 18 1e e0 7d | emaxm | 125, x |
| db26 1 | 18 1e e8 7d | emaxm | 125, y |
| db2a 1 | 18 1e 8f | emaxm | 15, sp |
| db2d 1 | 181 e 0 f | emaxm | 15, x |
| db30 1 | 181 e 4 f | emaxm | 15, y |
| db33 1 | 18 1e f0 10 | emaxm | 16, sp |
| db37 1 | 18 1e e0 10 | emaxm | 16,x |
| db3b 1 | 18 1e e8 10 | emaxm | 16, y |
| db3f 1 | 18 le b7 | emaxm | 8,sp+ |
| db42 1 | 18 1e 37 | emaxm | 8, x+ |
| db 451 | 18 1e 77 | emaxm | 8, $\mathrm{y}^{+}$ |
| db 481 | 18 1e b8 | emaxm | 8,sp- |
| db4b 1 | 18 1e 38 | emaxm | 8, x- |
| db4e 1 | 18 1e 78 | emaxm | 8, $\mathrm{Y}^{-}$ |
| db51 1 | 18 1e f4 | emaxm | a,sp |
| db54 1 | 18 1e e4 | emaxm | $\mathrm{a}, \mathrm{x}$ |
| db57 1 | 181 e ec | emaxm | a, y |






| de5f e8 | 867 | eorb | 8, +y |
| :---: | :---: | :---: | :---: |
| de61 e8 | e c0 | eorb | , pc |
| de63 e | 880 | eorb | , sp |
| de65 e | 800 | eorb | , x |
| de67 e | 840 | eorb | , Y |
| de69 e | 8 af | eorb | 1,-sp |
| de6b e | 8 2f | eorb | 1,-x |
| de6d e | 8 6f | eorb | 1,-y |
| de6f e8 | 8 a8 | eorb | 8,-sp |
| de71 e | 828 | eorb | 8,-x |
| de73 e | 868 | eorb | 8,-y |
| de75 e | 8 9f | eorb | -1, sp |
| de77 e | 8 1f | eorb | -1, x |
| de79 e | 8 5f | eorb | -1, y |
| de7b e | e8 90 | eorb | -16, sp |
| de7d e | 810 | eorb | -16, x |
| de7f e8 | e 50 | eorb | -16,y |
| de81 e | $8 \mathrm{f1}$ ef | eorb | -17, sp |
| de84 e | 8 e1 ef | eorb | -17, x |
| de87 e | 88 e9 ef | eorb | -17, y |
| de8a e | 8 d 2 | eorb | -small, pc |
| de8c e | e 92 | eorb | -small,sp |
| de8e e | 812 | eorb | -small,x |
| de90 e | 852 | eorb | -small,y |
| de92 e | 8 c 0 | eorb | 0, pc |
| de94 e | 880 | eorb | $0, \mathrm{sp}$ |
| de96 e | 800 | eorb | 0 , x |
| de98 e | e 40 | eorb | 0, y |
| de9a e | 8 b0 | eorb | 1, sp+ |
| de9c e8 | e 30 | eorb | 1, x+ |
| de9e e | 870 | eorb | 1, $\mathrm{y}^{+}$ |
| dea0 e | 881 | eorb | 1, sp |
| dea2 e | 801 | eorb | 1, x |
| dea4 e | 841 | eorb | 1, y |
| dea6 e | 8 bf | eorb | 1, sp- |
| dea8 e8 | 83 f | eorb | 1, $\mathrm{x}^{-}$ |
| deaa e | 87 f | eorb | 1, $\mathrm{y}^{-}$ |
| deac e8 | e8 f8 7d | eorb | 125, pc |
| deaf e8 | 8 f0 7d | eorb | 125, sp |
| deb2 e8 | e8 e0 7d | eorb | 125, x |
| deb5 e | e8 e8 7d | eorb | 125, y |
| deb8 e8 | 88 f | eorb | 15, sp |
| deba e | 80 f | eorb | 15, x |
| debc e8 | 8 4f | eorb | 15, y |
| debe e8 | 8 f0 10 | eorb | 16, sp |
| dec1 e8 | e8 e0 10 | eorb | 16, x |
| dec4 e | e8 e8 10 | eorb | 16, y |
| dec7 e | e b7 | eorb | 8,sp+ |
| dec9 e | e 37 | eorb | 8, x+ |
| decb e | 877 | eorb | 8,y+ |
| decd e | 8 b8 | eorb | 8, sp- |
| decf e8 | e8 38 | eorb | 8, x- |
| ded1 e | 878 | eorb | 8, y- |
| ded3 e | ¢ 84 | eorb | a,sp |
| ded5 e | e8 e4 | eorb | a, x |
| ded7 e8 | e ec | eorb | a, y |
| ded9 e | 8 f5 | eorb | b, sp |
| dedb e | e 8 5 | eorb | b , x |
| dedd e8 | 8 ed | eorb | b, y |
| dedf e | 8 f6 | eorb | d, sp |
| dee1 e8 | e8 e6 | eorb | d, x |
| dee3 e8 | 8 ee | eorb | d, y |
| dee5 d | d8 55 | eorb | dir |
| dee7 d8 | d8 55 | eorb | dir |
| dee9 f | £ 0188 | eorb | ext |
| deec f | £8 0188 | eorb | ext |





| e137 1580 | jsr | 0,sp | ele9 1820 ff fc | lbra | * |
| :---: | :---: | :---: | :---: | :---: | :---: |
| e139 1500 | jsr | 0 , x | eled 1821 ff fc | lbrn | * |
| e13b 1540 | jsr | 0, y | e1f1 15 fa ff fc | lbsr | * |
| e13d 15 b0 | jsr | 1, sp+ | e1f5 1828 ff fc | lbvc | * |
| e13f 1530 | jsr | 1, x+ | e1f9 1829 ff fc | lbvs | * |
| e141 1570 | jsr | 1, $\mathrm{y}+$ | elfd 8672 | ldaa | \#immed |
| e143 1581 | jsr | 1, sp | elff 8672 | ldaa | \#immed |
| e145 1501 | jsr | 1, x | e201 a6 a0 | ldaa | $1,+\mathrm{sp}$ |
| e147 1541 | jsr | 1, y | e203 a6 20 | ldaa | 1, +x |
| e149 15 bf | jsr | 1,sp- | e205 a6 60 | ldaa | 1, +y |
| e14b 15 3f | jsr | 1, x- | e207 a6 a7 | ldaa | 8, +sp |
| e14d 157 f | jsr | 1, $\mathrm{Y}^{-}$ | e209 a6 27 | ldaa | $8,+x$ |
| e14f 15 f8 7d | jsr | 125, pc | e20b a6 67 | ldaa | 8, +y |
| e152 15 f0 7d | jsr | 125, sp | e20d a6 c0 | ldaa | , pc |
| e155 15 e0 7d | jsr | 125, x | e20f a6 80 | ldaa | , sp |
| e158 15 e8 7d | jsr | 125, y | e211 a6 00 | ldaa | , x |
| e15b 158 f | jsr | 15, sp | e213 a6 40 | ldaa | , Y |
| e15d 150 f | jsr | 15, x | e215 a6 af | ldaa | 1,-sp |
| e15f 154 f | jsr | 15, y | e217 a6 2f | ldaa | 1,-x |
| e161 15 f0 10 | jsr | 16, sp | e219 a6 6f | ldaa | 1,-y |
| e164 15 e0 10 | jsr | 16, x | e21b a6 a8 | ldaa | 8,-sp |
| e167 15 e8 10 | jsr | 16, y | e21d a6 28 | ldaa | 8,-x |
| e16a 15 b7 | jsr | 8, sp+ | e21f a6 68 | ldaa | 8,-y |
| e16c 1537 | jsr | 8, x+ | e221 a6 9f | ldaa | -1,sp |
| e16e 1577 | jsr | 8, y+ | e223 a6 1f | ldaa | -1, x |
| e170 15 b8 | jsr | 8,sp- | e225 a6 5f | ldaa | -1, y |
| e172 1538 | jsr | 8, x- | e227 a6 90 | ldaa | -16, sp |
| e174 1578 | jsr | 8, $\mathrm{y}^{-}$ | e229 a6 10 | ldaa | -16,x |
| e176 15 f4 | jsr | a,sp | e22b a6 50 | ldaa | -16, y |
| e178 15 e4 | jsr | a, x | e22d a6 f1 ef | ldaa | -17, sp |
| e17a 15 ec | jsr | a, y | e230 a6 e1 ef | ldaa | -17,x |
| e17c 15 f5 | jsr | b, sp | e233 a6 e9 ef | ldaa | -17, y |
| e17e 15 e5 | jsr | $\mathrm{b}, \mathrm{x}$ | e236 a6 d2 | ldaa | -small, pc |
| e180 15 ed | jsr | b, y | e238 a6 92 | ldaa | -small,sp |
| e182 15 f6 | jsr | d,sp | e23a a6 12 | ldaa | -small, x |
| e184 15 e6 | jsr | d, x | e23c a6 52 | ldaa | -small, y |
| e186 15 ee | jsr | d, y | e23e a6 c0 | ldaa | $0, \mathrm{pc}$ |
| e188 1755 | jsr | dir | e240 a6 80 | ldaa | $0, \mathrm{sp}$ |
| e18a 1755 | jsr | dir | e242 a6 00 | ldaa | 0,x |
| e18c 160188 | jsr | ext | e244 a6 40 | ldaa | 0, y |
| e18f 160188 | jsr | ext | e246 a6 b0 | ldaa | 1, sp+ |
| e192 160188 | jsr | ext | e248 a6 30 | ldaa | 1, x+ |
| e195 15 f2 0188 | jsr | ext,sp | e24a a6 70 | ldaa | 1, $\mathrm{y}^{+}$ |
| e199 15 e2 0188 | jsr | ext, x | e24c a6 81 | ldaa | 1, sp |
| e19d 15 ea 0188 | jsr | ext,y | e24e a6 01 | ldaa | 1,x |
| elal 15 f8 37 | jsr | ind, pc | e250 a6 41 | ldaa | 1, y |
| e1a4 15 f0 37 | jsr | ind, sp | e252 a6 bf | ldaa | 1,sp- |
| e1a7 15 e0 37 | jsr | ind, x | e254 a6 3f | ldaa | 1, $\mathrm{x}^{-}$ |
| elaa 15 e8 37 | jsr | ind, y | e256 a6 7f | ldaa | 1, $\mathrm{y}^{-}$ |
| elad 15 ce | jsr | small, pc | e258 a6 f8 7d | ldaa | 125, pc |
| elaf 158 e | jsr | small,sp | e25b a6 f0 7d | ldaa | 125, sp |
| e1b1 150 e | jsr | small, x | e25e a6 e0 7d | ldaa | 125,x |
| e1b3 154 e | jsr | small, y | e261 a6 e8 7d | ldaa | 125, y |
| e1b5 1824 ff fc | lbcc | * | e264 a6 8f | ldaa | 15, sp |
| e1b9 1824 ff fc | lbcc | * | e266 a6 0f | ldaa | 15, x |
| e1bd 1825 ff fc | lbcs | * | e268 a6 4f | ldaa | 15, y |
| e1c1 1827 ff fc | lbeq | * | e26a a6 f0 10 | ldaa | 16, sp |
| e1c5 18 2c ff fc | lbge | * | e26d a6 e0 10 | ldaa | 16, x |
| e1c9 18 2e ff fc | lbgt | * | e270 a6 e8 10 | ldaa | 16, y |
| e1cd 1822 ff fc | lbhi | * | e273 a6 b7 | ldaa | 8, sp+ |
| eld1 18 2f ff fc | lble | * | e275 a6 37 | ldaa | 8, x+ |
| e1d5 1823 ff fc | lbls | * | e277 a6 77 | ldaa | 8, y+ |
| e1d9 18 2d ff fc | lblt | * | e279 a6 b8 | ldaa | 8, sp- |
| e1dd 18 2b ff fc | lbmi | * | e27b a6 38 | ldaa | 8, x- |
| ele1 1826 ff fc | lbne | * | e27d a6 78 | ldaa | 8, y- |
| e1e5 18 2a ff fc | lbpl | * | e27f a6 f4 | ldaa | a,sp |


| e281 a6 e4 | ldaa | a, x | e314 e6 7f | 1 dab | 1, $\mathrm{Y}^{-}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| e283 a6 ec | ldaa | a, y | e316 e6 f8 7d | 1 dab | 125, pc |
| e285 a6 f5 | ldaa | b, sp | e319 e6 f0 7d | ldab | 125, sp |
| e287 a6 e5 | ldaa | b , x | e31c e6 e0 7d | ldab | 125, x |
| e289 a6 ed | ldaa | b, y | e31f e6 e8 7d | ldab | 125, y |
| e28b a6 f6 | ldaa | d, sp | e322 e6 8f | 1 dab | 15, sp |
| e28d a6 e6 | ldaa | d, x | e324 e6 0f | ldab | 15, x |
| e28f a6 ee | ldaa | d, y | e326 e6 4f | 1 dab | 15, y |
| e29196 55 | ldaa | dir | e328 e6 f0 10 | 1 dab | 16, sp |
| e2939655 | ldaa | dir | e32b e6 e0 10 | ldab | 16, x |
| e295 b6 0188 | ldaa | ext | e32e e6 e8 10 | ldab | 16, y |
| e298 b6 0188 | ldaa | ext | e331 e6 b7 | ldab | 8, sp+ |
| e29b a6 f2 0188 | ldaa | ext,sp | e333 e6 37 | ldab | 8, x+ |
| e29f a6 e2 0188 | ldaa | ext, x | e335 e6 77 | ldab | 8, $\mathrm{Y}^{+}$ |
| e2a3 a6 ea 0188 | ldaa | ext,y | e337 e6 b8 | 1 dab | 8,sp- |
| e2a7 a6 f8 37 | ldaa | ind, pc | e339 e6 38 | 1 dab | 8, x- |
| e2aa a6 f0 37 | ldaa | ind, sp | e33b e6 78 | 1 dab | 8, y- |
| e2ad a6 e0 37 | ldaa | ind, $x$ | e33d e6 f4 | ldab | a,sp |
| e2b0 a6 e8 37 | ldaa | ind, y | e33f e6 e4 | ldab | a, x |
| e2b3 a6 ce | ldaa | small, pc | e341 e6 ec | ldab | a, y |
| e2b5 a6 8e | ldaa | small,sp | e343 e6 f5 | 1 dab | b, sp |
| e2b7 a6 0e | ldaa | small, x | e345 e6 e5 | ldab | b , x |
| e2b9 a6 4e | ldaa | small, y | e347 e6 ed | 1 dab | b, y |
| e2bb c6 72 | 1 dab | \#immed | e349 e6 f6 | 1 dab | d,sp |
| e2bd c6 72 | 1 dab | \#immed | e34b e6 e6 | ldab | d, x |
| e2bf e6 a0 | 1 dab | 1, +sp | e34d e6 ee | ldab | d, y |
| e2c1 e6 20 | ldab | 1, +x | e34f d6 55 | ldab | dir |
| e2c3 e6 60 | ldab | 1, +y | e351 d6 55 | ldab | dir |
| e2c5 e6 a7 | 1 dab | 8, +sp | e353 f6 0188 | 1 dab | ext |
| e2c7 e6 27 | ldab | $8,+x$ | e356 f6 0188 | ldab | ext |
| e2c9 e6 67 | 1 dab | 8, +y | e359 e6 f2 0188 | 1 dab | ext,sp |
| e2cb e6 c0 | 1 dab | , pc | e35d e6 e2 0188 | 1 dab | ext, x |
| e2cd e6 80 | 1 dab | , sp | e361 e6 ea 0188 | 1 dab | ext,y |
| e2cf e6 00 | ldab | , x | e365 e6 f8 37 | ldab | ind, pc |
| e2d1 e6 40 | ldab | , Y | e368 e6 f0 37 | 1 dab | ind, sp |
| e2d3 e6 af | 1 dab | 1,-sp | e36b e6 e0 37 | 1 dab | ind, $x$ |
| e2d5 e6 2f | 1 dab | 1,-x | e36e e6 e8 37 | ldab | ind, y |
| e2d7 e6 6f | ldab | 1,-y | e371 e6 ce | ldab | small, pc |
| e2d9 e6 a8 | 1 dab | 8,-sp | e373 e6 8e | 1 dab | small, sp |
| e2db e6 28 | ldab | 8,-x | e375 e6 0e | 1 dab | small, x |
| e2dd e6 68 | 1 dab | 8,-y | e377 e6 4e | ldab | small, y |
| e2df e6 9f | 1 dab | -1, sp | e379 cc 0072 | ldd | \#immed |
| e2e1 e6 1f | ldab | -1, x | e37c cc 0072 | ldd | \#immed |
| e2e3 e6 5f | 1 dab | -1, y | e37f ec a0 | ldd | 1, +sp |
| e2e5 e6 90 | 1 dab | -16, sp | e381 ec 20 | ldd | $1,+x$ |
| e2e7 e6 10 | ldab | -16, x | e383 ec 60 | ldd | 1, +y |
| e2e9 e6 50 | 1 dab | -16, y | e385 ec a7 | ldd | 8, +sp |
| e2eb e6 f1 ef | 1 dab | -17, sp | e387 ec 27 | ldd | 8, +x |
| e2ee e6 e1 ef | 1 dab | -17,x | e389 ec 67 | ldd | 8, +y |
| e2f1 e6 e9 ef | 1 dab | -17, y | e38b ec c0 | ldd | , pc |
| e2f4 e6 d2 | ldab | -small, pc | e38d ec 80 | ldd | , sp |
| e2f6 e6 92 | 1 dab | -small,sp | e38f ec 00 | ldd | , x |
| e2f8 e6 12 | 1 dab | -small, x | e391 ec 40 | ldd | , Y |
| e2fa e6 52 | 1 dab | -small, y | e393 ec af | ldd | 1,-sp |
| e2fc e6 c0 | 1 dab | 0, pc | e395 ec 2f | ldd | 1,-x |
| e2fe e6 80 | 1 dab | $0, \mathrm{sp}$ | e397 ec 6f | ldd | 1,-y |
| e300 e6 00 | ldab | 0 , x | e399 ec a8 | ldd | 8,-sp |
| e302 e6 40 | ldab | 0,y | e39b ec 28 | ldd | 8,-x |
| e304 e6 b0 | 1 dab | 1, sp+ | e39d ec 68 | ldd | 8,-y |
| e306 e6 30 | 1 dab | 1, x+ | e39f ec 9f | ldd | -1, sp |
| e308 e6 70 | 1 dab | 1, $\mathrm{Y}^{+}$ | e3a1 ec 1f | ldd | -1, x |
| e30a e6 81 | 1 dab | 1, sp | e3a3 ec 5f | ldd | -1, y |
| e30c e6 01 | 1 dab | 1, x | e3a5 ec 90 | ldd | -16, sp |
| e30e e6 41 | 1 dab | 1, y | e3a7 ec 10 | ldd | -16, x |
| e310 e6 bf | 1 dab | 1, sp- | e3a9 ec 50 | ldd | -16, y |
| e312 e6 3f | ldab | 1, $\mathrm{x}-$ | e3ab ec fl ef | ldd | -17, sp |


| e3ae ec el ef | ldd | -17, x | e449 ef 67 | lds | 8, +y |
| :---: | :---: | :---: | :---: | :---: | :---: |
| e3b1 ec e9 ef | ldd | -17, y | e44b ef c0 | lds | , pc |
| e3b4 ec d2 | ldd | -small,pc | e44d ef 80 | lds | , sp |
| e3b6 ec 92 | ldd | -small,sp | e44f ef 00 | lds | , x |
| e3b8 ec 12 | ldd | -small, x | e451 ef 40 | lds | , Y |
| e3ba ec 52 | ldd | -small, y | e453 ef af | lds | 1,-sp |
| e3bc ec c0 | ldd | 0, pc | e455 ef 2 f | lds | 1,-x |
| e3be ec 80 | ldd | $0, \mathrm{sp}$ | e457 ef 6f | lds | 1,-y |
| e3c0 ec 00 | ldd | 0, x | e459 ef a8 | lds | 8,-sp |
| e3c2 ec 40 | ldd | 0,y | e45b ef 28 | lds | 8,-x |
| e3c4 ec b0 | ldd | 1, sp+ | e45d ef 68 | lds | 8,-y |
| e3c6 ec 30 | ldd | 1,x+ | e45f ef 9f | lds | -1, sp |
| e3c8 ec 70 | ldd | 1, $\mathrm{y}+$ | e461 ef 1f | lds | -1, x |
| e3ca ec 81 | ldd | 1, sp | e463 ef 5f | lds | -1, y |
| e3cc ec 01 | ldd | 1, x | e465 ef 90 | lds | -16, sp |
| e3ce ec 41 | ldd | 1, y | e467 ef 10 | lds | -16,x |
| e3d0 ec bf | ldd | 1, sp- | e469 ef 50 | lds | -16,y |
| e3d2 ec 3f | ldd | 1, $\mathrm{x}-$ | e46b ef fl ef | lds | -17, sp |
| e3d4 ec 7f | ldd | 1, $\mathrm{y}^{-}$ | e46e ef el ef | lds | -17, x |
| e3d6 ec f8 7d | ldd | 125, pc | e471 ef e9 ef | lds | -17, y |
| e3d9 ec f0 7d | ldd | 125, sp | e474 ef d2 | lds | -small, pc |
| e3dc ec e0 7d | ldd | 125, x | e476 ef 92 | lds | -small, sp |
| e3df ec e8 7d | ldd | 125, y | e478 ef 12 | lds | -small, x |
| e3e2 ec 8f | ldd | 15, sp | e47a ef 52 | lds | -small, y |
| e3e4 ec $0 f$ | ldd | 15, x | e47c ef c0 | lds | 0, pc |
| e3e6 ec 4f | ldd | 15, y | e47e ef 80 | lds | $0, \mathrm{sp}$ |
| e3e8 ec f0 10 | ldd | 16, sp | e480 ef 00 | lds | 0 , x |
| e3eb ec e0 10 | ldd | 16, x | e482 ef 40 | lds | 0, y |
| e3ee ec e8 10 | ldd | 16, y | e484 ef b0 | lds | 1, sp+ |
| e3f1 ec b7 | ldd | 8, sp+ | e486 ef 30 | lds | 1, x+ |
| e3f3 ec 37 | ldd | 8, x+ | e488 ef 70 | lds | 1, $\mathrm{y}+$ |
| e3f5 ec 77 | ldd | 8, y+ | e48a ef 81 | lds | 1, sp |
| e3f7 ec b8 | ldd | 8,sp- | e48c ef 01 | lds | 1, x |
| e3f9 ec 38 | ldd | 8, x- | e48e ef 41 | lds | 1, y |
| e3fb ec 78 | ldd | 8, y- | e490 ef bf | lds | 1,sp- |
| e3fd ec f4 | ldd | a,sp | e492 ef 3f | lds | 1, $\mathrm{x}-$ |
| e3ff ec e4 | ldd | a, x | e494 ef 7f | lds | 1, $\mathrm{Y}^{-}$ |
| e401 ec ec | ldd | a, y | e496 ef f8 7d | lds | 125, pc |
| e403 ec f5 | ldd | b, sp | e499 ef f0 7d | lds | 125, sp |
| e405 ec e5 | ldd | b , x | e49c ef e0 7d | lds | 125, x |
| e407 ec ed | ldd | b, y | e49f ef e8 7d | lds | 125, y |
| e409 ec f6 | ldd | d,sp | e4a2 ef 8f | lds | 15, sp |
| e40b ec e6 | ldd | d, x | e4a4 ef $0 f$ | lds | 15, x |
| e40d ec ee | ldd | d, y | e4a6 ef 4f | lds | 15, y |
| e40f dc 55 | ldd | dir | e4a8 ef f0 10 | lds | 16, sp |
| e411 dc 55 | ldd | dir | e4ab ef e0 10 | lds | 16, x |
| e413 fc 0188 | ldd | ext | e4ae ef e8 10 | lds | 16, y |
| e416 fc 0188 | ldd | ext | e4b1 ef b7 | lds | 8,sp+ |
| e419 ec f2 0188 | ldd | ext,sp | e4b3 ef 37 | lds | 8, x+ |
| e41d ec e2 0188 | ldd | ext, x | e4b5 ef 77 | lds | 8, y+ |
| e421 ec ea 0188 | ldd | ext,y | e4b7 ef b8 | lds | 8,sp- |
| e425 ec f8 37 | ldd | ind, pc | e4b9 ef 38 | lds | 8, x- |
| e428 ec f0 37 | ldd | ind,sp | e4bb ef 78 | lds | 8, y- |
| e42b ec e0 37 | ldd | ind, x | e4bd ef f4 | lds | a,sp |
| e42e ec e8 37 | ldd | ind, y | e4bf ef e4 | lds | a, x |
| e431 ec ce | ldd | small, pc | e4c1 ef ec | lds | a, y |
| e433 ec 8e | ldd | small,sp | e4c3 ef f5 | lds | b, sp |
| e435 ec 0 e | ldd | small, x | e4c5 ef e5 | lds | b, x |
| e437 ec 4e | ldd | small, y | e4c7 ef ed | lds | b, y |
| e439 cf 0072 | lds | \#immed | e4c9 ef f6 | lds | d, sp |
| e43c cf 0072 | lds | \#immed | e4cb ef e6 | lds | d, x |
| e43f ef a0 | lds | 1, +sp | e4cd ef ee | lds | d, y |
| e441 ef 20 | lds | $1,+\mathrm{x}$ | e4cf df 55 | lds | dir |
| e443 ef 60 | lds | 1, +y | e4d1 ff 0188 | lds | ext |
| e445 ef a7 | lds | 8, +sp | e4d4 ef f2 0188 | lds | ext,sp |
| e447 ef 27 | 1 ds | 8, +x | e4d8 ef e2 0188 | 1 ds | ext, x |


| e4dc ef ea 0188 | lds | ext,y | e572 ee b8 | ldx | 8,sp- |
| :---: | :---: | :---: | :---: | :---: | :---: |
| e4e0 ef f8 37 | lds | ind, pc | e574 ee 38 | ldx | 8, x- |
| e4e3 ef f0 37 | lds | ind, sp | e576 ee 78 | ldx | 8, y- |
| e4e6 ef e0 37 | lds | ind, $x$ | e578 ee f4 | ldx | a,sp |
| e4e9 ef e8 37 | lds | ind, y | e57a ee e4 | $1 d x$ | a, x |
| e4ec ef ce | lds | small, pc | e57c ee ec | ldx | a, y |
| e4ee ef 8 e | lds | small,sp | e57e ee f5 | $1 d x$ | b, sp |
| e4f0 ef 0 e | lds | small, x | e580 ee e5 | ldx | b , x |
| e4f2 ef 4 e | lds | small, y | e582 ee ed | $1 d x$ | b, y |
| e4f4 ce 0072 | $1 d x$ | \#immed | e584 ee f6 | $1 d x$ | d, sp |
| e4f7 ce 0072 | $1 d x$ | \#immed | e586 ee e6 | ldx | d, x |
| e4fa ee a0 | $1 d x$ | 1, +sp | e588 ee ee | ldx | d, y |
| e4fc ee 20 | ldx | 1, +x | e58a de 55 | ldx | dir |
| e4fe ee 60 | $1 d x$ | 1, +y | e58c de 55 | $1 d x$ | dir |
| e500 ee a7 | $1 d x$ | 8, +sp | e58e fe 0188 | $1 d x$ | ext |
| e502 ee 27 | ldx | $8,+x$ | e591 fe 0188 | ldx | ext |
| e504 ee 67 | $1 d x$ | 8, +y | e594 ee f2 0188 | $1 d x$ | ext,sp |
| e506 ee c0 | 1 dx | , pc | e598 ee e2 0188 | $1 d x$ | ext, x |
| e508 ee 80 | $1 d x$ | , sp | e59c ee ea 0188 | ldx | ext, y |
| e50a ee 00 | ldx | , x | e5a0 ee f8 37 | ldx | ind, pc |
| e50c ee 40 | $1 d x$ | , Y | e5a3 ee f0 37 | ldx | ind, sp |
| e50e ee af | 1 dx | 1,-sp | e5a6 ee e0 37 | $1 d x$ | ind, $x$ |
| e510 ee 2 f | ldx | 1,-x | e5a9 ee e8 37 | ldx | ind, y |
| e512 ee 6f | 1 dx | 1,-y | e5ac ee ce | 1 dx | small, pc |
| e514 ee a8 | $1 d x$ | 8,-sp | e5ae ee 8e | $1 d x$ | small, sp |
| e516 ee 28 | $1 d x$ | 8,-x | e5b0 ee 0 e | $1 d x$ | small, x |
| e518 ee 68 | ldx | 8,-y | e5b2 ee 4 e | ldx | small, y |
| e51a ee 9f | 1 dx | -1, sp | e5b4 cd 0072 | ldy | \#immed |
| e51c ee 1f | $1 d x$ | -1, x | e5b7 cd 0072 | ldy | \#immed |
| e51e ee 5f | $1 d x$ | -1, y | e5ba ed a0 | ldy | 1, +sp |
| e520 ee 90 | $1 d x$ | -16, sp | e5bc ed 20 | ldy | $1,+\mathrm{x}$ |
| e522 ee 10 | $1 d x$ | -16, x | e5be ed 60 | ldy | 1, +y |
| e524 ee 50 | $1 d x$ | -16,y | e5c0 ed a7 | ldy | 8, +sp |
| e526 ee f1 ef | ldx | -17, sp | e5c2 ed 27 | ldy | $8,+x$ |
| e529 ee e1 ef | $1 d x$ | -17, x | e5c4 ed 67 | ldy | 8, +y |
| e52c ee e9 ef | 1 dx | -17, y | e5c6 ed c0 | ldy | , pc |
| e52f ee d2 | $1 d x$ | -small, pc | e5c8 ed 80 | ldy | , sp |
| e531 ee 92 | $1 d x$ | -small,sp | e5ca ed 00 | ldy | , x |
| e533 ee 12 | $1 d x$ | -small, x | e5cc ed 40 | ldy | , y |
| e535 ee 52 | ldx | -small, y | e5ce ed af | ldy | 1,-sp |
| e537 ee c0 | $1 d x$ | $0, \mathrm{pc}$ | e5d0 ed 2f | ldy | 1,-x |
| e539 ee 80 | 1 dx | $0, \mathrm{sp}$ | e5d2 ed 6f | ldy | 1,-y |
| e53b ee 00 | 1 dx | 0 , x | e5d4 ed a8 | ldy | 8,-sp |
| e53d ee 40 | $1 d x$ | 0, y | e5d6 ed 28 | ldy | 8,-x |
| e53f ee b0 | $1 d x$ | 1, sp+ | e5d8 ed 68 | ldy | 8,-y |
| e541 ee 30 | $1 d x$ | 1, x+ | e5da ed 9f | ldy | -1, sp |
| e543 ee 70 | $1 d x$ | 1, $\mathrm{y}+$ | e5dc ed 1f | ldy | -1, x |
| e545 ee 81 | 1 dx | 1,sp | e5de ed 5f | ldy | -1, y |
| e547 ee 01 | $1 d x$ | 1, x | e5e0 ed 90 | ldy | -16, sp |
| e549 ee 41 | $1 d x$ | 1, Y | e5e2 ed 10 | ldy | -16, x |
| e54b ee bf | 1 dx | 1,sp- | e5e4 ed 50 | ldy | -16, y |
| e54d ee 3f | 1 dx | 1, $\mathrm{x}-$ | e5e6 ed f1 ef | ldy | -17, sp |
| e54f ee 7f | $1 d x$ | 1, $\mathrm{y}^{-}$ | e5e9 ed e1 ef | ldy | -17,x |
| e551 ee f8 7d | $1 d x$ | 125, pc | e5ec ed e9 ef | ldy | -17, y |
| e554 ee f0 7d | $1 d x$ | 125, sp | e5ef ed d2 | ldy | -small, pc |
| e557 ee e0 7d | $1 d x$ | 125, x | e5f1 ed 92 | ldy | -small,sp |
| e55a ee e8 7d | $1 d x$ | 125, y | e5f3 ed 12 | ldy | -small, x |
| e55d ee 8f | $1 d x$ | 15, sp | e5f5 ed 52 | ldy | -small, y |
| e55f ee 0 f | $1 d x$ | 15, x | e5f7 ed c0 | ldy | 0, pc |
| e561 ee 4f | 1 dx | 15, y | e5f9 ed 80 | ldy | 0, sp |
| e563 ee f0 10 | $1 d x$ | 16, sp | e5fb ed 00 | ldy | 0, x |
| e566 ee e0 10 | $1 d x$ | 16, x | e5fd ed 40 | ldy | 0,y |
| e569 ee e8 10 | $1 d x$ | 16, y | e5ff ed b0 | ldy | 1, sp+ |
| e56c ee b7 | $1 d x$ | 8, sp+ | e601 ed 30 | ldy | 1, x+ |
| e56e ee 37 | $1 d x$ | 8, x+ | e603 ed 70 | ldy | 1, y+ |
| e570 ee 77 | $1 d x$ | 8, $\mathrm{Y}+$ | e605 ed 81 | ldy | 1, sp |


| e607 ed 01 | $1 d y$ | 1, x | e69e 1b 50 | leas | -16,y |
| :---: | :---: | :---: | :---: | :---: | :---: |
| e609 ed 41 | ldy | 1, y | e6a0 1b f1 ef | leas | -17, sp |
| e60b ed bf | ldy | 1,sp- | e6a3 1b e1 ef | leas | -17,x |
| e60d ed 3f | ldy | 1, $\mathrm{x}-$ | e6a6 1b e9 ef | leas | -17, y |
| e60f ed 7f | ldy | 1, $\mathrm{Y}^{-}$ | e6a9 1b d2 | leas | -small, pc |
| e611 ed f8 7d | ldy | 125, pc | e6ab 1b 92 | leas | -small,sp |
| e614 ed f0 7d | ldy | 125, sp | e6ad 1b 12 | leas | -small,x |
| e617 ed e0 7d | ldy | 125, x | e6af 1b 52 | leas | -small, y |
| e61a ed e8 7d | ldy | 125, y | e6b1 1b c0 | leas | 0, pc |
| e61d ed 8f | 1 dy | 15, sp | e6b3 1b 80 | leas | $0, \mathrm{sp}$ |
| e61f ed 0f | ldy | 15, x | e6b5 1b 00 | leas | 0,x |
| e621 ed 4f | ldy | 15, y | e6b7 1b 40 | leas | 0,y |
| e623 ed f0 10 | 1 dy | $16, \mathrm{sp}$ | e6b9 1b b0 | leas | 1, sp+ |
| e626 ed e0 10 | ldy | 16, x | e6bb 1b 30 | leas | 1, x+ |
| e629 ed e8 10 | ldy | 16, y | e6bd 1b 70 | leas | 1, $\mathrm{y}^{+}$ |
| e62c ed b7 | 1 dy | 8,sp+ | e6bf 1b 81 | leas | 1, sp |
| e62e ed 37 | ldy | 8,x+ | e6c1 1b 01 | leas | 1, x |
| e630 ed 77 | ldy | 8, y+ | e6c3 1b 41 | leas | 1, y |
| e632 ed b8 | ldy | 8, sp- | e6c5 1b bf | leas | 1, sp- |
| e634 ed 38 | ldy | 8, x- | e6c7 1b 3f | leas | 1, $\mathrm{x}-$ |
| e636 ed 78 | 1 dy | 8, y- | e6c9 1b 7 f | leas | 1, $\mathrm{y}^{-}$ |
| e638 ed f4 | ldy | a,sp | e6cb 1b f8 7d | leas | 125, pc |
| e63a ed e4 | ldy | a, x | e6ce 1b f0 7d | leas | 125, sp |
| e63c ed ec | ldy | a, y | e6d1 1b e0 7d | leas | 125, x |
| e63e ed f5 | 1 dy | b, sp | e6d4 1b e8 7d | leas | 125, y |
| e640 ed e5 | ldy | b, x | e6d7 1b 8f | leas | 15, sp |
| e642 ed ed | ldy | $b, y$ | e6d9 1b 0 f | leas | 15, x |
| e644 ed f6 | 1 dy | d, sp | e6db 1b 4 f | leas | 15, y |
| e646 ed e6 | ldy | d, x | e6dd 1b f0 10 | leas | 16, sp |
| e648 ed ee | ldy | d, y | e6e0 1b e0 10 | leas | 16,x |
| e64a dd 55 | 1 dy | dir | e6e3 1b e8 10 | leas | 16, y |
| e64c dd 55 | $1 d y$ | dir | e6e6 1b b7 | leas | 8, sp+ |
| e64e fd 0188 | ldy | ext | e6e8 1b 37 | leas | 8, x+ |
| e651 fd 0188 | ldy | ext | e6ea 1b 77 | leas | 8, y+ |
| e654 ed f2 0188 | ldy | ext,sp | e6ec 1b b8 | leas | 8,sp- |
| e658 ed e2 0188 | ldy | ext, x | e6ee 1b 38 | leas | 8, $\mathrm{x}-$ |
| e65c ed ea 0188 | ldy | ext,y | e6f0 1b 78 | leas | 8, $\mathrm{y}^{-}$ |
| e660 ed f8 37 | ldy | ind, pc | e6f2 1b f4 | leas | a,sp |
| e663 ed f0 37 | 1 dy | ind, sp | e6f4 1b e4 | leas | a, x |
| e666 ed e0 37 | $1 d y$ | ind, x | e6f6 1b ec | leas | a, y |
| e669 ed e8 37 | ldy | ind, y | e6f8 1b f5 | leas | b, sp |
| e66c ed ce | ldy | small, pc | e6fa 1b e5 | leas | b, x |
| e66e ed 8e | ldy | small,sp | e6fc 1b ed | leas | b, y |
| e670 ed 0 e | 1 dy | small, x | e6fe 1b f6 | leas | d, sp |
| e672 ed 4e | 1 dy | small,y | e700 1b e6 | leas | d, x |
| e674 1b a0 | leas | 1, +sp | e702 1b ee | leas | d, y |
| e676 1b 20 | leas | $1,+\mathrm{x}$ | e704 1b f2 0188 | leas | ext,sp |
| e678 1b 60 | leas | 1, +y | e708 1b e2 0188 | leas | ext, x |
| e67a 1b a7 | leas | 8, +sp | e70c 1b ea 0188 | leas | ext,y |
| e67c 1b 27 | leas | $8,+x$ | e710 1b f8 37 | leas | ind, pc |
| e67e 1b 67 | leas | 8, +y | e713 1b f0 37 | leas | ind, sp |
| e680 1b c0 | leas | , pc | e716 1b e0 37 | leas | ind, x |
| e682 1b 80 | leas | , sp | e719 1b e8 37 | leas | ind, y |
| e684 1b 00 | leas | , x | e71c 1b ce | leas | small, pc |
| e686 1b 40 | leas | , Y | e71e 1b 8e | leas | small,sp |
| e688 1b af | leas | 1,-sp | e720 1b 0e | leas | small, x |
| e68a 1b 2f | leas | 1,-x | e722 1b 4e | leas | small, y |
| e68c 1b 6f | leas | 1,-y | e724 1a a0 | leax | 1, +sp |
| e68e 1b a8 | leas | 8,-sp | e726 1a 20 | leax | $1,+x$ |
| e690 1b 28 | leas | 8,-x | e728 1a 60 | leax | 1, +y |
| e692 1b 68 | leas | 8,-y | e72a 1a a7 | leax | 8, +sp |
| e694 1b 9f | leas | -1, sp | e72c 1a 27 | leax | 8, +x |
| e696 1b 1f | leas | -1, x | e72e 1a 67 | leax | 8, +y |
| e698 1b 5f | leas | -1, y | e730 1a c0 | leax | , pc |
| e69a 1b 90 | leas | -16, sp | e732 1a 80 | leax | , sp |
| e69c 1b 10 | leas | -16, x | e734 1a 00 | leax | , x |


| e736 1a 40 | leax | , y | e7ce 1a 8e | leax | small,sp |
| :---: | :---: | :---: | :---: | :---: | :---: |
| e738 1a af | leax | 1,-sp | e7d0 1a 0 e | leax | small, x |
| e73a 1a 2f | leax | 1,-x | e7d2 1a 4 e | leax | small, y |
| e73c 1a 6 f | leax | 1,-y | e7d4 19 a0 | leay | 1, +sp |
| e73e 1a a8 | leax | 8,-sp | e7d6 1920 | leay | $1,+\mathrm{x}$ |
| e740 1a 28 | leax | 8,-x | e7d8 1960 | leay | 1, +y |
| e742 1a 68 | leax | 8,-y | e7da 19 a7 | leay | 8, +sp |
| e744 1a 9f | leax | -1, sp | e7dc 1927 | leay | 8, +x |
| e746 1a 1f | leax | -1, x | e7de 1967 | leay | 8, +y |
| e748 1a 5f | leax | -1, y | e7e0 19 c0 | leay | , pc |
| e74a 1a 90 | leax | -16, sp | e7e2 1980 | leay | , sp |
| e74c 1a 10 | leax | -16, x | e7e4 1900 | leay | , x |
| e74e 1a 50 | leax | -16, y | e7e6 1940 | leay | , Y |
| e750 1a f1 ef | leax | -17, sp | e7e8 19 af | leay | 1,-sp |
| e753 1a e1 ef | leax | -17, x | e7ea 192 f | leay | 1,-x |
| e756 1a e9 ef | leax | -17,y | e7ec 19 6f | leay | 1,-y |
| e759 1a d2 | leax | -small, pc | e7ee 19 a8 | leay | 8,-sp |
| e75b 1a 92 | leax | -small,sp | e7f0 1928 | leay | 8,-x |
| e75d 1a 12 | leax | -small, x | e7f2 1968 | leay | 8,-y |
| e75f 1a 52 | leax | -small, y | e7f4 19 9f | leay | -1, sp |
| e761 1a c0 | leax | 0, pc | e7f6 19 1f | leay | -1, x |
| e763 1a 80 | leax | 0, sp | e7f8 195 f | leay | -1, y |
| e765 1a 00 | leax | 0 , x | e7fa 1990 | leay | -16, sp |
| e767 1a 40 | leax | 0, y | e7fc 1910 | leay | -16, x |
| e769 1a b0 | leax | 1, sp+ | e7fe 1950 | leay | -16, y |
| e76b 1a 30 | leax | 1, x+ | e800 19 f1 ef | leay | -17, sp |
| e76d 1a 70 | leax | 1, $\mathrm{y}^{+}$ | e803 19 e1 ef | leay | -17, x |
| e76f 1a 81 | leax | 1, sp | e806 19 e9 ef | leay | -17, y |
| e771 1a 01 | leax | 1, x | e809 19 d2 | leay | -small, pc |
| e773 1a 41 | leax | 1, y | e80b 1992 | leay | -small,sp |
| e775 1a bf | leax | 1, sp- | e80d 1912 | leay | -small, x |
| e777 1a 3f | leax | 1, $\mathrm{x}-$ | e80f 1952 | leay | -small, y |
| e779 1a 7f | leax | 1, $\mathrm{y}^{-}$ | e811 19 c0 | leay | 0, pc |
| e77b 1a f8 7d | leax | 125, pc | e813 1980 | leay | 0, sp |
| e77e 1a f0 7d | leax | 125, sp | e815 1900 | leay | 0 , x |
| e781 1a e0 7d | leax | 125, x | e817 1940 | leay | 0, y |
| e784 1a e8 7d | leax | 125, y | e819 19 b0 | leay | 1, sp+ |
| e787 1a 8f | leax | 15, sp | e81b 1930 | leay | 1, x+ |
| e789 1a $0 ¢$ | leax | 15, x | e81d 1970 | leay | 1, $\mathrm{y}^{+}$ |
| e78b 1a 4 f | leax | 15, y | e81f 1981 | leay | 1, sp |
| e78d 1a f0 10 | leax | 16, sp | e821 1901 | leay | 1, x |
| e790 1a e0 10 | leax | 16, x | e823 1941 | leay | 1, y |
| e793 1a e8 10 | leax | 16, y | e825 19 bf | leay | 1, sp- |
| e796 1a b7 | leax | 8,sp+ | e827 19 3f | leay | 1, $\mathrm{x}^{-}$ |
| e798 1a 37 | leax | 8, x+ | e829 197 f | leay | 1, $\mathrm{y}^{-}$ |
| e79a 1a 77 | leax | 8, y+ | e82b 19 f8 7d | leay | 125, pc |
| e79c 1a b8 | leax | 8,sp- | e82e 19 f0 7d | leay | 125, sp |
| e79e 1a 38 | leax | 8, x- | e831 19 e0 7d | leay | 125, x |
| e7a0 1a 78 | leax | 8, $\mathrm{y}^{-}$ | e834 19 e8 7d | leay | 125, y |
| e7a2 1a f4 | leax | a,sp | e837 198 f | leay | 15, sp |
| e7a4 1a e4 | leax | a, x | e839 190 f | leay | 15, x |
| e7a6 1a ec | leax | a, y | e83b 194 f | leay | 15, y |
| e7a8 1a f5 | leax | b, sp | e83d 19 f0 10 | leay | 16, sp |
| e7aa 1a e5 | leax | b , x | e840 19 e0 10 | leay | 16, x |
| e7ac la ed | leax | $\mathrm{b}, \mathrm{y}$ | e843 19 e8 10 | leay | 16, y |
| e7ae 1a f6 | leax | d,sp | e846 $19 \mathrm{b7}$ | leay | 8, sp+ |
| e7b0 1a e6 | leax | d, x | e848 1937 | leay | 8, x+ |
| e7b2 1a ee | leax | d, y | e84a 1977 | leay | 8, y+ |
| e7b4 1a f2 0188 | leax | ext,sp | e84c 19 b8 | leay | 8, sp- |
| e7b8 1a e2 0188 | leax | ext, x | e84e 1938 | leay | 8, $\mathrm{x}^{-}$ |
| e7bc 1a ea 0188 | leax | ext, y | e850 1978 | leay | 8, y- |
| e7c0 1a f8 37 | leax | ind, pc | e852 19 f4 | leay | a,sp |
| e7c3 1a f0 37 | leax | ind,sp | e854 19 e4 | leay | a, x |
| e7c6 1a e0 37 | leax | ind, x | e856 19 ec | leay | a, y |
| e7c9 1a e8 37 | leax | ind, y | e858 19 f5 | leay | b, sp |
| e7cc 1a ce | leax | small, pc | e85a 19 e5 | leay | b , x |



| e985 64 b0 | lsr | 1, sp+ | $\begin{array}{lllll}e a 27 & 18 & 18 & 28\end{array}$ | maxa | 8,-x |
| :---: | :---: | :---: | :---: | :---: | :---: |
| e987 6430 | lsr | 1,x+ | ea2a 181868 | maxa | 8,-y |
| e989 6470 | lsr | 1, $\mathrm{y}+$ | ea2d 18189 f | maxa | -1, sp |
| e98b 6481 | lsr | 1, sp | ea30 18 18 1f | maxa | -1, x |
| e98d 6401 | lsr | 1, x | ea33 18185 f | maxa | -1, y |
| e98f 6441 | lsr | 1, y | ea36 181890 | maxa | -16, sp |
| e991 64 bf | 1 sr | 1, sp- | ea39 181818 | maxa | $-16, \mathrm{x}$ |
| e993 643 f | lsr | 1, x- | ea3c 181850 | maxa | -16, y |
| e995 647 f | lsr | 1, $\mathrm{y}^{-}$ | ea3f 1818 f1 ef | maxa | -17, sp |
| e997 64 f8 7d | lsr | 125, pc | ea43 1818 e1 ef | maxa | -17,x |
| e99a 64 f0 7d | lsr | 125, sp | ea47 1818 e9 ef | maxa | -17, y |
| e99d 64 e0 7d | lsr | 125, x | ea4b 1818 d2 | maxa | -small, pc |
| e9a0 64 e8 7d | lsr | 125, y | ea4e 181892 | maxa | -small, sp |
| e9a3 648 f | 1 sr | 15, sp | $\begin{array}{lllll}\text { ea51 } & 18 & 18 & 12\end{array}$ | maxa | -small, x |
| e9a5 640 f | lsr | 15, x | ea54 181852 | maxa | -small, y |
| e9a7 644 f | lsr | 15, y | ea57 1818 c0 | maxa | 0, pc |
| e9a9 64 f0 10 | lsr | 16, sp | ea5a 181880 | maxa | $0, \mathrm{sp}$ |
| e9ac 64 e0 10 | lsr | 16, x | ea5d 181800 | maxa | 0,x |
| e9af 64 e8 10 | lsr | 16, y | ea60 181840 | maxa | 0,y |
| e9b2 64 b7 | lsr | 8, sp+ | ea63 1818 b0 | maxa | 1, sp+ |
| e9b4 6437 | lsr | 8, x+ | ea66 181830 | maxa | 1, x+ |
| e9b6 6477 | lsr | 8, y+ | ea69 181870 | maxa | 1, $\mathrm{y}^{+}$ |
| e9b8 64 b8 | lsr | 8, sp- | ea6c 181881 | maxa | 1, sp |
| e9ba 6438 | lsr | 8, x- | ea6f 181801 | maxa | 1,x |
| e9bc 6478 | lsr | 8, $\mathrm{y}^{-}$ | ea72 181841 | maxa | 1, Y |
| e9be 64 f 4 | lsr | a,sp | ea75 1818 bf | maxa | 1, sp- |
| e9c0 64 e4 | lsr | a, x | ea78 1818 3f | maxa | 1, x- |
| e9c2 64 ec | lsr | a, y | ea7b 18187 f | maxa | 1, $\mathrm{y}^{-}$ |
| e9c4 64 f 5 | lsr | b, sp | ea7e 1818 f8 7d | maxa | 125, pc |
| e9c6 64 e5 | lsr | $\mathrm{b}, \mathrm{x}$ | ea82 $1818 \mathrm{f0} 7 \mathrm{~d}$ | maxa | 125, sp |
| e9c8 64 ed | lsr | b, y | ea86 1818 e0 7d | maxa | 125, x |
| e9ca $64 \mathrm{f6}$ | lsr | d, sp | ea8a 1818 e8 7d | maxa | 125, y |
| e9cc 64 e6 | lsr | d, x | ea8e 1818 8f | maxa | 15, sp |
| e9ce 64 ee | lsr | d, y | ea91 $18180 f$ | maxa | 15, x |
| e9d0 740055 | 1 sr | dir | ea94 18184 f | maxa | 15, y |
| e9d3 740188 | lsr | ext | ea97 1818 f0 10 | maxa | 16, sp |
| e9d6 740188 | lsr | ext | ea9b 1818 e0 10 | maxa | 16, x |
| e9d9 64 f2 0188 | lsr | ext,sp | ea9f 1818 e8 10 | maxa | 16, y |
| e9dd 64 e2 0188 | lsr | ext, x | eaa3 1818 b7 | maxa | 8, sp+ |
| e9e1 64 ea 0188 | lsr | ext,y | eaa6 181837 | maxa | 8, x+ |
| e9e5 64 f8 37 | lsr | ind, pc | eaa9 181877 | maxa | 8, $\mathrm{y}^{+}$ |
| e9e8 64 f0 37 | lsr | ind, sp | eaac 1818 b8 | maxa | 8,sp- |
| e9eb 64 e0 37 | lsr | ind, x | eaaf 181838 | maxa | 8, x- |
| e9ee 64 e8 37 | 1 sr | ind, $y$ | eab2 181878 | maxa | 8, $\mathrm{y}^{-}$ |
| e9f1 64 ce | lsr | small, pc | eab5 181818 f 4 | maxa | a,sp |
| e9f3 648 e | lsr | small,sp | eab8 1818 e4 | maxa | a, x |
| e9f5 640 l | lsr | small, x | eabb 1818 ec | maxa | a, y |
| e9f7 64 4e | lsr | small,y | eabe 1818 f 5 | maxa | b, sp |
| e9f9 44 | lsra |  | eac1 1818 e5 | maxa | b, x |
| e9fa 54 | lsrb |  | eac4 1818 ed | maxa | b, y |
| e9fb 49 | lsrd |  | eac7 1818 f 6 | maxa | d, sp |
| e9fc 49 | lsrd |  | eaca 1818 e6 | maxa | d, x |
| e9fd 1818 a0 | maxa | 1, +sp | eacd 1818 ee | maxa | d, y |
| ea00 181818 | maxa | 1, +x | ead0 1818 f2 0188 | maxa | ext,sp |
| ea03 18 18 60 | maxa | 1, + y | ead5 1818 e2 0188 | maxa | ext,x |
| ea06 18 18 a7 | maxa | 8, +sp | eada 1818 ea 0188 | maxa | ext,y |
| ea09 1818 27 | maxa | $8,+x$ | eadf 1818 f8 37 | maxa | ind, pc |
| ea0c 181867 | maxa | 8, +y | eae3 1818 f0 37 | maxa | ind,sp |
| ea0f 1818 c 0 | maxa | , pc | eae7 1818 e0 37 | maxa | ind, x |
| ea12 181880 | maxa | , sp | eaeb 1818 e8 37 | maxa | ind,y |
| ea15 181800 | maxa | , x | eaef 1818 ce | maxa | small, pc |
| ea18 181840 | maxa | , y | eaf2 1818 8e | maxa | small,sp |
| ealb 1818 af | maxa | 1,-sp | eaf5 18180 l | maxa | small, x |
| eale 18182 f | maxa | 1,-x | eaf8 18184 e | maxa | small, y |
| ea21 1818 6f | maxa | 1,-y | eafb 18 1c a0 | maxm | 1, +sp |
| ea24 1818 a8 | maxa | 8,-sp | eafe 18 1c 20 | maxm | $1,+\mathrm{x}$ |


| eb01 18 1c 60 | maxm | 1, +y | ebd3 18 1c e2 0188 | maxm | ext, x |
| :---: | :---: | :---: | :---: | :---: | :---: |
| eb04 18 1c a7 | maxm | 8, +sp | ebd8 18 1c ea 0188 | maxm | ext,y |
| eb07 18 1c 27 | maxm | $8,+x$ | ebdd 18 1c f8 37 | maxm | ind, pc |
| eb0a 181 c 67 | maxm | 8, +y | ebe1 18 1c f0 37 | maxm | ind, sp |
| eb0d 18 1c c0 | maxm | , pc | ebe5 18 1c e0 37 | $\operatorname{maxm}$ | ind, $x$ |
| eb10 18 1c 80 | maxm | , sp | ebe9 181 c e8 37 | maxm | ind, y |
| eb13 18 1c 00 | maxm | , x | ebed 18 1c ce | maxm | small, pc |
| eb16 18 1c 40 | maxm | , Y | ebf0 181 c 8 e | maxm | small,sp |
| eb19 18 1c af | maxm | 1,-sp | ebf3 18 1c 0e | maxm | small, x |
| eb1c 181 l 2f | maxm | 1,-x | ebf6 18 1c 4e | maxm | small,y |
| eb1f 181 c 6f | maxm | 1,-y | ebf9 01 | mem |  |
| eb22 18 1c a8 | maxm | 8,-sp | ebfa 1819 a 0 | mina | 1, +sp |
| eb25 18 1c 28 | maxm | 8,-x | ebfd 181920 | mina | $1,+x$ |
| eb28 18 1c 68 | maxm | 8,-y | ec00 181960 | mina | 1, +y |
| eb2b 181 l 9f | maxm | -1, sp | ec03 18 19 a7 | mina | 8, +sp |
| eb2e 18 1c 1f | maxm | -1, x | ec06 18181927 | mina | 8, +x |
| eb31 18 1c 5f | maxm | -1, y | $\begin{array}{llllll}e c 09 & 18 & 19 & 67\end{array}$ | mina | 8, +y |
| eb34 18 1c 90 | maxm | -16, sp | ec0c 1819 c 0 | mina | , pc |
| eb37 18 1c 10 | maxm | -16, x | ec0f 181980 | mina | , sp |
| eb3a 18 1c 50 | maxm | -16, y | ec12 181900 | mina | , X |
| eb3d 181 l f1 ef | maxm | -17, sp | $\begin{array}{lllll}\text { ec15 } & 18 & 19 & 40\end{array}$ | mina | , Y |
| eb41 18 1c e1 ef | maxm | -17, x | ec18 1819 af | mina | 1,-sp |
| eb45 18 1c e9 ef | maxm | -17, y | ec1b 18192 f | mina | 1,-x |
| eb49 18 1c d2 | maxm | -small, pc | ecle 1819 6f | mina | 1,-y |
| eb4c 18 1c 92 | maxm | -small, sp | ec21 1819 a8 | mina | 8,-sp |
| eb4f 18 1c 12 | maxm | -small,x | $\begin{array}{llllll}e c 24 & 18 & 19 & 28\end{array}$ | mina | 8,-x |
| eb52 18 1c 52 | maxm | -small,y | ec27 181968 | mina | 8,-y |
| eb55 18 1c c0 | maxm | 0, pc | ec2a 1819 9f | mina | -1, sp |
| eb58 18 1c 80 | maxm | 0,sp | ec2d 1819 1f | mina | -1, x |
| eb5b 18 1c 00 | maxm | 0, x | ec30 1819 5f | mina | -1, y |
| eb5e 18 1c 40 | maxm | 0, y | ec33 181990 | mina | -16, sp |
| eb61 18 1c b0 | maxm | 1, sp+ | ec36 181910 | mina | -16, x |
| eb64 18 1c 30 | maxm | 1, x+ | ec39 181950 | mina | -16, y |
| eb67 18 1c 70 | maxm | 1, $\mathrm{Y}^{+}$ | ec3c $1819 \mathrm{f1}$ ef | mina | -17, sp |
| eb6a 181 c 81 | maxm | 1, sp | ec40 1819 e1 ef | mina | -17, x |
| eb6d 18 1c 01 | maxm | 1, x | ec44 1819 e9 ef | mina | -17, y |
| eb70 18 1c 41 | maxm | 1, y | ec48 1819 d 2 | mina | -small, pc |
| eb73 18 1c bf | maxm | 1,sp- | ec4b 181992 | mina | -small,sp |
| eb76 18 1c 3f | maxm | 1, $\mathrm{x}-$ | ec4e 181912 | mina | -small, x |
| eb79 18 1c 7f | maxm | 1, $\mathrm{y}^{-}$ | ec51 181952 | mina | -small, y |
| eb7c 18 1c f8 7d | maxm | 125, pc | ec54 181819 c0 | mina | 0, pc |
| eb80 18 1c f0 7d | maxm | 125, sp | $\begin{array}{llllll}e c 57 & 18 & 19 & 80\end{array}$ | mina | $0, \mathrm{sp}$ |
| eb84 18 1c e0 7d | maxm | 125, x | ec5a 181900 | mina | 0 , x |
| eb88 18 1c e8 7d | maxm | 125, y | ec5d 181940 | mina | 0, y |
| eb8c 18 1c 8f | maxm | 15, sp | ec60 1819 b0 | mina | 1, sp+ |
| eb8f 181 l 0 f | maxm | 15, x | ec63 181930 | mina | 1, x+ |
| eb92 181 l 4 f | maxm | 15, y | ec66 181970 | mina | 1, $\mathrm{Y}^{+}$ |
| eb95 18 1c f0 10 | maxm | 16, sp | ec69 181981 | mina | 1,sp |
| eb99 18 1c e0 10 | maxm | 16, x | ec6c 181901 | mina | 1, x |
| eb9d 181 c e8 10 | maxm | 16, y | ec6f 181941 | mina | 1, y |
| ebal 18 1c b7 | maxm | 8, sp+ | ec72 1819 bf | mina | 1, sp- |
| eba4 18 1c 37 | maxm | 8, x+ | ec75 1819 3f | mina | 1, $\mathrm{x}-$ |
| eba7 18 1c 77 | maxm | 8,y+ | ec78 1819 7f | mina | 1, $\mathrm{Y}^{-}$ |
| ebaa 181 c b8 | maxm | 8,sp- | ec7b $1819 \mathrm{f8} 7 \mathrm{~d}$ | mina | 125, pc |
| ebad 181 c 38 | maxm | 8, x- | ec7f 1819 f0 7d | mina | 125, sp |
| ebb0 18 1c 78 | maxm | 8, $\mathrm{y}^{-}$ | ec83 1819 e0 7d | mina | 125, x |
| ebb3 18 1c f4 | maxm | a,sp | ec87 1819 e8 7d | mina | 125, y |
| ebb6 181c e4 | maxm | a, x | ec8b 1819 8f | mina | 15, sp |
| ebb9 181 l ec | maxm | a, y | ec8e 1819 0f | mina | 15, x |
| ebbc 181 l f5 | maxm | b, sp | ec91 18194 f | mina | 15, y |
| ebbf 181 l e5 | maxm | b , x | ec94 1819 f0 10 | mina | 16, sp |
| ebc2 181 l ed | maxm | b, y | ec98 1819 e0 10 | mina | 16, x |
| ebc5 18 1c f6 | maxm | d,sp | ec9c 1819 e8 10 | mina | 16, y |
| ebc8 181 l e6 | maxm | d, x | eca0 1819 b7 | mina | 8, sp+ |
| ebcb 181 l ee | maxm | d, y | eca3 181937 | mina | 8, x+ |
| ebce 18 1c f2 0188 | maxm | ext,sp | eca6 181977 | mina | 8, y+ |










| fd98 18019 fl 8188 | movw | ext $-1, s p$ | fec1 60 c0 | neg | , pc |
| :---: | :---: | :---: | :---: | :---: | :---: |
| fd9d 1801 1f 0188 | movw | ext $-1, x$ | fec3 6080 | neg | , sp |
| fda2 18015 f 0188 | movw | ext $-1, y$ | fec5 6000 | neg | , x |
| fda7 1801900188 | movw | ext $-16, \mathrm{sp}$ | fec7 6040 | neg | , Y |
| fdac 1801100188 | movw | ext $-16, x$ | fec9 60 af | neg | 1,-sp |
|  | movw | ext $-16, y$ | fecb 602 f | neg | 1,-x |
| fdb6 1801 d 20188 | movw | ext -small,pc | fecd 606 f | neg | 1,-y |
| fdbb 1801920188 | movw | ext -small,sp | fecf 60 a8 | neg | 8,-sp |
| fdc0 1801120188 | movw | ext -small,x | fed1 6028 | neg | 8,-x |
| fdc5 1801520188 | movw | ext -small,y | fed3 6068 | neg | 8,-y |
| fdca 1801 c 00188 | movw | ext 0,pc | fed5 609 f | neg | -1, sp |
| fdcf 1801800188 | movw | ext $0, \mathrm{sp}$ | fed7 60 1f | neg | -1, x |
| fdd4 1801000188 | movw | ext 0,x | fed9 605 f | neg | -1, y |
| fdd9 1801400188 | movw | ext 0,y | fedb 6090 | neg | -16, sp |
| fdde 1801 b0 0188 | movw | ext 1,sp+ | fedd 6010 | neg | -16, x |
| fde3 1801300188 | movw | ext 1,x+ | fedf 6050 | neg | -16, y |
| fde8 1801700188 | movw | ext 1,y+ | fee1 60 f1 ef | neg | -17, sp |
| fded 1801810188 | movw | ext 1,sp | fee4 60 e1 ef | neg | -17, x |
| fdf2 1801010188 | movw | ext 1,x | fee7 60 e9 ef | neg | -17, y |
| fdf7 1801410188 | movw | ext 1,y | feea 60 d 2 | neg | -small, pc |
| fdfc 1801 bf 0188 | movw | ext 1,sp- | feec 6092 | neg | -small, sp |
| fe01 18013 f 0188 | movw | ext 1,x- | feee 6012 | neg | -small, x |
| fe06 18017 f 0188 | movw | ext 1,y- | fef0 6052 | neg | -small, y |
| fe0b 1801 b7 0188 | movw | ext 8,sp+ | fef2 60 c0 | neg | 0, pc |
| fell 1801370188 | movw | ext 8,x+ | fef4 6080 | neg | 0,sp |
| fe15 1801770188 | movw | ext 8,y+ | fef6 6000 | neg | 0 , x |
| fela 1801 b8 0188 | movw | ext 8,sp- | fef8 6040 | neg | 0,y |
| felf 1801380188 | movw | ext 8,x- | fefa 60 b0 | neg | 1,sp+ |
| fe24 1801780188 | movw | ext 8,y- | fefc 6030 | neg | 1, x+ |
| fe29 1801 f 40188 | movw | ext a,sp | fefe 6070 | neg | 1, $\mathrm{y}^{+}$ |
| fe2e 1801 e 40188 | movw | ext $a, x$ | ff00 6081 | neg | 1,sp |
| fe33 1801 ec 0188 | movw | ext $a, y$ | ff02 6001 | neg | 1, x |
| fe38 1801 f5 0188 | movw | ext b,sp | ff0 6041 | neg | 1, y |
| fe3d 1801 e5 0188 | movw | ext b, x | ff06 60 bf | neg | 1,sp- |
| fe42 1801 ed 0188 | movw | ext b,y | ff08 603 f | neg | 1, $\mathrm{x}-$ |
| fe47 1801 f 60188 | movw | ext d,sp | ff0a 60 7f | neg | 1, $\mathrm{y}^{-}$ |
| fe4c 1801 e6 0188 | movw | ext d, x | ff0c 60 f8 7d | neg | 125, pc |
| fe51 1801 ee 0188 | movw | ext d,y | ff0f 60 f0 7d | neg | 125, sp |
| fe56 180401880188 | movw | ext ext | ff12 60 e0 7d | neg | 125, x |
| fe5c 1801 ce 0188 | movw | ext small,pc | ff15 60 e8 7d | neg | 125, y |
| fe61 1801880188 | movw | ext small,sp | ffi8 608 f | neg | 15, sp |
| fe66 1801 0e 0188 | movw | ext small,x | ffia 600 f | neg | 15, x |
| fe6b 18014 l 0188 | movw | ext small,y | ffic 604 f | neg | 15, y |
| fe70 1802 ce 22 | movw | small, pc 3,+x | ffle 60 f0 10 | neg | 16, sp |
| fe74 18 02 ce 6b | movw | small, pc 5,-y | ff21 60 e0 10 | neg | 16,x |
| fe78 1802 ce 85 | movw | small,pc 5,sp | ff24 60 e8 10 | neg | 16, y |
| fe7c 1805 ce 0188 | movw | small,pc ext | ff27 60 b7 | neg | 8, sp+ |
| fe81 1802 8e 22 | movw | small,sp 3,+x | ff29 6037 | neg | 8, x+ |
| fe85 18 02 8e 6b | movw | small,sp 5,-y | ff2b 6077 | neg | 8, y+ |
| fe89 18028 e 85 | movw | small,sp 5,sp | ff2d 60 b8 | neg | 8,sp- |
| fe8d 18058 l 0188 | movw | small,sp ext | ff2f 6038 | neg | 8, x- |
| fe92 18020 e 22 | movw | small, x 3, +x | ff31 6078 | neg | 8,y- |
| fe96 18020 le 6 b | movw | small, x 5,-y | ff33 60 f4 | neg | a,sp |
| fe9a 1802 0e 85 | movw | small, x 5,sp | ff35 60 e 4 | neg | a, x |
| fe9e 18050 l 0188 | movw | small, x ext | ff37 60 ec | neg | a, y |
| fea3 18024 e 22 | movw | small, y 3, +x | ff39 60 f5 | neg | b, sp |
| fea7 18024 e 6 b | movw | small, y 5,-y | ff3b 60 e5 | neg | b , x |
| feab 18024 e 85 | movw | small,y 5, sp | ff3d 60 ed | neg | b, y |
| feaf 18054 e 0188 | movw | small, y ext | ff3f 60 f6 | neg | d, sp |
| feb4 12 | mul |  | ff41 60 e6 | neg | d, x |
| feb5 60 a0 | neg | 1, +sp | ff43 60 ee | neg | d, y |
| feb7 6020 | neg | 1, +x | ff45 700055 | neg | dir |
| feb9 6060 | neg | 1, +y | ff48 700188 | neg | ext |
| febb 60 a7 | neg | 8, +sp | ff4b 700188 | neg | ext |
| febd 6027 | neg | $8,+x$ | ff 4 e 60 f2 0188 | neg | ext,sp |
| febf 6067 | neg | 8, +y | ff52 60 e2 0188 | neg | ext, x |



| ffe7 aa b7 | oraa | 8, sp+ |
| :---: | :---: | :---: |
| ffe9 aa 37 | oraa | 8, x+ |
| ffeb aa 77 | oraa | 8, y+ |
| ffed aa b8 | oraa | 8,sp- |
| ffef aa 38 | oraa | 8, x- |
| fffi aa 78 | oraa | 8, y- |
| fff 3 aa f4 | oraa | a,sp |
| fff5 aa e4 | oraa | a, x |
| fff7 aa ec | oraa | a, y |
| fff9 a $f 5$ | oraa | b, sp |
| fffb aa e5 | oraa | b, x |
| fffd aa ed | oraa | b, y |
| ffff aa f6 | oraa | d, sp |
| 0001 aa e6 | oraa | d, x |
| 0003 aa ee | oraa | d, y |
| 0005 9a 55 | oraa | dir |
| 0007 9a 55 | oraa | dir |
| 0009 ba 0188 | oraa | ext |
| 000c ba 0188 | oraa | ext |
| $000 f$ aa f2 0188 | oraa | ext,sp |
| 0013 aa e2 0188 | oraa | ext, x |
| 0017 aa ea 0188 | oraa | ext,y |
| 001 b aa f8 37 | oraa | ind, pc |
| 001 e aa f0 37 | oraa | ind, sp |
| 0021 aa e0 37 | oraa | ind, x |
| 0024 aa e8 37 | oraa | ind, $y$ |
| 0027 aa ce | oraa | small, pc |
| 0029 aa 8 e | oraa | small,sp |
| 002b aa 0 e | oraa | small, x |
| 002d aa 4e | oraa | small,y |
| 002f ca 72 | orab | \#immed |
| 0031 ca 72 | orab | \#immed |
| 0033 ea a0 | orab | 1, +sp |
| 0035 ea 20 | orab | $1,+x$ |
| 0037 ea 60 | orab | 1, +y |
| 0039 ea a7 | orab | 8, +sp |
| 003b ea 27 | orab | $8,+x$ |
| 003d ea 67 | orab | 8, +y |
| 003f ea c0 | orab | , pc |
| 0041 ea 80 | orab | , sp |
| 0043 ea 00 | orab | , x |
| 0045 ea 40 | orab | , Y |
| 0047 ea af | orab | 1,-sp |
| 0049 ea 2f | orab | 1, -x |
| 004b ea 6f | orab | 1,-y |
| 004d ea a8 | orab | 8,-sp |
| 004f ea 28 | orab | 8,-x |
| 0051 ea 68 | orab | 8,-y |
| 0053 ea 9f | orab | -1, sp |
| 0055 ea 1f | orab | -1, x |
| 0057 ea 5f | orab | -1, y |
| 0059 ea 90 | orab | -16, sp |
| 005b ea 10 | orab | -16, x |
| 005d ea 50 | orab | -16, y |
| 005 f ea f1 ef | orab | -17, sp |
| 0062 ea e1 ef | orab | -17, x |
| 0065 ea e9 ef | orab | -17, y |
| 0068 ea d2 | orab | -small, pc |
| 006a ea 92 | orab | -small,sp |
| 006 c ea 12 | orab | -small, x |
| 006 e ea 52 | orab | -small, y |
| 0070 ea c0 | orab | 0, pc |
| 0072 ea 80 | orab | 0,sp |
| 0074 ea 00 | orab | 0,x |
| 0076 ea 40 | orab | 0, y |
| 0078 ea b0 | orab | 1,sp+ |


| 007 a ea 30 | orab | 1, x+ | 01066567 | rol | 8, +y |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 007c ea 70 | orab | 1, $\mathrm{Y}^{+}$ | 010865 c0 | rol | , pc |
| 007 e ea 81 | orab | 1, sp | 010a 6580 | rol | , sp |
| 0080 ea 01 | orab | 1, x | 010c 6500 | rol | , x |
| 0082 ea 41 | orab | 1, y | 010e 6540 | rol | , y |
| 0084 ea bf | orab | 1, sp- | 011065 af | rol | 1,-sp |
| 0086 ea 3f | orab | 1, x- | 0112652 f | rol | 1,-x |
| 0088 ea 7f | orab | 1, $\mathrm{y}^{-}$ | 0114656 f | rol | 1,-y |
| 008a ea f8 7d | orab | 125, pc | 011665 a8 | rol | 8,-sp |
| 008d ea f0 7d | orab | 125, sp | 01186528 | rol | 8,-x |
| 0090 ea e0 7d | orab | 125,x | 011a 6568 | rol | 8,-y |
| 0093 ea e8 7d | orab | 125, y | 011c 65 9f | rol | -1, sp |
| 0096 ea 8f | orab | 15, sp | 011e 651 f | rol | -1, x |
| 0098 ea 0 f | orab | 15, x | 012065 5f | rol | -1, y |
| 009a ea 4f | orab | 15, y | 01226590 | rol | -16, sp |
| 009 c ea f0 10 | orab | 16, sp | 01246510 | rol | -16, x |
| 009 f ea e0 10 | orab | 16, x | 01266550 | rol | -16,y |
| 00 a ea e8 10 | orab | 16, y | 012865 f1 ef | rol | -17, sp |
| 00 a ea b7 | orab | 8, sp+ | 012b 65 e1 ef | rol | -17,x |
| 00 a 7 ea 37 | orab | 8, x+ | 012e 65 e9 ef | rol | -17, y |
| $00 a 9$ ea 77 | orab | 8, y+ | 013165 d 2 | rol | -small, pc |
| 00 ab ea b8 | orab | 8, sp- | 01336592 | rol | -small, sp |
| 00 ad ea 38 | orab | 8, x- | 01356512 | rol | -small, x |
| 00af ea 78 | orab | 8, $\mathrm{y}^{-}$ | 01376552 | rol | -small, y |
| 00b1 ea f4 | orab | a,sp | 013965 c0 | rol | 0, pc |
| 00 b 3 ea e4 | orab | a, x | 013b 6580 | rol | 0, sp |
| 00b5 ea ec | orab | a, y | 013d 6500 | rol | 0,x |
| 00 b 7 ea f5 | orab | b, sp | 013f 6540 | rol | 0, y |
| 00 b 9 ea e5 | orab | b , x | 014165 b0 | rol | 1, sp+ |
| 00 bb ea ed | orab | $\mathrm{b}, \mathrm{y}$ | 01436530 | rol | 1, x+ |
| 00 bd ea f6 | orab | d, sp | 01456570 | rol | 1, $\mathrm{y}^{+}$ |
| 00 bf ea e6 | orab | d, x | 01476581 | rol | 1, sp |
| 00c1 ea ee | orab | d, y | 01496501 | rol | 1, x |
| 00 c 3 da 55 | orab | dir | 014b 6541 | rol | 1, y |
| 00 c 5 da 55 | orab | dir | 014d 65 bf | rol | 1, sp- |
| 00 c 7 fa 0188 | orab | ext | 014f 65 3f | rol | 1, x- |
| O0ca fa 0188 | orab | ext | 0151657 f | rol | 1, $\mathrm{Y}-$ |
| 00 cd ea f2 0188 | orab | ext,sp | 015365 f8 7d | rol | 125, pc |
| 00 d 1 ea e2 0188 | orab | ext, x | 015665 f0 7d | rol | 125, sp |
| 00 d ea ea 0188 | orab | ext,y | 015965 e0 7d | rol | 125,x |
| 00 d 9 ea f8 37 | orab | ind, pc | 015c 65 e8 7d | rol | 125, y |
| 00 dc ea f0 37 | orab | ind, sp | 015f 658 f | rol | 15, sp |
| 00 df ea e0 37 | orab | ind, $x$ | 0161650 f | rol | 15, x |
| 00 e 2 ea e8 37 | orab | ind, y | 0163654 f | rol | 15, y |
| 00 5 ea ce | orab | small, pc | 016565 f0 10 | rol | 16, sp |
| 00 e 7 ea 8 e | orab | small,sp | 016865 e0 10 | rol | 16, x |
| 00 e 9 ea 0 e | orab | small, x | 016b 65 e8 10 | rol | 16, y |
| 00 eb ea 4 e | orab | small,y | 016 e 65 b 7 | rol | 8,sp+ |
| 00ed 1472 | orcc | \#immed | 01706537 | rol | 8, x+ |
| 00ef 36 | psha |  | 01726577 | rol | 8,y+ |
| 00f0 37 | pshb |  | 017465 b8 | rol | 8,sp- |
| 00 f1 3b | pshd |  | 01766538 | rol | 8, x- |
| 00f2 34 | pshx |  | 01786578 | rol | 8, $\mathrm{y}^{-}$ |
| 00f3 35 | pshy |  | 017a 65 f4 | rol | a,sp |
| 00f4 32 | pula |  | 017c 65 e 4 | rol | a, x |
| 00f5 33 | pulb |  | 017e 65 ec | rol | a, y |
| 00f6 38 | pulc |  | 018065 f5 | rol | b, sp |
| 00 f7 3a | puld |  | 018265 e5 | rol | b , x |
| 00f8 30 | pulx |  | 018465 ed | rol | b, y |
| 00f9 31 | puly |  | 018665 f6 | rol | d,sp |
| 00fa 18 3a | rev |  | 018865 e6 | rol | d, x |
| 00 fc 65 a 0 | rol | 1, +sp | 018a 65 ee | rol | d, y |
| 00fe 6520 | rol | 1, +x | 018c 750055 | rol | dir |
| 01006560 | rol | 1, +y | 018f 750188 | rol | ext |
| 010265 a7 | rol | 8, +sp | 0192750188 | rol | ext |
| 01046527 | rol | $8,+x$ | 019565 f2 0188 | rol | ext,sp |


| 01996 | 65 e2 0188 | rol | ext, x |
| :---: | :---: | :---: | :---: |
| 019d 6 | 65 ea 0188 | rol | ext,y |
| $01 a 16$ | 65 f8 37 | rol | ind, pc |
| $01 a 46$ | 65 f0 37 | rol | ind, sp |
| $01 a 76$ | 65 e0 37 | rol | ind, x |
| 01aa 6 | 65 e8 37 | rol | ind, y |
| 01ad 6 | 65 ce | rol | small, pc |
| 01af 6 | 658 e | rol | small,sp |
| 01b1 6 | 650 e | rol | small, x |
| 01b3 6 | 654 e | rol | small, y |
| 01b5 4 | 45 | rola |  |
| 01b6 5 | 55 | rolb |  |
| 01 b 76 | 66 a 0 | ror | 1, +sp |
| 01b9 6 | 6620 | ror | $1,+x$ |
| 01bb 6 | 6660 | ror | 1, +y |
| 01bd 6 | 66 a7 | ror | 8, +sp |
| 01bf 6 | 6627 | ror | $8,+x$ |
| 01c1 6 | 6667 | ror | 8, +y |
| 01c3 6 | 66 c 0 | ror | , pc |
| 01c5 6 | 6680 | ror | , sp |
| 01c7 6 | 6600 | ror | , x |
| 01c9 6 | 6640 | ror | , Y |
| 01 cb 6 | 66 af | ror | 1,-sp |
| 01 cd 6 | 662 f | ror | 1,-x |
| 01cf 6 | 66 6f | ror | 1,-y |
| 01d1 6 | 66 a8 | ror | 8,-sp |
| 01d3 6 | 6628 | ror | 8,-x |
| 01d5 6 | 6668 | ror | 8,-y |
| $01 \mathrm{d7} 6$ | 669 f | ror | -1, sp |
| 01d9 6 | 661 f | ror | -1, x |
| 01 db 6 | 665 f | ror | -1, y |
| 01 dd 6 | 6690 | ror | -16, sp |
| 01 df 6 | 6610 | ror | -16, x |
| 01e1 6 | 6650 | ror | -16, y |
| 01 e 36 | 66 f1 ef | ror | -17, sp |
| 01e6 6 | 66 e1 ef | ror | -17, x |
| 01 e 96 | 66 e9 ef | ror | -17, y |
| 01ec 6 | 66 d 2 | ror | -small, pc |
| 01ee 6 | 6692 | ror | -small,sp |
| 01 f0 6 | 6612 | ror | -small,x |
| 01 f2 6 | 6652 | ror | -small, y |
| $01 \pm 46$ | 66 c 0 | ror | 0, pc |
| 01 f6 6 | 6680 | ror | $0, \mathrm{sp}$ |
| 01 f8 6 | 6600 | ror | 0, x |
| 01fa 6 | 6640 | ror | 0, y |
| 01fc 6 | 66 b0 | ror | 1,sp+ |
| 01 fe 6 | 6630 | ror | 1, x+ |
| 02006 | 6670 | ror | 1, $\mathrm{y}^{+}$ |
| 02026 | 6681 | ror | 1,sp |
| 02046 | 6601 | ror | 1, x |
| 02066 | 6641 | ror | 1, y |
| 02086 | 66 bf | ror | 1,sp- |
| 020a 6 | 663 f | ror | 1, x- |
| 020c 6 | 667 f | ror | 1, $\mathrm{Y}^{-}$ |
| 020e 6 | 66 f8 7d | ror | 125, pc |
| 02116 | 66 f0 7d | ror | 125, sp |
| 02146 | 66 e0 7d | ror | 125, x |
| 02176 | 66 e8 7d | ror | 125, y |
| 021a 6 | 668 f | ror | 15, sp |
| 021c 6 | 660 f | ror | 15, x |
| 021 e 6 | 664 f | ror | 15, y |
| 02206 | 66 f0 10 | ror | 16, sp |
| 02236 | 66 e0 10 | ror | 16, x |
| 02266 | 66 e8 10 | ror | 16, y |
| 02296 | 66 b7 | ror | 8,sp+ |
| 022b 6 | 6637 | ror | 8, x+ |




| 0354 e2 | e2 28 | sbcb | 8,-x |
| :---: | :---: | :---: | :---: |
| 0356 e2 | e2 68 | sbcb | 8,-y |
| 0358 e | e2 9f | sbcb | -1, sp |
| 035a e2 | e2 1f | sbcb | -1, x |
| 035c e2 | e2 5f | sbcb | -1, y |
| 035e e2 | e2 90 | sbcb | -16, sp |
| 0360 e2 | e2 10 | sbcb | -16, x |
| 0362 e2 | e2 50 | sbcb | -16, y |
| 0364 e2 | e2 f1 ef | sbcb | -17, sp |
| 0367 e2 | e2 e1 ef | sbcb | -17, x |
| 036a e2 | e2 e9 ef | sbcb | -17, y |
| 036d e2 | e2 d2 | sbcb | -small, pc |
| 036 f e2 | e2 92 | sbcb | -small, sp |
| 0371 e2 | e2 12 | sbcb | -small, x |
| 0373 e2 | e2 52 | sbcb | -small, y |
| 0375 e2 | e2 c0 | sbcb | 0, pc |
| 0377 e2 | e2 80 | sbcb | 0,sp |
| 0379 e2 | e2 00 | sbcb | 0, x |
| 037b e2 | e2 40 | sbcb | 0, y |
| 037d e2 | e2 b0 | sbcb | 1,sp+ |
| 037 f e2 | e2 30 | sbcb | 1, x+ |
| 0381 e2 | e2 70 | sbcb | 1, $\mathrm{y}+$ |
| 0383 e2 | e2 81 | sbcb | 1,sp |
| 0385 e2 | e2 01 | sbcb | 1,x |
| 0387 e2 | e2 41 | sbcb | 1, y |
| 0389 e2 | e2 bf | sbcb | 1,sp- |
| 038b e2 | e2 3f | sbcb | 1, x- |
| 038d e2 | e2 7f | sbcb | 1, $\mathrm{Y}^{-}$ |
| 038f e2 | e2 f8 7d | sbcb | 125, pc |
| 0392 e2 | e2 f0 7d | sbcb | 125, sp |
| 0395 e2 | e2 e0 7d | sbcb | 125, x |
| 0398 e2 | e2 e8 7d | sbcb | 125, y |
| 039b e2 | e2 8f | sbcb | 15, sp |
| 039d e2 | e2 0f | sbcb | 15, x |
| 039f e2 | e2 4f | sbcb | 15, y |
| 03 al e2 | e2 f0 10 | sbcb | 16, sp |
| 03 a e2 | e2 e0 10 | sbcb | 16, x |
| 03 a e2 | e2 e8 10 | sbcb | 16, y |
| 03aa e2 | e2 b7 | sbcb | 8, sp+ |
| 03 ac e | e2 37 | sbcb | 8, x+ |
| 03 ae e2 | e2 77 | sbcb | 8, y+ |
| 03b0 e2 | e2 b8 | sbcb | 8,sp- |
| 03b2 e2 | e2 38 | sbcb | 8, x- |
| 03b4 e2 | e2 78 | sbcb | 8, y- |
| 03b6 e2 | e2 f4 | sbcb | a,sp |
| 03b8 e2 | e2 e4 | sbcb | a, x |
| 03 ba e2 | e2 ec | sbcb | a, y |
| 03 bc e2 | e2 f5 | sbcb | b, sp |
| 03 be e2 | e2 e5 | sbcb | b, x |
| 03c0 e2 | e2 ed | sbcb | b, y |
| 03c2 e2 | e2 f6 | sbcb | d, sp |
| 03c4 e2 | e2 e6 | sbcb | d, x |
| 03 c 6 e2 | e2 ee | sbcb | d, y |
| 03c8 d2 | d2 55 | sbcb | dir |
| 03ca d | d2 55 | sbcb | dir |
| 03cc f2 | f2 0188 | sbcb | ext |
| 03cf f2 | f2 0188 | sbcb | ext |
| 03d2 e2 |  | sbcb | ext,sp |
| 03d6 e2 | e2 e2 0188 | sbcb | ext, x |
| 03 da e2 | e2 ea 0188 | sbcb | ext,y |
| 03 de e | e2 f8 37 | sbcb | ind, pc |
| 03 e 1 e | e2 f0 37 | sbcb | ind, sp |
| 03 4 e | e2 e0 37 | sbcb | ind, $x$ |
| 03 e 7 e | e2 e8 37 | sbcb | ind, y |
| 03 ea e2 | e2 ce | sbcb | small, pc |
| 03 cc e | e2 8e | sbcb | small,sp |


| 03ee e2 0e | sbcb | small, x | 0476 6a f0 7d | staa | 125, sp |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 03f0 e2 4e | sbcb | small,y | 0479 6a e0 7d | staa | 125, x |
| 03f2 1401 | sec |  | 047c 6a e8 7d | staa | 125, y |
| 03f4 1410 | sei |  | 047 f 6a 8f | staa | 15, sp |
| 03f6 1402 | sev |  | 0481 6a 0f | staa | 15, x |
| 03f8 b7 04 | sex | a d | 0483 6a 4f | staa | 15, y |
| 03fa b7 07 | sex | a sp | 0485 6a f0 10 | staa | 16, sp |
| 03fc b7 07 | sex | a,sp | 0488 6a e0 10 | staa | 16, x |
| 03fe b7 05 | sex | a x | 048 b 6a e8 10 | staa | 16,y |
| 0400 b7 05 | sex | a, x | 048e 6a b7 | staa | 8, sp+ |
| 0402 b7 06 | sex | a Y | 0490 6a 37 | staa | 8, x+ |
| 0404 b7 06 | sex | $a, y$ | 0492 6a 77 | staa | 8, y+ |
| 0406 b7 14 | sex | b d | 0494 6a b8 | staa | 8,sp- |
| 0408 b7 17 | sex | b sp | 0496 6a 38 | staa | 8, x- |
| 040a b7 17 | sex | b, sp | 0498 6a 78 | staa | 8, $\mathrm{Y}^{-}$ |
| 040c b7 15 | sex | b x | 049a 6a f4 | staa | a,sp |
| 040 e b7 15 | sex | b , x | 049c 6a e4 | staa | a, x |
| 0410 b7 16 | sex | b y | 049e 6a ec | staa | a, y |
| 0412 b7 16 | sex | b, y | 04a0 6a f5 | staa | b, sp |
| 0414 b7 24 | sex | cor d | 04a2 6a e5 | staa | b, x |
| 0416 b7 27 | sex | ccr sp | 04a4 6a ed | staa | b, y |
| 0418 b7 25 | sex | ccr x | 04 a 6 6a f6 | staa | d, sp |
| 041a b7 26 | sex | cor y | $04 a 8$ 6a e6 | staa | d, x |
| 041c 6a a0 | staa | 1, +sp | 04aa 6a ee | staa | d, y |
| 041 e 6a 20 | staa | 1, +x | 04ac 5a 55 | staa | dir |
| 0420 6a 60 | staa | 1, +y | 04ae 5a 55 | staa | dir |
| 0422 6a a7 | staa | 8, +sp | 04b0 7a 0188 | staa | ext |
| 0424 6a 27 | staa | $8,+x$ | 04 b 3 7a 0188 | staa | ext |
| 0426 6a 67 | staa | 8, +y | 04b6 6a f2 0188 | staa | ext,sp |
| 0428 6a c0 | staa | , pc | 04 ba 6a e2 0188 | staa | ext, x |
| 042a 6a 80 | staa | , sp | 04 be 6 a ea 0188 | staa | ext,y |
| 042c 6a 00 | staa | , x | $04 c 2$ 6a f8 37 | staa | ind, pc |
| 042 e 6a 40 | staa | , Y | $04 \mathrm{c5}$ 6a f0 37 | staa | ind, sp |
| 0430 6a af | staa | 1,-sp | $04 c 8$ 6a e0 37 | staa | ind, $x$ |
| 0432 6a 2f | staa | 1,-x | 04 cb 6 a e8 37 | staa | ind, y |
| 0434 6a 6f | staa | 1,-y | 04ce 6a ce | staa | small, pc |
| 0436 6a a8 | staa | 8,-sp | 04d0 6a 8e | staa | small,sp |
| 0438 6a 28 | staa | 8,-x | $04 \mathrm{~d} 2 \mathrm{6a} 0 \mathrm{e}$ | staa | small, x |
| 043a 6a 68 | staa | 8,-y | 04d4 6a 4e | staa | small,y |
| 043c 6a 9f | staa | -1, sp | 04d6 6b a0 | stab | 1, +sp |
| 043 e 6a 1f | staa | -1, x | 04d8 6b 20 | stab | 1, +x |
| 0440 6a 5f | staa | -1, y | 04 da 6b 60 | stab | 1, +y |
| 0442 6a 90 | staa | -16,sp | 04dc 6b a7 | stab | 8, +sp |
| 0444 6a 10 | staa | -16,x | 04 de 6 b 27 | stab | 8, +x |
| 0446 6a 50 | staa | -16,y | 04 e 0 6b 67 | stab | 8, +y |
| 0448 6a f1 ef | staa | -17, sp | $04 \mathrm{e} 2 \mathrm{6b} \mathrm{c0}$ | stab | , pc |
| 044 b 6a e1 ef | staa | -17, x | 04e 4 6b 80 | stab | , sp |
| 044e 6a e9 ef | staa | -17, y | 04e6 6b 00 | stab | , x |
| 0451 6a d2 | staa | -small, pc | 04 e 8 6b 40 | stab | , Y |
| 0453 6a 92 | staa | -small,sp | $04 \mathrm{ea} \mathrm{6b} \mathrm{af}$ | stab | 1,-sp |
| 0455 6a 12 | staa | -small, x | 04 ec 6b 2f | stab | 1,-x |
| 0457 6a 52 | staa | -small,y | 04 ee 6b 6f | stab | 1,-y |
| 0459 6a c0 | staa | 0, pc | $04 \mathrm{f0}$ 6b a8 | stab | 8,-sp |
| 045b 6a 80 | staa | 0,sp | $04 \mathrm{f} 2 \mathrm{6b} 28$ | stab | 8,-x |
| 045d 6a 00 | staa | 0, x | 04 f 4 6b 68 | stab | 8,-y |
| 045f 6a 40 | staa | 0, y | $04 \mathrm{f} 6 \mathrm{6b} 9 \mathrm{f}$ | stab | -1, sp |
| 0461 6a b0 | staa | 1, sp+ | 04 f 8 6b 1f | stab | -1, x |
| 0463 6a 30 | staa | 1, x+ | 04 fa 6b 5f | stab | -1, y |
| 0465 6a 70 | staa | 1, $\mathrm{y}+$ | 04fc 6b 90 | stab | -16, sp |
| 0467 6a 81 | staa | 1, sp | 04 fe 6b 10 | stab | -16,x |
| 0469 6a 01 | staa | 1, x | 0500 6b 50 | stab | -16, y |
| 046 b 6a 41 | staa | 1, y | 0502 6b f1 ef | stab | -17, sp |
| 046d 6a bf | staa | 1,sp- | 0505 6b e1 ef | stab | -17, x |
| 046 f 6a 3f | staa | 1, x- | 0508 6b e9 ef | stab | -17, y |
| 0471 6a 7f | staa | 1, $\mathrm{y}^{-}$ | 050b 6b d2 | stab | -small, pc |
| 0473 6a f8 7d | staa | 125, pc | 050d 6b 92 | stab | -small,sp |


| 050 f 6b 12 | stab | -small, x | 05 ab 6c 2f | std | 1, -x |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0511 6b 52 | stab | -small,y | 05a8 6c 6f | std | 1,-y |
| 0513 6b c0 | stab | 0, pc | 05aa 6c a8 | std | 8,-sp |
| 0515 6b 80 | stab | $0, \mathrm{sp}$ | 05ac 6c 28 | std | 8,-x |
| 0517 6b 00 | stab | $0, \mathrm{x}$ | 05ae 6c 68 | std | 8,-y |
| 0519 6b 40 | stab | 0, y | 05b0 6c 9f | std | -1, sp |
| 051b 6b b0 | stab | 1, sp+ | 05b2 6c 1f | std | -1, x |
| 051d 6b 30 | stab | 1, x+ | 05b4 6c 5f | std | -1, y |
| 051f 6b 70 | stab | 1, $\mathrm{Y}^{+}$ | 05b6 6c 90 | std | -16, sp |
| 0521 6b 81 | stab | 1, sp | 05b8 6c 10 | std | -16,x |
| 0523 6b 01 | stab | 1, x | 05ba 6c 50 | std | -16, y |
| 0525 6b 41 | stab | 1, Y | 05bc 6c f1 ef | std | -17, sp |
| 0527 6b bf | stab | 1, sp- | 05bf 6c e1 ef | std | -17, x |
| 0529 6b 3f | stab | 1, $\mathrm{x}-$ | 05c2 6c e9 ef | std | -17, y |
| 052 b 6b 7f | stab | 1, $\mathrm{Y}^{-}$ | 05c5 6c d2 | std | -small, pc |
| 052d 6b f8 7d | stab | 125, pc | 05c7 6c 92 | std | -small, sp |
| 0530 6b f0 7d | stab | 125, sp | 05c9 6c 12 | std | -small, x |
| 0533 6b e0 7d | stab | 125, x | 05 cb 6 c 52 | std | -small, y |
| 0536 6b e8 7d | stab | 125, y | 05cd 6c c0 | std | 0, pc |
| 0539 6b 8f | stab | 15, sp | 05cf 6c 80 | std | $0, \mathrm{sp}$ |
| 053b 6b 0 f | stab | 15, x | 05d1 6c 00 | std | 0, x |
| 053d 6b 4f | stab | 15, y | 05d3 6c 40 | std | 0, y |
| 053 f 6b f0 10 | stab | 16, sp | 05d5 6c b0 | std | 1, sp+ |
| 0542 6b e0 10 | stab | 16, x | 05d7 6c 30 | std | 1, x+ |
| 0545 6b e8 10 | stab | 16, y | 05d9 6c 70 | std | 1, y+ |
| 0548 6b b7 | stab | 8, sp+ | 05db 6c 81 | std | 1, sp |
| 054a 6b 37 | stab | 8, x+ | 05dd 6c 01 | std | 1, x |
| 054c 6b 77 | stab | 8, y+ | 05df 6c 41 | std | 1, y |
| 054 e 6b b8 | stab | 8,sp- | 05e1 6c bf | std | 1, sp- |
| 0550 6b 38 | stab | 8, x- | 05e3 6c 3f | std | 1, x- |
| 0552 6b 78 | stab | 8, y- | 05e5 6c 7f | std | 1, $\mathrm{Y}-$ |
| 0554 6b f4 | stab | a,sp | 05 e 7 6c f8 7d | std | 125, pc |
| 0556 6b e4 | stab | a, x | 05ea 6c f0 7d | std | 125, sp |
| 0558 6b ec | stab | a, y | 05ed 6c e0 7d | std | 125, x |
| 055a 6b f5 | stab | b, sp | $05 \mathrm{f0} 6 \mathrm{c}$ e8 7d | std | 125, y |
| 055c 6b e5 | stab | $\mathrm{b}, \mathrm{x}$ | 05 f 36 c 8 f | std | 15, sp |
| 055e 6b ed | stab | b, y | 05f5 6c 0f | std | 15, x |
| 0560 6b f6 | stab | d, sp | 05 f 7 6c 4f | std | 15, y |
| 0562 6b e6 | stab | d, x | $05 \mathrm{f} 9 \mathrm{6c}$ f0 10 | std | 16, sp |
| 0564 6b ee | stab | d, y | 05fc 6c e0 10 | std | 16, x |
| 0566 5b 55 | stab | dir | 05ff 6c e8 10 | std | 16, y |
| 0568 5b 55 | stab | dir | 0602 6c b7 | std | 8,sp+ |
| 056a 7b 0188 | stab | ext | 0604 6c 37 | std | 8, x+ |
| 056d 7b 0188 | stab | ext | 0606 6c 77 | std | 8, y+ |
| 0570 6b f2 0188 | stab | ext,sp | 0608 6c b8 | std | 8,sp- |
| 0574 6b e2 0188 | stab | ext, x | 060a 6c 38 | std | 8, x- |
| 0578 6b ea 0188 | stab | ext,y | 060c 6c 78 | std | 8, y- |
| 057c 6b f8 37 | stab | ind, pc | 060e 6c f4 | std | a,sp |
| 057 f 6b f0 37 | stab | ind, sp | 0610 6c e4 | std | a, x |
| 0582 6b e0 37 | stab | ind, $x$ | 0612 6c ec | std | a, y |
| 0585 6b e8 37 | stab | ind, y | 0614 6c f5 | std | b, sp |
| 0588 6b ce | stab | small, pc | 0616 6c e5 | std | b , x |
| 058 a 6b 8e | stab | small,sp | 0618 6c ed | std | b, y |
| 058c 6b 0e | stab | small, x | 061 a 6c f6 | std | d, sp |
| 058e 6b 4e | stab | small, y | 061c 6c e6 | std | d, x |
| 0590 6c a0 | std | 1, +sp | 061 e 6c ee | std | d, y |
| 0592 6c 20 | std | 1, +x | 0620 5c 55 | std | dir |
| 0594 6c 60 | std | 1, +y | 0622 5c 55 | std | dir |
| 0596 6c a7 | std | 8, +sp | 0624 7c 0188 | std | ext |
| 0598 6c 27 | std | 8, +x | 0627 7c 0188 | std | ext |
| 059a 6c 67 | std | 8, +y | 062 a 6c f2 0188 | std | ext,sp |
| 059c 6c c0 | std | , pc | $062 e$ 6c e2 0188 | std | ext, x |
| 059e 6c 80 | std | , sp | 0632 6c ea 0188 | std | ext,y |
| 05a0 6c 00 | std | , x | 0636 6c f8 37 | std | ind, pc |
| 05a2 6c 40 | std | , Y | 0639 6c f0 37 | std | ind, sp |
| 05a4 6c af | std | 1,-sp | 063c 6c e0 37 | std | ind, x |


| 063 f | 6 c e8 37 | std | ind, y |
| :---: | :---: | :---: | :---: |
| 0642 | 6 c ce | std | small, pc |
| 0644 | 6 c 8 e | std | small,sp |
| 0646 | 6 c 0 e | std | small, x |
| 0648 | 6 c 4 e | std | small, y |
| 064 a | 183 e | stop |  |
| 064 c | 6f a0 | sts | 1, +sp |
| 064 e | 6£ 20 | sts | $1,+x$ |
| 0650 | 6£ 60 | sts | 1, +y |
| 0652 | 6f a7 | sts | 8, +sp |
| 0654 | 6£ 27 | sts | 8, +x |
| 0656 | 6f 67 | sts | 8, +y |
| 0658 | 6f c0 | sts | , pc |
| 065a | 6 f 80 | sts | , sp |
| 065 c | $6 \pm 00$ | sts | , x |
| 065 e | 6£ 40 | sts | , Y |
| 0660 | 6f af | sts | 1,-sp |
| 0662 | 6f 2f | sts | 1,-x |
| 0664 | 6f 6f | sts | 1,-y |
| 0666 | 6£ a8 | sts | 8,-sp |
| 0668 | 6f 28 | sts | 8,-x |
| 066 a | 6f 68 | sts | 8,-y |
| 066 c | 6f 9f | sts | -1, sp |
| 066 e | 6f 1f | sts | -1, x |
| 0670 | 6f 5f | sts | -1, y |
| 0672 | 6f 90 | sts | -16,sp |
| 0674 | 6f 10 | sts | -16, x |
| 0676 | 6f 50 | sts | -16,y |
| 0678 | 6 f f1 ef | sts | -17, sp |
| 067 b | 6 f e1 ef | sts | -17,x |
| 067 e | 6 f e9 ef | sts | -17, y |
| 0681 | 6 f d2 | sts | -small, pc |
| 0683 | 6£ 92 | sts | -small,sp |
| 0685 | 6f 12 | sts | -small,x |
| 0687 | 6£ 52 | sts | -small, y |
| 0689 | 6f c0 | sts | 0, pc |
| 068b | 6f 80 | sts | 0,sp |
| 068d | $6 \pm 00$ | sts | 0, x |
| 068 f | $6 \pm 40$ | sts | 0, y |
| 0691 | 6f bo | sts | 1, sp+ |
| 0693 | 6£ 30 | sts | 1,x+ |
| 0695 | 6£ 70 | sts | 1, $\mathrm{y}+$ |
| 0697 | 6f 81 | sts | 1, sp |
| 0699 | 6£ 01 | sts | 1, x |
| 069b | 6£ 41 | sts | 1, y |
| 069d | 6 f bf | sts | 1,sp- |
| 069 f | 6f 3f | sts | 1, $\mathrm{x}-$ |
| 06 al | 6f 7f | sts | 1, $\mathrm{Y}^{-}$ |
| 06a3 | 6f f8 7d | sts | 125, pc |
| 06 a | 6f f0 7d | sts | 125, sp |
| $06 a 9$ | 6f e0 7d | sts | 125,x |
| 06 ac | 6f e8 7d | sts | 125, y |
| 06af | 6f 8f | sts | 15, sp |
| 06 bl 1 | 6f 0f | sts | 15, x |
| 06b3 | 6f 4f | sts | 15, y |
| 06b5 | 6f f0 10 | sts | 16, sp |
| 06b8 | 6f e0 10 | sts | 16, x |
| 06 bb | 6 f e8 10 | sts | 16, y |
| 06 be | 6f b7 | sts | 8,sp+ |
| 06 c 0 | 6£ 37 | sts | 8,x+ |
| 06 c 2 | 6f 77 | sts | 8, y+ |
| 06 c 4 | 6f b8 | sts | 8,sp- |
| 06 c 6 | 6f 38 | sts | 8, x- |
| 06 c 8 | 6f 78 | sts | 8, y- |
| 06 ca | 6 f f4 | sts | a,sp |
| 06 cc | 6 f e4 | sts | a, x |


| 06 ce | 6f ec | sts | a, y |
| :---: | :---: | :---: | :---: |
| 06d0 | 6f f5 | sts | b, sp |
| 06d2 | 6f e5 | sts | b , x |
| 06d4 | 6f ed | sts | b, y |
| 06d6 | 6f f6 | sts | d,sp |
| 06 d 8 | 6f e6 | sts | d, x |
| 06 da | 6f ee | sts | d, y |
| 06 dc | 5f 55 | sts | dir |
| 06 de | 7 f 0188 | sts | ext |
| 06 e 1 | 6f f2 0188 | sts | ext,sp |
| 06 e 5 | $6 \pm$ e2 0188 | sts | ext,x |
| 06 e 9 | 6 f ea 0188 | sts | ext,y |
| 06 ed | $6 \pm$ f8 37 | sts | ind, pc |
| $06 \pm 0$ | 6 f f0 37 | sts | ind, sp |
| $06 \pm 3$ | 6 f e0 37 | sts | ind, $x$ |
| $06 \pm 6$ | 6 f e8 37 | sts | ind,y |
| 06f9 | 6f ce | sts | small, pc |
| 06 fb | 6f 8e | sts | small,sp |
| 06 fd | 6f 0 e | sts | small, x |
| 06 ff | 6f 4e | sts | small, y |
| 0701 | 6 e a0 | stx | 1, +sp |
| 0703 | 6 e 20 | stx | 1, +x |
| 0705 | 6 e 60 | stx | 1, +y |
| 0707 | 6e a7 | stx | 8, +sp |
| 0709 | 6 e 27 | stx | 8, +x |
| 070b | 6 e 67 | stx | 8, +y |
| 070d | 6 ec 0 | stx | , pc |
| 070 f | 6 e 80 | stx | , sp |
| 0711 | 6 e 00 | stx | , x |
| 0713 | 6 e 40 | stx | , Y |
| 0715 | 6 e af | stx | 1,-sp |
| 0717 | 6e 2 f | stx | 1,-x |
| 0719 | 6 e 6f | stx | 1,-y |
| 071b | 6 e a 8 | stx | 8,-sp |
| 071d | 6 e 28 | stx | 8,-x |
| 071 f | 6 e 68 | stx | 8,-y |
| 0721 | 6 e 9 f | stx | -1, sp |
| 0723 | 6 e 1f | stx | -1, x |
| 0725 | 6 e 5 f | stx | -1, y |
| 0727 | 6 e 90 | stx | -16, sp |
| 0729 | 6 e 10 | stx | -16, x |
| 072b | 6 e 50 | stx | -16,y |
| 072d | 6 e f1 ef | stx | -17, sp |
| 0730 | 6 e e1 ef | stx | -17, x |
| 0733 | 6 e e9 ef | stx | -17, y |
| 0736 | 6 e d2 | stx | -small, pc |
| 0738 | 6 e 92 | stx | -small, sp |
| 073a | 6 e 12 | stx | -small,x |
| 073c | 6e 52 | stx | -small, y |
| 073e | 6 e c0 | stx | 0, pc |
| 0740 | 6 e 80 | stx | 0,sp |
| 0742 | 6e 00 | stx | 0 , x |
| 0744 | 6 e 40 | stx | 0, y |
| 0746 | 6 e b0 | stx | 1, sp+ |
| 0748 | 6 e 30 | stx | 1, x+ |
| 074a | 6 e 70 | stx | 1, y+ |
| 074c | 6 e 81 | stx | 1, sp |
| 074e | 6e 01 | stx | 1, x |
| 0750 | 6 e 41 | stx | 1, y |
| 0752 | 6e bf | stx | 1,sp- |
| 0754 | 6 e 3 f | stx | 1, x- |
| 0756 | 6 e 7 f | stx | 1, y - |
| 0758 | 6 f f8 7d | stx | 125, pc |
| 075b | 6 f f0 7d | stx | 125, sp |
| 075e | 6 e e0 7d | stx | 125,x |
| 0761 | 6 e e8 7d | stx | 125, y |


| 0764 6e 8f | stx | 15, sp | 07fa 6d 80 | sty | 0,sp |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0766 6e 0f | stx | 15, x | 07fc 6d 00 | sty | 0 , x |
| 0768 6e 4f | stx | 15, y | 07fe 6d 40 | sty | 0, y |
| 076a 6e f0 10 | stx | 16, sp | 0800 6d b0 | sty | 1, sp+ |
| 076d 6e e0 10 | stx | 16, x | 0802 6d 30 | sty | 1, x+ |
| 0770 6e e8 10 | stx | 16, y | 0804 6d 70 | sty | 1, $\mathrm{Y}+$ |
| 0773 6e b7 | stx | 8, sp+ | 0806 6d 81 | sty | 1, sp |
| 0775 6e 37 | stx | 8, x+ | 0808 6d 01 | sty | 1, x |
| 0777 6e 77 | stx | 8, y+ | 080a 6d 41 | sty | 1, y |
| 0779 6e b8 | stx | 8,sp- | 080c 6d bf | sty | 1, sp- |
| 077 b 6e 38 | stx | 8, x- | 080e 6d 3f | sty | 1, $\mathrm{x}^{-}$ |
| 077d 6e 78 | stx | 8, y- | 0810 6d 7f | sty | 1, $\mathrm{y}^{-}$ |
| 077 f 6e f4 | stx | a,sp | 0812 6d f8 7d | sty | 125, pc |
| 0781 6e e4 | stx | a, x | 0815 6d f0 7d | sty | 125, sp |
| 0783 6e ec | stx | a, y | 0818 6d e0 7d | sty | 125, x |
| 0785 6e f5 | stx | b, sp | 081b 6d e8 7d | sty | 125,y |
| 0787 6e e5 | stx | b , x | 081e 6d 8f | sty | 15, sp |
| 0789 6e ed | stx | b, y | 0820 6d 0f | sty | 15, x |
| 078 b 6e f6 | stx | d, sp | 0822 6d 4f | sty | 15, y |
| 078d 6e e6 | stx | d, x | 0824 6d f0 10 | sty | 16, sp |
| 078f 6e ee | stx | d, y | 0827 6d e0 10 | sty | 16, x |
| 0791 5e 55 | stx | dir | 082a 6d e8 10 | sty | 16, y |
| 0793 5e 55 | stx | dir | 082d 6d b7 | sty | 8,sp+ |
| 0795 7e 0188 | stx | ext | 082f 6d 37 | sty | 8, x+ |
| 0798 7e 0188 | stx | ext | 0831 6d 77 | sty | 8, y+ |
| 079 b 6e f2 0188 | stx | ext,sp | 0833 6d b8 | sty | 8,sp- |
| 079 f 6e e2 0188 | stx | ext, x | 0835 6d 38 | sty | 8, x- |
| 07 a 6e ea 0188 | stx | ext,y | 0837 6d 78 | sty | 8, y- |
| $07 a 7$ 6e f8 37 | stx | ind, pc | 0839 6d f4 | sty | a,sp |
| 07aa 6e f0 37 | stx | ind, sp | 083b 6d e4 | sty | a, x |
| 07 ad 6 e e0 37 | stx | ind, $x$ | 083d 6d ec | sty | a, y |
| 07 b 06 e e8 37 | stx | ind, y | 083f 6d f5 | sty | b, sp |
| 07b3 6e ce | stx | small, pc | 0841 6d e5 | sty | b, x |
| 07 b 56 e 8 e | stx | small,sp | 0843 6d ed | sty | b, y |
| 07 b 7 6e 0e | stx | small, x | 0845 6d f6 | sty | d, sp |
| 07b9 6e 4e | stx | small, y | 0847 6d e6 | sty | d, x |
| 07 bb 6d a0 | sty | 1, +sp | 0849 6d ee | sty | d, y |
| 07bd 6d 20 | sty | 1, +x | 084b 5d 55 | sty | dir |
| 07bf 6d 60 | sty | 1, +y | 084d 5d 55 | sty | dir |
| 07c1 6d a7 | sty | 8, +sp | 084 f 7 d 0188 | sty | ext |
| 07 c 3 6d 27 | sty | 8, +x | 0852 7d 0188 | sty | ext |
| 07c5 6d 67 | sty | 8, +y | 0855 6d f2 0188 | sty | ext,sp |
| 07c7 6d c0 | sty | , pc | 0859 6d e2 0188 | sty | ext, x |
| 07c9 6d 80 | sty | , sp | 085d 6d ea 0188 | sty | ext,y |
| 07 cb 6d 00 | sty | , x | 0861 6d f8 37 | sty | ind, pc |
| 07cd 6d 40 | sty | , Y | 0864 6d f0 37 | sty | ind, sp |
| 07cf 6d af | sty | 1,-sp | 0867 6d e0 37 | sty | ind, $x$ |
| 07d1 6d 2f | sty | 1,-x | 086a 6d e8 37 | sty | ind,y |
| 07d3 6d 6f | sty | 1,-y | 086d 6d ce | sty | small, pc |
| 07d5 6d a8 | sty | 8,-sp | 086f 6d 8e | sty | small, sp |
| 07d7 6d 28 | sty | 8,-x | 0871 6d 0e | sty | small, x |
| 07d9 6d 68 | sty | 8,-y | 0873 6d 4e | sty | small, y |
| 07db 6d 9f | sty | -1, sp | 08758072 | suba | \#immed |
| 07dd 6d 1f | sty | -1, x | 0877 a0 a0 | suba | 1, +sp |
| 07df 6d 5f | sty | -1, y | 0879 a0 20 | suba | $1,+x$ |
| 07e1 6d 90 | sty | -16, sp | 087b a0 60 | suba | 1, +y |
| 07 e 3 6d 10 | sty | -16, x | 087d a0 a7 | suba | 8, +sp |
| 07 e 5 6d 50 | sty | -16, y | 087f a0 27 | suba | $8,+x$ |
| 07 f 6d f1 ef | sty | -17, sp | 0881 a0 67 | suba | 8, +y |
| 07 ea 6d e1 ef | sty | -17, x | 0883 a0 c0 | suba | , pc |
| 07ed 6d e9 ef | sty | -17, y | 0885 a0 80 | suba | , sp |
| $07 \mathrm{f0}$ 6d d2 | sty | -small, pc | 0887 a0 00 | suba | , x |
| 07 f 2 6d 92 | sty | -small, sp | 0889 a0 40 | suba | , Y |
| 07 f 4 6d 12 | sty | -small, x | 088b a0 af | suba | 1,-sp |
| $07 \mathrm{f6}$ 6d 52 | sty | -small, y | 088d a0 2f | suba | 1,-x |
| $07 \mathrm{f} 8 \mathrm{6d} \mathrm{c0}$ | sty | 0, pc | 088f a0 6f | suba | 1,-y |


| 0891 a0 a8 | suba | 8,-sp | 092a a0 4e | suba | small, y |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0893 a0 28 | suba | 8,-x | 092c c0 72 | subb | \#immed |
| 0895 a0 68 | suba | 8,-y | 092e c0 72 | subb | \#immed |
| 0897 a0 9f | suba | -1, sp | 0930 e0 a0 | subb | 1, +sp |
| 0899 a0 1f | suba | -1, x | 0932 e0 20 | subb | 1, +x |
| 089b a0 5f | suba | -1, y | 0934 e0 60 | subb | 1, +y |
| 089d a0 90 | suba | -16, sp | 0936 e0 a7 | subb | 8, +sp |
| 089f a0 10 | suba | -16, x | 0938 e0 27 | subb | $8,+x$ |
| 08a1 a0 50 | suba | -16, y | 093a e0 67 | subb | 8, +y |
| 08 a 3 a 0 f1 ef | suba | -17, sp | 093c e0 c0 | subb | , pc |
| 08 a 6 a 0 e1 ef | suba | -17, x | 093e e0 80 | subb | , sp |
| 08 a 9 a 0 e9 ef | suba | -17, y | 0940 e0 00 | subb | , x |
| 08ac a0 d2 | suba | -small, pc | 0942 e0 40 | subb | , Y |
| 08ae a0 92 | suba | -small, sp | 0944 e0 af | subb | 1,-sp |
| 08b0 a0 12 | suba | -small, x | 0946 e0 2f | subb | 1,-x |
| 08b2 a0 52 | suba | -small, y | 0948 e0 6f | subb | 1,-y |
| 08b4 a0 c0 | suba | 0, pc | 094a e0 a8 | subb | 8,-sp |
| 08b6 a0 80 | suba | 0,sp | 094c e0 28 | subb | 8,-x |
| 08b8 a0 00 | suba | 0 , x | 094 e e0 68 | subb | 8,-y |
| 08ba a0 40 | suba | 0,y | 0950 e0 9f | subb | -1, sp |
| 08bc a0 b0 | suba | 1, sp+ | 0952 e0 1f | subb | -1, x |
| 08be a0 30 | suba | 1, x+ | 0954 e0 5f | subb | -1, y |
| 08c0 a0 70 | suba | 1, y+ | 0956 e0 90 | subb | -16,sp |
| 08 c 2 a 081 | suba | 1, sp | 0958 e0 10 | subb | -16, x |
| 08c4 a0 01 | suba | 1, x | 095a e0 50 | subb | -16,y |
| 08c6 a0 41 | suba | 1, y | 095c e0 f1 ef | subb | -17, sp |
| 08c8 a0 bf | suba | 1, sp- | $095 f$ e0 e1 ef | subb | -17, x |
| 08ca a0 3f | suba | 1, $\mathrm{x}-$ | 0962 e0 e9 ef | subb | -17, y |
| 08 cc a0 7f | suba | 1, $\mathrm{y}^{-}$ | 0965 e0 d2 | subb | -small, pc |
| 08 ce a0 f8 7d | suba | 125, pc | 0967 e0 92 | subb | -small,sp |
| $08 d 1$ a0 f0 7d | suba | 125, sp | 0969 e0 12 | subb | -small, x |
| 08d4 a0 e0 7d | suba | 125, x | 096 b e0 52 | subb | -small, y |
| $08 d 7$ a0 e8 7d | suba | 125, y | 096d e0 c0 | subb | 0, pc |
| 08da a0 8f | suba | 15, sp | 096 f e0 80 | subb | $0, \mathrm{sp}$ |
| 08dc a0 0f | suba | 15, x | 0971 e0 00 | subb | 0,x |
| 08de a0 4f | suba | 15, y | 0973 e0 40 | subb | 0, y |
| 08 e 0 a0 f0 10 | suba | 16, sp | 0975 e0 b0 | subb | 1, sp+ |
| 08 e 3 a 0 e0 10 | suba | 16, x | 0977 e0 30 | subb | 1, x+ |
| 08 e 6 a 0 e8 10 | suba | 16, y | 0979 e0 70 | subb | 1, $\mathrm{y}^{+}$ |
| 08e9 a0 b7 | suba | 8, sp+ | 097 b e0 81 | subb | 1, sp |
| 08 eb a0 37 | suba | 8, x+ | 097d e0 01 | subb | 1, x |
| 08ed a0 77 | suba | 8,y+ | 097 f e0 41 | subb | 1, y |
| 08ef a0 b8 | suba | 8, sp- | 0981 e0 bf | subb | 1, sp- |
| 08f1 a0 38 | suba | 8, x- | 0983 e0 3f | subb | 1, $\mathrm{x}-$ |
| 08f3 a0 78 | suba | 8, y- | 0985 e0 7f | subb | 1, $\mathrm{y}^{-}$ |
| 08 f 5 a0 f4 | suba | a,sp | 0987 e0 f8 7d | subb | 125, pc |
| $08 \mathrm{f7}$ a0 e4 | suba | a, x | 098a e0 f0 7d | subb | 125, sp |
| 08f9 a0 ec | suba | a, y | 098d e0 e0 7d | subb | 125, x |
| 08 fb a0 f5 | suba | b, sp | 0990 e0 e8 7d | subb | 125, y |
| 08 fd a 0 e5 | suba | b , x | 0993 e0 8f | subb | 15, sp |
| 08ff a0 ed | suba | b, y | 0995 e0 0f | subb | 15, x |
| 0901 a0 f6 | suba | d,sp | 0997 e0 4f | subb | 15, y |
| 0903 a0 e6 | suba | d, x | 0999 e0 f0 10 | subb | 16, sp |
| 0905 a0 ee | suba | d, y | 099c e0 e0 10 | subb | 16, x |
| 09079055 | suba | dir | 099 fe e 810 | subb | 16, y |
| 0909 b0 0188 | suba | ext | 09a2 e0 b7 | subb | 8, sp+ |
| 090c a0 f2 0188 | suba | ext,sp | 09a4 e0 37 | subb | 8, x+ |
| 0910 a0 e2 0188 | suba | ext, x | 09a6 e0 77 | subb | 8, y+ |
| 0914 a0 ea 0188 | suba | ext,y | 09 a 8 e0 b8 | subb | 8, sp- |
| 0918 a0 f8 37 | suba | ind, pc | 09aa e0 38 | subb | 8, x- |
| $091 b$ a0 f0 37 | suba | ind, sp | 09 ac e0 78 | subb | 8, y- |
| 091 e a0 e0 37 | suba | ind, x | 09ae e0 f4 | subb | a,sp |
| 0921 a0 e8 37 | suba | ind, y | 09b0 e0 e4 | subb | a, x |
| 0924 a0 ce | suba | small, pc | 09b2 e0 ec | subb | a, y |
| 0926 a0 8e | suba | small,sp | 09b4 e0 f5 | subb | b, sp |
| 0928 a0 0e | suba | small, x | 09 b 6 e0 e5 | subb | b, x |


| 09 b 8 e 0 ed | subb | b, y | 0a50 a3 e8 7d | subd | 125, y |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 09 ba e0 f6 | subb | d, sp | 0a53 a3 8f | subd | 15, sp |
| 09 bc e0 e6 | subb | d, x | 0a55 a3 0f | subd | 15, x |
| 09 be e0 ee | subb | d, y | 0 a 7 a3 4f | subd | 15, y |
| 09c0 d0 55 | subb | dir | 0 a 9 a3 f0 10 | subd | $16, \mathrm{sp}$ |
| 09c2 d0 55 | subb | dir | $0 \mathrm{a} c \mathrm{c}$ a ${ }^{\text {e }} 010$ | subd | 16, x |
| 09c4 f0 0188 | subb | ext | 0 5 f a3 e8 10 | subd | 16,y |
| 09c7 f0 0188 | subb | ext | 0a62 a3 b7 | subd | 8, sp+ |
| 09 ca e0 f2 0188 | subb | ext,sp | 0 a 64 a3 37 | subd | 8, x+ |
| 09 ce e0 e2 0188 | subb | ext,x | 0a66 a3 77 | subd | 8, $\mathrm{Y}^{+}$ |
| 09 d 2 e0 ea 0188 | subb | ext, y | 0 a 68 a3 b8 | subd | 8,sp- |
| $09 \mathrm{d6}$ e0 f8 37 | subb | ind, pc | 0a6a a3 38 | subd | 8, x- |
| $09 \mathrm{d9}$ e0 f0 37 | subb | ind,sp | $0 \mathrm{a6c}$ a3 78 | subd | 8, $\mathrm{y}^{-}$ |
| 09 dc e0 e0 37 | subb | ind, $x$ | 0a6e a3 f4 | subd | a,sp |
| $09 \mathrm{df} \mathrm{e0} \mathrm{e8} 37$ | subb | ind, y | 0a70 a3 e4 | subd | a, x |
| 09 e 2 e0 ce | subb | small, pc | 0a72 a3 ec | subd | a, y |
| 09 e 4 e0 8e | subb | small,sp | 0a74 a3 f5 | subd | b, sp |
| 09 e e e 0 e | subb | small, x | 0a76 a3 e5 | subd | b , x |
| 09 e 8 e0 4e | subb | small, y | $0 \mathrm{a78}$ a3 ed | subd | b, y |
| 09ea 830072 | subd | \#immed | 0a7a a3 f6 | subd | d,sp |
| 09ed 830072 | subd | \#immed | 0a7c a3 e6 | subd | d, x |
| $09 f 0$ a3 a0 | subd | 1, +sp | 0a7e a3 ee | subd | d, y |
| 09 f 2 a3 20 | subd | $1,+x$ | $0 \mathrm{a80} 9355$ | subd | dir |
| $09 f 4$ a3 60 | subd | 1, +y | 0a82 9355 | subd | dir |
| $09 \mathrm{f6}$ a3 a7 | subd | 8, +sp | 0 a 44 b 30188 | subd | ext |
| 09 f 8 a3 27 | subd | 8, +x | 0 a 7 b b3 0188 | subd | ext |
| 09 fa a3 67 | subd | $8,+y$ | 0a8a a3 f2 0188 | subd | ext,sp |
| 09fc a3 c0 | subd | , pc | 0a8e a3 e2 0188 | subd | ext, x |
| 09 fe a3 80 | subd | , sp | $0 \mathrm{a92}$ a3 ea 0188 | subd | ext,y |
| 0 a 00 a3 00 | subd | , x | 0 096 a3 f8 37 | subd | ind, pc |
| 0 a 02 a3 40 | subd | , Y | 0 O 99 a3 f0 37 | subd | ind,sp |
| 0a04 a3 af | subd | 1,-sp | 0a9c a3 e0 37 | subd | ind, $x$ |
| 0a06 a3 2f | subd | 1,-x | 0a9f a3 e8 37 | subd | ind,y |
| 0a08 a3 6f | subd | 1,-y | 0aa2 a3 ce | subd | small, pc |
| 0 a 0 a a3 a8 | subd | 8,-sp | 0aa4 a3 8e | subd | small,sp |
| 0 a 0 c a3 28 | subd | 8,-x | 0aa6 a3 0e | subd | small, x |
| 0a0e a3 68 | subd | 8,-y | 0aa8 a3 4e | subd | small, y |
| 0a10 a3 9f | subd | -1, sp | 0aaa 3f | swi |  |
| $0 \mathrm{al2} \mathrm{a3} \mathrm{1f}$ | subd | -1, x | 0aab b7 c4 | swpb | d |
| 0a14 a3 5f | subd | -1, y | Oaad 180 e | tab |  |
| 0a16 a3 90 | subd | -16,sp | 0aaf b7 02 | tap |  |
| $0 \mathrm{a18}$ a3 10 | subd | -16, x | $0 \mathrm{ab1} 18$ 0f | tba |  |
| 0a1a a3 50 | subd | -16, y | 0ab3 18 3d e5 | tbl | b, x |
| Oa1c a3 f1 ef | subd | -17, sp | 0 ab 6 b 700 | $t \mathrm{fr}$ | a a |
| $0 a 1 f$ a3 e1 ef | subd | -17,x | 0 ab 8 b 700 | tfr | a, a |
| 0 a 22 a3 e9 ef | subd | -17,y | 0aba b7 01 | $t \mathrm{fr}$ | a b |
| 0 a 25 a3 d2 | subd | -small, pc | 0abc b7 01 | tfr | $a, b$ |
| $0 a 27$ a3 92 | subd | -small,sp | 0abe b7 02 | $t \mathrm{fr}$ | a ccr |
| 0 a 29 a3 12 | subd | -small, x | 0ac0 b7 04 | $t f r$ | a d |
| 0a2b a3 52 | subd | -small, y | 0ac2 b7 07 | $t f r$ | a sp |
| 0a2d a3 c0 | subd | 0, pc | 0ac4 b7 05 | $t \mathrm{fr}$ | a x |
| 0 a 2 f a3 80 | subd | $0, \mathrm{sp}$ | 0ac6 b7 05 | $t \mathrm{fr}$ | a, x |
| $0 a 31$ a3 00 | subd | 0,x | 0ac8 b7 06 | tfr | a y |
| 0 a 33 a3 40 | subd | 0, y | 0aca b7 06 | tfr | a, y |
| 0a35 a3 b0 | subd | 1, sp+ | 0acc b7 10 | $t \mathrm{fr}$ | b a |
| 0 a 37 a3 30 | subd | 1, x+ | 0ace b7 11 | $t \mathrm{fr}$ | b b |
| 0 a 39 a3 70 | subd | 1, $\mathrm{Y}^{+}$ | Oad0 b7 12 | $t f r$ | b ccr |
| 0 a 3 b a3 81 | subd | 1, sp | 0ad2 b7 14 | $t \mathrm{fr}$ | b d |
| $0 a 3 d$ a3 01 | subd | 1, x | 0ad4 b7 17 | tfr | b sp |
| 0a3f a3 41 | subd | 1, y | 0ad6 b7 15 | $t \mathrm{fr}$ | b x |
| 0 a 41 a 3 bf | subd | 1, sp- | 0ad8 b7 16 | $t \mathrm{fr}$ | b y |
| $0 a 43$ a3 3f | subd | 1, $\mathrm{x}^{-}$ | 0ada b7 20 | tfr | ccr a |
| 0 a 45 a3 7f | subd | 1, $\mathrm{y}^{-}$ | Oadc b7 21 | tfr | ccr b |
| $0 \mathrm{a47}$ a3 f8 7d | subd | 125, pc | 0ade b7 22 | $t f r$ | ccr cor |
| 0 a 4 a a3 f0 7d | subd | 125, sp | 0ae0 b7 24 | $t f r$ | ccr d |
| 0a4d a3 e0 7d | subd | 125, x | Oae2 b7 27 | tfr | ccr sp |


| 0ae4 b7 25 | $t f r$ | ccr x | 0 b 6 b e7 70 | tst | 1, $\mathrm{y}+$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0ae6 b7 26 | tfr | cor y | 0 b 6 d e7 81 | tst | 1, sp |
| 0ae8 b7 40 | $t \mathrm{fr}$ | d a | 0 b 6 f e7 01 | tst | 1, x |
| 0aea b7 41 | tfr | d b | 0b71 e7 41 | tst | 1, y |
| 0aec b7 42 | tfr | d ccr | 0 b 73 e7 bf | tst | 1, sp- |
| 0aee b7 44 | $t f r$ | d d | 0 b 75 e7 3f | tst | 1, $\mathrm{x}-$ |
| 0af0 b7 47 | tfr | d sp | 0 b 77 e7 7f | tst | 1, $\mathrm{Y}^{-}$ |
| 0af2 b7 45 | $t f r$ | d x | 0b79 e7 f8 7d | tst | 125, pc |
| 0af4 b7 46 | $t f r$ | d y | 0b7c e7 f0 7d | tst | 125, sp |
| 0af6 b7 70 | $t \mathrm{fr}$ | sp a | 0 b 7 f e7 e0 7d | tst | 125, x |
| 0af8 b7 71 | tfr | sp b | 0 b 82 e 7 e8 7d | tst | 125, y |
| 0afa b7 72 | tfr | sp ccr | 0 b 85 e 78 f | tst | 15, sp |
| 0afc b7 74 | $t \mathrm{fr}$ | sp d | 0 b 87 e 7 0f | tst | 15, x |
| 0afe b7 77 | $t f r$ | sp sp | 0 b 89 e 7 4f | tst | 15, y |
| 0 b 00 b7 75 | $t f r$ | sp x | 0 b 8 b e7 f0 10 | tst | 16, sp |
| 0b02 b7 76 | tfr | sp y | 0b8e e7 e0 10 | tst | 16, x |
| 0b04 b7 50 | $t f r$ | x a | 0b91 e7 e8 10 | tst | 16, y |
| 0b06 b7 51 | $t \mathrm{fr}$ | x b | 0 b 94 e7 b7 | tst | 8,sp+ |
| 0b08 b7 52 | tfr | x ccr | 0 b 96 e7 37 | tst | 8, x+ |
| 0 b 0 a b7 54 | $t \mathrm{fr}$ | x d | 0b98 e7 77 | tst | 8, $\mathrm{Y}^{+}$ |
| 0 b 0 c b7 57 | $t f r$ | x sp | 0 b 9 a e7 b8 | tst | 8,sp- |
| 0b0e b7 55 | $t \mathrm{fr}$ | x x | 0 b 9 c e7 38 | tst | 8, x- |
| 0b10 b7 56 | $t f r$ | $x$ y | 0b9e e7 78 | tst | 8, y- |
| 0b12 b7 60 | $t f r$ | y a | 0ba0 e7 f4 | tst | a,sp |
| 0b14 b7 61 | $t f r$ | y b | $0 \mathrm{ba2}$ e7 e4 | tst | a, x |
| 0b16 b7 62 | tfr | $y \mathrm{ccr}$ | $0 \mathrm{ba4}$ e7 ec | tst | a, y |
| 0b18 b7 64 | tfr | y d | $0 \mathrm{ba6}$ e7 f5 | tst | b, sp |
| 0b1a b7 67 | $t f r$ | y $s p$ | $0 \mathrm{ba8}$ e7 e5 | tst | b, x |
| 0b1c b7 65 | $t f r$ | y x | 0 baa e7 ed | tst | b, y |
| 0b1e b7 66 | tfr | y y | $0 \mathrm{bac} \mathrm{e7} \mathrm{f6}$ | tst | d, sp |
| 0b20 b7 20 | tpa |  | Obae e7 e6 | tst | d, x |
| 0 b 22 e7 a0 | tst | 1, +sp | 0 bb 0 e7 ee | tst | d, y |
| 0 b 24 e7 20 | tst | $1,+\mathrm{x}$ | 0bb2 f7 0055 | tst | dir |
| 0 b 26 e7 60 | tst | 1, +y | 0bb5 f7 0188 | tst | ext |
| 0 b 28 e7 a7 | tst | 8, +sp | 0bb8 f7 0188 | tst | ext |
| 0 b 2 a e7 27 | tst | $8,+x$ | Obbb e7 f2 0188 | tst | ext,sp |
| 0 b 2 c e7 67 | tst | 8, +y | Obbf e7 e2 0188 | tst | ext,x |
| 0b2e e7 c0 | tst | , pc | 0 bc 3 e7 ea 0188 | tst | ext,y |
| 0 b 30 e7 80 | tst | , sp | $0 \mathrm{bc7}$ e7 f8 37 | tst | ind, pc |
| 0 b 32 e7 00 | tst | , x | Obca e7 f0 37 | tst | ind, sp |
| 0 b 34 e7 40 | tst | , Y | Obcd e7 e0 37 | tst | ind, $x$ |
| 0 b 36 e7 af | tst | 1,-sp | Obd0 e7 e8 37 | tst | ind, y |
| 0 b 38 e7 2f | tst | 1,-x | 0 bd 3 e7 ce | tst | small, pc |
| 0 b 3 a e7 6f | tst | 1,-y | $0 \mathrm{bd5}$ e7 8e | tst | small,sp |
| 0 b 3 c e7 a8 | tst | 8,-sp | $0 \mathrm{bd7}$ e7 0e | tst | small, x |
| Ob3e e7 28 | tst | 8,-x | 0bd9 e7 4e | tst | small,y |
| $0 \mathrm{b40}$ e7 68 | tst | 8,-y | 0 bdb 97 | tsta |  |
| 0 b 42 e7 9f | tst | -1, sp | 0 bdc d7 | tstb |  |
| 0 b 44 e 7 1f | tst | -1, x | 0bdd b7 75 | tsx |  |
| 0 b 46 e7 5f | tst | -1, y | 0bdf b7 76 | tsy |  |
| 0 b 48 e7 90 | tst | -16, sp | Obe1 b7 57 | txs |  |
| 0 b 4 a e7 10 | tst | -16, x | Obe3 b7 67 | tys |  |
| 0 b 4 c e7 50 | tst | -16,y | Obe5 1839 | trap | \$39 |
| 0 b 4 e e7 f1 ef | tst | -17, sp | Obe7 3e | wai |  |
| 0 b 51 e7 el ef | tst | -17, x | Obe8 18 3c | wav |  |
| 0 b 4 e7 e9 ef | tst | -17, y | Obea b7 c5 | xgdx |  |
| 0 b 57 e 7 d 2 | tst | -small, pc | 0bec b7 c6 | xgdy |  |
| 0 b 59 e7 92 | tst | -small, sp | Obee 39 | pshc |  |
| 0 b 5 b e7 12 | tst | -small,x | Obef 0a | rtc |  |
| 0 b 5 d e7 52 | tst | -small, y |  |  |  |
| 0 b 5 f e7 c0 | tst | 0, pc |  |  |  |
| 0 b 61 e7 80 | tst | 0,sp |  |  |  |
| 0 b 63 e7 00 | tst | 0 , x |  |  |  |
| 0 b 65 e7 40 | tst | 0, y |  |  |  |
| 0 b 67 e7 b0 | tst | 1, sp+ |  |  |  |
| 0 b 69 e7 30 | tst | 1, x+ |  |  |  |

## A

ABA instruction 6-8
Abbreviations for system resources 1-2
ABX instruction 6-9
ABY instruction 6-10
Accumulator direct indexed addressing mode 3-9 Accumulator offset indexed addressing mode 3-9 Accumulators 2-1, 5-8, 5-19

А 2-1, 3-5, 5-8, 6-8, 6-11, 6-13, 6-15 to 6-16, 6-20, 6-24, 6-35, 6-53, 6-57, 6-60, 6-63, $6-69$ to 6-71, 6-73, 6-87, 6-90, 6-92 to 6-93, 6-97, 6-122, 6-124, 6-132, 6-134, 6-136, $6-139$ to $6-140,6-142$ to $6-143,6-146$, $6-148,6-151,6-154,6-157,6-160,6-167$, 6-169, 6-171, 6-174, 6-177, 6-179 to 6-180, 6-185 to 6-186, 6-193, 6-196 to 6-204, 6-207
В 2-1, 3-5, 5-8, 6-8 to 6-10, 6-12, 6-14 to 6-15, $6-17,6-21,6-25,6-36,6-53,6-58,6-61,6-64$, 6-70 to 6-71, 6-74, 6-88 to 6-90, $6-92$ to $6-93,6-98,6-123$ to $6-124,6-133$, $6-137,6-146,6-149,6-152,6-155,6-161$, $6-172,6-175,6-177,6-179,6-181,6-185$, 6-187, 6-194, 6-196 to 6-197, 6-199 to 6-203, 6-208
D 2-1, 3-5, 5-8, 6-15, 6-22, 6-65, 6-70 to 6-71, 6-78 to 6-79, 6-81 to 6-86, 6-89 to 6-95, $6-124,6-134,6-138,6-146,6-157,6-163$, $6-185,6-188,6-195$ to $6-196,6-200$, 6-202 to 6-203, 6-215 to 6-216
Indexed addressing 3-9
ADCA instruction 6-11
ADCB instruction 6-12
ADDA instruction 6-13
ADDB instruction 6-14
ADDD instruction 6-15
Addition instructions 5-3, 6-8 to 6-15
ADDR mnemonic 1-3
Addressing modes 3-1
Direct 3-3
Extended 3-3
Immediate 3-2
Indexed 2-2, 3-5
Inherent 3-2
Memory expansion 10-7
Relative 3-4
ANDA instruction 6-16
ANDB instruction 6-17
ANDCC instruction 6-18
ASL instruction 6-19
ASLA instruction 6-20
ASLB instruction 6-21
ASLD instruction 6-22
ASR instruction 6-23

ASRA instruction 6-24
ASRB instruction 6-25
Asserted 1-3
Automatic indexing 3-8
Automatic program stack 2-2

## B

Background debugging mode 5-22, 8-6
BKGD pin 8-7 to 8-9
Commands 8-9 to 8-10
Enabling and disabling 8-6
Instruction 5-22, 6-31, 8-6
Registers 8-11
ROM 8-6
Serial interface 8-7 to 8-9
Base index register 3-6, 3-10
BCC instruction 6-26
BCLR instruction 6-27
BCS instruction 6-28
BEQ instruction 6-29
BGE instruction 6-30
BGND instruction 5-22, 6-31, 8-6
BGT instruction 6-32
BHI instruction 6-33
BHS instruction 6-34
Binary-coded decimal instructions 5-4, 6-8, 6-11 to 6-14, 6-69
Bit manipulation instructions 5-7, 6-27, 6-48, B-15, C-1
Mask operand 3-11, 6-27, 6-48
Multiple addressing modes 3-11, 6-27, 6-48
Bit test instructions 5-7, 6-35 to 6-36, C-1
BITA instruction 6-35
BITB instruction 6-36
Bit-condition branches 5-16, 6-45, 6-47
BKGD pin 8-7 to 8-9
BLE instruction 6-37
BLO instruction 6-38
BLS instruction 6-39
BLT instruction 6-40
BMI instruction 6-41
BNE instruction 6-42
Boolean logic instructions 5-6
AND 6-16 to 6-18
Complement 6-62 to 6-64
Exclusive OR 6-87 to 6-88
Inclusive OR 6-151 to 6-153
Negate 6-147 to 6-149
BPL instruction 6-43
BRA instruction 6-44
Branch instructions 3-4, 4-4 to 4-5, 5-13, C-4 Bit-condition 4-4 to 4-5, 5-16, 6-45, 6-47
Long $4-4$ to $4-5,5-13,6-104$ to $6-121, B-13$

Loop primitive 4-5, 5-16, 6-70 to 6-71, 6-92 to 6-93, 6-200, 6-202
Offset values 5-13, 5-16
Offsets 3-4
Short 4-4 to 4-5, 5-13, 6-26, 6-28 to 6-30, $6-32$ to $6-34,6-37$ to $6-44,6-46,6-50$ to $6-51$
Signed 5-13, 6-30, 6-32, 6-37, 6-40, 6-107 to 6-108, 6-111, 6-114
Simple 5-13, 6-26, 6-28 to 6-29, 6-41 to 6-43, $6-50$ to $6-51,6-104$ to $6-106,6-115$ to $6-117$, 6-120 to 6-121
Subroutine 5-17, 6-49
Taken/not-taken cases 4-4, 6-7
Unary 5-13, 6-44, 6-46, 6-118 to 6-119
Unsigned 5-13, 6-33 to 6-34, 6-38 to 6-39, 6-109 to 6-110, 6-112 to 6-113
BRCLR instruction 6-45
BRN instruction 6-46
BRSET instruction 6-47
BSET instruction 6-48
BSR instruction 4-3, 6-49
Bus cycles 6-5
Bus structure B-4
BVC instruction 6-50
BVS instruction 6-51
Byte moves 6-144
Byte order in memory 2-5
Byte-sized instructions 4-4 to 4-5

## C

C status bit 2-5, 6-19 to 6-26, 6-28, 6-33 to 6-34, $6-38$ to 6-39, 6-54, 6-69, 6-72 to 6-74, $6-78$ to $6-79,6-81$ to $6-86,6-95$ to $6-98$, 6-104 to 6-105, 6-109 to 6-110, $6-112$ to $6-113,6-131$ to $6-140$, $6-142$ to $6-143,6-168,6-170$ to $6-175$, 6-179 to 6-182, 6-193 to 6-195
CALL instruction 3-12, 4-3, 5-17, 6-52, 10-2 to 10-3, B-16, C-4 to C-5
Case statements C-4
CBA instruction 6-53
Changes in execution flow 4-2 to 4-5, $6-102$ to $6-103,6-176$ to $6-178,6-196$, 7-1 to 7-6
CLC instruction 6-54
Clear instructions 5-6, 6-56 to 6-58
Cleared 1-3
CLI instruction 6-55
Clock monitor reset 7-3
CLR instruction 6-56
CLRA instruction 6-57
CLRB instruction 6-58
CLV instruction 6-59
CMPA instruction 6-60

CMPB instruction 6-61
Code size B-10
COM instruction 6-62
COMA instruction 6-63
COMB instruction 6-64
Compare instructions 5-5, 6-53, 6-60 to 6-61, 6-65 to 6-68
Complement instructions 5-6, 6-62 to 6-64
Computer operating properly monitor 7-3
Condition codes instructions 5-21, 6-18, $6-54$ to 6-55, 6-59, 6-153, 6-156, 6-162, 6-182 to 6-184, 6-198, 6-203 to 6-204, B-15
Condition codes register 2-1, 2-3, 6-18, $6-54$ to $6-55,6-59,6-90,6-128,6-153,6-156$, 6-162, 6-177, 6-183 to 6-185, 6-198, $6-203$ to 6-204, 6-206 to 6-208, C-4
C status bit 2-5, 6-19 to 6-26, 6-28, 6-33 to 6-34, $6-38$ to $6-39,6-54,6-69,6-72$ to $6-74$, $6-78$ to $6-79,6-81$ to $6-86,6-95$ to $6-98$, 6-104 to 6-105, 6-109 to 6-110, 6-112 to 6-113, 6-131 to 6-140, $6-142$ to $6-143,6-168,6-170$ to $6-175$, $6-179$ to $6-182,6-193$ to $6-195$
H status bit 2-4, 6-8, 6-11 to 6-14, 6-69
I mask bit 2-4, 6-18, 6-55, 6-183, 6-196, 6-205, 6-213, 7-2, 7-4
Manipulation 5-21, 6-18, 6-54 to 6-55, 6-59, 6-153, 6-182 to 6-184, 6-198, 6-204
N status bit 2-4, 6-41, 6-43, 6-115, 6-117
S control bit 2-3, 6-189
Stacking 6-156, 6-162
V status bit 2-4, 6-50 to 6-51, 6-59, 6-120 to 6-121, 6-166 to 6-169, 6-184
X mask bit 2-3, 6-90, 6-162, 6-177, 6-189, 6-198, 6-203, 6-213, 7-2, 7-4
Z status bit 2-4, 6-29, 6-42, 6-81 to 6-84, 6-100 to 6-101, 6-106, 6-116, 6-139 to 6-140, 6-142 to 6-143
Conditional 16-bit read cycle 6-7
Conditional 8-bit read cycle 6-7
Conditional 8-bit write cycle 6-7
Conserving power 5-21, 6-189
Constant indirect indexed addressing mode 3-7
Constant offset indexed addressing mode 3-6 to 3-7
Conventions 1-3
COP reset 7-3
CPD instruction 6-65
CPS instruction 6-66
CPU wait 6-213
CPX instruction 6-67
CPY instruction 6-68
Cycle code letters 6-5
Cycle counts B-9

Cycle-by-cycle operation 6-5

## D

DAA instruction 6-69
DATA mnemonic 1-3
Data types 2-5
DBEQ instruction 6-70, A-25
DBNE instruction 6-71, A-25
DEC instruction 6-72
DECA instruction 6-73
DECB instruction 6-74
Decrement instructions 5-4, 6-72 to 6-77
Defuzzification 9-6, 9-22 to 9-24, 9-26, 9-29
DES instruction 6-75
DEX instruction 6-76
DEY instruction 6-77
Direct addressing mode 3-3
Division instructions 5-7
16-bit fractional 6-91
16-bit integer 6-94 to 6-95
32-bit extended 6-78 to 6-79
Divsion instructions C-3

## E

EDIV instruction 6-78
EDIVS instruction 6-79
Effective address 3-2, 3-5, 6-128 to 6-130
EMACS instruction 5-11, 6-80, 9-1, 9-29
EMAXD 6-81
EMAXD instruction 6-81
EMAXM instruction 6-82, 9-1
EMIND instruction 6-83, 9-1
EMINM instruction 6-84
EMUL instruction 6-85
EMULS instruction 6-86
Enabling maskable interrupts 2-4
EORA instruction 6-87
EORB instruction 6-88
ETBL instruction 5-12, 6-89, 9-1
Even bytes 2-5
Exceptions 4-3, 7-1
Interrupts 7-3
Maskable interrupts 7-1, 7-4 to 7-5
Non-maskable interrupts 7-1, 7-4
Priority 7-2
Processing flow 7-6
Resets 7-1 to 7-3
Software interrupts 5-18, 6-196, 7-1, 7-6
Unimplemented opcode trap 7-1 to 7-2, 7-5
Vectors 7-1, 7-6
Exchange instructions 5-2, 6-90, 6-215 to 6-216, B-11, B-13
Postbyte encoding A-24

Execution cycles 6-5
Conditional 16-bit read 6-7
Conditional 8-bit read 6-7
Conditional 8-bit write 6-7
Free 6-5
Optional 4-4 to 4-5, 6-6
Program word access 6-6
Read indirect pointer 6-5
Read indirect PPAGE value 6-5
Read PPAGE 6-5
Read 16-bit data 6-6
Read 8-bit data 6-6
Stack 16-bit data 6-6
Stack 8-bit data 6-6
Unstack 16-bit data 6-7
Unstack 8-bit data 6-6
Vector fetch 6-7
Write PPAGE 6-5
Write 16-bit data 6-6
Write 8-bit data 6-6
Execution time 6-5
EXG instruction 6-90
Expanded memory 3-12, 4-3, 10-1, B-16, C-4 to C-5
Addressing modes $3-12,10-4$ to 10-6
Bank switching 3-12, 10-1, 10-3 to 10-6
Chip-select circuits 10-4
Instructions 3-12, 5-17, 6-52, 6-176, 10-2 to 10-3
Overlay windows $10-1,10-3$ to $10-6$
Page registers 3-12, 10-1, 10-4 to 10-6
Registers 10-5 to 10-6
Subroutines 5-17, 10-2, C-4 to C-5
Extended addressing mode 3-3
Extended division 5-7
Extension byte 3-5
External interrupts 7-5
External queue reconstruction 8-1
External reset 7-3

## F

Fast math B-9
FDIV instruction 6-91
Fractional division 5-7
Frame pointer C-2 to C-3
Free cycle 6-5
Fuzzy logic 9-1
Antecedants 9-5
Consequents 9-5
Custom programming 9-26
Defuzzification 5-9, 9-6, 9-22 to 9-24, 9-26, 9-29
Fuzzification 5-9, 9-3, 9-26
Inference kernel 5-9, 9-2, 9-7
Inputs 5-9, 9-30

Instructions 5-9, 6-141, 6-166, 6-168, 6-214, 9-1, $9-9,9-13$ to $9-14,9-17$ to $9-19,9-22, B-14$
Interrupts 9-20, 9-23 to 9-24, 9-26
Knowledge base 9-2, 9-5
Membership functions 5-9, 6-141, 9-1 to 9-3, 9-9 to 9-13, 9-26 to 9-27
Outputs 5-9, 9-30
Rule evaluation 5-9, 6-166, 6-168, 9-1, 9-5, 9-13 to 9-15, 9-17 to 9-20, 9-22, 9-29
Rules 9-2, 9-5
Sets 9-2
Tabular membership functions 5-12, 9-26
Weighted average 5-9, 6-214, 9-1, 9-6, 9-22 to 9-24, 9-26

## G

General purpose accumulators 2-1

## H

H status bit 2-4, 6-8, 6-11 to 6-14, 6-69
High-level language C-1, C-3
Addressing modes C-1, C-3 to C-4
Condition codes register C-4
Expanded memory C-4 to C-5
Instructions C-1
Loop primitives C-3
Stack C-1 to C-2
I
I mask bit 2-4, 6-18, 6-55, 6-183, 6-196, 6-205, 6-213, 7-2
IBEQ instruction 6-92, A-25
IBNE A-25
IBNE instruction 6-93
IDIV instruction 6-94
IDIVS instruction 6-95, C-3
Immediate addressing mode 3-2
INC instruction 6-96
INCA instruction 6-97
INCB instruction 6-98
Increment instructions 5-4, 6-96 to 6-101
Index calculation instructions 5-20, 6-9 to 6-10,
$6-76$ to $6-77,6-100$ to $6-101,6-129$ to $6-130$, B-11
Index manipulation instructions 5-19, 6-67 to 6-68, 6-90, 6-126 to 6-127, 6-158 to 6-159,
6-164 to 6-165, 6-191 to 6-192, 6-203,
$6-209$ to $6-212,6-215$ to $6-216$
Index registers 2-1 to 2-2, 5-19, C-2
X 3-5, 6-9, 6-67, 6-70 to 6-71, 6-76, 6-90 to 6-95, $6-100,6-126,6-128$ to $6-130,6-158,6-164$, $6-166,6-168,6-177,6-185,6-191,6-196$, 6-200 to 6-203, 6-209, 6-211, 6-215
Y 3-5, 6-10, 6-68, 6-70 to 6-71, 6-77 to 6-80,

6-85 to 6-86, 6-90, 6-92 to 6-93, 6-101, $6-127$ to $6-130,6-159,6-165$ to $6-166$, 6-168, 6-177, 6-185, 6-192, 6-196, $6-200$ to 6-203, 6-210, 6-212, 6-216
Indexed addressing modes $2-2,3-5, \mathrm{~A}-22$, B-6 to B-9
Accumulator direct 3-9
Accumulator offset 3-9
Automatic indexing 3-8
Base index register 3-6, 3-10
Extension byte 3-5
Postbyte 3-5
Postbyte encoding 3-5, A-22
16-bit constant indirect 3-7
16-bit constant offset 3-7
5-bit constant offset 3-6
9-bit constant offset 3-7
Inference kernel, fuzzy logic 9-7
Inherent addressing mode 3-2
INS instruction 6-99
Instruction queue 1-1, 2-5, 4-1, 8-1, B-4
Alignment 4-1
Buffer 4-1
Debugging 8-1
Movement cycles 4-2
Reconstruction 8-1, 8-3, 8-5
Stages 4-1, 8-1
Status registers 8-4 to 8-5
Status signals 4-1, 8-1 to 8-3, 8-5 to 8-6
Instruction set A-2
Integer division 5-7
Interrupt instructions 5-18
Interrupts 7-3
Enabling and disabling 2-3 to 2-4, 6-55, 6-183, 7-2
External 7-5
I mask bit 2-4, 6-55, 6-183, 6-196, 6-213, 7-4
Instructions 5-18, 6-55, 6-177, 6-183, 6-196, 6-205
Low-power stop 5-21, 6-189
Maskable 2-4, 7-4
Non-maskable 2-3, 7-2, 7-4
Recognition 7-4
Return 2-4, 5-18, 6-177, 7-5
Service routines 7-4
Software 5-18, 6-196, 7-1, 7-6
Stacking 7-4
Vectors 7-3
Wait instruction 5-21, 6-213
$X$ mask bit 2-3, 6-189, 6-213, 7-4
INX instruction 6-100
INY instruction 6-101

## J

JMP instruction 4-5, 6-102
JSR instruction 4-3, 6-103
Jump instructions 5-17
Jumps 4-5
K
Knowledge base 9-2

## L

LBCC instruction 6-104
LBCS instruction 6-105
LBEQ instruction 6-106
LBGE instruction 6-107
LBGT instruction 6-108
LBHI instruction 6-109
LBHS instruction 6-110
LBLE instruction 6-111
LBLO instruction 6-112
LBLS instruction 6-113
LBLT instruction 6-114
LBMI instruction 6-115
LBNE instruction 6-116
LBPL instruction 6-117
LBRA instruction 6-118
LBRN instruction 6-119
LBVC instruction 6-120
LBVS instruction 6-121
LDAA instruction 6-122
LDAB instruction 6-123
LDD instruction 6-124
LDS instruction 6-125
LDX instruction 6-126
LDY instruction 6-127
LEAS instruction 6-128, C-2, C-4
Least signficant byte 1-3
Least significant word 1-3
LEAX instruction 6-129, C-4
LEAY instruction 6-130, C-4
Legal label 6-3
Literal expression 6-3
Load instructions 5-1, 6-122 to 6-130
Logic level one 1-3
Logic level zero 1-3
Loop primitive instructions 4-5, 6-70 to 6-71, 6-92 to 6-93, 6-200, 6-202, A-25, B-13, C-3 Offset values 5-16
Postbyte encoding A-25
Low-power stop 5-21, 6-189
LSL instruction 6-131
LSL mnemonics 5-8
LSLA instruction 6-132
LSLB instruction 6-133

LSLD instruction 6-134
LSR instruction 6-135
LSRA instruction 6-136
LSRB instruction 6-137
LSRD instruction 6-138

## M

Maskable interrupts 7-1, 7-4
MAXA instruction 6-139
Maximum instructions 5-11, B-14
16-bit 6-81 to 6-82
8-bit 6-139 to 6-140
MAXM instruction 6-140, 9-1
MEM instruction 5-9, 6-141, 9-1, 9-9 to 9-13
Membership functions 9-2
Memory and addressing symbols 1-2
Memory expansion
Addressing 10-7
Bank switching 10-7
Overlay windows 10-7
Page registers 10-3, 10-7
MINA instruction 6-142, 9-1
Minimum instructions 5-11, B-14
16-bit 6-83 to 6-84
8-bit 6-142 to 6-143
MINM instruction 6-143
Misaligned instructions 4-4 to 4-5
Mnemonic 1-3
Mnemonic ranges 1-3
Most significant byte 1-3
Most significant word 1-3
MOVB instruction 6-144
Move instructions 5-3, 6-144 to 6-145, B-10, B-13
Destination 3-10
Multiple addressing modes 3-10
PC relative addressing 3-10
Reference index register 3-10
Source 3-10
MOVW instruction 6-145
MUL instruction 6-146
Multiple addressing modes
Bit manipulation instructions 3-11, 6-27, 6-48
Move instructions 3-10, 6-144 to 6-145
Multiplication instructions 5-7
16-bit 6-85 to 6-86
8-bit 6-146
Multiply and accumulate instructions 5-11, 6-80, 6-214
M68HC11 compatibility 3-2, B-1
M68HC11 instruction mnemonics B-1

## N

$N$ status bit 2-4, 6-41, 6-43, 6-115, 6-117

NEG instruction 6-147
NEGA instruction 6-148
Negate instructions 5-6, 6-147 to 6-149
Negated 1-3
Negative integers 2-5
NEGB instruction 6-149
Non-maskable interrupts 7-1 to 7-2, 7-4
NOP instruction 5-22, 6-150
Notation
Branch taken/not taken 6-7
Changes in CCR bits 6-2
Cycle-by-cycle operation 6-5
Memory and addressing 1-2
Object code 6-2
Operators 1-3
Source forms 6-3
System resources 1-2
Null operation instruction 5-22, 6-150
Numeric range of branch offsets 3-4

## 0

Object code notation 6-2
Odd bytes 2-5
Opcodes B-2, B-9
Map A-20
Operators 1-3
Optional cycles 4-4 to 4-5, 6-6
ORAA instruction 6-151
ORAB instruction 6-152
ORCC instruction 6-153
Orthogonality C-5

## P

Pointer calculation instructions 5-20, 6-128 to 6-130
Pointers C-4
Postbyte 3-5, 6-90, 6-185, 6-203
Postbyte encoding
Exchange instructions A-24
Indexed addressing modes A-22
Loop primitive instruction A-25
Transfer instructions A-24
Post-decrement indexed addressing mode 3-8
Post-increment indexed addressing mode 3-8
Power conservation 5-21, 6-189, 6-213
Power-on reset 7-3
Pre-decrement indexed addressing mode 3-8
Pre-increment indexed addressing mode 3-8
Priority, exception 7-2
Program counter 2-1 to 2-2, 3-5, 6-31, 6-49, 6-52, $6-103,6-128$ to $6-130,6-144$ to $6-145,6-150$, 6-177 to 6-178, 6-196, 6-201, 6-205
Program word access cycle 6-6
Programming model 1-1, 2-1, B-3

Pseudo-non-maskable interrupt 7-2
PSHA instruction 6-154
PSHB instruction 6-155
PSHC instruction 6-156
PSHD instruction 6-157
PSHX instruction 6-158
PSHY instruction 6-159
PULA instruction 6-160
PULB instruction 6-161
PULC instruction 6-162
PULD instruction 6-163, C-2
Pull instructions C-5
PULX instruction 6-164
PULY instruction 6-165
Push instructions C-5
PUSHD instruction C-2

## R

Range of mnemonics 1-3
Read indirect PPAGE cycle 6-5
Read PPAGE cycle 6-5
Read 8-bit data cycle 6-6
Read16-bit data cycle 6-6
Register designators 6-3
Relative addressing mode 3-4
Relative offset 3-4
Resets 7-1 to 7-2
Clock monitor 7-3
COP 7-3
External 7-3
Power-on 7-3
REV instruction 5-9, 6-166, 9-1, 9-5, 9-13 to 9-15, 9-17 to 9-20, 9-22, 9-29
REVW instruction 5-9, 6-168, 9-1, 9-5, 9-13 to 9-15, 9-17 to 9-20, 9-22, 9-29
ROL instruction 6-170
ROLA instruction 6-171
ROLB instruction 6-172
ROM, BDM 8-6
ROR instruction 6-173
RORA instruction 6-174
RORB instruction 6-175
Rotate instructions 5-8, 6-170 to 6-175
RTC instruction 3-12, 4-3, 5-17, 6-176, 10-2 to 10-3, B-16, C-4 to C-5
RTI instruction 2-4, 5-18, 6-177, 7-5
RTS instruction 4-3, 6-178
S
S control bit 2-3, 6-189
SBA instruction 6-179
SBCA instruction 6-180
SBCB instruction 6-181
SEC instruction 6-182

SEI instruction 6-183
Set 1-3
Setting memory bits 6-48
SEV instruction 6-184
SEX instruction 5-2, 6-185
Shift instructions 5-8
Arithmetic 6-19 to 6-25
Logical 6-131 to 6-138
Sign extension instruction 6-185
Signed branches 5-13
Signed integers 2-5
Signed multiplication 5-7
Sign-extension instruction 5-2, C-1
Simple branches 5-13
Software interrupts 6-196, 7-1
Source code compatibility 1-1, B-1
Source form notation 6-3
Specific mnemonic 1-3
STAA instruction 6-186
STAB instruction 6-187
Stack 2-2, B-5 to B-6
Interrupts 6-177, 6-196
Stop and wait 6-189, 6-213
Subroutines 6-49, 6-52, 6-103, 6-176, 6-178
Traps 6-205
Stack operation instructions 5-20, 6-154 to 6-165
Stack pointer 2-1 to 2-2, 3-5, 6-49, 6-52, 6-66, 6-70 to 6-71, 6-75, 6-90, 6-92 to 6-93, 6-99, $6-103,6-125,6-128$ to $6-130,6-155$ to $6-165$, 6-178, 6-185, 6-190, 6-200 to 6-203, 6-209 to 6-212, C-1
Initialization 2-2
Manipulation 5-20, 6-66, 6-75, 6-99, 6-125, 6-128, 6-154 to 6-155, 6-190, 6-209 to 6-212
Stacking order 2-2, B-5
Stack pointer instructions 5-20, 6-66, 6-75, 6-99, 6-125, 6-128, 6-190, 6-203, 6-209 to 6-212, B-15, C-1
Stack 16-bit data cycle 6-6
Stack 8-bit data cycle 6-6
Stacking instructions 6-154 to 6-155
Standard CPU12 address space 2-5
STD instruction 6-188
STOP instruction 2-3, 5-21, 6-189
Store instructions 5-1, 6-186 to 6-188, 6-190 to 6-192
STS instruction 6-190
STX instruction 6-191
STY instruction 6-192
SUBA instruction 6-193
SUBB instruction 6-194
SUBD instruction 6-195
Subroutine instructions 5-17

Subroutines 4-3, 6-103, C-4 to C-5
Expanded memory 4-3, 5-17, 6-52, 6-176
Instructions 5-17, 6-49, 6-103, C-4 to C-5
Return 6-176, 6-178
Subtraction instructions 5-3, 6-179 to 6-181, 6-193 to 6-195
SWI instruction 5-18, 6-196, 7-6
Switch statements C-4
Symbols and notation 1-2

## T

TAB instruction 6-197
Table interpolation instructions 5-12, 6-89, 6-201, B-15
Tabular membership functions 9-26 to 9-27
TAP instruction 6-198
TBA instruction 6-199
TBEQ instruction 6-200, A-25
TBL instruction 5-12, 6-201, 9-1, 9-26 to 9-27
TBNE instruction 6-202, A-25
Termination of interrupt service routines 5-18, 6-177, 7-5
Termination of subroutines 6-176, 6-178
Test instructions 5-5, 6-35 to 6-36, 6-200, 6-202, 6-206 to 6-208
TFR instruction 6-185, 6-198, 6-203 to 6-204, 6-209 to 6-212
TPA instruction 6-204
Transfer and exchange instructions C -1
Transfer instructions 5-2, 6-197 to 6-199, 6-203 to 6-204, 6-209 to 6-212, B-11, B-13
Postbyte encoding A-24
TRAP instruction 5-18, 6-205, 7-5
TST 6-206
TST instruction 6-206
TSTA instruction 6-207
TSTB instruction 6-208
TSX instruction 6-209
TSY instruction 6-210
Twos-complement form 2-5
TXS instruction 6-211
Types of instructions
Addition and Subtraction 5-3
Background and null 5-22
Binary-coded decimal 5-4
Bit test and manipulation 5-7
Boolean logic 5-6
Branch 5-13
Clear, complement, and negate 5-6
Compare and test 5-5
Condition code 5-21
Decrement and increment 5-4
Fuzzy logic 5-9

Index manipulation 5-19
Interrupt 5-18
Jump and subroutine 5-17
Load and store 5-1
Loop primitives 5-16
Maximum and minimum 5-11
Move 5-3
Multiplication and division 5-7
Multiply and accumulate 5-11
Pointer and index calculation 5-20
Shift and rotate 5-8
Sign extension 5-2
Stacking 5-20
Stop and wait 5-21
Table interpolation 5-12
Transfer and exchange 5-2
TYS instruction 6-212

## U

Unary branches 5-13
Unimplemented opcode trap 5-18, 6-205, 7-1 to 7-2
Unsigned branches 5-13
Unsigned multiplication 5-7
Unstack 16-bit data cycle 6-7
Unstack 8-bit data cycle 6-6
Unweighted rule evaluation 6-166, 9-5, 9-13 to 9-15, 9-17 to 9-20, 9-22, 9-29

## V

V status bit $2-4,6-50$ to $6-51,6-59,6-120$ to $6-121$, 6-166 to 6-169, 6-184
Vector fetch cycle 6-7
Vectors, exception 7-1, 7-6

## W

WAI instruction 5-21, 6-213
WAV instruction 5-9, 5-11, 6-214, 9-1, 9-6, 9-22 to 9-24, 9-26, 9-29
Wavr pseudoinstruction 9-23 to 9-24, 9-26
Weighted average 6-214
Weighted rule evaluation 6-168, 9-5, 9-13 to 9-15, 9-17 to 9-20, 9-22, 9-29
Word moves 6-145
Write PPAGE cycle 6-5
Write 16-bit data cycle 6-6
Write 8-bit data cycle 6-6

## X

$X$ mask bit 2-3, 6-90, 6-162, 6-177, 6-189, 6-198, 6-203, 6-213
XGDX instruction 6-215
XGDY instruction 6-216

## Z

Z status bit 2-4, 6-29, 6-42, 6-81 to 6-84, $6-100$ to $6-101,6-106,6-116,6-139$ to $6-140$, 6-142 to 6-143
Zero-page addressing 3-3

## SUMMARY OF CHANGES

This is a complete revision and reprint. All known errors in the publication have been corrected. The following summary lists significant changes.

| Page | Change |
| :---: | :---: |
| 3-6 | Additional information provided in Table 3-2. |
| 3-9 | Changed paragraph 3.8.6 to indicate accumulator offset is an unsigned value. |
| 4-5 | Changed paragraph 4.3.3.4 to show that both taken and not taken cases for loop primitives use the same number of $P$ cycles. |
| 5-18 | Table 5-22, operation sequence of RTI instruction modified to match sequence in Sec. 6. |
| 6-3 and 6-4 | Removed spurious letter "e" from "opr" source forms. |
| 6-11 to 6-14 | Added overbars to terms in Boolean formulae for ADCA, ADCB, ADDA, and ADDB. |
| 6-27 | Modified V bit description of condition code register. |
| 6-70, 6-71, 6-92, 6-93, 6-200 and 6-202 | Corrected access details for loop primitives to show that taken and not taken cases both use three P cycles. |
| 6-78, 6-79, 6-94 | Correction in descriptions for EDIV, EDIVS, and IDIV: "dividend" is divided by "divisor." |
| 6-78 | Comment removed in EDIV description regarding C status bit. |
| $\begin{aligned} & 6-81,6-82,6-83,6-84, \\ & 6-139,6-140,6-142, \\ & 6-143,6-193,6-194, \\ & 6-195 \end{aligned}$ | In condition code C bit description of EMAXD, EMAXM, EMIND, EMINM, MAXA, MAXM, MINA, MINM, SUBA, SUBB and SUBD, two occurrences of the word "absolute" have been removed. |
| 6-148 | Overbar added to term in NEGA operation description. |
| 6-167 | Corrected access detail for REV instruction. |
| 6-177 | Corrected operation sequence for RTI instruction. |
| 6-189 | Corrected operation sequence for STOP instruction. Also, fourth paragraph of description modified so as to not indicate that SP is changed. |
| 6-196 | Condition code register corrected; status bit I is set (1) following the SWI instruction. |
| 6-213 | Corrected operation sequence for WAI instruction. |
| 6-214 | Corrected access detail for WAV instruction. |
| 8-7 | Section 8.4.2, second paragraph, time-out of 256 E clock cycles is changed to 512 E clock cycles. Fourth paragraph, "Nine target E-cycles later," is now "Ten target E-cycles later." |
| 8-8 | Figure 8-2, nine cycle reference is changed to ten cycles; art is modified accordingly. |
| 8-10 | Table 8-2, command order changed, footnote explanations added, ENTER_TAG_MODE command deleted. |
| 8-12 | Section 8.4.4.1, reset conditions for STATUS register corrected. ITF bit name is changed to ENTAG, Instruction Tagging Enable. |
| 9-16 and 9-21 | Corrected flow arrow and font substitution errors in Figures 9-9 and 9-10. |
| 9-24 | Changed paragraph 9.6.3. to reflect a three-cycle delay rather than a four-cycle delay. |
| 9-25 | Corrected flow arrow error and removed cycle 10.1 Figure 9-11. |
| 9-28 | Figure 9-12, Corrected inappropriate line break in code. |
| B-10 | Table B-3, last row (EMACS) math operation corrected and two occurrences of "per iteration" removed. |
| B-13 | Section B.7.2, first sentence, "six transfer instructions" is now "eight transfer instructions." |
| General | Minor grammatical and typographic corrections to improve consistency and presentation. New index markers. |

Motorola reserves the right to make changes without further notice to any products herein. Motorola makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Motorola assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters which may be provided in Motorola data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Motorola does not convey any license under its patent rights nor the rights of others. Motorola products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Motorola was negligent regarding the design or manufacture of the part. Motorola and (A) are registered trademarks of Motorola, Inc. Motorola, Inc. is an Equal Opportunity/Affirmative Action Employer.

## How to reach us:

USA/EUROPE/Locations Not Listed: Motorola Literature Distribution, P.O. Box 5405, Denver, Colorado 80217, 1-800-441-2447 or 1-303-675-2140. Customer Focus Center, 1-800-521-6274
JAPAN: Nippon Motorola Ltd.: SPD, Strategic Planning Office, 141, 4-32-1 Nishi-Gotanda, Shinagawa-ku, Tokyo, Japan. 03-5487-8488
ASIA/PACIFIC: Motorola Semiconductors H.K. Ltd., 8B Tai Ping Industrial Park, 51 Ting Kok Road, Tai Po, N.T., Hong Kong. 852-26629298
Mfax ${ }^{\text {TM }}$, Motorola Fax Back System: RMFAX0@email.sps.mot.com; http://sps.motorola.com/mfax/; TOUCHTONE, 1-602-244-6609; US and Canada ONLY, 1-800-774-1848
HOME PAGE: http://motorola.com/sps/


[^0]:    $a b c$ - Any one legal register designator for accumulators $A$ or $B$ or the CCR.
    abcdxys - Any one legal register designator for accumulators A or B, the CCR, the double accumulator D, index registers X or Y, or the SP. Some assemblers may accept t 2 , T2, t 3 , or T3 codes in certain cases of transfer and exchange instructions, but these forms are intended for Motorola use only.
    abd - Any one legal register designator for accumulators A or B or the double accumulator D.
    abdxys - Any one legal register designator for accumulators A or B , the double accumulator $D$, index register $X$ or $Y$, or the SP.
    $d x y s$ - Any one legal register designation for the double accumulator D, index registers X or Y , or the SP.
    msk8 - Any label or expression that evaluates to an 8-bit value. Some assemblers require a \# symbol before this value.
    opr8i - Any label or expression that evaluates to an 8-bit immediate value.
    opr16i - Any label or expression that evaluates to a 16 -bit immediate value.
    opr8a - Any label or expression that evaluates to an 8 -bit value. The instruction treats this 8 -bit value as the low order 8 -bits of an address in the direct page of the 64 -Kbyte address space ( $\$ 00 \mathrm{xx}$ ).

[^1]:    Operation: $\quad(D) \Leftrightarrow(Y)$

