

## Addressing Modes

Addressing modes determine how the CPU accesses memory locations to be operated upon. The STAR12 CPU includes all of the addressing modes of the M68HC11 CPU as well as several new forms of indexed addressing. [Table 3](#) is a summary of the available addressing modes.

**Table 3 M68HC12 Addressing Mode Summary**

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

## Indexed Addressing Modes

The STAR12 CPU indexed modes reduce execution time and eliminate code size penalties for using the Y index register. STAR12 CPU indexed addressing uses a postbyte plus zero, one, or two extension bytes after the instruction opcode. The postbyte and extensions do the following tasks:

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

**Table 4 Summary of Indexed Operations**

| Postbyte Code (xb) | Source Code Syntax     | Comments                                                                                                                                                                                                |
|--------------------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rr0nnnnn           | ,r<br>n,r<br>-n,r      | <b>5-bit constant offset</b> n = -16 to +15<br>rr can specify X, Y, SP, or PC                                                                                                                           |
| 111rr0zs           | n,r<br>-n,r            | <b>Constant offset</b> (9- or 16-bit signed)<br>z=0 = 9-bit with sign in LSB of postbyte(s)<br>1 = 16-bit<br>if z = s = 1, 16-bit offset indexed-indirect (see below)<br>rr can specify X, Y, SP, or PC |
| 111rr011           | [n,r]                  | <b>16-bit offset indexed-indirect</b><br>rr can specify X, Y, SP, or PC                                                                                                                                 |
| rr1pnnnn           | n,-r n,+r<br>n,r- n,r+ | <b>Auto pre-decrement/increment or Auto post-decrement/increment;</b><br>p = pre-(0) or post-(1), n = -8 to -1, +1 to +8<br>rr can specify X, Y, or SP (PC not a valid choice)                          |
| 111rr1aa           | A,r<br>B,r<br>D,r      | <b>Accumulator offset</b> (unsigned 8-bit or 16-bit)<br>aa-00 = A<br>01 = B<br>10 = D (16-bit)<br>11 = see accumulator D offset indexed-indirect<br>rr can specify X, Y, SP, or PC                      |
| 111rr111           | [D,r]                  | <b>Accumulator D offset indexed-indirect</b><br>rr can specify X, Y, SP, or PC                                                                                                                          |

## Opcodes and Operands

The STAR12 CPU uses 8-bit opcodes. Each opcode identifies a particular instruction and associated addressing mode to the CPU. Several opcodes are required to provide each instruction with a range of addressing capabilities.

Only 256 opcodes would be available if the range of values were restricted to the number that can be represented by 8-bit binary numbers. To expand the number of opcodes, a second page is added to the opcode map. Opcodes on the second page are preceded by an additional byte with the value \$18.

To provide additional addressing flexibility, opcodes can also be followed by a postbyte or extension bytes. Postbytes implement certain forms of indexed addressing, transfers, exchanges, and loop primitives. Extension bytes contain additional program information such as addresses, offsets, and immediate data.

## Instruction Set Summary

The following table defines the special characters used to describe the effects of instruction execution on the status bits in the condition codes register (SXHINZVC column).

**Table 5 Condition Code Changes**

| Special Character | Description                                                                  |
|-------------------|------------------------------------------------------------------------------|
| -                 | Status bit not affected by operation.                                        |
| 0                 | Status bit cleared by operation.                                             |
| 1                 | Status bit set by operation.                                                 |
| △                 | Status bit affected by operation.                                            |
| ↓                 | Status bit may be cleared or remain set, but is not set by operation.        |
| ↑                 | Status bit may be set or remain cleared, but the final state is not defined. |
| ?                 | Status bit may be changed by operation but the final state is not defined.   |
| !                 | Status bit used for a special purpose.                                       |

| Source Form                                                                                                                                        | Operation                                       | Address Mode                                                  | Machine Coding (Hex)                                                                   | Access Detail                                             | S X H I N Z V C       |
|----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------|-----------------------|
| ABA                                                                                                                                                | Add B to A; (A)+(B)⇒A                           | INH                                                           | 18 06                                                                                  | OO                                                        | [- - Δ - Δ   Δ   Δ]   |
| ABX                                                                                                                                                | Add B to X; (X)+(B)⇒X; assembles as LEAX B,X    | IDX                                                           | 1A E5                                                                                  | Pf                                                        | [- - - - - - - - - -] |
| ABY                                                                                                                                                | Add B to Y; (Y)+(B)⇒Y; assembles as LEAY B,Y    | IDX                                                           | 19 ED                                                                                  | Pf                                                        | [- - - - - - - - - -] |
| ADCA #opr8i<br>ADCA opr8a<br>ADCA opr16a<br>ADCA oprx0_xysppc<br>ADCA oprx9,xysppc<br>ADCA oprx16,xysppc<br>ADCA [D,xysppc]<br>ADCA [opr16,xysppc] | Add with carry to A; (A)+(M)+C⇒A or (A)+imm+C⇒A | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 89 ii<br>99 dd<br>B9 hh 11<br>A9 xb<br>A9 xb ff<br>A9 xb ee ff<br>A9 xb<br>A9 xb ee ff | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf | [- - Δ - Δ   Δ   Δ]   |

| Source Form                                                                                                                                         | Operation                                                                                                                                                                                                    | Address Mode                                                  | Machine Coding (Hex)                                                                      | Access Detail                                              | S X H I N Z V C     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------|------------------------------------------------------------|---------------------|
| ADCB #opr8i<br>ADCB opr8a<br>ADCB opr16a<br>ADCB oprx0_xysppc<br>ADCB oprx9_xysppc<br>ADCB oprx16_xysppc<br>ADCB [D,xysppc]<br>ADCB [opr16,xysppc]  | Add with carry to B; (B)+(M)+C⇒B or (B)+imm+C⇒B                                                                                                                                                              | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | C9 ii<br>D9 dd<br>F9 hh 11<br>E9 xb<br>E9 xb ff<br>E9 xb ee ff<br>E9 xb<br>E9 xb ee ff    | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf  | [- - Δ - - Δ Δ Δ Δ] |
| ADDA #opr8i<br>ADDA opr8a<br>ADDA opr16a<br>ADDA oprx0_xysppc<br>ADDA oprx9_xysppc<br>ADDA oprx16_xysppc<br>ADDA [D,xysppc]<br>ADDA [opr16,xysppc]  | Add to A; (A)+(M)⇒A or (A)+imm⇒A                                                                                                                                                                             | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 8B ii<br>9B dd<br>BB hh 11<br>AB xb<br>AB xb ff<br>AB xb ee ff<br>AB xb<br>AB xb ee ff    | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf  | [- - Δ - - Δ Δ Δ Δ] |
| ADDB #opr8i<br>ADDB opr8a<br>ADDB opr16a<br>ADDB oprx0_xysppc<br>ADDB oprx9_xysppc<br>ADDB oprx16_xysppc<br>ADDB [D,xysppc]<br>ADDB [opr16,xysppc]  | Add to B; (B)+(M)⇒B or (B)+imm⇒B                                                                                                                                                                             | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | CB ii<br>DB dd<br>FB hh 11<br>EB xb<br>EB xb ff<br>EB xb ee ff<br>EB xb<br>EB xb ee ff    | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf  | [- - Δ - - Δ Δ Δ Δ] |
| ADDD #opr16i<br>ADDD opr8a<br>ADDD opr16a<br>ADDD oprx0_xysppc<br>ADDD oprx9_xysppc<br>ADDD oprx16_xysppc<br>ADDD [D,xysppc]<br>ADDD [opr16,xysppc] | Add to D; (A:B)+(M:M+1)⇒A:B or (A:B)+imm⇒A:B                                                                                                                                                                 | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | C3 jj kk<br>D3 dd<br>F3 hh 11<br>E3 xb<br>E3 xb ff<br>E3 xb ee ff<br>E3 xb<br>E3 xb ee ff | PO<br>RPf<br>RPO<br>RPf<br>RPO<br>frPP<br>fIFRPf<br>fIPRPf | [- - - - Δ Δ Δ Δ]   |
| ANDA #opr8i<br>ANDA opr8a<br>ANDA opr16a<br>ANDA oprx0_xysppc<br>ANDA oprx9_xysppc<br>ANDA oprx16_xysppc<br>ANDA [D,xysppc]<br>ANDA [opr16,xysppc]  | AND with A; (A)•(M)⇒A or (A)•imm⇒A                                                                                                                                                                           | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 84 ii<br>94 dd<br>B4 hh 11<br>A4 xb<br>A4 xb ff<br>A4 xb ee ff<br>A4 xb<br>A4 xb ee ff    | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf  | [- - - - Δ Δ 0 -]   |
| ANDB #opr8i<br>ANDB opr8a<br>ANDB opr16a<br>ANDB oprx0_xysppc<br>ANDB oprx9_xysppc<br>ANDB oprx16_xysppc<br>ANDB [D,xysppc]<br>ANDB [opr16,xysppc]  | AND with B; (B)•(M)⇒B or (B)•imm⇒B                                                                                                                                                                           | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | C4 ii<br>D4 dd<br>F4 hh 11<br>E4 xb<br>E4 xb ff<br>E4 xb ee ff<br>E4 xb<br>E4 xb ee ff    | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf  | [- - - - Δ Δ 0 -]   |
| ANDCC #opr8i                                                                                                                                        | AND with CCR; (CCR)•imm⇒CCR                                                                                                                                                                                  | IMM                                                           | 10 ii                                                                                     | P                                                          | ↓↓↓↓↓↓↓↓            |
| ASL opr16a<br>ASL oprx0_xysp<br>ASL oprx9_xysppc<br>ASL oprx16_xysppc<br>ASL [D,xysppc]<br>ASL [opr16,xysppc]<br>ASLA<br>ASLB                       | Arithmetic shift left M; same as LSL<br><br>Arithmetic shift left A; same as LSLA<br>Arithmetic shift left B; same as LSB | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]<br>INH<br>INH | 78 hh 11<br>68 xb<br>68 xb ff<br>68 xb ee ff<br>68 xb<br>68 xb ee ff<br>48<br>58          | rPwO<br>rPw<br>rPwO<br>frPwP<br>fIfrPw<br>fIPrPw<br>O<br>O | [- - - - Δ Δ Δ Δ]   |
| ASLD                                                                                                                                                | Arithmetic shift left D; same as LS LD<br>                                                                                | INH                                                           | 59                                                                                        | O                                                          | [- - - - Δ Δ Δ Δ]   |

# Central Processing Unit (CPU)

| Source Form                                                                                                                                        | Operation                                                                                                                                                             | Address Mode                                                  | Machine Coding (Hex)                                                                   | Access Detail                                              | S X H I N Z V C |
|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------|
| ASR opr16a<br>ASR oprx0_xysppc<br>ASR oprx9_xysppc<br>ASR oprx16_xysppc<br>ASR [D,xysppc]<br>ASR [opr16,xysppc]<br>ASRA<br>ASRB                    | Arithmetic shift right M<br><br>Arithmetic shift right A<br>Arithmetic shift right B | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]<br>INH<br>INH | 77 hh 11<br>67 xb<br>67 xb ff<br>67 xb ee ff<br>67 xb<br>67 xb ee ff<br>47<br>57       | rPwO<br>rPw<br>rPwO<br>frPwP<br>fIfrPw<br>fIPrPw<br>O<br>O | - - - - Δ Δ Δ Δ |
| BCC rel8                                                                                                                                           | Branch if C clear; if C=0, then (PC)+2+rel→PC; same as BHS                                                                                                            | REL                                                           | 24 rr                                                                                  | PPP (branch)<br>P (no branch)                              | - - - - - - - - |
| BCLR opr8a, msk8<br>BCLR opr16a, msk8<br>BCLR oprx0_xysppc, msk8<br>BCLR oprx9_xysppc, msk8<br>BCLR oprx16_xysppc, msk8                            | Clear bit(s) in M; (M)•(mask byte)→M                                                                                                                                  | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2                             | 4D dd mm<br>1D hh 11 mm<br>0D xb mm<br>0D xb ff mm<br>0D xb ee ff mm                   | rPwO<br>rPwP<br>rPwO<br>rPwP<br>frPwPO                     | - - - - Δ Δ 0 - |
| BCS rel8                                                                                                                                           | Branch if C set; if C=1, then (PC)+2+rel→PC; same as BLO                                                                                                              | REL                                                           | 25 rr                                                                                  | PPP (branch)<br>P (no branch)                              | - - - - - - - - |
| BEQ rel8                                                                                                                                           | Branch if equal; if Z=1, then (PC)+2+rel→PC                                                                                                                           | REL                                                           | 27 rr                                                                                  | PPP (branch)<br>P (no branch)                              | - - - - - - - - |
| BGE rel8                                                                                                                                           | Branch if $\geq 0$ , signed; if $N \oplus V = 0$ , then (PC)+2+rel→PC                                                                                                 | REL                                                           | 2C rr                                                                                  | PPP (branch)<br>P (no branch)                              | - - - - - - - - |
| BGND                                                                                                                                               | Enter background debug mode                                                                                                                                           | INH                                                           | 00                                                                                     | Vf PPPP                                                    | - - - - - - - - |
| BGT rel8                                                                                                                                           | Branch if $> 0$ , signed; if $Z   (N \oplus V) = 0$ , then (PC)+2+rel→PC                                                                                              | REL                                                           | 2E rr                                                                                  | PPP (branch)<br>P (no branch)                              | - - - - - - - - |
| BHI rel8                                                                                                                                           | Branch if higher, unsigned; if $C   Z = 0$ , then (PC)+2+rel→PC                                                                                                       | REL                                                           | 22 rr                                                                                  | PPP (branch)<br>P (no branch)                              | - - - - - - - - |
| BHS rel8                                                                                                                                           | Branch if higher or same, unsigned; if $C=0$ , then (PC)+2+rel→PC; same as BCC                                                                                        | REL                                                           | 24 rr                                                                                  | PPP (branch)<br>P (no branch)                              | - - - - - - - - |
| BITA #opr8i<br>BITA opr8a<br>BITA opr16a<br>BITA oprx0_xysppc<br>BITA oprx9_xysppc<br>BITA oprx16_xysppc<br>BITA [D,xysppc]<br>BITA [opr16,xysppc] | Bit test A; (A)•(M) or (A)•imm                                                                                                                                        | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 85 ii<br>95 dd<br>B5 hh 11<br>A5 xb<br>A5 xb ff<br>A5 xb ee ff<br>A5 xb<br>A5 xb ee ff | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf  | - - - - Δ Δ 0 - |
| BITB #opr8i<br>BITB opr8a<br>BITB opr16a<br>BITB oprx0_xysppc<br>BITB oprx9_xysppc<br>BITB oprx16_xysppc<br>BITB [D,xysppc]<br>BITB [opr16,xysppc] | Bit test B; (B)•(M) or (B)•imm                                                                                                                                        | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | C5 ii<br>D5 dd<br>F5 hh 11<br>E5 xb<br>E5 xb ff<br>E5 xb ee ff<br>E5 xb<br>E5 xb ee ff | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf  | - - - - Δ Δ 0 - |
| BLE rel8                                                                                                                                           | Branch if $\leq 0$ , signed; if $Z   (N \oplus V) = 1$ , then (PC)+2+rel→PC                                                                                           | REL                                                           | 2F rr                                                                                  | PPP (branch)<br>P (no branch)                              | - - - - - - - - |
| BLO rel8                                                                                                                                           | Branch if lower, unsigned; if $C=1$ , then (PC)+2+rel→PC; same as BCS                                                                                                 | REL                                                           | 25 rr                                                                                  | PPP (branch)<br>P (no branch)                              | - - - - - - - - |
| BLS rel8                                                                                                                                           | Branch if lower or same, unsigned; if $C   Z = 1$ , then (PC)+2+rel→PC                                                                                                | REL                                                           | 23 rr                                                                                  | PPP (branch)<br>P (no branch)                              | - - - - - - - - |
| BLT rel8                                                                                                                                           | Branch if $< 0$ , signed; if $N \oplus V = 1$ , then (PC)+2+rel→PC                                                                                                    | REL                                                           | 2D rr                                                                                  | PPP (branch)<br>P (no branch)                              | - - - - - - - - |
| BMI rel8                                                                                                                                           | Branch if minus; if $N=1$ , then (PC)+2+rel→PC                                                                                                                        | REL                                                           | 2B rr                                                                                  | PPP (branch)<br>P (no branch)                              | - - - - - - - - |
| BNE rel8                                                                                                                                           | Branch if not equal to 0; if $Z=0$ , then (PC)+2+rel→PC                                                                                                               | REL                                                           | 26 rr                                                                                  | PPP (branch)<br>P (no branch)                              | - - - - - - - - |

| Source Form                                                                                                                                                | Operation                                                                                                                                                                                                                                                                                             | Address Mode                                                  | Machine Coding (Hex)                                                                   | Access Detail                                                         | S X H I N Z V C |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------|-----------------|
| BPL rel8                                                                                                                                                   | Branch if plus; if N=0, then (PC)+2+rel $\Rightarrow$ PC                                                                                                                                                                                                                                              | REL                                                           | 2A rr                                                                                  | PPP (branch)<br>P (no branch)                                         | [- - - - - -]   |
| BRA rel8                                                                                                                                                   | Branch always                                                                                                                                                                                                                                                                                         | REL                                                           | 20 rr                                                                                  | PPP                                                                   | [- - - - - -]   |
| BRCLR opr8a, msk8, rel8<br>BRCLR opr16a, msk8, rel8<br>BRCLR oprx0_xysppc, msk8, rel8<br>BRCLR oprx9_xysppc, msk8, rel8<br>BRCLR oprx16_xysppc, msk8, rel8 | Branch if bit(s) clear; if (M) $\bullet$ (mask byte)=0, then (PC)+2+rel $\Rightarrow$ PC                                                                                                                                                                                                              | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2                             | 4F dd mm rr<br>1F hh 11 mm rr<br>0F xb mm rr<br>0F xb ff mm rr<br>0F xb ee ff mm rr    | rPPP<br>rfPPP<br>rPPP<br>rfPPP<br>PrfPPP                              | [- - - - - -]   |
| BRN rel8                                                                                                                                                   | Branch never                                                                                                                                                                                                                                                                                          | REL                                                           | 21 rr                                                                                  | P                                                                     | [- - - - - -]   |
| BRSET opr8, msk8, rel8<br>BRSET opr16a, msk8, rel8<br>BRSET oprx0_xysppc, msk8, rel8<br>BRSET oprx9_xysppc, msk8, rel8<br>BRSET oprx16_xysppc, msk8, rel8  | Branch if bit(s) set; if ( $\bar{M}$ ) $\bullet$ (mask byte)=0, then (PC)+2+rel $\Rightarrow$ PC                                                                                                                                                                                                      | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2                             | 4E dd mm rr<br>1E hh 11 mm rr<br>0E xb mm rr<br>0E xb ff mm rr<br>0E xb ee ff mm rr    | rPPP<br>rfPPP<br>rPPP<br>rfPPP<br>PrfPPP                              | [- - - - - -]   |
| BSET opr8, msk8<br>BSET opr16a, msk8<br>BSET oprx0_xysppc, msk8<br>BSET oprx9_xysppc, msk8<br>BSET oprx16_xysppc, msk8                                     | Set bit(s) in M; (M) $\mid$ (mask byte) $\Rightarrow$ M                                                                                                                                                                                                                                               | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2                             | 4C dd mm<br>1C hh 11 mm<br>0C xb mm<br>0C xb ff mm<br>0C xb ee ff mm                   | rPwO<br>rPwP<br>rPwO<br>rPwP<br>frPwPO                                | [- - - Δ Δ 0 -] |
| BSR rel8                                                                                                                                                   | Branch to subroutine; (SP)-2 $\Rightarrow$ SP;<br>RTN <sub>H</sub> :RTN <sub>L</sub> $\Rightarrow$ M <sub>SP</sub> :M <sub>SP+1</sub> ;<br>(PC)+2+rel $\Rightarrow$ PC                                                                                                                                | REL                                                           | 07 rr                                                                                  | SPPP                                                                  | [- - - - - -]   |
| BVC rel8                                                                                                                                                   | Branch if V clear; if V=0, then (PC)+2+rel $\Rightarrow$ PC                                                                                                                                                                                                                                           | REL                                                           | 28 rr                                                                                  | PPP (branch)<br>P (no branch)                                         | [- - - - - -]   |
| BVS rel8                                                                                                                                                   | Branch if V set; if V=1, then (PC)+2+rel $\Rightarrow$ PC                                                                                                                                                                                                                                             | REL                                                           | 29 rr                                                                                  | PPP (branch)<br>P (no branch)                                         | [- - - - - -]   |
| CALL opr16a, page<br>CALL oprx0_xysppc, page<br>CALL oprx9_xysppc, page<br>CALL oprx16_xysppc, page<br>CALL [D,xysppc]<br>CALL [oprx16_xysppc]             | Call subroutine in expanded memory;<br>(SP)-2 $\Rightarrow$ SP;<br>RTN <sub>H</sub> :RTN <sub>L</sub> $\Rightarrow$ M <sub>SP</sub> :M <sub>SP+1</sub> ;<br>(SP)-1 $\Rightarrow$ SP; (PPG) $\Rightarrow$ M <sub>SP</sub> ;<br>pg $\Rightarrow$ PPAGE register;<br>subroutine address $\Rightarrow$ PC | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]               | 4A hh 11 pg<br>4B xb pg<br>4B xb ff pg<br>4B xb ee ff pg<br>4B xb<br>4B xb ee ff       | gnSsPPP<br>gnSsPPP<br>gnSsPPP<br>fgnSsPPP<br>fIignSsPPP<br>fIignSsPPP | [- - - - - -]   |
| CBA                                                                                                                                                        | Compare A to B; (A)-(B)                                                                                                                                                                                                                                                                               | INH                                                           | 18 17                                                                                  | OO                                                                    | [- - - Δ Δ Δ Δ] |
| CLC                                                                                                                                                        | Clear C; assembles as ANDCC #\$FE                                                                                                                                                                                                                                                                     | IMM                                                           | 10 FE                                                                                  | P                                                                     | [- - - - - 0]   |
| CLI                                                                                                                                                        | Clear I; assembles as ANDCC #\$EF                                                                                                                                                                                                                                                                     | IMM                                                           | 10 EF                                                                                  | P                                                                     | [- - 0 - - -]   |
| CLR opr16a<br>CLR oprx0_xysppc<br>CLR oprx9_xysppc<br>CLR oprx16_xysppc<br>CLR [D,xysppc]<br>CLR [oprx16_xysppc]<br>CLRA<br>CLRB                           | Clear M; \$00 $\Rightarrow$ M<br><br>Clear A; \$00 $\Rightarrow$ A<br>Clear B; \$00 $\Rightarrow$ B                                                                                                                                                                                                   | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]<br>INH<br>INH | 79 hh 11<br>69 xb<br>69 xb ff<br>69 xb ee ff<br>69 xb<br>69 xb ee ff<br>87<br>C7       | PwO<br>Pw<br>PwO<br>PwP<br>PIfw<br>PIPw<br>O<br>O                     | [- - - 0 1 0 0] |
| CLV                                                                                                                                                        | Clear V; assembles as ANDCC #\$FD                                                                                                                                                                                                                                                                     | IMM                                                           | 10 FD                                                                                  | P                                                                     | [- - - - - 0 -] |
| CMPA #opr8i<br>CMPA opr8a<br>CMPA opr16a<br>CMPA oprx0_xysppc<br>CMPA oprx9_xysppc<br>CMPA oprx16_xysppc<br>CMPA [D,xysppc]<br>CMPA [oprx16_xysppc]        | Compare A; (A)-(M) or (A)-imm                                                                                                                                                                                                                                                                         | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 81 ii<br>91 dd<br>B1 hh 11<br>A1 xb<br>A1 xb ff<br>A1 xb ee ff<br>A1 xb<br>A1 xb ee ff | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf             | [- - - Δ Δ Δ Δ] |

# Central Processing Unit (CPU)

| Source Form                                                                                                                                        | Operation                                                                                                                                                                | Address Mode                                                  | Machine Coding (Hex)                                                                      | Access Detail                                              | S X H I N Z V C |
|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------|
| CMPB #opr8i<br>CMPB opr8a<br>CMPB opr16a<br>CMPB oprx0_xysppc<br>CMPB oprx9_xysppc<br>CMPB oprx16,xysppc<br>CMPB [D,xysppc]<br>CMPB [opr16,xysppc] | Compare B; (B)–(M) or (B)–imm                                                                                                                                            | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | C1 ii<br>D1 dd<br>F1 hh ll<br>E1 xb<br>E1 xb ff<br>E1 xb ee ff<br>E1 xb<br>E1 xb ee ff    | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfnPf<br>fIPrPf  | - - - Δ Δ Δ     |
| COM opr16a<br>COM oprx0_xysppc<br>COM oprx9,xysppc<br>COM oprx16,xysppc<br>COM [D,xysppc]<br>COM [opr16,xysppc]<br>COMA<br>COMB                    | Complement M; ( $\bar{M}$ )=\$FF–(M) $\Rightarrow$ M<br><br>Complement A; ( $\bar{A}$ )=\$FF–(A) $\Rightarrow$ A<br>Complement B; ( $\bar{B}$ )=\$FF–(B) $\Rightarrow$ B | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]<br>INH<br>INH | 71 hh ll<br>61 xb<br>61 xb ff<br>61 xb ee ff<br>61 xb<br>61 xb ee ff<br>41<br>51          | rPwO<br>rPw<br>rPwO<br>frPwP<br>fIfnPw<br>fIPrPw<br>O<br>O | - - - Δ Δ 0 1   |
| CPD #opr16i<br>CPD opr8a<br>CPD opr16a<br>CPD oprx0_xysppc<br>CPD oprx9,xysppc<br>CPD oprx16,xysppc<br>CPD [D,xysppc]<br>CPD [opr16,xysppc]        | Compare D; (A:B)–(M:M+1) or (A:B)–imm                                                                                                                                    | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 8C jj kk<br>9C dd<br>BC hh ll<br>AC xb<br>AC xb ff<br>AC xb ee ff<br>AC xb<br>AC xb ee ff | PO<br>RPf<br>RPO<br>RPf<br>RPO<br>fRPP<br>fIfRPf<br>fIPRPf | - - - Δ Δ Δ     |
| CPS #opr16i<br>CPS opr8a<br>CPS opr16a<br>CPS oprx0_xysppc<br>CPS oprx9,xysppc<br>CPS oprx16,xysppc<br>CPS [D,xysppc]<br>CPS [opr16,xysppc]        | Compare SP; (SP)–(M:M+1) or (SP)–imm                                                                                                                                     | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 8F jj kk<br>9F dd<br>BF hh ll<br>AF xb<br>AF xb ff<br>AF xb ee ff<br>AF xb<br>AF xb ee ff | PO<br>RPf<br>RPO<br>RPf<br>RPO<br>fRPP<br>fIfRPf<br>fIPRPf | - - - Δ Δ Δ     |
| CPX #opr16i<br>CPX opr8a<br>CPX opr16a<br>CPX oprx0_xysppc<br>CPX oprx9,xysppc<br>CPX oprx16,xysppc<br>CPX [D,xysppc]<br>CPX [opr16,xysppc]        | Compare X; (X)–(M:M+1) or (X)–imm                                                                                                                                        | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 8E jj kk<br>9E dd<br>BE hh ll<br>AE xb<br>AE xb ff<br>AE xb ee ff<br>AE xb<br>AE xb ee ff | PO<br>RPf<br>RPO<br>RPf<br>RPO<br>fRPP<br>fIfRPf<br>fIPRPf | - - - Δ Δ Δ     |
| CPY #opr16i<br>CPY opr8a<br>CPY opr16a<br>CPY oprx0_xysppc<br>CPY oprx9,xysppc<br>CPY oprx16,xysppc<br>CPY [D,xysppc]<br>CPY [opr16,xysppc]        | Compare Y; (Y)–(M:M+1) or (Y)–imm                                                                                                                                        | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 8D jj kk<br>9D dd<br>BD hh ll<br>AD xb<br>AD xb ff<br>AD xb ee ff<br>AD xb<br>AD xb ee ff | PO<br>RPf<br>RPO<br>RPf<br>RPO<br>fRPP<br>fIfRPf<br>fIPRPf | - - - Δ Δ Δ     |
| DAA                                                                                                                                                | Decimal adjust A for BCD                                                                                                                                                 | INH                                                           | 18 07                                                                                     | OFO                                                        | - - - Δ Δ ? Δ   |
| DBEQ abdxysp, rel9                                                                                                                                 | Decrement and branch if equal to 0;<br>(counter)–1 $\Rightarrow$ counter;<br>if (counter)=0, then branch                                                                 | REL<br>(9-bit)                                                | 04 1b rr                                                                                  | PPP (branch)<br>PPO (no branch)                            | - - - - - -     |
| DBNE abdxysp, rel9                                                                                                                                 | Decrement and branch if not equal to 0;<br>(counter)–1 $\Rightarrow$ counter;<br>if (counter) $\neq$ 0, then branch                                                      | REL<br>(9-bit)                                                | 04 1b rr                                                                                  | PPP (branch)<br>PPO (no branch)                            | - - - - - -     |

| Source Form                                                                                                                                        | Operation                                                                                                                                                                  | Address Mode                                                  | Machine Coding (Hex)                                                                   | Access Detail                                              | S X H I N Z V C |
|----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------|
| DEC opr16a<br>DEC oprx0_xysppc<br>DEC oprx9_xysppc<br>DEC oprx16_xysppc<br>DEC [D,xysppc]<br>DEC [opr16,xysppc]<br>DECA<br>DECB                    | Decrement M; (M)-1⇒M<br>Decrement A; (A)-1⇒A<br>Decrement B; (B)-1⇒B                                                                                                       | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]<br>INH<br>INH | 73 hh 11<br>63 xb<br>63 xb ff<br>63 xb ee ff<br>63 xb<br>63 xb ee ff<br>43<br>53       | rPwO<br>rPw<br>rPwO<br>frPwP<br>fIfPrw<br>fIPrPw<br>O<br>O | - - - - Δ Δ - - |
| DES                                                                                                                                                | Decrement SP; (SP)-1⇒SP;<br>assembles as LEAS-1,SP                                                                                                                         | IDX                                                           | 1B 9F                                                                                  | Pf                                                         | - - - - - - - - |
| DEX                                                                                                                                                | Decrement X; (X)-1⇒X                                                                                                                                                       | INH                                                           | 09                                                                                     | O                                                          | - - - - - Δ - - |
| DEY                                                                                                                                                | Decrement Y; (Y)-1⇒Y                                                                                                                                                       | INH                                                           | 03                                                                                     | O                                                          | - - - - - Δ - - |
| EDIV                                                                                                                                               | Extended divide, unsigned; 32 by 16 to<br>16-bit; (Y:D)÷(X)⇒Y; remainder⇒D                                                                                                 | INH                                                           | 11                                                                                     | ffffffffffffO                                              | - - - - Δ Δ Δ Δ |
| EDIVS                                                                                                                                              | Extended divide, signed; 32 by 16 to<br>16-bit; (Y:D)÷(X)⇒Y; remainder⇒D                                                                                                   | INH                                                           | 18 14                                                                                  | 0xffffffffffffO                                            | - - - - Δ Δ Δ Δ |
| EMACS opr16a                                                                                                                                       | Extended multiply and accumulate,<br>signed; (M <sub>X</sub> :M <sub>X+1</sub> )×(M <sub>Y</sub> :M <sub>Y+1</sub> )+<br>(M-M+3)⇒M-M+3; 16 by 16 to 32-bit                 | Special                                                       | 18 12 hh 11                                                                            | ORROffFRRfWWP                                              | - - - - Δ Δ Δ Δ |
| EMAXD oprx0_xysppc<br>EMAXD oprx9_xysppc<br>EMAXD oprx16_xysppc<br>EMAXD [D,xysppc]<br>EMAXD [opr16,xysppc]                                        | Extended maximum in D; put larger of 2<br>unsigned 16-bit values in D;<br>MAX[(D), (M:M+1)]⇒D;<br>N, Z, V, C bits reflect result of internal<br>compare [(D)-(M:M+1)]      | IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]                      | 18 1A xb<br>18 1A xb ff<br>18 1A xb ee ff<br>18 1A xb<br>18 1A xb ee ff                | ORPF<br>ORPO<br>OfRPP<br>OfIFRPf<br>OfIPRPF                | - - - - Δ Δ Δ Δ |
| EMAXM oprx0_xysppc<br>EMAXM oprx9_xysppc<br>EMAXM oprx16_xysppc<br>EMAXM [D,xysppc]<br>EMAXM [opr16,xysppc]                                        | Extended maximum in M; put larger of<br>2 unsigned 16-bit values in M;<br>MAX[(D), (M:M+1)]⇒M:M+1;<br>N, Z, V, C bits reflect result of internal<br>compare [(D)-(M:M+1)]  | IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]                      | 18 1E xb<br>18 1E xb ff<br>18 1E xb ee ff<br>18 1E xb<br>18 1E xb ee ff                | ORPW<br>ORPWO<br>OfRPWP<br>OfIFRPW<br>OfIPRWP              | - - - - Δ Δ Δ Δ |
| EMIND oprx0_xysppc<br>EMIND oprx9_xysppc<br>EMIND oprx16_xysppc<br>EMIND [D,xysppc]<br>EMIND [opr16,xysppc]                                        | Extended minimum in D; put smaller of<br>2 unsigned 16-bit values in D;<br>MIN[(D), (M:M+1)]⇒D;<br>N, Z, V, C bits reflect result of internal<br>compare [(D)-(M:M+1)]     | IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]                      | 18 1B xb<br>18 1B xb ff<br>18 1B xb ee ff<br>18 1B xb<br>18 1B xb ee ff                | ORPF<br>ORPO<br>OfRPP<br>OfIFRPf<br>OfIPRPF                | - - - - Δ Δ Δ Δ |
| EMINM oprx0_xysppc<br>EMINM oprx9_xysppc<br>EMINM oprx16_xysppc<br>EMINM [D,xysppc]<br>EMINM [opr16,xysppc]                                        | Extended minimum in M; put smaller of<br>2 unsigned 16-bit values in M;<br>MIN[(D), (M:M+1)]⇒M:M+1;<br>N, Z, V, C bits reflect result of internal<br>compare [(D)-(M:M+1)] | IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]                      | 18 1F xb<br>18 1F xb ff<br>18 1F xb ee ff<br>18 1F xb<br>18 1F xb ee ff                | ORPW<br>ORPWO<br>OfRPWP<br>OfIFRPW<br>OfIPRWP              | - - - - Δ Δ Δ Δ |
| EMUL                                                                                                                                               | Extended multiply, unsigned;<br>(D)×(Y)⇒Y:D; 16 by 16 to 32-bit                                                                                                            | INH                                                           | 13                                                                                     | ffO                                                        | - - - - Δ Δ - - |
| EMULS                                                                                                                                              | Extended multiply, signed;<br>(D)×(Y)⇒Y:D; 16 by 16 to 32-bit                                                                                                              | INH                                                           | 18 13                                                                                  | Ofo<br>OffO (if followed by<br>page 2 instruction)         | - - - - Δ Δ - - |
| EORA #opr8i<br>EORA opr8a<br>EORA opr16a<br>EORA oprx0_xysppc<br>EORA oprx9_xysppc<br>EORA oprx16_xysppc<br>EORA [D,xysppc]<br>EORA [opr16,xysppc] | Exclusive OR A; (A)⊕(M)⇒A or<br>(A)⊕imm⇒A                                                                                                                                  | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 88 ii<br>98 dd<br>B8 hh 11<br>A8 xb<br>A8 xb ff<br>A8 xb ee ff<br>A8 xb<br>A8 xb ee ff | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfPrf<br>fIPrPf  | - - - - Δ Δ O - |

# Central Processing Unit (CPU)

| Source Form                                                                                                                                                                              | Operation                                                                                                                                                                            | Address Mode                                                  | Machine Coding (Hex)                                                                   | Access Detail                                               | S X H I N Z V C           |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------|---------------------------|
| EORB #opr8i<br>EORB opr8a<br>EORB opr16a<br>EORB oprx0_xysppc<br>EORB oprx9_xysppc<br>EORB oprx16_xysppc<br>EORB [D,xysppc]<br>EORB [opr16,xysppc]                                       | Exclusive OR B; (B) $\oplus$ (M) $\Rightarrow$ B or (B) $\oplus$ imm $\Rightarrow$ B                                                                                                 | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | C8 ii<br>D8 dd<br>F8 hh 11<br>E8 xb<br>E8 xb ff<br>E8 xb ee ff<br>E8 xb<br>E8 xb ee ff | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfPf<br>fIPrPf    | [--- --- Δ Δ 0 ---]       |
| ETBL oprx0_xysppc                                                                                                                                                                        | Extended table lookup and interpolate, 16-bit; (M:M+1)+[(B) $\times$ ((M+2:M+3)–(M:M+1))] $\Rightarrow$ D                                                                            | IDX                                                           | 18 3F xb                                                                               | ORRfffffP                                                   | [--- --- Δ Δ --- Δ]       |
| Before executing ETBL, initialize B with fractional part of lookup value; initialize index register to point to first table entry (M:M+1). No extensions or indirect addressing allowed. |                                                                                                                                                                                      |                                                               |                                                                                        |                                                             |                           |
| EXG abcdxysp,abcdxysp                                                                                                                                                                    | Exchange register contents; (r1) $\leftrightarrow$ (r2); r1 and r2 same size or \$00:(r1) $\Rightarrow$ r2; r1=8-bit; r2=16-bit or (r1L) $\leftrightarrow$ (r2); r1=16-bit; r2=8-bit | INH                                                           | B7 eb                                                                                  | P                                                           | [--- --- --- --- --- ---] |
| FDIV                                                                                                                                                                                     | Fractional divide; 16 by 16-bit; (D) $\div$ (X) $\Rightarrow$ X; remainder $\Rightarrow$ D                                                                                           | INH                                                           | 18 11                                                                                  | 0xfffffffffO                                                | [--- --- --- Δ Δ Δ]       |
| IBEQ abdxysp, rel9                                                                                                                                                                       | Increment and branch if equal to 0; (counter)+1 $\Rightarrow$ counter; if (counter)=0, then branch                                                                                   | REL (9-bit)                                                   | 04 1b rr                                                                               | PPP (branch)<br>PPO (no branch)                             | [--- --- --- --- --- ---] |
| IBNE abdxysp, rel9                                                                                                                                                                       | Increment and branch if not equal to 0; (counter)+1 $\Rightarrow$ counter; if (counter) $\neq$ 0, then branch                                                                        | REL (9-bit)                                                   | 04 1b rr                                                                               | PPP (branch)<br>PPO (no branch)                             | [--- --- --- --- --- ---] |
| IDIV                                                                                                                                                                                     | Integer divide, unsigned; 16 by 16-bit; (D) $\div$ (X) $\Rightarrow$ X; remainder $\Rightarrow$ D                                                                                    | INH                                                           | 18 10                                                                                  | 0xfffffffffO                                                | [--- --- --- Δ 0 Δ]       |
| IDIVS                                                                                                                                                                                    | Integer divide, signed; 16 by 16-bit; (D) $\div$ (X) $\Rightarrow$ X; remainder $\Rightarrow$ D                                                                                      | INH                                                           | 18 15                                                                                  | 0xfffffffffO                                                | [--- --- --- Δ Δ Δ Δ]     |
| INC opr16a<br>INC oprx0_xysppc<br>INC oprx9_xysppc<br>INC oprx16_xysppc<br>INC [D,xysppc]<br>INC [opr16,xysppc]<br>INCA<br>INCB                                                          | Increment M; (M)+1 $\Rightarrow$ M<br><br>Increment A; (A)+1 $\Rightarrow$ A<br>Increment B; (B)+1 $\Rightarrow$ B                                                                   | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]<br>INH<br>INH | 72 hh 11<br>62 xb<br>62 xb ff<br>62 xb ee ff<br>62 xb<br>62 xb ee ff<br>42<br>52       | rPwO<br>rPw<br>rPwO<br>frPwP<br>fIfPw<br>fIPrPw<br>O<br>O   | [--- --- --- Δ Δ Δ ---]   |
| INS                                                                                                                                                                                      | Increment SP; (SP)+1 $\Rightarrow$ SP; assembles as LEAS 1,SP                                                                                                                        | IDX                                                           | 1B 81                                                                                  | Pf                                                          | [--- --- --- --- --- ---] |
| INX                                                                                                                                                                                      | Increment X; (X)+1 $\Rightarrow$ X                                                                                                                                                   | INH                                                           | 08                                                                                     | O                                                           | [--- --- --- Δ --- ---]   |
| INY                                                                                                                                                                                      | Increment Y; (Y)+1 $\Rightarrow$ Y                                                                                                                                                   | INH                                                           | 02                                                                                     | O                                                           | [--- --- --- Δ --- ---]   |
| JMP opr16a<br>JMP oprx0_xysppc<br>JMP oprx9_xysppc<br>JMP oprx16_xysppc<br>JMP [D,xysppc]<br>JMP [opr16,xysppc]                                                                          | Jump; subroutine address $\Rightarrow$ PC                                                                                                                                            | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]               | 06 hh 11<br>05 xb<br>05 xb ff<br>05 xb ee ff<br>05 xb<br>05 xb ee ff                   | PPP<br>PPP<br>PPP<br>fPPP<br>fIfPPP<br>fIfPPP               | [--- --- --- --- --- ---] |
| JSR opr8a<br>JSR opr16a<br>JSR oprx0_xysppc<br>JSR oprx9_xysppc<br>JSR oprx16_xysppc<br>JSR [D,xysppc]<br>JSR [opr16,xysppc]                                                             | Jump to subroutine; (SP)-2 $\Rightarrow$ SP; RTN <sub>H</sub> :RTN <sub>L</sub> $\Rightarrow$ M <sub>SP</sub> :M <sub>SP+1</sub> ; subroutine address $\Rightarrow$ PC               | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 17 dd<br>16 hh 11<br>15 xb<br>15 xb ff<br>15 xb ee ff<br>15 xb<br>15 xb ee ff          | SPPP<br>SPPP<br>PPPS<br>PPPS<br>fPPPS<br>fIfPPPS<br>fIfPPPS | [--- --- --- --- --- ---] |
| LBCC rel16                                                                                                                                                                               | Long branch if C clear; if C=0, then (PC)+4+rel $\Rightarrow$ PC; same as LBHS                                                                                                       | REL                                                           | 18 24 qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                            | [--- --- --- --- --- ---] |

| Source Form                                                                                                                                                                | Operation                                                                              | Address Mode                                                  | Machine Coding (Hex)                                                                   | Access Detail                                             | S X H I N Z V C       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------|-----------------------|
| LBCS <i>rel16</i>                                                                                                                                                          | Long branch if C set; if C=1, then (PC)+4+rel⇒PC; same as LBLO                         | REL                                                           | 18 25 qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBEQ <i>rel16</i>                                                                                                                                                          | Long branch if equal; if Z=1, then (PC)+4+rel⇒PC                                       | REL                                                           | 18 27 qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBGE <i>rel16</i>                                                                                                                                                          | Long branch if $\geq 0$ , signed; if $N \oplus V = 0$ , then (PC)+4+rel⇒PC             | REL                                                           | 18 2C qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBGT <i>rel16</i>                                                                                                                                                          | Long branch if $> 0$ , signed; if $Z   (N \oplus V) = 0$ , then (PC)+4+rel⇒PC          | REL                                                           | 18 2E qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBHI <i>rel16</i>                                                                                                                                                          | Long branch if higher, unsigned; if $C   Z = 0$ , then (PC)+4+rel⇒PC                   | REL                                                           | 18 22 qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBHS <i>rel16</i>                                                                                                                                                          | Long branch if higher or same, unsigned; if $C = 0$ , then (PC)+4+rel⇒PC; same as LBCC | REL                                                           | 18 24 qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBLE <i>rel16</i>                                                                                                                                                          | Long branch if $\leq 0$ , signed; if $Z   (N \oplus V) = 1$ , then (PC)+4+rel⇒PC       | REL                                                           | 18 2F qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBLO <i>rel16</i>                                                                                                                                                          | Long branch if lower, unsigned; if $C = 1$ , then (PC)+4+rel⇒PC; same as LBCS          | REL                                                           | 18 25 qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBLS <i>rel16</i>                                                                                                                                                          | Long branch if lower or same, unsigned; if $C   Z = 1$ , then (PC)+4+rel⇒PC            | REL                                                           | 18 23 qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBLT <i>rel16</i>                                                                                                                                                          | Long branch if $< 0$ , signed; if $N \oplus V = 1$ , then (PC)+4+rel⇒PC                | REL                                                           | 18 2D qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBMI <i>rel16</i>                                                                                                                                                          | Long branch if minus; if $N = 1$ , then (PC)+4+rel⇒PC                                  | REL                                                           | 18 2B qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBNE <i>rel16</i>                                                                                                                                                          | Long branch if not equal to 0; if $Z = 0$ , then (PC)+4+rel⇒PC                         | REL                                                           | 18 26 qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBPL <i>rel16</i>                                                                                                                                                          | Long branch if plus; if $N = 0$ , then (PC)+4+rel⇒PC                                   | REL                                                           | 18 2A qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBRA <i>rel16</i>                                                                                                                                                          | Long branch always                                                                     | REL                                                           | 18 20 qq rr                                                                            | OPPP                                                      | [- - -   - - - - - -] |
| LBRN <i>rel16</i>                                                                                                                                                          | Long branch never                                                                      | REL                                                           | 18 21 qq rr                                                                            | OPO                                                       | [- - -   - - - - - -] |
| LBVC <i>rel16</i>                                                                                                                                                          | Long branch if V clear; if $V = 0$ , then (PC)+4+rel⇒PC                                | REL                                                           | 18 28 qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LBVS <i>rel16</i>                                                                                                                                                          | Long branch if V set; if $V = 1$ , then (PC)+4+rel⇒PC                                  | REL                                                           | 18 29 qq rr                                                                            | OPPP (branch)<br>OPO (no branch)                          | [- - -   - - - - - -] |
| LDAA #opr8 <i>i</i><br>LDAA opr8 <i>a</i><br>LDAA opr16 <i>a</i><br>LDAA oprx0_xysppc<br>LDAA oprx9,xysppc<br>LDAA oprx16,xysppc<br>LDAA [D,xysppc]<br>LDAA [opr16,xysppc] | Load A; (M)⇒A or imm⇒A                                                                 | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 86 ii<br>96 dd<br>B6 hh ll<br>A6 xb<br>A6 xb ff<br>A6 xb ee ff<br>A6 xb<br>A6 xb ee ff | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf | [- - -   ΔΔ 0-]       |
| LDAB #opr8 <i>i</i><br>LDAB opr8 <i>a</i><br>LDAB opr16 <i>a</i><br>LDAB oprx0_xysppc<br>LDAB oprx9,xysppc<br>LDAB oprx16,xysppc<br>LDAB [D,xysppc]<br>LDAB [opr16,xysppc] | Load B; (M)⇒B or imm⇒B                                                                 | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | C6 ii<br>D6 dd<br>F6 hh ll<br>E6 xb<br>E6 xb ff<br>E6 xb ee ff<br>E6 xb<br>E6 xb ee ff | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf | [- - -   ΔΔ 0-]       |

# Central Processing Unit (CPU)

| Source Form                                                                                                                                 | Operation                                                                                                                 | Address Mode                                                  | Machine Coding (Hex)                                                                      | Access Detail                                              | S X H I N Z V C |
|---------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------|
| LDD #opr16i<br>LDD opr8a<br>LDD opr16a<br>LDD oprx0_xysppc<br>LDD oprx9,xysppc<br>LDD oprx16,xysppc<br>LDD [D,xysppc]<br>LDD [opr16,xysppc] | Load D; (M:M+1)⇒A:B or imm⇒A:B                                                                                            | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | CC jj kk<br>DC dd<br>FC hh ll<br>EC xb<br>EC xb ff<br>EC xb ee ff<br>EC xb<br>EC xb ee ff | PO<br>RPf<br>RPO<br>RPf<br>RPO<br>fRPP<br>fIFRPf<br>fIPRPf | - - - - ΔΔ0 -   |
| LDS #opr16i<br>LDS opr8a<br>LDS opr16a<br>LDS oprx0_xysppc<br>LDS oprx9,xysppc<br>LDS oprx16,xysppc<br>LDS [D,xysppc]<br>LDS [opr16,xysppc] | Load SP; (M:M+1)⇒SP or imm⇒SP                                                                                             | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | CF jj kk<br>DF dd<br>FF hh ll<br>EF xb<br>EF xb ff<br>EF xb ee ff<br>EF xb<br>EF xb ee ff | PO<br>RPf<br>RPO<br>RPf<br>RPO<br>fRPP<br>fIFRPf<br>fIPRPf | - - - - ΔΔ0 -   |
| LDX #opr16i<br>LDX opr8a<br>LDX opr16a<br>LDX oprx0_xysppc<br>LDX oprx9,xysppc<br>LDX oprx16,xysppc<br>LDX [D,xysppc]<br>LDX [opr16,xysppc] | Load X; (M:M+1)⇒X or imm⇒X                                                                                                | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | CE jj kk<br>DE dd<br>FE hh ll<br>EE xb<br>EE xb ff<br>EE xb ee ff<br>EE xb<br>EE xb ee ff | PO<br>RPf<br>RPO<br>RPf<br>RPO<br>fRPP<br>fIFRPf<br>fIPRPf | - - - - ΔΔ0 -   |
| LDY #opr16i<br>LDY opr8a<br>LDY opr16a<br>LDY oprx0_xysppc<br>LDY oprx9,xysppc<br>LDY oprx16,xysppc<br>LDY [D,xysppc]<br>LDY [opr16,xysppc] | Load Y; (M:M+1)⇒Y or imm⇒Y                                                                                                | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | CD jj kk<br>DD dd<br>FD hh ll<br>ED xb<br>ED xb ff<br>ED xb ee ff<br>ED xb<br>ED xb ee ff | PO<br>RPf<br>RPO<br>RPf<br>RPO<br>fRPP<br>fIFRPf<br>fIPRPf | - - - - ΔΔ0 -   |
| LEAS oprx0_xysppc<br>LEAS oprx9,xysppc<br>LEAS oprx16,xysppc                                                                                | Load effective address into SP;<br>effective address⇒SP                                                                   | IDX<br>IDX1<br>IDX2                                           | 1B xb<br>1B xb ff<br>1B xb ee ff                                                          | Pf<br>PO<br>PP                                             | - - - - - - -   |
| LEAX oprx0_xysppc<br>LEAX oprx9,xysppc<br>LEAX oprx16,xysppc                                                                                | Load effective address into X;<br>effective address⇒X                                                                     | IDX<br>IDX1<br>IDX2                                           | 1A xb<br>1A xb ff<br>1A xb ee ff                                                          | Pf<br>PO<br>PP                                             | - - - - - - -   |
| LEAY oprx0_xysppc<br>LEAY oprx9,xysppc<br>LEAY oprx16,xysppc                                                                                | Load effective address into Y;<br>effective address⇒Y                                                                     | IDX<br>IDX1<br>IDX2                                           | 19 xb<br>19 xb ff<br>19 xb ee ff                                                          | Pf<br>PO<br>PP                                             | - - - - - - -   |
| LSL opr16a<br>LSL oprx0_xysppc<br>LSL oprx9,xysppc<br>LSL oprx16,xysppc<br>LSL [D,xysppc]<br>LSL [opr16,xysppc]                             | Logical shift left M; same as ASL<br>  | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]<br>INH<br>INH | 78 hh ll<br>68 xb<br>68 xb ff<br>68 xb ee ff<br>68 xb<br>68 xb ee ff<br>48<br>58          | rOPw<br>rPw<br>rPOw<br>fRPPw<br>fIFrPw<br>fIPrPw<br>O<br>O | - - - - ΔΔΔΔ    |
| LSLA<br>LSLB                                                                                                                                | Logical shift left A; same as ASLA<br>Logical shift left B; same as ASLB                                                  |                                                               |                                                                                           |                                                            |                 |
| LSLD                                                                                                                                        | Logical shift left D; same as ASLD<br> | INH                                                           | 59                                                                                        | O                                                          | - - - - ΔΔΔΔ    |
| LSR opr16a<br>LSR oprx0_xysppc<br>LSR oprx9,xysppc<br>LSR oprx16,xysppc<br>LSR [D,xysppc]<br>LSR [opr16,xysppc]                             | Logical shift right M<br>              | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]<br>INH<br>INH | 74 hh ll<br>64 xb<br>64 xb ff<br>64 xb ee ff<br>64 xb<br>64 xb ee ff<br>44<br>54          | rPwO<br>rPw<br>rPwO<br>fRpwP<br>fIFrPw<br>fIPrPw<br>O<br>O | - - - - 0 ΔΔΔ   |
| LSRA<br>LSRB                                                                                                                                | Logical shift right A<br>Logical shift right B                                                                            |                                                               |                                                                                           |                                                            |                 |

| Source Form                                                                                                                                                           | Operation                                                                                                                                                                                                                                                                                                                                              | Address Mode                                                   | Machine Coding (Hex)                                                                                        | Access Detail                                              | S X H I N Z V C |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------|
| LSRD                                                                                                                                                                  | Logical shift right D<br>                                                                                                                                                                                                                                             | INH                                                            | 49                                                                                                          | O                                                          | - - -   0 Δ Δ Δ |
| MAXA oprx0_xysppc<br>MAXA oprx9_xysppc<br>MAXA oprx16_xysppc<br>MAXA [D,xysppc]<br>MAXA [oprx16,xysppc]                                                               | Maximum in A; put larger of 2 unsigned 8-bit values in A; MAX[(A), (M)]⇒A; N, Z, V, C bits reflect result of internal compare [(A)–(M)]                                                                                                                                                                                                                | IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]                       | 18 18 xb<br>18 18 xb ff<br>18 18 xb ee ff<br>18 18 xb<br>18 18 xb ee ff                                     | OrPf<br>OrPO<br>OfrrPP<br>OfIfrPf<br>OfIPrPf               | - - -   Δ Δ Δ Δ |
| MAXM oprx0_xysppc<br>MAXM oprx9_xysppc<br>MAXM oprx16_xysppc<br>MAXM [D,xysppc]<br>MAXM [oprx16,xysppc]                                                               | Maximum in M; put larger of 2 unsigned 8-bit values in M; MAX[(A), (M)]⇒M; N, Z, V, C bits reflect result of internal compare [(A)–(M)]                                                                                                                                                                                                                | IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]                       | 18 1C xb<br>18 1C xb ff<br>18 1C xb ee ff<br>18 1C xb<br>18 1C xb ee ff                                     | OrPw<br>OrPwO<br>OfrrPwP<br>OfIfrPw<br>OfIPrPw             | - - -   Δ Δ Δ Δ |
| MEM                                                                                                                                                                   | Determine grade of membership;<br>$\mu$ (grade)⇒M <sub>Y</sub> ; (X)+4⇒X; (Y)+1⇒Y;<br>if (A)<P1 or (A)>P2 then $\mu=0$ , else $\mu=\min[((A)-P1) \times S1, (P2-(A)) \times S2, \$FF]$ ;<br>(A)=current crisp input value; X points at 4-byte data describing trapezoidal membership function (P1, P2, S1, S2); X points at fuzzy input (RAM location) | Special                                                        | 01                                                                                                          | RRfOw                                                      | - - ? - ? ? ? ? |
| MINA oprx0_xysppc<br>MINA oprx9_xysppc<br>MINA oprx16_xysppc<br>MINA [D,xysppc]<br>MINA [oprx16,xysppc]                                                               | Minimum in A; put smaller of 2 unsigned 8-bit values in A; MIN[(A), (M)]⇒A; N, Z, V, C bits reflect result of internal compare [(A)–(M)]                                                                                                                                                                                                               | IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]                       | 18 19 xb<br>18 19 xb ff<br>18 19 xb ee ff<br>18 19 xb<br>18 19 xb ee ff                                     | OrPf<br>OrPO<br>OfrrPP<br>OfIfrPf<br>OfIPrPf               | - - -   Δ Δ Δ Δ |
| MINM oprx0_xysppc<br>MINM oprx9_xysppc<br>MINM oprx16_xysppc<br>MINM [D,xysppc]<br>MINM [oprx16,xysppc]                                                               | Minimum in N; put smaller of 2 unsigned 8-bit values in M; MIN[(A), (M)]⇒M; N, Z, V, C bits reflect result of internal compare [(A)–(M)]                                                                                                                                                                                                               | IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]                       | 18 1D xb<br>18 1D xb ff<br>18 1D xb ee ff<br>18 1D xb<br>18 1D xb ee ff                                     | OrPw<br>OrPwO<br>OfrrPwP<br>OfIfrPw<br>OfIPrPw             | - - -   Δ Δ Δ Δ |
| MOVB #opr8, opr16a<br>MOVB #opr8i, oprx0_xysppc<br>MOVB opr16a, opr16a<br>MOVB opr16a, oprx0_xysppc<br>MOVB oprx0_xysppc, opr16a<br>MOVB oprx0_xysppc, oprx0_xysppc   | Move byte; memory-to-memory 8-bit byte-move; (M <sub>1</sub> )⇒M <sub>2</sub> ; first operand specifies byte to move                                                                                                                                                                                                                                   | IMM-EXT<br>IMM-IDX<br>EXT-EXT<br>EXT-IDX<br>IDX-EXT<br>IDX-IDX | 18 0B ii hh 11<br>18 08 xb ii<br>18 0C hh 11 hh 11<br>18 09 xb hh 11<br>18 0D xb hh 11<br>18 0A xb xb       | OPwP<br>OPwO<br>OrPwPO<br>OPrPw<br>OrPwP<br>OrPwO          | - - - - - - - - |
| MOVW #opr16, opr16a<br>MOVW #opr16i, oprx0_xysppc<br>MOVW opr16a, opr16a<br>MOVW opr16a, oprx0_xysppc<br>MOVW oprx0_xysppc, opr16a<br>MOVW oprx0_xysppc, oprx0_xysppc | Move word; memory-to-memory 16-bit word-move; (M <sub>1</sub> :M <sub>1</sub> +1)⇒M <sub>2</sub> :M <sub>2</sub> +1; first operand specifies word to move                                                                                                                                                                                              | IMM-EXT<br>IMM-IDX<br>EXT-EXT<br>EXT-IDX<br>IDX-EXT<br>IDX-IDX | 18 03 jj kk hh 11<br>18 00 xb jj kk<br>18 04 hh 11 hh 11<br>18 01 xb hh 11<br>18 05 xb hh 11<br>18 02 xb xb | OPWPO<br>OPPW<br>ORPWP<br>OPRPW<br>ORWP<br>ORPWO           | - - - - - - - - |
| MUL                                                                                                                                                                   | Multiply, unsigned, 8 by 8-bit; (A)×(B)⇒A:B                                                                                                                                                                                                                                                                                                            | INH                                                            | 12                                                                                                          | O                                                          | - - - - - - - Δ |
| NEG opr16a<br>NEG oprx0_xysppc<br>NEG oprx9_xysppc<br>NEG oprx16_xysppc<br>NEG [D,xysppc]<br>NEG [oprx16,xysppc]<br>NEGA<br>NEGB                                      | Negate M; 0–(M)⇒M or (M)+1⇒M<br>Negate A; 0–(A)⇒A or (A)+1⇒A<br>Negate B; 0–(B)⇒B or (B)+1⇒B                                                                                                                                                                                                                                                           | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]<br>INH<br>INH  | 70 hh 11<br>60 xb<br>60 xb ff<br>60 xb ee ff<br>60 xb<br>60 xb ee ff<br>40<br>50                            | rPwO<br>rPw<br>rPwO<br>frPwP<br>fIfrPw<br>fIPrPw<br>O<br>O | - - -   Δ Δ Δ Δ |
| NOP                                                                                                                                                                   | No operation                                                                                                                                                                                                                                                                                                                                           | INH                                                            | A7                                                                                                          | O                                                          | - - - - - - - - |

## **Central Processing Unit (CPU)**

| Source Form                                                                                                                                                            | Operation                                                                                                                               | Address Mode                                                  | Machine Coding (Hex)                                                                   | Access Detail                                                                                                             | S X H I N Z V C   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|-------------------|
| ORAA #opr8i<br>ORAA opr8a<br>ORAA opr16a<br>ORAA oprx0_xysppc<br>ORAA oprx9_xysppc<br>ORAA oprx16_xysppc<br>ORAA [D,xysppc]<br>ORAA [opr16,xysppc]                     | OR accumulator A; (A)   (M) $\Rightarrow$ A or (A)   imm $\Rightarrow$ A                                                                | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 8A ii<br>9A dd<br>BA hh 11<br>AA xb<br>AA xb ff<br>AA xb ee ff<br>AA xb<br>AA xb ee ff | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf                                                                 | [---ΔΔ 0 ---]     |
| ORAB #opr8i<br>ORAB opr8a<br>ORAB opr16a<br>ORAB oprx0_xysppc<br>ORAB oprx9_xysppc<br>ORAB oprx16_xysppc<br>ORAB [D,xysppc]<br>ORAB [opr16,xysppc]                     | OR accumulator B; (B)   (M) $\Rightarrow$ B or (B)   imm $\Rightarrow$ B                                                                | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | CA ii<br>DA dd<br>FA hh 11<br>EA xb<br>EA xb ff<br>EA xb ee ff<br>EA xb<br>EA xb ee ff | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf                                                                 | [---ΔΔ 0 ---]     |
| ORCC #opr8i                                                                                                                                                            | OR CCR; (CCR)   imm $\Rightarrow$ CCR                                                                                                   | IMM                                                           | 14 ii                                                                                  | P                                                                                                                         | [↑ ---↑↑↑↑↑↑↑↑↑↑] |
| PSHA                                                                                                                                                                   | Push A; (SP)-1 $\Rightarrow$ SP; (A) $\Rightarrow$ M <sub>SP</sub>                                                                      | INH                                                           | 36                                                                                     | Os                                                                                                                        | [--- --- --- ---] |
| PSHB                                                                                                                                                                   | Push B; (SP)-1 $\Rightarrow$ SP; (B) $\Rightarrow$ M <sub>SP</sub>                                                                      | INH                                                           | 37                                                                                     | Os                                                                                                                        | [--- --- --- ---] |
| PSHC                                                                                                                                                                   | Push CCR; (SP)-1 $\Rightarrow$ SP; (CCR) $\Rightarrow$ M <sub>SP</sub>                                                                  | INH                                                           | 39                                                                                     | Os                                                                                                                        | [--- --- --- ---] |
| PSHD                                                                                                                                                                   | Push D; (SP)-2 $\Rightarrow$ SP; (A:B) $\Rightarrow$ M <sub>SP:M<sub>SP+1</sub></sub>                                                   | INH                                                           | 3B                                                                                     | OS                                                                                                                        | [--- --- --- ---] |
| PSHX                                                                                                                                                                   | Push X; (SP)-2 $\Rightarrow$ SP; (X <sub>H</sub> :X <sub>L</sub> ) $\Rightarrow$ M <sub>SP:M<sub>SP+1</sub></sub>                       | INH                                                           | 34                                                                                     | OS                                                                                                                        | [--- --- --- ---] |
| PSHY                                                                                                                                                                   | Push Y; (SP)-2 $\Rightarrow$ SP; (Y <sub>H</sub> :Y <sub>L</sub> ) $\Rightarrow$ M <sub>SP:M<sub>SP+1</sub></sub>                       | INH                                                           | 35                                                                                     | OS                                                                                                                        | [--- --- --- ---] |
| PULA                                                                                                                                                                   | Pull A; (M <sub>SP</sub> ) $\Rightarrow$ A; (SP)+1 $\Rightarrow$ SP                                                                     | INH                                                           | 32                                                                                     | ufO                                                                                                                       | [--- --- --- ---] |
| PULB                                                                                                                                                                   | Pull B; (M <sub>SP</sub> ) $\Rightarrow$ B; (SP)+1 $\Rightarrow$ SP                                                                     | INH                                                           | 33                                                                                     | ufO                                                                                                                       | [--- --- --- ---] |
| PULC                                                                                                                                                                   | Pull CCR; (M <sub>SP</sub> ) $\Rightarrow$ CCR; (SP)+1 $\Rightarrow$ SP                                                                 | INH                                                           | 38                                                                                     | ufO                                                                                                                       | [Δ↓ΔΔΔΔΔΔ]        |
| PULD                                                                                                                                                                   | Pull D; (M <sub>SP:M<sub>SP+1</sub></sub> ) $\Rightarrow$ A:B; (SP)+2 $\Rightarrow$ SP                                                  | INH                                                           | 3A                                                                                     | UfO                                                                                                                       | [--- --- --- ---] |
| PULX                                                                                                                                                                   | Pull X; (M <sub>SP:M<sub>SP+1</sub></sub> ) $\Rightarrow$ X <sub>H</sub> :X <sub>L</sub> ; (SP)+2 $\Rightarrow$ SP                      | INH                                                           | 30                                                                                     | UfO                                                                                                                       | [--- --- --- ---] |
| PULY                                                                                                                                                                   | Pull Y; (M <sub>SP:M<sub>SP+1</sub></sub> ) $\Rightarrow$ Y <sub>H</sub> :Y <sub>L</sub> ; (SP)+2 $\Rightarrow$ SP                      | INH                                                           | 31                                                                                     | UfO                                                                                                                       | [--- --- --- ---] |
| REV                                                                                                                                                                    | Rule evaluation, unweighted; find smallest rule input; store to rule outputs unless fuzzy output is already larger                      | Special                                                       | 18 3A                                                                                  | Orf(t <sup>^</sup> Tx)O*<br>ff+Orft <sup>^</sup> **                                                                       | [---? ---? Δ?]    |
| REVV                                                                                                                                                                   | Rule evaluation, weighted; rule weights optional; find smallest rule input; store to rule outputs unless fuzzy output is already larger | Special                                                       | 18 3B                                                                                  | Orf(t <sup>^</sup> Tx)O*<br>or<br>ORf(r <sup>^</sup> fRFf)O*<br>ffff+ORft <sup>^</sup> ***<br>ffff+ORfr <sup>^</sup> **** | [---? ---? Δ?]    |
| *The t <sup>^</sup> Tx loop is executed once for each element in the rule list. The ^ denotes a check for pending interrupt requests.                                  |                                                                                                                                         |                                                               |                                                                                        |                                                                                                                           |                   |
| **These are additional cycles caused by an interrupt: ff is the exit sequence and Orft <sup>^</sup> is the re-entry sequence.                                          |                                                                                                                                         |                                                               |                                                                                        |                                                                                                                           |                   |
| ***When weighting is not enabled, the t <sup>^</sup> Tx loop is executed once for each element in the rule list. The ^ denotes a check for pending interrupt requests. |                                                                                                                                         |                                                               |                                                                                        |                                                                                                                           |                   |
| **When weighting is enabled, the t <sup>^</sup> Tx loop is replaced by r <sup>^</sup> ffRf.                                                                            |                                                                                                                                         |                                                               |                                                                                        |                                                                                                                           |                   |
| ***These are additional cycles caused by an interrupt when weighting is not enabled: ffff is the exit sequence and ORft <sup>^</sup> is the re-entry sequence.         |                                                                                                                                         |                                                               |                                                                                        |                                                                                                                           |                   |
| **** These are additional cycles caused by an interrupt when weighting is enabled: ffff is the exit sequence and ORfr <sup>^</sup> is the re-entry sequence.           |                                                                                                                                         |                                                               |                                                                                        |                                                                                                                           |                   |

\*Where sightline is established, the angle is measured from the horizontal to the object. The angle to the object from the horizontal is called the angle of elevation.

**\*When weighting is not enabled, the  $t^T x$  loop is executed once for each row.**

\*\*When weighting is enabled, the  $t^T x$  loop is replaced by  $r^T ffrE$ .  
 \*\*\*There are additional cycles caused by an interrupt when weighting is not enabled; **FFFF** is the exit sequence and **OP\_F1\_A** is the re-entry sequence.

\*\*\*These are additional cycles caused by an interrupt when weighting is not enabled. **ffff** is the exit sequence and **ORF↑↑** is the re-entry sequence. \*\*\*\* These are additional cycles caused by an interrupt when weighting is enabled. **ffff** is the exit sequence and **ORF↑↑** is the re-entry sequence.

| Source Form                                                                                                                                        | Operation                                                                                                                                                                                                                                                                                                                                                                               | Address Mode                                                  | Machine Coding (Hex)                                                                   | Access Detail                                               | S X H I N Z V C |
|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------|-----------------|
| ROL opr16a<br>ROL oprx0_xysppc<br>ROL oprx9_xysppc<br>ROL oprx16_xysppc<br>ROL [D,xysppc]<br>ROL [opr16,xysppc]<br>ROLA<br>ROLB                    | Rotate left M<br>                                                                                                                                                                                                                                                                                                                                                                       | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]<br>INH<br>INH | 75 hh 11<br>65 xb<br>65 xb ff<br>65 xb ee ff<br>65 xb<br>65 xb ee ff<br>45<br>55       | rPwO<br>rPw<br>rPwO<br>frPwP<br>fIfPrPw<br>fIPrPw<br>O<br>O | - - - - Δ Δ Δ Δ |
| ROR opr16a<br>ROR oprx0_xysppc<br>ROR oprx9_xysppc<br>ROR oprx16_xysppc<br>ROR [D,xysppc]<br>ROR [opr16,xysppc]<br>RORA<br>RORB                    | Rotate right M<br>                                                                                                                                                                                                                                                                                                                                                                      | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]<br>INH<br>INH | 76 hh 11<br>66 xb<br>66 xb ff<br>66 xb ee ff<br>66 xb<br>66 xb ee ff<br>46<br>56       | rPwO<br>rPw<br>rPwO<br>frPwP<br>fIfPrPw<br>fIPrPw<br>O<br>O | - - - - Δ Δ Δ Δ |
| RTC                                                                                                                                                | Return from call; $(M_{SP}) \Rightarrow PPAGE$ ;<br>$(SP)+1 \Rightarrow SP$ ;<br>$(M_{SP}:M_{SP+1}) \Rightarrow PC_H:PC_L$ ;<br>$(SP)+2 \Rightarrow SP$                                                                                                                                                                                                                                 | INH                                                           | 0A                                                                                     | uUnfPPP                                                     | - - - - - - - - |
| RTI                                                                                                                                                | Return from interrupt;<br>$(M_{SP}) \Rightarrow CCR$ ;<br>$(SP)+1 \Rightarrow SP$ ;<br>$(M_{SP}:M_{SP+1}) \Rightarrow B:A$ ;<br>$(SP)+2 \Rightarrow SP$ ;<br>$(M_{SP}:M_{SP+1}) \Rightarrow X_H:X_L$ ;<br>$(SP)+4 \Rightarrow SP$ ;<br>$(M_{SP}:M_{SP+1}) \Rightarrow PC_H:PC_L$ ;<br>$(SP)+2 \Rightarrow SP$ ;<br>$(M_{SP}:M_{SP+1}) \Rightarrow Y_H:Y_L$ ;<br>$(SP)+4 \Rightarrow SP$ | INH                                                           | 0B                                                                                     | uUUUUUPPP<br>or<br>uUUUUfVfPPP*                             | Δ ↓ Δ Δ Δ Δ Δ Δ |
| *RTI takes 11 cycles if an interrupt is pending.                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                         |                                                               |                                                                                        |                                                             |                 |
| RTS                                                                                                                                                | Return from subroutine;<br>$(M_{SP}:M_{SP+1}) \Rightarrow PC_H:PC_L$ ;<br>$(SP)+2 \Rightarrow SP$                                                                                                                                                                                                                                                                                       | INH                                                           | 3D                                                                                     | UfPPP                                                       | - - - - - - - - |
| SBA                                                                                                                                                | Subtract B from A; $(A)-(B) \Rightarrow A$                                                                                                                                                                                                                                                                                                                                              | INH                                                           | 18 16                                                                                  | OO                                                          | - - - - Δ Δ Δ Δ |
| SBCA #opr8i<br>SBCA opr8a<br>SBCA opr16a<br>SBCA oprx0_xysppc<br>SBCA oprx9_xysppc<br>SBCA oprx16_xysppc<br>SBCA [D,xysppc]<br>SBCA [opr16,xysppc] | Subtract with carry from A;<br>$(A)-(M)-C \Rightarrow A$ or $(A)-imm-C \Rightarrow A$                                                                                                                                                                                                                                                                                                   | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 82 ii<br>92 dd<br>B2 hh 11<br>A2 xb<br>A2 xb ff<br>A2 xb ee ff<br>A2 xb<br>A2 xb ee ff | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfPrPf<br>fIPrPf  | - - - - Δ Δ Δ Δ |
| SBCB #opr8i<br>SBCB opr8a<br>SBCB opr16a<br>SBCB oprx0_xysppc<br>SBCB oprx9_xysppc<br>SBCB oprx16_xysppc<br>SBCB [D,xysppc]<br>SBCB [opr16,xysppc] | Subtract with carry from B;<br>$(B)-(M)-C \Rightarrow B$ or $(B)-imm-C \Rightarrow B$                                                                                                                                                                                                                                                                                                   | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | C2 ii<br>D2 dd<br>F2 hh 11<br>E2 xb<br>E2 xb ff<br>E2 xb ee ff<br>E2 xb<br>E2 xb ee ff | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfPrPf<br>fIPrPf  | - - - - Δ Δ Δ Δ |
| SEC                                                                                                                                                | Set C; assembles as ORCC #\$01                                                                                                                                                                                                                                                                                                                                                          | IMM                                                           | 14 01                                                                                  | P                                                           | - - - - - - - 1 |
| SEI                                                                                                                                                | Set I; assembles as ORCC #\$10                                                                                                                                                                                                                                                                                                                                                          | IMM                                                           | 14 10                                                                                  | P                                                           | - - - 1 - - - - |
| SEV                                                                                                                                                | Set V; assembles as ORCC #\$02                                                                                                                                                                                                                                                                                                                                                          | IMM                                                           | 14 02                                                                                  | P                                                           | - - - - - - 1 - |
| SEX abc,dxysp                                                                                                                                      | Sign extend; 8-bit r1 to 16-bit r2;<br>$\$00:(r1) \Rightarrow r2$ if r1 bit 7 is 0 or<br>$\$FF:(r1) \Rightarrow r2$ if r1, bit 7 is 1;<br>alternate mnemonic for TFR r1, r2                                                                                                                                                                                                             | INH                                                           | B7 eb                                                                                  | P                                                           | - - - - - - - - |

# Central Processing Unit (CPU)

| Source Form                                                                                                                                        | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Address Mode                                                  | Machine Coding (Hex)                                                                   | Access Detail                                                                                                         | S X H I N Z V C           |
|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|---------------------------|
| STAA opr8a<br>STAA opr16a<br>STAA oprx0_xysppc<br>STAA oprx9,xysppc<br>STAA oprx16,xysppc<br>STAA [D,xysppc]<br>STAA [opr16,xysppc]                | Store accumulator A; (A) $\Rightarrow$ M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 5A dd<br>7A hh 11<br>6A xb<br>6A xb ff<br>6A xb ee ff<br>6A xb<br>6A xb ee ff          | Pw<br>PwO<br>Pw<br>PwO<br>PwP<br>PIfw<br>PIPw                                                                         | [--- --- Δ Δ 0 ---]       |
| STAB opr8a<br>STAB opr16a<br>STAB oprx0_xysppc<br>STAB oprx9,xysppc<br>STAB oprx16,xysppc<br>STAB [D,xysppc]<br>STAB [opr16,xysppc]                | Store accumulator B; (B) $\Rightarrow$ M                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 5B dd<br>7B hh 11<br>6B xb<br>6B xb ff<br>6B xb ee ff<br>6B xb<br>6B xb ee ff          | Pw<br>PwO<br>Pw<br>PwO<br>PwP<br>PIfw<br>PIPw                                                                         | [--- --- --- Δ Δ 0 ---]   |
| STD opr8a<br>STD opr16a<br>STD oprx0_xysppc<br>STD oprx9,xysppc<br>STD oprx16,xysppc<br>STD [D,xysppc]<br>STD [opr16,xysppc]                       | Store D; (A:B) $\Rightarrow$ M:M+1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 5C dd<br>7C hh 11<br>6C xb<br>6C xb ff<br>6C xb ee ff<br>6C xb<br>6C xb ee ff          | PW<br>PWO<br>PW<br>PWO<br>PWP<br>PIfw<br>PIPw                                                                         | [--- --- --- Δ Δ 0 ---]   |
| STOP                                                                                                                                               | Stop processing; (SP) $\rightarrow$ SP;<br>RTN <sub>H</sub> :RTN <sub>L</sub> $\Rightarrow$ M <sub>SP</sub> :M <sub>SP+1</sub> ;<br>(SP) $\rightarrow$ SP; (Y <sub>H</sub> :Y <sub>L</sub> ) $\Rightarrow$ M <sub>SP</sub> :M <sub>SP+1</sub> ;<br>(SP) $\rightarrow$ SP; (X <sub>H</sub> :X <sub>L</sub> ) $\Rightarrow$ M <sub>SP</sub> :M <sub>SP+1</sub> ;<br>(SP) $\rightarrow$ SP; (B:A) $\Rightarrow$ M <sub>SP</sub> :M <sub>SP+1</sub> ;<br>(SP) $\rightarrow$ SP; (CCR) $\Rightarrow$ M <sub>SP</sub> ;<br>stop all clocks | INH                                                           | 18 3E                                                                                  | 00SSSSsf (enter stop mode)<br>fVfPPP (exit stop mode)<br>ff (continue stop mode)<br>OO (if stop mode disabled by S=1) | [--- --- --- --- --- ---] |
| STS opr8a<br>STS opr16a<br>STS oprx0_xysppc<br>STS oprx9,xysppc<br>STS oprx16,xysppc<br>STS [D,xysppc]<br>STS [opr16,xysppc]                       | Store SP; (SP <sub>H</sub> :SP <sub>L</sub> ) $\Rightarrow$ M:M+1                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 5F dd<br>7F hh 11<br>6F xb<br>6F xb ff<br>6F xb ee ff<br>6F xb<br>6F xb ee ff          | PW<br>PWO<br>PW<br>PWO<br>PWP<br>PIfw<br>PIPw                                                                         | [--- --- --- Δ Δ 0 ---]   |
| STX opr8a<br>STX opr16a<br>STX oprx0_xysppc<br>STX oprx9,xysppc<br>STX oprx16,xysppc<br>STX [D,xysppc]<br>STX [opr16,xysppc]                       | Store X; (X <sub>H</sub> :X <sub>L</sub> ) $\Rightarrow$ M:M+1                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 5E dd<br>7E hh 11<br>6E xb<br>6E xb ff<br>6E xb ee ff<br>6E xb<br>6E xb ee ff          | PW<br>PWO<br>PW<br>PWO<br>PWP<br>PIfw<br>PIPw                                                                         | [--- --- --- Δ Δ 0 ---]   |
| STY opr8a<br>STY opr16a<br>STY oprx0_xysppc<br>STY oprx9,xysppc<br>STY oprx16,xysppc<br>STY [D,xysppc]<br>STY [opr16,xysppc]                       | Store Y; (Y <sub>H</sub> :Y <sub>L</sub> ) $\Rightarrow$ M:M+1                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 5D dd<br>7D hh 11<br>6D xb<br>6D xb ff<br>6D xb ee ff<br>6D xb<br>6D xb ee ff          | PW<br>PWO<br>PW<br>PWO<br>PWP<br>PIfw<br>PIPw                                                                         | [--- --- --- Δ Δ 0 ---]   |
| SUBA #opr8i<br>SUBA opr8a<br>SUBA opr16a<br>SUBA oprx0_xysppc<br>SUBA oprx9,xysppc<br>SUBA oprx16,xysppc<br>SUBA [D,xysppc]<br>SUBA [opr16,xysppc] | Subtract from A; (A) $\rightarrow$ (M) $\Rightarrow$ A or<br>(A) $\rightarrow$ imm $\Rightarrow$ A                                                                                                                                                                                                                                                                                                                                                                                                                                   | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 80 ii<br>90 dd<br>B0 hh 11<br>A0 xb<br>A0 xb ff<br>A0 xb ee ff<br>A0 xb<br>A0 xb ee ff | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfrPf<br>fIPrPf                                                             | [--- --- --- Δ Δ Δ Δ]     |

| Source Form                                                                                                                                         | Operation                                                                                                                                                                                                                                                                        | Address Mode                                                  | Machine Coding (Hex)                                                                      | Access Detail                                              | S X H I N Z V C |
|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------|------------------------------------------------------------|-----------------|
| SUBB #opr8i<br>SUBB opr8a<br>SUBB opr16a<br>SUBB oprx0_xysppc<br>SUBB oprx9_xysppc<br>SUBB oprx16_xysppc<br>SUBB [D,xysppc]<br>SUBB [opr16,xysppc]  | Subtract from B; (B)-(M)⇒B or (B)-imm⇒B                                                                                                                                                                                                                                          | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | C0 ii<br>D0 dd<br>F0 hh 11<br>E0 xb<br>E0 xb ff<br>E0 xb ee ff<br>E0 xb<br>E0 xb ee ff    | P<br>rPf<br>rPO<br>rPf<br>rPO<br>frPP<br>fIfPrPf<br>fIPrPf | [--- Δ Δ Δ Δ Δ] |
| SUBD #opr16i<br>SUBD opr8a<br>SUBD opr16a<br>SUBD oprx0_xysppc<br>SUBD oprx9_xysppc<br>SUBD oprx16_xysppc<br>SUBD [D,xysppc]<br>SUBD [opr16,xysppc] | Subtract from D; (A:B)-(M:M+1)⇒A:B or (A:B)-imm⇒A:B                                                                                                                                                                                                                              | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 83 jj kk<br>93 dd<br>B3 hh 11<br>A3 xb<br>A3 xb ff<br>A3 xb ee ff<br>A3 xb<br>A3 xb ee ff | PO<br>RPf<br>RPO<br>RPf<br>RPO<br>frPP<br>fIfRPf<br>fIPRPf | [--- Δ Δ Δ Δ Δ] |
| SWI                                                                                                                                                 | Software interrupt; (SP)-2⇒SP;<br>$RTN_H:RTN_L \Rightarrow M_{SP}:M_{SP+1}$ ;<br>(SP)-2⇒SP; ( $Y_H:Y_L$ )⇒ $M_{SP}:M_{SP+1}$ ;<br>(SP)-2⇒SP; ( $X_H:X_L$ )⇒ $M_{SP}:M_{SP+1}$ ;<br>(SP)-2⇒SP; (B:A)⇒ $M_{SP}:M_{SP+1}$ ;<br>(SP)-1⇒SP; (CCR)⇒ $M_{SP}$ ; 1⇒l;<br>(SWI vector)⇒PC | INH                                                           | 3F                                                                                        | VSPSSPSSP*                                                 | [--- 1 --- ---] |

\*The CPU also uses VSPSSPSSP for hardware interrupts and unimplemented opcode traps. Reset uses a variation of VfPPP.

|                                                                                                                                 |                                                                                                                                                                                                                                                                                             |                                                               |                                                                                  |                                                          |                                                  |
|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------|--------------------------------------------------|
| TAB                                                                                                                             | Transfer A to B; (A)⇒B                                                                                                                                                                                                                                                                      | INH                                                           | 18 0E                                                                            | OO                                                       | [--- Δ Δ 0 ---]                                  |
| TAP                                                                                                                             | Transfer A to CCR; (A)⇒CCR;<br>assembled as TFR A, CCR                                                                                                                                                                                                                                      | INH                                                           | B7 02                                                                            | P                                                        | [Δ ↓ Δ Δ Δ Δ Δ]                                  |
| TBA                                                                                                                             | Transfer B to A; (B)⇒A                                                                                                                                                                                                                                                                      | INH                                                           | 18 0F                                                                            | OO                                                       | [--- Δ Δ 0 ---]                                  |
| TBEQ abdxysp,rel9                                                                                                               | Test and branch if equal to 0; if (register)=0, then (PC)+2+rel⇒PC                                                                                                                                                                                                                          | REL<br>(9-bit)                                                | 04 1b rr                                                                         | PPP (branch)<br>PPO (no branch)                          | [--- --- --- --- ---]                            |
| TBL oprx0_xysppc                                                                                                                | Table lookup and interpolate, 8-bit;<br>(M)+(B)×((M+1)-(M))⇒A                                                                                                                                                                                                                               | IDX                                                           | 18 3D xb                                                                         | ORffffP                                                  | [--- Δ Δ --- Δ ---]                              |
| TBNE abdxysp,rel9                                                                                                               | Test and branch if not equal to 0; if (register)≠0, then (PC)+2+rel⇒PC                                                                                                                                                                                                                      | REL<br>(9-bit)                                                | 04 1b rr                                                                         | PPP (branch)<br>PPO (no branch)                          | [--- --- --- --- ---]                            |
| TFR abcdxysp,abcdxysp                                                                                                           | Transfer register to register;<br>(r1)⇒r2; r1 and r2 same size or \$00:(r1)⇒r2; r1=8-bit; r2=16-bit or (r1L)⇒r2; r1=16-bit; r2=8-bit                                                                                                                                                        | INH                                                           | B7 eb                                                                            | P<br>or<br>[Δ ↓ Δ Δ Δ Δ Δ Δ]                             | [--- --- --- --- ---]<br>or<br>[Δ ↓ Δ Δ Δ Δ Δ Δ] |
| TPA                                                                                                                             | Transfer CCR to A; (CCR)⇒A;<br>assembles as TFR CCR ,A                                                                                                                                                                                                                                      | INH                                                           | B7 20                                                                            | P                                                        | [--- --- --- --- ---]                            |
| TRAP trapnum                                                                                                                    | Trap unimplemented opcode;<br>(SP)-2⇒SP;<br>$RTN_H:RTN_L \Rightarrow M_{SP}:M_{SP+1}$ ;<br>(SP)-2⇒SP; ( $Y_H:Y_L$ )⇒ $M_{SP}:M_{SP+1}$ ;<br>(SP)-2⇒SP; ( $X_H:X_L$ )⇒ $M_{SP}:M_{SP+1}$ ;<br>(SP)-2⇒SP; (B:A)⇒ $M_{SP}:M_{SP+1}$ ;<br>(SP)-1⇒SP; (CCR)⇒ $M_{SP}$ ;<br>1⇒l; (trap vector)⇒PC | INH                                                           | 18 tn<br>tn = \$30-\$39<br>or<br>tn = \$40-\$FF                                  | OVSPSSPSSP                                               | [--- 1 --- ---]                                  |
| TST opr16a<br>TST oprx0_xysppc<br>TST oprx9_xysppc<br>TST oprx16_xysppc<br>TST [D,xysppc]<br>TST [opr16,xysppc]<br>TSTA<br>TSTB | Test M; (M)=0<br>Test A; (A)=0<br>Test B; (B)=0                                                                                                                                                                                                                                             | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]<br>INH<br>INH | F7 hh 11<br>E7 xb<br>E7 xb ff<br>E7 xb ee ff<br>E7 xb<br>E7 xb ee ff<br>97<br>D7 | rPO<br>rPf<br>rPO<br>frPP<br>fIfPrPf<br>fIPrPf<br>O<br>O | [--- Δ Δ 0 0 0]                                  |

## Central Processing Unit (CPU)

| Source Form                                                                                                                                                                     | Operation                                                                                                                                                                                                                                                                                                                                                | Address Mode | Machine Coding (Hex) | Access Detail                                                                | S X H I N Z V C                                                   |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------------------|------------------------------------------------------------------------------|-------------------------------------------------------------------|
| TSX                                                                                                                                                                             | Transfer SP to X; (SP) $\Rightarrow$ X;<br>assembles as TFR SP,X                                                                                                                                                                                                                                                                                         | INH          | B7 75                | P                                                                            | [--- --- --- ---]                                                 |
| TSY                                                                                                                                                                             | Transfer SP to Y; (SP) $\Rightarrow$ Y;<br>assembles as TFR SP,Y                                                                                                                                                                                                                                                                                         | INH          | B7 76                | P                                                                            | [--- --- --- ---]                                                 |
| TXS                                                                                                                                                                             | Transfer X to SP; (X) $\Rightarrow$ SP;<br>assembles as TFR X,SP                                                                                                                                                                                                                                                                                         | INH          | B7 57                | P                                                                            | [--- --- --- ---]                                                 |
| TYS                                                                                                                                                                             | Transfer Y to SP; (Y) $\Rightarrow$ SP;<br>assembles as TFR Y,SP                                                                                                                                                                                                                                                                                         | INH          | B7 67                | P                                                                            | [--- --- --- ---]                                                 |
| WAI                                                                                                                                                                             | Wait for interrupt; (SP) $\rightarrow$ SP;<br>$RTN_H:RTN_L \Rightarrow M_{SP}:M_{SP+1}$ ;<br>(SP) $\rightarrow$ SP; ( $Y_H:Y_L \Rightarrow M_{SP}:M_{SP+1}$ );<br>(SP) $\rightarrow$ SP; ( $X_H:X_L \Rightarrow M_{SP}:M_{SP+1}$ );<br>(SP) $\rightarrow$ SP; (B:A) $\Rightarrow M_{SP}:M_{SP+1}$ ;<br>(SP) $\rightarrow$ SP; (CCR) $\Rightarrow M_{SP}$ | INH          | 3E                   | OSSSSsf<br>(before interrupt)<br>EVFPPP<br>(after interrupt)                 | [--- --- --- ---]<br>or<br>[--- 1 --- ---]<br>or<br>[1 1 --- ---] |
| WAV                                                                                                                                                                             | Calculate weighted average; sum of products (SOP) and sum of weights (SOW)*<br>$B$<br>$\sum_{i=1}^B S_i F_i \Rightarrow Y:D$<br>$B$<br>$\sum_{i=1}^B F_i \Rightarrow X$                                                                                                                                                                                  | Special      | 18 3C                | O(frr <sup>ffff</sup> )O**<br>SSS+UUUrr <sup>****</sup>                      | [--- ? -? Δ ? ?]                                                  |
| wavr*                                                                                                                                                                           | Resume executing interrupted WAV                                                                                                                                                                                                                                                                                                                         | Special      | 3C                   | UUUrr <sup>ffff</sup> (frr <sup>ffff</sup> )O**<br>SSS+UUUrr <sup>****</sup> | [--- ? -? Δ ? ?]                                                  |
| *Initialize B, X, and Y: B=number of elements; X points at first element in $S_i$ list; Y points at first element in $F_i$ list. All $S_i$ and $F_i$ elements are 8-bit values. |                                                                                                                                                                                                                                                                                                                                                          |              |                      |                                                                              |                                                                   |
| **The frr <sup>ffff</sup> sequence is the loop for one iteration of SOP and SOW accumulation. The ^ denotes a check for pending interrupt requests.                             |                                                                                                                                                                                                                                                                                                                                                          |              |                      |                                                                              |                                                                   |
| ***These are additional cycles caused by an interrupt: SSS is the exit sequence and UUUrr <sup>^</sup> is the re-entry sequence. Intermediate values use six stack bytes.       |                                                                                                                                                                                                                                                                                                                                                          |              |                      |                                                                              |                                                                   |
| XGDX                                                                                                                                                                            | Exchange D with X; (D) $\leftrightarrow$ (X);<br>assembles as EXG D,X                                                                                                                                                                                                                                                                                    | INH          | B7 C5                | P                                                                            | [--- --- --- ---]                                                 |
| XGDY                                                                                                                                                                            | Exchange D with Y; (D) $\leftrightarrow$ (Y);<br>assembles as EXG D,Y                                                                                                                                                                                                                                                                                    | INH          | B7 C6                | P                                                                            | [--- --- --- ---]                                                 |

## Pinout and Signal Description



Note: This pinout is for the 112-pin version of the device.  
Pins shown in bold are not available on the 80-pin version.

Figure 3 Pin Assignments in 112-pin LQFP for MC9S12DP256