



#### **Outline**

- □ 作業內容說明
- □ 作業驗證說明
- □ 作業繳交注意事項









#### 作業內容說明



#### **Problem 1**

□ 根據作業中附的RISC-V ISA,完成一個pipelined CPU





#### **Problem 1 Specification**

- Implement the 33 instructions as listed
- ☐ The number of pipeline stage is 5.
- ☐ Register File size: 32x32-bit
  - > x0 is read only 0.
- Instruction memory size: 16Kx32-bit
- □ Data memory size: 16Kx32-bit
- ☐ Timescale: 1ns/10ps
- Maximum Clock period: 20ns (50MHz)





#### Problem 1 – Instructions (1/2)

R-type

| 31 25   | 24 20 | 19 15 | 14 12  | 11 7 | 6 0     |          |                              |
|---------|-------|-------|--------|------|---------|----------|------------------------------|
| funct7  | rs2   | rs1   | funct3 | rd   | opcode  | Mnemonic | Description                  |
| 0000000 | rs2   | rs1   | 000    | rd   | 0110011 | ADD      | rd = rs1 + rs2               |
| 0100000 | rs2   | rs1   | 000    | rd   | 0110011 | SUB      | rd = rs1 - rs2               |
| 0000000 | rs2   | rs1   | 001    | rd   | 0110011 | SLL      | $rd = rs1_u << rs2[4:0]$     |
| 0000000 | rs2   | rs1   | 010    | rd   | 0110011 | SLT      | $rd = (rs1_s < rs2_s)$ ? 1:0 |
| 0000000 | rs2   | rs1   | 011    | rd   | 0110011 | SLTU     | $rd = (rs1_u < rs2_u)$ ? 1:0 |
| 0000000 | rs2   | rs1   | 100    | rd   | 0110011 | XOR      | $rd = rs1 \wedge rs2$        |
| 0000000 | rs2   | rs1   | 101    | rd   | 0110011 | SRL      | $rd = rs1_u >> rs2[4:0]$     |
| 0100000 | rs2   | rs1   | 101    | rd   | 0110011 | SRA      | $rd = rs1_s >> rs2[4:0]$     |
| 0000000 | rs2   | rs1   | 110    | rd   | 0110011 | OR       | $rd = rs1 \mid rs2$          |
| 0000000 | rs2   | rs1   | 111    | rd   | 0110011 | AND      | rd = rs1 & rs2               |

I-type

| 31      | 20    | 19 15 | 14 12  | 11 7 | 6 0     |          |                             |
|---------|-------|-------|--------|------|---------|----------|-----------------------------|
| imm[11  | :0]   | rs1   | funct3 | rd   | opcode  | Mnemonic | Description                 |
| imm[11  | :0]   | rs1   | 010    | rd   | 0000011 | LW       | rd = M[rs1+imm]             |
| imm[11  | :0]   | rs1   | 000    | rd   | 0010011 | ADDI     | rd = rs1 + imm              |
| imm[11  | :0]   | rs1   | 010    | rd   | 0010011 | SLTI     | $rd = (rs1_s < imm_s)? 1:0$ |
| imm[11  | :0]   | rs1   | 011    | rd   | 0010011 | SLTIU    | $rd = (rs1_u < imm_u)? 1:0$ |
| imm[11  | :0]   | rs1   | 100    | rd   | 0010011 | XORI     | $rd = rs1 \wedge imm$       |
| imm[11  | :0]   | rs1   | 110    | rd   | 0010011 | ORI      | rd = rs1   imm              |
| imm[11  | :0]   | rs1   | 111    | rd   | 0010011 | ANDI     | rd = rs1 & imm              |
| imm[11  | :0]   | rs1   | 000    | rd   | 0000011 | LB       | rd = M[rs1+imm]bs           |
| 0000000 | shamt | rs1   | 001    | rd   | 0010011 | SLLI     | $rd = rs1_u \ll shamt$      |
| 0000000 | shamt | rs1   | 101    | rd   | 0010011 | SRLI     | $rd = rs1_u >> shamt$       |
| 0100000 | shamt | rs1   | 101    | rd   | 0010011 | SRAI     | $rd = rs1_s >> shamt$       |
|         |       |       |        |      |         |          | rd = PC + 4                 |
| imm[11  | :0]   | rs1   | 000    | rd   | 1100111 | JALR     | PC = imm + rs1              |
|         |       |       |        |      |         |          | (Set LSB of PC to 0)        |





#### Problem 1 – Instructions (2/2)

☐ S-type

| 31 25     | 24 20 | 19 15 | 14 12  | 11 7     | 6 0     |          |                       |
|-----------|-------|-------|--------|----------|---------|----------|-----------------------|
| imm[11:5] | rs2   | rs1   | funct3 | imm[4:0] | opcode  | Mnemonic | Description           |
| imm[11:5] | rs2   | rs1   | 010    | imm[4:0] | 0100011 | SW       | M[rs1+imm] = rs2      |
| imm[11:5] | rs2   | rs1   | 000    | imm[4:0] | 0100011 | SB       | $M[rs1+imm]b = rs2_b$ |

□ B-type

| <del> </del>    |       |       |        |                 |         | •        |                           |
|-----------------|-------|-------|--------|-----------------|---------|----------|---------------------------|
| 31 25           | 24 20 | 19 15 | 14 12  | 11 7            | 6 0     |          |                           |
| imm[12 10:5]    | rs2   | rs1   | funct3 | imm[4:1 11]     | opcode  | Mnemonic | Description               |
| imm[12 10:5]    | rs2   | rs1   | 000    | imm[4:1 11]     | 1100011 | BEQ      | PC = (rs1 == rs2)?        |
| . ,             |       |       |        | , ,             |         |          | PC + imm: PC + 4          |
| imm[12 10:5]    | rs2   | rs1   | 001    | imm[4:1 11]     | 1100011 | BNE      | PC = (rs1 != rs2)?        |
| mm[12 10.5]     | 132   | 131   | 001    | 111111[4.1]11]  | 1100011 | DIVE     | PC + imm: PC + 4          |
| imm[12 10:5]    | rs2   | rs1   | 100    | imm[4:1 11]     | 1100011 | BLT      | $PC = (rs1_s < rs2_s)?$   |
| mm[12 10.3]     | 132   | 131   | 100    | 1111111[4.1 11] | 1100011 | BLI      | PC + imm: PC + 4          |
| imm[12 10:5]    | rs2   | rs1   | 101    | imm[4:1 11]     | 1100011 | BGE      | $PC = (rs1_s \ge rs2_s)?$ |
| 111111[12 10.3] | 182   | 181   | 101    | 111111[4.1 11]  | 1100011 | DOL      | PC + imm: PC + 4          |
| imm[12 10:5]    | rs2   | rs1   | 110    | imm[4:1 11]     | 1100011 | BLTU     | $PC = (rs1_u < rs2_u)?$   |
| 111111[12 10.5] | 182   | 181   | 110    | 111111[4.1 11]  | 1100011 | BLIC     | PC + imm: PC + 4          |
| imm[12 10:5]    | rs2   | rs1   | 111    | imm[4:1 11]     | 1100011 | BGEU     | $PC = (rs1_u \ge rs2_u)?$ |
| 111111[12 10.3] | 182   | 151   | 111    | 111111[4.1 11]  | 1100011 | DGEU     | PC + imm: PC + 4          |

U-type

| 31 12      | 11 7 | 6 0     |          |               |
|------------|------|---------|----------|---------------|
| imm[31:12] | rd   | opcode  | Mnemonic | Description   |
| imm[31:12] | rd   | 0010111 | AUIPC    | rd = PC + imm |
| imm[31:12] | rd   | 0110111 | LUI      | rd = imm      |

J-type

| 31 12                 | 11 7 | 6 0     |          |               |
|-----------------------|------|---------|----------|---------------|
| imm[20 10:1 11 19:12] | rd   | opcode  | Mnemonic | Description   |
| imm[20 10:1 11 19:12] | rd   | 1101111 | JAL      | rd = PC + 4   |
| mm[20 10.1 11 17.12]  | Tu.  | 1101111 | JAL      | PC = PC + imm |

# LPHPLAB VISIDESIGN LAB

#### **Problem 1 – SRAM**





## LPHPLAB VLSI Design LAB

#### 作業驗證說明





#### **Program**

- prog0
  - → 測試31個instruction (助教提供)
- prog1
  - Sort Algorithm
- prog2
  - Multiplication
- prog3
  - Greatest common divisor





#### **Simulation**

Table B-1: Simulation commands

| Simulation Level          | Command      |
|---------------------------|--------------|
|                           | Problem1     |
| RTL                       | make rtl_all |
| Post-synthesis (optional) | make syn_all |

Table B-2: Makefile macros

| Situation                                    | Command                 | Example          |
|----------------------------------------------|-------------------------|------------------|
| RTL simulation for progX                     | make rtlX               | make rtl0        |
| Post-synthesis simulation for progX          | make synX               | make syn1        |
| Dump waveform (no array)                     | make {rtlX,synX} FSDB=1 | make rtl2 FSDB=1 |
| Dump waveform (with array)                   | make {rtlX,synX} FSDB=2 | make syn3 FSDB=2 |
| Open nWave without file pollution            | make nWave              |                  |
| Open Superlint without file pollution        | make superlint          |                  |
| Open DesignVision without file pollution     | make dv                 |                  |
| Synthesize your RTL code (You need write     | make synthesize         |                  |
| synthesis.tcl in script folder by yourself)  | make synthesize         |                  |
| Delete built files for simulation, synthesis | make clean              |                  |
| or verification                              | make clean              |                  |
| Check correctness of your file structure     | make check              |                  |
| Compress your homework to tar format         | make tar                |                  |





### 作業繳交注意事項





#### **Testbench Structure**





#### **Module (1/2)**

□ Module name須符合下表要求

| Catagory | Name            |              |          |     |  |  |  |
|----------|-----------------|--------------|----------|-----|--|--|--|
| Category | File            | Module       | Instance | SDF |  |  |  |
| RTL      | top.sv          | top          | TOP      |     |  |  |  |
| RTL      | SRAM_wrapper.sv | SRAM_wrapper | IM1      |     |  |  |  |
| RTL      | SRAM_wrapper.sv | SRAM_wrapper | DM1      |     |  |  |  |
| RTL      | SRAM_rtl.sv     | SRAM         | i_SRAM   |     |  |  |  |

- □ 紫色部分為助教已提供或已定義好,請勿任意更 改
- □ 其餘部分需按照要求命名,以免testbench抓不到 正確的名稱





#### **Module (2/2)**

■ Module port須符合下表要求

| Module       |              | cations |      |                             |  |
|--------------|--------------|---------|------|-----------------------------|--|
|              | Name         | Signal  | Bits | Function explanation        |  |
| top          | clk          | input   | 1    | System clock                |  |
|              | rst          | input   | 1    | System reset (active high)  |  |
| 5,6          | CK           | input   | 1    | System clock                |  |
|              | CS           | input   | 1    | Chip select (active high)   |  |
|              | OE           | input   | 1    | Output enable (active high) |  |
| SRAM_wrapper | WEB          | input   | 4    | Write enable (active low)   |  |
|              | A            | input   | 14   | Address                     |  |
|              | DI           | input   | 32   | Data input                  |  |
|              | DO           | output  | 32   | Data output                 |  |
|              | Memory Space |         |      |                             |  |
|              | Memory_byte0 | logic   | 8    | Size: [16384]               |  |
| SRAM         | Memory_byte1 | logic   | 8    | Size: [16384]               |  |
|              | Memory_byte2 | logic   | 8    | Size: [16384]               |  |
|              | Memory_byte3 | logic   | 8    | Size: [16384]               |  |

- □ 紫色部分為助教已提供或已定義好,請勿任意更 改
- □ 其餘部分需按照要求命名,以免testbench抓不到 正確的名稱





- □ 請勿將code貼在.docx內
  - → 請將.sv包在壓縮檔內,不可截圖於.docx中
- □ 需要Summary及Lessons learned
- Block diagram
  - → 不必畫到gate level,除非該處的邏輯對於設計上有重要意義
  - → 可用一個矩形標上名稱以及I/O代表一個 functional block
  - → 呈現要點在於讓人較容易理解你的設計的架構
  - → 可以使用Visio、Open Office Draw,或其他繪圖軟體







- □ 驗證波形圖
  - → 保留完整訊號名稱以及訊號值
  - → 輔以文字解釋該波形圖的操作
  - → 可在波形圖加上標示輔助了解
  - → 截圖裁減至合適大小
    - v. 測試AND的功能。當enable\_execute為1時,表示alu開始做運算,opcode 為100000,sub\_opcode為00010,動作為AND。↓

```
scr1=32'b1100_0101_1010_1111_1000_0101_1010_1001 ,
```

scr2=32'b1111\_1010\_0101\_0000\_1110\_0101\_1010\_1111 ,

结果為=32'b1100\_0000\_0000\_0000\_1000\_0101\_1010\_1001。↓





#### 繳交檔案

- □ 依照檔案結構壓縮成 ".tar" 格式
  - → 在Homework主資料夾(N260XXXXX)使用make tar產生的tar檔即可符合要求
- □ 檔案結構請依照作業說明
- □ 請勿附上檔案結構內未要求繳交的檔案
  - → 在Homework主資料夾(N260XXXXX)使用make clean即可刪除不必要的檔案
- □ 請務必確認繳交檔案可以在SoC實驗室的工作站下compile,且功能正常
- □ 無法compile將直接以0分計算
- □ 請勿使用generator產生code再修改
- □ 禁止抄襲



#### 檔案結構 (1/2)

- □ N260XXXXX.docx
  - Your report file
- □ src
  - → Your source code (\*.sv)
- □ include
  - → Your definition code (\*.svh)
- StudentID
  - Specify your Student ID number
- sim/CYCLE
  - Specify your clock cycle time
- sim/MAX
  - Specify max clock cycle number







#### 檔案結構 (2/2)

- sim/prog0
  - Don't modify contents
- sim/progX (X ≠ 0)
  - main.S
  - main.c
    - Submit one of these

- ☐ SRAM (SRAM libraries and behavior models)
   ☐ Library files (\*.lib, \*.db, \*.lef or \*.gds)
   ☐ SRAM.ds (SRAM datasheet)
   ☐ SRAM\_rtl.sv (SRAM RTL model)
   ☐ SRAM.v (SRAM behavior model)
- prog0 (Subfolder for Program 0)
  - Makefile (Compile and generate memory content)
  - main.S (Assembly code for verification)
  - **setup.** *S* (Assembly code for testing environment setup)
  - link.ld (Linker script for testing environment)
  - **golden.hex** (Golden hexadecimal data)
- prog1 (Subfolder for Program 1)
  - Makefile (Compile and generate memory content)
  - main.S \* (Assembly code for verification)
  - $\blacksquare$  *main.c* \* (C code for verification)
  - data.S (Assembly code for testing data)
  - setup.S (Assembly code for testing environment setup)
  - link.ld (Linker script for testing environment)
  - golden.hex (Golden hexadecimal data)
- prog2 (Subfolder for Program 2)
  - Makefile (Compile and generate memory content)
  - main.S \* (Assembly code for verification)
  - main.c \* (C code for verification)
  - data.S (Assembly code for testing data)
  - setup.S (Assembly code for testing environment setup)
  - link.ld (Linker script for testing environment)
  - **golden.hex** (Golden hexadecimal data)
- prog3 (Subfolder for Program 3)
  - Makefile (Compile and generate memory content)
  - main.S \* (Assembly code for verification)
  - $\blacksquare$  *main.c* \* (C code for verification)
  - data.S (Assembly code for testing data)
  - setup.S (Assembly code for testing environment setup)
  - *link.ld* (Linker script for testing environment)
  - **golden.hex** (Golden hexadecimal data)





#### 繳交期限

- □ 2020/10/14 (三) 14:00前上傳
  - → 不接受遲交,請務必注意時間
  - → Moodle只會留存你最後一次上傳的檔案,檔名只要是「N260XXXXX.tar」即可,不需要加上版本號
- □ 作業二預計在2020/10/7 (三)會上傳,請務必加快作業一的設計時間,以免壓縮到作業二的時間





## Thanks for your participation and attendance!!



