

### INTRODUCTION

- •RISC-V is an open-source instruction set architecture (ISA)
- •It is a type of Reduced Instruction Set Computing (RISC) architecture
- •It is designed to be simple, modular, and extensible
- •RISC-V is highly scalable and customizable, making it suitable for a wide range of applications



#### **SPECIFICATIONS**

- 1.Core must be compatible with rv32i instruction set.
- 2. Implement base ISA spec. Reference: RISC-V ISA.
- 3. Use input global clock (positive edge triggered: clk), global reset (negative edge triggered: rst\_n) and core\_select signal
- 4. Functionality of core\_select

| core_select | Functionality                                                                                                        |  |  |  |
|-------------|----------------------------------------------------------------------------------------------------------------------|--|--|--|
| 0           | <ol> <li>Memory controller interface will be active<br/>to write data into the memory.</li> </ol>                    |  |  |  |
| 1           | Core will start to work     Core side interface of the memory will be active to read and write data into the memory. |  |  |  |

- 5. Core HDL descriptions need to be Synthesizable and optimized.
- 6. Base Clock Frequency 100 MHz



### WHY MULTICYCLE?

- Faster Clock Speed Greater Flexibility
- Lower Hardware Costs.
- Improved Performance
- Reduced Power Consumption processor.



### FSM



#### ALU Control DATA PATH Control ALU SrcA Unit ALU SrcB 14:12 Shift Src =instr[5] ALU Flag ResultSrc AdrSrc Next PC **A**LUResult WEM WER Instr 19:15 24:20 A2 RD2 **IRWrite** 11:7 Instr/Data Memory WD3 ALU Flag MaskEn ReadData 15:0 Data 7:0 Extend 3:0 31:0 Mem\_Read\_State Extend RegW.Src Result

### CPI

#### Global CPI is 4

| Instruction   | CPI (cycle) |
|---------------|-------------|
| I type        | 4           |
| I type (load) | 5           |
| J type        | 4           |
| R type        | 4           |
| S type        | 4           |
| U type        | 3           |
| B type        | 4           |

### ALU

| ALU CONTROL | Operation              |  |  |  |  |  |
|-------------|------------------------|--|--|--|--|--|
| 000         | Addition               |  |  |  |  |  |
| 001         | Subtraction            |  |  |  |  |  |
| 010         | Bitwise And            |  |  |  |  |  |
| 011         | Bitwise OR             |  |  |  |  |  |
| 100         | Bitwise XOR            |  |  |  |  |  |
| 101         | Logical Right Shift    |  |  |  |  |  |
| 110         | Arithmetic Right Shift |  |  |  |  |  |
| 111         | Logical Left Shift     |  |  |  |  |  |

### CONTROL UNIT



### FSM FOR LW (ITYPE)



#### **ALU Control** DATAPATH FOR LW Control ALU SrcA ALU SrcB $rd \leftarrow sx(m32(rs1+imm_i)), pc \leftarrow pc+4$ Shift Src =instr[5] ALU Flag ResultSrc AdrSrc Next PC WEM 19:15 M ALUOut RD1 24:20 RD2 **IRWrite** 11:7 Instr/Data Memory WD3 ReadData 15:0 Extend 31:0 Mem Read State RegWSrc Result

### INSTRUCTION - LW



lw

a5,-24(s0)

Value written in this clk

## FSM FOR JUMP (J TYPE)





### INSTRUCTION – JUMP



### FSM FOR ADD (R TYPE)



## DATAPATH FOR ADD (R TYPE)

 $rd \leftarrow rs1 + rs2$ ,  $pc \leftarrow pc+4$ 

Next PC

AdrSrc



### INSTRUCTION - ADD(R TYPE)



## FSM FOR BNE (B TYPE)



### DATAPATH FOR BNE

 $pc \leftarrow pc + ((rs1!=rs2) ? imm_b : 4)$ 



ALU Control

#### INSTRUCTION - BNE



bne a4,a5,4c <prime\_number+0x34>

## FSM FOR SW (S TYPE)



#### **ALU Control** DATAPATH FOR SW Control ALU SrcA Unit rs2, imm(rs1)ALU SrcB swShift Src =instr[5] $m32(rs1+imm\_s) \leftarrow rs2[31:0], pc \leftarrow pc+4$ Flag\* ResultSrc Next PC WEM Instr 19:15 24:20 **IRWrite** 11:7 Instr/Data Memory WD3 ReadData 15:0 Extend Mem\_Read\_State RegW,Src

### INSTRUCTION - SW



• SP means R2

S0 means R8

• Mem[R2+28] R8

Value is available in memory from this cycle

## FSM FOR & IUPC (U TYPE)



### DATAPATH FOR



ALU Control

### INSTRUCTION - &UIPC



#### RESULT AND DISCUSSIONS



## INSTRUCTIONS COVERED

#### RV32I Base Instruction Set Encoding [1, p. 104]

| imm[31:12]         rd         0 1 1 0 1 1 1 1 U-type         lui rd,imm           imm[31:12]         rd         0 0 1 0 1 1 1 1 U-type         auipc rd,imm           imm[20 10:1 11 19:12]         rd         1 1 0 1 1 1 1 1 J-type         jal rd,pcrel_21 I-type           imm[11:0]         rs1         0 0 0 imm[4:1 11]         1 1 0 0 0 1 1 I I I I I I I I I I I I I                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| imm[20 10:1 11 19:12]         rd         1 1 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| imm[11:0]         rs1         0 0 0         rd         1 1 0 0 1 1 1         I-type         jalr         rd,imm(rs1)           imm[12 10:5]         rs2         rs1         0 0 0 imm[4:1 11]         1 1 0 0 0 1 1         B-type         beq         rs1,rs2,pcre1           imm[12 10:5]         rs2         rs1         0 0 1 imm[4:1 11]         1 1 0 0 0 1 1         B-type         bne         rs1,rs2,pcre1           imm[12 10:5]         rs2         rs1         1 0 0 imm[4:1 11]         1 1 0 0 0 1 1         B-type         blt         rs1,rs2,pcre1           imm[12 10:5]         rs2         rs1         1 0 1 imm[4:1 11]         1 1 0 0 0 1 1         B-type         bg         rs1,rs2,pcre1 |
| imm[12 10:5]         rs2         rs1         0 0 0 imm[4:1 11]         1 1 0 0 0 1 1         B-type         beq         rs1,rs2,pcred           imm[12 10:5]         rs2         rs1         0 0 1 imm[4:1 11]         1 1 0 0 0 1 1         B-type         bne         rs1,rs2,pcred           imm[12 10:5]         rs2         rs1         1 0 0 imm[4:1 11]         1 1 0 0 0 1 1         B-type         blt         rs1,rs2,pcred           imm[12 10:5]         rs2         rs1         1 0 1 imm[4:1 11]         1 1 0 0 0 1 1         B-type         bg         rs1,rs2,pcred                                                                                                                                |
| imm[12 10:5]         rs2         rs1         0 0 1 imm[4:1 11]         1 1 0 0 0 1 1         B-type         bne         rs1,rs2,pcre           imm[12 10:5]         rs2         rs1         1 0 0 imm[4:1 11]         1 1 0 0 0 1 1         B-type         blt         rs1,rs2,pcre           imm[12 10:5]         rs2         rs1         1 0 1 imm[4:1 11]         1 1 0 0 0 1 1         B-type         bge         rs1,rs2,pcre                                                                                                                                                                                                                                                                                  |
| imm[12 10:5]         rs2         rs1         1 0 0 imm[4:1 11]         1 1 0 0 0 1 1         B-type         blt         rs1,rs2,pcre           imm[12 10:5]         rs2         rs1         1 0 1 imm[4:1 11]         1 1 0 0 0 1 1         B-type         bge         rs1,rs2,pcre                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| imm[12 10:5] rs2 rs1 1 0 1 imm[4:1 11] 1 1 0 0 0 1 1 B-type bge rs1,rs2,pcre                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| imm[12 10:5] rs2 rs1 1 1 0 imm[4:1 11] 1 1 0 0 0 1 1 B-type bltm rs1,rs2,pcre                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| imm[12 10:5] rs2 rs1   1 1 1 imm[4:1 11]   1 1 0 0 0 1 1 B-type bgeu rs1,rs2,pcre                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| imm[11:0] rs1 0 0 0 rd 0 0 0 0 1 1 I-type 1b rd,imm(rs1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| imm[11:0] rs1 0 0 1 rd 0 0 0 0 0 1 1 I-type 1h rd,imm(rs1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| imm[11:0] rs1 0 1 0 rd 0 0 0 0 0 1 1 I-type lw rd,imm(rs1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| imm[11:0] rs1 1 0 0 rd 0 0 0 0 0 1 1 I-type 1bu rd,imm(rs1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| imm[11:0] rs1   1 0 1 rd   0 0 0 0 0 1 1 I-type lhu rd,imm(rs1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| imm[11:5] rs2 rs1 0 0 0 imm[4:0] 0 1 0 0 0 1 1 S-type sb rs2, imm(rs1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| imm[11:5] rs2 rs1 0 0 1 imm[4:0] 0 1 0 0 0 1 1 S-type sh rs2, imm(rs1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| imm[11:5] rs2 rs1 0 1 0 imm[4:0] 0 1 0 0 0 1 1 S-type sw rs2,imm(rs1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| imm[11:0] rs1 0 0 0 rd 0 0 1 0 0 1 1 I-type addi rd,rs1,imm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| imm[11:0] rs1 0 1 0 rd 0 0 1 0 0 1 1 I-type slti rd,rs1,imm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| imm[11:0] rs1 0 1 1 rd 0 0 1 0 0 1 1 I-type sltiu rd,rs1,imm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| imm[11:0] rs1 1 0 0 rd 0 0 1 0 0 1 1 I-type xori rd,rs1,imm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| imm[11:0] rs1 1 1 0 rd 0 0 1 0 0 1 1 I-type ori rd,rs1,imm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| imm[11:0] rs1   1 1 1   rd   0 0 1 0 0 1 1   I-type   andi rd,rs1,imm                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0 0 0 0 0 0 0 shamt rs1 0 0 1 rd 0 0 1 0 0 1 1 I-type slli rd,rs1,shamt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0 0 0 0 0 0 0 0 shamt rs1 1 0 1 rd 0 0 1 0 0 1 1 I-type srli rd,rs1,shamt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0 1 0 0 0 0 0 shamt rs1 1 0 1 rd 0 0 1 0 0 1 1 I-type srai rd,rs1,shamt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 0 0 0 0 0 0 0 0 rs2 rs1 0 0 0 rd 0 1 1 0 0 1 1 R-type add rd,rs1,rs2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0 1 0 0 0 0 0 0 rs2 rs1 0 0 0 rd 0 1 1 0 0 1 1 R-type sub rd,rs1,rs2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0 0 0 0 0 0 0 0 rs2 rs1 0 0 1 rd 0 1 1 0 0 1 1 R-type s11 rd,rs1,rs2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0 0 0 0 0 0 0 0 rs2 rs1 0 1 0 rd 0 1 1 0 0 1 1 R-type slt rd,rs1,rs2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0 0 0 0 0 0 0 0 rs2 rs1 0 1 1 rd 0 1 1 0 0 1 1 R-type sltu rd,rs1,rs2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0 0 0 0 0 0 0 0 rs2 rs1 1 0 0 rd 0 1 1 0 0 1 1 R-type xor rd,rs1,rs2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0 0 0 0 0 0 0 0 rs2 rs1 1 0 1 rd 0 1 1 0 0 1 1 R-type sr1 rd,rs1,rs2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0 1 0 0 0 0 0 0 rs2 rs1 1 0 1 rd 0 1 1 0 0 1 1 R-type sra rd,rs1,rs2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 0 0 0 0 0 0 0 0 rs2 rs1 1 1 0 rd 0 1 1 0 0 1 1 R-type or rd,rs1,rs2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0 0 0 0 0 0 0 0 rs2 rs1 1 1 1 rd 0 1 1 0 0 1 1 R-type and rd,rs1,rs2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### CHALLENGES

- Handling PC Logic- Adding old pc register to our existing data path.
- Handling Instruction and data conflict- We added two separate register in the datapath.

### FUTURE IMPROVEMENT

 WE can implement these special type of instructions

| 0 0 0 0 0 0 0 0 0 0 0 0 | 0 0 0 0 0 | 0 0 0 | 0 0 0 0 0  | 1 1 1 | 0 0 1 1 |        |
|-------------------------|-----------|-------|------------|-------|---------|--------|
| 0 0 0 0 0 0 0 0 0 0 0 1 | 0 0 0 0 0 | 0 0 0 | 0 0 0 0 0  | 1 1 1 | 0 0 1 1 |        |
| csr[11:0]               | rs1       | 0 0 1 | $_{ m rd}$ |       | 0 0 1 1 |        |
| csr[11:0]               | rs1       | 0 1 0 | $_{ m rd}$ |       | 0 0 1 1 |        |
| csr[11:0]               | rs1       | 0 1 1 | $_{ m rd}$ |       | 0 0 1 1 |        |
| csr[11:0]               | zimm[4:0] | 1 0 1 | $_{ m rd}$ | 1 1 1 | 0 0 1 1 | I-type |
| csr[11:0]               | zimm[4:0] | 1 1 0 | $_{ m rd}$ | 1 1 1 | 0 0 1 1 | I-type |
| csr[11:0]               | zimm[4:0] | 1 1 1 | $_{ m rd}$ | 1 1 1 | 0 0 1 1 | I-type |

 We can use pipeline architecture to minimize run time. ecall
ebreak
csrrw rd,csr,rs1
csrrs rd,csr,rs1
csrrc rd,csr,rs1
csrrwi rd,csr,zimm
csrrsi rd,csr,zimm
csrrci rd,csr,zimm

# Thank You!





Dr. A.B.M. Harun-ur-Rashid
Professor
Electrical & Electronic Engeineering,
BUET

Nafis Sadik
Lecturer
Electrical & Electronic
Engineering,
BUET

Ashiqur Rasul Lecturer Electrical & Electronic Engineering, BUET