| Category     | Instruction | Oprands     | 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 |
|              | 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 | ΦΦ ΦΦΦΦ ΦΦΦΦ        | BBBB BAAA AAФT TTTT |
|              | andi        | rt,ra,imm   | m rt <= ra AND immediate value                                                    | 01 01 01 | II IIII IIII        | ΙΙΙΙ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|              | 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,n     | rt <= ra shifted left by n bits                                                   | 01 00 01 | ΦΦ ΝΝΝΝ ΦΦΦΦ        | ΦΦΦΦ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|              | shr         | 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        | ΑΑΑΑ ΑΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|              | 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 | 00 0000 0000        | ΟΟΟΟ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|              | stori       | rt,addr     | DMEM[addr] <= rb {direct addressing}                                              | 10 10 01 | AA AAAA AAAA        | ΑΑΑΑ ΑΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|              | 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 | 00 0000 0000        | ΟΟΟΟ ΦΑΑΑ ΑΑΦΤ ΤΤΤΤ |
|              | jmp         | off         | Jump to IMEM[PC+off]                                                              | 11 00 00 | 00 0000 0000        | 0000 0000 0000 0000 |
|              | bro         | ra cond off | f If condition is true, then jump to IMEM[PC+off], else continue                  | 11 10 00 | 00 0000 0000        | 0000 4444 4444 4666 |
| control      | brc         | ra,cond,off | Conditions: ra = 0; ra $\neq$ 0; ra = 1; ra < 0; ra > 0; ra $\leq$ 0; ra $\geq$ 0 | 11 10 00 | 00 0000 0000        | ΟΟΟΟ ΦΑΑΑ ΑΑΦΦ ΦССС |

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

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