# Team 24: RISC-V CPU (Pipelined with Data Cache)

## **Table of Contents**

#### **Processor**

- Single Cycle
  - F1 Program (Samuel)
  - Program Counter & Instruction Memory (Qidong)
  - Control Unit (Samuel, Bharathaan)
  - ALU (Bharathaan)
  - Data Memory (Chenglin)
- Pipeline
  - Programs For Pipelined CPUs (Samuel)
- Data Cache
  - Data Cache (Chenglin, Qidong)
- Others
  - Result Verification (Samuel)
- Top-Level
  - o Top Level File (Bharathaan)

### Individual Statements

- Personal Statement: Chenglin
- Personal Statement: Qidong
- Personal Statement: Bharathaan
- Personal Statement: Samuel

## **Quick Start**

Entrypoint.sh is a shell written to easily load different sets of instructions & data into the processor. Three modes are available: f1, ref, and comp. Each mode runs the F1 program, the reference program, or the component specific testbench respectively. See Table 1 below for a list of operations you can run with the entrypoint.sh shell.

Table 1: Entrypoint.sh Usage

| Command                    | What It Does            | Remarks |
|----------------------------|-------------------------|---------|
| source<br>entrypoint.sh f1 | Runs F1 Lights program. |         |

| Command                                 | Vhat It Does Remarks                                                                     |                                          |
|-----------------------------------------|------------------------------------------------------------------------------------------|------------------------------------------|
| source<br>entrypoint.sh f1<br>debug     | Runs F1 Lights debug program, which shows special state when LFSR subroutine is running. |                                          |
| source<br>entrypoint.sh ref<br>gaussian | Runs reference program, loading gaussian waveform into memory.                           |                                          |
| source<br>entrypoint.sh ref<br>noisy    | Runs reference program, loading noisy waveform into memory.                              |                                          |
| source<br>entrypoint.sh ref<br>sine     | Runs reference program, loading sine waveform into memory.                               |                                          |
| source<br>entrypoint.sh ref<br>triangle | Runs reference program, loading triangle waveform into memory.                           |                                          |
| source<br>entrypoint.sh comp<br>alu     | Runs ALU component testbench.                                                            | Only works in v2.0-<br>pipeline release. |
| source<br>entrypoint.sh comp<br>ctrl    | Runs Control Unit component testbench.                                                   | Only works in v2.0-<br>pipeline release. |
| source<br>entrypoint.sh comp<br>mem     | Runs Data Memory component testbench.                                                    | Only works in v2.0-<br>pipeline release. |
| source<br>entrypoint.sh comp<br>pc      | Runs Program Counter component testbench.                                                | Only works in v2.0-<br>pipeline release. |

If entrypoint.sh does not work, you should configure the debug.sh script to execute what you want. Note that the instruction memory loads from program/instr.hex and the data memory loads from program/data.mem. These were dynamically created by entrypoint.sh, which means you would need to copy the data over and rename before running.

## Overview

Versions (See Release)

• Single Cycle: v1.0-single-cycle

• Pipeline: v2.0-pipeline

• Data Cache (merged to main): v3.0-data-cache

See the following embedded videos, for the F1 program and the 4 waveforms PDF programs.



Figure 1: F1 Lights



Figure 2: Reference Program (Gaussian)



Figure 3: Reference Program (Noisy)



Figure 4: Reference Program (Sine)



Figure 5: Reference Program (Triangle)

# **Contribution Table**

**Note:** o = Main Contributor; v = Co-Author.

Table 2: Contribution List

| Task                                 | Files                                                      | Chenglin | Qidong | Bharathaan | Samuel |
|--------------------------------------|------------------------------------------------------------|----------|--------|------------|--------|
| Single<br>Cycle                      |                                                            |          |        |            |        |
| Repo Setup                           | .gitignore, .gitkeep,                                      |          |        |            | 0      |
| Entry Script                         | debug.sh, entrypoint.sh,                                   |          |        | V          | 0      |
| F1 Program                           | f1_branch.s,f1_jump.s,                                     |          |        |            | 0      |
| Program Counter & Instruction Memory | <pre>pc_reg.sv, instruction_memory.sv, pc_reg_tb.cpp</pre> | V        | O      |            |        |
| Control Unit                         | <pre>control_unit.sv, extend.sv, control_top_tb.cpp</pre>  |          |        | V          | 0      |
| ALU                                  | alu.sv, reg_file.sv, alu_tb.cpp                            |          |        | 0          |        |
| Data<br>Memory                       | <pre>data_memory.sv, data_memory_tb.cpp</pre>              | 0        | V      |            |        |

| Task                                 | Files                                                         | Chenglin | Qidong | Bharathaan | Samuel |
|--------------------------------------|---------------------------------------------------------------|----------|--------|------------|--------|
| Top-Level<br>Debugging               | rtl.sv, ref_tb.cpp, f1_tb.cpp                                 |          |        | O          | V      |
| Pipeline                             |                                                               |          |        |            |        |
| Pipeline<br>Programs                 | <pre>f1_pipeline.s, f1_pipeline_debug.s, pdf_pipeline.s</pre> |          |        | V          | 0      |
| Fetch Stage<br>Registers             | instruction_memory_pip.sv                                     |          | 0      |            |        |
| Decode<br>Stage<br>Registers         | decode_register.sv                                            |          |        |            | 0      |
| Execute<br>Stage<br>Registers        | memory_stage_register.sv                                      |          |        | o          |        |
| Memory<br>Stage<br>Registers         | memory_writeback_register.sv                                  | 0        |        |            |        |
| Top-Level<br>Debugging               | rtl.sv, ref_tb.cpp, f1_tb.cpp                                 |          |        | O          | V      |
| Data<br>Cache                        |                                                               |          |        |            |        |
| Data Cache<br>(1-way)                |                                                               | 0        | 0      |            |        |
| Data Cache<br>(2-way,<br>incomplete) |                                                               | o        | 0      |            |        |
| Top-Level<br>Debugging               | rtl.sv, ref_tb.cpp, f1_tb.cpp                                 | V        | ٧      | 0          |        |

# Specifications

Table 3: Implemented Instructions

| Туре | Instructions            |  |
|------|-------------------------|--|
| R    | add, xor                |  |
| В    | bne                     |  |
| I    | addi, slli, lb, lw, lbu |  |

| Туре | Instructions |
|------|--------------|
| S    | sb, sw       |
| U    | lui          |
| J    | jal, jalr    |

Table 4: General Specifications

| Property                | value      |
|-------------------------|------------|
| Instruction Memory Size | 2^12 bits  |
| Instruction Width       | 32-bit     |
| Data Memory Size        | 2^17 bits  |
| Data Witdh              | 8-bit      |
| Data Cache Size         | 128 bytes  |
| Data Cache Sets         | 8          |
| Data Cache Ways         | 1          |
| Data Cache Block Size   | 4 * 32-bit |

For more detailed detailed specifications, see our Specification Sheet.

## File Structure

### **Ideal Final File Structure**





#### **Directories**

- 1. docs: directory that holds information about the project and its source files.
- 2. source: directory that holds all the .sv design files.
- 3. testbench: directory that holds the testbench for each component and overall design.
- 4. program: directory that holds the .s source files for program and data to be loaded into the processor.

#### **Notable Files**

- 1. README.md: overall readme document.
- 2. •gitignore: standard file to ignore verilator obj\_dir, .vcd, and other os files.
- 3. entrypoint.sh: shell script that builds and runs the design, with easy debugging features.
- 4. entrypoint.config: configuration file for verilator arguments, such as suppressing warnings and others.
- 5. debug sh: fall back for entrypoint.sh.
- 6. source/rtl.sv: top level file for our design.