## Enrico Nardelli Logic Circuits and Computer Architecture

#### Appendix B The design of VS0: a very simple CPU

#### Instruction set

- Just 4 instructions
- LOAD M Copy into Accumulator the value from memory at address M
- STORE M Save Accumulator value into memory at address M
- ADD M Sum values of Accumulator and of memory at address M and put the result into the Accumulator
- JUMP A Execute in the next step the instruction stored at address A of memory

## **Registers and Memory**

- The bare minimum
- PC Program Counter
- IR Instruction Register
- MAR Memory Address Register
- MBR Memory Buffer Register
- AC Accumulator
- All registers have 8 bits
- 64 (2<sup>6</sup>) bytes of memory, each with 8 bits

#### **Instruction format**

- 2 bits for the opcode
- 6 bits for the address (b<sub>5</sub> is the MSB, b<sub>0</sub> is the LSB)
- LOAD 0 0  $b_5 b_4 b_3 b_2 b_1 b_0$
- STORE 1 1  $b_5 b_4 b_3 b_2 b_1 b_0$
- ADD 0 1  $b_5 b_4 b_3 b_2 b_1 b_0$
- JUMP 1 0  $b_5 b_4 b_3 b_2 b_1 b_0$

## ALU's organization

- Only capable of adding (signal CA) two 8 bits number with a possible carry-in (signal CC)
- No overflow signal
- One addend is the Accumulator
- The other addend is the selection between PC and a memory address (through C6 and C14)
- ALU's output is stored into an internal buffer register

#### **ALU's internal structure**



#### **Internal schema**



## Micro-operations (1)

# Micro-operations (2)

- Execute LOAD
- t1: MAR <-  $(IR_{addr})$  C16
- t2: MBR <- (memory) C0 C5 CR
- t3: AC <- (MBR) C10
- Execute STORE

t1: MAR <- 
$$(IR_{addr})$$
; MBR <-  $(AC)$ 

C11 C16

- t2: memory <- (MBR) C0 C12 CW
- Execute JUMP
- t1: PC <- ( $IR_{addr}$ ) C13

#### **Decoding instructions**



 Inside the Control Unit a 2-to-4 decoder provides L, S, A, J signals denoting which instruction is currently in IR

# Micro-operations (3)

- Generate t<sub>1</sub>,t<sub>2</sub>,t<sub>3</sub>,t<sub>4</sub> from the clock through a base-4 counter and a 2-to-4 decoder
- Distinguish between Fetch and Execute with a 1bit state register (can be inside the Control Unit)
- For each control signal Cn write the boolean expression for its activation in terms of status (Fetch/Execute), mOP step being executed (t<sub>1</sub>,t<sub>2</sub>,t<sub>3</sub>,t<sub>4</sub>), and operation to be executed (L,S,A,J), by scanning the list of activated control signals for each step of each mOP

#### Generating clocks for mOPs



- Counter can be reset to optimize at the last step of each mOP
- Reset signal:  $Ft_3 + F't_1J + F't_2S + F't_3L$

#### **State representation**

- Control unit can be in the state of fetch (F=1) or in the state of execute (F=0)
- Status changes are activated during the last mOP step of each phase of fetch or execute NOT(t<sub>4</sub>A, t<sub>3</sub>L, t<sub>2</sub>S, t<sub>1</sub>J)



• There is just one boolean expression for the transition condition of the unique state variable  $F_{n+1} = F_n t_3' + F_n' t_4 A + F_n' t_3 L + F_n' t_2 S + F_n' t_1 J$ 

## Activation of control signals

| Control<br>Signal | Boolean expression                | Control<br>Signal | Boolean expression         |
|-------------------|-----------------------------------|-------------------|----------------------------|
| CO                | $Ft_2 + F't_2A + F't_2L + F't_2S$ | C12               | F't <sub>2</sub> S         |
| C2                | Ft <sub>1</sub>                   | C13               | F't <sub>1</sub> J         |
| C4                | Ft <sub>3</sub>                   | C14               | Ft <sub>2</sub>            |
| C5                | $Ft_2 + F't_2A + F't_2L$          | C15               | Ft <sub>3</sub>            |
| C6                | F't <sub>3</sub> A                | C16               | $F't_1A + F't_1L + F't_1S$ |
| C7                | F't <sub>3</sub> A                | CC                | Ft <sub>2</sub>            |
| С9                | F't <sub>4</sub> A                | СА                | $Ft_2 + F't_3A$            |
| C10               | Ft <sub>3</sub> L                 | CR                | $Ft_2 + F't_2A + F't_2L$   |
| C11               | $Ft_3 + F't_1S$                   | CW                | F't <sub>2</sub> S         |

# A note on boolean expressions (1)

- Boolean expressions written have been derived directly from inspection of mOPs
- The theory of circuit synthesis tells us to examine what happens in general to each output signal for each possible combination of input signals (t<sub>1</sub>, t<sub>2</sub>, t<sub>3</sub>, t<sub>4</sub>, L, S, A, J) and state signal (F)
- Writing, e.g., F't<sub>2</sub>L could be wrong, since the exact and complete term is F't<sub>1</sub>'t<sub>2</sub>t<sub>3</sub>'t<sub>4</sub>'LS'A'J' : this is not equivalent to the former, which corresponds to F'(t<sub>1</sub>+t<sub>1</sub>')t<sub>2</sub>(t<sub>3</sub>+t<sub>3</sub>')(t<sub>4</sub>+t<sub>4</sub>')L(S+S')(A+A')(J+J')

## A note on boolean expressions (2)

- But we know that among t<sub>1</sub>, t<sub>2</sub>, t<sub>3</sub>, and t<sub>4</sub> only and exactly one can be true, therefore we can substitute, e.g., t<sub>1</sub>' t<sub>2</sub> with (t<sub>1</sub>+t<sub>1</sub>')t<sub>2</sub> knowing that the condition t<sub>1</sub>t<sub>2</sub> can never be true and hence derive the correct simpler term t<sub>2</sub> (in other words, t<sub>1</sub>t<sub>2</sub> is a **don't care** condition)
- For signals L, S, A, and J, if one of them is true then all the others are false and the same reasoning above applies.
- Finally, there are also those situations (e.g., for C2 activation in mOP t<sub>1</sub> during the fetch phase) where we don't care at all about which of these signals is true

## **Global optimization of signals**

| Signal  | Boolean expression     | Signal           | Boolean expression              |
|---------|------------------------|------------------|---------------------------------|
| CC, C14 | Ft <sub>2</sub>        |                  |                                 |
| C2      | Ft <sub>1</sub>        | C13              | F't <sub>1</sub> J              |
| C4, C15 | Ft <sub>3</sub>        | CW, C12          | F't <sub>2</sub> S              |
| C5, CR  | $CC + F't_2A + F't_2L$ | C16              | $F't_1A + F't_1L + F't_1S$      |
| C6, C7  | F't <sub>3</sub> A     | CO               | C5 + CW                         |
|         |                        | СА               | CC + C6                         |
| С9      | F't <sub>4</sub> A     |                  |                                 |
| C10     | F't <sub>3</sub> L     |                  |                                 |
| C11     | $C4 + F't_1S$          | F <sub>n+1</sub> | $Ft_{3}' + C9 + C10 + CW + C13$ |

## Additional considerations

- Do we need both state signal and instruction signals L,S,A,J to activate control signals?
  - e.g. in the activation expression for C7, instead of F' t<sub>3</sub>A, can we just write t<sub>3</sub>A ?
    - no, because if the previously fetched instruction was also an ADD then C7 is (wrongly) activated also during mOP step t<sub>3</sub> in the fetch phase
  - hence we need both state signal and instruction signals
- Do we need an explicit representation for state ?
  - no, if we use for the execution phases a different set of clock signals t<sub>4</sub>,t<sub>5</sub>,t<sub>6</sub>,t<sub>7</sub>
  - What changes using this approach? What do we lose?

## No Explicit State: Micro-operations (1)

| • Fet | ch                           |                     |     |    |    |    |
|-------|------------------------------|---------------------|-----|----|----|----|
| t1:   | MAR <- PC                    | C2                  |     |    |    |    |
| t2:   | MBR <- (memory);             | (PC) + <sup>-</sup> | 1;  |    |    |    |
|       | CO                           | C5                  | C14 | CA | CC | CR |
| t3:   | PC <- (ALU); IR <-           | (MBR)               |     |    |    |    |
|       |                              | C4                  | C15 |    |    |    |
| • Exe | ecute ADD                    |                     |     |    |    |    |
| t4:   | MAR <- (IR <sub>addr</sub> ) | C16                 |     |    |    |    |
| t5:   | MBR <- (memory)              | C0                  | C5  | CR |    |    |
| t6:   | (AC) + (MBR)                 | C6                  | C7  | CA |    |    |
| t7:   | AC <- (ALU)                  | C9                  |     |    |    |    |

## No Explicit State: Micro-operations (2)

- Execute LOAD
- t4: MAR <-  $(IR_{addr})$  C16
- t5: MBR <- (memory) C0 C5 CR
- t6: AC <- (MBR) C10
- Execute STORE
- t4: MAR <- (IR<sub>addr</sub>); MBR <- (AC) C11 C16
- t5: memory <- (MBR) C0 C12 CW
- Execute JUMP
- t4: PC <- ( $IR_{addr}$ ) C13

## No Explicit State: Micro-operations (3)

- Generate t<sub>1</sub>,t<sub>2</sub>,t<sub>3</sub>,t<sub>4</sub>,t<sub>5</sub>,t<sub>6</sub>,t<sub>7</sub> from the clock through a base-8 counter and a 3-to-8 decoder (possibly use a counter with reset for optimization)
- For each control signal Cn write the boolean expression for its activation in terms of mOP step being executed (t<sub>1</sub>,t<sub>2</sub>,t<sub>3</sub>,t<sub>4</sub>,t<sub>5</sub>,t<sub>6</sub>,t<sub>7</sub>), and operation to be executed (L,S,A,J), by scanning the list of activated control signals for each step of each mOP

## No Explicit State: Activation of control signals

| Control<br>Signal | Boolean expression            | Control<br>Signal | Boolean expression    |
|-------------------|-------------------------------|-------------------|-----------------------|
| CO                | $t_2 + t_5 A + t_5 L + t_5 S$ | C12               | t <sub>5</sub> S      |
| C2                | t <sub>1</sub>                | C13               | t <sub>4</sub> J      |
| C4                | t <sub>3</sub>                | C14               | t <sub>2</sub>        |
| C5                | $t_2 + t_5A + t_5L$           | C15               | t <sub>3</sub>        |
| C6                | t <sub>6</sub> A              | C16               | $t_4A + t_4L + t_4S$  |
| C7                | t <sub>6</sub> A              | CC                | t <sub>2</sub>        |
| С9                | t <sub>7</sub> A              | СА                | $t_2 + t_6 A$         |
| C10               | t <sub>3</sub> L              | CR                | $t_2 + t_5 A + t_5 L$ |
| C11               | $t_3 + t_4 S$                 | CW                | t <sub>5</sub> S      |

## The complete circuit

- All circuital elements (including the Control Unit) have now been defined and it is known how to realize them
- Try drawing the complete circuit for the CPU and the memory!!
- It is a long but worthwhile task
- Do it in hierarchical stages: first layout modules and afterwards layout gates within modules
- In the real life they use CAD systems for electronic circuit design !

#### A trivial program

 Give at location SUM the sum of four numbers stored in locations of memory N1, N2, N3, N4

| ; Location SUM is dist | inc | ct from N1, N2, N3, N4   |
|------------------------|-----|--------------------------|
| LOAD N1                | • / | AC <- N1                 |
| ADD N2                 | • / | AC <- N1 + N2            |
| ADD N3                 | • / | AC <- N1 + N2 + N3       |
| ADD N4                 | • / | AC <- N1 + N2 + N3 + N4  |
| STORE SUM              | • / | SUM < -N1 + N2 + N3 + N4 |

# Control Unit's implementation with micro-programmed control

- For the implementation of CU with a microprogrammed approach we **do not need**:
  - signals t<sub>1</sub> ... t<sub>n</sub> marking different mOPs
  - state register distinguishing between fetch and execute
- Even the IR decoder is not really needed, but we may use it depending on the CW structure
- Structure of CW and structure of Sequencing Logic are strictly related: a CW with more information needs a simpler Sequencing Logic and vice-versa

# CW and sequencing mOPs

- CW has two address fields (SmA and JmA) of 5 bits each
  - SmA is the next CW address in case of sequential execution
  - JmA is the next CW address in case of jump
  - Fields are empty when the choice is forced
- A 2-way multiplexer is used to select between SmA and JmA and hence choose the next CW to be executed
- Selection line (SEL) for multiplexer is activated by a circuit in the Sequential Logic whose structure depends on the structure of jump conditions in CW
  - No jump flags
  - One jump flag (K) only for end-of-mOP
  - Jump flags both for end-of-mOP and for selecting the proper micro-procedure during the CPU execution phase

#### **Generic structure of CU**



## CW without jump conditions: CU's structure



# CW without jump conditions: Sequencing Logic

- If there are no flags in CW the selection between SmA and JmA may use only the state of CU, represented by CAR value
- Towards the end of CU execution cycle, CAR contains the address of current CW in execution hence the value of such an address is used to drive the selection of next CW
- A CAR decoder provides I<sub>n</sub> signals telling that CW at address *n* is being executed
- A 2-to-4 decoder on the two most significant bits of IR is needed to understand which CPU instruction is being executed and to provide L, S, A, and J signals
- Signal for selection line (0 to select SmA, 1 for JmA) is
  - SEL =  $I_3 + I_6 + I_{12} + I_{16} + I_{17} + I_7L + I_8S + I_9A + I_{10}J$
- Both decoders are part of the Sequencing Logic

## CW without jump conditions: Control Memory

| Micro<br>Procedure | mA | CO | C2 | C4 | C5 | C6 | C7 | С9 | C<br>10 | C<br>11 | C<br>12 | C<br>13 | C<br>14 | C<br>15 | C<br>16 | сс | CA | CR | CW | S<br>mA | J<br>mA |
|--------------------|----|----|----|----|----|----|----|----|---------|---------|---------|---------|---------|---------|---------|----|----|----|----|---------|---------|
| Fetch              | 1  |    | 1  |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    | 2       |         |
|                    | 2  | 1  |    |    | 1  |    |    |    |         |         |         |         | 1       |         |         | 1  | 1  | 1  |    | 3       |         |
|                    | 3  |    |    | 1  |    |    |    |    |         |         |         |         |         | 1       |         |    |    |    |    |         | 7       |
| Load               | 4  |    |    |    |    |    |    |    |         |         |         |         |         |         | 1       |    |    |    |    | 5       |         |
|                    | 5  | 1  |    |    | 1  |    |    |    |         |         |         |         |         |         |         |    |    | 1  |    | 6       |         |
|                    | 6  |    |    |    |    |    |    |    | 1       |         |         |         |         |         |         |    |    |    |    |         | 1       |
| Execute            | 7  |    |    |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    | 8       | 4       |
|                    | 8  |    |    |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    | 9       | 11      |
|                    | 9  |    |    |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    | 10      | 13      |
|                    | 10 |    |    |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    | 7       | 17      |
| Store              | 11 |    |    |    |    |    |    |    |         |         | 1       |         |         |         | 1       |    |    |    |    | 12      |         |
|                    | 12 | 1  |    |    |    |    |    |    |         |         | 1       |         |         |         |         |    |    |    | 1  |         | 1       |
| Add                | 13 |    |    |    |    |    |    |    |         |         |         |         |         |         | 1       |    |    |    |    | 14      |         |
|                    | 14 | 1  |    |    | 1  |    |    |    |         |         |         |         |         |         |         |    |    | 1  |    | 15      |         |
|                    | 15 |    |    |    |    | 1  | 1  |    |         |         |         |         |         |         |         |    | 1  |    |    | 16      |         |
|                    | 16 |    |    |    |    |    |    | 1  |         |         |         |         |         |         |         |    |    |    |    |         | 1       |
| Jump               | 17 |    |    |    |    |    |    |    |         |         |         | 1       |         |         |         |    |    |    |    |         | 1       |

## CW with one jump condition: CU's structure



# CW with one jump condition: Sequencing Logic

- A jump flag (K) is used to mark the last mOP of each microprocedure (but for the Execute one)
- I<sub>n</sub> signals provided by the CAR decoder now are only needed during the Execute micro-procedure
- A 2-to-4 decoder on the two most significant bits of IR is needed to understand which CPU instruction is being executed and to provide L, S, A, and J signals
- Signal for selection line (0 to select SmA, 1 for JmA) is

• SEL = K +  $I_7L + I_8S + I_9A + I_{10}J$ 

 Sequencing Logic is independent from the location of any micro-procedure in Control Memory, but for the Execute one

# CW with one jump condition: Control Memory

| Micro<br>Procedure | mA | CO | C2 | C4 | C5 | C6 | C7 | С9 | C<br>10 | C<br>11 | C<br>12 | C<br>13 | C<br>14 | C<br>15 | C<br>16 | сс | СА | CR | cw | К | S<br>mA | J<br>mA |
|--------------------|----|----|----|----|----|----|----|----|---------|---------|---------|---------|---------|---------|---------|----|----|----|----|---|---------|---------|
| Fetch              | 1  |    | 1  |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    |   | 2       |         |
|                    | 2  | 1  |    |    | 1  |    |    |    |         |         |         |         | 1       |         |         | 1  | 1  | 1  |    |   | 3       |         |
|                    | 3  |    |    | 1  |    |    |    |    |         |         |         |         |         | 1       |         |    |    |    |    | 1 |         | 7       |
| Load               | 4  |    |    |    |    |    |    |    |         |         |         |         |         |         | 1       |    |    |    |    |   | 5       |         |
|                    | 5  | 1  |    |    | 1  |    |    |    |         |         |         |         |         |         |         |    |    | 1  |    |   | 6       |         |
|                    | 6  |    |    |    |    |    |    |    | 1       |         |         |         |         |         |         |    |    |    |    | 1 |         | 1       |
| Execute            | 7  |    |    |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    |   | 8       | 4       |
|                    | 8  |    |    |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    |   | 9       | 11      |
|                    | 9  |    |    |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    |   | 10      | 13      |
|                    | 10 |    |    |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    |   | 7       | 17      |
| Store              | 11 |    |    |    |    |    |    |    |         |         | 1       |         |         |         | 1       |    |    |    |    |   | 12      |         |
|                    | 12 | 1  |    |    |    |    |    |    |         |         | 1       |         |         |         |         |    |    |    | 1  | 1 |         | 1       |
| Add                | 13 |    |    |    |    |    |    |    |         |         |         |         |         |         | 1       |    |    |    |    |   | 14      |         |
|                    | 14 | 1  |    |    | 1  |    |    |    |         |         |         |         |         |         |         |    |    | 1  |    |   | 15      |         |
|                    | 15 |    |    |    |    | 1  | 1  |    |         |         |         |         |         |         |         |    | 1  |    |    |   | 16      |         |
|                    | 16 |    |    |    |    |    |    | 1  |         |         |         |         |         |         |         |    |    |    |    | 1 |         | 1       |
| Jump               | 17 |    |    |    |    |    |    |    |         |         |         | 1       |         |         |         |    |    |    |    | 1 |         | 1       |

## CW with many jump conditions: CU's structure



# CW with many jump conditions: Sequencing logic

- A jump flag (K) is used to mark the last mOP of each micro-procedure
- Four jump flags (E<sub>L</sub>, E<sub>S</sub>, E<sub>A</sub>, E<sub>J</sub>) mark the four mOPs in the Execute micro-procedure
- There is no need now for a CAR decoder: this is obtained at the cost of a longer CW
- A 2-to-4 decoder on the two most significant bits of IR is needed to understand which CPU instruction is being executed and to provide L, S, A, and J signals
- Signal for selection line (0 to select SmA, 1 for JmA) is

• SEL = K +  $E_LL$  +  $E_SS$  +  $E_AA$  +  $E_JJ$ 

 Sequencing Logic is now fully independent from the location of any micro-procedure in Control Memory

# CW with many jump conditions: Control Memory

| Micro<br>Procedure | mA | CO | C2 | C4 | C5 | C6 | C7 | С9 | C<br>10 | C<br>11 | C<br>12 | C<br>13 | C<br>14 | C<br>15 | C<br>16 | СС | CA | CR | cw | EL | ES | EA | EJ | К | S<br>mA | J<br>mA |
|--------------------|----|----|----|----|----|----|----|----|---------|---------|---------|---------|---------|---------|---------|----|----|----|----|----|----|----|----|---|---------|---------|
| Fetch              | 1  |    | 1  |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    |    |    |    |    |   | 2       |         |
|                    | 2  | 1  |    |    | 1  |    |    |    |         |         |         |         | 1       |         |         | 1  | 1  | 1  |    |    |    |    |    |   | 3       |         |
|                    | 3  |    |    | 1  |    |    |    |    |         |         |         |         |         | 1       |         |    |    |    |    |    |    |    |    | 1 |         | 7       |
| Load               | 4  |    |    |    |    |    |    |    |         |         |         |         |         |         | 1       |    |    |    |    |    |    |    |    |   | 5       |         |
|                    | 5  | 1  |    |    | 1  |    |    |    |         |         |         |         |         |         |         |    |    | 1  |    |    |    |    |    |   | 6       |         |
|                    | 6  |    |    |    |    |    |    |    | 1       |         |         |         |         |         |         |    |    |    |    |    |    |    |    | 1 |         | 1       |
| Execute            | 7  |    |    |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    | 1  |    |    |    |   | 8       | 4       |
|                    | 8  |    |    |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    |    | 1  |    |    |   | 9       | 11      |
|                    | 9  |    |    |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    |    |    | 1  |    |   | 10      | 13      |
|                    | 10 |    |    |    |    |    |    |    |         |         |         |         |         |         |         |    |    |    |    |    |    |    | 1  |   | 7       | 17      |
| Store              | 11 |    |    |    |    |    |    |    |         |         | 1       |         |         |         | 1       |    |    |    |    |    |    |    |    |   | 12      |         |
|                    | 12 | 1  |    |    |    |    |    |    |         |         | 1       |         |         |         |         |    |    |    | 1  |    |    |    |    | 1 |         | 1       |
| Add                | 13 |    |    |    |    |    |    |    |         |         |         |         |         |         | 1       |    |    |    |    |    |    |    |    |   | 14      |         |
|                    | 14 | 1  |    |    | 1  |    |    |    |         |         |         |         |         |         |         |    |    | 1  |    |    |    |    |    |   | 15      |         |
|                    | 15 |    |    |    |    | 1  | 1  |    |         |         |         |         |         |         |         |    | 1  |    |    |    |    |    |    |   | 16      |         |
|                    | 16 |    |    |    |    |    |    | 1  |         |         |         |         |         |         |         |    |    |    |    |    |    |    |    | 1 | 17      | 1       |
| Jump               | 17 |    |    |    |    |    |    |    |         |         |         | 1       |         |         |         |    |    |    |    |    |    |    |    | 1 |         | 1       |

#### An internal schema with single bus



#### **ALU changes**

• ALU needs a buffer (with reset) also for input



## Micro-operations (1) Single Bus

- Fetch
  - one more step
- t1: MAR <- PC C2 C13
- t2: MBR <- (memory) C16 C15 CR (PC)+1 C2 C7 CT CA CC
- t3: PC <- (ALU) C8 C1
- t4: IR <- (MBR) C10 C3

# Micro-operations (2) Single Bus

- Execute ADD
  - reorganization of micro-operations
- t1: MAR <-  $(IR_{addr})$  C4 C13
- t2: MBR <- (memory) C16 C15 CR ALU <- (AC) C6 C9
- t3: (MBR)+(ALU) C10 C7 CA
- t4: AC <- (ALU) C8 C5

## Micro-operations (3) Single Bus

- Execute LOAD
- t1: MAR <- ( $IR_{addr}$ )
- t2: MBR <- (memory) C16 C15 CR
- t3: AC <- (MBR)

- C4 C13
- C10 C5

## Micro-operations (4) Single Bus

- Execute STORE
  - one more step
- t1: MAR <- (IR<sub>addr</sub>) C4 C13
- t1: MBR <- (AC) C6 C11
- t2: memory <- (MBR) C14 C16 CW
- C14 C16 CW
- Execute JUMP
  t1: PC <- (IR<sub>addr</sub>) C14 C2

## **Completion of single bus**

- Continue development as shown before
- Decide whether to explicitly represent state or not
- Decide whether to implement a hardwired CU or a micro-programmed one
- In the latter case, decide the structure of the control word

# Other simple design variations

- Try them (even together) to understand consequences of various design decisions !
  - 1. Add to the ALU the capability to provide Zero or Overflow signal and use a JUMP conditional to the signal value instead of the unconditional JUMP
  - 2. Use an internal CPU schema with two internal buses to connect CPU elements instead of direct paths
  - 3. Use two variants of ADD. One, specified by  $b_5=0$ , having as parameter the address of memory cell, written in the byte right after the one with ADD. The other, specified by  $b_5=1$ , having as argument the number to be added written in bits  $b_4-b_0$
  - 4. Use a micro-programmed CU with just one address field
  - Study if it is possible to avoid the use of the 2-to-4 IR decoder by means of a different organization of the micro-procedure for the CPU execution phase