# Transporting M68HC11 Code to M68HC12 Devices 

By James M. Sibigtroth

## 1 INTRODUCTION

In general, the CPU12 is a proper superset of the M68HC11 CPU. Significant changes have been made to improve the efficiency and capabilities of the CPU without sacrificing compatibility with the popular M 68 HC 11 family. This note provides information that will allow the large number of programmers familiar with the M68HC11 to evaluate moving from an M68HC11 system to an M68HC12 system. For more detailed information, please refer to the CPU12 Reference Manual, Motorola Publication Number CPU12RM/AD. The manual is available on the Freeware Data Systems website: http://www.freeware.aus.sps.mot.com/.

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


## 2 SOURCE CODE COMPATIBILITY

Every M68HC11 instruction mnemonic and source code statement can be assembled directly with a CPU12 assembler with no modifications. CPU12 instructions affect condition code bits in the same way as M68HC11 instructions. The CPU12 supports all M68HC11 addressing modes and several new variations of indexed addressing mode.

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 to according to the result of the operation.

Table 1 shows M68HC11 instruction mnemonics that are automatically translated into equivalent CPU12 instructions. The translation is performed by the assembler so there is no need to modify old M68HC11 code in order to assemble it for the CPU12. In fact, M68HC11 mnemonics can be used in new CPU12 programs.

Table 1 Translated M68HC11 Mnemonics

| M68HC11 <br> Mnemonic | Equivalent <br> CPU12 Instruction | Comments |
| :---: | :---: | :--- |
| ABX | LEAX B,X |  |
| ABY | 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. |

All of the translations produce the same amount of or slightly more object code than the original M68HC11 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 the CPU12. Some opcodes that are on other pages of the M68HC11 opcode map have been moved to page 1 of the CPU12 map. CPU12 object code for each of these instructions is one byte smaller than object code for the equivalent M68HC11 instruction. Table 2 shows these instructions.

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 8-Kbyte 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.

The relative size of M68HC11 and CPU12 code has also been tested by rewriting several smaller assembly programs from scratch. In these cases, the CPU12 code is typically about $30 \%$ smaller. These savings are mostly due to improved indexed addressing.

It is useful to compare the relative sizes of C programs. A C program compiled for the CPU12 is about $30 \%$ smaller than the same program compiled for the M68HC11. The difference is largely attributable to better indexing.

Table 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} & \text { PSHY } \\ & \text { PULY } \end{aligned}$ | Were on page 2, now are on page 1. |
| $\begin{aligned} & \text { LDY } \\ & \text { STY } \\ & \text { CPY } \end{aligned}$ | Were on page 2, now are on page 1. |
|  | 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. |

## 3 PROGRAMMER'S MODEL AND STACKING

The CPU12 programming model ( Figure $\mathbf{1}$ ) is identical to that of the M 68 HC 11.


Figure 1 CPU12 Programming Model

Both the M68HC11 and the CPU12 stack nine bytes of system resources when an interrupt occurs. The stacking order is identical. However, since this is an odd number of bytes, there is no practical way to assure that the CPU12 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 16-bit 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.

## 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 8 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 $\mathrm{M} 68 \mathrm{HC11}$ instruction set. The larger ALU of the CPU12 (it can perform some 20-bit operations) is used to calculate 16bit pointers and to speed up math operations.

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 MC68HC11 can stretch clock cycles to accommodate slow peripherals.

## 5 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 advance 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 in16-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.

## 6 STACK FUNCTION

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 does allow 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 $\mathrm{SP}=\$ 01 \mathrm{FO}$ when execution begins, the sequence of operations is: $\mathrm{SP}=\mathrm{SP}+1$; load X from \$01F1:01F2; SP=SP+1; and the SP ends up at \$01F2. With the last-used CPU12 stack, if the SP=\$01F0 when execution begins, the sequence is: load X from $\$ 01 \mathrm{F0} 001 \mathrm{~F} 1 ; \mathrm{SP}=\mathrm{SP}+2$; and the SP again ends up at $\$ 01 \mathrm{~F} 2$. 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, so that the the X index points to the last stack location used. The TXS instruction decrements the SP by one during the transfer for the same reason. CPU12 TSX and TXS instructions are ordinary transfers - the CPU12 stack requires no adjustment.

For ordinary uses of the stack, such as pushes, pulls, and manipulations involving TSX and TXS, the M68HC11 and CPU12 stacks appear identical. However, there is one very subtle difference.

The LDS \#\$xxxx instruction is normally used to initialize the stack pointer. In the M68HC11, the address specified in the LDS instruction is the first stack location used. In the CPU12, the first stack location used is one address lower than the address specified in the LDS instruction. Since the stack builds downward, M68HC11 programs re-assembled for the CPU12 operate normally, but stacked values are located 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, the programmer must change either the initial LDS \#\$xxxx, or the absolute extended address used to read the stack.

## 7 IMPROVED INDEXING

The CPU12 has significantly improved indexed addressing capability, yet retains compatibility with the M 68 HC 11 . 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 M68HC11 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 16bit 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 M68HC11. For offsets of +0 to +15 from the $Y$ index register, the object code is one byte smaller than it was for the M68HC11.

### 7.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 M6HC11 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-Kbyte 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 16 -bit constant offset mode, the offset is supplied in two extension bytes after the opcode and postbyte.

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

| HC11 |  |  | HC12 |
| :--- | :--- | :--- | :---: |
| 18 A6 00 | LDAA 0,Y | A6 71 | LDAA 2,Y+ |
| 18 | 08 | INY |  |
| 18 | 08 | INY |  |

The M68HC11 object code requires seven bytes, while the CPU12 requires only two bytes to accomplish the same functions. Three bytes of $\mathrm{M} 68 \mathrm{HC11}$ 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 M 68 HC 11 INY instructions, while the $Z$ bit in the CPU12 would be determined by the value loaded into $A$.

### 7.3 Accumulator Offset Indexing

This indexed addressing variation allows use of either an 8 -bit accumulator (A or B), or of the 16 -bit D accumulator as an offset for indexed addressing. This supports program-generated offsets, which are more difficult to achieve in the M68HC11. The following code compares M68HC11 and CPU12 operation.

| HC11 |  |  |  | HC12 |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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 |  |  | 0, X[4] | 0431 FB |  | DBNE | B, LOOP [3] |
| 5A |  | DECB | [2] |  |  |  |  |
| 26 F7 |  | 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 loop execution time from 15 cycles to 6 cycles. This reduction, combined with the 8 MHz bus speed of the M 68 HC 12 family, can have significant effects.

### 7.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 $\mathrm{X}, \mathrm{Y}, \mathrm{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.

## 8 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 M 68 HC 16 and M 68300 families of modular microcontrollers. M 68 HC 12 devices have a base bus speed of 8 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.

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

### 8.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 3 compares the speed of CPU12 and M68HC11 math instructions. The CPU12 require much fewer cycles to perform an operation, and the cycle time is half that of the M68HC11.

Table 3 Comparison of Math Instruction Speeds

| Instruction Mnemonic | Math Operation | M68HC11 1 cycle = 250 ns | M68HC11 w/co-processor 1 cycle = 250 ns | $\begin{gathered} \text { CPU12 } \\ 1 \text { cycle }=125 \mathrm{~ns} \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: |
| MUL | $8 \times 8=16$ <br> (signed) | 10 cycles | - | 3 cycles |
| EMUL | $16 \times 16=32$ <br> (unsigned) | - | 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 | $16 \times 16 \Rightarrow 32$ <br> (signed MAC) | - | 20 cycles per iteration | 12 cycles per iteration |

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.

### 8.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 M68HC11, 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 M 68 HC 11 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 M 68 HC 11 instructions into a single operation.

## 9 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. The following paragraphs discuss the most significant of these enhancements. For detailed information, please refer to the CPU12 Reference Manual, Motorola Publication Number CPU12RM/AD

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

### 9.2 Universal Transfer and Exchange

The M68HC11 has only six 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 signextend 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 smaller (object code) than saving data to memory with pushes or stores.

### 9.3 Loop Construct

The CPU12 instruction set includes a new family of six loop primitive instructions thatdecrement, 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.

### 9.4 Long Branches

All of the branch instructions from the M68HC11 are also available with 16 -bit offsets which allows them to reach any location in the 64 K address space.

### 9.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 | \#SFF | ; start with largest 8-bit number in $A$ |
| MINA | $1, X+$ | ;A=MIN(A, IN1) |
| MINA | $1, X+$ | ;A=MIN(A,IN2) |
| MINA | $1, X+$ | ;A=MIN(A,IN3) |
| MINA | $1, X+$ | ;A=MIN $(A, I N 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 $\$ 7 F$. 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.

### 9.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 M68HC11 required about 250 bytes and executed in about 750 milliseconds. The CPU12 kernel uses about 50 bytes and executes in about 50 microseconds.

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

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

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

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

### 9.11 Support for Memory Expansion

Bank switching is a common method of expanding memory, but there are some known difficulties associated with it. 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 expands the address space beyond the standard 64 Kbytes, but 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 bank-switching 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 $\mathbf{M} 68 \mathrm{HC} 12$ 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-Kbyte address space, thus providing for portable code.

## 10 INSTRUCTION SET REFERENCE

Table 4 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.

Table 4 Instruction Set Summary

| Source Form | Operation | Addr. <br> Mode | Machine Coding (hex) | ~1 | S | X | H | I | 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 | $(\mathrm{B})+(\mathrm{X}) \Rightarrow \mathrm{X}$ <br> Translates to LEAX B, X | IDX | 1A E5 | 2 | - | - | - | - | - | - | - | - |
| ABY | $\begin{aligned} & (\mathrm{B})+(\mathrm{Y}) \Rightarrow \mathrm{Y} \\ & \text { Translates to LEAY B,Y } \end{aligned}$ | 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 \\ & 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 | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 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} & 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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> $A B \times b$ <br> $A B \times b$ ff <br> $A B \times b$ ee ff <br> $A B \times b$ <br> $A B \times b$ ee ff | $\begin{aligned} & 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \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 ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 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$ |
| ANDA opr | $(A) \cdot(M) \Rightarrow A$ <br> Logical And A with Memory | $\begin{gathered} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \hline \text { IDX2] } \\ \hline \end{gathered}$ | 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} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \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} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| ANDCC opr | $(C C R) \bullet(M) \Rightarrow C C R$ <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} \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 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ASLD | Arithmetic Shift Left Double | INH | 59 | 1 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| ASR opr <br> ASRA <br> 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 C $=0$ ) | REL | 24 rr | 3/1 | - | - | - | - | - | - | - | - |
| BCLR opr, msk | $(\mathrm{M}) \cdot(\overline{\mathrm{mm}}) \Rightarrow \mathrm{M}$ <br> Clear Bit(s) in Memory | $\begin{aligned} & \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 $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ ) (signed) | REL | 2E rr | 3/1 | - | - | - | - | - | - | - | - |
| BHI rel | Branch if Higher (if $\mathrm{C}+\mathrm{Z}=0$ ) (unsigned) | REL | 22 rr | 3/1 | - | - | - | - | - | - | - | - |
| 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 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \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 \\ & 4 \\ & 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} & 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| BLE rel | Branch if Less Than or Equal (if $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ ) (signed) | REL | 2F rr | 3/1 | - | - | - | - | - | - | - | - |
| BLO rel | Branch if Lower (if $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 | 2A rr | 3/1 | - | - | - | - | - | - | - | - |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| BRA rel | Branch Always (if $1=1$ ) | REL | 20 rr | 3 | - | - | - | - | - | - | - | - |
| BRCLR opr, msk, rel | Branch if $(\mathrm{M}) \cdot(\mathrm{mm})=0$ (if All Selected Bit(s) Clear) | DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 | 4F dd mm rr 1 F hh II mm rr OF xb mm rr OF xb ff mm rr OF xb ee ff mm rr | $\begin{aligned} & 4 \\ & 5 \\ & 4 \\ & 6 \\ & 8 \end{aligned}$ | - | - | - | - | - | - | - | - |
| BRN rel | Branch Never (if $1=0$ ) | REL | 21 rr | 1 | - | - | - | - | - | - | - | - |
| BRSET opr, msk, rel | $\begin{aligned} & \text { Branch if }(\overline{\mathrm{M}}) \bullet(\mathrm{mm})=0 \\ & \text { (if All Selected Bit(s) Set) } \end{aligned}$ | $\begin{aligned} & \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} & 4 \\ & 5 \\ & 4 \\ & 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 } \end{aligned}$ | 4C dd mm 1C hh II mm OC xb mm OC xb ff mm OC xb ee ff mm | $\begin{aligned} & 4 \\ & 4 \\ & 4 \\ & 4 \\ & 4 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| BSR rel | $\begin{aligned} & (S P)-2 \Rightarrow S P ; \\ & R_{H}: N_{H} N_{\mathrm{L}} \Rightarrow M_{(S P)}: M_{(S P+1)} \\ & \text { Subroutine address } \Rightarrow P C \\ & \text { Branch to Subroutine } \end{aligned}$ | REL | 07 rr | 4 | - | - | - | - | - | - | - | - |
| BVC rel | Branch if Overflow Bit Clear (if V = 0) | REL | 28 rr | 3/1 | - | - | - | - | - | - | - | - |
| BVS rel | Branch if Overflow Bit Set (if $\mathrm{V}=1$ ) | REL | 29 rr | 3/1 | - | - | - | - | - | - | - | - |
| CALL opr, page | $\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})-1 \Rightarrow \mathrm{SP} ; \\ & (\mathrm{PPG}) \Rightarrow \mathrm{M}_{(\mathrm{SP})} ; \\ & \mathrm{pg} \Rightarrow \mathrm{PPAGE} \text { register; } \\ & \text { Program address } \Rightarrow \mathrm{PC} \\ & \\ & \text { Call Subroutine in extended memory } \\ & \text { (Program may be located on another } \\ & \text { expansion memory page.) } \\ & \hline \end{aligned}$ | $\begin{aligned} & \text { EXT } \\ & \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \end{aligned}$ | 4A hh II pg 4B xb pg 4B xb ff pg 4B xb ee ff pg | $\begin{aligned} & 8 \\ & 8 \\ & 8 \\ & 9 \end{aligned}$ | - | - | - | - | - | - | - | - |
| $\begin{aligned} & \text { CALL }[\mathrm{D}, r] \\ & \mathrm{CALL}[o p r, r] \end{aligned}$ | 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} {[\mathrm{D}, \mathrm{IDX}]} \\ {[\text { IDX2] }} \end{gathered}$ | $4 B \times b$ $4 B \times b$ ee ff | $\begin{aligned} & 10 \\ & 10 \end{aligned}$ | - | - | - | - | - | - | - | - |
| CBA | (A) - (B) <br> Compare 8-Bit Accumulators | INH | 1817 | 2 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CLC | $\begin{aligned} & 0 \Rightarrow \text { C } \\ & \text { Translates to ANDCC \#\$FE } \end{aligned}$ | 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 | - | - | - | - |
| $\begin{gathered} \text { CLR opr } \\ \\ \\ \\ \text { CLRA } \\ \text { CLRB } \end{gathered}$ | $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 | EXT IDX IDX1 IDX2 [D,IDX] [IDX2] INH INH | $79 \mathrm{hh} I I$ 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{aligned} & 0 \Rightarrow \mathrm{~V} \\ & \text { Translates to ANDCC \#\$FD } \end{aligned}$ | IMM | 10 FD | 1 | - | - | - | - | - | - | 0 | - |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| CMPA opr | $(\mathrm{A})-(\mathrm{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 | (B) - (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} & 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| 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$ | $\begin{gathered} \hline \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \text { INH } \\ \text { INH } \end{gathered}$ | 71 hh II <br> 61 xb <br> 61 xb ff <br> 61 xb ee ff <br> 61 xb <br> 61 xb ee ff <br> 41 <br> 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) | $\begin{gathered} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \hline \text { IDX2] } \\ \hline \end{gathered}$ | 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> $A C x b$ <br> $A C x b$ ee ff | $\begin{aligned} & 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 4 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CPS opr | $(S P)-(M: 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 \\ & \hline \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 <br> 9E dd <br> BE hh II <br> AE xb <br> AE xb ff <br> $A E x b$ ee ff <br> AE xb <br> $A E x b$ ee ff | $\begin{aligned} & 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \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> AD 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$ |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DAA | Adjust Sum to BCD Decimal Adjust Accumulator A | INH | 1807 | 3 | - | - | - | - | $\Delta$ | $\Delta$ | ? | $\Delta$ |
| DBEQ cntr, rel | (cntr) $-1 \Rightarrow \mathrm{cntr}$ if ( $\mathrm{c} n \mathrm{tr}$ ) $=0$, then Branch else Continue to next instruction <br> Decrement Counter and Branch if $=0$ (cntr = A, B, D, X, Y, or SP) | $\begin{gathered} \hline \text { REL } \\ \text { (9-bit) } \end{gathered}$ | 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} \hline \text { REL } \\ \text { (9-bit) } \end{gathered}$ | 04 lb rr | 3 | - | - | - | - | - | - | - | - |
| DEC opr | $(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} \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} & 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 | $\begin{aligned} & (X)-\$ 0001 \Rightarrow X \\ & \text { Decrement Index Register } X \end{aligned}$ | INH | 09 | 1 | - | - | - | - | - | $\Delta$ | - | - |
| DEY | $(Y)-\$ 0001 \Rightarrow 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 } \\ & \text { Multiply and Accumulate (signed) } \end{aligned}$ | Special | 1812 hh II | 13 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMAXD opr | $\operatorname{MAX}((D),(M: M+1)) \Rightarrow D$ 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 A xb 18 1A xb ff 181 A xb ee ff 18 1A xb 181 A xb ee ff | $\begin{aligned} & 4 \\ & 4 \\ & 5 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMAXM opr | $\operatorname{MAX}((D),(M: M+1)) \Rightarrow M: 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} \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | 181 Ex 18 1E xb ff 181 Exb ee ff 181 Ex 181 Exb ee ff | $\begin{aligned} & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMIND opr | $\operatorname{MIN}((D),(M: M+1)) \Rightarrow 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} \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \hline \end{gathered}$ | $\begin{aligned} & 181 \mathrm{~B} \times \mathrm{b} \\ & 181 \mathrm{~B} \times \mathrm{ff} \\ & 181 \mathrm{Bb} \text { ee ff } \\ & 18 \text { 1B xb } \\ & 18 \text { 1B xb ee ff } \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \\ & 5 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| EMINM opr | $\operatorname{MIN}((D),(M: M+1)) \Rightarrow M: M+1$ 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 F \times b$ $181 F \times b$ ff $181 F \times b$ ee ff $181 F \times b$ $181 F \times b$ ee ff | $\begin{aligned} & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMUL | $\begin{array}{\|l\|} \hline(\mathrm{D}) \times(\mathrm{Y}) \Rightarrow \mathrm{Y}: \mathrm{D} \\ 16 \times 16 \text { Bit Multiply (unsigned) } \\ \hline \end{array}$ | 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 } \text { (signed) } \end{aligned}$ | INH | 1813 | 3 | - | - | - | - | $\Delta$ | $\Delta$ | - | $\Delta$ |
| 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} & 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| EORB opr | (B) $\oplus(M) \Rightarrow B$ <br> Exclusive-OR B with Memory | $\begin{gathered} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \end{gathered}$ | 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} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \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 (M: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 | (r1) $\Leftrightarrow$ (r2) (if r1 and r2 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 | $\begin{aligned} & \text { (cntr) }+1 \Rightarrow \text { cntr } \\ & \text { If }(\text { cntr) }=0 \text {, then Branch } \\ & \text { else Continue to next instruction } \\ & \\ & \text { Increment Counter and Branch if = } 0 \\ & \text { (cntr = A, B, D, X, Y, or SP) } \end{aligned}$ | $\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 } \\ \text { (9-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$ |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| IDIVS | $\begin{array}{\|l\|} \hline(\mathrm{D}) \div(\mathrm{X}) \Rightarrow \mathrm{X} ; \mathrm{r} \Rightarrow \mathrm{D} \\ 16 \times 16 \text { Bit Integer Divide (signed) } \\ \hline \end{array}$ | INH | 1815 | 12 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| 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} \end{aligned} \quad \text { Increment Acc. A } \quad \text { Increment Acc. B }$ | $\begin{gathered} \hline \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \text { INH } \\ \text { INH } \end{gathered}$ | 72 hh II 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 \\ & 1 \\ & 1 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | - |
| INS | $(S P)+\$ 0001 \Rightarrow S P$ <br> Translates to LEAS 1,SP | IDX | 1B 81 | 2 | - | - | - | - | - | - | - | - |
| INX | $(X)+\$ 0001 \Rightarrow X$ <br> Increment Index Register $X$ | INH | 08 | 1 | - | - | - | - | - | $\Delta$ | - | - |
| INY | $(Y)+\$ 0001 \Rightarrow Y$ <br> Increment Index Register $Y$ | INH | 02 | 1 | - | - | - | - | - | $\Delta$ | - | - |
| JMP opr | Subroutine address $\Rightarrow P C$ Jump | $\begin{gathered} \hline \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \hline \end{gathered}$ | 06 hh II <br> 05 xb <br> 05 xb ff <br> 05 xb ee ff <br> 05 xb <br> 05 xb ee ff | $3$ | - | - | - | - | - | - | - | - |
| 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}$ | $\begin{gathered} \hline \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \end{gathered}$ | 17 dd <br> 16 hh II <br> 15 xb <br> 15 xb ff <br> 15 xb ee ff <br> 15 xb <br> 15 xb ee ff | $\begin{aligned} & \hline 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 $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 $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ ) (signed) | REL | 18 2E qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBHI rel | Long Branch if Higher (if $\mathrm{C}+\mathrm{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 $\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ ) (signed) | REL | 18 2F qq 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 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LBRN rel | Long Branch Never (if $1=0$ ) | REL | 1821 qq rr | 3 | - | - | - | - | - | - | - | - |
| LBVC rel | Long Branch if Overflow Bit Clear (if V=0) | REL | 1828 qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LBVS rel | Long Branch if Overflow Bit Set (if $\mathrm{V}=1$ ) | REL | 1829 qq rr | 4/3 | - | - | - | - | - | - | - | - |
| LDAA opr | $(M) \Rightarrow A$ <br> Load Accumulator A | $\begin{gathered} \hline \text { IMM } \\ \text { DIR } \\ \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | 86 ii <br> 96 dd <br> B6 hh II <br> A6 xb <br> A6 xb ff <br> A6 xb eeff <br> A6 xb <br> A6 xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| LDAB opr | $(M) \Rightarrow B$ <br> Load Accumulator B | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 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) | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 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 DIR EXT IDX IDX1 IDX2 [D,IDX] [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 | $(\mathrm{M}: \mathrm{M}+1) \Rightarrow \mathrm{X}$ <br> Load Index Register X | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | CE jj kk 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} & 2 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \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} & 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{gathered} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \hline \end{gathered}$ | $\begin{aligned} & 1 \mathrm{~B} \times \mathrm{b} \\ & 1 \mathrm{~B} \times \mathrm{ff} \\ & 1 \mathrm{~B} \times \mathrm{bee} \mathrm{ff} \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & \hline \end{aligned}$ | - | - | - | - | - | - | - | - |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| LEAX opr | Effective Address $\Rightarrow \mathrm{X}$ Load Effective Address into $X$ | $\begin{aligned} & \hline \text { IDX } \\ & \text { IDX1 } \\ & \text { IDX2 } \\ & \hline \end{aligned}$ | 1A xb <br> 1A xb ff <br> $1 \mathrm{~A} x \mathrm{~b}$ ee ff | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & \hline \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}{\|c} \hline \text { LSL opr } \\ \\ \\ \\ \text { LSLA } \\ \text { LSLB } \end{array}$ | Logical Shift Left same function as ASL <br> Logical Shift Accumulator A to Left Logical Shift Accumulator B to Left | $\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$ |
| LSLD | Logical Shift Left D Accumulator same function as ASLD | INH | 59 | 1 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
|  | Logical Shift Right <br> Logical Shift Accumulator A to Right Logical Shift Accumulator B to Right | $\begin{gathered} \hline \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \text { INH } \\ \text { INH } \end{gathered}$ | 74 hh II 64 xb 64 xb ff 64 xb ee ff 64 xb 64 xb ee ff 44 54 | $\begin{aligned} & \hline 4 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 6 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | - | - | - | - | 0 | $\Delta$ | $\Delta$ | $\Delta$ |
| LSRD | Logical Shift Right D Accumulator | INH | 49 | 1 | - | - | - | - | 0 | $\Delta$ | $\Delta$ | $\Delta$ |
| MAXA | $\operatorname{MAX}((\mathrm{A}),(\mathrm{M})) \Rightarrow \mathrm{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)). | $\begin{gathered} \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | $\begin{array}{\|l} 1818 \mathrm{xb} \\ 1818 \mathrm{xb} \mathrm{ff} \\ 1818 \mathrm{xb} \text { ee ff } \\ 1818 \mathrm{xb} \\ 1818 \mathrm{xb} \text { ee ff } \\ \hline \end{array}$ | $\begin{aligned} & 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} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ {[\text { IDX2] }} \\ \hline \end{gathered}$ | $\begin{aligned} & 181 \mathrm{C} \times \mathrm{b} \\ & 181 \mathrm{Cb} \text { ff } \\ & 181 \mathrm{Cb} \text { ee ff } \\ & 181 \mathrm{Cbb} \\ & 181 \mathrm{Cb} \text { ee ff } \end{aligned}$ | $\begin{aligned} & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| MEM | $\mu$ (grade) $\Rightarrow M_{(Y)}$; <br> $(X)+4 \Rightarrow X ;(Y)+1 \Rightarrow Y ; A$ unchanged $\begin{aligned} & \text { if }(\mathrm{A})<\text { P1 or }(\mathrm{A})>\text { P2 then } \mu=0 \text {, else } \\ & \mu=\operatorname{MIN}[((\mathrm{A})-\mathrm{P} 1) \times \text { S1, }(\mathrm{P} 2-(\mathrm{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 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MINA | $\operatorname{MIN}((\mathrm{A}),(\mathrm{M})) \Rightarrow \mathrm{A}$ <br> MIN 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} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \end{gathered}$ | 1819 xb 1819 xb ff 1819 xb ee ff 1819 xb 1819 xb ee ff | $\begin{aligned} & 4 \\ & 4 \\ & 4 \\ & 7 \\ & 7 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| MINM | $\operatorname{MIN}((A),(M)) \Rightarrow M$ <br> MIN 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} \hline \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \end{gathered}$ | $\begin{aligned} & 181 \mathrm{D} \mathrm{xb} \\ & 18 \text { 1D xb ff } \\ & 18 \text { 1D xb ee ff } \\ & 18 \text { 1D xb } \\ & 18 \text { 1D xb ee ff } \end{aligned}$ | $\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 { IDX-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} & 4 \\ & 4 \\ & 4 \\ & 6 \\ & 5 \\ & 5 \\ & 5 \end{aligned}$ | - | - | - | - | - | - | - | - |
| MOVW opr1, opr2 | $\left(M: M+1_{1}\right) \Rightarrow M: 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 { ID-IDX } \end{aligned}$ | $1803 \mathrm{jj} \mathrm{kk} \mathrm{hh} I$ 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> 2's Complement Negate $0-(A) \Rightarrow A \text { equivalent to }(\bar{A})+1 \Rightarrow B$ <br> Negate Accumulator A <br> $0-(B) \Rightarrow B$ equivalent to $(\bar{B})+1 \Rightarrow B$ <br> 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 <br> 60 xb <br> $60 \mathrm{xb} f f$ <br> 60 xb ee ff <br> 60 xb <br> 60 xb ee ff <br> 40 <br> 50 | $\begin{aligned} & \hline 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] | 8A ii <br> 9A dd <br> BA hh II <br> AA xb <br> $A A x b$ ff <br> $A A x b$ ee ff <br> $A A x b$ <br> $A A$ xb ee ff | $\begin{aligned} & 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| ORAB opr | $(B)+(M) \Rightarrow B$ <br> Logical OR B with Memory | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 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 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| ORCC opr | $\begin{aligned} & (C C R)+M \Rightarrow C C R \\ & \text { Logical OR CCR with Memory } \end{aligned}$ | IMM | 14 ii | 1 | $\Uparrow$ | - | $\Uparrow$ | $\Uparrow$ | $\Uparrow$ | $\Uparrow$ | $\Uparrow$ | $\Uparrow$ |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | 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 | $(\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> 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 | $\left(\mathrm{M}_{(\mathrm{SP})}\right) \Rightarrow \mathrm{A} ;(\mathrm{SP})+1 \Rightarrow \mathrm{SP}$ <br> Pull Accumulator A from Stack | 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 ${ }^{2}$ | 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 | 3 <br> per <br> rule <br> byte | - | - | - | - | - | - | $\Delta$ | - |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | 1 | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| REVW ${ }^{2}$ | 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 |  | - | - | ? | - | ? | ? | $\Delta$ | ! |
| ROL opr <br> ROLA <br> ROLB | Rotate Memory Left through Carry <br> Rotate A Left through Carry <br> Rotate B Left through Carry | $\begin{gathered} \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \text { INH } \\ \text { INH } \end{gathered}$ | 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 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ROR opr <br> RORA <br> RORB | Rotate Memory Right through Carry <br> Rotate A Right through Carry <br> Rotate B Right through Carry | $\begin{gathered} \hline \text { EXT } \\ \text { IDX } \\ \text { IDX1 } \\ \text { IDX2 } \\ \text { [D,IDX] } \\ \text { [IDX2] } \\ \text { INH } \\ \text { INH } \\ \hline \end{gathered}$ | 76 hh II <br> 66 xb <br> 66 xb ff <br> 66 xb ee ff <br> 66 xb <br> 66 xb ee ff <br> 46 <br> 56 | $\begin{aligned} & \hline 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}: \mathrm{A} ;(\mathrm{SP})+2 \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})+4 \Rightarrow \mathrm{SP} \\ & \left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{PC}_{H}: P C_{\mathrm{L}} ;(\mathrm{SP})-2 \Rightarrow \mathrm{SP} \\ & \left(\mathrm{M}_{(\mathrm{SP})}: \mathrm{M}_{(\mathrm{SP}+1)}\right) \Rightarrow \mathrm{Y}_{\mathrm{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$ |
| SBCA opr | $(A)-(M)-C \Rightarrow A$ <br> Subtract with Borrow from A | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 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 \\ & 3 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| SBCB opr | $(B)-(M)-C \Rightarrow B$ <br> Subtract with Borrow from B | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | 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 \\ & 3 \\ & 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:(r 1) \Rightarrow 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 |  <br> DIR <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | 5 A 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 \mathrm{xb}$ 6 Bb ff $6 \mathrm{~B} \times \mathrm{b}$ ee ff $6 \mathrm{~B} \times \mathrm{b}$ $6 \mathrm{~B} \times \mathrm{b}$ ee ff | 2 2 3 2 3 3 5 5 | - | - | - | - | $\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 <br> 7C hh II <br> 6C xb <br> 6 C xb ff <br> 6C xb ee ff <br> 6C xb <br> 6C xb ee ff | $\begin{aligned} & 2 \\ & 3 \\ & 2 \\ & 3 \\ & 3 \\ & 5 \\ & 5 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| STOP ${ }^{2}$ | $\begin{aligned} & (S P)-2 \Rightarrow S P ; \\ & R T N_{\mathrm{H}}: R T N_{\mathrm{L}} \Rightarrow \mathrm{M}_{(\mathrm{SPP}}: \mathrm{M}_{(\mathrm{SP}+1)} ; \\ & \left.(\mathrm{SP})-2 \Rightarrow S P ; \mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}_{(\mathrm{SPP}}: \mathrm{M}_{(\mathrm{SP}+1)} ; \\ & \left.(\mathrm{SP})-2 \Rightarrow \mathrm{SP} ; \mathrm{X}_{\mathrm{H}}: \mathrm{XL}_{\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)} ; \\ & \text { (SP) - } 1 \Rightarrow \mathrm{SP} ;(\mathrm{CCR}) \Rightarrow \mathrm{M}_{(\mathrm{SP})} ; \\ & \text { STOP All Clocks } \end{aligned}$ <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}$ | - | - | - | - | - | - | - | - |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| STS opr | $\left(S P_{H}: S P_{L}\right) \Rightarrow M: 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> 6 F xb ff <br> 6F xb ee ff <br> 6F xb <br> 6F xb ee ff | $\begin{aligned} & 2 \\ & 3 \\ & 2 \\ & 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 <br> EXT <br> IDX <br> IDX1 <br> IDX2 <br> [D,IDX] <br> [IDX2] | 5E dd <br> 7E hh II <br> 6E xb <br> 6E xb ff <br> $6 E \times b$ ee ff <br> 6E xb <br> 6E xb ee ff | $\begin{aligned} & 2 \\ & 3 \\ & 2 \\ & 3 \\ & 3 \\ & 3 \\ & 5 \\ & 5 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| STY opr | $\left(\mathrm{Y}_{\mathrm{H}}: \mathrm{Y}_{\mathrm{L}}\right) \Rightarrow \mathrm{M}: \mathrm{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> 6 D xb ff <br> 6D xb ee ff <br> 6D xb <br> 6D xb ee ff | $\begin{aligned} & 2 \\ & 3 \\ & 2 \\ & 3 \\ & 3 \\ & 5 \\ & 5 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |
| SUBA opr | $(A)-(M) \Rightarrow 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 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SUBB opr | $(B)-(M) \Rightarrow B$ <br> Subtract Memory from Accumulator B | IMM DIR EXT IDX IDX1 IDX2 [D,IDX] [IDX2] | CO ii <br> D0 dd <br> FO hh II <br> E0 xb <br> E0 xb ff <br> E0 xb eeff <br> E0 xb <br> E0 xb ee ff | $\begin{aligned} & \hline 1 \\ & 3 \\ & 3 \\ & 3 \\ & 3 \\ & 4 \\ & 4 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| 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 \\ & 4 \\ & 6 \\ & 6 \end{aligned}$ | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SWI | $\begin{aligned} & (\mathrm{SP})-2 \Rightarrow \mathrm{SP} ; \\ & \mathrm{RTN}_{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})} \\ & 1 \Rightarrow \mathrm{I} ;(\mathrm{SWI} \text { Vector) } \Rightarrow \mathrm{PC} \end{aligned}$ <br> Software Interrupt | INH | 3F | 9 | - | - | - | 1 | - | - | - | - |
| TAB | $\begin{aligned} & (\mathrm{A}) \Rightarrow \mathrm{B} \\ & \text { Transfer } \mathrm{A} \text { to } \mathrm{B} \end{aligned}$ | INH | 18 0E | 2 | - | - | - | - | $\Delta$ | $\Delta$ | 0 | - |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 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 | 18 0F | 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} \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 ( $\mathrm{cntr}=\mathrm{A}, \mathrm{B}, \mathrm{D}, \mathrm{X}, \mathrm{Y}$, or SP) | $\begin{gathered} \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 | $\begin{array}{\|l} \hline- \\ \text { or } \\ \Delta \end{array}$ | $\Downarrow$ | $\Delta$ | - | - | $-$ | $\Delta$ | - $\Delta$ |
| TPA | $(C C R) \Rightarrow A$ <br> Translates to TFR CCR , A | INH | B7 20 | 1 | - | - | - | - | - | - | - | - |
| TRAP | Unimplemented opcode trap | INH | $\begin{aligned} & 18 \mathrm{tn} \\ & \mathrm{tn}=\$ 30-\$ 39 \\ & \quad \text { or } \\ & \quad \$ 40-\$ \mathrm{FF} \end{aligned}$ | 10 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 |
| $\begin{array}{\|c} \text { TST opr } \\ \\ \\ \\ \text { TSTA } \\ \text { TSTB } \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 | $\begin{aligned} & (\mathrm{X}) \Rightarrow \mathrm{SP} \\ & \text { Translates to TFR X,SP } \end{aligned}$ | INH | B7 57 | 1 | - | - | - | - | - | - | - | - |
| TYS | $\begin{aligned} & (\mathrm{Y}) \Rightarrow \mathrm{SP} \\ & \text { Translates to TFR } \mathrm{Y}, \mathrm{SP} \end{aligned}$ | INH | B7 67 | 1 | - | - | - | - | - | - | - | - |

Table 4 Instruction Set Summary (Continued)

| Source Form | Operation | Addr. Mode | Machine Coding (hex) | ~1 | S | X | H | I | N | Z | V | C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{WAI}^{2}$ | $\begin{aligned} & (\mathrm{SP})-2 \Rightarrow \mathrm{SP} ; \\ & \mathrm{RTN}_{\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}: 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 | 8 (in) + 5 (int) | or <br> or | - - 1 | - - - | 1 | - | - - - | - | - |
| WAV ${ }^{2}$ | $\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, 6 extra bytes of stack used for intermediate values | Special | 183 C | $\begin{array}{\|c\|} \hline 8 \\ \text { per } \\ \text { lable } \end{array}$ | - | - | ? | - | ? | $\Delta$ | ? | $?$ |
| $\text { wavr }^{2}$ <br> pseudoinstruction | see WAV <br> Resume executing an interrupted WAV instruction (recover intermediate results from stack rather than initializing them to 0 ) | Special | 3 C |  | - | - | ? | - | ? | $\Delta$ | ? | ? |
| 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:

1. Each cycle $(\sim)$ is typically 125 ns for an 8 MHz bus ( 16 MHz oscillator).
2. Refer to CPU12 Reference Manual for additional information.

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 can and do vary in different applications. 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. (4) motorola is a registered trademark of Motorola, Inc. Motorola, Inc. is an Equal Opportunity/Affirmative Action Employer.

[^0]
[^0]:    TO OBTAIN ADDITIONAL PRODUCT INFORMATION:
    USA/EUROPE: Motorola Literature Distribution;
    P.O. Box 20912; Phoenix, Arizona 85036. 1-800-441-2447

    JAPAN:
    Nippon Motorola Ltd.; Tatsumi-SPD-JLDC, Toshikatsu Otsuki,
    6F Seibu-Butsuryu-Center, 3-14-2 Tatsumi Koto-Ku, Tokyo 135, Japan. 03-3521-8315
    HONG KONG: Motorola Semiconductors H.K. Ltd.; 8B Tai Ping Industrial Park,
    MFAX:
    INTERNET:
    51 Ting Kok Road, Tai Po, N.T., Hong Kong. 852-26629298
    RMFAX0@email.sps.mot.com - TOUCHTONE (602) 244-6609
    http://www.mot.com

