## CS 61C Fall 2018

## 1 Single-Cycle CPU

1.1

For this worksheet, we will be working with the following single-cycle CPU datapath:



- (a) On the datapath above, fill in each **round** box with the name of the datapath component, and each **square** box with the name of the control signal.
- (b) Explain what happens in each datapath stage.

 ${\bf IF}\,$  Instruction Fetch

 ${\bf ID}\,$  Instruction Decode

 ${\bf E}{\bf X}$  Execute

 $\mathbf{MEM} \ \mathrm{Memory}$ 

 $\mathbf{WB}$  Writeback

## 2 Single-Cycle Datapath

1.2 Fill out the following table with the control signals for each instruction based on the datapath on the previous page. Wherever possible, use \* to indicate that what this signal is does not matter.

|                   | BrEq | BrLT | PCSel | ImmSel | BrUn | ASel | BSel | ALUSel | MemRW | RegWEn | WBSel |
|-------------------|------|------|-------|--------|------|------|------|--------|-------|--------|-------|
| add               |      |      |       |        |      |      |      |        |       |        |       |
| ori               |      |      |       |        |      |      |      |        |       |        |       |
| lw                |      |      |       |        |      |      |      |        |       |        |       |
| $\mathbf{sw}$     |      |      |       |        |      |      |      |        |       |        |       |
| beq               |      |      |       |        |      |      |      |        |       |        |       |
| $_{\mathrm{jal}}$ |      |      |       |        |      |      |      |        |       |        |       |
| bltu              |      |      |       |        |      |      |      |        |       |        |       |

1.3

## **Clocking Methodology**

- A state element is an element connected to the clock (denoted by a triangle at the bottom). The **input signal** to each state element must stabilize before each **rising edge**.
- The critical path is the longest delay path between state elements in the circuit. If we place registers in the critical path, we can shorten the period by reducing the amount of logic between registers.

For this exercise, assume the delay for each stage in the datapath is as follows:

| 11.200  ps $112.100  ps$ $113.200  ps$ $111111.200  ps$ $100$ | IF: $200 \text{ ps}$ | ID: 100 ps | EX: 200 ps | MEM: 200 ps | WB: 100 ps |
|---------------------------------------------------------------|----------------------|------------|------------|-------------|------------|
|---------------------------------------------------------------|----------------------|------------|------------|-------------|------------|

(a) Mark the stages of the datapath that the following instructions use and calculate the total time needed to execute the instruction.

|                   | IF | ID | EX | MEM | WB | Total Time |
|-------------------|----|----|----|-----|----|------------|
| add               |    |    |    |     |    |            |
| ori               |    |    |    |     |    |            |
| lw                |    |    |    |     |    |            |
| $\mathbf{SW}$     |    |    |    |     |    |            |
| $\mathbf{beq}$    |    |    |    |     |    |            |
| $_{\mathrm{jal}}$ |    |    |    |     |    |            |
| bltu              |    |    |    |     |    |            |

- (b) Which instruction(s) exercise the critical path?
- (c) What is the fastest you could clock this single cycle datapath?
- (d) Why is the single cycle datapath inefficient?
- (e) How can you improve its performance? What is the purpose of pipelining?