# Crappy CPU machine code equivalence

# Antoine VIALLON

# 14 janvier 2020

# Table des matières

| 1    | Registers               | 6               |
|------|-------------------------|-----------------|
| 2    | High level instructions | 6               |
| 2.1  | ABRT                    | 6               |
| 2.2  | ADD                     | 7               |
| 2.3  | AND                     | 7               |
| 2.4  | CALL                    | 7               |
| 2.5  | CLR                     | 7               |
| 2.6  | CMP                     | 7               |
| 2.7  | DISP                    | 7               |
| 2.8  | HALT                    | 8               |
| 2.9  | INC                     | 8               |
| 2.10 | JBIT                    | 8               |
| 2.11 |                         | 8               |
| 2.12 | JGE                     | 8               |
| 2.13 |                         | 8               |
|      | JLE                     | 8               |
| 2.15 | JMP                     | 8               |
| 2.16 | JMPPTR                  | 8               |
| 2.17 | JNBIT                   | 8               |
| 2.18 | JNZ                     | 9               |
| 2.19 |                         | 9               |
| 2.20 | LEDTGL                  | 9               |
|      | MOV                     | 9               |
|      | NEG                     | 9               |
|      | NOP                     | 9               |
|      | NOT                     | 9               |
| 2.25 |                         | 9               |
|      |                         | 10              |
|      |                         | 10              |
|      |                         | $\frac{10}{10}$ |
|      |                         | 10              |
|      |                         | $10 \\ 10$      |
|      |                         | 10<br>10        |

| 3   | Instru          | ctions (low level)                    |
|-----|-----------------|---------------------------------------|
| 3.1 | default         | · · · · · · · · · · · · · · · · · · · |
|     | 3.1.1           | default: 0x00                         |
| 3.2 | ADD .           |                                       |
|     | 3.2.1           | ADD A to A: 0x01                      |
|     | 3.2.2           | ADD A to U0:0x02                      |
|     | 3.2.3           | ADD A to U1:0x03                      |
|     | 3.2.4           | ADD A to U2:0x04                      |
|     | 3.2.5           | ADD A to U3:0x05                      |
|     | 3.2.6           | ADD A to mem: 0x06                    |
|     | 3.2.7           | ADD B to A: 0x07                      |
|     | 3.2.8           | ADD B to U0:0x08                      |
|     | 3.2.9           | ADD_B_to_U1:0x09                      |
|     | 3.2.10          | ADD B to U2:0x0a                      |
|     | 3.2.10 $3.2.11$ | ADD B to U3:0x0b                      |
|     | 3.2.11 $3.2.12$ | ADD U0 to A:0x0c                      |
|     | 3.2.12 $3.2.13$ | ADD U0 to mem: 0x0d                   |
|     | 3.2.14          | ADD U1 to A:0x0e                      |
|     | 3.2.14 $3.2.15$ | ADD_U1_to_A . 0x0e                    |
|     | 3.2.16          | ADD_U1_to_mem : 0x01                  |
|     | 3.2.10 $3.2.17$ |                                       |
|     |                 |                                       |
|     | 3.2.18          |                                       |
|     | 3.2.19          | ADD_U3_to_mem: 0x13                   |
|     | 3.2.20          | ADD_const_to_A: 0x14                  |
|     | 3.2.21          | ADD_const_to_U0: 0x15                 |
|     | 3.2.22          | ADD_const_to_U1 : 0x16                |
|     | 3.2.23          | ADD_const_to_U2: 0x17                 |
|     | 3.2.24          | ADD_const_to_U3: 0x18                 |
|     | 3.2.25          | ADD_const_to_const_in_A : 0x19        |
|     | 3.2.26          | ADD_const_to_mem : 0x1a               |
|     | 3.2.27          | ADD_mem_to_A: 0x1b                    |
|     | 3.2.28          | ADD_mem_to_U0:0x1c                    |
|     | 3.2.29          | ADD_mem_to_U1:0x1d                    |
|     | 3.2.30          | ADD_mem_to_U2:0x1e 16                 |
|     | 3.2.31          | ADD_mem_to_U3:0x1f                    |
|     | 3.2.32          | ADD_mem_to_mem : 0x20                 |
| 3.3 |                 |                                       |
|     | 3.3.1           | AND_A_B_to_itself: 0x21 16            |
|     | 3.3.2           | AND_U0_B_to_itself: 0x22 16           |
|     | 3.3.3           | AND_U1_B_to_itself: 0x23              |
|     | 3.3.4           | AND_U2_B_to_itself: 0x24 17           |
|     | 3.3.5           | AND_U3_B_to_itself: 0x25 17           |
| 3.4 | CALL            |                                       |
|     | 3.4.1           | CALL_addr: 0x26 17                    |
| 3.5 | CMP .           |                                       |
|     | 3.5.1           | CMP_A_B: 0x27                         |
|     | 3.5.2           | CMP_A_U0:0x28 17                      |
|     | 3.5.3           | CMP_A_U1:0x29 18                      |
|     | 3.5.4           | CMP_A_U2:0x2a 18                      |
|     | 3.5.5           | CMP_A_U3: 0x2b                        |

A. Viallon Page 2/42

|     | 3.5.6  | CMP_A_const : 0x2c          | 8        |
|-----|--------|-----------------------------|----------|
|     | 3.5.7  | CMP_A_mem: 0x2d             | 8        |
|     | 3.5.8  | CMP_U0_A: 0x2e              | 9        |
|     | 3.5.9  |                             | 9        |
|     | 3.5.10 |                             | 9        |
|     | 3.5.11 | <del>_</del> <del>_</del> _ | 9        |
|     | 3.5.12 | <del>_</del> <del>_</del> _ | 9        |
|     | 3.5.13 |                             | 20       |
|     | 3.5.14 |                             | 20       |
|     | 3.5.15 |                             | 20       |
|     | 3.5.16 |                             | 20       |
|     | 3.5.17 |                             | 20       |
|     | 3.5.18 |                             | 21       |
|     | 3.5.19 |                             | 21       |
| 3.6 | COPY   |                             | 21       |
| 0.0 | 3.6.1  |                             | 21       |
|     | 3.6.2  |                             | 21       |
|     | 3.6.3  |                             | 21       |
|     | 3.6.4  |                             | 21       |
|     | 3.6.5  |                             | 22       |
|     | 3.6.6  |                             | 22       |
|     | 3.6.7  |                             | 22       |
|     | 3.6.8  |                             | 22       |
|     | 3.6.9  |                             | 22       |
|     | 3.6.10 |                             | 22       |
|     | 3.6.11 |                             | 22       |
|     | 3.6.12 |                             | 22       |
|     | 3.6.13 |                             | 23       |
|     | 3.6.14 |                             | 23       |
|     | 3.6.14 |                             | 23       |
|     | 3.6.16 |                             | 23       |
|     | 3.6.17 |                             | 23       |
|     | 3.6.18 |                             | 23       |
|     | 3.6.19 |                             | 23       |
|     | 3.6.20 |                             | 23       |
|     | 3.6.20 |                             | 24       |
|     | 3.6.21 |                             | 24       |
|     | 3.6.23 |                             | 24       |
|     | 3.6.24 | ·                           | 24<br>24 |
|     | 3.6.24 |                             | 24<br>24 |
|     | 3.6.26 |                             | 24<br>24 |
|     |        | — — - ·                     |          |
|     | 3.6.27 | <del>_</del>                | 24       |
| 27  | 3.6.28 | — — <b>-</b>                | 25       |
| 3.7 | DISPL. |                             | 25       |
|     | 3.7.1  | <del>_</del>                | 25<br>5  |
|     | 3.7.2  | <del>_</del>                | 25<br>5  |
|     | 3.7.3  |                             | 25       |
|     | 3.7.4  | <del>_</del>                | 25       |
|     | 3.7.5  |                             | 25       |
|     | 3.7.6  | DISPLAY_U3:0x5b 2           | 25       |

A. Viallon Page 3/42

|      | 3.7.7           | DISPLAY mem: 0x5c         |
|------|-----------------|---------------------------|
| 3.8  |                 |                           |
| 0.0  | 3.8.1           | FAIL: 0x5d                |
| 3.9  | HALT            |                           |
| 0.0  | 3.9.1           | HALT: 0x5e                |
| 3 10 |                 |                           |
| 5.10 | 3.10.1          | INC A: 0x5f               |
|      | 3.10.1 $3.10.2$ | INC B: 0x60               |
|      |                 | INC U0: 0x61              |
|      | 3.10.3          | <del>_</del>              |
|      | 3.10.4          | INC_U1: 0x62              |
|      | 3.10.5          | INC_U2: 0x63              |
|      | 3.10.6          | INC_U3: 0x64              |
|      | 3.10.7          | INC_mem: 0x65 27          |
| 3.11 | JMP .           |                           |
|      | 3.11.1          | JMP_const : 0x66          |
|      | 3.11.2          | JMP_if_eq: 0x67           |
|      | 3.11.3          | JMP_if_ge: 0x68           |
|      | 3.11.4          | JMP_if_gt: 0x69           |
|      | 3.11.5          | JMP_if_le: 0x6a 28        |
|      | 3.11.6          | JMP_if_lt: 0x6b           |
|      | 3.11.7          | JMP if neq: 0x6c          |
|      | 3.11.8          | JMP not sel bit 0:0x6d 28 |
|      | 3.11.9          | JMP not sel bit 1:0x6e    |
|      | 3.11.10         | JMP not sel bit 2:0x6f    |
|      |                 | JMP not sel bit 3:0x70    |
|      |                 | JMP not sel bit 4:0x71    |
|      |                 | JMP not sel bit 5:0x72    |
|      |                 | JMP not sel bit 6:0x73    |
|      |                 | JMP_not_sel_bit_7:0x74    |
|      |                 | JMP_ptr: 0x75             |
|      |                 | JMP sel bit 0:0x76        |
|      |                 |                           |
|      |                 | JMP_sel_bit_1: 0x77       |
|      |                 | JMP_sel_bit_2:0x78        |
|      |                 | JMP_sel_bit_3: 0x79       |
|      |                 | JMP_sel_bit_4: 0x7a       |
|      |                 | JMP_sel_bit_5: 0x7b       |
|      |                 | JMP_sel_bit_6: 0x7c 31    |
|      |                 | JMP_sel_bit_7:0x7d 31     |
| 3.12 |                 | 31                        |
|      | 3.12.1          | LED_tgl: 0x7e 31          |
| 3.13 | LOAD            | 31                        |
|      | 3.13.1          | LOAD_const_to_A : 0x7f    |
|      | 3.13.2          | LOAD_const_to_B : 0x80    |
|      | 3.13.3          | LOAD_const_to_U0:0x81 32  |
|      | 3.13.4          | LOAD_const_to_U1:0x82 32  |
|      | 3.13.5          | LOAD_const_to_U2:0x83 32  |
|      | 3.13.6          | LOAD_const_to_U3:0x84     |
|      | 3.13.7          | LOAD ptr to A: 0x85       |
|      | 3.13.8          | LOAD ptr to B: 0x86       |
|      | 3.13.9          | LOAD_ptr_to_U0:0x87       |

A. Viallon Page 4/42

|      |         | LOAD_ptr_to_U1:0x88 3   |
|------|---------|-------------------------|
|      | 3.13.11 | LOAD_ptr_to_U2:0x89     |
|      | 3.13.12 | LOAD_ptr_to_U3:0x8a     |
| 3.14 | NEG .   | 3:                      |
|      | 3.14.1  | NEG_A: 0x8b             |
|      | 3.14.2  | NEG_B: 0x8c             |
|      | 3.14.3  | NEG_U0:0x8d 3           |
|      |         | NEG U1:0x8e 3           |
|      | 3.14.5  | NEG U2:0x8f             |
|      | 3.14.6  | NEG U3:0x90 3           |
|      | 3.14.7  | NEG mem: 0x91           |
| 3.15 | NOP .   |                         |
|      |         | NOP: 0x92               |
| 3.16 | NOT .   |                         |
|      | 3.16.1  | NOT_A: 0x93             |
|      | 3.16.2  | NOT_B: 0x94             |
|      |         | NOT_U0:0x95 3           |
|      | 3.16.4  | NOT_U1:0x96 3           |
|      | 3.16.5  | NOT_U2:0x97 3           |
|      |         | NOT U3:0x98             |
| 3.17 |         |                         |
|      |         | OR A B to itself: 0x99  |
|      | 3.17.2  | OR U0 B to itself: 0x9a |
|      | 3.17.3  | OR U1 B to itself: 0x9b |
|      | 3.17.4  | OR U2 B to itself: 0x9c |
|      | 3.17.5  | OR_U3_B_to_itself: 0x9d |
|      |         |                         |
|      | 3.18.1  | RET: 0x9e               |
|      |         |                         |
|      | 3.19.1  | SHIFTL A: 0x9f          |
|      | 3.19.2  | SHIFTL_B: 0xa0          |
|      | 3.19.3  | SHIFTL_U0: 0xa1 3       |
|      | 3.19.4  | SHIFTL U1:0xa2 3        |
|      | 3.19.5  | SHIFTL U2:0xa3 3        |
|      | 3.19.6  | SHIFTL_U3: 0xa4         |
| 3.20 | SHIFTI  | R                       |
|      | 3.20.1  | SHIFTR_A: 0xa5          |
|      |         | SHIFTR_B: 0xa6          |
|      | 3.20.3  | SHIFTR_U0: 0xa7 3       |
|      | 3.20.4  | SHIFTR_U1:0xa8 3        |
|      | 3.20.5  | SHIFTR_U2:0xa9 3        |
|      | 3.20.6  | SHIFTR U3:0xaa 39       |
| 3.21 | SLEEP   |                         |
|      | 3.21.1  | SLEEP A: 0xab 39        |
|      | 3.21.2  | SLEEP_B: 0xac 3         |
|      | 3.21.3  | SLEEP_U0: 0xad          |
|      | 3.21.4  | SLEEP_U1: 0xae          |
|      | 3.21.5  | SLEEP_U2:0xaf 3         |
|      | 3.21.6  | SLEEP_U3: 0xb0          |
|      | 3.21.7  | SLEEP_const: 0xb1       |
|      |         |                         |

A. Viallon Page 5/42

| 3.21.8             | SLEEP_mem : 0xb2                           | 40 |
|--------------------|--------------------------------------------|----|
| 3.22 STORI         | E                                          | 40 |
| 3.22.1             | $STORE\_A\_to\_address: Oxb3 \dots \dots$  | 40 |
| 3.22.2             | STORE_B_to_address: 0xb4                   | 40 |
| 3.22.3             | STORE_PCp1_to_address: 0xb5                | 40 |
| 3.22.4             | $STORE\_U0\_to\_address: Oxb6 \dots \dots$ | 40 |
| 3.22.5             | STORE_U1_to_address: 0xb7                  | 41 |
| 3.22.6             | $STORE\_U2\_to\_address: Oxb8 \dots \dots$ | 41 |
| 3.22.7             | STORE_U3_to_address: 0xb9                  | 41 |
| 3.22.8             | STORE_const_to_address: 0xba               | 41 |
| $3.23\mathrm{SUB}$ |                                            | 41 |
| 3.23.1             | SUB_A_to_A : 0xbb                          | 41 |
| 3.23.2             | SUB_B_to_A : 0xbc                          | 41 |
| 3.23.3             | SUB_U0_to_A : 0xbd                         | 42 |
| 3.23.4             | SUB_U1_to_A: 0xbe                          | 42 |
| 3.23.5             | SUB_U2_to_A: 0xbf                          | 42 |
| 3.23.6             | SUB_U3_to_A : 0xc0                         | 42 |
| 3.23.7             | SUB mem to A: 0xc1                         | 42 |

# 1 Registers

 $Available\ registers:$ 

- A: multi-purpose register. Is not overwriten quietly.
- B: work register. Used in many operations as a buffer
- U# : user registers. Will **never** be overwritten unless *explicitely* mentionned (see the instructions for more detail). There are only 4 of those currently.
- $\mathtt{ret}:$  not directly accessible. Used with CALL and RET
- cmp : not directly accessible. Used with CMP and JMPxxx
- disp: used to display something in decimal. Write-only.
- C: single bit register

# 2 High level instructions

# 2.1 ABRT

Set error bit and halt

— ABRT (size: 1, duration: 3)

A. Viallon Page 6/42

#### 2.2 ADD

 $Add\ a\ value\ from\ a\ register/memory\ address/const\ to\ a\ register\ or\ a\ memory\ address\ and\ save\ it\ in\ register\ A$ 

```
— ADD A, U# (size: 1, duration: 6)

— ADD R, B (size: 1, duration: 5)

— ADD R, A (size: 1, duration: 6)

— ADD R, @Oxhh (size: 2, duration: 9)

— ADD R, #Oxhh (size: 2, duration: 7)

— ADD @Oxhh, @Oxhh (size: 3, duration: 13)

— ADD @Oxhh, R (size: 2, duration: 9)

— ADD #Oxhh, #Oxhh (size: 3, duration: 9)

— ADD @Oxhh, #Oxhh (size: 3, duration: 10)
```

#### 2.3 AND

```
AND two registers, save the result to the first operand — AND R, B (size: 1, duration: 5)
```

# 2.4 CALL

Jump to specified address and save current PC in Ret register. Useful for subroutines.

```
— CALL #0xHH (size : 2, duration : 8)
```

#### 2.5 CLR

```
Clear a register address.
```

```
    CLR A (size: 1, duration: 6)
    CLR U# (size: 1, duration: 6)
    CLR @OxHH (size: 3, duration: 7)
```

# 2.6 CMP

Compare two values (substracts them) and store the result in CMP register. Overwrites B.

```
CMP R, @OxHH (size: 2, duration: 12)
CMP A, B (size: 1, duration: 8)
CMP A, U# (size: 1, duration: 8)
CMP R, #0xHH (size: 2, duration: 10)
CMP U#, A (size: 1, duration: 8)
CMP R (size: 1, duration: 4)
CMP @OxHH (size: 2, duration: 7)
```

#### 2.7 DISP

 $Display\ a\ value\ contained\ in\ specified\ register/memory\ address\ as\ an\ unsigned\ integer.$ 

```
DISP R (size: 1, duration: 4)DISP @OxHH (size: 2, duration: 7)
```

A. Viallon Page 7/42

```
2.8 HALT
```

```
Halt the CPU
— HALT (size: 1, duration: 3)
```

#### 2.9 INC

```
Increment register or value at memory address
```

```
— INC R (size: 1, duration: 5)
```

```
— INC @OxHH (size : 2, duration : 8)
```

# 2.10 JBIT

```
Go to specified address if selected bit of comparison register is 1.
```

```
— JBIT %b, #0xHH (size : 2, duration : 6)
```

#### 2.11 JG

```
Go to specified address if comparison register is strictly positive.
```

```
— JG #0xHH (size : 2, duration : 6)
```

#### 2.12 JGE

```
Go to specified address if comparison register is positive (or zero).

— JGE #0xHH (size : 2, duration : 6)
```

# 2.13 JL

```
Go to specified address if comparison register is strictly negative.

— JL #0xHH (size : 2, duration : 6)
```

#### 2.14 JLE

```
Go to specified address if comparison register is negative or zero. — JLE #0xHH (size : 2, duration : 6)
```

#### 2.15 JMP

```
Go to specified address
```

```
— JMP @0xHH (size : 2, duration : 7)
```

```
— JMP #0xHH (size : 2, duration : 5)
```

# 2.16 JMPPTR

```
Go to address value at memory address.

— JMPPTR @OxHH (size : 2, duration : 7)
```

# 2.17 JNBIT

```
Go to specified address if selected bit of comparison register is 0.

— JNBIT %b, #0xHH (size: 2, duration: 6)
```

A. Viallon Page 8/42

#### 2.18 JNZ

```
Go to specified address if comparison register is NOT zero.

— JNZ #0xHH (size : 2, duration : 6)
```

#### 2.19 JZ

```
Go to specified address if comparison register is zero.

— JZ #0xHH (size : 2, duration : 6)
```

#### 2.20 LEDTGL

```
Toggle led. Useful for debugging.
— LEDTGL (size: 1, duration: 4)
```

#### 2.21 MOV

Move a value from a register/memory address/const to a register or a memory address

```
MOV A, R (size: 1, duration: 4)
MOV B, R (size: 1, duration: 4)
MOV U#, A (size: 1, duration: 4)
MOV U#, B (size: 1, duration: 4)
MOV R, @OxHH (size: 2, duration: 7)
MOV R, #OxHH (size: 2, duration: 5)
MOV @OxHH, R (size: 2, duration: 6)
MOV @OxHH, @OxHH (size: 3, duration: 10)
MOV @OxHH, #OxHH (size: 3, duration: 7)
```

# 2.22 NEG

Compute two's complement of register/memory (useful for substractions), and store result in itself.

```
NEG R (size: 1, duration: 6)NEG @OxHH (size: 2, duration: 9)
```

#### 2.23 NOP

```
Go to next address
— NOP (size: 1, duration: 3)
```

#### 2.24 NOT

```
Invert bit by bit register, and store result in itself
— NOT R (size: 1, duration: 5)
```

#### 2.25 OR

```
OR two registers, save the result to the first operand
— OR A, B (size: 1, duration: 5)
— OR U#, B (size: 1, duration: 5)
```

A. Viallon Page 9/42

```
2.26 RET
```

```
Revert PC to value saved in Ret register. Use with CALL. — RET (size : 1, duration : 6)
```

#### 2.27 SHIFTL

```
Shift register to the left
— SHIFTL R (size: 1, duration: 5)
```

#### 2.28 **SHIFTR**

```
Shift register to the right
— SHIFTR R (size: 1, duration: 5)
```

#### 2.29 SLEEP

```
Pause\ clock\ for\ specified\ amount\ of\ ticks
```

```
— SLEEP R (size: 1, duration: 4)
```

- SLEEP #0xHH (size: 1, duration: 5)
- SLEEP @Oxhh (size: 1, duration: 7)

#### 2.30 SUB

Sub a value from a memory/register to register A and save it in register A. Overwrites B.

```
SUB R, @OxHH (size: 2, duration: 12)SUB A, R (size: 1, duration: 9)
```

# 2.31 XOR

XOR two registers, save the result to the first operand

```
— XOR A, B (size: 1, duration: 5)
```

- XOR A, A (size: 1, duration: 6)
- XOR U#, U# (size : 1, duration : 6)

# 3 Instructions (low level)

#### 3.1 default

#### 3.1.1 default: 0x00

Micro-instructions:

1. outPC, loadRAM

2. outRAM, loadInstruction, incPC

A. Viallon Page 10/42

# 3.2 ADD

# $3.2.1 \quad ADD\_A\_to\_A:0x01$

Micro-instructions:

1. outA, loadB

- 3. outALU, loadA
- $2. \ \mathtt{enableAdd}, \ \mathtt{loadALU}, \ \mathtt{outA}$
- 4. clearMIcounter

#### 3.2.2 ADD\_A\_to\_U0: 0x02

Micro-instructions:

1. outA, loadB

- 3. outALU, loadU0
- 2. enableAdd, loadALU, outU0
- 4. clearMIcounter

# $3.2.3 \quad ADD\_A\_to\_U1: 0x03$

 ${\it Micro-instructions}$  :

1. outA, loadB

- 3. outALU, loadU1
- 2. enableAdd, loadALU, outU1
- 4. clearMIcounter

# 3.2.4 ADD\_A\_to\_U2: 0x04

Micro-instructions:

1. outA, loadB

- 3. outALU, loadU2
- $2. \ \mathtt{enableAdd}, \ \mathtt{loadALU}, \ \mathtt{outU2}$
- 4. clearMIcounter

#### 3.2.5 ADD\_A\_to\_U3: 0x05

Micro-instructions:

1. outA, loadB

- 3. outALU, loadU3
- 2. enableAdd, loadALU, outU3
- 4. clearMIcounter

#### 3.2.6 ADD\_A\_to\_mem: 0x06

Micro-instructions:

1. outPC, loadRAM

- 5. enableAdd, loadALU, outA
- 2. outRAM, loadMemAddr, incPC
- 6. outALU, storeRAM
- 3. loadRAM, outMemAddr

4. outRAM, loadB

7. clearMIcounter

A. Viallon Page 11/42

#### 3.2.7 ADD\_B\_to\_A: 0x07

 ${\it Micro-instructions}$  :

1. enableAdd, loadALU, outA

3. clearMIcounter

2. outALU, loadA

# 3.2.8 ADD\_B\_to\_U0:0x08

Micro-instructions:

1. enableAdd, loadALU, outU0

3. clearMIcounter

2. outALU, loadU0

# 3.2.9 ADD\_B\_to\_U1:0x09

Micro-instructions:

1. enableAdd, loadALU, outU1

3. clearMIcounter

2. outALU, loadU1

# 3.2.10 ADD\_B\_to\_U2: 0x0a

Micro-instructions:

1. enableAdd, loadALU, outU2

3. clearMIcounter

 $2. \ \mathtt{outALU}, \ \mathtt{loadU2}$ 

# 3.2.11 ADD\_B\_to\_U3: 0x0b

Micro-instructions:

 $1. \ \mathtt{enableAdd}, \ \mathtt{loadALU}, \ \mathtt{outU3}$ 

3. clearMIcounter

 $2. \ \mathtt{outALU}, \ \mathtt{loadU3}$ 

# 3.2.12 ADD\_U0\_to\_A: 0x0c

 ${\it Micro-instructions}$  :

 $1. \ \mathtt{outU0}, \, \mathtt{loadB}$ 

3. outALU, loadA

 $2. \ \mathtt{enableAdd}, \, \mathtt{loadALU}, \, \mathtt{outA}$ 

4. clearMIcounter

A. Viallon Page 12/42

#### 3.2.13 ADD\_U0\_to\_mem: 0x0d

 ${\it Micro-instructions}$  :

- 1. outPC, loadRAM
- 2. outRAM, loadMemAddr, incPC
- 3. loadRAM, outMemAddr
- 4. outRAM, loadB

- 5. enableAdd, loadALU, outU0
- 6. outALU, storeRAM
- 7. clearMIcounter

#### 3.2.14 ADD\_U1\_to\_A: 0x0e

Micro-instructions:

- 1. outU1, loadB
- 2. enableAdd, loadALU, outA
- 3. outALU, loadA
- 4. clearMIcounter

#### 3.2.15 ADD\_U1\_to\_mem: 0x0f

Micro-instructions:

- 1. outPC, loadRAM
- 2. outRAM, loadMemAddr, incPC
- 3. loadRAM, outMemAddr
- 4. outRAM, loadB

- 5. enableAdd, loadALU, outU1
- 6. outALU, storeRAM
- 7. clearMIcounter

#### 3.2.16 ADD\_U2\_to\_A: 0x10

Micro-instructions:

- 1. outU2, loadB
- $2. \ \mathtt{enableAdd}, \, \mathtt{loadALU}, \, \mathtt{outA}$
- 3. outALU, loadA
- 4. clearMIcounter

# $3.2.17 \quad ADD\_U2\_to\_mem: \texttt{0x11}$

 ${\it Micro-instructions}:$ 

- $1. \ \mathtt{outPC}, \ \mathtt{loadRAM}$
- $2. \ \mathtt{outRAM}, \ \mathtt{loadMemAddr}, \ \mathtt{incPC}$
- $3. \ {\tt loadRAM}, \, {\tt outMemAddr}$
- $4. \ \mathtt{outRAM}, \, \mathtt{loadB}$

- 5. enableAdd, loadALU, outU2
- 6. outALU, storeRAM
- 7. clearMIcounter

# 3.2.18 ADD\_U3\_to\_A: 0x12

Micro-instructions:

- 1. outU3, loadB
- 2. enableAdd, loadALU, outA
- 3. outALU, loadA
- 4. clearMIcounter

Page 13/42

A. Viallon

#### 3.2.19 ADD\_U3\_to\_mem: 0x13

 ${\it Micro-instructions}$  :

- 1. outPC, loadRAM
- 2. outRAM, loadMemAddr, incPC
- 3. loadRAM, outMemAddr
- 4. outRAM, loadB

- 5. enableAdd, loadALU, outU3
- 6. outALU, storeRAM
- 7. clearMIcounter

#### $3.2.20 \quad ADD\_const\_to\_A : 0x14$

Micro-instructions:

- 1. outPC, loadRAM
- 2. outRAM, loadB, incPC
- 3. enableAdd, loadALU, outA
- 4. outALU, loadA
- 5. clearMIcounter

# $3.2.21 \quad ADD\_const\_to\_U0:0x15$

Micro-instructions:

- 1. outPC, loadRAM
- $2. \ \mathtt{outRAM}, \, \mathtt{loadB}, \, \mathtt{incPC}$
- 3. enableAdd, loadALU, outU0
- 4. outALU, loadUO
- 5. clearMIcounter

#### 3.2.22 ADD\_const\_to\_U1: 0x16

 ${\it Micro-instructions}$ :

- 1. outPC, loadRAM
- $2. \ \mathtt{outRAM}, \, \mathtt{loadB}, \, \mathtt{incPC}$
- $3. \ \mathtt{enableAdd}, \, \mathtt{loadALU}, \, \mathtt{outU1}$
- 4. outALU, loadU1
- 5. clearMIcounter

# $3.2.23 \quad ADD\_const\_to\_U2: \texttt{0x17}$

 ${\it Micro-instructions}$  :

1. outPC, loadRAM

- $4. \, \, {\tt outALU}, \, {\tt loadU2}$
- $2. \ \mathtt{outRAM}, \ \mathtt{loadB}, \ \mathtt{incPC}$
- 3. enableAdd, loadALU, outU2
- 5. clearMIcounter

# 3.2.24 ADD\_const\_to\_U3: 0x18

 ${\it Micro-instructions}$  :

- 1. outPC, loadRAM
- $3. \ \mathtt{enableAdd}, \ \mathtt{loadALU}, \ \mathtt{outU3}$

2. outRAM, loadB, incPC

5. clearMIcounter

4. outALU, loadU3

A. Viallon Page 14/42

#### 3.2.25 ADD\_const\_to\_const\_in\_A: 0x19

 ${\it Micro-instructions}$  :

- 1. outPC, loadRAM 5. enableAdd, loadALU, outA
- 2. outRAM, loadA, incPC
- 3. outPC, loadRAM

  6. outALU, loadA
- 4. outRAM, loadB, incPC 7. clearMIcounter

#### 3.2.26 ADD\_const\_to\_mem: 0x1a

Micro-instructions:

- $1. \ \mathtt{outPC}, \ \mathtt{loadRAM} \qquad \qquad 6. \ \mathtt{enableAdd}, \quad \mathtt{loadALU}, \quad \mathtt{outRAM},$
- 2. outRAM, loadMemAddr, incPC incPC
- 3. loadRAM, outMemAddr
  4. outRAM, loadB
  7. outALU, storeRAM
- 5. outPC, loadRAM 8. clearMIcounter

# 3.2.27 ADD\_mem\_to\_A: 0x1b

Micro-instructions:

- 1. outPC, loadRAM 5. enableAdd, loadALU, outA
- 2. outRAM, loadMemAddr, incPC 6. outALU, loadA
- 3. loadRAM, outMemAddr
  4. outRAM, loadB
  7. clearMIcounter

# 3.2.28 ADD\_mem\_to\_U0:0x1c

Micro-instructions:

- 1. outPC, loadRAM 5. enableAdd, loadALU, outU0
- 2. outRAM, loadMemAddr, incPC 6. outALU, loadU0
- 3. loadRAM, outMemAddr
  4. outRAM, loadB
  7. clearMIcounter

#### 3.2.29 ADD\_mem\_to\_U1:0x1d

Micro-instructions:

- 1. outPC, loadRAM 5. enableAdd, loadALU, outU1
- 2. outRAM, loadMemAddr, incPC 6. outALU, loadU1 3. loadRAM, outMemAddr
- 4. outRAM, loadB 7. clearMIcounter

A. Viallon Page 15/42

#### 3.2.30 ADD\_mem\_to\_U2:0x1e

 ${\it Micro-instructions}$  :

- 1. outPC, loadRAM
- 2. outRAM, loadMemAddr, incPC
- 3. loadRAM, outMemAddr
- 4. outRAM, loadB

- 5. enableAdd, loadALU, outU2
- 6. outALU, loadU2
- 7. clearMIcounter

# 3.2.31 ADD\_mem\_to\_U3:0x1f

Micro-instructions:

- 1. outPC, loadRAM
- $2. \ \mathtt{outRAM}, \ \mathtt{loadMemAddr}, \ \mathtt{incPC}$
- 3. loadRAM, outMemAddr
- 4. outRAM, loadB

- 5. enableAdd, loadALU, outU3
- 6. outALU, loadU3
- 7. clearMIcounter

# 3.2.32 ADD\_mem\_to\_mem: 0x20

Micro-instructions:

- 1. outPC, loadRAM
- 2. outRAM, loadMemAddr
- 3. outMemAddr, loadRAM
- 4. outRAM, loadA, incPC
- 5. outPC, loadRAM6. outRAM, loadMemAddr

- $7. \ \mathtt{outMemAddr}, \ \mathtt{loadRAM}$
- 8. outRAM, loadB, incPC
- 9. loadALU, enableAdd, outA
- 10. outALU, storeRAM
- 11. clearMIcounter

# 3.3 AND

# 3.3.1 AND\_A\_B\_to\_itself: 0x21

 ${\it Micro-instructions}$  :

- 1. enableAND, loadALU, outA
- 3. clearMIcounter

2. outALU, loadA

# 3.3.2 AND\_U0\_B\_to\_itself: 0x22

Micro-instructions:

- 1. enableAND, loadALU, outU0
- 3. clearMIcounter

 $2. \ \mathtt{outALU}, \ \mathtt{loadU0}$ 

A. Viallon Page 16/42

#### 3.3.3 AND\_U1\_B\_to\_itself: 0x23

 ${\it Micro-instructions}$  :

- 1. enableAND, loadALU, outU1
- 3. clearMIcounter

2. outALU, loadU1

#### 3.3.4 AND\_U2\_B\_to\_itself: 0x24

Micro-instructions:

- 1. enableAND, loadALU, outU2
- 3. clearMIcounter

2. outALU, loadU2

# 3.3.5 AND\_U3\_B\_to\_itself: 0x25

 ${\it Micro-instructions}$  :

- 1. enableAND, loadALU, outU3
- 3. clearMIcounter

2. outALU, loadU3

# 3.4 CALL

# 3.4.1 CALL\_addr: 0x26

Micro-instructions:

- outRetAddr, loadMemAddr
- 4. outRAM, loadMemAddr
- 2. outPCp1, storeRAM, incRet
- 5. loadPC, cond\_always, outMemAddr

3. outPC, loadRAM

6. clearMIcounter

#### 3.5 CMP

# 3.5.1 CMP\_A\_B: 0x27

Micro-instructions:

- $1. \ \mathtt{outB}, \ \mathtt{enableNOT}, \ \mathtt{loadALU}$
- 4. enableAdd, loadALU, outA
- $2. \ \mathtt{outALU}, \, \mathtt{enableInc}, \, \mathtt{loadALU}$
- 5. outALU, loadCmp

3. outALU, loadB

6. clearMIcounter

# 3.5.2 CMP\_A\_U0: 0x28

Micro-instructions:

- 1. outU0, enableNOT, loadALU
- 4. enableAdd, loadALU, outA
- 2. outALU, enableInc, loadALU
- 5. outALU, loadCmp

3. outALU, loadB

6. clearMIcounter

A. Viallon Page 17/42

#### 3.5.3 CMP\_A\_U1: 0x29

Micro-instructions:

- 1. outU1, enableNOT, loadALU
- 2. outALU, enableInc, loadALU
- 3. outALU, loadB

- 4. enableAdd, loadALU, outA
- 5. outALU, loadCmp
- 6. clearMIcounter

# 3.5.4 CMP\_A\_U2: 0x2a

Micro-instructions:

- 1. outU2, enableNOT, loadALU
- 2. outALU, enableInc, loadALU
- 3. outALU, loadB

- 4. enableAdd, loadALU, outA
- 5. outALU, loadCmp
- 6. clearMIcounter

#### $3.5.5 \text{ CMP}_A_U3:0x2b$

Micro-instructions:

- 1. outU3, enableNOT, loadALU
- 2. outALU, enableInc, loadALU
- 3. outALU, loadB

- 4. enableAdd, loadALU, outA
- 5. outALU, loadCmp
- 6. clearMIcounter

# 3.5.6 CMP\_A\_const: 0x2c

 ${\it Micro-instructions}$  :

- 1. outPC, loadRAM
- 2. outRAM, loadB, incPC
- $3. \ \mathtt{outB}, \ \mathtt{enableNOT}, \ \mathtt{loadALU}$
- $4. \ \mathtt{outALU}, \, \mathtt{enableInc}, \, \mathtt{loadALU}$
- 5. outALU, loadB
- 6. enableAdd, loadALU, outA
- 7. outALU, loadCmp
- 8. clearMIcounter

# 3.5.7 CMP\_A\_mem: 0x2d

 ${\it Micro-instructions}:$ 

- 1. outPC, loadRAM
- 2. outRAM, loadMemAddr, incPC
- 3. outMemAddr, loadRAM
- $4. \ \mathtt{outRAM}, \, \mathtt{loadB}$
- $5. \ \, {\tt outB}, \, {\tt enableNOT}, \, {\tt loadALU}$
- 6. outALU, enableInc, loadALU
- 7. outALU, loadB
- 8. enableAdd, loadALU, outA
- 9. outALU, loadCmp
- 10. clearMIcounter

A. Viallon Page 18/42

#### 3.5.8 CMP\_U0\_A: 0x2e

 ${\it Micro-instructions}$ :

- 1. outA, enableNOT, loadALU
- 2. outALU, enableInc, loadALU
- 3. outALU, loadB

- 4. enableAdd, loadALU, outU0
- 5. outALU, loadCmp
- 6. clearMIcounter

# 3.5.9 CMP\_U0\_const: 0x2f

Micro-instructions:

- 1. outPC, loadRAM
- 2. outRAM, loadB, incPC
- 3. outB, enableNOT, loadALU
- 4. outALU, enableInc, loadALU
- 5. outALU, loadB
- 6. enableAdd, loadALU, outU0
- 7. outALU, loadCmp
- 8. clearMIcounter

#### 3.5.10 CMP\_U0\_mem: 0x30

 ${\it Micro-instructions}$  :

- 1. outPC, loadRAM
- 2. outRAM, loadMemAddr, incPC
- 3. outMemAddr, loadRAM
- 4. outRAM, loadB
- $5. \ \mathtt{outB}, \ \mathtt{enableNOT}, \ \mathtt{loadALU}$
- 6. outALU, enableInc, loadALU
- 7. outALU, loadB
- 8. enableAdd, loadALU, outU0
- 9. outALU, loadCmp
- 10. clearMIcounter

#### 3.5.11 CMP\_U1\_A: 0x31

 ${\it Micro-instructions}:$ 

- $1. \ \mathtt{outA}, \ \mathtt{enableNOT}, \ \mathtt{loadALU}$
- $2. \ \mathtt{outALU}, \, \mathtt{enableInc}, \, \mathtt{loadALU}$
- 3. outALU, loadB

- 4. enableAdd, loadALU, outU1
- 5. outALU, loadCmp
- 6. clearMIcounter

#### 3.5.12 CMP\_U1\_const : 0x32

Micro-instructions:

- 1. outPC, loadRAM
- 2. outRAM, loadB, incPC
- $3. \ \mathtt{outB}, \, \mathtt{enableNOT}, \, \mathtt{loadALU}$
- 4. outALU, enableInc, loadALU
- 5. outALU, loadB
- 6. enableAdd, loadALU, outU1
- 7. outALU, loadCmp
- 8. clearMIcounter

A. Viallon Page 19/42

#### 3.5.13 CMP\_U1\_mem: 0x33

Micro-instructions:

- 1. outPC, loadRAM
- 2. outRAM, loadMemAddr, incPC
- 3. outMemAddr, loadRAM
- 4. outRAM, loadB
- 5. outB, enableNOT, loadALU
- 6. outALU, enableInc, loadALU
- 7. outALU, loadB
- 8. enableAdd, loadALU, outU1
- 9. outALU, loadCmp
- 10. clearMIcounter

#### 3.5.14 CMP\_U2\_A: 0x34

 ${\it Micro-instructions}:$ 

- 1. outA, enableNOT, loadALU
- 2. outALU, enableInc, loadALU
- 3. outALU, loadB

- $4. \ \mathtt{enableAdd}, \ \mathtt{loadALU}, \ \mathtt{outU2}$
- 5. outALU, loadCmp
- 6. clearMIcounter

# 3.5.15 CMP\_U2\_const : 0x35

Micro-instructions:

- 1. outPC, loadRAM
- 2. outRAM, loadB, incPC
- 3. outB, enableNOT, loadALU
- $4. \ \mathtt{outALU}, \, \mathtt{enableInc}, \, \mathtt{loadALU}$
- 5. outALU, loadB
- 6. enableAdd, loadALU, outU2
- 7. outALU, loadCmp
- 8. clearMIcounter

#### 3.5.16 CMP\_U2\_mem: 0x36

 ${\it Micro-instructions}:$ 

- $1. \ \mathtt{outPC}, \ \mathtt{loadRAM}$
- 2. outRAM, loadMemAddr, incPC
- 3. outMemAddr, loadRAM
- $4. \ \mathtt{outRAM}, \, \mathtt{loadB}$
- $5. \ \mathtt{outB}, \, \mathtt{enableNOT}, \, \mathtt{loadALU}$
- 6. outALU, enableInc, loadALU
- 7. outALU, loadB
- 8. enableAdd, loadALU, outU2
- 9. outALU, loadCmp
- 10. clearMIcounter

# 3.5.17 CMP\_U3\_A: 0x37

 ${\it Micro-instructions}:$ 

- $1. \ \mathtt{outA}, \ \mathtt{enableNOT}, \ \mathtt{loadALU}$
- $2. \ \mathtt{outALU}, \, \mathtt{enableInc}, \, \mathtt{loadALU}$
- 3. outALU, loadB

- 4. enableAdd, loadALU, outU3
- 5. outALU, loadCmp
- 6. clearMIcounter

A. Viallon Page 20/42

#### 3.5.18 CMP\_U3\_const: 0x38

 ${\it Micro-instructions}$  :

- 1. outPC, loadRAM
- 2. outRAM, loadB, incPC
- 3. outB, enableNOT, loadALU
- 4. outALU, enableInc, loadALU
- 5. outALU, loadB
- 6. enableAdd, loadALU, outU3
- 7. outALU, loadCmp
- 8. clearMIcounter

# $3.5.19 \quad CMP\_U3\_mem: 0x39$

 ${\it Micro-instructions}:$ 

- 1. outPC, loadRAM
- 2. outRAM, loadMemAddr, incPC
- 3. outMemAddr, loadRAM
- 4. outRAM, loadB
- $5. \ \mathtt{outB}, \, \mathtt{enableNOT}, \, \mathtt{loadALU}$
- $6. \ \mathtt{outALU}, \, \mathtt{enableInc}, \, \mathtt{loadALU}$
- 7. outALU, loadB
- 8. enableAdd, loadALU, outU3
- 9. outALU, loadCmp
- 10. clearMIcounter

# 3.6 COPY

# 3.6.1 COPY\_A\_to\_A: 0x3a

Micro-instructions:

1. outA, loadA

2. clearMIcounter

# 3.6.2 COPY\_A\_to\_B: 0x3b

 ${\it Micro-instructions}:$ 

1. outA, loadB

2. clearMIcounter

# 3.6.3 COPY\_A\_to\_U0: 0x3c

Micro-instructions:

1. outA, loadU0

2. clearMIcounter

# 3.6.4 COPY\_A\_to\_U1: 0x3d

 ${\it Micro-instructions}$  :

outA, loadU1

2. clearMIcounter

A. Viallon Page 21/42

3.6.5 COPY\_A\_to\_U2:0x3e  ${\it Micro-instructions}$  : outA, loadU2 2. clearMIcounter 3.6.6 COPY\_A\_to\_U3: 0x3f  ${\it Micro-instructions}$  : 2. clearMIcounter outA, loadU3 3.6.7 COPY\_A\_to\_cmp: 0x40  ${\it Micro-instructions}:$ 1. outA, loadCmp 2. clearMIcounter 3.6.8 COPY\_B\_to\_A: 0x41  ${\it Micro-instructions}$  : 1. outB, loadA 2. clearMIcounter 3.6.9 COPY\_B\_to\_B: 0x42 ${\it Micro-instructions}$  : 1. outB, loadB 2. clearMIcounter 3.6.10 COPY\_B\_to\_U0: 0x43  ${\it Micro-instructions}:$ 2. clearMIcounter 1. outB, loadU0 3.6.11 COPY\_B\_to\_U1: 0x44 Micro-instructions:1. outB, loadU1 2. clearMIcounter 3.6.12 COPY\_B\_to\_U2: 0x45  ${\it Micro-instructions}:$ 1. outB, loadU2 2. clearMIcounter

A. Viallon Page 22/42

 ${\it Micro-instructions}$  : 1. outB, loadU3 2. clearMIcounter 3.6.14 COPY\_B\_to\_cmp: 0x47 Micro-instructions:2. clearMIcounter  $1. \ \mathtt{outB}, \ \mathtt{loadCmp}$ 3.6.15 COPY\_U0\_to\_A: 0x48 Micro-instructions:1. outUO, loadA 2. clearMIcounter 3.6.16 COPY\_U0\_to\_B: 0x49  ${\it Micro-instructions}$ : 1. outUO, loadB 2. clearMIcounter 3.6.17 COPY\_U0\_to\_cmp: 0x4a  ${\it Micro-instructions}$  : 1. outU0, loadCmp 2. clearMIcounter 3.6.18 COPY\_U1\_to\_A: 0x4b  ${\it Micro-instructions}:$ 2. clearMIcounter 1. outU1, loadA 3.6.19 COPY\_U1\_to\_B: 0x4c Micro-instructions:1. outU1, loadB 2. clearMIcounter 3.6.20 COPY\_U1\_to\_cmp: 0x4d  ${\it Micro-instructions}$  : 2. clearMIcounter 1. outU1, loadCmp

3.6.13 COPY\_B\_to\_U3: 0x46

A. Viallon Page 23/42

3.6.21 COPY\_U2\_to\_A: 0x4e

 ${\it Micro-instructions}$  :

1. outU2, loadA 2. clearMIcounter

3.6.22 COPY\_U2\_to\_B: 0x4f

Micro-instructions:

1. outU2, loadB 2. clearMIcounter

3.6.23 COPY\_U2\_to\_cmp: 0x50

 ${\it Micro-instructions}$  :

1. outU2, loadCmp 2. clearMIcounter

3.6.24 COPY\_U3\_to\_A: 0x51

Micro-instructions:

1. outU3, loadA 2. clearMIcounter

 $3.6.25 \quad COPY\_U3\_to\_B: \texttt{0x52}$ 

 ${\it Micro-instructions}$  :

1. outU3, loadB 2. clearMIcounter

3.6.26 COPY\_U3\_to\_cmp: 0x53

Micro-instructions:

1. outU3, loadCmp 2. clearMIcounter

3.6.27 COPY\_mem: 0x54

 ${\it Micro-instructions}$  :

1. outPC, loadRAM 5. outPC, loadRAM

2. outRAM, loadMemAddr, incPC 6. outRAM, loadMemAddr, incPC

3. outMemAddr, loadRAM 7. storeRAM, outB 4. outRAM, loadB 8. clearMIcounter

A. Viallon Page 24/42

# 3.6.28 COPY\_mem\_to\_cmp: 0x55 Micro-instructions:

 $1. \ \mathtt{outPC}, \, \mathtt{loadRAM}$ 

4. outRAM, loadCmp

 $2. \ \mathtt{outRAM}, \ \mathtt{loadMemAddr}, \ \mathtt{incPC}$ 

 $3. \ \mathtt{outMemAddr}, \, \mathtt{loadRAM}$ 

5. clearMIcounter

# 3.7 DISPLAY

# 3.7.1 DISPLAY\_A: 0x56

 ${\it Micro-instructions}$  :

 $1. \ \mathtt{outA}, \ \mathtt{loadDisplay}$ 

2. clearMIcounter

# 3.7.2 DISPLAY\_B: 0x57

 ${\it Micro-instructions}:$ 

1. outB, loadDisplay

2. clearMIcounter

# 3.7.3 DISPLAY\_U0: 0x58

 ${\it Micro-instructions}:$ 

1. outUO, loadDisplay

2. clearMIcounter

# 3.7.4 DISPLAY\_U1: 0x59

 ${\it Micro-instructions}:$ 

1. outU1, loadDisplay

2. clearMIcounter

# 3.7.5 DISPLAY\_U2: 0x5a

Micro-instructions:

 $1. \ \mathtt{outU2}, \ \mathtt{loadDisplay}$ 

2. clearMIcounter

#### 3.7.6 DISPLAY U3: 0x5b

 ${\it Micro-instructions}:$ 

 $1. \ \mathtt{outU3}, \ \mathtt{loadDisplay}$ 

2. clearMIcounter

A. Viallon Page 25/42

# 3.7.7 DISPLAY\_mem: 0x5c

 ${\it Micro-instructions}$  :

- 1. outPC, loadRAM
- 2. outRAM, loadMemAddr, incPC
- 3. loadRAM, outMemAddr
- 4. outRAM, loadDisplay
- 5. clearMIcounter

#### 3.8 FAIL

#### 3.8.1 FAIL: 0x5d

 ${\it Micro-instructions}$  :

1. error, halt

# 3.9 HALT

#### 3.9.1 HALT: 0x5e

Micro-instructions:

1. halt

# 3.10 INC

# 3.10.1 INC\_A: 0x5f

 ${\it Micro-instructions}$  :

- 1. outA, enableInc, loadALU
- 2. outALU, loadA

3. clearMIcounter

# 3.10.2 INC\_B: 0x60

 ${\it Micro-instructions}$  :

- $1. \ \mathtt{outB}, \, \mathtt{enableInc}, \, \mathtt{loadALU}$
- 3. clearMIcounter

 $2. \ \mathtt{outALU}, \, \mathtt{loadB}$ 

# 3.10.3 INC\_U0: 0x61

 ${\it Micro-instructions}:$ 

- 1. outU0, enableInc, loadALU
- 3. clearMIcounter

 $2. \ \mathtt{outALU}, \ \mathtt{loadU0}$ 

A. Viallon Page 26/42

# 3.10.4 INC\_U1: 0x62

 ${\it Micro-instructions}$  :

- 1. outU1, enableInc, loadALU
- 2. outALU, loadU1

3. clearMIcounter

# 3.10.5 INC\_U2: 0x63

Micro-instructions:

- 1. outU2, enableInc, loadALU
- 2. outALU, loadU2

3. clearMIcounter

# 3.10.6 INC\_U3: 0x64

Micro-instructions:

- 1. outU3, enableInc, loadALU
- 2. outALU, loadU3

3. clearMIcounter

# 3.10.7 INC\_mem: 0x65

 ${\it Micro-instructions}$  :

- 1. outPC, loadRAM
- 2. outRAM, loadMemAddr, incPC
- $3. \ \mathtt{outMemAddr}, \, \mathtt{loadRAM}$
- 4. outRAM, enableInc, loadALU
- 5. outALU, storeRAM
- $6. \ {\tt clearMIcounter}$

# 3.11 JMP

# $3.11.1 \quad JMP\_const: 0x66$

 ${\it Micro-instructions}:$ 

- $1. \ \mathtt{outPC}, \ \mathtt{loadRAM}$
- 2. outRAM, loadPC, cond\_always
- 3. clearMIcounter

#### 3.11.2 JMP\_if\_eq: 0x67

Micro-instructions:

1. outPC, loadRAM

outRAM, loadPC, cond\_null

 $2.\ {\tt incPC}$ 

4. clearMIcounter

A. Viallon Page 27/42

#### 3.11.3 JMP\_if\_ge: 0x68

 ${\it Micro-instructions}$  :

1. outPC, loadRAM cond\_null

 $2.\ {\tt incPC}$ 

3. outRAM, loadPC, cond\_pos, 4. clearMIcounter

# 3.11.4 JMP\_if\_gt: 0x69

 ${\it Micro-instructions}$  :

1. outPC, loadRAM cond\_not\_null

2. incPC

3. outRAM, loadPC, cond\_pos, 4. clearMIcounter

#### 3.11.5 JMP\_if\_le: 0x6a

Micro-instructions:

1. outPC, loadRAM cond\_null

 $2. \ {\tt incPC}$ 

3. outRAM, loadPC, cond\_neg, 4. clearMIcounter

# $3.11.6 \quad JMP\_if\_lt: \texttt{0x6b}$

 ${\it Micro-instructions}$  :

1. outPC, loadRAM cond\_not\_null

 $2. \ {\tt incPC}$ 

3. outRAM, loadPC, cond\_neg, 4. clearMIcounter

# 3.11.7 JMP\_if\_neq: 0x6c

Micro-instructions:

1. outPC, loadRAM invert\_cond

 $2.\ {\tt incPC}$ 

3. outRAM, loadPC, cond\_null, 4. clearMIcounter

# $3.11.8 \quad JMP\_not\_sel\_bit\_0: 0x6d$

Micro-instructions:

1. outPC, loadRAM invert\_cond

 $2.\ {\tt incPC}$ 

 $3. \ \mathtt{outRAM}, \mathtt{loadPC}, \mathtt{cond\_selected\_bit}, \qquad 4. \ \mathtt{clearMIcounter}$ 

A. Viallon Page 28/42

#### 3.11.9 JMP\_not\_sel\_bit\_1: 0x6e

 ${\it Micro-instructions}$  :

1. outPC, loadRAM invert\_cond, selector0

2. incPC

 $3. \ \mathtt{outRAM}, \mathtt{loadPC}, \mathtt{cond\_selected\_bit}, \qquad 4. \ \mathtt{clearMIcounter}$ 

# $3.11.10 \quad JMP\_not\_sel\_bit\_2:0x6f$

Micro-instructions:

1. outPC, loadRAM invert\_cond, selector1

 $2.\ {\tt incPC}$ 

3. outRAM, loadPC, cond\_selected\_bit, 4. clearMIcounter

#### 3.11.11 JMP\_not\_sel\_bit\_3:0x70

 ${\it Micro-instructions}:$ 

1. outPC, loadRAM invert\_cond, selector0,

2. incPC selector1

3. outRAM, loadPC, cond\_selected\_bit, 4. clearMIcounter

# 3.11.12 JMP\_not\_sel\_bit\_4:0x71

 ${\it Micro-instructions}$  :

1. outPC, loadRAM invert\_cond, selector2

 $2.\ \mathtt{incPC}$ 

 $3. \ \mathtt{outRAM}, \mathtt{loadPC}, \mathtt{cond\_selected\_bit}, \qquad 4. \ \mathtt{clearMIcounter}$ 

#### 3.11.13 JMP\_not\_sel\_bit\_5: 0x72

 ${\it Micro-instructions}:$ 

1. outPC, loadRAM invert\_cond, selector0,

2. incPC selector2

3. outRAM, loadPC, cond\_selected\_bit, 4. clearMIcounter

#### $3.11.14 \quad JMP\_not\_sel\_bit\_6:0x73$

 ${\it Micro-instructions}$  :

1. outPC, loadRAM invert\_cond, selector1,

2. incPC selector2

3. outRAM, loadPC, cond\_selected\_bit, 4. clearMIcounter

A. Viallon Page 29/42

#### 3.11.15 JMP\_not\_sel\_bit\_7:0x74

 ${\it Micro-instructions}$  :

1. outPC, loadRAM invert\_cond, selector0,

2. incPC selector2

3. outRAM, loadPC, cond\_selected\_bit, 4. clearMIcounter

#### 3.11.16 JMP\_ptr: 0x75

 ${\it Micro-instructions}:$ 

1. outPC, loadRAM 4. outRAM, loadPC, cond\_always

 $2. \ \mathtt{outRAM}, \ \mathtt{loadMemAddr}$ 

3. outMemAddr, loadRAM 5. clearMIcounter

# 3.11.17 JMP\_sel\_bit\_0: 0x76

Micro-instructions:

1. outPC, loadRAM 3. outRAM, loadPC, cond\_selected\_bit

2. incPC 4. clearMIcounter

# 3.11.18 JMP\_sel\_bit\_1: 0x77

 ${\it Micro-instructions}:$ 

1. outPC, loadRAM selector0

 $2.\ {\tt incPC}$ 

3. outRAM, loadPC, cond\_selected\_bit, 4. clearMIcounter

#### 3.11.19 JMP\_sel\_bit\_2:0x78

Micro-instructions:

1. outPC, loadRAM selector1

 $2.\ {\tt incPC}$ 

 $3. \ \mathtt{outRAM}, \mathtt{loadPC}, \mathtt{cond\_selected\_bit}, \qquad 4. \ \mathtt{clearMIcounter}$ 

# $3.11.20 \quad JMP\_sel\_bit\_3:0x79$

Micro-instructions:

1. outPC, loadRAM selector0, selector1

 $2.\ {\tt incPC}$ 

3. outRAM, loadPC, cond\_selected\_bit, 4. clearMIcounter

A. Viallon Page 30/42

#### $3.11.21 \quad JMP\_sel\_bit\_4:0x7a$

 ${\it Micro-instructions}$  :

1. outPC, loadRAM selector2

2. incPC

3. outRAM, loadPC, cond\_selected\_bit, 4. clearMIcounter

# 3.11.22 JMP\_sel\_bit\_5: 0x7b

Micro-instructions:

1. outPC, loadRAM selector0, selector2

2. incPC

3. outRAM, loadPC, cond\_selected\_bit, 4. clearMIcounter

#### 3.11.23 JMP\_sel\_bit\_6: 0x7c

 ${\it Micro-instructions}:$ 

1. outPC, loadRAM selector1, selector2

 $2. \ {\tt incPC}$ 

3. outRAM, loadPC, cond\_selected\_bit, 4. clearMIcounter

# 3.11.24 JMP\_sel\_bit\_7:0x7d

 ${\it Micro-instructions}$  :

1. outPC, loadRAM selector0, selector1, selector2

 $2.\ \mathtt{incPC}$ 

 $3. \ \mathtt{outRAM}, \mathtt{loadPC}, \mathtt{cond\_selected\_bit}, \qquad 4. \ \mathtt{clearMIcounter}$ 

#### 3.12 LED

#### 3.12.1 LED\_tgl: 0x7e

Micro-instructions:

1. flipLed 2. clearMIcounter

# 3.13 LOAD

#### $3.13.1 \quad LOAD\_const\_to\_A : 0x7f$

 ${\it Micro-instructions}:$ 

1. outPC, loadRAM 3. clearMIcounter

 $2. \ \mathtt{outRAM}, \ \mathtt{loadA}, \ \mathtt{incPC}$ 

A. Viallon Page 31/42

#### $3.13.2 \quad LOAD\_const\_to\_B: 0x80$

 ${\it Micro-instructions}$  :

1. outPC, loadRAM 3. clearMIcounter

 $2. \ \mathtt{outRAM}, \, \mathtt{loadB}, \, \mathtt{incPC}$ 

# $3.13.3 \quad LOAD\_const\_to\_U0:0x81$

Micro-instructions:

1. outPC, loadRAM 3. clearMIcounter

2. outRAM, loadUO, incPC

# 3.13.4 LOAD\_const\_to\_U1: 0x82

 ${\it Micro-instructions}:$ 

1. outPC, loadRAM 3. clearMIcounter

2. outRAM, loadU1, incPC

# $3.13.5 \quad LOAD\_const\_to\_U2:0x83$

 ${\it Micro-instructions}:$ 

1. outPC, loadRAM 3. clearMIcounter

2. outRAM, loadU2, incPC

# 3.13.6 LOAD\_const\_to\_U3: 0x84

Micro-instructions:

1. outPC, loadRAM 3. clearMIcounter

 $2. \ \mathtt{outRAM}, \ \mathtt{loadU3}, \ \mathtt{incPC}$ 

# $3.13.7 \quad LOAD\_ptr\_to\_A : 0x85$

 ${\it Micro-instructions}$  :

1. outPC, loadRAM 4. outRAM, loadA

 $2. \ \mathtt{outRAM}, \ \mathtt{loadMemAddr}, \ \mathtt{incPC}$ 

 $3. \ \mathtt{outMemAddr}, \ \mathtt{loadRAM} \qquad \qquad 5. \ \mathtt{clearMIcounter}$ 

A. Viallon Page 32/42

#### 3.13.8 LOAD\_ptr\_to\_B: 0x86

 ${\it Micro-instructions}$ :

- 1. outPC, loadRAM 4. outRAM, loadB
- 2. outRAM, loadMemAddr, incPC
- 3. outMemAddr, loadRAM 5. clearMIcounter

# 3.13.9 LOAD\_ptr\_to\_U0: 0x87

Micro-instructions:

- 1. outPC, loadRAM 4. outRAM, loadUO
- $2. \ \mathtt{outRAM}, \ \mathtt{loadMemAddr}, \ \mathtt{incPC}$
- 3. outMemAddr, loadRAM 5. clearMIcounter

#### 3.13.10 LOAD\_ptr\_to\_U1: 0x88

Micro-instructions:

- 1. outPC, loadRAM 4. outRAM, loadU1
- 2. outRAM, loadMemAddr, incPC
- 3. outMemAddr, loadRAM 5. clearMIcounter

# $3.13.11 \quad LOAD\_ptr\_to\_U2:0x89$

 ${\it Micro-instructions}$ :

- 1. outPC, loadRAM 4. outRAM, loadU2
- 2. outRAM, loadMemAddr, incPC
- 3. outMemAddr, loadRAM 5. clearMIcounter

#### 3.13.12 LOAD\_ptr\_to\_U3: 0x8a

Micro-instructions:

- 1. outPC, loadRAM 4. outRAM, loadU3
- $2. \ \mathtt{outRAM}, \ \mathtt{loadMemAddr}, \ \mathtt{incPC}$
- 3. outMemAddr, loadRAM 5. clearMIcounter

# 3.14 NEG

#### 3.14.1 NEG\_A: 0x8b

Micro-instructions:

- 1. outA, enableNOT, loadALU 3. outALU, loadA
- $2. \ \mathtt{outALU}, \, \mathtt{enableInc}, \, \mathtt{loadALU} \qquad \qquad 4. \ \mathtt{clearMIcounter}$

A. Viallon Page 33/42

# 3.14.2 NEG\_B: 0x8c

 ${\it Micro-instructions}$  :

- 1. outB, enableNOT, loadALU 3. outALU, loadB
- 2. outALU, enableInc, loadALU 4. clearMIcounter

# 3.14.3 NEG\_U0: 0x8d

Micro-instructions:

- 1. outU0, enableNOT, loadALU 3. outALU, loadU0
- 2. outALU, enableInc, loadALU 4. clearMIcounter

# 3.14.4 NEG\_U1: 0x8e

Micro-instructions:

- $1. \ \, \mathtt{outU1}, \, \mathtt{enableNOT}, \, \mathtt{loadALU} \qquad \qquad 3. \, \, \mathtt{outALU}, \, \mathtt{loadU1}$
- 2. outALU, enableInc, loadALU 4. clearMIcounter

#### 3.14.5 NEG\_U2: 0x8f

Micro-instructions:

- 1. outU2, enableNOT, loadALU 3. outALU, loadU2
- $2. \ \, {\tt outALU}, \, {\tt enableInc}, \, {\tt loadALU} \qquad \qquad 4. \, \, {\tt clearMIcounter}$

# 3.14.6 NEG\_U3: 0x90

 ${\it Micro-instructions}:$ 

- outU3, enableNOT, loadALU
   outALU, enableInc, loadALU
   clearMIcounter

# 3.14.7 NEG\_mem: 0x91

Micro-instructions:

- 1. outPC, loadRAM 5. outALU, enableInc, loadALU
- 2. outRAM, loadMemAddr 6. outALU, storeRAM
- 3. outMemAddr, loadRAM, incPC
  4. outRAM, enableNOT, loadALU
  7. clearMIcounter
- A. Viallon Page 34/42

# 3.15 NOP

#### 3.15.1 NOP: 0x92

Micro-instructions:

1. clearMIcounter

# 3.16 NOT

#### 3.16.1 NOT\_A: 0x93

 ${\it Micro-instructions}$  :

 $1. \ \mathtt{enable NOT}, \, \mathtt{loadALU}, \, \mathtt{outA}$ 

3. clearMIcounter

2. outALU, loadA

# 3.16.2 NOT\_B: 0x94

Micro-instructions:

1. enableNOT, loadALU, outB

3. clearMIcounter

2. outALU, loadB

# 3.16.3 NOT\_U0: 0x95

 ${\it Micro-instructions}:$ 

1. enableNOT, loadALU, outUO

3. clearMIcounter

 $2. \ \mathtt{outALU}, \ \mathtt{loadU0}$ 

# 3.16.4 NOT\_U1: 0x96

Micro-instructions:

1. enableNOT, loadALU, outU1

3. clearMIcounter

2. outALU, loadU1

# 3.16.5 NOT\_U2: 0x97

 ${\it Micro-instructions}$  :

1. enableNOT, loadALU, outU2

3. clearMIcounter

2. outALU, loadU2

A. Viallon Page 35/42

# 3.16.6 NOT\_U3: 0x98

 ${\it Micro-instructions}$  :

- 1. enableNOT, loadALU, outU3
- 3. clearMIcounter

2. outALU, loadU3

# 3.17 OR

# 3.17.1 OR\_A\_B\_to\_itself: 0x99

Micro-instructions:

- 1. enableOR, loadALU, outA
- 3. clearMIcounter

2. outALU, loadA

# $3.17.2 \quad OR\_U0\_B\_to\_itself: \texttt{0x9a}$

 ${\it Micro-instructions}$  :

- $1. \ \mathtt{enableOR}, \ \mathtt{loadALU}, \ \mathtt{outUO}$
- 3. clearMIcounter

 $2. \ \mathtt{outALU}, \ \mathtt{loadU0}$ 

#### 3.17.3 OR\_U1\_B\_to\_itself: 0x9b

Micro-instructions:

- 1. enableOR, loadALU, outU1
- 3. clearMIcounter

2. outALU, loadU1

# 3.17.4 OR\_U2\_B\_to\_itself: 0x9c

 ${\it Micro-instructions}:$ 

- 1. enableOR, loadALU, outU2
- 3. clearMIcounter

 $2. \ \mathtt{outALU}, \ \mathtt{loadU2}$ 

# 3.17.5 OR\_U3\_B\_to\_itself: 0x9d

 ${\it Micro-instructions}$  :

- 1. enableOR, loadALU, outU3
- 3. clearMIcounter

 $2. \ \mathtt{outALU}, \ \mathtt{loadU3}$ 

A. Viallon Page 36/42

#### 3.18 RET

#### 3.18.1 RET : 0x9e

Micro-instructions:

- 1. decRet 3. outRAM, loadPC, cond\_always
- 2. outRetAddr, loadRAM 4. clearMIcounter

# 3.19 **SHIFTL**

#### 3.19.1 SHIFTL\_A: 0x9f

Micro-instructions:

- 1. outA, enableSHIFTL, loadALU 3. clearMIcounter
- 2. outALU, loadA

# 3.19.2 SHIFTL\_B: 0xa0

 ${\it Micro-instructions}:$ 

- 1. outB, enableSHIFTL, loadALU 3. clearMIcounter
- $2. \ \mathtt{outALU}, \, \mathtt{loadB}$

# 3.19.3 SHIFTL\_U0: 0xa1

Micro-instructions:

- 1. outU0, enableSHIFTL, loadALU 3. clearMIcounter
- $2. \ \mathtt{outALU}, \ \mathtt{loadU0}$

# 3.19.4 SHIFTL\_U1: 0xa2

Micro-instructions:

- $1. \ \mathtt{outU1}, \, \mathtt{enableSHIFTL}, \, \mathtt{loadALU} \qquad \qquad 3. \ \mathtt{clearMIcounter}$
- 2. outALU, loadU1

# 3.19.5 SHIFTL\_U2: 0xa3

Micro-instructions:

- $1. \ \mathtt{outU2}, \ \mathtt{enableSHIFTL}, \ \mathtt{loadALU}$
- 2. outALU, loadU2

3. clearMIcounter

A. Viallon Page 37/42

# 3.19.6 SHIFTL\_U3: 0xa4

 ${\it Micro-instructions}$  :

- 1. outU3, enableSHIFTL, loadALU
- 2. outALU, loadU3

3. clearMIcounter

# **3.20** SHIFTR

#### 3.20.1 SHIFTR A: 0xa5

Micro-instructions:

- 1. outA, enableSHIFTR, loadALU
- 2. outALU, loadA

3. clearMIcounter

# 3.20.2 SHIFTR\_B: 0xa6

 ${\it Micro-instructions}:$ 

- 1. outB, enableSHIFTR, loadALU
- 2. outALU, loadB

3. clearMIcounter

#### 3.20.3 SHIFTR\_U0: 0xa7

Micro-instructions:

- 1. outU0, enableSHIFTR, loadALU
- 2. outALU, loadUO

3. clearMIcounter

# 3.20.4 SHIFTR\_U1: 0xa8

 ${\it Micro-instructions}$  :

- 1. outU1, enableSHIFTR, loadALU
- 2. outALU, loadU1
- 3. clearMIcounter
- 3.20.5 SHIFTR\_U2: 0xa9

Micro-instructions:

- 1. outU2, enableSHIFTR, loadALU
- 3. clearMIcounter

 $2. \ \mathtt{outALU}, \ \mathtt{loadU2}$ 

A. Viallon Page 38/42

# 3.20.6 SHIFTR\_U3: 0xaa

 ${\it Micro-instructions}$  :

1. outU3, enableSHIFTR, loadALU

3. clearMIcounter

2. outALU, loadU3

# 3.21 SLEEP

# 3.21.1 SLEEP\_A : 0xab

 ${\it Micro-instructions}$ :

1. outA, loadSleep, incPC

2. clearMIcounter

# 3.21.2 SLEEP\_B: 0xac

Micro-instructions:

1. outB, loadSleep, incPC

2. clearMIcounter

# 3.21.3 SLEEP\_U0: 0xad

 ${\it Micro-instructions}$  :

 $1. \ \mathtt{outU0}, \, \mathtt{loadSleep}, \, \mathtt{incPC}$ 

2. clearMIcounter

#### 3.21.4 SLEEP\_U1: 0xae

 ${\it Micro-instructions}:$ 

 $1. \ \mathtt{outU1}, \ \mathtt{loadSleep}, \ \mathtt{incPC}$ 

2. clearMIcounter

# 3.21.5 SLEEP\_U2: 0xaf

 ${\it Micro-instructions}$  :

1. outU2, loadSleep, incPC

2. clearMIcounter

# 3.21.6 SLEEP\_U3: 0xb0

Micro-instructions:

 $1. \ \mathtt{outU3}, \ \mathtt{loadSleep}, \ \mathtt{incPC}$ 

2. clearMIcounter

A. Viallon Page 39/42

# 3.21.7 SLEEP\_const: 0xb1

 ${\it Micro-instructions}$  :

1. outPC, loadRAM 3. clearMIcounter

2. outRAM, loadSleep, incPC

# 3.21.8 SLEEP\_mem: 0xb2

Micro-instructions:

1. outPC, loadRAM 4. outRAM, loadSleep

 $2. \ \mathtt{outRAM}, \ \mathtt{loadMemAddr}, \ \mathtt{incPC}$ 

3. loadRAM, outMemAddr 5. clearMIcounter

# **3.22 STORE**

# $3.22.1 \quad STORE\_A\_to\_address: 0xb3$

Micro-instructions:

1. outPC, loadRAM 3. storeRAM, outA
2. outRAM, loadMemAddr, incPC 4. clearMIcounter

# 3.22.2 STORE\_B\_to\_address: 0xb4

 ${\it Micro-instructions}$  :

1. outPC, loadRAM 3. storeRAM, outB
2. outRAM, loadMemAddr, incPC 4. clearMIcounter

# 3.22.3 STORE\_PCp1\_to\_address: 0xb5

Micro-instructions:

outPC, loadRAM
 outRAM, loadMemAddr, incPC
 clearMIcounter

#### 3.22.4 STORE\_U0\_to\_address: 0xb6

 ${\it Micro-instructions}:$ 

1. outPC, loadRAM 3. storeRAM, outU0
2. outRAM, loadMemAddr, incPC 4. clearMIcounter

A. Viallon Page 40/42

#### 3.22.5 STORE\_U1\_to\_address: 0xb7

 ${\it Micro-instructions}$  :

outPC, loadRAM
 outRAM, loadMemAddr, incPC
 clearMIcounter

#### 3.22.6 STORE\_U2\_to\_address: 0xb8

Micro-instructions:

outPC, loadRAM
 outRAM, loadMemAddr, incPC
 dearMIcounter

#### 3.22.7 STORE\_U3\_to\_address: 0xb9

Micro-instructions:

outPC, loadRAM
 outRAM, loadMemAddr, incPC
 dearMIcounter

#### 3.22.8 STORE\_const\_to\_address: 0xba

Micro-instructions:

1. outPC, loadRAM 4. storeRAM, outRAM, incPC

2. outRAM, loadMemAddr, incPC

3. outPC, loadRAM 5. clearMIcounter

#### 3.23 SUB

# $3.23.1 \quad SUB\_A\_to\_A: Oxbb$

Micro-instructions:

1. outA, loadB 5. enableAdd, loadALU, outA

2. outB, enableNOT, loadALU3. outALU, enableInc, loadALU6. outALU, loadA

4. outALU, loadB 7. clearMIcounter

#### 3.23.2 SUB\_B\_to\_A: 0xbc

Micro-instructions:

1. outB, enableNOT, loadALU 4. enableAdd, loadALU, outA

2. outALU, enableInc, loadALU 5. outALU, loadA
3. outALU, loadB 6. clearMIcounter

A. Viallon Page 41/42

#### 3.23.3 SUB\_U0\_to\_A: 0xbd

 ${\it Micro-instructions}$  :

- $1. \ \mathtt{outU0}, \, \mathtt{loadB}$
- 2. outB, enableNOT, loadALU
- 3. outALU, enableInc, loadALU
- 4. outALU, loadB

- 5. enableAdd, loadALU, outA
- 6. outALU, loadA
- 7. clearMIcounter

#### 3.23.4 SUB\_U1\_to\_A: 0xbe

Micro-instructions:

- 1. outU1, loadB
- 2. outB, enableNOT, loadALU
- 3. outALU, enableInc, loadALU
- 4. outALU, loadB

- 5. enableAdd, loadALU, outA
- 6. outALU, loadA
- 7. clearMIcounter

# 3.23.5 SUB\_U2\_to\_A: 0xbf

 ${\it Micro-instructions}$ :

- 1. outU2, loadB
- 2. outB, enableNOT, loadALU
- 3. outALU, enableInc, loadALU
- 4. outALU, loadB

- 5. enableAdd, loadALU, outA
- 6. outALU, loadA
- 7. clearMIcounter

# 3.23.6 SUB\_U3\_to\_A: 0xc0

 ${\it Micro-instructions}$  :

- 1. outU3, loadB
- $2. \ \mathtt{outB}, \, \mathtt{enableNOT}, \, \mathtt{loadALU}$
- $3. \ \mathtt{outALU}, \, \mathtt{enableInc}, \, \mathtt{loadALU}$
- $4. \ \mathtt{outALU}, \, \mathtt{loadB}$

- 5. enableAdd, loadALU, outA
- 6. outALU, loadA
- 7. clearMIcounter

# $3.23.7 \quad SUB\_mem\_to\_A: \texttt{0xc1}$

Micro-instructions:

- 1. outPC, loadRAM
- 2. outRAM, loadMemAddr, incPC
- $3. \ \mathtt{outMemAddr}, \ \mathtt{loadRAM}$
- 4. outRAM, loadB
- $5. \ \mathtt{outB}, \ \mathtt{enableNOT}, \ \mathtt{loadALU}$
- 6. outALU, enableInc, loadALU
- $7. \ \mathtt{outALU}, \ \mathtt{loadB}$
- 8. enableAdd, loadALU, outA
- 9. outALU, loadA
- 10. clearMIcounter

A. Viallon Page 42/42