

|         | MA          | R ← P             | рс р             | C ← I            | PC + 1        |           |           |  |  |
|---------|-------------|-------------------|------------------|------------------|---------------|-----------|-----------|--|--|
|         | Wh<br>in th | ich re<br>he firs | egiste<br>st sta | ers ch<br>ite of | ange<br>fetch | ?         |           |  |  |
|         | LD.<br>MAR  | LD.<br>MDR        | LD.<br>IR        | LD.<br>BEN       | LD.<br>REG    | LD.<br>CC | LD.<br>PC |  |  |
| fetch 1 | 1           | 0                 | 0                | 0                | 0             | 0         | 1         |  |  |
| fetch 2 |             |                   |                  |                  |               |           |           |  |  |
| fetch 3 |             |                   |                  |                  |               |           |           |  |  |
|         |             |                   |                  |                  |               |           |           |  |  |



| What            | are the             | e Bus Ga              | ting Sig                                   | nals?          |         |
|-----------------|---------------------|-----------------------|--------------------------------------------|----------------|---------|
| So              | MAR<br>what ar      | ← PC, PC<br>e the bus | $\leftarrow \mathbf{PC} + 1$<br>gating sig | l<br>gnals?    |         |
|                 | GatePC              | GateMDR               | GateALU                                    | Gate<br>MARMUX |         |
| fetch 1         | 1                   | 0                     | 0                                          | 0              |         |
| fetch 2         |                     |                       |                                            |                |         |
| fetch 3         |                     |                       |                                            |                |         |
| decode          |                     |                       |                                            |                |         |
|                 |                     |                       |                                            |                |         |
| ECE 120: Introd | action to Computing | © 2016                | Steven S. Lumetta. All ri                  | ghts reserved. | slide 5 |



| Wh      | MA<br>at ar | AR ←<br>e the | PC, H<br>mux s | PC ← P(<br>selectio | C + 1<br>n signal | ls?        |  |
|---------|-------------|---------------|----------------|---------------------|-------------------|------------|--|
|         | PC<br>MUX   | DR<br>MUX     | SR1<br>MUX     | ADDR1<br>MUX        | ADDR2<br>MUX      | MAR<br>MUX |  |
| fetch 1 | 00          | xx            | xx             | x                   | xx                | x          |  |
| fetch 2 |             |               |                |                     |                   |            |  |
| fetch 3 |             |               |                |                     |                   |            |  |
| dooodo  |             |               |                |                     |                   |            |  |







|         |              | MDR              | ← <b>M</b>      | [MA]             | RI             |           |           |  |  |
|---------|--------------|------------------|-----------------|------------------|----------------|-----------|-----------|--|--|
|         | Wh<br>in the | ich re<br>e seco | egiste<br>nd st | ers ch<br>tate o | ange<br>f fetc | h?        |           |  |  |
|         | LD.<br>MAR   | LD.<br>MDR       | LD.<br>IR       | LD.<br>BEN       | LD.<br>REG     | LD.<br>CC | LD.<br>PC |  |  |
| fetch 1 | 1            | 0                | 0               | 0                | 0              | 0         | 1         |  |  |
| fetch 2 | 0            | 1                | 0               | 0                | 0              | 0         | 0         |  |  |
| fetch 3 |              |                  |                 |                  |                |           |           |  |  |
| decode  |              |                  |                 |                  |                |           |           |  |  |



| So      | M<br>what ar | IDR ← M[<br>e the bus | MAR]<br>gating si | gnals?         |  |  |
|---------|--------------|-----------------------|-------------------|----------------|--|--|
|         | GatePC       | GateMDR               | GateALU           | Gate<br>MARMUX |  |  |
| fetch 1 | 1            | 0                     | 0                 | 0              |  |  |
| fetch 2 | 0            | 0                     | 0                 | 0              |  |  |
| fetch 3 |              |                       |                   |                |  |  |
| decode  |              |                       |                   |                |  |  |



| Wh    | at ar     | MD<br>e the | $\mathbf{R} \leftarrow \mathbf{N}$<br>mux : | M[MAR]<br>selectio | n signal     | ls?        |   |
|-------|-----------|-------------|---------------------------------------------|--------------------|--------------|------------|---|
|       | PC<br>MUX | DR<br>MUX   | SR1<br>MUX                                  | ADDR1<br>MUX       | ADDR2<br>MUX | MAR<br>MUX |   |
| tch 1 | 00        | xx          | xx                                          | x                  | xx           | x          |   |
| tch 2 | xx        | xx          | xx                                          | x                  | xx           | x          |   |
| tch 3 |           |             |                                             |                    |              |            |   |
| apope |           |             |                                             |                    |              |            | Í |







|         |             |                   |                           | 8                |                 |           |           |  |
|---------|-------------|-------------------|---------------------------|------------------|-----------------|-----------|-----------|--|
|         |             | IR                | $L \leftarrow \mathbf{N}$ | IDR              |                 |           |           |  |
|         | Wh<br>in th | ich re<br>le thir | egiste<br>rd sta          | ers ch<br>ate of | nange<br>'fetch | ?         |           |  |
|         | LD.<br>MAR  | LD.<br>MDR        | LD.<br>IR                 | LD.<br>BEN       | LD.<br>REG      | LD.<br>CC | LD.<br>PC |  |
| fetch 1 | 1           | 0                 | 0                         | 0                | 0               | 0         | 1         |  |
| fetch 2 | 0           | 1                 | 0                         | 0                | 0               | 0         | 0         |  |
| fetch 3 | 0           | 0                 | 1                         | 0                | 0               | 0         | 0         |  |
| decode  |             |                   |                           |                  |                 |           |           |  |



| So      | what ar | IR ← MI<br>e the bus | DR<br>gating sig | gnals?         |  |
|---------|---------|----------------------|------------------|----------------|--|
|         | GatePC  | GateMDR              | GateALU          | Gate<br>MARMUX |  |
| fetch 1 | 1       | 0                    | 0                | 0              |  |
| fetch 2 | 0       | 0                    | 0                | 0              |  |
| fetch 3 | 0       | 1                    | 0                | 0              |  |
| decode  |         |                      |                  |                |  |



| Wh      | at ar     | I<br>e the | $\mathbf{R} \leftarrow \mathbf{R}$<br>mux | MDR<br>selectio | n signal     | ls?        |  |
|---------|-----------|------------|-------------------------------------------|-----------------|--------------|------------|--|
|         | PC<br>MUX | DR<br>MUX  | SR1<br>MUX                                | ADDR1<br>MUX    | ADDR2<br>MUX | MAR<br>MUX |  |
| fetch 1 | 00        | xx         | xx                                        | x               | xx           | x          |  |
| fetch 2 | xx        | xx         | xx                                        | x               | xx           | x          |  |
| fetch 3 | xx        | xx         | xx                                        | x               | xx           | x          |  |
| decode  |           |            |                                           |                 |              |            |  |







|   | What    | are t    | he Lo             | oad S          | Signa            | als?         |       |       |   |
|---|---------|----------|-------------------|----------------|------------------|--------------|-------|-------|---|
| ] | BEN ←   | IR[1]    | l] & N            | + <b>I</b> R   | [10] a           | & Z +        | IR[9] | ] & I | • |
|   |         | Wh<br>iı | ich re<br>1 the o | egiste<br>deco | ers ch<br>de sta | ange<br>ate? |       |       |   |
|   |         | LD.      | LD.               | LD.            | LD.              | LD.          | LD.   | LD.   |   |
|   |         | MAR      | MDR               | IR             | BEN              | REG          | CC    | PC    |   |
|   | fetch 1 | 1        | 0                 | 0              | 0                | 0            | 0     | 1     |   |
|   | fetch 2 | 0        | 1                 | 0              | 0                | 0            | 0     | 0     |   |
|   | fetch 3 | 0        | 0                 | 1              | 0                | 0            | 0     | 0     |   |

decode

ECE 120: Introduction to Computing

0

0

0

1

0

© 2016 Steven S. Lumetta. All rights reserved.

0

slide 27

0

| Look at How Bits Must Move in the Datapath                                                                    |  |
|---------------------------------------------------------------------------------------------------------------|--|
| We have<br>BEN $\leftarrow$ IR[11] & N + IR[10] & Z + IR[9] & P                                               |  |
| But the implementation<br>• is just some logic<br>• based on the condition codes<br>(N, Z, and P) and the IR. |  |
| There's nothing to see in the datapath.                                                                       |  |
| ECE 120' Introduction to Computing © 2016 Steven S. Lumetta. All rights reserved slide 28                     |  |

| What        | are the             | e Bus Ga               | ting Sig                | nals?               |   | What        | t are            | the I         | Mux             | Selecti             | on Sigr             | nals?         |  |
|-------------|---------------------|------------------------|-------------------------|---------------------|---|-------------|------------------|---------------|-----------------|---------------------|---------------------|---------------|--|
| BEN ←<br>So | - IR[11]<br>what ar | & N + IR[<br>e the bus | 10] & Z +<br>gating sig | IR[9] & P<br>gnals? | 1 | BEN ←<br>Wh | – IR[1<br>at are | 1] &<br>e the | N + II<br>mux s | R[10] &<br>selectio | Z + IR[9<br>n signa | 9] & P<br>ls? |  |
|             | GatePC              | GateMDR                | GateALU                 | Gate<br>MARMUX      |   |             | PC<br>MUX        | DR<br>MUX     | SR1<br>MUX      | ADDR1<br>MUX        | ADDR2<br>MUX        | MAR<br>MUX    |  |
| fetch 1     | 1                   | 0                      | 0                       | 0                   |   | fetch 1     | 00               | xx            | xx              | x                   | xx                  | x             |  |
| fetch 2     | 0                   | 0                      | 0                       | 0                   |   | fetch 2     | xx               | xx            | xx              | x                   | xx                  | x             |  |
| fetch 3     | 0                   | 1                      | 0                       | 0                   |   | fetch 3     | xx               | xx            | xx              | x                   | xx                  | x             |  |
| decode      | 0                   | 0                      | 0                       | 0                   |   | decode      | xx               | xx            | xx              | x                   | xx                  | x             |  |
|             |                     |                        |                         |                     |   |             |                  |               |                 |                     |                     |               |  |

| What are the | ALU and | Memory | Signals? |
|--------------|---------|--------|----------|
|--------------|---------|--------|----------|

## $BEN \leftarrow IR[11] \And N + IR[10] \And Z + IR[9] \And P$

What are the ALU and memory signals?

|         | ALUK | MIO.EN | R.W |
|---------|------|--------|-----|
| fetch 1 | xx   | 0      | x   |
| fetch 2 | xx   | 1      | 0   |
| fetch 3 | xx   | 0      | х   |
| decode  | xx   | 0      | x   |

Notice that MIO.EN is NOT a don't care!

ECE 120: Introduction to Computing

 $\ensuremath{\mathbb{C}}$  2016 Steven S. Lumetta. All rights reserved.

slide 31

## Summary of Control Signals for Fetch and Decode

|                                                                                   | LD.<br>MAR | LD.<br>MDR | LD.<br>IR  | LD.<br>BEN | LD.<br>REG | LD.<br>CC   | LD.<br>PC  |         | GatePC | GateMDR | GateA | LU     | Gate<br>MARMUX |     |
|-----------------------------------------------------------------------------------|------------|------------|------------|------------|------------|-------------|------------|---------|--------|---------|-------|--------|----------------|-----|
| fetch 1                                                                           | 1          | 0          | 0          | 0          | 0          | 0           | 1          | fetch 1 | 1      | 0       | 0     |        | (              | C   |
| fetch 2                                                                           | 0          | 1          | 0          | 0          | 0          | 0           | 0          | fetch 2 | 0      | 0       | 0     |        | 0              |     |
| fetch 3                                                                           | 0          | 0          | 1          | 0          | 0          | 0           | 0          | fetch 3 | 0      | 1       | 0     |        |                | C   |
| decode                                                                            | 0          | 0          | 0          | 1          | 0          | 0           | 0          | decode  | 0      | 0       | 0     | 0      |                | C   |
|                                                                                   |            |            |            |            |            |             |            |         |        |         |       |        |                |     |
|                                                                                   | PC<br>MUX  | DR<br>MUX  | SR1<br>MUX | ADD<br>MU  | R1 A       | DDR2<br>MUX | MAR<br>MUX |         |        |         | ALUK  | MIO.EN |                | R.W |
| fetch 1                                                                           | 00         | xx         | xx         | x          |            | xx          | x          | 1       |        | fetch 1 | xx    | (      | D              | x   |
| fetch 2                                                                           | xx         | xx         | xx         | x          |            | xx          |            | 1       |        | fetch 2 | xx    | 1      | L              | 0   |
| fetch 3                                                                           | xx         | xx         | xx         | x          | <b>x</b> : |             | x          |         |        | fetch 3 | xx    | (      | D              | x   |
| decode                                                                            | xx         | xx         | хх         | x          |            | xx          | x          | 1       |        | decode  | xx    | (      | D              | x   |
|                                                                                   |            |            |            |            |            |             |            | _       |        | -       |       |        |                |     |
| ECE 120: Introduction to Computing © 2016 Steven S. Lumetta. All rights reserved. |            |            |            |            |            |             |            |         | 00     |         |       |        |                |     |