| Category                 | Instruction | Operands    | Operation                                                                                                                                                     | Opcode   | Fields              |                     |
|--------------------------|-------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---------------------|---------------------|
| No-operation             | nop         | N/A         | none                                                                                                                                                          | 00 00 00 | <b>ΦΦ ΦΦΦΦ ΦΦΦΦ</b> | ФФФФ ФФФФ ФФФФ ФФФФ |
|                          | add         | rt,ra,rb    | rt <= ra + rb                                                                                                                                                 | 00 10 00 | <b>ΦΦ ΦΦΦΦ ΦΦΦΦ</b> | BBBB BAAA AAФT TTTT |
| Arithmetic               | sub         | rt,ra,rb    | rt <= ra – rb                                                                                                                                                 | 00 01 00 | <b>ΦΦΦΦ ΦΦΦΦ</b>    | BBBB BAAA AAФT TTTT |
|                          | addi        | rt,ra,imm   | rt <= ra + immediate value                                                                                                                                    | 00 10 01 | II IIII IIII        | IIII ФААА ААФТ TTTT |
| ·                        | subi        | rt,ra,imm   | rt <= ra – immediate value                                                                                                                                    | 00 01 01 | II IIII IIII        | IIII ФААА ААФТ TTTT |
|                          | inc         | rt,ra       | rt <= ra + 1                                                                                                                                                  | 00 10 10 | <b>ΦΦΦΦ ΦΦΦΦ</b>    | ΦΦΦΦ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
| Arithmetic               | dec         | rt,ra       | rt <= ra – 1                                                                                                                                                  | 00 01 10 | <b>ΦΦΦΦ ΦΦΦΦ</b>    | ΦΦΦΦ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|                          | not         | rt,ra       | rt <= NOT ra                                                                                                                                                  | 01 11 11 | <b>ΦΦΦΦ ΦΦΦΦ</b>    | ΦΦΦΦ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|                          | and         | rt,ra,rb    | rt <= ra AND rb                                                                                                                                               | 01 01 00 | <b>ΦΦ ΦΦΦΦ ΦΦΦΦ</b> | BBBB BAAA AAФT TTTT |
|                          | or          | rt,ra,rb    | rt <= ra OR rb                                                                                                                                                | 01 10 00 | <b>ΦΦΦΦ ΦΦΦΦ</b>    | BBBB BAAA AAФT TTTT |
|                          | xor         | rt,ra,rb    | rt <= ra XOR rb                                                                                                                                               | 01 11 00 | <b>ΦΦ ΦΦΦΦ ΦΦΦΦ</b> | BBBB BAAA AAФT TTTT |
|                          | andi        | rt,ra,imm   | m rt <= ra AND immediate value                                                                                                                                | 01 01 01 | II IIII IIII        | IIII ФААА ААФТ TTTT |
|                          | ori         | rt,ra,imm   | rt <= ra OR immediate value                                                                                                                                   | 01 10 01 | II IIII IIII        | IIII ФААА ААФТ TTTT |
|                          | xori        | rt,ra,imm   | rt <= ra XOR immediate value                                                                                                                                  | 01 11 01 | II IIII IIII        | IIII ФААА ААФТ TTTT |
| shl rt,ra,<br>shr rt,ra, |             | rt,ra,n     | rt <= ra shifted left by n bits                                                                                                                               | 01 00 01 | ΦΦ ΝΝΝΝ ΦΦΦΦ        | ΦΦΦΦ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|                          |             | rt,ra,n     | rt <= ra shifted right by n bits                                                                                                                              | 01 00 00 | ΦΦ ΝΝΝΝ ΦΦΦΦ        | ΦΦΦΦ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|                          | rol         | rt,ra,n     | n rt <= ra rotated left by n bits                                                                                                                             | 01 00 11 | ΦΦ ΝΝΝΝ ΦΦΦΦ        | ΦΦΦΦ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
| Logic                    | ror         | rt,ra,n     | rt <= ra rotated right by n bits                                                                                                                              | 01 00 10 | ΦΦ ΝΝΝΝ ΦΦΦΦ        | ΦΦΦΦ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|                          | move        | rt,ra       | rt <= ra                                                                                                                                                      | 10 00 00 | <b>ΦΦ ΦΦΦΦ ΦΦΦΦ</b> | ΦΦΦΦ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|                          | loadi       | rt,addr     | rt <= DMEM[addr] {direct addressing}                                                                                                                          | 10 01 01 | AA AAAA AAAA        | AAAA AAAA AAФT TTTT |
|                          | loadr       | rt,ra       | rt <= DMEM[ra] {register indirect addressing}                                                                                                                 | 10 01 10 | <b>ΦΦ ΦΦΦΦ ΦΦΦΦ</b> | ΦΦΦΦ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|                          | loado       | rt,ra,off   | rt <= DMEM[ra+off] {base plus offset addressing}                                                                                                              | 10 01 11 | ΦΦ ΦΦΦΟ ΟΟΟΟ        | ΟΟΟΟ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|                          | stori       | rt,addr     | DMEM[addr] <= rb {direct addressing}                                                                                                                          | 10 10 01 | AA AAAA AAAA        | AAAA AAAA AAФT TTTT |
|                          | storr       | rt,ra       | DMEM[ra] <= rb {register indirect addressing}                                                                                                                 | 10 10 10 | <b>ΦΦΦΦ ΦΦΦΦ</b>    | ΦΦΦΦ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
| Transfer                 | storo       | rt,ra,off   | DMEM[ra+off] <= rb {base plus offset addressing}                                                                                                              | 10 10 11 | ΦΦ ΦΦΦΟ ΟΟΟΟ        | ΟΟΟΟ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|                          | jmp         | off         | Jump to IMEM[PC+off]                                                                                                                                          | 11 00 00 | ΦΦ ΦΦΦΦ ΟΟΟΟ        | 0000 ФФФФ ФФФФ ФФФФ |
| control                  | brc         | ra,cond,off | f If condition is true, then jump to IMEM[PC+off], else continue Conditions: $ra = 0$ ; $ra \ne 0$ ; $ra = 1$ ; $ra < 0$ ; $ra > 0$ ; $ra \le 0$ ; $ra \ge 0$ | 11 10 00 | ΦΦ ΦΦΦΦ 0000        | ОООО ФААА ААФФ ФССС |

| Operands    | Fields                                   |
|-------------|------------------------------------------|
| rt,ra,rb    | ΦΦ ΦΦΦΦ ΦΦΦΦ ΒΒΒΒ ΒΑΑΑ ΑΑΦΤ ΤΤΤΤ         |
| rt,ra,off   | ΦΦ ΦΦΦΟ ΟΟΟΟ ΟΟΟΟ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ         |
| rt,ra,n     | ΦΦ ΝΝΝΝ ΦΦΦΦ ΦΦΦΦ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ         |
| rt,ra,imm   | II IIII IIII IIII ФААА ААФТ TTTT         |
| rt,ra       | ΦΦ ΦΦΦΦ ΦΦΦΦ ΦΦΦΦ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ         |
| rt,imm      | II IIII IIII IIII IIII IIAT TTTT         |
| ra,cond,off | ΦΦ ΦΦΦΦ 0000 0000 ΦΑΑΑ ΑΑΦΦ ΦССС         |
| rt,addr     | ΑΑ ΑΑΑΑ ΑΑΑΑ ΑΑΑΑ ΑΑΦΤ ΤΤΤΤ              |
| off         | ΦΦ ΦΦΦΦ ΟΟΟΟ ΟΟΟΟ ΦΦΦΦ ΦΦΦΦ ΦΦΦΦ         |
| N/A         | <b>ወ</b> ወ ወወወወ ወወወወ ወወወወ ወወወወ ወወወወ ወወወወ |

| Spec               | num bits | ;  |
|--------------------|----------|----|
| Instruction set    | 4.29E+09 | 32 |
| opcode             | 64       | 6  |
| data size          | 65536    | 16 |
| registers          | 32       | 5  |
| data offset        | 512      | 9  |
| instruction offset | 256      | 8  |
| max shift          | 16       | 4  |
| flags              | 7        | 3  |

| Command          | Steps       | RA[2:0] | RB[2:0] | WA[2:0] | MA[15:0] | IMM[15:0] | OEN | S[1:4] | AL[2:0] | SH[5:0] | WEN |
|------------------|-------------|---------|---------|---------|----------|-----------|-----|--------|---------|---------|-----|
| SHR R3, R1, 5    | S1 - Fetch  | ØØØ     | ØØØ     | ØØØ     | 0xøøøø   | 0xøøøø    | 0   | ø1øø   | 111     | ØØØØØ   | 0   |
|                  | S2 - Reg R  | 000     | 001     | ØØØ     | 0xøøøø   | 0xøøøø    | 0   | ØØØØ   | ØØØ     | ØØØØØ   | 0   |
|                  | S3 - ALU    | ØØØ     | ØØØ     | ØØØ     | 0xøøøø   | 0xøøøø    | 0   | 00ø0   | 011     | 10101   | 0   |
|                  | S4 - Reg W  | ØØØ     | ØØØ     | 011     | 0xøøøø   | 0xøøøø    | 0   | øøø0   | ØØØ     | ØØØØØ   | 1   |
| LOADI R5, 0xAF1F | S1 - Fetch  | ØØØ     | ØØØ     | ØØØ     | 0xøøøø   | 0xøøøø    | 0   | ø1øø   | 111     | ØØØØØ   | 0   |
|                  | S4 - Mem RW | ØØØ     | ØØØ     | ØØØ     | 0xAF1F   | 0xøøøø    | 0   | øø1ø   | ØØØ     | ØØØØØ   | 0   |
|                  | S5 - Reg W  | ØØØ     | ØØØ     | 101     | 0xøøøø   | 0xøøøø    | 0   | øøø1   | ØØØ     | ØØØØØ   | 1   |
| BRNEQ R3, 0x11A  | S1 - Fetch  | ØØØ     | ØØØ     | ØØØ     | 0xøøøø   | 0xøøøø    | 0   | ø1øø   | 111     | ØØØØØ   | 0   |
|                  | S2 - Reg R  | 011     | 000     | ØØØ     | 0xøøøø   | 0x011A    | 0   | 11øø   | 101     | øø000   | 0   |
|                  | S3 - ALU    | ØØØ     | ØØØ     | ØØØ     | 0xøøøø   | 0хøøøø    | 0   | 00øø   | 101     | øø000   | 0   |

| Command                      | Opcode | RA[2:0] | RB[2:0] | WA[2:0] | IMM[15:0] | OEN | S[4:1] | AI[2:0] | SH[5:0] | WEN |
|------------------------------|--------|---------|---------|---------|-----------|-----|--------|---------|---------|-----|
| move R2, R7                  | 10001  | 111     | 000     | 010     | 0хФФФФ    | 0   | 0ФФ0   | 101     | ФФ0000  | 0   |
| movi R3, 0x0000              | 10000  | 000     | ФФФ     | 011     | 0x0000    | 0   | 0ФФ1   | 101     | ФФ0000  | 0   |
| move R4, R1                  | 10001  | 001     | 000     | 001     | ФФФФх0    | 0   | 0ФФ0   | 101     | ФФ0000  | 0   |
| movi R5, 0x0001              | 10000  | 000     | ФФФ     | 101     | 0x0001    | 0   | 0ФФ1   | 101     | ФФ0000  | 0   |
| br R4, 000, loop_end_label   | 11000  | 100     | 000     | ΦΦΦ     | 0x0005    | 0   | ΦΦΦ1   | 101     | ФФ0000  | 0   |
| and R6, R2, R4               | 01100  | 010     | 100     | 110     | 0хФФФФ    | 0   | 0ФФ0   | 001     | ФФ0000  | 0   |
| xor R3, R6, R4               | 01110  | 110     | 100     | 011     | 0χΦΦΦΦ    | 0   | 0ФФ0   | 010     | ФФ0000  | 0   |
| shr R2, R2, 1                | 01001  | 010     | 000     | 010     | ФФФФх0    | 0   | 0ФФ0   | 101     | 100001  | 0   |
| dec R4, R4                   | 00011  | 100     | ФФФ     | 100     | ФФФФх0    | 0   | 0ФФ0   | 100     | ФФ0000  | 0   |
| br R0, 000, loop_start_label | 11000  | ФФФ     | 000     | ФФФ     | 0xFFFB    | 0   | ΦΦΦ1   | 101     | ФФ0000  | 0   |
| storo R7, R3, 2              | 10111  | 011     | ФФФ     | 111     | 0x0002    | 1   | 00Ф1   | 101     | ФФ0000  | 1   |