

# CSED311: Lab 4 Multi-cycle CPU

**Jiwoong Shin** 

jwshin0610@postech.ac.kr

Contact the TAs at <a href="mailto:csed311-ta@postech.ac.kr">csed311-ta@postech.ac.kr</a>





# **Objectives**

 To understand why a multi-cycle CPU is better than the single-cycle implementation

 To design and implement a multi-cycle CPU, which has its own datapath and control unit





# Why do we need multi-cycle CPU?

- Problem on single-cycle CPU: underutilization of resources (ALU, memory, register file, etc.)
- Solution: use higher clock frequency and allocate different number of cycles for each instruction type

Memory units (read or write): 200 ps

ALU (add op): 100 ps

Register file (read or write): 50 ps

Other combinational logic: 0 ps

| Steps     | IF  | ID | EX  | MEM | WB | Delay |  |
|-----------|-----|----|-----|-----|----|-------|--|
| Resources | mem | RF | ALU | mem | RF |       |  |
| R-type    | 200 | 50 | 100 |     | 50 | 400   |  |
| I-type    | 200 | 50 | 100 |     | 50 | 400   |  |
| LD        | 200 | 50 | 100 | 200 | 50 | 600   |  |
| SD        | 200 | 50 | 100 | 200 |    | 550   |  |
| Bxx       | 200 | 50 | 100 |     |    | 350   |  |
| JAL       | 200 |    | 100 |     | 50 | 350   |  |
| JALR      | 200 | 50 | 100 |     | 50 | 400   |  |



## Multi-cycle CPU (Datapath)





### Multi-cycle CPU (Finite state machine)





### Multi-cycle CPU (Micro-code controller)



| State            | Control<br>flow | Conditional targets |                  |                  |                 |                 |                 |  |  |
|------------------|-----------------|---------------------|------------------|------------------|-----------------|-----------------|-----------------|--|--|
| label            |                 | R/I-type            | LD               | SD               | Вхх             | JALR            | JAL             |  |  |
| IF <sub>1</sub>  | next            | -                   | -                | -                | -               | -               | -               |  |  |
| IF <sub>2</sub>  | next            | -                   | -                | -                | -               | -               | -               |  |  |
| IF <sub>3</sub>  | next            | -                   | 1                | -                | -               | -               | -               |  |  |
| IF <sub>4</sub>  | go to           | ID                  | ID               | ID               | ID              | ID              | EX <sub>1</sub> |  |  |
| ID               | next            | -                   | 1                | -                | 1               | 1               |                 |  |  |
| EX <sub>1</sub>  | next            | -                   | 1                | -                | -               | -               | -               |  |  |
| EX <sub>2</sub>  | go to           | WB                  | MEM <sub>1</sub> | MEM <sub>1</sub> | IF <sub>1</sub> | WB              | WB              |  |  |
| MEM <sub>1</sub> | next            |                     | 1                | -                |                 |                 |                 |  |  |
| MEM <sub>2</sub> | next            |                     | 1                | -                |                 |                 |                 |  |  |
| MEM <sub>3</sub> | next            |                     | -                | -                |                 |                 |                 |  |  |
| MEM <sub>4</sub> | go to           |                     | WB               | IF <sub>1</sub>  |                 |                 |                 |  |  |
| WB               | go to           | IF <sub>1</sub>     | IF <sub>1</sub>  |                  |                 | IF <sub>1</sub> | IF <sub>1</sub> |  |  |
| СРІ              |                 | 8                   | 12               | 11               | 7               | 8               | 7               |  |  |





# Multi-cycle CPU

- Details for multi-cycle CPU are given in the lecture note and textbook
- Please read those materials yourself to work on it

Let's discuss the design and implementation



### The testbench file

**cpu UUT** (clk, reset\_n, readM, writeM, address, data, num\_inst, output\_port, is\_halted);

**Memory NUUT**(!clk, reset\_n, readM, writeM, address, data);

- Note that the memory is not using the clock signal properly.
  - It is done to allow the CPU to use access the memory in a single cycle and make it easier to implement.
  - Such use of clk is forbidden within your code.



# Assignment (1)

- Implement a multi-cycle CPU
  - Datapath for a 16-bit CPU
  - Full support for TSC instruction set except for RWD, ENI, DSI
  - num\_inst should be increased when the CPU finishes executing an instruction
  - The WWD instruction outputs the register value at the output\_port
  - The HLT instruction sets the is\_halted signal
  - Other instructions follow the TSC instruction set manual
- The datapath and the control unit should be separated
  - The control unit controls the finite state machine
  - The control unit gives appropriate signals to the datapath



# Assignment (2)

- Your implementation should pass all tests in the testbench
  - But the message of "All pass!" does not mean you will get a full score
- Your control unit should have well-designed states
- Your control unit should be a well-implemented state machine
- Each state should generate its control signals
- All your circuits (Datapath + Control unit) should be clocksynchronized
  - You should not use "delay(#)" nor "wait"
  - All storage units (registers, PC, etc.) must be updated only at the clock's positive edges
- Your code should have "resource reuse", which affects your control unit design
  - E.g. Using only one RAM port, combining a "PC + 1" logic with the ALU



### Submission

- Please submit your report and codes to LMS
  - Due date for the codes: 2020/5/11 (Mon) 9:00am
  - Due date for the report: 2020/5/11 (Mon) 20:00pm
- The file names for report and codes follow these formats
  - "Lab4\_TeamID\_StudentID1[\_StudentID2].pdf": PDF file for your report
    - ex) Lab1\_20\_20180001\_20180002.pdf, Lab1\_21\_20180003.pdf (for a single-person team)
  - "Lab4\_TeamID\_StudentID1[\_StudentID2].zip": Zip file for your own codes (\*.v) only
- If you do not follow the given format, you will get penalty on your score

