# dv-cpu-rv: CPU design of RISC-V

 $\begin{array}{c} Devin \\ balddevin@outlook.com \\ 2023/7/15 \end{array}$ 

# Content

| 1 | Hardy    | ware Design错误!未定义书签。                | ,   |
|---|----------|-------------------------------------|-----|
|   | 1.1 Basi | ic Single Cycle Implementation      | . 3 |
|   | 1.1.1    | Deisng Diagram                      | .3  |
|   | 1.2 Basi | ic Pilelined Implementation         | . 4 |
|   | 1.2.1    | Design Diagram                      | .4  |
|   | 1.2.2    | Data Hazard: Forwarding or Bypass   | .4  |
|   | 1.2.3    | Control Hazard: Branch Prediction   | .4  |
| 2 | Appe     | ndices                              | 4   |
|   | 2.1 App  | endix 1: Support of Instruction Set | . 4 |
|   | 2.3 App  | endix 2: Examples for Run           | . 7 |
|   | 2.3.1    | Example 1: Add and Store.           |     |
|   | 2.3.2    | Example 2: Sum Less Than.           |     |

### 1 Preface

The design of this CPU mainly refers to *Computer Organization and Design: The Hardware / Software Interface*: RISC-V Edition, David A.Patterson, John L. Hennessy.

The source code is also distributed to Github: devindang/dv-cpu-rv.

# 2 Hardware Design

# 2.1 Basic Single Cycle Implementation

### 2.1.1 Deisng Diagram



Figure 1.1 The Basic Single Cycle Implementation of CPU

The figure above shows the implementation of the basic single cycle cpu, in which the hinted lines are signals of control path, while the others are signals of data path.

# 2.2 Basic Pilelined Implementation

### 2.2.1 Design Diagram

### 2.2.2 Data Hazard: Forwarding or Bypass

Data hazards are obstacles to pipelined execution.

### 2.2.3 Control Hazard: Branch Prediction

# 3 Appendices

# 3.1 Appendix 1: Support of Instruction Set

The regularity of opcode:

The example of RISC-V pseudoinstructions can be found in *risc-v specification* v2.2 p109, from which we can deal with the assembly codes.

### **RV32I Base Instruction Set**

Total: 47

| Type   | Order | Instruction | Description             | Compatibility |
|--------|-------|-------------|-------------------------|---------------|
|        | 1     | ADD         | Add.                    |               |
|        | 2     | SUB         | Subtract.               |               |
|        | 3     | SLL         | Shift Left Logical.     |               |
|        | 4     | SLT         | Set Less Than.          |               |
| R-type | 5     | SLTU        | Set Less Than Unsigned. |               |
| K-type | 6     | XOR         | Exclusive or.           |               |
|        | 7     | SRL         | Shift Right Logical.    |               |
|        | 8     | SRA         | Shift Right Arithmetic. |               |
|        | 9     | OR          | Or.                     |               |
|        | 10    | AND         | And.                    |               |
|        | 11    | JALR        | Jump And Link Register. |               |
|        | 12    | LB          | Load Byte.              |               |
| I-type | 13    | LH          | Load Halfword.          |               |
| 1-турс | 14    | LW          | Load Word.              |               |
|        | 15    | LBU         | Load Byte Unsigned.     |               |
|        | 16    | LHU         | Load Halfword Unsigned. |               |

|         | 17 | ADDI    | Add Immediate.                    |    |
|---------|----|---------|-----------------------------------|----|
|         | 18 | SLTI    | Set Less Than Immediate.          |    |
|         | 19 | SLTIU   | Set Less Than Immediate Unsigned. |    |
|         | 20 | XORI    | Exclusive Or Immediate.           |    |
|         | 21 | ORI     | Or Immediate.                     |    |
|         | 22 | ANDI    | And Immediate.                    |    |
|         | 23 | SLLI    | Shift Left Logic Immediate.       |    |
|         | 24 | SRLI    | Shift Right Logic Immediate.      |    |
|         | 25 | SRAI    | Shift Right Arithmeic Immediate.  |    |
|         | 26 | SB      | Store Byte.                       |    |
| S-type  | 27 | SH      | Store Halfword.                   |    |
|         | 28 | SW      | Store Word.                       |    |
|         | 29 | BEQ     | Branch if Equal.                  |    |
|         | 30 | BNE     | Branch Not Equal.                 |    |
| D turno | 31 | BLT     | Branch Less Than.                 |    |
| B-type  | 32 | BGE     | Branch Greater or Equal.          |    |
|         | 33 | BLTU    | Branch Less Than Unsigned.        |    |
|         | 34 | BGEU    | Branch Greater or Equal Unsigned. |    |
| U-type  | 35 | LUI     | Load Upper Immediate.             |    |
| О-турс  | 36 | AUIPC   | Add Upper Immediate to PC.        |    |
| J-type  | 37 | JAL     | Jump And Link.                    |    |
|         | 38 | FENCE   |                                   | NO |
|         | 39 | FENCE.I |                                   | NO |
|         | 40 | ECALL   |                                   | NO |
|         | 41 | EBREAK  |                                   | NO |
| other   | 42 | CSRRW   |                                   | NO |
| ouici   | 43 | CSRRS   |                                   | NO |
|         | 44 | CSRRC   |                                   | NO |
|         | 45 | CSRRWI  |                                   | NO |
|         | 46 | CSRRSI  |                                   | NO |
|         | 47 | CSRRCI  |                                   | NO |

# RV64I Base Instruction Set (in addition to RV32I)

Total: 15

| Туре   | Order | Instruction | Description                  | Compatibility |
|--------|-------|-------------|------------------------------|---------------|
|        | 1     | ADDW        | Add Word.                    |               |
|        | 2     | SUBW        | Subtract Word.               |               |
| R-type | 3     | SLLW        | Shift Left Logical Word.     |               |
|        | 4     | SRLW        | Set Less Than Word.          |               |
|        | 5     | SRAW        | Set Less Than Unsigned Word. |               |
|        | 6     | LWU         | Load Word Unsigned.          |               |
| I-type | 7     | LD          | Load Doubleword.             |               |
|        | 8     | SLLI        | Shift Left Logic Immediate.  |               |

|        | 9  | SRLI  | Shift Right Logic Immediate.           |  |
|--------|----|-------|----------------------------------------|--|
|        | 10 | SRAI  | Shift Right Arithmetic Immediate.      |  |
|        | 11 | ADDIW | Add Immediate Word.                    |  |
|        | 12 | SLLIW | Shift Left Logic Immediate Word.       |  |
|        | 13 | SRLIW | Shift Right Logic Immediate Word.      |  |
|        | 14 | SRAIW | Shift Right Arithmetic Immediate Word. |  |
| S-type | 15 | SD    | Store Doubleword.                      |  |

### 3.3 Appendix 2: Examples for Run

### 3.3.1 Example 1: Add and Store.

Date: 2023/7/23

Hash: a7b05c264b7f45e27a81ddc02184c6dcee29fdf9

**Description**: Given two numbers, add them and store into memory.

#### C code

```
#include "stdio.h"
int main() {
    int a = 14;
    int b = 15;
    int c;
    c = a + b;
    return 0;
}
```

### Assembly code

### 3.3.2 Example 2: Sum Less Than.

Date: 2023/7/29

Hash: 1d28ab2a485737b8bd90fa777fd550d5183b705c

Description: Given a non-zero natural number N, calculate the sum of natural numbers less

than N.

C code

```
#include "stdio.h"
int main() {
    int N = 10;
    int sum = 0;
    for(int i=1; i<N; i++){
        sum = sum+i;
    }
    return 0;
}</pre>
```

### Assembly code

```
addi x1 x0 10; //0// 000000001010000000000010010011
addi x2 x0 1; //4// 00000000001000000000100010011
addi x3 x0 0; //8// 00000000000000000000110010011
```