| Instruction      | Macro<br>Instruction | Cycle     | T-States              | Micro Instructions      | Active Bits                                               | CON            |
|------------------|----------------------|-----------|-----------------------|-------------------------|-----------------------------------------------------------|----------------|
|                  |                      |           | T <sub>1</sub>        | MAR←PC                  | E <sub>PC</sub> , L <sub>MAR</sub>                        | 18 00 00 00 00 |
|                  |                      | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]            | R,                                                        | 44 00 00 00 00 |
|                  |                      |           |                       | PC←PC+1                 | C <sub>p</sub>                                            |                |
| 1)               | ACC ←<br>Memory      |           | T <sub>3</sub>        | IR←MDR                  | E <sub>MDR</sub> , L <sub>IR1</sub> ,<br>CTR <sub>L</sub> | 00 C0 00 00 80 |
| LDA Address      | [Address]            |           | T <sub>4</sub>        | MAR←PC                  | $E_PC$ , $L_MAR$                                          | 18 00 00 00 00 |
|                  |                      | Execution | <b>T</b> <sub>5</sub> | MDR←RAM[MAR]<br>PC←PC+1 | R,<br>Cp                                                  | 44 00 00 00 00 |
|                  |                      |           | <b>T</b> <sub>6</sub> | MAR←MDR                 | E <sub>MDR</sub> , L <sub>MAR</sub>                       | 08 80 00 00 00 |
|                  |                      |           | T <sub>7</sub>        | MDR←RAM[MAR]            | R                                                         | 04 00 00 00 00 |
|                  |                      |           | T <sub>8</sub>        | ACC←MDR                 | $E_{MDR}$ , $L_{A}$ , $CTR_{R}$                           | 00 84 00 00 40 |
|                  |                      |           | T <sub>1</sub>        | MAR←PC                  | E <sub>PC</sub> , L <sub>MAR</sub>                        | 18 00 00 00 00 |
|                  |                      | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]            | R,                                                        | 44 00 00 00 00 |
| 2)               | • •                  |           |                       | PC←PC+1                 | C <sub>p</sub>                                            |                |
| 2)               | Memory<br>[Address]  |           | T <sub>3</sub>        | IR←MDR                  | E <sub>MDR</sub> , L <sub>IR1,</sub> CTR <sub>L</sub>     | 00 C0 00 00 80 |
| STA Address      | $\leftarrow$ ACC     |           | T <sub>4</sub>        | MAR←PC                  | E <sub>PC</sub> , L <sub>MAR</sub>                        | 18 00 00 00 00 |
|                  |                      | Execution | <b>T</b> <sub>5</sub> | MDR←RAM[MAR]<br>PC←PC+1 | R,<br>C <sub>p</sub>                                      | 44 00 00 00 00 |
|                  |                      |           | <b>T</b> <sub>6</sub> | MAR←MDR                 | E <sub>MDR</sub> , L <sub>MAR</sub>                       | 08 80 00 00 00 |
|                  |                      |           | <b>T</b> <sub>7</sub> | MDR←ACC                 | E <sub>A</sub> , L <sub>MDR</sub>                         | 01 02 00 00 00 |
|                  |                      |           | T <sub>8</sub>        | RAM[MAR]←MDR            | W, CTR <sub>R</sub>                                       | 02 00 00 00 40 |
|                  |                      |           | T <sub>1</sub>        | MAR←PC                  | E <sub>PC</sub> , L <sub>MAR</sub>                        | 18 00 00 00 00 |
| 3)<br>MOV ACC, B | ACC←B                | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1 | R,<br>C <sub>p</sub>                                      | 44 00 00 00 00 |
| , -              |                      |           | T <sub>3</sub>        | IR←MDR                  | E <sub>MDR</sub> , L <sub>IR1,</sub> CTR <sub>L</sub>     | 00 CO 00 00 80 |
|                  |                      | Execution | T <sub>4</sub>        | ACC←B                   | L <sub>A</sub> , E <sub>B,</sub><br>CTR <sub>R</sub>      | 00 04 00 80 40 |
|                  |                      |           |                       |                         |                                                           |                |

| Instruction        | Macro<br>Instruction | Cycle     | T-States       | Micro Instructions | Active Bits                                              | CON            |
|--------------------|----------------------|-----------|----------------|--------------------|----------------------------------------------------------|----------------|
|                    |                      |           | $T_1$          | MAR←PC             | E <sub>PC</sub> , L <sub>MAR</sub>                       | 18 00 00 00 00 |
| 4)                 |                      | Fetch     | $T_2$          | MDR←RAM[MAR]       | R,                                                       | 44 00 00 00 00 |
| MOV B, ACC         | B←ACC                |           |                | PC←PC+1            | Cp                                                       |                |
|                    |                      |           | T <sub>3</sub> | IR←MDR             | E <sub>MDR</sub> , L <sub>IR1,</sub><br>CTR <sub>L</sub> | 00 C0 00 00 80 |
|                    |                      | Execution | $T_4$          | B←ACC              | $L_B$ , $E_{A_r}$ CTR <sub>R</sub>                       |                |
|                    |                      |           |                |                    |                                                          | 00 02 01 00 40 |
|                    |                      |           | T <sub>1</sub> | MAR←PC             | E <sub>PC</sub> , L <sub>MAR</sub>                       | 18 00 00 00 00 |
| 5)                 |                      | Fetch     | T <sub>2</sub> | MDR←RAM[MAR]       | R,                                                       | 44 00 00 00 00 |
|                    |                      |           |                | PC←PC+1            | C <sub>p</sub>                                           |                |
| MOV ACC, immediate | ACC ← immediate      |           | T <sub>3</sub> | IR←MDR             | E <sub>MDR</sub> , L <sub>IR1</sub><br>CTR <sub>L</sub>  | 00 C0 00 00 80 |
|                    |                      |           | T <sub>4</sub> | MAR←PC             | E <sub>PC</sub> , L <sub>MAR</sub>                       | 18 00 00 00 00 |
|                    |                      |           | T <sub>5</sub> | MDR←RAM[MAR]       | R,                                                       | 44 00 00 00 00 |
|                    |                      | Execution |                | PC←PC+1            | Cp                                                       |                |
|                    |                      |           | T <sub>6</sub> | ACC←MDR            | L <sub>A</sub> , E <sub>MDR,</sub>                       | 00 84 00 00 40 |
|                    |                      |           |                |                    | CTR <sub>R</sub>                                         |                |
|                    |                      |           | T <sub>1</sub> | MAR←PC             | E <sub>PC</sub> , L <sub>MAR</sub>                       | 18 00 00 00 00 |
| 6)                 |                      | Fetch     | T <sub>2</sub> | MDR←RAM[MAR]       | R,                                                       | 44 00 00 00 00 |
|                    | ACC <b>←</b> input   |           |                | PC←PC+1            | C <sub>p</sub>                                           |                |
| IN                 |                      |           | T <sub>3</sub> | IR←MDR             | E <sub>MDR</sub> , L <sub>IR1</sub>                      | 00 C0 00 00 80 |
|                    |                      | Execution | T <sub>4</sub> | ACC←IN             | $L_A$ , $E_{IN}$ , $CTR_R$                               | 80 04 00 00 40 |
|                    |                      |           | T <sub>1</sub> | MAR←PC             | E <sub>PC</sub> , L <sub>MAR</sub>                       | 18 00 00 00 00 |
| 7)                 |                      | Fetch     | T <sub>2</sub> | MDR←RAM[MAR]       | R,                                                       | 44 00 00 00 00 |
| •                  | output←ACC           |           | _              | PC←PC+1            | C <sub>p</sub>                                           |                |
| OUT                | ·                    |           | T <sub>3</sub> | IR←MDR             | E <sub>MDR</sub> , L <sub>IR1</sub>                      | 00 C0 00 00 80 |
|                    |                      | Execution | T <sub>4</sub> | OUT←ACC            | L <sub>O</sub> , E <sub>A,</sub> CTR <sub>R</sub>        | 00 02 00 01 40 |
|                    |                      |           |                |                    |                                                          |                |

| Instruction | Macro<br>Instruction | Cycle     | T-States              | Micro Instructions                         | Active Bits                                                              | CON            |
|-------------|----------------------|-----------|-----------------------|--------------------------------------------|--------------------------------------------------------------------------|----------------|
|             |                      |           | $T_1$                 | MAR←PC                                     | $E_{PC}$ , $L_{MAR}$                                                     | 18 00 00 00 00 |
| 8)          |                      | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1                    | R,<br>C <sub>p</sub>                                                     | 44 00 00 00 00 |
| ADD B       | B ACC ←<br>ACC+B     |           | <b>T</b> <sub>3</sub> | IR←MDR                                     | E <sub>MDR</sub> , L <sub>IR1</sub>                                      | 00 C0 00 00 80 |
|             |                      | Execution | T <sub>4</sub>        | TEMP←B                                     | L <sub>TEMP</sub> , E <sub>B,</sub> E <sub>ADD</sub>                     | 00 00 44 80 00 |
|             |                      |           | <b>T</b> <sub>5</sub> | ACC←ACC+TEMP<br>FLAGS←C,Z                  | E <sub>ALU</sub> , L <sub>A,</sub> L <sub>FLAG</sub><br>CTR <sub>R</sub> | 00 04 80 08 40 |
|             |                      |           | T <sub>1</sub>        | MAR←PC                                     | E <sub>PC</sub> , L <sub>MAR</sub>                                       | 18 00 00 00 00 |
| 9)          | ACC ←                | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1                    | R,<br>Cp                                                                 | 44 00 00 00 00 |
| ADC B       | ACC+B+C              |           | <b>T</b> <sub>3</sub> | IR←MDR                                     | E <sub>MDR</sub> , L <sub>IR1</sub>                                      | 00 C0 00 00 80 |
|             |                      |           | T <sub>4</sub>        | IR←FLAGS                                   | L <sub>IR2</sub> , E <sub>FLAGS</sub>                                    | 00 20 00 02 00 |
|             |                      | Execution | <b>T</b> <sub>5</sub> | TEMP←B<br>C <sub>IN</sub> ←IR <sub>C</sub> | L <sub>TEMP</sub> , E <sub>B</sub><br>SADD,<br>E <sub>ADD</sub>          | 00 00 44 80 08 |
|             |                      |           | T <sub>6</sub>        | ACC←ACC+TEMP+C<br>FLAGS←C,Z                | E <sub>ALU,</sub> L <sub>A,</sub> L <sub>FLAGS,</sub> CTR <sub>R</sub>   | 00 04 80 08 40 |
|             |                      |           | T <sub>1</sub>        | MAR←PC                                     | E <sub>PC</sub> , L <sub>MAR</sub>                                       | 18 00 00 00 00 |
| 10)         |                      | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1                    | R,<br>C <sub>p</sub>                                                     | 44 00 00 00 00 |
| SUB B       | ACC ←ACC-B           |           | T <sub>3</sub>        | IR←MDR                                     | E <sub>MDR</sub> , L <sub>IR1</sub>                                      | 00 C0 00 00 80 |
|             |                      | Execution | T <sub>4</sub>        | TEMP←B                                     | L <sub>TEMP</sub> , E <sub>B</sub> ,                                     | 00 00 24 80 00 |
|             |                      |           | <b>T</b> <sub>5</sub> | ACC←ACC-TEMP<br>FLAGS←C,Z                  | E <sub>ALU</sub> , L <sub>A,</sub> L <sub>FLAG</sub> CTR <sub>R</sub>    | 00 04 80 08 40 |

| Instruction | Macro<br>Instruction  | Cycle     | T-States              | Micro Instructions                           | Active Bits                                                                              | CON            |
|-------------|-----------------------|-----------|-----------------------|----------------------------------------------|------------------------------------------------------------------------------------------|----------------|
|             |                       |           | $T_1$                 | MAR←PC                                       | E <sub>PC</sub> , L <sub>MAR</sub>                                                       | 18 00 00 00 00 |
| 11)         | ACC ←ACC-             | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1                      | R,<br>C <sub>p</sub>                                                                     | 44 00 00 00 00 |
| SBB B       | B-C                   |           | T <sub>3</sub>        | IR←MDR                                       | E <sub>MDR</sub> , L <sub>IR1</sub>                                                      | 00 C0 00 00 80 |
|             |                       |           | T <sub>4</sub>        | IR←FLAGS                                     | L <sub>IR2</sub> , E <sub>FLAGS</sub>                                                    | 00 20 00 02 00 |
|             |                       | Execution | <b>T</b> <sub>5</sub> | TEMP←B<br>C <sub>IN</sub> ←IR <sub>C</sub>   | L <sub>TEMP</sub> , E <sub>B</sub> SADD,                                                 | 00 00 24 80 08 |
|             |                       |           | T <sub>6</sub>        | ACC←ACC-TEMP-C<br>FLAGS←C,Z                  | E <sub>SUB</sub> E <sub>ALU</sub> , L <sub>A</sub> , L <sub>FLAGS</sub> CTR <sub>R</sub> | 00 04 80 08 40 |
|             |                       |           | T <sub>1</sub>        | MAR←PC                                       | E <sub>PC</sub> , L <sub>MAR</sub>                                                       | 18 00 00 00 00 |
|             |                       | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1                      | R,<br>C <sub>p</sub>                                                                     | 44 00 00 00 00 |
| 12)         | ACC←ACC + immediate + |           | T <sub>3</sub>        | IR←MDR                                       | E <sub>MDR</sub> , L <sub>IR1</sub>                                                      | 00 C0 00 00 80 |
| ADC         | С                     |           | T <sub>4</sub>        | MAR←PC                                       | E <sub>PC</sub> , L <sub>MAR</sub>                                                       | 18 00 00 00 00 |
| immediate   |                       | Execution | T <sub>5</sub>        | MDR←RAM[MAR]<br>PC←PC+1                      | R,<br>C <sub>p</sub>                                                                     | 44 00 00 00 00 |
|             |                       |           | <b>T</b> <sub>6</sub> | IR←FLAGS                                     | L <sub>IR2</sub> , E <sub>FLAGS</sub>                                                    | 00 20 00 02 00 |
|             |                       |           | T <sub>7</sub>        | TEMP←MDR<br>C <sub>IN</sub> ←IR <sub>C</sub> | E <sub>MDR</sub> , L <sub>TEMP</sub> SADD, E <sub>ADD</sub>                              | 00 80 44 00 08 |
|             |                       |           | T <sub>8</sub>        | ACC←ACC+<br>TEMP+C<br>FLAGS←C,Z              | E <sub>ALU</sub> , L <sub>A</sub> , L <sub>FLAGS</sub> CTR <sub>R</sub>                  | 00 04 80 08 40 |

| Instruction | Macro<br>Instruction  | Cycle     | T-States              | Micro Instructions                           | Active Bits                                                                            | CON            |
|-------------|-----------------------|-----------|-----------------------|----------------------------------------------|----------------------------------------------------------------------------------------|----------------|
|             |                       |           | T <sub>1</sub>        | MAR←PC                                       | E <sub>PC</sub> , L <sub>MAR</sub>                                                     | 18 00 00 00 00 |
| 13)         |                       | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1                      | R,<br>C <sub>p</sub>                                                                   | 44 00 00 00 00 |
| SBB         | ACC←ACC - immediate - |           | <b>T</b> <sub>3</sub> | IR←MDR                                       | E <sub>MDR</sub> , L <sub>IR1</sub>                                                    | 00 C0 00 00 80 |
| immediate   | С                     |           | <b>T</b> <sub>4</sub> | MAR←PC                                       | E <sub>PC</sub> , L <sub>MAR</sub>                                                     | 18 00 00 00 00 |
|             |                       | Execution | <b>T</b> <sub>5</sub> | MDR←RAM[MAR]<br>PC←PC+1                      | R,<br>C <sub>p</sub>                                                                   | 44 00 00 00 00 |
|             |                       |           | <b>T</b> <sub>6</sub> | IR←FLAGS                                     | L <sub>IR2</sub> , E <sub>FLAGS</sub>                                                  | 00 20 00 02 00 |
|             |                       |           | T <sub>7</sub>        | TEMP←MDR<br>C <sub>IN</sub> ←IR <sub>C</sub> | E <sub>MDR</sub> , L <sub>TEMP</sub> SADD,                                             | 00 80 24 00 08 |
|             |                       |           | T <sub>8</sub>        | ACC←ACC –TEMP-C<br>FLAGS←C,Z                 | E <sub>SUB</sub> E <sub>ALU,</sub> L <sub>A,</sub> L <sub>FLAGS</sub> CTR <sub>R</sub> | 00 04 80 08 40 |
|             | ACC                   |           | T <sub>1</sub>        | MAR←PC                                       | E <sub>PC</sub> , L <sub>MAR</sub>                                                     | 18 00 00 00 00 |
| 14)         | Unchanged;<br>FLAGS   | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1                      | R,                                                                                     | 44 00 00 00 00 |
| CMP B       | changed accordingly   |           | T <sub>3</sub>        | IR←MDR                                       | E <sub>MDR</sub> , L <sub>IR1</sub>                                                    | 00 C0 00 00 80 |
|             |                       | Execution | T <sub>4</sub>        | TEMP←B                                       | L <sub>TEMP</sub> , E <sub>B,</sub> E <sub>SUB</sub>                                   | 00 00 24 80 00 |
|             |                       |           | <b>T</b> <sub>5</sub> | FLAGS←ALU                                    | L <sub>FLAGS</sub> , E <sub>ALU</sub> CTR <sub>R</sub>                                 | 00 00 80 08 40 |
|             |                       |           | T <sub>1</sub>        | MAR←PC                                       | E <sub>PC</sub> , L <sub>MAR</sub>                                                     | 18 00 00 00 00 |
| 15)         |                       | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1                      | R,<br>C <sub>p</sub>                                                                   | 44 00 00 00 00 |
| XCHG        | ACC←→B                |           | <b>T</b> <sub>3</sub> | IR←MDR                                       | E <sub>MDR</sub> , L <sub>IR1</sub>                                                    | 00 C0 00 00 80 |
|             |                       |           | T <sub>4</sub>        | TEMP←B                                       | L <sub>TEMP</sub> , E <sub>B</sub>                                                     | 00 00 04 80 00 |
|             |                       | Execution | <b>T</b> <sub>5</sub> | B←ACC                                        | L <sub>B</sub> , E <sub>A</sub>                                                        | 00 02 01 00 00 |
|             |                       |           | T <sub>6</sub>        | ACC←TEMP                                     | $L_A$ , $E_{TEMP}$                                                                     | 00 04 02 00 40 |

| Instruction | Macro<br>Instruction | Cycle     | T-States              | Micro Instructions      | Active Bits                                           | CON            |
|-------------|----------------------|-----------|-----------------------|-------------------------|-------------------------------------------------------|----------------|
|             |                      |           | $T_1$                 | MAR←PC                  | E <sub>PC</sub> , L <sub>MAR</sub>                    | 18 00 00 00 00 |
| 16)         |                      | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1 | R,<br>C <sub>p</sub>                                  | 44 00 00 00 00 |
| JC address  | Jumps if C=1         |           | <b>T</b> <sub>3</sub> | IR←MDR                  | E <sub>MDR</sub> , L <sub>IR1</sub>                   | 00 C0 00 00 80 |
|             |                      |           | T <sub>4</sub>        | MAR←PC                  | E <sub>PC</sub> , L <sub>MAR</sub>                    | 18 00 00 00 00 |
|             |                      | Execution | <b>T</b> <sub>5</sub> | MDR←RAM[MAR]<br>PC←PC+1 | R,<br>C <sub>p</sub>                                  | 44 00 00 00 00 |
|             |                      |           | T <sub>6</sub>        | IR(6,7)←FLAGS           | E <sub>FLAGS</sub> , L <sub>IR2</sub>                 | 00 20 00 02 00 |
|             |                      |           | T <sub>7</sub>        | MUX C determine         | CTR <sub>C</sub>                                      | 00 00 00 00 20 |
|             |                      |           | T <sub>8</sub>        | PC ← MDR                | E <sub>MDR,</sub> L <sub>PC</sub> CTR <sub>R</sub>    | 20 80 00 00 40 |
| 44          |                      | Fetch     | T <sub>1</sub>        | MAR←PC                  | E <sub>PC</sub> , L <sub>MAR</sub>                    | 18 00 00 00 00 |
| 17)         |                      |           |                       |                         |                                                       |                |
| JE address  | Jumps if Z=1         |           | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1 | R,<br>C <sub>p</sub>                                  | 44 00 00 00 00 |
|             |                      |           | T <sub>3</sub>        | IR←MDR                  | E <sub>MDR</sub> , L <sub>IR1</sub>                   | 00 C0 00 00 80 |
|             |                      | Execution | T <sub>4</sub>        | MAR←PC                  | E <sub>PC</sub> , L <sub>MAR</sub>                    | 18 00 00 00 00 |
|             |                      |           | <b>T</b> <sub>5</sub> | MDR←RAM[MAR]<br>PC←PC+1 | R,<br>C <sub>p</sub>                                  | 44 00 00 00 00 |
|             |                      |           | T <sub>6</sub>        | IR(6,7)←FLAGS           | E <sub>FLAGS</sub> , L <sub>IR2</sub>                 | 00 20 00 02 00 |
|             |                      |           | T <sub>7</sub>        | MUX Z determine         | CTR <sub>z</sub>                                      | 00 00 00 00 10 |
|             |                      |           | T <sub>8</sub>        | PC ← MDR                | E <sub>MDR,</sub> L <sub>PC</sub><br>CTR <sub>R</sub> | 20 80 00 00 40 |

| Instruction | Macro<br>Instruction | Cycle     | T-States              | Micro Instructions      | Active Bits                                             | CON            |
|-------------|----------------------|-----------|-----------------------|-------------------------|---------------------------------------------------------|----------------|
|             |                      | Fetch     | T <sub>1</sub>        | MAR←PC                  | E <sub>PC</sub> , L <sub>MAR</sub>                      | 18 00 00 00 00 |
| 18)         | STACK←ACC            |           | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1 | R,<br>C <sub>p</sub>                                    | 44 00 00 00 00 |
| PUSH        |                      |           | <b>T</b> <sub>3</sub> | IR←MDR                  | E <sub>MDR</sub> , L <sub>IR1</sub><br>CTR <sub>L</sub> | 00 C0 00 00 80 |
|             |                      | Execution | T <sub>4</sub>        | MDR←ACC<br>SP←SP-1      | L <sub>MDR</sub> , E <sub>A</sub> D <sub>SP</sub>       | 01 02 00 10 00 |
|             |                      |           | T <sub>5</sub>        | MAR←SP                  | L <sub>MAR</sub> , E <sub>SP</sub>                      | 08 00 00 40 00 |
|             |                      |           | T <sub>6</sub>        | RAM[MAR]←MDR            | W<br>CTR <sub>R</sub>                                   | 02 00 00 00 40 |
|             |                      | Fetch     | T <sub>1</sub>        | MAR←PC                  | E <sub>PC</sub> , L <sub>MAR</sub>                      | 18 00 00 00    |
| 19)         | ACC←STACK            |           | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1 | R,<br>C <sub>p</sub>                                    | 44 00 00 00 00 |
| POP         |                      |           | T <sub>3</sub>        | IR←MDR                  | E <sub>MDR</sub> , L <sub>IR1</sub><br>CTR <sub>L</sub> | 00 C0 00 00 80 |
|             |                      | Execution | T <sub>4</sub>        | MAR←SP                  | L <sub>MAR</sub> , E <sub>SP</sub>                      | 08 00 00 40 00 |
|             |                      |           | T <sub>5</sub>        | MDR←RAM[MAR]<br>SP←SP+1 | R,<br>U <sub>SP</sub>                                   | 04 00 00 20 00 |
|             |                      |           | T <sub>6</sub>        | ACC←MDR                 | L <sub>A</sub> , E <sub>MDR</sub><br>CTR <sub>R</sub>   | 00 84 00 00 40 |

| Instruction     | Macro<br>Instruction | Cycle     | T-States        | Micro Instructions                       | Active Bits                                             | CON            |
|-----------------|----------------------|-----------|-----------------|------------------------------------------|---------------------------------------------------------|----------------|
|                 |                      | Fetch     | T <sub>1</sub>  | MAR←PC                                   | E <sub>PC</sub> , L <sub>MAR</sub>                      | 18 00 00 00 00 |
| 20)             | Calls                |           | T <sub>2</sub>  | MDR←RAM[MAR]<br>PC←PC+1                  | R,<br>C <sub>p</sub>                                    | 44 00 00 00 00 |
| CALL<br>Address | subroutine           |           | T <sub>3</sub>  | IR←MDR                                   | E <sub>MDR</sub> , L <sub>IR1</sub><br>CTR <sub>L</sub> | 00 C0 00 00 80 |
|                 |                      | Execution | T <sub>4</sub>  | MDR(0-4)←ACC<br>MDR(6-7)←FLAG<br>SP←SP-1 | L <sub>MDR</sub> , E <sub>A</sub> , E <sub>FLAGS</sub>  | 01 02 00 12 00 |
|                 |                      | Execution | T <sub>5</sub>  | MAR←SP                                   | $D_{SP}$ $L_{MAR}$ , $E_{SP}$                           | 08 00 00 40 00 |
|                 |                      |           | T <sub>6</sub>  | RAM[MAR]←MDR                             | W                                                       | 02 00 00 00 00 |
|                 |                      |           | T <sub>7</sub>  | MAR←PC                                   | E <sub>PC</sub> , L <sub>MAR</sub>                      | 18 00 00 00 00 |
|                 |                      |           | T <sub>8</sub>  | MDR←RAM[MAR]<br>PC←PC+1                  | R,<br>C <sub>p</sub>                                    | 44 00 00 00 00 |
|                 |                      |           | T <sub>9</sub>  | TEMP←MDR<br>SP←SP-1                      | L <sub>TEMP</sub> , E <sub>MDR</sub> , DSP              | 00 80 04 10 00 |
|                 |                      |           | T <sub>10</sub> | MDR←PC                                   | L <sub>MDR</sub> , E <sub>PC</sub>                      | 11 00 00 00 00 |
|                 |                      |           | T <sub>11</sub> | MAR←SP                                   | L <sub>MAR</sub> , E <sub>SP</sub>                      | 08 00 00 40 00 |
|                 |                      |           | T <sub>12</sub> | RAM[MAR]←MDR                             | W                                                       | 02 00 00 00 00 |
|                 |                      |           | T <sub>13</sub> | PC←TEMP                                  | L <sub>PC</sub> , E <sub>TEMP</sub> CTR <sub>R</sub>    | 20 00 02 00 40 |

| Instruction | Macro<br>Instruction   | Cycle     | T-States              | Micro Instructions             | Active Bits                                                             | CON            |
|-------------|------------------------|-----------|-----------------------|--------------------------------|-------------------------------------------------------------------------|----------------|
|             |                        |           | T <sub>1</sub>        | MAR←PC                         | E <sub>PC</sub> , L <sub>MAR</sub>                                      | 18 00 00 00 00 |
|             |                        | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]                   | R,                                                                      | 44 00 00 00 00 |
| 21)         |                        |           |                       | PC←PC+1                        | $C_p$                                                                   |                |
| RET         | Returns to caller from |           | T <sub>3</sub>        | IR←MDR                         | E <sub>MDR</sub> , L <sub>IR1</sub><br>CTR <sub>L</sub>                 | 00 C0 00 00 80 |
|             | current                |           | $T_4$                 | MAR←SP                         | L <sub>MAR</sub> , E <sub>SP</sub>                                      | 08 00 00 40 00 |
|             | subroutine             | Execution | <b>T</b> <sub>5</sub> | MDR←RAM[MAR]<br>SP←SP+1        | R<br>U <sub>SP</sub>                                                    | 04 00 00 20 00 |
|             |                        |           | <b>T</b> <sub>6</sub> | PC←MDR                         | L <sub>PC</sub> , E <sub>MDR</sub>                                      | 20 80 00 00 00 |
|             |                        |           | T <sub>7</sub>        | MAR←SP                         | L <sub>MAR</sub> , E <sub>SP</sub>                                      | 08 00 00 40 00 |
|             |                        |           | T <sub>8</sub>        | MDR←RAM[MAR]<br>SP←SP+1        | R,<br>U <sub>SP</sub>                                                   | 04 00 00 20 00 |
|             |                        |           | T <sub>9</sub>        | ACC←MDR(0-4)<br>FLAGS←MDR(6-7) | L <sub>A</sub> , E <sub>MDR</sub> , L <sub>FLAGS</sub> CTR <sub>R</sub> | 00 84 00 08 40 |
|             |                        |           | T <sub>1</sub>        | MAR <b>←</b> PC                | E <sub>PC</sub> , L <sub>MAR</sub>                                      | 18 00 00 00 00 |
|             |                        | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]                   | R,                                                                      | 44 00 00 00 00 |
| 22)         |                        |           | ٠,٧                   | PC←PC+1                        | C <sub>p</sub>                                                          |                |
| JMP address | Jumps to address       |           | <b>T</b> <sub>3</sub> | IR←MDR                         | E <sub>MDR</sub> , L <sub>IR1</sub>                                     | 00 C0 00 00 80 |
|             |                        |           | T <sub>4</sub>        | MAR←PC                         | L <sub>MAR</sub> , E <sub>PC</sub>                                      | 18 00 00 00 00 |
|             |                        | Execution | T <sub>5</sub>        | MDR←RAM[MAR]                   | R                                                                       | 04 00 00 00 00 |
|             |                        |           | T <sub>6</sub>        | PC←MDR                         | $L_{PC}$ , $E_{MDR}$ $CTR_{R}$                                          | 20 80 00 00 40 |
|             |                        |           | T <sub>1</sub>        | MAR←PC                         | E <sub>PC</sub> , L <sub>MAR</sub>                                      | 18 00 00 00 00 |
| 23)<br>HLT  | Halts                  |           | T <sub>2</sub>        | MDR←RAM[MAR]<br>PC←PC+1        | R,<br>C <sub>p</sub>                                                    | 44 00 00 00 00 |
|             | execution              |           | T <sub>3</sub>        | IR←MDR                         | E <sub>MDR</sub> , L <sub>IR1</sub>                                     | 00 C0 00 00 80 |
|             |                        | Execution | T <sub>4</sub>        | Stops clock                    | HLT,<br>CTR <sub>R</sub>                                                | 00 00 00 044   |

| Instruction | Macro<br>Instruction | Cycle     | T-States       | Micro Instructions      | Active Bits                                          | CON            |
|-------------|----------------------|-----------|----------------|-------------------------|------------------------------------------------------|----------------|
| 24)         |                      | Fetch     | T <sub>1</sub> | MAR←PC                  | E <sub>PC</sub> , L <sub>MAR</sub>                   | 18 00 00 00 00 |
| NOP         | No<br>operation      |           | T <sub>2</sub> | MDR←RAM[MAR]<br>PC←PC+1 | R,<br>C <sub>p</sub>                                 | 44 00 00 00 00 |
|             |                      |           | T <sub>3</sub> | IR←MDR                  | E <sub>MDR</sub> , L <sub>IR1</sub> CTR <sub>L</sub> | 00 C0 00 00 80 |
|             |                      | Execution | $T_4$          | Do nothing              | CTR <sub>R</sub>                                     | 00 00 00 00 40 |
| 25)         |                      | Fetch     | T <sub>1</sub> | MAR←PC                  | E <sub>PC</sub> , L <sub>MAR</sub>                   | 18 00 00 00 00 |
| STZ         | Z <b>←</b> 1         |           | T <sub>2</sub> | MDR←RAM[MAR]<br>PC←PC+1 | R,<br>C <sub>p</sub>                                 | 44 00 00 00 00 |
|             |                      |           | T <sub>3</sub> | IR←MDR                  | E <sub>MDR</sub> , L <sub>IR1</sub>                  | 00 CO 00 00 80 |
|             |                      | Execution | T <sub>4</sub> | FLAGS←SET_ZF_BUF<br>(1) | SET_ZF,<br>E_SET_ZF,<br>L_FLAG_Z<br>CTR <sub>R</sub> | 00 18 00 04 40 |
| 26)<br>CLZ  | z <b>←</b> 0         | Fetch     | T <sub>1</sub> | MAR←PC                  | E <sub>PC</sub> , L <sub>MAR</sub>                   | 18 00 00 00 00 |
|             |                      |           | T <sub>2</sub> | MDR←RAM[MAR]<br>PC←PC+1 | R,<br>C <sub>p</sub>                                 | 44 00 00 00 00 |
|             |                      |           | T <sub>3</sub> | IR←MDR                  | E <sub>MDR</sub> , L <sub>IR1</sub>                  | 00 CO 00 00 80 |
|             |                      | Execution | T <sub>4</sub> | FLAGS←SET_ZF_BUF<br>(0) | E_SET_ZF,<br>L_FLAG_Z<br>CTR <sub>R</sub>            | 00 08 00 04 40 |

| Instruction | Macro<br>Instruction | Cycle     | T-States              | Micro Instructions | Active Bits                            | CON            |
|-------------|----------------------|-----------|-----------------------|--------------------|----------------------------------------|----------------|
|             |                      |           | T <sub>1</sub>        | MAR←PC             | $E_{PC}$ , $L_{MAR}$                   | 18 00 00 00 00 |
|             |                      | Fetch     | $T_2$                 | MDR←RAM[MAR]       | R,                                     | 44 00 00 00 00 |
|             |                      |           |                       | PC←PC+1            | $C_p$                                  |                |
| 27)         | ACC ← ACC            |           | $T_3$                 | IR←MDR             | $E_{MDR}$ , $L_{IR1}$                  | 00 CO 00 00 80 |
| AND         | & immediate          |           |                       |                    | CTR <sub>L</sub>                       |                |
| immediate   |                      |           | T <sub>4</sub>        | MAR←PC             | $E_{PC}$ , $L_{MAR}$                   | 18 00 00 00 00 |
|             |                      |           | $T_{5}$               | MDR←RAM[MAR]       | R,                                     | 44 00 00 00 00 |
|             |                      | Execution |                       | PC←PC+1            | $C_p$                                  |                |
|             |                      |           | $T_6$                 | TEMP←MDR           | L <sub>TEMP</sub> , E <sub>MDR</sub> , | 00 80 14 00 00 |
|             |                      |           |                       |                    | E <sub>AND</sub>                       |                |
|             |                      |           | $T_7$                 | ACC←ACC & TEMP     | $E_{ALU}, L_{A}$                       | 00 04 80 08 40 |
|             |                      |           |                       | FLAGS←C,Z          | L <sub>FLAGS</sub>                     |                |
|             |                      |           |                       |                    | CTR <sub>R</sub>                       |                |
|             |                      |           | T <sub>1</sub>        | MAR←PC             | $E_PC$ , $L_MAR$                       | 18 00 00 00 00 |
|             |                      | Fetch     | T <sub>2</sub>        | MDR←RAM[MAR]       | R,                                     | 44 00 00 00 00 |
|             |                      |           |                       | PC←PC+1            | C <sub>p</sub>                         |                |
| 28)         | ACC ← ACC            |           | T <sub>3</sub>        | IR←MDR             | $E_{MDR}$ , $L_{IR1}$                  | 00 C0 00 00 80 |
|             | Memory               |           |                       |                    | CTR <sub>L</sub>                       |                |
| OR[address] | [address]            |           | T <sub>4</sub>        | MAR←PC             | $E_PC$ , $L_MAR$                       | 18 00 00 00 00 |
|             |                      |           | <b>T</b> <sub>5</sub> | MDR←RAM[MAR]       | R,                                     | 44 00 00 00 00 |
|             |                      | Execution |                       | PC←PC+1            | C <sub>p</sub>                         |                |
|             |                      |           | $T_6$                 | MAR←MDR            | $L_{MAR}$ , $E_{MDR}$                  | 08 80 00 00 00 |
|             |                      |           | T <sub>7</sub>        | MDR←RAM[MAR]       | R                                      | 04 00 00 00 00 |
|             |                      |           | T <sub>8</sub>        | TEMP←MDR           | L <sub>TEMP</sub> , E <sub>MDR</sub> , | 00 80 0C 00 00 |
|             |                      |           |                       |                    | E <sub>OR</sub>                        |                |
|             |                      |           | T <sub>9</sub>        | ACC←ACC   TEMP     | $E_{ALU}, L_{A}$                       | 00 04 80 08 40 |
|             |                      |           |                       | FLAGS←C,Z          | $L_{FLAGS}$                            |                |
|             |                      |           |                       |                    | CTR <sub>R</sub>                       |                |