## Instruction Word

|                                        |           |                                |              |            |            |            |                 |                             |                                                                                                  |                        |            |                                |                                 |                                 | Internal Control Signals            |                                               |                                      |                               |                                           |         |                                               |                                              | Fetch<br>Control<br>Signals                        |
|----------------------------------------|-----------|--------------------------------|--------------|------------|------------|------------|-----------------|-----------------------------|--------------------------------------------------------------------------------------------------|------------------------|------------|--------------------------------|---------------------------------|---------------------------------|-------------------------------------|-----------------------------------------------|--------------------------------------|-------------------------------|-------------------------------------------|---------|-----------------------------------------------|----------------------------------------------|----------------------------------------------------|
| Opcode # (DEC) Opcode # (HEX) MSB(HEX) | Inst Size | ExecCycles<br>00,01,10 = 1 Cyc | Obcode       | Register C | Register B | Register A |                 |                             |                                                                                                  |                        | Needed ALU | Actual ALU Op<br>Memory Access | 8b or 16b Mem<br>Jump Condition | /IR2_0E<br>/PC_BB0E<br>/PC_AD0E | / JMPINST<br>/ SP_BBOE<br>/ SP_ADOE | SP_MODE/2<br>/SP_D2B_OE<br>/B2A_OE<br>/RF_CEW | /RF_FHZ<br>/RF_BOE<br>ALU_FUNC/3     | /ALU_CFLATCH                  | /SFT_DE<br>/SFT_DE<br>/SFT_DIR<br>/SFT_AR | /SFT_WC | /DBL_OE<br>DB_DIR (0=W)<br>H/2L_OE<br>H2L_DIR | NEM_R/W<br>/NEM_AS<br>/NEM_H_EN<br>/NEM_L EN | /IR1_LATCH<br>/IR2_LATCH<br>/EXECUTE1<br>/EXECUTE2 |
| Fetch Cycle 2 (La                      | ARGE IN   | NSTRUCT                        | rion)        |            |            |            |                 |                             |                                                                                                  |                        |            | y<br>y                         | 16<br>16                        | 1 1 0 oc 1 1 1 0 oc             | 1 1 1 1<br>1 1 1                    | 1 1<br>1 1                                    | 1 1<br>1 1                           | 1 1 1 1<br>1 1 1 1            | 1 1 ~ ~<br>1 1 ~ ~                        | ~       | 1 1 1<br>1 1 1                                | 1 0 0 0<br>1 0 0 0                           | 0 1 1 1 1 1 0 1 1                                  |
|                                        | 15        | 14-13                          | 12-9         | 8-6        | 5-3        | 2-0        | Word2 Mneumoni  | c Mneumonic Fmt             | Operation                                                                                        | Flags                  |            |                                | ĦП                              | ш                               | TH                                  |                                               | Ш                                    | ΤΠÍ                           |                                           | 1116    | <del>i ii i</del>                             | піі                                          |                                                    |
| 0 #0 #0,#1<br>1 #1 #2,#3               | 0         | 00<br>00                       | 0000<br>0001 |            |            |            | NOP<br>HALT     | NOP<br>HALT                 | No Operation<br>STOPS ALL OPERATIONS                                                             | ~                      |            | a n                            |                                 | 1 1 1 00                        | 1 1 1                               | 00 1 1                                        | 1 ~<br>1 ~<br>1 0 001                | ~ 1 1 1                       | 1 1 ~ ~                                   | ~       | 1 1 ~ 1 ~                                     | 1 1 1 1                                      | 1 1 0 1                                            |
| 1 #1 #2,#3<br>2 #2 #4,#5               | 0         | 00                             | 0010         |            | bbb        | aaa        | SUB             | SUB a,b,c                   | Sub Reg-b from Reg-a, Store in Reg-c                                                             | ZF,CF,OVF              | a-b        | a n<br>a-b n                   |                                 | 1 1 1 00                        | 00 1 1 1<br>00 1 1 1                | 00 1 0                                        | 1 0 001                              | ~ 1 1 1<br>~ ~ 1 1<br>0 0 1 1 | 1 1 ~ ~                                   | ~       | 1 1~ 1~                                       | 1 1 1 1                                      | 1 1 0 1                                            |
| 3 #3 #6,#7                             | 0         | 00                             | 0011         | ccc        | bbb        | aaa        | SUBC            | SUBC a,b,c                  |                                                                                                  | ZF,CF,OVF              | a-b        | a-b n                          |                                 | 1 1 1 00                        | 99 1 1 1                            | 00 1 0                                        | 1 0 001                              | 0 0 0 1                       | 1 1 ~ ~                                   | ~       | 1 1 ~ 1 ~                                     | 1 1 1 1                                      | 1 1 0 1                                            |
| 4 #4 #8,#9<br>5 #5 #A,#B               | 0         | 00<br>00                       | 0100<br>0101 |            | bbb<br>bbb | aaa<br>aaa | ADDC            | ADD a,b,c<br>ADDC a,b,c     | Add Reg-a and Reg-b, Store in Reg-c                                                              | ZF,CF,OVF<br>ZF,CF,OVF | a+b<br>a+b | a+b n<br>a+b n                 |                                 | 1 1 1 00                        | 00 1 1 1<br>00 1 1 1                |                                               |                                      | 0 0 1 1<br>0 0 0 1            | 1 1 ~ ~                                   | ~       | 1 1~ 1~ 1~ 1~                                 | 1 1 1 1                                      | 1 1 0 1                                            |
| 6 #6 #C,#D                             | Θ<br>Θ    | 00<br>00                       | 0110         |            | bbb        | aaa        | XOR             | XOR a,b,c                   | Logical XOR Reg-a and Reg-b, Store in Reg-c                                                      | ZF,CF/OVF=0            | a \$ b     | a\$b n                         |                                 | 1 1 1 00                        | 1 1 1                               |                                               | 1 0 011                              | 0 0 1 1                       | 1 1 ~ ~                                   | ~       | 1 1 ~ 1 ~                                     | 1 1 1 1                                      | 1 1 0 1                                            |
| 7 #7 #E,#F<br>8 #8 #10,#11             | 0         | 00                             | 0111<br>1000 | ссс        | bbb        | aaa        | OR              | OR a,b,c                    | Logical OR Reg-a and Reg-b, Store in Reg-c                                                       | ZF,CF/OVF=0            | a   b      | a \$ b<br>a   b n              |                                 | 1 1 1 0                         | 00 1 1 1                            | 00 1 0                                        | 1 0 100                              | 0 0 1 1                       | 1 1 ~ ~                                   | ~       | 1 1 ~ 1 ~                                     | 1 1 1 1                                      |                                                    |
| 9 #9 #12,#13<br>10 #A #14,#15          | 0         | 00<br>00                       | 1001         |            | bbb        | aaa        | AND             | AND a,b,c                   | Logical AND Reg-a and Reg-b, Store in Reg-c                                                      | ZF,CF/OVF=0            | a & b      | a   b<br>a & b n               |                                 | 1 1 1 0                         | 00 1 1 1                            | 00 1 0                                        |                                      | 0 0 1 1                       |                                           |         | 1 1 ~ 1 ~                                     | 1 1 1 1                                      |                                                    |
| 11 #B #16,#17                          | 0         | 00                             | 1011         |            |            |            | AND             |                             | LOGICAL MND Reg-a and Reg-D, Stole in Reg-C                                                      | ZF,CF/OVF=0            | a & D<br>~ | a & b n                        |                                 | 1 1 1 00                        | 1 1 1                               |                                               |                                      |                               |                                           |         |                                               |                                              |                                                    |
| 12 #C #18,#19<br>13 #D #1A,#1B         | 0         | 00<br>00                       | 1100         |            | bbb        | 000        | NOT             | NOT b,c                     | Logical NOT Reg-a into Reg-c                                                                     | ZF,CF/OVF=0            | ! b        | !b n                           |                                 | 1 1 1 00                        | 0 1 1 1                             | 00 1 0                                        | 1 0 110                              | 0 0 1 1                       | 1 1 ~ ~                                   | ~       | 1 1 ~ 1 ~                                     | 1 1 1 1                                      | 1 1 0 1                                            |
| 14 #E #1C,#1D                          | 0         | 00                             | 1110         |            |            |            |                 |                             |                                                                                                  |                        | -          | b                              |                                 | 1111                            | 1 1 1 1                             |                                               |                                      |                               |                                           |         |                                               |                                              |                                                    |
| 15 #F #1E,#1F<br>16 #10 #20,#21        | 0         | 00<br>01                       | 1111         |            | bbb        | aaa        | STORERW         | STOREW a,[b]                | Store word reg-a to address in reg-b                                                             |                        | -          | b v                            | .                               | 1 1 1 2                         | 00 1 1 1                            | 0 1                                           | 1 0 080                              | 0 1 1 1                       | 1 1 ~ ~                                   |         | 0 0 1 ~                                       | 0 0 0 0                                      | 1 1 0 1                                            |
| 17 #11 #22,#23                         | 0         | 01                             | 0001         |            | DDD        | aaa        | STORERB         | STOREB a,[b]                | Store byte reg-a to address in reg-b                                                             | -                      | a          | a y<br>a y                     | 8                               | 1 1 1 00                        | 00 1 1 1                            | ee 0 1                                        | 1 0 000                              | 0 1 1 1                       | 1 1 ~ ~                                   | ~       | 1 ADO 0 !ADO 0                                | 0 0 !ADB ADB                                 |                                                    |
| 18 #12 #24,#25<br>19 #13 #26,#27       | 0         | 01<br>01                       | 0010         |            | bbb        | aaa        | CMP<br>CMPC     | CMP a,b<br>CMPC             | Set flags based on a-b<br>Complement Carry                                                       | ZF,CF,OVF<br>CF=!CF    | a-b        | a-b n<br>a-b                   |                                 | 1 1 1 00                        | 00 1 1 1<br>00 1 1 1                | 00 1 1                                        | 1 0 001<br>1 ~ 001<br>1 0 ~<br>0 0 ~ | 0 0 1 1 0                     | 1 1 ~ ~                                   | ~       | 1 1~ 1~                                       | 1 1 1 1                                      | 1 1 0 1                                            |
| 20 #14 #28,#29                         | 0         | 01                             | 0100         |            |            |            | LOADRW          | LOADW [b],c                 | Load word from address in reg-b into reg-c                                                       | ~                      | -          | a+b y                          | 16                              | 1 1 1 00                        | 00 1 1 1                            | 00 0 0                                        | 1 0 ~                                | 1 1 1 1                       | 1 1 ~ ~                                   | ~       | 0 0 1 1~                                      | 1 0 0 0                                      | 1 1 0 1                                            |
| 21 #15 #2A,#2B<br>22 #16 #2C,#2D       | 0         | 01<br>01                       | 0101         |            |            |            | LOADRB          | LOADB [b],c                 | Load byte from address in reg-b into reg-c                                                       | -                      | ~          | a+b y<br>a \$ b                | 8                               | 1 1 1 0                         | 1 1 1                               | 0 0                                           | 0 0 ~                                | 1 1 1 1                       | 1 1 ~ ~                                   | ~       | 1 ADO 1 ! ADO 1                               | 1 0 !ADB ADB                                 | 1 1 0 1                                            |
| 23 #17 #2E,#2F                         | 0         | 01                             | 0111         |            |            |            |                 |                             |                                                                                                  |                        | -          | a \$ b                         |                                 |                                 |                                     |                                               |                                      |                               |                                           |         |                                               |                                              |                                                    |
| 24 #18 #30,#31<br>25 #19 #32,#33       | 0         | 01<br>01                       | 1000         |            | bbb<br>bbb | 000<br>000 | JMPR<br>JZR     | JMP [b]                     | jmp to [b]                                                                                       | ~                      | ~          | a   b n                        | 000                             | 1 1 1 00                        | 0 1 1<br>0 0 1 1                    |                                               | 1 0 ~<br>1 0 ~                       | 1 1 1 1<br>1 1 1 1            | 1 1 ~ ~                                   |         | 1 1 ~ 1 ~<br>1 1 ~ 1 ~                        | 1 1 1 1                                      | 1 1 0 1                                            |
| 25 #19 #32,#33<br>26 #1A #34,#35       | 0         | 01                             | 1010         |            | bbb        | 000        | JNZR            | JZ [b]<br>JNZ [b]           | <pre>if Z: jmp to [b] if NZ: jmp to [b]</pre>                                                    | -                      | ~          | a l b n<br>a & b n             | 010                             | 1 1 1 00                        | 0 1 1                               |                                               | 1 0 ~                                | 1 1 1 1                       | 1 1 ~ ~                                   |         | 1 1~ 1~                                       | 1 1 1 1                                      | 1 1 0 1                                            |
| 27 #1B #36,#37<br>28 #1C #38,#39       | 0         | 01<br>01                       | 1011         |            | bbb<br>bbb | 000<br>000 | JCR<br>JNCR     | JC [b]                      | if C: jmp to [b]                                                                                 | ~                      | ~          | a-b n                          | 011                             | 1 1 1 00                        |                                     | 00 1 1<br>00 1 1                              | 1 0 ~                                | 1 1 1 1                       | 1 1 ~ ~                                   | ~       | 1 1 ~ 1 ~                                     | 1 1 1 1                                      | 1 1 0 1                                            |
| 28 #1C #38,#39<br>29 #1D #3A,#3B       | 0         | 01                             | 1100         |            | bbb        | 000        | JVR             | JNC [b]<br>JV [b]           | <pre>if NC: jmp to [b] if V: jmp to [b]</pre>                                                    | -                      | ~          | !b n                           | 100                             | 1 1 1 00                        |                                     | 00 1 1                                        | 1 0 ~<br>1 0 ~                       | 1 1 1 1                       | 1 1 ~ ~                                   | ~       | 1 1~ 1~                                       | 1 1 1 1                                      | 1 1 0 1                                            |
| 30 #1E #3C,#3D                         | 0         | 01                             | 1110         |            | bbb        | 000        | JNVR            | JNV [b]                     | if NV: jmp to [b]                                                                                | ~                      | ~          | b n                            | 110                             | 1 1 1 0                         | 0 1 1                               | 00 1 1                                        | 1 0 ~                                | 1 1 1 1                       | 1 1 ~ ~                                   | ~       | 1 1 ~ 1 ~                                     | 1 1 1 1                                      | 1 1 0 1                                            |
| 31 #1F #3E,#3F<br>32 #20 #40,#41       | 0         | 01<br>10                       | 0000         |            |            |            |                 | Jreserved<br>Shift Reserved |                                                                                                  |                        | ~          | b<br>a                         |                                 |                                 |                                     |                                               |                                      |                               |                                           |         |                                               |                                              |                                                    |
| 33 #21 #42,#43                         | 0         | 10                             | 0001         |            | l          |            |                 | Shift Reserved              |                                                                                                  |                        | -          | a                              |                                 | ш                               |                                     |                                               |                                      |                               |                                           | ∐IL     |                                               |                                              |                                                    |
| 34 #22 #44,#45<br>35 #23 #46,#47       | 0         | 10<br>10                       | 0010         |            | bbb<br>bbb |            | SHL<br>SHR      | SHL b,c,cnt<br>SHR b,c,cnt  | <pre>c = b &lt;&lt; (cnt+1) (zero fill) c = b &gt;&gt; (cnt+1) (zero fill)</pre>                 | CF=LAST BIT            | -          | b n                            |                                 | 1 1 1 00                        | 00 1 1 1<br>00 1 1 1                | 99 1 0<br>99 1 0                              | 1 0 ~<br>1 0 ~                       | 1 1 1 0<br>1 1 1 0            | 1 0 0 1<br>1 0 1 1                        | 1       | 1 1 ~ 1 ~<br>1 1 ~ 1 ~                        | 1 1 1 1                                      | 1 1 0 1                                            |
| 36 #24 #48,#49                         | 0         | 10                             | 0100         | ссс        | bbb        |            | SHLC            | SHLC b,c,cnt                | c = b << (cnt+1) (carry flag fill)                                                               | CF=LAST BIT            | ~          | b n                            |                                 | 1 1 1 00                        | 0 1 1 1                             | 00 1 0                                        | 1 0 ~<br>1 0 ~                       | 1 1 1 0                       | 1 0 0 1                                   | 0       | 1 1 ~ 1 ~                                     | 1 1 1                                        | 1 1 0 1                                            |
| 37 #25 #4A,#4B<br>38 #26 #4C,#4D       | 0         | 10<br>10                       | 0101         |            |            |            | SHRA<br>??SHRC? | SHRA b,c,cnt SHRC b,cnt,c   | <pre>c = b &gt;&gt; (cnt+1) (sign extented shift) c = b &gt;&gt; (cnt+1) (carry flag fill)</pre> | CF=LAST BIT            | ~          | b n                            |                                 | 1 1 1 00                        | 00 1 1 1<br>00 1 1 1                | 90 1 0<br>90 1 0                              | 1 0 ~<br>1 0 ~                       | 1 1 1 0<br>1 1 1 0            | 1 0 1 0 1 1                               | 0       | 1 1~ 1~ 1~ 1~                                 | 1 1 1 1                                      | 1 1 0 1                                            |
| 39 #27 #4E,#4F                         | 0         | 10                             | 0111         |            |            |            |                 | Shift Reserved              |                                                                                                  |                        | -          | b                              |                                 | ПП                              |                                     |                                               |                                      |                               |                                           |         |                                               |                                              |                                                    |
| 40 #28 #50,#51<br>41 #29 #52,#53       | 0         | 10<br>10                       | 1000         |            |            |            |                 |                             |                                                                                                  |                        | ~          | b<br>b                         |                                 |                                 |                                     |                                               |                                      |                               |                                           |         |                                               |                                              |                                                    |
| 42 #2A #54,#55                         | 0         | 10                             | 1010         | ссс        | 000        | 000        | MOVSP           | MOVSP c                     | Register c = SP                                                                                  | ZF                     | b          | b n                            |                                 | 1 1 1 00                        | 1 0 1                               | 00 1 0                                        | 1 1 111                              | 0 0 1 1                       | 1 1 ~ ~                                   | ~ ~     | 1 ~ 1 ~                                       | 1 1 1 1                                      | 1 1 0 1                                            |
| 43 #2B #56,#57<br>44 #2C #58,#59       | 0         | 10<br>10                       | 1011         |            | bbb<br>bbb | 000<br>000 | MOVTSP<br>MOV   | MOVTSP b<br>MOV b,c         | SP = Register b<br>c = b                                                                         | ~<br>ZF                | b<br>b     | b n<br>b n                     |                                 | 1 1 1 00<br>1 1 1 n             | 99 1 1 1                            | 10 1 1<br>00 1 0                              | 1 0 ~<br>1 0 111                     | 1 1 1 1 0 0 1 1               | 1 1 ~ ~ 1 1 ~ ~                           | ~     ~ | 1~ 1~ 1~                                      | 1 1 1 1                                      | 1 1 0 1                                            |
| 45 #2D #5A,#5B                         | 0         | 10                             | 1101         | 000        | 000        | 000        | MOVPC           | MOVPC c                     | c = PC                                                                                           | ZF                     | ~          | b n                            |                                 | 1 0 1 00                        | 90 1 1 1                            | ee <b>1</b> 0                                 | 1 1 111                              | 0 0 1 1                       | 1 1 ~ ~                                   | ~ ~     | 1 ~ 1 ~                                       | 1 1 1                                        | 1 1 0 1                                            |
| 46 #2E #5C,#5D<br>47 #2F #5E,#5F       | 0         | 10<br>10                       | 1110         |            | bbb        | 000        | PUSH            | PUSH b                      |                                                                                                  | -                      | b          | b y                            | 16                              | 1 1 1 0                         | 1 1 0                               |                                               | 1 0 111                              | 0 1 1 1                       | 1 1 ~ ~                                   | ~       | 0 0 1 ~                                       | 0 0 0                                        | 1 1 0 1                                            |
| 48 #30 #60,#61                         | 0         | 11                             | 0000         | ссс        |            | 000        | POP             | POP c (Cycle 1)             |                                                                                                  | -                      | ~          | а у                            | 16                              | 1 1 1 00                        | 1 1 1                               | 01 1 1                                        | 1 1 ~                                | 1 1 1 1                       | 1 1 ~ ~                                   | ~       | 1 1 ~ 1 ~                                     | 1 1 1 1                                      | 1 1 0 1                                            |
| 48<br>49 #31 #62,#63                   | Θ         | 11                             | 0001         | 1          |            |            |                 | POP c (Cycle 2)             |                                                                                                  | *                      | -          | a                              | ${\mathbb H}$                   | 1 1 1 00                        | 1 1 0                               | 00 1 0                                        | 1 1 ~                                | 1111                          | 1 1 ~ ~                                   | ~       | 0 1 1 ~                                       | 1 0 0 0                                      | 1 1 0 1                                            |
| 50 #32 #64,#65                         | 0         | 11                             | 0010         |            |            |            |                 |                             |                                                                                                  |                        | -          | b                              |                                 |                                 | 111                                 |                                               | $ \  \  \  $                         |                               |                                           |         |                                               |                                              |                                                    |
| 51 #33 #66,#67<br>52 #34 #68,#69       | 0         | 11                             | 0011<br>0100 |            | bbb        | 000        | CALLR           | CALL b (Cycle 1)            |                                                                                                  | -                      | ~<br>b     | b v                            | 16                              | 1 0 1 00                        | 1 1 0                               | 11 1 1                                        | 1 1 111                              | 0 1 1 1                       | 1 1 ~ ~                                   | ~       | 0 0 1 ~                                       | 0 0 0 0                                      | 1 1 0 1                                            |
| 52                                     |           |                                |              |            |            |            |                 | CALL b (Cycle 2)            |                                                                                                  | -                      | b          |                                | Ш                               | 1 1 1 01                        | 1 1 1                               | 00 1 1                                        | 1 0 ~                                | 1 1 1 1                       | 1 1 ~ ~                                   | ~ ~     | 0 0 1 ~                                       | 1 1 1 1                                      | 1 1 1 0                                            |
| 53 #35 #6A,#6B<br>54 #36 #6C,#6D       | 0         | 11<br>11                       | 0101<br>0110 | 000        | bbb        | 000        |                 | CALL [b] (Cycle 1)          | Not possible with D->B Bridge inside IR2                                                         |                        | b<br>~     | b<br>b                         |                                 |                                 | 111                                 |                                               | $ \  \  \  $                         |                               |                                           |         |                                               |                                              |                                                    |
| 54                                     |           |                                |              |            |            |            |                 | CALL [b] (Cycle 2)          | Not possible with D->B Bridge inside IR2                                                         |                        |            |                                |                                 |                                 | 111                                 |                                               |                                      |                               |                                           |         |                                               |                                              |                                                    |
| 55 #37 #6E,#6F<br>56 #38 #70,#71       | 0         | 11<br>11                       | 0111<br>1000 | 000        | 000        | 000        | RET             | RET (Cycle 1)               |                                                                                                  | -                      | ~          | b y                            | 16                              | 1 1 1 00                        | 0 1 1 1                             | 01 1 1 1                                      | 1 1 ~                                | 1 1 1 1                       | 1 1 ~ ~                                   | ~   ~   | 1 ~ 1 ~                                       | 1 1 1 1                                      | 1 1 0 1                                            |
| 56                                     |           |                                |              |            |            |            |                 | RET (Cycle 2)               |                                                                                                  | -                      | ~          |                                | Ш                               | 1 1 1 01                        | 1 1 0                               | 00 0 1 1                                      | 1 1 ~                                | 1 1 1 1                       | 1 1 ~ ~                                   | ~ ~     | 1 ~ 1 ~                                       | 1000                                         | 1 1 1 0                                            |

| Opcode # (DEC) Opcode # (HEX)                                                | (нех)                                                                     | t Size                     | ExecCycles<br>00,01,10 = 1 Cyc<br>11 = 2 Cyc | ode                                                  | Register C                      | Register B               | Register A                             |                                           |                                         |                                                                                    |                     |                                                                                                                                                                                                                                            |                                    |                                                    | Veeded ALU               | Actual ALU Op<br>Memory Access                        | 8b or 16b Mem<br>Jump Condition | /IR2_0E<br>/PC_BB0E                      | /PC_ADOE<br>PC_MODE/3                     | _BBOE<br>_ADOE                                     | MUDE/ 2<br>_D28_0E<br>A_0E | /RF_CEW<br>/RF_FHZ<br>/RF_BOE                      | _FUNC/3<br>U_OE<br>U_FL                            | U_WC<br>U_CFLATCH                      | /SHFI_INVERICARRY<br>/SFT_OE<br>SFT_DIR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | T_MC                                    | /DBH_0E<br>/DBL_0E                    | UB_UIR (⊌=W)<br>H/2L_OE<br>H2L_DIR                 | 16M_R/W                       | 'MEM_H_EN                                 | TR1_LATCH<br>TR2_LATCH<br>FEXECUTE1<br>FEXECUTE2               |
|------------------------------------------------------------------------------|---------------------------------------------------------------------------|----------------------------|----------------------------------------------|------------------------------------------------------|---------------------------------|--------------------------|----------------------------------------|-------------------------------------------|-----------------------------------------|------------------------------------------------------------------------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|----------------------------------------------------|--------------------------|-------------------------------------------------------|---------------------------------|------------------------------------------|-------------------------------------------|----------------------------------------------------|----------------------------|----------------------------------------------------|----------------------------------------------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------------------------------------|----------------------------------------------------|-------------------------------|-------------------------------------------|----------------------------------------------------------------|
| 57 #39<br>58 #3A<br>59 #3B<br>60 #3C<br>61 #3D<br>62 #3E                     | #74,#75<br>#76,#77<br>#78,#79<br>#7A,#7B<br>#7C,#7D                       | 0 0 0 0 0 0 Inst           | 11<br>11<br>11<br>11<br>11<br>11<br>11       | 1001<br>1010<br>1011<br>1100<br>1101<br>1110         | Reg                             | Reg                      | я<br>в<br>в                            |                                           |                                         |                                                                                    |                     |                                                                                                                                                                                                                                            |                                    |                                                    | Nee                      | a a a a a Act                                         | 8b<br>Jun                       | II.                                      | ) NC                                      | R                                                  | SF_<br>/ SF<br>/ R2        | /RF<br>/RF                                         | ALU<br>/AL                                         | /AL                                    | RY   RY   RY   RY   RY   RY   RY   RY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 35/                                     | 80/                                   | H/2                                                | MEM MEM                       | W/<br>BW/                                 | / IR<br>/ II/<br>/ EX                                          |
| 63 #3F<br>64 #40<br>65 #41<br>66 #42<br>67 #43<br>68 #44<br>69 #45<br>70 #46 | #80,#81<br>#82,#83<br>#84,#85<br>#86,#87<br>#88,#89<br>#8A,#8B<br>#8C,#8D | 1<br>1<br>1<br>1<br>1<br>1 | 00<br>00<br>00<br>00<br>00<br>00<br>00       | 0000<br>0001<br>0010<br>0011<br>0100<br>0101<br>0110 | 000<br>000<br>000<br>000<br>000 | 000<br>000<br>000<br>000 | 000<br>000<br>000                      | imm16<br>imm16<br>imm16<br>imm16          | SUBCI<br>ADDI<br>ADDCI<br>XORI          | SUB a,imm16,c<br>SUBC a,imm16,<br>ADD a,imm16,c<br>ADDC a,imm16,c<br>XOR a,imm16,c | c<br>c              | Sub Reg-b from Reg-a, Store in Reg-c Add Reg-a and Reg-b, Store in Reg-c Logical XOR Reg-a and Reg-b, Store in                                                                                                                             | n Reg-c                            | ZF,CF,OVF<br>ZF,CF,OVF<br>ZF,CF,OVF<br>ZF,CF,OVF=0 | a-b<br>a-b<br>a+b<br>a+b | a a a -b n a -b n a +b n a \$ b n a \$ b              |                                 | 0 1<br>0 1<br>0 1<br>0 1                 | 1 080<br>1 080<br>1 080<br>1 080          | 1 1 1<br>1 1 1<br>1 1 1<br>1 1 1<br>1 1 1          | 00 1<br>00 1<br>00 1       | 0 1 1<br>0 1 1<br>0 1 1<br>0 1 1                   |                                                    | 0 1<br>1 1<br>0 1<br>1 1               | 1 1 ~<br>1 1 ~<br>1 1 ~<br>1 1 ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ | 1 1<br>1 1<br>1 1<br>1 1<br>1 1       | - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1            | 1 1 1 1 1 1 1 1 1 1 1         | 1 1 1 1 1 1 1 1 1 1 1 1 1                 | 1 1 0 1<br>1 1 0 1<br>1 1 0 1<br>1 1 0 1<br>1 1 0 1            |
| 72 #48<br>73 #49<br>74 #4A<br>75 #4B<br>76 #4C<br>77 #4D<br>78 #4E           | #92,#93<br>#94,#95<br>#96,#97<br>#98,#99<br>#9A,#9B                       | 1<br>1<br>1<br>1<br>1<br>1 | 00<br>00<br>00<br>00<br>00<br>00             | 1000<br>1001<br>1010<br>1011<br>1100<br>1101<br>1110 | 000                             | 000                      |                                        | imm16                                     |                                         | OR a,imm16,c  AND a,imm16,c  TESTI a,imm16                                         |                     | Logical AND Reg-a and Reg-b, Store in Logical AND Reg-a and Reg-b, Store in Logical AND of Reg-a and imm16, no st                                                                                                                          | n Reg-c                            | ZF,CF/OVF=0 ZF,CF/OVF=0 ZF,CF/OVF=0                | a   b                    | a   b n a   b a & b n a & b !b !b                     |                                 | 0 1 0 1                                  | 1 000                                     | 1 1 1                                              | 90 1                       | 0 1 1 1 1 1 1 1                                    | 101 0 0                                            |                                        | 1 1 ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ~ ~ ~                                   | 1 1 1 1 1 1                           | ~ 1 ~<br>~ 1 ~<br>~ 1 ~                            | 1 1                           | 1 1 1                                     | 1 1 0 1                                                        |
| 79 #4F<br>80 #50<br>81 #51<br>82 #52<br>83 #53<br>84 #54                     | #9E,#9F<br>#A0,#A1<br>#A2,#A3<br>#A4,#A5<br>#A6,#A7                       | 1<br>1<br>1<br>1<br>1      | 00<br>01<br>01<br>01<br>01                   | 1111<br>0000<br>0001<br>0010<br>0011<br>0100         | 000                             | 000<br>000               | aaa                                    |                                           | STOREBI<br>CMPI                         | STOREW a,[imm:<br>STOREB a,[imm:<br>CMPI a,#imm16                                  | ,c                  | Store word reg-a to address imm16 Store byte reg-a to address imm16 Potential new instruction Load word from address imm16 into reg                                                                                                        | g-c                                | -                                                  | a<br>a                   | a y a y a-b a+b y                                     | 16<br>8                         | 0 1<br>0 1<br>0 1                        | 1 000                                     | 1 1 1<br>1 1 1<br>1 1 1<br>1 1 1                   | ee <b>0</b>                | 1 1 1<br>1 1 1<br>0 1 1                            | 0 1<br>0 0<br>0 0<br>~ 1 1                         | 1 1<br>1 1<br>1 1                      | 1 1 ~<br>1 1 ~<br>1 1 ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ~ ~ ~ ~ ~ ~ ~ ~ ~ ~                     | 0 0<br>1 AD0<br>1 1                   | 0 !ADB 6                                           | 1 1                           | 1 AD0 | 1 1 0 1<br>1 1 0 1                                             |
| 85 #55<br>86 #56<br>87 #57<br>88 #58<br>89 #59<br>90 #5A<br>91 #5B           | #AC,#AD<br>#AE,#AF<br>#B0,#B1<br>#B2,#B3<br>#B4,#B5                       | 1<br>1<br>1<br>1<br>1<br>1 | 01<br>01<br>01<br>01<br>01<br>01             | 0101<br>0110<br>0111<br>1000<br>1001<br>1010         | 000<br>000<br>000<br>000        | 000<br>000<br>000<br>000 | 000<br>000<br>000<br>000               | imm16<br>imm16                            | JMPI<br>JZI<br>JNZI                     | JMP imm16 JZ imm16 JNZ imm16 JC imm16                                              | , с                 | Load byte from address imm16 into reg  r=0: jump to imm16, r=1 jump to +imm1 if Z r=0: jump to imm16, r=1 jump to if NZ r=0: jump to imm16, r=1 jump to                                                                                    | 16<br>+imm16<br>o +imm16           | -                                                  | ~                        | a+b y a \$ b n a \$ b a   b n a   b n a & b n a & b n | 8<br>996<br>991                 | 0 1 0 1 0 1 0 1                          | 1 080<br>1 080<br>1 080                   | 1 1 1<br>0 1 1<br>0 1 1<br>0 1 1                   | 00 1<br>00 1<br>00 1       | 0 0 1<br>1 1 1<br>1 1 1<br>1 1 1<br>1 1 1          | ~ 1 1<br>~ 1 1<br>~ 1 1<br>~ 1 1                   | 1 1 1 1 1 1 1                          | 1 1 ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | ~ ! ADO 1 ~ 1 ~ ~ 1 ~ ~ ~ 1 ~ ~                    | 1 1 1 1 1 1 1 1 1 1 1 1       | 1 1 1 1 1 1 1 1 1                         | 1 1 0 1 1 1 0 1 1 1 0 1 1 1 0 1                                |
| 91 #5B<br>92 #5C<br>93 #5D<br>94 #5E<br>95 #5F<br>96 #60<br>97 #61           | #B8,#B9<br>#BA,#BB<br>#BC,#BD<br>#BE,#BF<br>#C0,#C1                       | 1<br>1<br>1<br>1<br>1      | 01<br>01<br>01<br>01<br>01<br>10             | 1011<br>1100<br>1101<br>1110<br>1111<br>0000<br>0001 | 000<br>000<br>000<br>000        | 000<br>000<br>000        | 000<br>000<br>000<br>aaa               | imm16<br>imm16<br>imm16<br>imm16<br>imm16 | JNCI<br>JVI<br>JNVI<br>STOREWR          | JNC imm16 JNC imm16 JV imm16 JNV imm16 Jreserved I STOREW a,[+im I STOREB a,[+im   |                     | <pre>if C r=0: jump to imm16, r=1 jump to if NC r=0: jump to imm16, r=1 jump to if V r=0: jump to imm16, r=1 jump to if NV r=0: jump to imm16, r=1 jump to Store word reg-a to address PC+imm16 Store byte reg-a to address PC+imm16</pre> | o +imm16<br>+imm16<br>o +imm16     | -                                                  | ~                        | a & b n !b n !b n b n a y a y                         | 100<br>100<br>110<br>116<br>8   | 0 1 0 1 0 1 0 1 0 1 0 1                  | 1 080<br>1 080<br>1 080                   | 0 1 1<br>0 1 1<br>0 1 1<br>0 1 1<br>1 1 1          | 00 1<br>00 1<br>00 1       | 1 1 1<br>1 1 1<br>1 1 1<br>1 1 1<br>1 1 1          | ~ 1 1<br>~ 1 1<br>~ 1 1<br>~ 1 1<br>000 0 1        | 1 1 1 1 1 1 1 1 1 1 1 1 1              | 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 ~ 1 1 1 ~ 1 1 1 ~ 1 1 1 ~ 1 1 1 ~ 1 1 1 ~ 1 1 1 ~ 1 1 1 ~ 1 1 1 ~ 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |                                                    | 1 1 1 1 1 1 1 1 1             | 1 1 1 1 1 1 1 1 1 1 1 1                   | 1 1 0 1<br>1 1 0 1 |
| 98 #62<br>99 #63<br>100 #64<br>101 #65<br>102 #66<br>103 #67<br>104 #68      | #C6,#C7<br>#C8,#C9<br>#CA,#CB<br>#CC,#CD<br>#CE,#CF                       | 1<br>1<br>1<br>1<br>1      | 10<br>10<br>10<br>10<br>10<br>10             | 0010<br>0011<br>0100<br>0101<br>0110<br>0111<br>1000 | ссс                             | 000<br>000<br>000        | 000<br>000                             | imm16<br>imm16                            | LOADBRI<br>LOADI<br>LOADEA              |                                                                                    | ],c                 | Load word from address PC+imm16 into<br>Load byte from address PC+imm16 into<br>Load imm16 value into register C<br>Load address calculated as PC+imm16 i<br>jump to PC+imm16 offset                                                       | reg-c                              | -                                                  | ~                        | b b y b y b n b                                       | 16                              | 0 1<br>0 1<br>0 1                        | 0 100<br>1 000                            | 1 1 1 1 1 1 1 1 1 1                                | 00 1<br>00 1               | 0 1 1<br>0 0 1<br>0 1 1                            | ~ 1 1<br>~ 1 1<br>111 0 1                          | 1 1 1 1 1 1                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ~ ~ ~ ~ ~ ~ ~ ~ ~                       | 0 0<br>1 ADO<br>1 1                   | 1 1 ~<br>~ !AD0 1<br>~ 1 ~                         | 1 0 1 1                       | !AD0 AD0                                  | 11011101                                                       |
| 105 #69<br>106 #6A<br>107 #6B<br>108 #6C<br>109 #6D<br>110 #6E               | #D2,#D3<br>#D4,#D5<br>#D6,#D7<br>#D8,#D9<br>#DA,#DB<br>#DC,#DD            | 1<br>1<br>1<br>1<br>1      | 10<br>10<br>10<br>10<br>10                   | 1001<br>1010<br>1011<br>1100<br>1101<br>1110         |                                 |                          | 000<br>000<br>000<br>000<br>000<br>000 | imm16<br>imm16<br>imm16<br>imm16<br>imm16 | JZRIO<br>JNZIO<br>JCIO<br>JNCIO<br>JVIO | JZ +imm16<br>JNZ +imm16<br>JC +imm16<br>JNC +imm16<br>JV +imm16<br>JNV +imm16      |                     | if Z jump to PC+imm16 if Z jump to PC+imm16 if NZ r=0: jump to imm16, r=1 jump to if C r=0: jump to imm16, r=1 jump to if NC r=0: jump to imm16, r=1 jump to if V r=0: jump to imm16, r=1 jump to if NV r=0: jump to imm16, r=1 jump to    | PC+imm16<br>o PC+imm16<br>PC+imm16 | -                                                  |                          | b                                                     | 901<br>916<br>911<br>106<br>101 | 0101010101010101010101010101010101010101 | 1 001<br>1 001<br>1 001<br>1 001<br>1 001 | 0 1 1<br>0 1 1<br>0 1 1<br>0 1 1<br>0 1 1<br>0 1 1 | 00 1<br>00 1<br>00 1       | 1 1 1<br>1 1 1<br>1 1 1<br>1 1 1<br>1 1 1<br>1 1 1 | ~ 1 1<br>~ 1 1<br>~ 1 1<br>~ 1 1<br>~ 1 1<br>~ 1 1 | 1 1<br>1 1<br>1 1<br>1 1<br>1 1<br>1 1 | 1 1 ~<br>1 1 ~<br>1 1 ~<br>1 1 ~<br>1 1 ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ | 1 1<br>1 1<br>1 1<br>1 1<br>1 1       | ~ 1 ~<br>~ 1 ~<br>~ 1 ~<br>~ 1 ~<br>~ 1 ~<br>~ 1 ~ | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1     | 1 1 0 1<br>1 1 0 1 |
| 111 #6F<br>112 #70<br>113 #71<br>114 #72<br>115 #73<br>116 #74               | #E0,#E1<br>#E2,#E3<br>#E4,#E5<br>#E6,#E7                                  | 1<br>1<br>1<br>1<br>1      | 10<br>11<br>11<br>11<br>11<br>11             | 1111<br>0000<br>0001<br>0010<br>0011<br>0100         |                                 |                          |                                        | imm16                                     |                                         | Jreserved                                                                          |                     |                                                                                                                                                                                                                                            |                                    |                                                    | -                        | a<br>a<br>b<br>b                                      |                                 |                                          |                                           |                                                    |                            |                                                    |                                                    |                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                         |                                       |                                                    |                               |                                           |                                                                |
| 117 #75<br>118 #76<br>119 #77<br>120 #78<br>120                              | #EC,#ED<br>#EE,#EF<br>#FO,#F1                                             | 1<br>1<br>1                | 11<br>11<br>11<br>11                         | 0101<br>0110<br>0111<br>1000                         |                                 |                          | 000<br>000<br>000                      | imm16                                     | CALLI                                   |                                                                                    | ycle 2)<br>Cycle 1) | Not possible with D->B Bridge inside                                                                                                                                                                                                       | IR2                                | -                                                  | ~                        | b b b b y b y                                         | 16                              | 1 0<br>0 1<br>1 0                        | 1 010                                     | 1 1 0<br>1 1 1<br>1 1 0                            | 11 1 1 1 1 1 1 1 1 1 1     | 1 1 1<br>1 1 1<br>1 1 1                            | ~ 1 1<br>~ 1 1<br>~ 1 1                            | 1 1<br>1 1<br>1 1                      | 1 1 ~<br>1 1 ~<br>1 1 ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~         | 1 1<br>1 1<br>1 1                     | ~ 1 ~<br>~ 1 ~<br>~ 1 ~                            | 0 0<br>1 1                    | 1 1 1                                     | 1 1 0 1<br>1 1 1 0<br>1 1 0 1                                  |
| 121<br>122 #7A<br>123 #7B                                                    |                                                                           | 1                          | 11<br>11                                     | 1010                                                 |                                 |                          | 000                                    | imm16                                     |                                         | CALL +imm16 (                                                                      | Cycle 2)            |                                                                                                                                                                                                                                            |                                    | 2                                                  | ~                        | b<br>b                                                | $\parallel$                     | 0 1                                      | 1 011                                     | 1 1 1                                              | 00 1                       | 1 1 1                                              | ~ 111                                              | 1 1                                    | 1 1 ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ~  ~                                    | 1 1                                   | ~ 1 ~                                              | 1 1                           | 1 1                                       | 1 1 1 0                                                        |

