

## *MikroLeo Instruction Set*

| Instruction Hex Code | Encoding of MikroLeo Instruction Word (16-bits) |       |                 |       |               | Mnemonic | Instructions with all possibilities | Operation                          | Affected Flags |  |  |  |  |
|----------------------|-------------------------------------------------|-------|-----------------|-------|---------------|----------|-------------------------------------|------------------------------------|----------------|--|--|--|--|
|                      | ROMH (8-bit)                                    |       | ROML (8-bit)    |       |               |          |                                     |                                    |                |  |  |  |  |
|                      | High Nibble (HiNB)                              |       | Decoder Address | MAddr | Operand/LAddr |          |                                     |                                    |                |  |  |  |  |
| ROM (16-bit)         | MICRO2_IN                                       | AMODE | MOD             | MICRO | b11:b8        | b7:b4    | b3:b0                               |                                    |                |  |  |  |  |
| 00Xn                 | X                                               | 0     | 0               | X     | n             | LDI      | LDI ACC,n                           | ACC ← n                            | ZF             |  |  |  |  |
| 10Xn                 |                                                 |       | 1               |       |               |          | LDI RA,n                            | RA ← n                             | -              |  |  |  |  |
| 20Xn                 |                                                 |       | 2               |       |               |          | LDI RB,n                            | RB ← n                             | -              |  |  |  |  |
| 30Xn                 |                                                 |       | 3               |       |               |          | LDI RC,n                            | RC ← n                             | -              |  |  |  |  |
| 01Xn                 |                                                 | 1     | 0               | X     | n             | NAND     | NAND ACC,n                          | ACC ← ACC NAND n                   | ZF             |  |  |  |  |
| 11XX                 |                                                 |       | 1               |       | X             |          | NAND ACC,RA                         | ACC ← ACC NAND RA                  |                |  |  |  |  |
| 21XX                 |                                                 |       | 2               | 1     | X             |          | NAND ACC,RB                         | ACC ← ACC NAND RB                  |                |  |  |  |  |
| 31mn                 |                                                 |       | 0               |       | MAddr         |          | NAND ACC, RAM[Addr]                 | ACC ← ACC NAND RAM[RC:MAddr:LAddr] |                |  |  |  |  |
| 71XX                 |                                                 | 3     | 1               | X     | X             |          | NAND ACC, RAM[RC:RB:RA]             | ACC ← ACC NAND RAM[RC:RB:RA]       |                |  |  |  |  |
| 02mn                 |                                                 |       | 0               | 2     | MAddr         | LDW      | LDW ACC, RAM[Addr]                  | ACC ← RAM[RC:MAddr:LAddr]          | ZF             |  |  |  |  |
| 42XX                 |                                                 |       | 1               |       | X             |          | LDW ACC, RAM[RC:RB:RA]              | ACC ← RAM[RC:RB:RA]                |                |  |  |  |  |
| 13XX                 | X                                               | 2     | 1               | 3     | X             | LDA      | LDA RA                              | ACC ← RA                           | ZF             |  |  |  |  |
| 23XX                 |                                                 |       | 2               |       |               |          | LDA RB                              | ACC ← RB                           |                |  |  |  |  |
| 33XX                 |                                                 |       | 3               |       |               |          | LDA RC                              | ACC ← RC                           |                |  |  |  |  |
| 04Xn                 |                                                 | 3     | 0               | 4     | X             | OUTA     | OUTA n                              | OUTA ← n                           | -              |  |  |  |  |
| 14XX                 |                                                 |       | 1               |       |               |          | OUTA ACC                            | OUTA ← ACC                         |                |  |  |  |  |
| 24XX                 |                                                 |       | 2               |       |               |          | OUTA RA                             | OUTA ← RA                          |                |  |  |  |  |
| 34mn                 |                                                 |       | 0               |       | MAddr         |          | OUTA RAM[Addr]                      | OUTA ← RAM[RC:MAddr:LAddr]         |                |  |  |  |  |
| 74XX                 |                                                 | 1     | 3               |       | X             |          | OUTA RAM[RC:RB:RA]                  | OUTA ← RAM[RC:RB:RA]               |                |  |  |  |  |
| 05Xn                 | 0                                               | 2     | 0               | 5     | X             | OUTB     | OUTB n                              | OUTB ← n                           | -              |  |  |  |  |
| 15XX                 |                                                 |       | 1               |       |               |          | OUTB ACC                            | OUTB ← ACC                         |                |  |  |  |  |
| 25XX                 |                                                 |       | 2               |       |               |          | OUTB RA                             | OUTB ← RA                          |                |  |  |  |  |
| 35mn                 |                                                 | 3     | 0               |       | MAddr         |          | OUTB RAM[Addr]                      | OUTB ← RAM[RC:MAddr:LAddr]         |                |  |  |  |  |
| 75XX                 |                                                 |       | 1               |       | X             |          | OUTB RAM[RC:RB:RA]                  | OUTB ← RAM[RC:RB:RA]               |                |  |  |  |  |
| 06Xn                 |                                                 | 2     | 0               | 6     | X             | OUTC     | OUTC n                              | OUTC ← n                           | -              |  |  |  |  |
| 16XX                 |                                                 |       | 1               |       |               |          | OUTC ACC                            | OUTC ← ACC                         |                |  |  |  |  |
| 26XX                 |                                                 |       | 2               |       |               |          | OUTC RA                             | OUTC ← RA                          |                |  |  |  |  |
| 36mn                 |                                                 |       | 0               |       | MAddr         |          | OUTC RAM[Addr]                      | OUTC ← RAM[RC:MAddr:LAddr]         |                |  |  |  |  |
| 76XX                 |                                                 | 3     | 3               |       | X             |          | OUTC RAM[RC:RB:RA]                  | OUTC ← RAM[RC:RB:RA]               |                |  |  |  |  |
| 07XX                 | X                                               | 3     | 0               | 7     | X             | NOP      | NOP                                 | No Operation                       | -              |  |  |  |  |
| 17XX                 |                                                 |       | 1               |       |               |          | LDR RA                              | RA ← ACC                           | -              |  |  |  |  |
| 27XX                 |                                                 |       | 2               |       |               |          | LDR RB                              | RB ← ACC                           | -              |  |  |  |  |
| 37XX                 |                                                 |       | 3               |       |               |          | LDR RC                              | RC ← ACC                           | -              |  |  |  |  |
| 08Xn                 |                                                 | 4     | 0               | 8     | X             | CMP      | CMP ACC,n                           | ACC - n                            | CF, ZF         |  |  |  |  |
| 18XX                 |                                                 |       | 1               |       |               |          | CMP ACC,RA                          | ACC - RA                           |                |  |  |  |  |
| 28XX                 |                                                 |       | 2               |       |               |          | CMP ACC,RB                          | ACC - RB                           |                |  |  |  |  |
| 38mn                 |                                                 |       | 0               |       | MAddr         |          | CMP ACC, RAM[Addr]                  | ACC - RAM[RC:MAddr:LAddr]          |                |  |  |  |  |
| 78XX                 |                                                 | 1     | 3               |       | X             |          | ACC - RAM[RC:RB:RA]                 | ACC - RAM[RC:RB:RA]                |                |  |  |  |  |
| 09Xn                 | X                                               | 2     | 0               | 9     | X             | OUTD     | OUTD n                              | OUTD ← n                           | -              |  |  |  |  |
| 19XX                 |                                                 |       | 1               |       |               |          | OUTD ACC                            | OUTD ← ACC                         |                |  |  |  |  |
| 29XX                 |                                                 |       | 2               |       |               |          | OUTD RA                             | OUTD ← RA                          |                |  |  |  |  |
| 39mn                 |                                                 | 3     | 0               |       | MAddr         |          | OUTD RAM[Addr]                      | OUTD ← RAM[RC:MAddr:LAddr]         |                |  |  |  |  |
| 79XX                 |                                                 |       | 1               |       | X             |          | OUTD RAM[RC:RB:RA]                  | OUTD ← RAM[RC:RB:RA]               |                |  |  |  |  |
| 04mn                 |                                                 | 0     | 0               | Ah    | MAddr         | STW      | STW RAM[Addr], ACC                  | RAM[RC:MAddr:LAddr] ← ACC          | -              |  |  |  |  |
| 4AXX                 |                                                 |       | 1               |       | X             |          | STW RAM[RC:RB:RA], ACC              | RAM[RC:RB:RA] ← ACC                |                |  |  |  |  |
| 0BXn                 | X                                               | 2     | 0               | Bh    | X             | SUB      | SUB ACC,n                           | ACC ← ACC - n                      | CF, ZF         |  |  |  |  |
| 1BXX                 |                                                 |       | 1               |       |               |          | SUB ACC,RA                          | ACC ← ACC - RA                     |                |  |  |  |  |
| 2BXX                 |                                                 |       | 2               |       |               |          | SUB ACC,RB                          | ACC ← ACC - RB                     |                |  |  |  |  |
| 3Bmn                 |                                                 | 3     | 0               |       | MAddr         |          | SUB ACC, RAM[Addr]                  | ACC ← ACC - RAM[RC:MAddr:LAddr]    |                |  |  |  |  |
| 7BXX                 |                                                 |       | 1               |       | X             |          | SUB ACC, RAM[RC:RB:RA]              | ACC ← ACC - RAM[RC:RB:RA]          |                |  |  |  |  |
| 0Cmn                 |                                                 | 0     | 0               | Ch    | MAddr         | JPI      | JPI RC:MA[7:4]:LA[3:0]              | PC ← [RC:MAddr:LAddr]              | -              |  |  |  |  |
| 4CXX                 |                                                 |       | 1               |       | X             |          | PC ← [RC:RB:RA]                     | -                                  |                |  |  |  |  |
| 0Dmn                 | 0                                               | 0     | 0               | Dh    | MAddr         | JPC      | JPC MA[7:4]:LA[3:0]                 | If CF=1, PC ← [PCH:MAddr:LAddr]    | -              |  |  |  |  |
| 4DXX                 |                                                 |       | 1               |       | X             |          | PC ← [PCH:RB:RA]                    | -                                  |                |  |  |  |  |
| 0Emn                 | 0                                               | 0     | 0               | Eh    | MAddr         | JPZ      | JPZ MA[7:4]:LA[3:0]                 | If ZF=1, PC ← [PCH:MAddr:LAddr]    | -              |  |  |  |  |
| 4EXX                 |                                                 |       | 1               |       | X             |          | PC ← [PCH:RB:RA]                    | -                                  |                |  |  |  |  |
| 0FXn                 | X                                               | 2     | 0               | Fh    | X             | ADD      | ADD ACC,n                           | ACC ← ACC + n                      | CF, ZF         |  |  |  |  |
| 1FXX                 |                                                 |       | 1               |       |               |          | ADD ACC,RA                          | ACC ← ACC + RA                     |                |  |  |  |  |
| 2FXX                 |                                                 |       | 2               |       |               |          | ADD ACC,RB                          | ACC ← ACC + RB                     |                |  |  |  |  |
| 3Fmn                 |                                                 | 3     | 0               |       | MAddr         |          | ADD ACC, RAM[Addr]                  | ACC ← ACC + RAM[RC:MAddr:LAddr]    |                |  |  |  |  |
| 7FXX                 |                                                 |       | 1               |       | X             |          | ACC ← ACC + RAM[RC:RB:RA]           | ACC ← ACC + RAM[RC:RB:RA]          |                |  |  |  |  |
| 8XXX                 | 1                                               | X     | 0               | X     | INA           | INA      | INA                                 | ACC ← INA                          | ZF             |  |  |  |  |
| 9XXX                 |                                                 |       | 1               |       |               | INB      | ACC ← INB                           |                                    |                |  |  |  |  |
| AXXX                 |                                                 |       | 2               |       |               | INC      | ACC ← INC                           |                                    |                |  |  |  |  |
| BXXX                 |                                                 |       | 3               |       |               | IND      | ACC ← IND                           |                                    |                |  |  |  |  |

LA[3:0] => can be RA or Operand (LAddr), depends on the AMODE bit.  
MA[7:4] => can be RB or MAddr, depends on the AMODE bit.

**Address = Addr => RC:MA[7:4]:LA[3:0]**

If AMODE=0, Addr=RC:Maddr:LAddr

If AMODE=1, Addr=RC:RB:RA  
X=1, Y=1

X = don't care

$MAddr = m$ , so  
 $Opand = n$ , as

Operand = n, so the names are interchangeable

AMODE = Addressing mode (b14)

**MOD = Modifier bits (b13:b12)**

MAddr = Medium Address (b7:b4)

LAddr = Low Address (b3:b0)

**MICRO** = Instruction (b11:b8)

OPCODE = AMODE:MOD:MICRO  
ZF - Zero Flag

ZF = Zero Flag

*CF = Carry Flag*