

## *68HC12 and HCS12 Instruction Set \**

\*Used with permission of Motorola, Inc.

A-1

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. This material is protected under all copyright laws as they currently exist. No portion of this material may be reproduced, in any form or by any means, without permission in writing from the publisher

For the exclusive use of adopters of the book Embedded Systems: Design and Applications with the 68HC12 and HCS12,  
by Steven F. Barrett and Daniel J. Pack. ISBN 0-13-140141-6.

**Notation Used in Instruction Set Summary****Explanation of Italic Expressions in Source Form Column**

*abc* — A or B or CCR  
*abcdxys* — A or B or CCR or D or X or Y or SP. Some assemblers also allow T2 or T3.  
*abd* — A or B or D  
*abdxys* — A or B or D or X or Y or SP  
*dxys* — D or X or Y or SP  
*msk8* — 8-bit mask, some assemblers require # symbol before value  
*opr8i* — 8-bit immediate value  
*opr16i* — 16-bit immediate value  
*opr8a* — 8-bit address used with direct address mode  
*opr16a* — 16-bit address value  
*opr0\_xyssp* — Indexed addressing postbyte code:  
    *opr3,-xys* Predecrement X or Y or SP by 1 . . . 8  
    *opr3,+xys* Preincrement X or Y or SP by 1 . . . 8  
    *opr3,xyss-* Postdecrement X or Y or SP by 1 . . . 8  
    *opr3,xyss+* Postincrement X or Y or SP by 1 . . . 8  
    *opr5,xyssp* 5-bit constant offset from X or Y or SP or PC  
    *abd,xyssp* Accumulator A or B or D offset from X or Y or SP or PC  
*opr3* — Any positive integer 1 . . . 8 for pre/post increment/decrement  
*opr5* — Any value in the range -16 . . . +15  
*opr9* — Any value in the range -256 . . . +255  
*opr16* — Any value in the range -32,768 . . . 65,535  
*page* — 8-bit value for PPAGE, some assemblers require # symbol before this value  
*rel8* — Label of branch destination within -256 to +255 locations  
*rel9* — Label of branch destination within -512 to +511 locations  
*rel16* — Any label within 64K memory space  
*trapnum* — Any 8-bit value in the range \$30-\$39 or \$40-\$FF  
*xys* — X or Y or SP  
*xyssp* — X or Y or SP or PC



## CPU12 REFERENCE GUIDE

## Address Modes

|          |                                                                                                                                                 |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| IMM      | — Immediate                                                                                                                                     |
| IDX      | — Indexed (no extension bytes) includes:<br>5-bit constant offset<br>Pre/post increment/decrement by 1 . . . 8<br>Accumulator A, B, or D offset |
| IDX1     | — 9-bit signed offset (1 extension byte)                                                                                                        |
| IDX2     | — 16-bit signed offset (2 extension bytes)                                                                                                      |
| [D, IDX] | — Indexed indirect (accumulator D offset)                                                                                                       |
| [IDX2]   | — Indexed indirect (16-bit offset)                                                                                                              |
| INH      | — Inherent (no operands in object code)                                                                                                         |
| REL      | — 2's complement relative offset (branches)                                                                                                     |

## Machine Coding

|    |                                                                                                                                                                                             |
|----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| dd | — 8-bit direct address \$0000 to \$00FF. (High byte assumed to be \$00).                                                                                                                    |
| ee | — High-order byte of a 16-bit constant offset for indexed addressing.                                                                                                                       |
| eb | — Exchange/Transfer post-byte.                                                                                                                                                              |
| ff | — Low-order eight bits of a 9-bit signed constant offset for indexed addressing,<br>or low-order byte of a 16-bit constant offset for indexed addressing.                                   |
| hh | — High-order byte of a 16-bit extended address.                                                                                                                                             |
| ii | — 8-bit immediate data value.                                                                                                                                                               |
| jj | — High-order byte of a 16-bit immediate data value.                                                                                                                                         |
| kk | — Low-order byte of a 16-bit immediate data value.                                                                                                                                          |
| 1b | — Loop primitive (DBNE) post-byte.                                                                                                                                                          |
| 11 | — Low-order byte of a 16-bit extended address.                                                                                                                                              |
| mm | — 8-bit immediate mask value for bit manipulation instructions.<br>Set bits indicate bits to be affected.                                                                                   |
| pg | — Program page (bank) number used in CALL instruction.                                                                                                                                      |
| qq | — High-order byte of a 16-bit relative offset for long branches.                                                                                                                            |
| tn | — Trap number \$30-\$39 or \$40-\$FF.                                                                                                                                                       |
| rr | — Signed relative offset \$80 (-128) to \$7F (+127).<br>Offset relative to the byte following the relative offset byte, or<br>low-order byte of a 16-bit relative offset for long branches. |
| xb | — Indexed addressing post-byte.                                                                                                                                                             |



### Access Detail

Each code letter equals one CPU cycle. Uppercase = 16-bit operation and lowercase = 8-bit operation. For complex sequences see the *CPU12 Reference Manual* (CPU12RM/AD).

- f — Free cycle, CPU doesn't use bus
- g — Read PPAGE internally
- I — Read indirect pointer (indexed indirect)
- i — Read indirect PPAGE value (call indirect)
- n — Write PPAGE internally
- o — Optional program word fetch (P) if instruction is misaligned and has an odd number of bytes of object code — otherwise, appears as a free cycle (f)
- p — Program word fetch (always an aligned word read)
- r — 8-bit data read
- R — 16-bit data read
- s — 8-bit stack write
- S — 16-bit stack write
- w — 8-bit data write
- W — 16-bit data write
- u — 8-bit stack read
- v — 16-bit stack read
- V — 16-bit vector fetch
- t — 8-bit conditional read (or free cycle)
- T — 16-bit conditional read (or free cycle)
- x — 8-bit conditional write

### Special Cases

- PPP/P — Short branch, PPP if branch taken, P if not
- OPPP/OPO — Long branch, OPPP if branch taken, OPO if not

### Condition Codes Columns

- — 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 is not cleared by operation.
- ? — Status bit may be changed by operation but the final state is not defined.
- ! — Status bit used for a special purpose.

| Source Form | Operation                                                  | Addr. Mode                                                    | Machine Coding (hex)                                                                      | ~                                    | * | S | X        | H | I        | N        | Z        | V        | C        |
|-------------|------------------------------------------------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------|---|---|----------|---|----------|----------|----------|----------|----------|
| ABA         | (A) + (B) $\Rightarrow$ A<br>Add Accumulators A and B      | INH                                                           | 18 06                                                                                     | 2                                    | - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| ABX         | (B) + (X) $\Rightarrow$ X<br><i>Translates to LEAX B,X</i> | IDX                                                           | 1A E5                                                                                     | 2                                    | - | - | -        | - | -        | -        | -        | -        | -        |
| ABY         | (B) + (Y) $\Rightarrow$ Y<br><i>Translates to LEAY B,Y</i> | IDX                                                           | 19 ED                                                                                     | 2                                    | - | - | -        | - | -        | -        | -        | -        | -        |
| ADCA opr    | (A) + (M) + C $\Rightarrow$ A<br>Add with Carry to 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 ll<br>A9 xb<br>A9 xb ff<br>A9 xb ee ff<br>A9 xb<br>A9 xb ee ff    | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |          |
| ADCB opr    | (B) + (M) + C $\Rightarrow$ B<br>Add with Carry to 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 ll<br>E9 xb<br>E9 xb ff<br>E9 xb ee ff<br>E9 xb<br>E9 xb ee ff    | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |          |
| ADDA opr    | (A) + (M) $\Rightarrow$ A<br>Add without Carry to 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 ll<br>AB xb<br>AB xb ff<br>AB xb ee ff<br>AB xb<br>AB xb ee ff    | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |          |
| ADDB opr    | (B) + (M) $\Rightarrow$ B<br>Add without Carry to 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 ll<br>EB xb<br>EB xb ff<br>EB xb ee ff<br>EB xb<br>EB xb ee ff    | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | $\Delta$ | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |          |
| ADDD opr    | (A:B) + (M:M+1) $\Rightarrow$ A:B<br>Add 16-Bit to D (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 ll<br>E3 xb<br>E3 xb ff<br>E3 xb ee ff<br>E3 xb<br>E3 xb ee ff | 2<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | -        | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |          |

| Source Form   | Operation                                                                                                           | Addr. Mode                                                    | Machine Coding (hex)                                                                   | $\sim$                               | S            | X            | H            | I            | N            | Z            | V            | C            |
|---------------|---------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| ANDA opr      | (A) • (M) $\Rightarrow$ A<br>Logical And A with Memory                                                              | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 84 ii<br>94 dd<br>94 hh ll<br>A4 xb<br>A4 xb ff<br>A4 xb ee ff<br>A4 xb<br>A4 xb ee ff | 1<br>3<br>3<br>3<br>3<br>4<br>5<br>6 | -            | -            | -            | -            | $\Delta$     | $\Delta$     | 0            | -            |
| ANDB opr      | (B) • (M) $\Rightarrow$ B<br>Logical And B with Memory                                                              | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | C4 ii<br>D4 dd<br>F4 hh ll<br>E4 xb<br>E4 xb ff<br>E4 xb ee ff<br>E4 xb<br>E4 xb ee ff | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | -            | -            | -            | -            | $\Delta$     | $\Delta$     | 0            | -            |
| ANDCC opr     | (CCR) • (M) $\Rightarrow$ CCR<br>Logical And CCR with Memory                                                        | IMM                                                           | 10 ii                                                                                  | 1                                    | $\Downarrow$ |
| ASL opr       | <br>Arithmetic Shift Left          | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]               | 78 hh ll<br>68 xb<br>68 xb ff<br>68 xb ee ff<br>68 xb<br>68 xb ee ff                   | 4<br>3<br>4<br>5<br>6<br>6           | -            | -            | -            | -            | $\Delta$     | $\Delta$     | $\Delta$     | $\Delta$     |
| ASLA<br>ASLB  | Arithmetic Shift Left Accumulator A<br>Arithmetic Shift Left Accumulator B                                          | INH<br>INH                                                    | 48<br>58                                                                               | 1<br>1                               |              |              |              |              |              |              |              |              |
| ASLD          | <br>Arithmetic Shift Left Double | INH                                                           | 59                                                                                     | 1                                    | -            | -            | -            | -            | $\Delta$     | $\Delta$     | $\Delta$     | $\Delta$     |
| ASR opr       | <br>Arithmetic Shift Right       | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]               | 77 hh ll<br>67 xb<br>67 xb ff<br>67 xb ee ff<br>67 xb<br>67 xb ee ff                   | 4<br>3<br>4<br>5<br>6<br>6           | -            | -            | -            | -            | $\Delta$     | $\Delta$     | $\Delta$     | $\Delta$     |
| ASRA<br>ASRB  | Arithmetic Shift Right Accumulator A<br>Arithmetic Shift Right Accumulator B                                        | INH<br>INH                                                    | 47<br>57                                                                               | 1<br>1                               |              |              |              |              |              |              |              |              |
| BCC rel       | Branch if Carry Clear (if C = 0)                                                                                    | REL                                                           | 24 rr                                                                                  | 3/1                                  | -            | -            | -            | -            | -            | -            | -            | -            |
| BCLR opr, msk | (M) • (mm) $\Rightarrow$ M<br>Clear Bit(s) in Memory                                                                | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2                             | 4D dd mm<br>1D hh ll mm<br>0D xb mm<br>0D xb ff mm<br>0D xb ee ff mm                   | 4<br>4<br>4<br>4<br>6                | -            | -            | -            | -            | $\Delta$     | $\Delta$     | 0            | -            |
| BCS rel       | Branch if Carry Set (if C = 1)                                                                                      | REL                                                           | 25 rr                                                                                  | 3/1                                  | -            | -            | -            | -            | -            | -            | -            | -            |
| BEQ rel       | Branch if Equal (if Z = 1)                                                                                          | REL                                                           | 27 rr                                                                                  | 3/1                                  | -            | -            | -            | -            | -            | -            | -            | -            |
| BGE rel       | Branch if Greater Than or Equal<br>(if N $\oplus$ V = 0) (signed)                                                   | REL                                                           | 2C rr                                                                                  | 3/1                                  | -            | -            | -            | -            | -            | -            | -            | -            |
| BGND          | Place CPU in Background Mode<br>see Background Mode section.                                                        | INH                                                           | 00                                                                                     | 5                                    | -            | -            | -            | -            | -            | -            | -            | -            |
| BGT rel       | Branch if Greater Than<br>(if Z + (N $\oplus$ V) = 0) (signed)                                                      | REL                                                           | 2E rr                                                                                  | 3/1                                  | -            | -            | -            | -            | -            | -            | -            | -            |
| BHI rel       | Branch if Higher<br>(if C + Z = 0) (unsigned)                                                                       | REL                                                           | 22 rr                                                                                  | 3/1                                  | -            | -            | -            | -            | -            | -            | -            | -            |

| Source Form                | Operation                                                                                                                                            | Addr. Mode                                                    | Machine Coding (hex)                                                                   | $\sim$                               | S | X | H | I | N | Z | V | C |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------|---|---|---|---|---|---|---|---|
| BHS <i>rel</i>             | Branch if Higher or Same<br>(if C = 0) (unsigned)<br>same function as BCC                                                                            | REL                                                           | 24 rr                                                                                  | 3/1                                  | - | - | - | - | - | - | - | - |
| BITA <i>opr</i>            | (A) • (M)<br>Logical And A with Memory                                                                                                               | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 85 ii<br>95 dd<br>85 hh ll<br>A5 xb<br>A5 xb ff<br>A5 xb ee ff<br>A5 xb<br>A5 xb ee ff | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | Δ | Δ | 0 | - |
| BITB <i>opr</i>            | (B) • (M)<br>Logical And B with Memory                                                                                                               | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | C5 ii<br>D5 dd<br>F5 hh ll<br>E5 xb<br>E5 xb ff<br>E5 xb ee ff<br>E5 xb<br>E5 xb ee ff | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | Δ | Δ | 0 | - |
| BLE <i>rel</i>             | Branch if Less Than or Equal<br>(if Z + (N ⊕ V) = 1) (signed)                                                                                        | REL                                                           | 2F rr                                                                                  | 3/1                                  | - | - | - | - | - | - | - | - |
| BLO <i>rel</i>             | Branch if Lower<br>(if C = 1) (unsigned)<br>same function as BCS                                                                                     | REL                                                           | 25 rr                                                                                  | 3/1                                  | - | - | - | - | - | - | - | - |
| BLS <i>rel</i>             | Branch if Lower or Same<br>(if C + Z = 1) (unsigned)                                                                                                 | REL                                                           | 23 rr                                                                                  | 3/1                                  | - | - | - | - | - | - | - | - |
| BLT <i>rel</i>             | Branch if Less Than<br>(if N ⊕ V = 1) (signed)                                                                                                       | REL                                                           | 2D rr                                                                                  | 3/1                                  | - | - | - | - | - | - | - | - |
| BMI <i>rel</i>             | Branch if Minus (if N = 1)                                                                                                                           | REL                                                           | 2B rr                                                                                  | 3/1                                  | - | - | - | - | - | - | - | - |
| BNE <i>rel</i>             | Branch if Not Equal (if Z = 0)                                                                                                                       | REL                                                           | 26 rr                                                                                  | 3/1                                  | - | - | - | - | - | - | - | - |
| BPL <i>rel</i>             | Branch if Plus (if N = 0)                                                                                                                            | REL                                                           | 2A rr                                                                                  | 3/1                                  | - | - | - | - | - | - | - | - |
| BRA <i>rel</i>             | Branch Always (if 1 = 1)                                                                                                                             | REL                                                           | 20 rr                                                                                  | 3                                    | - | - | - | - | - | - | - | - |
| BRCLR <i>opr, msk, rel</i> | Branch if (M) • (mm) = 0<br>(if All Selected Bit(s) Clear)                                                                                           | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2                             | 4F dd mm rr<br>1F hh ll mm rr<br>0F xb mm rr<br>0F xb ff mm rr<br>0F xb ee ff mm rr    | 4<br>5<br>4<br>6<br>8                | - | - | - | - | - | - | - | - |
| BRN <i>rel</i>             | Branch Never (if 1 = 0)                                                                                                                              | REL                                                           | 21 rr                                                                                  | 1                                    | - | - | - | - | - | - | - | - |
| BRSET <i>opr, msk, rel</i> | Branch if ( $\bar{M}$ ) • (mm) = 0<br>(if All Selected Bit(s) Set)                                                                                   | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2                             | 4E dd mm rr<br>1E hh ll mm rr<br>0E xb mm rr<br>0E xb ff mm rr<br>0E xb ee ff mm rr    | 4<br>5<br>4<br>6<br>8                | - | - | - | - | - | - | - | - |
| BSET <i>opr, msk</i>       | (M) + (mm) ⇒ M<br>Set Bit(s) in Memory                                                                                                               | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2                             | 4C dd mm<br>1C hh ll mm<br>0C xb mm<br>0C xb ff mm<br>0C xb ee ff mm                   | 4<br>4<br>4<br>4<br>6                | - | - | - | - | Δ | Δ | 0 | - |
| BSR <i>rel</i>             | (SP) - 2 ⇒ SP;<br>RTN <sub>H</sub> ;RTN <sub>L</sub> ⇒ M <sub>(SP)</sub> ;M <sub>(SP+1)</sub><br>Subroutine address ⇒ PC<br><br>Branch to Subroutine | REL                                                           | 07 rr                                                                                  | 4                                    | - | - | - | - | - | - | - | - |

| Source Form                | Operation                                                                                                                                                                                                                                                                                                                                                                      | Addr. Mode                                                    | Machine Coding (hex)                                                                   | $\sim$                               | S | X | H | I | N        | Z        | V        | C        |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------|---|---|---|---|----------|----------|----------|----------|
| BVC rel                    | Branch if Overflow Bit Clear (if V = 0)                                                                                                                                                                                                                                                                                                                                        | REL                                                           | 28 rr                                                                                  | 3/1                                  | - | - | - | - | -        | -        | -        | -        |
| BVS rel                    | Branch if Overflow Bit Set (if V = 1)                                                                                                                                                                                                                                                                                                                                          | REL                                                           | 29 rr                                                                                  | 3/1                                  | - | - | - | - | -        | -        | -        | -        |
| CALL opr, page             | (SP) - 2 $\Rightarrow$ SP;<br>RTN <sub>U</sub> ;RTN <sub>L</sub> $\Rightarrow$ M <sub>(SP)</sub> :M <sub>(SP+1)</sub><br>(SP) - 1 $\Rightarrow$ SP;<br>(PPG) $\Rightarrow$ M <sub>(SP)</sub> ;<br>pg $\Rightarrow$ PPAGE register;<br>Program address $\Rightarrow$ PC<br><br>Call subroutine in extended memory<br>(Program may be located on another expansion memory page.) | EXT<br>IDX<br>IDX1<br>IDX2                                    | 4A hh ll pg<br>4B xb pg<br>4B xb ff pg<br>4B xb ee ff pg                               | 8<br>8<br>8<br>9                     | - | - | - | - | -        | -        | -        | -        |
| CALL [D,r]<br>CALL [opr,r] | Indirect modes get program address and new pg value based on pointer.<br><br>r = X, Y, SP, or PC                                                                                                                                                                                                                                                                               | [D,IDX]<br>[IDX2]                                             | 4B xb<br>4B xb ee ff                                                                   | 10<br>10                             | - | - | - | - | -        | -        | -        | -        |
| CBA                        | (A) - (B)<br>Compare 8-Bit Accumulators                                                                                                                                                                                                                                                                                                                                        | INH                                                           | 18 17                                                                                  | 2                                    | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CLC                        | 0 $\Rightarrow$ C<br><i>Translates to ANDCC #\$FE</i>                                                                                                                                                                                                                                                                                                                          | IMM                                                           | 10 FE                                                                                  | 1                                    | - | - | - | - | -        | -        | -        | 0        |
| CLI                        | 0 $\Rightarrow$ I<br><i>Translates to ANDCC #\$EF</i><br>(enables I-bit interrupts)                                                                                                                                                                                                                                                                                            | IMM                                                           | 10 EF                                                                                  | 1                                    | - | - | - | 0 | -        | -        | -        | -        |
| CLR opr                    | 0 $\Rightarrow$ M Clear Memory Location                                                                                                                                                                                                                                                                                                                                        | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]               | 79 hh ll<br>69 xb<br>69 xb ff<br>69 xb ee ff<br>69 xb<br>69 xb ee ff                   | 3<br>2<br>3<br>3<br>5<br>5           | - | - | - | - | 0        | 1        | 0        | 0        |
| CLRA<br>CLRB               | 0 $\Rightarrow$ A Clear Accumulator A<br>0 $\Rightarrow$ B Clear Accumulator B                                                                                                                                                                                                                                                                                                 | INH<br>INH                                                    | 87<br>C7                                                                               | 1<br>1                               |   |   |   |   |          |          |          |          |
| CLV                        | 0 $\Rightarrow$ V<br><i>Translates to ANDCC #\$FD</i>                                                                                                                                                                                                                                                                                                                          | IMM                                                           | 10 FD                                                                                  | 1                                    | - | - | - | - | -        | -        | 0        | -        |
| CMPA opr                   | (A) - (M)<br>Compare Accumulator A with Memory                                                                                                                                                                                                                                                                                                                                 | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | B1 ii<br>91 dd<br>B1 hh ll<br>A1 xb<br>A1 xb ff<br>A1 xb ee ff<br>A1 xb<br>A1 xb ee ff | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CMPB opr                   | (B) - (M)<br>Compare Accumulator B with Memory                                                                                                                                                                                                                                                                                                                                 | 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 | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

| Source Form    | Operation                                                                                                                                                                                | Addr. Mode                                                    | Machine Coding (hex)                                                                      | -                                    | S | X | H | I | N        | Z        | V        | C        |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------|---|---|---|---|----------|----------|----------|----------|
| COM opr        | $(\bar{M}) \Rightarrow M$ equivalent to \$FF – $(M) \Rightarrow M$<br>1's Complement Memory Location                                                                                     | 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          | 4<br>3<br>4<br>5<br>6<br>6<br>1<br>1 | - | - | - | - | $\Delta$ | $\Delta$ | 0        | 1        |
| COMA<br>COMB   | $(\bar{A}) \Rightarrow A$ Complement Accumulator A<br>$(\bar{B}) \Rightarrow B$ Complement Accumulator B                                                                                 |                                                               |                                                                                           |                                      |   |   |   |   |          |          |          |          |
| CPD opr        | $(A:B) - (M:M+1)$<br>Compare D to Memory (16-Bit)                                                                                                                                        | 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 | 2<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CPS opr        | $(SP) - (M:M+1)$<br>Compare SP to Memory (16-Bit)                                                                                                                                        | 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 | 2<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CPX opr        | $(X) - (M:M+1)$<br>Compare X to Memory (16-Bit)                                                                                                                                          | 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 | 2<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| CPY opr        | $(Y) - (M:M+1)$<br>Compare Y to Memory (16-Bit)                                                                                                                                          | 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 | 2<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| DAA            | Adjust Sum to BCD<br>Decimal Adjust Accumulator A                                                                                                                                        | INH                                                           | 18 07                                                                                     | 3                                    | - | - | - | - | $\Delta$ | $\Delta$ | ?        | $\Delta$ |
| DBEQ cntr, rel | $(cntr) - 1 \Rightarrow cntr$<br>if $(cntr) = 0$ , then Branch<br>else Continue to next instruction<br><br>Decrement Counter and Branch if = 0<br>(cntr = A, B, D, X, Y, or SP)          | REL<br>(9-bit)                                                | 04 lb rr                                                                                  | 3                                    | - | - | - | - | -        | -        | -        | -        |
| DBNE cntr, rel | $(cntr) - 1 \Rightarrow cntr$<br>If $(cntr) \neq 0$ , then Branch;<br>else Continue to next instruction<br><br>Decrement Counter and Branch if $\neq 0$<br>(cntr = A, B, D, X, Y, or SP) | REL<br>(9-bit)                                                | 04 lb rr                                                                                  | 3                                    | - | - | - | - | -        | -        | -        | -        |

| Source Form    | Operation                                                                                                                                                           | Addr. Mode                                      | Machine Coding (hex)                                                    | *                          | S | X | H | I | N        | Z        | V        | C        |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|-------------------------------------------------------------------------|----------------------------|---|---|---|---|----------|----------|----------|----------|
| DEC <i>opr</i> | (M) - \$01 $\Rightarrow$ M<br>Decrement Memory Location                                                                                                             | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 73 hh ll<br>63 xb<br>63 xb ff<br>63 xb ee ff<br>63 xb<br>63 xb ee ff    | 4<br>3<br>4<br>5<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | -        |
| DECA           | (A) - \$01 $\Rightarrow$ A                                                                                                                                          | Decrement A                                     | INH                                                                     | 1                          |   |   |   |   |          |          |          |          |
| DECB           | (B) - \$01 $\Rightarrow$ B                                                                                                                                          | Decrement B                                     | INH                                                                     | 1                          |   |   |   |   |          |          |          |          |
| DES            | (SP) - \$0001 $\Rightarrow$ SP<br><i>Translates to LEAS -1,SP</i>                                                                                                   | IDX                                             | 1B 9F                                                                   | 2                          | - | - | - | - | -        | -        | -        | -        |
| DEX            | (X) - \$0001 $\Rightarrow$ X<br>Decrement Index Register X                                                                                                          | INH                                             | 09                                                                      | 1                          | - | - | - | - | -        | $\Delta$ | -        | -        |
| DEY            | (Y) - \$0001 $\Rightarrow$ Y<br>Decrement Index Register Y                                                                                                          | INH                                             | 03                                                                      | 1                          | - | - | - | - | -        | $\Delta$ | -        | -        |
| EDIV           | (Y:D) + (X) $\Rightarrow$ Y Remainder $\Rightarrow$ D<br>32 $\times$ 16 Bit $\Rightarrow$ 16 Bit Divide (unsigned)                                                  | INH                                             | 11                                                                      | 11                         | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EDIVS          | (Y:D) + (X) $\Rightarrow$ Y Remainder $\Rightarrow$ D<br>32 $\times$ 16 Bit $\Rightarrow$ 16 Bit Divide (signed)                                                    | INH                                             | 18 14                                                                   | 12                         | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMACS sum      | $(M_{(X)}:M_{(X+1)}) \times (M_{(Y)}:M_{(Y+1)}) + (M-M+3) \Rightarrow M-M+3$<br><br>16 $\times$ 16 Bit $\Rightarrow$ 32 Bit<br>Multiply and Accumulate (signed)     | Special                                         | 18 12 hh ll                                                             | 13                         | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMAXD opr      | $\text{MAX}((D), (M:M+1)) \Rightarrow D$<br>MAX of 2 Unsigned 16-Bit Values<br><br>N, Z, V and C status bits reflect result of internal 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 | 4<br>4<br>5<br>7<br>7      | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMAXM opr      | $\text{MAX}((D), (M:M+1)) \Rightarrow M:M+1$<br>MAX of 2 Unsigned 16-Bit Values<br><br>N, Z, V and C status bits reflect result of internal 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 | 4<br>5<br>6<br>7<br>7      | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMIND opr      | $\text{MIN}((D), (M:M+1)) \Rightarrow D$<br>MIN of 2 Unsigned 16-Bit Values<br><br>N, Z, V and C status bits reflect result of internal 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 | 4<br>4<br>5<br>7<br>7      | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMINM opr      | $\text{MIN}((D), (M:M+1)) \Rightarrow M:M+1$<br>MIN of 2 Unsigned 16-Bit Values<br><br>N, Z, V and C status bits reflect result of internal 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 | 4<br>5<br>6<br>7<br>7      | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| EMUL           | $(D) \times (Y) \Rightarrow Y:D$<br>16 $\times$ 16 Bit Multiply (unsigned)                                                                                          | INH                                             | 13                                                                      | 3                          | - | - | - | - | $\Delta$ | $\Delta$ | -        | $\Delta$ |
| EMULS          | $(D) \times (Y) \Rightarrow Y:D$<br>16 $\times$ 16 Bit Multiply (signed)                                                                                            | INH                                             | 18 13                                                                   | 3                          | - | - | - | - | $\Delta$ | $\Delta$ | -        | $\Delta$ |

| Source Form    | Operation                                                                                                                                                                                                                                                                        | Addr. Mode                                                    | Machine Coding (hex)                                                                   | -                                    | S | X | H | I | N        | Z        | V        | C        |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------|---|---|---|---|----------|----------|----------|----------|
| EORA opr       | (A) $\oplus$ (M) $\Rightarrow$ A<br>Exclusive-OR A with Memory                                                                                                                                                                                                                   | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | B8 ii<br>98 dd<br>B8 hh ll<br>A8 xb<br>A8 xb ff<br>A8 xb ee ff<br>A8 xb<br>A8 xb ee ff | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | 0        | -        |
| EORB opr       | (B) $\oplus$ (M) $\Rightarrow$ B<br>Exclusive-OR B with Memory                                                                                                                                                                                                                   | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | C8 ii<br>D8 dd<br>F8 hh ll<br>E8 xb<br>E8 xb ff<br>E8 xb ee ff<br>E8 xb<br>E8 xb ee ff | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | 0        | -        |
| ETBL opr       | $(M:M+1) + [(B) \times ((M+2:M+3) - (M:M+1))] \Rightarrow D$<br>16-Bit Table Lookup and Interpolate<br><br>Initialize B, and index before ETBL.<br><ea> points at first table entry (M:M+1)<br>and B is fractional part of lookup value<br><br>(no indirect addr. modes allowed) | IDX                                                           | 18 3F xb                                                                               | 10                                   | - | - | - | - | $\Delta$ | $\Delta$ | -        | ?        |
| EXG r1, r2     | $(r1) \leftrightarrow (r2)$ (if r1 and r2 same size) or<br>$\$00:(r1) \Rightarrow (r2)$ (if r1=8-bit; r2=16-bit) or<br>$(r1_{low}) \leftrightarrow (r2)$ (if r1=16-bit; r2=8-bit)<br><br>r1 and r2 may be<br>A, B, CCR, D, X, Y, or SP                                           | INH                                                           | B7 eb                                                                                  | 1                                    | - | - | - | - | -        | -        | -        | -        |
| FDIV           | $(D) \div (X) \Rightarrow X; r \Rightarrow D$<br>16 $\times$ 16 Bit Fractional Divide                                                                                                                                                                                            | INH                                                           | 18 11                                                                                  | 12                                   | - | - | - | - | -        | $\Delta$ | $\Delta$ | $\Delta$ |
| IBEQ cntr, rel | (cntr) + 1 $\Rightarrow$ cntr<br>if (cntr) = 0, then Branch<br>else Continue to next instruction<br><br>Increment Counter and Branch if = 0<br>(cntr = A, B, D, X, Y, or SP)                                                                                                     | REL (9-bit)                                                   | 04 lb rr                                                                               | 3                                    | - | - | - | - | -        | -        | -        | -        |
| IBNE cntr, rel | (cntr) + 1 $\Rightarrow$ cntr<br>if (cntr) not = 0, then Branch;<br>else Continue to next instruction<br><br>Increment Counter and Branch if $\neq$ 0<br>(cntr = A, B, D, X, Y, or SP)                                                                                           | REL (9-bit)                                                   | 04 lb rr                                                                               | 3                                    | - | - | - | - | -        | -        | -        | -        |
| IDIV           | $(D) \div (X) \Rightarrow X; r \Rightarrow D$<br>16 $\times$ 16 Bit Integer Divide (unsigned)                                                                                                                                                                                    | INH                                                           | 18 10                                                                                  | 12                                   | - | - | - | - | -        | $\Delta$ | 0        | $\Delta$ |
| IDIVS          | $(D) \div (X) \Rightarrow X; r \Rightarrow D$<br>16 $\times$ 16 Bit Integer Divide (signed)                                                                                                                                                                                      | INH                                                           | 18 15                                                                                  | 12                                   | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

| Source Form | Operation                                                                                                                                                      | Addr. Mode                                             | Machine Coding (hex)                                                          | ~                               | S | X | H | I | N | Z        | V        | C |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------|---|---|---|---|---|----------|----------|---|
| INC opr     | (M) + \$01 $\Rightarrow$ M<br>Increment Memory Byte                                                                                                            | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 72 hh ll<br>62 xb<br>62 xb ff<br>62 xb ee ff<br>62 xb<br>62 xb ee ff          | 4<br>3<br>4<br>5<br>6<br>6      | - | - | - | - | - | $\Delta$ | $\Delta$ | - |
| INCA        | (A) + \$01 $\Rightarrow$ A                                                                                                                                     | INH                                                    | 42                                                                            | 1                               | - | - | - | - | - | -        | -        | - |
| INCB        | (B) + \$01 $\Rightarrow$ B                                                                                                                                     | INH                                                    | 52                                                                            | 1                               | - | - | - | - | - | $\Delta$ | -        | - |
| INS         | (SP) + \$0001 $\Rightarrow$ SP<br><i>Translates to LEAS 1,SP</i>                                                                                               | IDX                                                    | 1B 81                                                                         | 2                               | - | - | - | - | - | -        | -        | - |
| INX         | (X) + \$0001 $\Rightarrow$ X<br>Increment Index Register X                                                                                                     | INH                                                    | 08                                                                            | 1                               | - | - | - | - | - | $\Delta$ | -        | - |
| INY         | (Y) + \$0001 $\Rightarrow$ Y<br>Increment Index Register Y                                                                                                     | INH                                                    | 02                                                                            | 1                               | - | - | - | - | - | $\Delta$ | -        | - |
| JMP opr     | Subroutine address $\Rightarrow$ PC                                                                                                                            | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 06 hh ll<br>05 xb<br>05 xb ff<br>05 xb ee ff<br>05 xb<br>05 xb ee ff          | 3<br>3<br>3<br>4<br>6<br>6      | - | - | - | - | - | -        | -        | - |
|             | Jump                                                                                                                                                           |                                                        |                                                                               |                                 |   |   |   |   |   |          |          |   |
| JSR opr     | (SP) - 2 $\Rightarrow$ SP;<br>RTN <sub>H</sub> ;RTN <sub>L</sub> $\Rightarrow$ M <sub>(SP)</sub> ;M <sub>(SP+1)</sub> ;<br>Subroutine address $\Rightarrow$ PC | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 17 dd<br>16 hh ll<br>15 xb<br>15 xb ff<br>15 xb ee ff<br>15 xb<br>15 xb ee ff | 4<br>4<br>4<br>4<br>5<br>7<br>7 | - | - | - | - | - | -        | -        | - |
|             | Jump to Subroutine                                                                                                                                             |                                                        |                                                                               |                                 |   |   |   |   |   |          |          |   |
| LBCC rel    | Long Branch if Carry Clear (if C = 0)                                                                                                                          | REL                                                    | 18 24 qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBCS rel    | Long Branch if Carry Set (if C = 1)                                                                                                                            | REL                                                    | 18 25 qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBEQ rel    | Long Branch if Equal (if Z = 1)                                                                                                                                | REL                                                    | 18 27 qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBGE rel    | Long Branch Greater Than or Equal<br>(if N $\oplus$ V = 0) (signed)                                                                                            | REL                                                    | 18 2C qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBGT rel    | Long Branch if Greater Than<br>(if Z + (N $\oplus$ V) = 0) (signed)                                                                                            | REL                                                    | 18 2E qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBHI rel    | Long Branch if Higher<br>(if C + Z = 0) (unsigned)                                                                                                             | REL                                                    | 18 22 qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBHS rel    | Long Branch if Higher or Same<br>(if C = 0) (unsigned)<br>same function as LBCC                                                                                | REL                                                    | 18 24 qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBLE rel    | Long Branch if Less Than or Equal<br>(if Z + (N $\oplus$ V) = 1) (signed)                                                                                      | REL                                                    | 18 2F qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBLO rel    | Long Branch if Lower<br>(if C = 1) (unsigned)<br>same function as LBGS                                                                                         | REL                                                    | 18 25 qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBLS rel    | Long Branch if Lower or Same<br>(if C + Z = 1) (unsigned)                                                                                                      | REL                                                    | 18 23 qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBLT rel    | Long Branch if Less Than<br>(if N $\oplus$ V = 1) (signed)                                                                                                     | REL                                                    | 18 2D qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBMI rel    | Long Branch if Minus (if N = 1)                                                                                                                                | REL                                                    | 18 2B qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBNE rel    | Long Branch if Not Equal (if Z = 0)                                                                                                                            | REL                                                    | 18 26 qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBPL rel    | Long Branch if Plus (if N = 0)                                                                                                                                 | REL                                                    | 18 2A qq rr                                                                   | 4/3                             | - | - | - | - | - | -        | -        | - |
| LBRA rel    | Long Branch Always (if I=1)                                                                                                                                    | REL                                                    | 18 20 qq rr                                                                   | 4                               | - | - | - | - | - | -        | -        | - |



| Source Form | Operation                                                            | Addr. Mode | Machine Coding (hex)                                          | *                                                                                         | S                                    | X | H | I | N | Z        | V        | C |
|-------------|----------------------------------------------------------------------|------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------|---|---|---|---|----------|----------|---|
| LBRN rel    | Long Branch Never (if 1 = 0)                                         | REL        | 18 21 qq rr                                                   | 3                                                                                         | -                                    | - | - | - | - | -        | -        | - |
| LBVC rel    | Long Branch if Overflow Bit Clear (if V=0)                           | REL        | 18 28 qq rr                                                   | 4/3                                                                                       | -                                    | - | - | - | - | -        | -        | - |
| LBVS rel    | Long Branch if Overflow Bit Set (if V = 1)                           | REL        | 18 29 qq rr                                                   | 4/3                                                                                       | -                                    | - | - | - | - | -        | -        | - |
| LDAA opr    | (M) $\Rightarrow$ A<br>Load Accumulator 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    | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | 0 |
| LDAB opr    | (M) $\Rightarrow$ B<br>Load Accumulator 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    | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | 0 |
| LDD opr     | (M:M+1) $\Rightarrow$ A:B<br>Load Double Accumulator D (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 | 2<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | 0 |
| LDS opr     | (M:M+1) $\Rightarrow$ SP<br>Load Stack Pointer                       |            | 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 | 2<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | 0 |
| LDX opr     | (M:M+1) $\Rightarrow$ X<br>Load Index Register 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 | 2<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | 0 |
| LDY opr     | (M:M+1) $\Rightarrow$ Y<br>Load Index Register 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 | 2<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | 0 |
| LEAS opr    | Effective Address $\Rightarrow$ SP<br>Load Effective Address into SP |            | IDX<br>IDX1<br>IDX2                                           | 1B xb<br>1B xb ff<br>1B xb ee ff                                                          | 2<br>2<br>2                          | - | - | - | - | -        | -        | - |

| Source Form  | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Addr. Mode                                      | Machine Coding (hex)                                                    | ~                          | S | X | H | I | N        | Z        | V        | C        |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|-------------------------------------------------------------------------|----------------------------|---|---|---|---|----------|----------|----------|----------|
| LEAX opr     | Effective Address $\Rightarrow$ X<br>Load Effective Address into X                                                                                                                                                                                                                                                                                                                                                                                                                  | IDX<br>IDX1<br>IDX2                             | 1A xb<br>1A xb ff<br>1A xb ee ff                                        | 2<br>2<br>2                | - | - | - | - | -        | -        | -        | -        |
| LEAY opr     | Effective Address $\Rightarrow$ Y<br>Load Effective Address into Y                                                                                                                                                                                                                                                                                                                                                                                                                  | IDX<br>IDX1<br>IDX2                             | 19 xb<br>19 xb ff<br>19 xb ee ff                                        | 2<br>2<br>2                | - | - | - | - | -        | -        | -        | -        |
| LSL opr      | Logical Shift Left<br>same function as ASL                                                                                                                                                                                                                                                                                                                                                                                                                                          | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 78 hh ll<br>68 xb<br>68 xb ff<br>68 xb ee ff<br>68 xb<br>68 xb ee ff    | 4<br>3<br>4<br>5<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| LSLA<br>LSLB | Logical Shift Accumulator A to Left<br>Logical Shift Accumulator B to Left                                                                                                                                                                                                                                                                                                                                                                                                          | INH                                             | 48<br>58                                                                | 1<br>1                     |   |   |   |   |          |          |          |          |
| LSLD         | Logical Shift Left D Accumulator<br>same function as ASLD                                                                                                                                                                                                                                                                                                                                                                                                                           | INH                                             | 59                                                                      | 1                          | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| LSR opr      | Logical Shift Right                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 74 hh ll<br>64 xb<br>64 xb ff<br>64 xb ee ff<br>64 xb<br>64 xb ee ff    | 4<br>3<br>4<br>5<br>6<br>6 | - | - | - | - | 0        | $\Delta$ | $\Delta$ | $\Delta$ |
| LSRA<br>LSRB | Logical Shift Accumulator A to Right<br>Logical Shift Accumulator B to Right                                                                                                                                                                                                                                                                                                                                                                                                        | INH                                             | 44<br>54                                                                | 1<br>1                     |   |   |   |   |          |          |          |          |
| LSRD         | Logical Shift Right D Accumulator                                                                                                                                                                                                                                                                                                                                                                                                                                                   | INH                                             | 49                                                                      | 1                          | - | - | - | - | 0        | $\Delta$ | $\Delta$ | $\Delta$ |
| MAXA         | MAX((A), (M)) $\Rightarrow$ A<br>MAX of 2 Unsigned 8-Bit Values<br><br>N, Z, V and C status 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 | 4<br>4<br>5<br>7<br>7      | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| MAXM         | MAX((A), (M)) $\Rightarrow$ M<br>MAX of 2 Unsigned 8-Bit Values<br><br>N, Z, V and C status 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 | 4<br>5<br>6<br>7<br>7      | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| MEM          | $\mu$ (grade) $\Rightarrow$ M <sub>(Y)</sub><br>(X) + 4 $\Rightarrow$ X; (Y) + 1 $\Rightarrow$ Y; A unchanged<br><br>if (A) < P1 or (A) > P2 then $\mu$ = 0, else<br>$\mu$ = MIN[((A) - P1) $\times$ S1, (P2 - (A)) $\times$ S2, \$FF]<br>where:<br>A = current crisp input value;<br>X points at 4-byte data structure that describes a trapezoidal membership function (P1, P2, S1, S2);<br>Y points at fuzzy input (RAM location).<br>See instruction details for special cases. | Special                                         | 01                                                                      | 5                          | - | - | ? | - | ?        | ?        | ?        | ?        |

© 2005 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. This material is protected under all copyright laws as they currently exist. No portion of this material may be reproduced, in any form or by any means, without permission in writing from the publisher

For the exclusive use of adopters of the book Embedded Systems: Design and Applications with the 68HC12 and HCS12,  
by Steven F. Barrett and Daniel J. Pack. ISBN 0-13-140141-6.

| Source Form     | Operation                                                                                                                                                                                       | Addr. Mode                                                     | Machine Coding (hex)                                                                                        | -                                    | S          | X          | H          | I          | N          | Z          | V          | C          |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|--------------------------------------|------------|------------|------------|------------|------------|------------|------------|------------|
| MINA            | $\text{MIN}((\text{A}), (\text{M})) \Rightarrow \text{A}$<br>MIN of Two Unsigned 8-Bit Values<br><br>N, Z, V and C status bits reflect result of internal compare $((\text{A}) - (\text{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                                     | 4<br>4<br>5<br>7<br>7                | -          | -          | -          | -          | $\Delta$   | $\Delta$   | $\Delta$   | $\Delta$   |
| MINM            | $\text{MIN}((\text{A}), (\text{M})) \Rightarrow \text{M}$<br>MIN of Two Unsigned 8-Bit Values<br><br>N, Z, V and C status bits reflect result of internal compare $((\text{A}) - (\text{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                                     | 4<br>5<br>6<br>7<br>7                | -          | -          | -          | -          | $\Delta$   | $\Delta$   | $\Delta$   | $\Delta$   |
| MOVB opr1, opr2 | $(\text{M}_1) \Rightarrow \text{M}_2$<br>Memory to Memory Byte-Move (8-Bit)                                                                                                                     | IMM-EXT<br>IMM-IDX<br>EXT-EXT<br>EXT-IDX<br>IDX-EXT<br>IDX-IDX | 18 0B ii hh ll<br>18 08 xb ii<br>18 0C hh ii hh ll<br>18 09 xb hh ll<br>18 0D xb hh ll<br>18 0A xb xb       | 4<br>4<br>6<br>5<br>5<br>5           | -          | -          | -          | -          | -          | -          | -          | -          |
| MOVW opr1, opr2 | $(\text{M}: \text{M}+1_1) \Rightarrow \text{M}: \text{M}+1_2$<br>Memory to Memory Word-Move (16-Bit)                                                                                            | IMM-EXT<br>IMM-IDX<br>EXT-EXT<br>EXT-IDX<br>IDX-EXT<br>IDX-IDX | 18 03 jj kk hh ll<br>18 00 xb jj kk<br>18 04 hn ll hh ll<br>18 01 xb hh ll<br>18 05 xb hh ll<br>18 02 xb xb | 5<br>4<br>6<br>5<br>5<br>5           | -          | -          | -          | -          | -          | -          | -          | -          |
| MUL             | $(\text{A}) \times (\text{B}) \Rightarrow \text{A:B}$<br><br>8 x 8 Unsigned Multiply                                                                                                            | INH                                                            | 12                                                                                                          | 3                                    | -          | -          | -          | -          | -          | -          | -          | $\Delta$   |
| NEG opr         | $0 - (\text{M}) \Rightarrow \text{M}$ or $(\bar{\text{M}}) + 1 \Rightarrow \text{M}$<br>Two's Complement Negate                                                                                 | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]<br>INH         | 70 hh ll<br>60 xb<br>60 xb ff<br>60 xb ee ff<br>60 xb<br>60 xb ee ff<br>40                                  | 4<br>3<br>4<br>5<br>6<br>6<br>1      | -          | -          | -          | -          | $\Delta$   | $\Delta$   | $\Delta$   | $\Delta$   |
| NEGA            | $0 - (\text{A}) \Rightarrow \text{A}$ equivalent to $(\bar{\text{A}}) + 1 \Rightarrow \text{B}$<br>Negate Accumulator A                                                                         | INH                                                            | 50                                                                                                          | 1                                    |            |            |            |            |            |            |            |            |
| NEGB            | $0 - (\text{B}) \Rightarrow \text{B}$ equivalent to $(\bar{\text{B}}) + 1 \Rightarrow \text{B}$<br>Negate Accumulator B                                                                         | INH                                                            | 50                                                                                                          | 1                                    |            |            |            |            |            |            |            |            |
| NOP             | No Operation                                                                                                                                                                                    | INH                                                            | A7                                                                                                          | 1                                    | -          | -          | -          | -          | -          | -          | -          | -          |
| ORAA opr        | $(\text{A}) + (\text{M}) \Rightarrow \text{A}$<br>Logical OR A with Memory                                                                                                                      | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]  | 8A ii<br>9A dd<br>BA hh ll<br>AA xb<br>AA xb ff<br>AA xb ee ff<br>AA xb<br>AA xb ee ff                      | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | -          | -          | -          | -          | $\Delta$   | $\Delta$   | 0          | -          |
| ORAB opr        | $(\text{B}) + (\text{M}) \Rightarrow \text{B}$<br>Logical OR B with Memory                                                                                                                      | IMM<br>DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]  | CA ii<br>DA dd<br>FA hh ll<br>EA xb<br>EA xb ff<br>EA xb ee ff<br>EA xb<br>EA xb ee ff                      | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | -          | -          | -          | -          | $\Delta$   | $\Delta$   | 0          | -          |
| ORCC opr        | $(\text{CCR}) + \text{M} \Rightarrow \text{CCR}$<br>Logical OR CCR with Memory                                                                                                                  | IMM                                                            | 14 ii                                                                                                       | 1                                    | $\uparrow$ |

| Source Form | Operation                                                                                                                                                                                                                                                                                                                                                                                                            | Addr. Mode | Machine Coding (hex) | *                          | S        | X            | H        | I        | N        | Z        | V        | C        |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|----------------------|----------------------------|----------|--------------|----------|----------|----------|----------|----------|----------|
| PSHA        | (SP) - 1 $\Rightarrow$ SP; (A) $\Rightarrow$ M <sub>(SP)</sub><br>Push Accumulator A onto Stack                                                                                                                                                                                                                                                                                                                      | INH        | 36                   | 2                          | -        | -            | -        | -        | -        | -        | -        | -        |
| PSHB        | (SP) - 1 $\Rightarrow$ SP; (B) $\Rightarrow$ M <sub>(SP)</sub><br>Push Accumulator B onto Stack                                                                                                                                                                                                                                                                                                                      | INH        | 37                   | 2                          | -        | -            | -        | -        | -        | -        | -        | -        |
| PSHC        | (SP) - 1 $\Rightarrow$ SP; (CCR) $\Rightarrow$ M <sub>(SP)</sub><br>Push CCR onto Stack                                                                                                                                                                                                                                                                                                                              | INH        | 39                   | 2                          | -        | -            | -        | -        | -        | -        | -        | -        |
| PSHD        | (SP) - 2 $\Rightarrow$ SP; (A:B) $\Rightarrow$ M <sub>(SP)</sub> :M <sub>(SP+1)</sub><br>Push D: Accumulator onto Stack                                                                                                                                                                                                                                                                                              | INH        | 3B                   | 2                          | -        | -            | -        | -        | -        | -        | -        | -        |
| PSHX        | (SP) - 2 $\Rightarrow$ SP; (X <sub>H</sub> :X <sub>L</sub> ) $\Rightarrow$ M <sub>(SP)</sub> :M <sub>(SP+1)</sub><br>Push Index Register X onto Stack                                                                                                                                                                                                                                                                | INH        | 34                   | 2                          | -        | -            | -        | -        | -        | -        | -        | -        |
| PSHY        | (SP) - 2 $\Rightarrow$ SP; (Y <sub>H</sub> :Y <sub>L</sub> ) $\Rightarrow$ M <sub>(SP)</sub> :M <sub>(SP+1)</sub><br>Push Index Register Y onto Stack                                                                                                                                                                                                                                                                | INH        | 35                   | 2                          | -        | -            | -        | -        | -        | -        | -        | -        |
| PULA        | (M <sub>(SP)</sub> ) $\Rightarrow$ A; (SP) + 1 $\Rightarrow$ SP<br>Pull Accumulator A from Stack                                                                                                                                                                                                                                                                                                                     | INH        | 32                   | 3                          | -        | -            | -        | -        | -        | -        | -        | -        |
| PULB        | (M <sub>(SP)</sub> ) $\Rightarrow$ B; (SP) + 1 $\Rightarrow$ SP<br>Pull Accumulator B from Stack                                                                                                                                                                                                                                                                                                                     | INH        | 33                   | 3                          | -        | -            | -        | -        | -        | -        | -        | -        |
| PULC        | (M <sub>(SP)</sub> ) $\Rightarrow$ CCR; (SP) + 1 $\Rightarrow$ SP<br>Pull CCR from Stack                                                                                                                                                                                                                                                                                                                             | INH        | 38                   | 3                          | $\Delta$ | $\Downarrow$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| PULD        | (M <sub>(SP)</sub> :M <sub>(SP+1)</sub> ) $\Rightarrow$ A:B; (SP) + 2 $\Rightarrow$ SP<br>Pull D from Stack                                                                                                                                                                                                                                                                                                          | INH        | 3A                   | 3                          | -        | -            | -        | -        | -        | -        | -        | -        |
| PULX        | (M <sub>(SP)</sub> :M <sub>(SP+1)</sub> ) $\Rightarrow$ X <sub>H</sub> :X <sub>L</sub> ; (SP) + 2 $\Rightarrow$ SP<br>Pull Index Register X from Stack                                                                                                                                                                                                                                                               | INH        | 30                   | 3                          | -        | -            | -        | -        | -        | -        | -        | -        |
| PULY        | (M <sub>(SP)</sub> :M <sub>(SP+1)</sub> ) $\Rightarrow$ Y <sub>H</sub> :Y <sub>L</sub> ; (SP) + 2 $\Rightarrow$ SP<br>Pull Index Register Y from Stack                                                                                                                                                                                                                                                               | INH        | 31                   | 3                          | -        | -            | -        | -        | -        | -        | -        | -        |
| REV         | MIN-MAX rule evaluation<br>Find smallest rule input (MIN).<br>Store to rule outputs unless fuzzy output is already larger (MAX).<br><br>For rule weights see REVW.<br><br>Each rule input is an 8-bit offset from the base address in Y. Each rule output is an 8-bit offset from the base address in Y. \$FE separates rule inputs from rule outputs. \$FF terminates the rule list.<br><br>REV may be interrupted. | Special    | 18 3A                | 3**<br>per<br>rule<br>byte | -        | -            | -        | -        | -        | -        | $\Delta$ | -        |

| Source Form  | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                 | Addr. Mode                                      | Machine Coding (hex)                                                 | ~*                              | S | X | H | I | N | Z | V | C |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|----------------------------------------------------------------------|---------------------------------|---|---|---|---|---|---|---|---|
| REVV         | MIN-MAX rule evaluation<br>Find smallest rule input (MIN),<br>Store to rule outputs unless fuzzy output is<br>already larger (MAX).<br><br>Rule weights supported, optional.<br><br>Each rule input is the 16-bit address of a<br>fuzzy input. Each rule output is the 16-bit address of a fuzzy output. The value \$FFFE<br>separates rule inputs from rule outputs.<br>\$FFFF terminates the rule list.<br><br>REVV may be interrupted. | Special                                         | 18 3B                                                                | 3** per rule byte;<br>5 per wt. | - | - | ? | - | ? | ? | Δ | ! |
| ROL opr      |                                                                                                                                                                                                                                                                                                                                                          | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 75 hh ll<br>65 xb<br>65 xb ff<br>65 xb ee ff<br>65 xb<br>65 xb ee ff | 4<br>3<br>4<br>5<br>6<br>6      | - | - | - | - | Δ | Δ | Δ | Δ |
| ROLA<br>ROLB | Rotate Memory Left through Carry<br>Rotate A Left through Carry<br>Rotate B Left through Carry                                                                                                                                                                                                                                                                                                                                            | INH<br>INH                                      | 45<br>55                                                             | 1<br>1                          |   |   |   |   |   |   |   |   |
| ROR opr      |                                                                                                                                                                                                                                                                                                                                                        | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | 76 hh ll<br>66 xb<br>66 xb ff<br>66 xb ee ff<br>66 xb<br>66 xb ee ff | 4<br>3<br>4<br>5<br>6<br>6      | - | - | - | - | Δ | Δ | Δ | Δ |
| RORA<br>RORB | Rotate Memory Right through Carry<br>Rotate A Right through Carry<br>Rotate B Right through Carry                                                                                                                                                                                                                                                                                                                                         | INH<br>INH                                      | 46<br>56                                                             | 1<br>1                          |   |   |   |   |   |   |   |   |
| RTC          | $(M_{(SP)}) \Rightarrow PPAGE; (SP) + 1 \Rightarrow SP;$<br>$(M_{(SP)}; M_{(SP+1)}) \Rightarrow PC_H:PC_L;$<br>$(SP) + 2 \Rightarrow SP$<br><br>Return from Call                                                                                                                                                                                                                                                                          | INH                                             | 0A                                                                   | 6                               | - | - | - | - | - | - | - | - |
| RTI          | $(M_{(SP)}) \Rightarrow CCR; (SP) + 1 \Rightarrow SP$<br>$(M_{(SP)}; M_{(SP+1)}) \Rightarrow B:A; (SP) + 2 \Rightarrow SP$<br>$(M_{(SP)}; M_{(SP+1)}) \Rightarrow X_H:X_L; (SP) + 4 \Rightarrow SP$<br>$(M_{(SP)}; M_{(SP+1)}) \Rightarrow PC_H:PC_L; (SP) - 2 \Rightarrow SP$<br>$(M_{(SP)}; M_{(SP+1)}) \Rightarrow Y_H:Y_L;$<br>$(SP) + 4 \Rightarrow SP$<br><br>Return from Interrupt                                                 | INH                                             | 0B                                                                   | 8                               | Δ | ↓ | Δ | Δ | Δ | Δ | Δ | Δ |
| RTS          | $(M_{(SP)}; M_{(SP+1)}) \Rightarrow PC_H:PC_L;$<br>$(SP) + 2 \Rightarrow SP$<br><br>Return from Subroutine                                                                                                                                                                                                                                                                                                                                | INH                                             | 3D                                                                   | 5                               | - | - | - | - | - | - | - | - |
| SBA          | $(A) - (B) \Rightarrow A$<br>Subtract B from A                                                                                                                                                                                                                                                                                                                                                                                            | INH                                             | 18 16                                                                | 2                               | - | - | - | - | Δ | Δ | Δ | Δ |

| Source Form | Operation                                                                                                                                                                                                                                      | Addr. Mode                                                    | Machine Coding (hex)                                                                   | $\sim^*$                             | S | X | H | I | N        | Z        | V        | C        |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------|---|---|---|---|----------|----------|----------|----------|
| SBCA opr    | (A) - (M) - C $\Rightarrow$ A<br>Subtract with Borrow from 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 ll<br>A2 xb<br>A2 xb ff<br>A2 xb ee ff<br>A2 xb<br>A2 xb ee ff | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SBCB opr    | (B) - (M) - C $\Rightarrow$ B<br>Subtract with Borrow from 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 ll<br>E2 xb<br>E2 xb ff<br>E2 xb ee ff<br>E2 xb<br>E2 xb ee ff | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SEC         | $1 \Rightarrow C$<br><i>Translates to ORCC #\$01</i>                                                                                                                                                                                           | IMM                                                           | 14 01                                                                                  | 1                                    | - | - | - | - | -        | -        | -        | 1        |
| SEI         | $1 \Rightarrow I$ ; (inhibit I interrupts)<br><i>Translates to ORCC #\$10</i>                                                                                                                                                                  | IMM                                                           | 14 10                                                                                  | 1                                    | - | - | - | 1 | -        | -        | -        | -        |
| SEV         | $1 \Rightarrow V$<br><i>Translates to ORCC #\$02</i>                                                                                                                                                                                           | IMM                                                           | 14 02                                                                                  | 1                                    | - | - | - | - | -        | -        | 1        | -        |
| SEX r1, r2  | \$00:(r1) $\Rightarrow$ r2 if r1, bit 7 is 0 or<br>\$FF:(r1) $\Rightarrow$ r2 if r1, bit 7 is 1<br><br>Sign Extend 8-bit r1 to 16-bit r2<br>r1 may be A, B, or CCR<br>r2 may be D, X, Y, or SP<br><br><i>Alternate mnemonic for TFR r1, r2</i> | INH                                                           | B7 eb                                                                                  | 1                                    | - | - | - | - | -        | -        | -        | -        |
| STAA opr    | (A) $\Rightarrow$ M<br>Store Accumulator A to Memory                                                                                                                                                                                           | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 5A dd<br>7A hh ll<br>6A xb<br>6A xb ff<br>6A xb ee ff<br>6A xb<br>6A xb ee ff          | 2<br>3<br>2<br>3<br>3<br>5<br>5      | - | - | - | - | $\Delta$ | $\Delta$ | 0        | -        |
| STAB opr    | (B) $\Rightarrow$ M<br>Store Accumulator B to Memory                                                                                                                                                                                           | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 5B dd<br>7B hh ll<br>6B xb<br>6B xb ff<br>6B xb ee ff<br>6B xb<br>6B xb ee ff          | 2<br>3<br>2<br>3<br>3<br>5<br>5      | - | - | - | - | $\Delta$ | $\Delta$ | 0        | -        |
| STD opr     | (A) $\Rightarrow$ M, (B) $\Rightarrow$ M+1<br>Store Double Accumulator                                                                                                                                                                         | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 5C dd<br>7C hh ll<br>6C xb<br>6C xb ff<br>6C xb ee ff<br>6C xb<br>6C xb ee ff          | 2<br>3<br>2<br>3<br>3<br>5<br>5      | - | - | - | - | $\Delta$ | $\Delta$ | 0        | -        |

| Source Form | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Addr. Mode                                                    | Machine Coding (hex)                                                                   | -*                                   | S | X | H | I | N        | Z        | V        | C        |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|----------------------------------------------------------------------------------------|--------------------------------------|---|---|---|---|----------|----------|----------|----------|
| STOP        | (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) - 2 $\Rightarrow$ SP; (Y <sub>H</sub> :Y <sub>L</sub> ) $\Rightarrow$ M <sub>(SP)</sub> :M <sub>(SP+1)</sub> ;<br>(SP) - 2 $\Rightarrow$ SP; (X <sub>H</sub> :X <sub>L</sub> ) $\Rightarrow$ M <sub>(SP)</sub> :M <sub>(SP+1)</sub> ;<br>(SP) - 2 $\Rightarrow$ SP; (B:A) $\Rightarrow$ M <sub>(SP)</sub> :M <sub>(SP+1)</sub> ;<br>(SP) - 1 $\Rightarrow$ SP; (CCR) $\Rightarrow$ M <sub>(SP)</sub> ;<br>STOP All Clocks<br><br>If S control bit = 1, the STOP instruction is disabled and acts like a two-cycle NOP.<br><br>Registers stacked to allow quicker recovery by interrupt. | 1NH                                                           | 18 3E                                                                                  | 9**<br>+5<br>or<br>+2**              | - | - | - | - | -        | -        | -        | -        |
| STS opr     | (SP <sub>H</sub> :SP <sub>L</sub> ) $\Rightarrow$ M:M+1<br>Store Stack Pointer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 5F dd<br>7F hh ll<br>6F xb<br>6F xb ff<br>6F xb ee ff<br>6F xb<br>6F xb ee ff          | 2<br>3<br>2<br>3<br>3<br>5<br>5      | - | - | - | - | $\Delta$ | $\Delta$ | 0        | -        |
| STX opr     | (X <sub>H</sub> :X <sub>L</sub> ) $\Rightarrow$ M:M+1<br>Store Index Register X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 5E dd<br>7E hh ll<br>6E xb<br>6E xb ff<br>6E xb ee ff<br>6E xb<br>6E xb ee ff          | 2<br>3<br>2<br>3<br>3<br>5<br>5      | - | - | - | - | $\Delta$ | $\Delta$ | 0        | -        |
| STY opr     | (Y <sub>H</sub> :Y <sub>L</sub> ) $\Rightarrow$ M:M+1<br>Store Index Register Y                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | DIR<br>EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2]        | 5D dd<br>7D hh ll<br>6D xb<br>6D xb ff<br>6D xb ee ff<br>6D xb<br>6D xb ee ff          | 2<br>3<br>2<br>3<br>3<br>5<br>5      | - | - | - | - | $\Delta$ | $\Delta$ | 0        | -        |
| SUBA opr    | (A) - (M) $\Rightarrow$ A<br>Subtract Memory from Accumulator 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 ll<br>A0 xb<br>A0 xb ff<br>A0 xb ee ff<br>A0 xb<br>A0 xb ee ff | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |
| SUBB opr    | (B) - (M) $\Rightarrow$ B<br>Subtract Memory from Accumulator 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 ll<br>E0 xb<br>E0 xb ff<br>E0 xb ee ff<br>E0 xb<br>E0 xb ee ff | 1<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | - | - | - | - | $\Delta$ | $\Delta$ | $\Delta$ | $\Delta$ |

| Source Form    | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Addr. Mode                                                    | Machine Coding (hex)                                                                      | -                                    | S                   | X                 | H             | I             | N             | Z             | V             | C             |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------|--------------------------------------|---------------------|-------------------|---------------|---------------|---------------|---------------|---------------|---------------|
| SUBD opr       | (D) - (M:M+1) $\Rightarrow$ D<br>Subtract Memory from D (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 ll<br>A3 xb<br>A3 xb ff<br>A3 xb ee ff<br>A3 xb<br>A3 xb ee ff | 2<br>3<br>3<br>3<br>3<br>4<br>6<br>6 | -                   | -                 | -             | -             | $\Delta$      | $\Delta$      | $\Delta$      | $\Delta$      |
| SWI            | (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) - 2 $\Rightarrow$ SP; (Y <sub>H</sub> :Y <sub>L</sub> ) $\Rightarrow$ M <sub>(SP)</sub> :M <sub>(SP+1)</sub> ;<br>(SP) - 2 $\Rightarrow$ SP; (X <sub>H</sub> :X <sub>L</sub> ) $\Rightarrow$ M <sub>(SP)</sub> :M <sub>(SP+1)</sub> ;<br>(SP) - 2 $\Rightarrow$ SP; (B:A) $\Rightarrow$ M <sub>(SP)</sub> :M <sub>(SP+1)</sub> ;<br>(SP) - 1 $\Rightarrow$ SP; (CCR) $\Rightarrow$ M <sub>(SP)</sub><br>1 $\Rightarrow$ I; (SWI Vector) $\Rightarrow$ PC<br><br>Software Interrupt | INH                                                           | 3F                                                                                        | 9                                    | -                   | -                 | -             | 1             | -             | -             | -             |               |
| TAB            | (A) $\Rightarrow$ B<br>Transfer A to B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | INH                                                           | 18 0E                                                                                     | 2                                    | -                   | -                 | -             | -             | $\Delta$      | $\Delta$      | 0             | -             |
| TAP            | (A) $\Rightarrow$ CCR<br><i>Translates to TFR A , CCR</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | INH                                                           | B7 02                                                                                     | 1                                    | $\Delta$            | $\Downarrow$      | $\Delta$      | $\Delta$      | $\Delta$      | $\Delta$      | $\Delta$      | $\Delta$      |
| TBA            | (B) $\Rightarrow$ A<br>Transfer B to A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | INH                                                           | 18 0F                                                                                     | 2                                    | -                   | -                 | -             | -             | $\Delta$      | $\Delta$      | 0             | -             |
| TBEQ cntr, rel | If (cntr) = 0, then Branch;<br>else Continue to next instruction<br><br>Test Counter and Branch if Zero<br>(cntr = A, B, D, X,Y, or SP)                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | REL<br>(9-bit)                                                | 04 lb rr                                                                                  | 3                                    | -                   | -                 | -             | -             | -             | -             | -             | -             |
| TBL opr        | (M) + [(B) $\times$ ((M+1) - (M))] $\Rightarrow$ A<br>8-Bit Table Lookup and Interpolate<br><br>Initialize B, and index before TBL.<br><ea> points at first 8-bit table entry (M) and<br>B is fractional part of lookup value.<br><br>(no indirect addressing modes allowed.)                                                                                                                                                                                                                                                                                                                                      | IDX                                                           | 18 3D xb                                                                                  | 8                                    | -                   | -                 | -             | -             | $\Delta$      | $\Delta$      | -             | ?             |
| TBNE cntr, rel | If (cntr) not = 0, then Branch;<br>else Continue to next instruction<br><br>Test Counter and Branch if Not Zero<br>(cntr = A, B, D, X,Y, or SP)                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | REL<br>(9-bit)                                                | 04 lb rr                                                                                  | 3                                    | -                   | -                 | -             | -             | -             | -             | -             | -             |
| TFR r1, r2     | (r1) $\Rightarrow$ r2 or<br>\$00:(r1) $\Rightarrow$ r2 or<br>(r1[7:0]) $\Rightarrow$ r2<br><br>Transfer Register to Register<br>r1 and r2 may be A, B, CCR, D, X, Y, or SP                                                                                                                                                                                                                                                                                                                                                                                                                                         | INH                                                           | B7 eb                                                                                     | 1                                    | -<br>or<br>$\Delta$ | -<br>$\Downarrow$ | -<br>$\Delta$ | -<br>$\Delta$ | -<br>$\Delta$ | -<br>$\Delta$ | -<br>$\Delta$ | -<br>$\Delta$ |
| TPA            | (CCR) $\Rightarrow$ A<br><i>Translates to TFR CCR , A</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | INH                                                           | B7 20                                                                                     | 1                                    | -                   | -                 | -             | -             | -             | -             | -             | -             |

| Source Form | Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Addr. Mode                                      | Machine Coding (hex)                                                 | ~*                             | S | X | H | I | N        | Z        | V | C |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|----------------------------------------------------------------------|--------------------------------|---|---|---|---|----------|----------|---|---|
| TRAP        | (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) - 2 $\Rightarrow$ SP; (Y <sub>H</sub> ;Y <sub>L</sub> ) $\Rightarrow$ M <sub>(SP)</sub> ;M <sub>(SP+1)</sub> ;<br>(SP) - 2 $\Rightarrow$ SP; (X <sub>H</sub> ;X <sub>L</sub> ) $\Rightarrow$ M <sub>(SP)</sub> ;M <sub>(SP+1)</sub> ;<br>(SP) - 2 $\Rightarrow$ SP; (B:A) $\Rightarrow$ M <sub>(SP)</sub> ;M <sub>(SP+1)</sub> ;<br>(SP) - 1 $\Rightarrow$ SP; (CCR) $\Rightarrow$ M <sub>(SP)</sub><br>1 $\Rightarrow$ I; (TRAP Vector) $\Rightarrow$ PC<br><br>Unimplemented opcode trap | INH                                             | 18 ln<br>ln = \$30-\$39<br>or<br>\$40-\$FF                           | 10                             | - | - | - | 1 | -        | -        | - | - |
| TST opr     | (M) - 0<br>Test Memory for Zero or Minus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | EXT<br>IDX<br>IDX1<br>IDX2<br>[D,IDX]<br>[IDX2] | F7 hh ll<br>E7 xb<br>E7 xb ff<br>E7 xb ee ff<br>E7 xb<br>E7 xb ee ff | 3<br>3<br>3<br>4<br>6<br>6     | - | - | - | - | $\Delta$ | $\Delta$ | 0 | 0 |
| TSTA        | (A) - 0 Test A for Zero or Minus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | INH                                             | 97                                                                   | 1                              |   |   |   |   |          |          |   |   |
| TSTB        | (B) - 0 Test B for Zero or Minus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | INH                                             | D7                                                                   | 1                              |   |   |   |   |          |          |   |   |
| TSX         | (SP) $\Rightarrow$ X<br><i>Translates to TFR SP,X</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | INH                                             | B7 75                                                                | 1                              | - | - | - | - | -        | -        | - | - |
| TSY         | (SP) $\Rightarrow$ Y<br><i>Translates to TFR SP,Y</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | INH                                             | B7 76                                                                | 1                              | - | - | - | - | -        | -        | - | - |
| TXS         | (X) $\Rightarrow$ SP<br><i>Translates to TFR X,SP</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | INH                                             | B7 57                                                                | 1                              | - | - | - | - | -        | -        | - | - |
| TYS         | (Y) $\Rightarrow$ SP<br><i>Translates to TFR Y,SP</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | INH                                             | B7 67                                                                | 1                              | - | - | - | - | -        | -        | - | - |
| WAI         | (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) - 2 $\Rightarrow$ SP; (Y <sub>H</sub> ;Y <sub>L</sub> ) $\Rightarrow$ M <sub>(SP)</sub> ;M <sub>(SP+1)</sub> ;<br>(SP) - 2 $\Rightarrow$ SP; (X <sub>H</sub> ;X <sub>L</sub> ) $\Rightarrow$ M <sub>(SP)</sub> ;M <sub>(SP+1)</sub> ;<br>(SP) - 2 $\Rightarrow$ SP; (B:A) $\Rightarrow$ M <sub>(SP)</sub> ;M <sub>(SP+1)</sub> ;<br>(SP) - 1 $\Rightarrow$ SP; (CCR) $\Rightarrow$ M <sub>(SP)</sub> ;<br><br>WAIT for interrupt                                                           | INH                                             | 3E                                                                   | 8**<br>(in)<br>+<br>5<br>(int) | - | - | - | - | -        | -        | - | - |
| WAV         | $\sum_{i=1}^B S_i F_i \Rightarrow Y \cdot D$<br>$\sum_{i=1}^B F_i \Rightarrow X$<br>Calculate Sum of Products and Sum of Weights for Weighted Average Calculation<br><br>Initialize B, X, and Y before WAV. B specifies number of elements. X points at first element in S <sub>i</sub> list. Y points at first element in F <sub>i</sub> list.<br><br>All S <sub>i</sub> and F <sub>i</sub> elements are 8-bits.<br><br>If interrupted, six extra bytes of slack used for intermediate values                                                                                                                             | Special                                         | 18 3C                                                                | 8**<br>per table               | - | - | ? | - | ?        | $\Delta$ | ? | ? |

| Source Form        | Operation                                                                                                                       | Addr. Mode | Machine Coding (hex) | -* | S | X | H | I | N | Z | V | C |
|--------------------|---------------------------------------------------------------------------------------------------------------------------------|------------|----------------------|----|---|---|---|---|---|---|---|---|
| wavr               | <i>see WAV</i>                                                                                                                  | Special    | 3C                   | ** | - | - | ? | - | ? | Δ | ? | ? |
| pseudo-instruction | Resume executing an interrupted WAV instruction (recover intermediate results from stack rather than initializing them to zero) |            |                      |    |   |   |   |   |   |   |   |   |
| XGDX               | (D) $\leftrightarrow$ (X)<br><i>Translates to EXG D, X</i>                                                                      | INH        | B7 C5                | 1  | - | - | - | - | - | - | - | - |
| XGDY               | (D) $\leftrightarrow$ (Y)<br><i>Translates to EXG D, Y</i>                                                                      | INH        | B7 C6                | 1  | - | - | - | - | - | - | - | - |

## NOTES:

\*Each cycle (-) is typically 125 ns for an 8-MHz bus (16-MHz oscillator).

\*\*Refer to detailed instruction descriptions for additional information.