## **CPU1 Instruction Set**

## **CPU1 Instruction Set**

| MNEMONIC | Opcode                                  | Binary   | Operand              | Operation                          | Description                                                                                                                                                 |
|----------|-----------------------------------------|----------|----------------------|------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADR      | 80                                      | 10000000 | XRRRYRRR             | RX <- RX + RY                      | Add register: RY to RX and store back in RX                                                                                                                 |
| ADI      | 88, 89,<br>8A, 8B,<br>8C, 8D,<br>8E, 8F | 10001RRR | VVVVVVV              | R <- R + (PC+1)                    | Add immediate: Add byte at PC+1 to contents of R and store in R.                                                                                            |
| ADM      | 90, 91,<br>92, 93,<br>94, 95,<br>96, 97 | 10010RRR | MMMMMMMM<br>MMMMMMMM | R <- R + (M)                       | Add memory: Add contents of memory at address M to contents or R and store in R                                                                             |
| ADRC     | 81                                      | 10000001 | XRRRYRRR             | $RX \leftarrow RX + RY + C$        | Add registers with carry: Add RX to RY and the Carry bit (flag). Result in RX.                                                                              |
| ADIC     | A0, A1,<br>A2, A3,<br>A4, A5,<br>A6, A7 | 10100RRR | VVVVVVV              | R <- R + (PC+1) + C                | Add w/carry immediate: Add content of register R to byte immediately following opcode plus the carry bit (flag).                                            |
| ADMC     | A8, A9,<br>AA, AB,<br>AC, AD,<br>AE, AF | 10101RRR | MMMMMMMM<br>MMMMMMMM | R <- R + (M) + C                   | Add memory w/carry: Add content of register R with byte at address M plus carry bit.                                                                        |
| SUB      | 82                                      | 10000010 | XRRRYRRR             | RX <- RX - RY                      | Subtract: Subtract contents of RY from RX and store back in RX. Set Carry and Negative flags as appropriate.                                                |
| SUBI     | B8, B9,<br>BA, BB,<br>BC, BD,<br>BE, BF | 10111RRR | VVVVVVV              | R <- R - (PC+1)                    | Subtract immediate: Subtract the contents of byte following the opcode from contents or R and store back in R. Set Carry and Negative flags as appropriate. |
| SUBM     | C0, C1,<br>C2, C3,<br>C4, C5,<br>C6, C7 | 11000RRR | MMMMMMMM<br>MMMMMMMM | R <- R - (M)                       | Subtract memory: Subtract the byte at address M from the content of R and store back in R. Set Carry and Negative flags as appropriate.                     |
| SUBC     | 83                                      | 10000011 | XRRRYRRR             | RX <- RX - RY - C - (NOT C)        | Subtract register w/borrow: Subtract RY from RX and subtract carry bit from that. Result to RX.                                                             |
| SUBIC    | D0, D1,<br>D2, D3,<br>D4, D5,<br>D6, D7 | 11010RRR | VVVVVVV              | R <- R - (PC+1) - C - (NOT C)      | Subtract immediate w/borrow: Subtract byte following opcode from R. Subtract carry bit from that and store in R.                                            |
| SUBMC    | D8, D9,<br>DA, DB,<br>DC, DD,<br>DE, DF | 11011RRR | MMMMMMMM<br>MMMMMMMM | R <- R - (M) -C - (NOT C)          | Subtract immediate memory w/borrow: Subtract byte at address M from R. Subtract carry bit. Store result in R.                                               |
| LDI      | E0, E1,<br>E2, E3,<br>E4, E5,<br>E6, E7 | 11100RRR | VVVVVVV              | R <- (PC+1)                        | Load immediate: Store the byte immediately after the opcode in register R                                                                                   |
| STI      | E8, E9,<br>EA, EB,<br>EC, ED,<br>EE, EF | 11101RRR | MMMMMMMM<br>MMMMMMMM | (M) <- R                           | Store immediate: Store the content of R at address M                                                                                                        |
| LDM      | F0, F1,<br>F2, F3,<br>F4, F5,<br>F6, F7 | 11110RRR | MMMMMMMM<br>MMMMMMMM | R <- (M)                           | Load memory: Store the byte at address M into register R                                                                                                    |
| EX       | 84                                      | 10000100 | XRRRYRRR             | RX <- RY; RY <- RX                 | Exchange registers: Swap content of registers RX and RY                                                                                                     |
| СМР      | 85                                      | 10000101 | XRRRYRRR             | IF RX = RY, CP=true, else CP=false | Compare register RX with RY and set compare flag true if equal                                                                                              |
| AND      | 86                                      | 10000110 | XRRRYRRR             | RX <- RX AND RY                    | AND: Logical AND of RX and RY. Result into RX.                                                                                                              |
| OR       | 87                                      | 10000111 | XRRRYRRR             | RX <- RX OR RY                     | OR: Logical OR of RX and RY. Result into RX.                                                                                                                |
| XOR      | 19                                      | 00011001 | XRRRYRRR             | RX <- RX XOR RY                    | XOR: Exclusive OR of RX and RY. Result into RX.                                                                                                             |
| ANI      | 50, 51,<br>52, 53,<br>54, 55,<br>56, 57 | 01010RRR | VVVVVVV              | R <- R AND (PC+1)                  | AND immediate: Logical AND of R with byte immediately following the opcode.                                                                                 |

## **CPU1 Instruction Set**

| MNEMONIC | Opcode                                  | Binary   | Operand              | Operation                                     | Description                                                                                                                                                                                                                                                                                         |
|----------|-----------------------------------------|----------|----------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ORI      | 58, 59,<br>5A, 5B,<br>5C, 5D,<br>5E, 5F | 01011RRR | VVVVVVV              | R <- R OR (PC+1)                              | OR immediate: Logical OR of R with byte immediately following the opcode.                                                                                                                                                                                                                           |
| XRI      | 60, 61,<br>62, 63,<br>64, 65,<br>66, 67 | 01100RRR | VVVVVVV              | R <- R XOR (PC+1)                             | XOR immediate: Logical XOR of R with byte immediately following the opcode.                                                                                                                                                                                                                         |
| SHR      | 68, 69,<br>6A, 6B,<br>6C, 6D,<br>6E, 6F | 01101RRR |                      | R <- R >> 1                                   | Shift right: Shift register R right one bit. Fill with 0 on left.                                                                                                                                                                                                                                   |
| SHRC     | 70, 71,<br>72, 73,<br>74, 75,<br>76, 77 | 01110RRR |                      | R <- R >> 1                                   | Shift right with carry: Shift register R right one bit and fill most significant bit with carry bit.                                                                                                                                                                                                |
| SHL      | 78, 79,<br>7A, 7B,<br>7C, 7D,<br>7E, 7F | 01111RRR |                      | R <- R << 1                                   | Shift left: Shift register R left one bit. Fill least significant bit with 0.                                                                                                                                                                                                                       |
| SHLC     | 20, 21,<br>22, 23,<br>24, 25,<br>26, 27 | 00100RRR |                      | R <- R << 1                                   | Shift left w/carry: Shift register R left one bit. Fill least significant bit with carry bit.                                                                                                                                                                                                       |
| INC      | 28, 29,<br>2A, 2B,<br>2C, 2D,<br>2E, 2F | 00101RRR |                      | R <- R + 1                                    | Increment: Increment register R by 1.                                                                                                                                                                                                                                                               |
| DEC      | 30, 31,<br>32, 33,<br>34, 35,<br>36, 37 | 00110RRR |                      | R <- R -1                                     | Decrement: Decrement register R by 1.                                                                                                                                                                                                                                                               |
| NOP      | 00                                      | 00000000 |                      | PC <- PC + 1                                  | NOP: continue to next instruction by incrementing PC by one.                                                                                                                                                                                                                                        |
| HALT     | 01                                      | 0000001  |                      | PC <- PC                                      | HALT: Stop CPU clock and instruction execution at current PC.                                                                                                                                                                                                                                       |
| SETQ     | 38, 39,<br>3A, 3B,<br>3C, 3D,<br>3E, 3F | 00111000 |                      | QN <- true (1)                                | Set QN: Sets specified I/O line to true (1)                                                                                                                                                                                                                                                         |
| RESETQ   | 10, 11,<br>12, 13,<br>14, 15,<br>16, 17 | 00010QQQ |                      | QN <- false (0)                               | Resets QN: Sets specified I/O line to false (0)                                                                                                                                                                                                                                                     |
| LBRC     | 18                                      | 00011000 | MMMMMMMM<br>MMMMMMMM | IF CP=true, PC <- M, else PC <- PC + 2        | Long branch: If compare bit is true (1), jump to address M. Otherwise, increment PC to next instruction.                                                                                                                                                                                            |
| LBRQ     | 08, 09,<br>0A, 0B,<br>0C, 0D,<br>0E, 0F | 00001QQQ | MMMMMMM<br>MMMMMMMM  | if QN, PC <- M, else PC <- PC + 2             | Branch if QN: Jump to address M if QN is true, otherwise, skip to next instruction.                                                                                                                                                                                                                 |
| PUSH     | 40, 41,<br>42, 43,<br>44, 45,<br>46, 47 | 01000RRR |                      | SP <- SP -1; (SP) <- R                        | Push register: First decrement SP by one byte. Then store R at top of stack.                                                                                                                                                                                                                        |
| POP      | 48, 49,<br>4A, 4B,<br>4C, 4D,<br>4E, 4F | 01001RRR |                      | R <- (SP)                                     | Pop register: Load R with byte at top of stack, then increment SP to new top.                                                                                                                                                                                                                       |
| CALL     | 02                                      | 0000010  | МММММММ<br>МММММММ   | PC <- PC + 3; SP <- SP - 1; (SP) <-<br>PC     | Call subroutine: Increment PC to point past the next two bytes to the return address. Decrement SP to new top. Store least significant byte of PC on stack. Then. decrement SP again and store most significant byte of PC on stack. SP now points to most significant byte of the return location. |
| RET      | 03                                      | 00000011 |                      | PC.1 <- (SP); SP + 1; PC.0 <- (SP);<br>SP + 1 | Return from subroutine: Places byte at top of stack into most significant byte of PC. Increments SP and places next byte into least significant byte of PC. Finally, increment SP to top of stack.                                                                                                  |